blob: 3779f9d782addf9bb583a4998b65a36ae1b137bf [file] [log] [blame]
Carmelo Cascone54fb90e2017-08-31 21:07:25 +02001BMV2_CPU_PORT=255
Carmelo Cascone5db39682017-09-07 16:36:42 +02002MAVERICKS_CPU_PORT=320
3MONTARA_CPU_PORT=192
Carmelo Casconeb7524272017-06-05 16:53:13 -04004
Carmelo Cascone5db39682017-09-07 16:36:42 +02005MAVERICKS_OPTIONS=-DCPU_PORT=$(MAVERICKS_CPU_PORT)
6MONTARA_OPTIONS=-DCPU_PORT=$(MONTARA_CPU_PORT)
Carmelo Cascone54fb90e2017-08-31 21:07:25 +02007BMV2_OPTIONS=-DDO_BMV2_BUILD -DCPU_PORT=$(BMV2_CPU_PORT)
8
9all: bmv2
10
11bmv2: default-bmv2 empty-bmv2 ecmp-bmv2 wcmp-bmv2
12
13default-bmv2: default.p4
14 p4c-bm2-ss $(BMV2_OPTIONS) --p4v 14 -o p4c-out/default.json \
Carmelo Casconeb7524272017-06-05 16:53:13 -040015 --p4runtime-file p4c-out/default.p4info --p4runtime-format text \
16 default.p4
17
Carmelo Cascone5db39682017-09-07 16:36:42 +020018default-tofino: default.p4
19 p4c-tofino --verbose 2 --new_ctx_json -o p4c-out/tofino/default/mavericks $(MAVERICKS_OPTIONS) default.p4
20 p4c-tofino --verbose 2 --new_ctx_json -o p4c-out/tofino/default/montara $(MONTARA_OPTIONS) default.p4
21 cp p4c-out/default.json p4c-out/tofino/default/mavericks
22 cp p4c-out/default.json p4c-out/tofino/default/montara
23 cp p4c-out/default.p4info p4c-out/tofino/default/mavericks
24 cp p4c-out/default.p4info p4c-out/tofino/default/montara
25 sed -i -e 's/standard_metadata/ig_intr_md/g' p4c-out/tofino/default/mavericks/default.json
26 sed -i -e 's/standard_metadata/ig_intr_md/g' p4c-out/tofino/default/montara/default.json
27 sed -i -e 's/standard_metadata/ig_intr_md/g' p4c-out/tofino/default/mavericks/default.p4info
28 sed -i -e 's/standard_metadata/ig_intr_md/g' p4c-out/tofino/default/montara/default.p4info
29
Carmelo Cascone54fb90e2017-08-31 21:07:25 +020030empty-bmv2: empty.p4
Carmelo Casconeb7524272017-06-05 16:53:13 -040031 p4c-bm2-ss --p4v 14 -o p4c-out/empty.json \
32 --p4runtime-file p4c-out/empty.p4info --p4runtime-format text \
33 empty.p4
34
Carmelo Cascone54fb90e2017-08-31 21:07:25 +020035ecmp-bmv2: ecmp.p4
36 p4c-bm2-ss $(BMV2_OPTIONS) --p4v 14 -o p4c-out/ecmp.json \
Carmelo Casconefc3776d2017-08-21 23:17:22 +020037 --p4runtime-file p4c-out/ecmp.p4info --p4runtime-format text \
Carmelo Casconeb7524272017-06-05 16:53:13 -040038 ecmp.p4
39
Carmelo Cascone54fb90e2017-08-31 21:07:25 +020040wcmp-bmv2: wcmp.p4
41 p4c-bm2-ss $(BMV2_OPTIONS) --p4v 14 -o p4c-out/wcmp.json \
Carmelo Cascone16de6db2017-08-22 00:27:57 +020042 --p4runtime-file p4c-out/wcmp.p4info --p4runtime-format text \
Carmelo Casconeb7524272017-06-05 16:53:13 -040043 wcmp.p4
44
45clean:
46 rm -rf p4c-out/*.json
Carmelo Cascone5db39682017-09-07 16:36:42 +020047 rm -rf p4c-out/*.p4info