blob: dfb2b041fbd477dbb4bcef8a8132f1fdded66b23 [file] [log] [blame]
{
"header_types" : [
{
"name" : "scalars_0",
"id" : 0,
"fields" : [
["tmp", 4, false],
["tmp_0", 1, false],
["tmp_1", 1, false],
["tmp_2", 32, false],
["tmp_3", 32, false],
["tmp_4", 32, false],
["filtering_tmp_0", 1, false],
["next_tmp_2", 1, false],
["next_tmp_3", 1, false],
["next_tmp_4", 1, false],
["next_hasReturned_0", 1, false],
["fabric_metadata_t.fwd_type", 3, false],
["fabric_metadata_t.next_id", 32, false],
["fabric_metadata_t.pop_vlan_when_packet_in", 1, false],
["fabric_metadata_t.is_multicast", 1, false],
["fabric_metadata_t.clone_to_cpu", 1, false],
["fabric_metadata_t.ip_proto", 8, false],
["fabric_metadata_t.l4_src_port", 16, false],
["fabric_metadata_t.l4_dst_port", 16, false],
["fabric_metadata_t.compute_checksum", 1, false],
["_padding_1", 6, false]
]
},
{
"name" : "standard_metadata",
"id" : 1,
"fields" : [
["ingress_port", 9, false],
["egress_spec", 9, false],
["egress_port", 9, false],
["clone_spec", 32, false],
["instance_type", 32, false],
["drop", 1, false],
["recirculate_port", 16, false],
["packet_length", 32, false],
["enq_timestamp", 32, false],
["enq_qdepth", 19, false],
["deq_timedelta", 32, false],
["deq_qdepth", 19, false],
["ingress_global_timestamp", 48, false],
["egress_global_timestamp", 48, false],
["lf_field_list", 32, false],
["mcast_grp", 16, false],
["resubmit_flag", 32, false],
["egress_rid", 16, false],
["checksum_error", 1, false],
["recirculate_flag", 32, false],
["_padding", 5, false]
]
},
{
"name" : "ethernet_t",
"id" : 2,
"fields" : [
["dst_addr", 48, false],
["src_addr", 48, false],
["ether_type", 16, false]
]
},
{
"name" : "vlan_tag_t",
"id" : 3,
"fields" : [
["pri", 3, false],
["cfi", 1, false],
["vlan_id", 12, false],
["ether_type", 16, false]
]
},
{
"name" : "mpls_t",
"id" : 4,
"fields" : [
["label", 20, false],
["tc", 3, false],
["bos", 1, false],
["ttl", 8, false]
]
},
{
"name" : "ipv4_t",
"id" : 5,
"fields" : [
["version", 4, false],
["ihl", 4, false],
["dscp", 6, false],
["ecn", 2, false],
["total_len", 16, false],
["identification", 16, false],
["flags", 3, false],
["frag_offset", 13, false],
["ttl", 8, false],
["protocol", 8, false],
["hdr_checksum", 16, false],
["src_addr", 32, false],
["dst_addr", 32, false]
]
},
{
"name" : "arp_t",
"id" : 6,
"fields" : [
["hw_type", 16, false],
["proto_type", 16, false],
["hw_addr_len", 8, false],
["proto_addr_len", 8, false],
["opcode", 16, false]
]
},
{
"name" : "tcp_t",
"id" : 7,
"fields" : [
["src_port", 16, false],
["dst_port", 16, false],
["seq_no", 32, false],
["ack_no", 32, false],
["data_offset", 4, false],
["res", 3, false],
["ecn", 3, false],
["ctrl", 6, false],
["window", 16, false],
["checksum", 16, false],
["urgent_ptr", 16, false]
]
},
{
"name" : "udp_t",
"id" : 8,
"fields" : [
["src_port", 16, false],
["dst_port", 16, false],
["len", 16, false],
["checksum", 16, false]
]
},
{
"name" : "icmp_t",
"id" : 9,
"fields" : [
["icmp_type", 8, false],
["icmp_code", 8, false],
["checksum", 16, false],
["identifier", 16, false],
["sequence_number", 16, false],
["timestamp", 64, false]
]
},
{
"name" : "packet_out_header_t",
"id" : 10,
"fields" : [
["egress_port", 9, false],
["_pad", 7, false]
]
},
{
"name" : "packet_in_header_t",
"id" : 11,
"fields" : [
["ingress_port", 9, false],
["_pad", 7, false]
]
},
{
"name" : "report_fixed_header_t",
"id" : 12,
"fields" : [
["ver", 4, false],
["nproto", 4, false],
["d", 1, false],
["q", 1, false],
["f", 1, false],
["rsvd", 15, false],
["hw_id", 6, false],
["seq_no", 32, false],
["ingress_tstamp", 32, false]
]
},
{
"name" : "drop_report_header_t",
"id" : 13,
"fields" : [
["switch_id", 32, false],
["ingress_port_id", 16, false],
["egress_port_id", 16, false],
["queue_id", 8, false],
["drop_reason", 8, false],
["pad", 16, false]
]
},
{
"name" : "local_report_header_t",
"id" : 14,
"fields" : [
["switch_id", 32, false],
["ingress_port_id", 16, false],
["egress_port_id", 16, false],
["queue_id", 8, false],
["queue_occupancy", 24, false],
["egress_tstamp", 32, false]
]
},
{
"name" : "intl4_shim_t",
"id" : 15,
"fields" : [
["int_type", 8, false],
["rsvd1", 8, false],
["len", 8, false],
["rsvd2", 8, false]
]
},
{
"name" : "int_header_t",
"id" : 16,
"fields" : [
["ver", 2, false],
["rep", 2, false],
["c", 1, false],
["e", 1, false],
["rsvd1", 5, false],
["ins_cnt", 5, false],
["max_hop_cnt", 8, false],
["total_hop_cnt", 8, false],
["instruction_mask_0003", 4, false],
["instruction_mask_0407", 4, false],
["instruction_mask_0811", 4, false],
["instruction_mask_1215", 4, false],
["rsvd2", 16, false]
]
},
{
"name" : "int_data_t",
"id" : 17,
"fields" : [
["data", "*"]
],
"max_length" : 1004
},
{
"name" : "int_switch_id_t",
"id" : 18,
"fields" : [
["switch_id", 32, false]
]
},
{
"name" : "int_port_ids_t",
"id" : 19,
"fields" : [
["ingress_port_id", 16, false],
["egress_port_id", 16, false]
]
},
{
"name" : "int_hop_latency_t",
"id" : 20,
"fields" : [
["hop_latency", 32, false]
]
},
{
"name" : "int_q_occupancy_t",
"id" : 21,
"fields" : [
["q_id", 8, false],
["q_occupancy", 24, false]
]
},
{
"name" : "int_ingress_tstamp_t",
"id" : 22,
"fields" : [
["ingress_tstamp", 32, false]
]
},
{
"name" : "int_egress_tstamp_t",
"id" : 23,
"fields" : [
["egress_tstamp", 32, false]
]
},
{
"name" : "int_q_congestion_t",
"id" : 24,
"fields" : [
["q_id", 8, false],
["q_congestion", 24, false]
]
},
{
"name" : "int_egress_port_tx_util_t",
"id" : 25,
"fields" : [
["egress_port_tx_util", 32, false]
]
},
{
"name" : "intl4_tail_t",
"id" : 26,
"fields" : [
["next_proto", 8, false],
["dest_port", 16, false],
["dscp", 8, false]
]
},
{
"name" : "int_metadata_t",
"id" : 27,
"fields" : [
["switch_id", 32, false],
["insert_byte_cnt", 16, false],
["source", 1, false],
["sink", 1, false],
["mirror_id", 8, false],
["flow_id", 16, false],
["metadata_len", 8, false],
["_padding_0", 6, false]
]
}
],
"headers" : [
{
"name" : "scalars",
"id" : 0,
"header_type" : "scalars_0",
"metadata" : true,
"pi_omit" : true
},
{
"name" : "standard_metadata",
"id" : 1,
"header_type" : "standard_metadata",
"metadata" : true,
"pi_omit" : true
},
{
"name" : "ethernet",
"id" : 2,
"header_type" : "ethernet_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "vlan_tag",
"id" : 3,
"header_type" : "vlan_tag_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "mpls",
"id" : 4,
"header_type" : "mpls_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "ipv4",
"id" : 5,
"header_type" : "ipv4_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "arp",
"id" : 6,
"header_type" : "arp_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "tcp",
"id" : 7,
"header_type" : "tcp_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "udp",
"id" : 8,
"header_type" : "udp_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "icmp",
"id" : 9,
"header_type" : "icmp_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "packet_out",
"id" : 10,
"header_type" : "packet_out_header_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "packet_in",
"id" : 11,
"header_type" : "packet_in_header_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "report_ethernet",
"id" : 12,
"header_type" : "ethernet_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "report_ipv4",
"id" : 13,
"header_type" : "ipv4_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "report_udp",
"id" : 14,
"header_type" : "udp_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "report_fixed_header",
"id" : 15,
"header_type" : "report_fixed_header_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "report_local.drop_report_header",
"id" : 16,
"header_type" : "drop_report_header_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "report_local.local_report_header",
"id" : 17,
"header_type" : "local_report_header_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "intl4_shim",
"id" : 18,
"header_type" : "intl4_shim_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_header",
"id" : 19,
"header_type" : "int_header_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_data",
"id" : 20,
"header_type" : "int_data_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_switch_id",
"id" : 21,
"header_type" : "int_switch_id_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_port_ids",
"id" : 22,
"header_type" : "int_port_ids_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_hop_latency",
"id" : 23,
"header_type" : "int_hop_latency_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_q_occupancy",
"id" : 24,
"header_type" : "int_q_occupancy_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_ingress_tstamp",
"id" : 25,
"header_type" : "int_ingress_tstamp_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_egress_tstamp",
"id" : 26,
"header_type" : "int_egress_tstamp_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_q_congestion",
"id" : 27,
"header_type" : "int_q_congestion_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "int_egress_tx_util",
"id" : 28,
"header_type" : "int_egress_port_tx_util_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "intl4_tail",
"id" : 29,
"header_type" : "intl4_tail_t",
"metadata" : false,
"pi_omit" : true
},
{
"name" : "userMetadata.int_meta",
"id" : 30,
"header_type" : "int_metadata_t",
"metadata" : true,
"pi_omit" : true
}
],
"header_stacks" : [],
"header_union_types" : [
{
"name" : "local_report_t",
"id" : 0,
"headers" : [
["drop_report_header", "drop_report_header_t"],
["local_report_header", "local_report_header_t"]
]
}
],
"header_unions" : [
{
"name" : "report_local",
"id" : 0,
"union_type" : "local_report_t",
"header_ids" : [16, 17],
"pi_omit" : true
}
],
"header_union_stacks" : [],
"field_lists" : [
{
"id" : 1,
"name" : "fl",
"elements" : []
}
],
"errors" : [],
"enums" : [],
"parsers" : [
{
"name" : "parser",
"id" : 0,
"init_state" : "start",
"parse_states" : [
{
"name" : "start",
"id" : 0,
"parser_ops" : [],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x00ff",
"mask" : null,
"next_state" : "parse_packet_out"
},
{
"value" : "default",
"mask" : null,
"next_state" : "parse_ethernet"
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
}
]
},
{
"name" : "parse_packet_out",
"id" : 1,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "packet_out"
}
],
"op" : "extract"
}
],
"transitions" : [
{
"value" : "default",
"mask" : null,
"next_state" : "parse_ethernet"
}
],
"transition_key" : []
},
{
"name" : "parse_ethernet",
"id" : 2,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "ethernet"
}
],
"op" : "extract"
}
],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x8100",
"mask" : null,
"next_state" : "parse_vlan_tag"
},
{
"type" : "hexstr",
"value" : "0x8847",
"mask" : null,
"next_state" : "parse_mpls"
},
{
"type" : "hexstr",
"value" : "0x0806",
"mask" : null,
"next_state" : "parse_arp"
},
{
"type" : "hexstr",
"value" : "0x0800",
"mask" : null,
"next_state" : "parse_ipv4"
},
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["ethernet", "ether_type"]
}
]
},
{
"name" : "parse_vlan_tag",
"id" : 3,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "vlan_tag"
}
],
"op" : "extract"
}
],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x0806",
"mask" : null,
"next_state" : "parse_arp"
},
{
"type" : "hexstr",
"value" : "0x0800",
"mask" : null,
"next_state" : "parse_ipv4"
},
{
"type" : "hexstr",
"value" : "0x8847",
"mask" : null,
"next_state" : "parse_mpls"
},
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
}
]
},
{
"name" : "parse_mpls",
"id" : 4,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "mpls"
}
],
"op" : "extract"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "tmp"]
},
{
"type" : "lookahead",
"value" : [0, 4]
}
],
"op" : "set"
}
],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x04",
"mask" : null,
"next_state" : "parse_ipv4"
},
{
"value" : "default",
"mask" : null,
"next_state" : "parse_ethernet"
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["scalars", "tmp"]
}
]
},
{
"name" : "parse_ipv4",
"id" : 5,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "ipv4"
}
],
"op" : "extract"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.ip_proto"]
},
{
"type" : "field",
"value" : ["ipv4", "protocol"]
}
],
"op" : "set"
}
],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x06",
"mask" : null,
"next_state" : "parse_tcp"
},
{
"type" : "hexstr",
"value" : "0x11",
"mask" : null,
"next_state" : "parse_udp"
},
{
"type" : "hexstr",
"value" : "0x01",
"mask" : null,
"next_state" : "parse_icmp"
},
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["ipv4", "protocol"]
}
]
},
{
"name" : "parse_arp",
"id" : 6,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "arp"
}
],
"op" : "extract"
}
],
"transitions" : [
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : []
},
{
"name" : "parse_tcp",
"id" : 7,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "tcp"
}
],
"op" : "extract"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.l4_src_port"]
},
{
"type" : "field",
"value" : ["tcp", "src_port"]
}
],
"op" : "set"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.l4_dst_port"]
},
{
"type" : "field",
"value" : ["tcp", "dst_port"]
}
],
"op" : "set"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "tmp_0"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "?",
"left" : {
"type" : "hexstr",
"value" : "0x01"
},
"right" : {
"type" : "hexstr",
"value" : "0x00"
},
"cond" : {
"type" : "expression",
"value" : {
"op" : "and",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["ipv4", "$valid$"]
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["ipv4", "dscp"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
}
}
}
}
}
}
],
"op" : "set"
}
],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x01",
"mask" : null,
"next_state" : "parse_intl4_shim"
},
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["scalars", "tmp_0"]
}
]
},
{
"name" : "parse_udp",
"id" : 8,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "udp"
}
],
"op" : "extract"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.l4_src_port"]
},
{
"type" : "field",
"value" : ["udp", "src_port"]
}
],
"op" : "set"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.l4_dst_port"]
},
{
"type" : "field",
"value" : ["udp", "dst_port"]
}
],
"op" : "set"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "tmp_1"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "?",
"left" : {
"type" : "hexstr",
"value" : "0x01"
},
"right" : {
"type" : "hexstr",
"value" : "0x00"
},
"cond" : {
"type" : "expression",
"value" : {
"op" : "and",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["ipv4", "$valid$"]
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["ipv4", "dscp"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
}
}
}
}
}
}
],
"op" : "set"
}
],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x01",
"mask" : null,
"next_state" : "parse_intl4_shim"
},
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["scalars", "tmp_1"]
}
]
},
{
"name" : "parse_icmp",
"id" : 9,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "icmp"
}
],
"op" : "extract"
}
],
"transitions" : [
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : []
},
{
"name" : "parse_intl4_shim",
"id" : 10,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "intl4_shim"
}
],
"op" : "extract"
},
{
"parameters" : [
{
"type" : "regular",
"value" : "int_header"
}
],
"op" : "extract"
},
{
"parameters" : [
{
"type" : "field",
"value" : ["userMetadata.int_meta", "metadata_len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["intl4_shim", "len"]
},
"right" : {
"type" : "hexstr",
"value" : "0xfc"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
}
}
],
"op" : "set"
}
],
"transitions" : [
{
"type" : "hexstr",
"value" : "0x00",
"mask" : null,
"next_state" : "parse_intl4_tail"
},
{
"value" : "default",
"mask" : null,
"next_state" : "parse_int_data"
}
],
"transition_key" : [
{
"type" : "field",
"value" : ["userMetadata.int_meta", "metadata_len"]
}
]
},
{
"name" : "parse_int_data",
"id" : 11,
"parser_ops" : [
{
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "tmp_2"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "<<",
"left" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["intl4_shim", "len"]
},
"right" : {
"type" : "hexstr",
"value" : "0xfc"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0x5"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"op" : "set"
},
{
"parameters" : [
{
"type" : "regular",
"value" : "int_data"
},
{
"type" : "expression",
"value" : {
"type" : "field",
"value" : ["scalars", "tmp_2"]
}
}
],
"op" : "extract_VL"
}
],
"transitions" : [
{
"value" : "default",
"mask" : null,
"next_state" : "parse_intl4_tail"
}
],
"transition_key" : []
},
{
"name" : "parse_intl4_tail",
"id" : 12,
"parser_ops" : [
{
"parameters" : [
{
"type" : "regular",
"value" : "intl4_tail"
}
],
"op" : "extract"
}
],
"transitions" : [
{
"value" : "default",
"mask" : null,
"next_state" : null
}
],
"transition_key" : []
}
]
}
],
"parse_vsets" : [],
"deparsers" : [
{
"name" : "deparser",
"id" : 0,
"source_info" : {
"filename" : "include/parser.p4",
"line" : 223,
"column" : 8,
"source_fragment" : "FabricDeparser"
},
"order" : ["packet_in", "report_ethernet", "report_ipv4", "report_udp", "report_fixed_header", "ethernet", "vlan_tag", "mpls", "arp", "ipv4", "tcp", "udp", "icmp", "intl4_shim", "int_header", "int_switch_id", "int_port_ids", "int_hop_latency", "int_q_occupancy", "int_ingress_tstamp", "int_egress_tstamp", "int_q_congestion", "int_egress_tx_util", "int_data", "intl4_tail"]
}
],
"meter_arrays" : [],
"counter_arrays" : [
{
"name" : "FabricIngress.process_set_source_sink.counter_set_source",
"id" : 0,
"is_direct" : true,
"binding" : "FabricIngress.process_set_source_sink.tb_set_source"
},
{
"name" : "FabricIngress.process_set_source_sink.counter_set_sink",
"id" : 1,
"is_direct" : true,
"binding" : "FabricIngress.process_set_source_sink.tb_set_sink"
},
{
"name" : "FabricIngress.filtering.ingress_port_vlan_counter",
"id" : 2,
"is_direct" : true,
"binding" : "FabricIngress.filtering.ingress_port_vlan"
},
{
"name" : "FabricIngress.filtering.fwd_classifier_counter",
"id" : 3,
"is_direct" : true,
"binding" : "FabricIngress.filtering.fwd_classifier"
},
{
"name" : "FabricIngress.forwarding.bridging_counter",
"id" : 4,
"is_direct" : true,
"binding" : "FabricIngress.forwarding.bridging"
},
{
"name" : "FabricIngress.forwarding.mpls_counter",
"id" : 5,
"is_direct" : true,
"binding" : "FabricIngress.forwarding.mpls"
},
{
"name" : "FabricIngress.forwarding.unicast_v4_counter",
"id" : 6,
"is_direct" : true,
"binding" : "FabricIngress.forwarding.unicast_v4"
},
{
"name" : "FabricIngress.forwarding.acl_counter",
"id" : 7,
"is_direct" : true,
"binding" : "FabricIngress.forwarding.acl"
},
{
"name" : "FabricIngress.next.vlan_meta_counter",
"id" : 8,
"is_direct" : true,
"binding" : "FabricIngress.next.vlan_meta"
},
{
"name" : "FabricIngress.next.simple_counter",
"id" : 9,
"is_direct" : true,
"binding" : "FabricIngress.next.simple"
},
{
"name" : "FabricIngress.next.hashed_counter",
"id" : 10,
"is_direct" : true,
"binding" : "FabricIngress.next.hashed"
},
{
"name" : "FabricIngress.next.multicast_counter",
"id" : 11,
"is_direct" : true,
"binding" : "FabricIngress.next.multicast"
},
{
"name" : "FabricIngress.port_counters_control.egress_port_counter",
"id" : 12,
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 23,
"column" : 48,
"source_fragment" : "egress_port_counter"
},
"size" : 511,
"is_direct" : false
},
{
"name" : "FabricIngress.port_counters_control.ingress_port_counter",
"id" : 13,
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 24,
"column" : 48,
"source_fragment" : "ingress_port_counter"
},
"size" : 511,
"is_direct" : false
},
{
"name" : "FabricEgress.process_int_source.counter_int_source",
"id" : 14,
"is_direct" : true,
"binding" : "FabricEgress.process_int_source.tb_int_source"
},
{
"name" : "FabricEgress.process_int_transit.counter_int_insert",
"id" : 15,
"is_direct" : true,
"binding" : "FabricEgress.process_int_transit.tb_int_insert"
},
{
"name" : "FabricEgress.process_int_transit.counter_int_inst_0003",
"id" : 16,
"is_direct" : true,
"binding" : "FabricEgress.process_int_transit.tb_int_inst_0003"
},
{
"name" : "FabricEgress.process_int_transit.counter_int_inst_0407",
"id" : 17,
"is_direct" : true,
"binding" : "FabricEgress.process_int_transit.tb_int_inst_0407"
},
{
"name" : "FabricEgress.egress_next.egress_vlan_counter",
"id" : 18,
"is_direct" : true,
"binding" : "FabricEgress.egress_next.egress_vlan"
}
],
"register_arrays" : [],
"calculations" : [
{
"name" : "calc",
"id" : 0,
"source_info" : {
"filename" : "include/checksum.p4",
"line" : 28,
"column" : 8,
"source_fragment" : "update_checksum(hdr.ipv4.isValid(), ..."
},
"algo" : "csum16",
"input" : [
{
"type" : "field",
"value" : ["ipv4", "version"]
},
{
"type" : "field",
"value" : ["ipv4", "ihl"]
},
{
"type" : "field",
"value" : ["ipv4", "dscp"]
},
{
"type" : "field",
"value" : ["ipv4", "ecn"]
},
{
"type" : "field",
"value" : ["ipv4", "total_len"]
},
{
"type" : "field",
"value" : ["ipv4", "identification"]
},
{
"type" : "field",
"value" : ["ipv4", "flags"]
},
{
"type" : "field",
"value" : ["ipv4", "frag_offset"]
},
{
"type" : "field",
"value" : ["ipv4", "ttl"]
},
{
"type" : "field",
"value" : ["ipv4", "protocol"]
},
{
"type" : "field",
"value" : ["ipv4", "src_addr"]
},
{
"type" : "field",
"value" : ["ipv4", "dst_addr"]
}
]
},
{
"name" : "calc_0",
"id" : 1,
"source_info" : {
"filename" : "include/checksum.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "verify_checksum(hdr.ipv4.isValid(), ..."
},
"algo" : "csum16",
"input" : [
{
"type" : "field",
"value" : ["ipv4", "version"]
},
{
"type" : "field",
"value" : ["ipv4", "ihl"]
},
{
"type" : "field",
"value" : ["ipv4", "dscp"]
},
{
"type" : "field",
"value" : ["ipv4", "ecn"]
},
{
"type" : "field",
"value" : ["ipv4", "total_len"]
},
{
"type" : "field",
"value" : ["ipv4", "identification"]
},
{
"type" : "field",
"value" : ["ipv4", "flags"]
},
{
"type" : "field",
"value" : ["ipv4", "frag_offset"]
},
{
"type" : "field",
"value" : ["ipv4", "ttl"]
},
{
"type" : "field",
"value" : ["ipv4", "protocol"]
},
{
"type" : "field",
"value" : ["ipv4", "src_addr"]
},
{
"type" : "field",
"value" : ["ipv4", "dst_addr"]
}
]
}
],
"learn_lists" : [],
"actions" : [
{
"name" : "NoAction",
"id" : 0,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 1,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 2,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 3,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 4,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 5,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 6,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 7,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "nop",
"id" : 8,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "FabricIngress.process_set_source_sink.int_set_source",
"id" : 9,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["userMetadata.int_meta", "source"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 94,
"column" : 8,
"source_fragment" : "fabric_metadata.int_meta.source = 1"
}
}
]
},
{
"name" : "FabricIngress.process_set_source_sink.int_set_sink",
"id" : 10,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["userMetadata.int_meta", "sink"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 98,
"column" : 8,
"source_fragment" : "fabric_metadata.int_meta.sink = 1"
}
}
]
},
{
"name" : "FabricIngress.filtering.drop",
"id" : 11,
"runtime_data" : [],
"primitives" : [
{
"op" : "drop",
"parameters" : [],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "mark_to_drop()"
}
}
]
},
{
"name" : "FabricIngress.filtering.set_vlan",
"id" : 12,
"runtime_data" : [
{
"name" : "new_vlan_id",
"bitwidth" : 12
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "vlan_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 42,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.vlan_id = new_vlan_id"
}
}
]
},
{
"name" : "FabricIngress.filtering.push_internal_vlan",
"id" : 13,
"runtime_data" : [
{
"name" : "new_vlan_id",
"bitwidth" : 12
}
],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "vlan_tag"
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 49,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "cfi"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 50,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.cfi = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "pri"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.pri = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
},
{
"type" : "field",
"value" : ["ethernet", "ether_type"]
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.ether_type = hdr.ethernet.ether_type"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "ether_type"]
},
{
"type" : "hexstr",
"value" : "0x8100"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 89,
"column" : 31,
"source_fragment" : "0x8100; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "vlan_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 54,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.vlan_id = new_vlan_id"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.pop_vlan_when_packet_in"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "fabric_metadata.pop_vlan_when_packet_in = true"
}
}
]
},
{
"name" : "FabricIngress.filtering.nop_ingress_port_vlan",
"id" : 14,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "FabricIngress.filtering.set_forwarding_type",
"id" : 15,
"runtime_data" : [
{
"name" : "fwd_type",
"bitwidth" : 3
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.fwd_type"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 99,
"column" : 8,
"source_fragment" : "fabric_metadata.fwd_type = fwd_type"
}
}
]
},
{
"name" : "FabricIngress.forwarding.set_next_id_bridging",
"id" : 16,
"runtime_data" : [
{
"name" : "next_id",
"bitwidth" : 32
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.next_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "fabric_metadata.next_id = next_id"
}
}
]
},
{
"name" : "FabricIngress.forwarding.pop_mpls_and_next",
"id" : 17,
"runtime_data" : [
{
"name" : "next_id",
"bitwidth" : 32
}
],
"primitives" : [
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "mpls"
}
],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 60,
"column" : 8,
"source_fragment" : "hdr.mpls.setInvalid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.next_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "fabric_metadata.next_id = next_id"
}
}
]
},
{
"name" : "FabricIngress.forwarding.set_next_id_unicast_v4",
"id" : 18,
"runtime_data" : [
{
"name" : "next_id",
"bitwidth" : 32
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.next_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 83,
"column" : 8,
"source_fragment" : "fabric_metadata.next_id = next_id"
}
}
]
},
{
"name" : "FabricIngress.forwarding.set_next_id_acl",
"id" : 19,
"runtime_data" : [
{
"name" : "next_id",
"bitwidth" : 32
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.next_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 105,
"column" : 8,
"source_fragment" : "fabric_metadata.next_id = next_id"
}
}
]
},
{
"name" : "FabricIngress.forwarding.punt_to_cpu",
"id" : 20,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "hexstr",
"value" : "0x00ff"
}
],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 111,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = 255"
}
},
{
"op" : "exit",
"parameters" : [],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 113,
"column" : 8,
"source_fragment" : "exit"
}
}
]
},
{
"name" : "FabricIngress.forwarding.clone_to_cpu",
"id" : 21,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.clone_to_cpu"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 118,
"column" : 8,
"source_fragment" : "fabric_metadata.clone_to_cpu = true"
}
}
]
},
{
"name" : "FabricIngress.forwarding.drop",
"id" : 22,
"runtime_data" : [],
"primitives" : [
{
"op" : "drop",
"parameters" : [],
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 123,
"column" : 8,
"source_fragment" : "mark_to_drop()"
}
}
]
},
{
"name" : "FabricIngress.forwarding.nop_acl",
"id" : 23,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "FabricIngress.next.set_vlan",
"id" : 24,
"runtime_data" : [
{
"name" : "new_vlan_id",
"bitwidth" : 12
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "vlan_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.vlan_id = new_vlan_id"
}
}
]
},
{
"name" : "FabricIngress.next.output_simple",
"id" : 25,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 85,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num"
}
}
]
},
{
"name" : "FabricIngress.next.set_vlan_output",
"id" : 26,
"runtime_data" : [
{
"name" : "new_vlan_id",
"bitwidth" : 12
},
{
"name" : "port_num",
"bitwidth" : 9
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "vlan_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 90,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.vlan_id = new_vlan_id"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 85,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
}
]
},
{
"name" : "FabricIngress.next.l3_routing_simple",
"id" : 27,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
},
{
"name" : "smac",
"bitwidth" : 48
},
{
"name" : "dmac",
"bitwidth" : 48
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.ethernet.src_addr = smac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.ethernet.dst_addr = dmac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 85,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
}
]
},
{
"name" : "FabricIngress.next.mpls_routing_v4_simple",
"id" : 28,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
},
{
"name" : "smac",
"bitwidth" : 48
},
{
"name" : "dmac",
"bitwidth" : 48
},
{
"name" : "label",
"bitwidth" : 20
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.ethernet.src_addr = smac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.ethernet.dst_addr = dmac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 85,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "mpls"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 46,
"column" : 8,
"source_fragment" : "hdr.mpls.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
},
{
"type" : "hexstr",
"value" : "0x8847"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 90,
"column" : 31,
"source_fragment" : "0x8847; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "label"]
},
{
"type" : "runtime_data",
"value" : 3
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 48,
"column" : 8,
"source_fragment" : "hdr.mpls.label = label; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "tc"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 49,
"column" : 8,
"source_fragment" : "hdr.mpls.tc = tc; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "bos"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 50,
"column" : 8,
"source_fragment" : "hdr.mpls.bos = 1w1"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "ttl"]
},
{
"type" : "hexstr",
"value" : "0x40"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 113,
"column" : 32,
"source_fragment" : "64; ..."
}
}
]
},
{
"name" : "FabricIngress.next.mpls_routing_v6_simple",
"id" : 29,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
},
{
"name" : "smac",
"bitwidth" : 48
},
{
"name" : "dmac",
"bitwidth" : 48
},
{
"name" : "label",
"bitwidth" : 20
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.ethernet.src_addr = smac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.ethernet.dst_addr = dmac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 85,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "mpls"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 46,
"column" : 8,
"source_fragment" : "hdr.mpls.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
},
{
"type" : "hexstr",
"value" : "0x8847"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 90,
"column" : 31,
"source_fragment" : "0x8847; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "label"]
},
{
"type" : "runtime_data",
"value" : 3
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 48,
"column" : 8,
"source_fragment" : "hdr.mpls.label = label; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "tc"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 49,
"column" : 8,
"source_fragment" : "hdr.mpls.tc = tc; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "bos"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 50,
"column" : 8,
"source_fragment" : "hdr.mpls.bos = 1w1"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "ttl"]
},
{
"type" : "hexstr",
"value" : "0x40"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 113,
"column" : 32,
"source_fragment" : "64; ..."
}
}
]
},
{
"name" : "FabricIngress.next.l3_routing_vlan",
"id" : 30,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
},
{
"name" : "smac",
"bitwidth" : 48
},
{
"name" : "dmac",
"bitwidth" : 48
},
{
"name" : "new_vlan_id",
"bitwidth" : 12
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.ethernet.src_addr = smac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.ethernet.dst_addr = dmac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "vlan_id"]
},
{
"type" : "runtime_data",
"value" : 3
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 90,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.vlan_id = new_vlan_id; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 85,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
}
]
},
{
"name" : "FabricIngress.next.l3_routing_hashed",
"id" : 31,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
},
{
"name" : "smac",
"bitwidth" : 48
},
{
"name" : "dmac",
"bitwidth" : 48
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.ethernet.src_addr = smac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.ethernet.dst_addr = dmac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 149,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
}
]
},
{
"name" : "FabricIngress.next.mpls_routing_v4_hashed",
"id" : 32,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
},
{
"name" : "smac",
"bitwidth" : 48
},
{
"name" : "dmac",
"bitwidth" : 48
},
{
"name" : "label",
"bitwidth" : 20
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.ethernet.src_addr = smac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.ethernet.dst_addr = dmac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 149,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "mpls"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 46,
"column" : 8,
"source_fragment" : "hdr.mpls.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
},
{
"type" : "hexstr",
"value" : "0x8847"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 90,
"column" : 31,
"source_fragment" : "0x8847; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "label"]
},
{
"type" : "runtime_data",
"value" : 3
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 48,
"column" : 8,
"source_fragment" : "hdr.mpls.label = label; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "tc"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 49,
"column" : 8,
"source_fragment" : "hdr.mpls.tc = tc; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "bos"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 50,
"column" : 8,
"source_fragment" : "hdr.mpls.bos = 1w1"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "ttl"]
},
{
"type" : "hexstr",
"value" : "0x40"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 113,
"column" : 32,
"source_fragment" : "64; ..."
}
}
]
},
{
"name" : "FabricIngress.next.mpls_routing_v6_hashed",
"id" : 33,
"runtime_data" : [
{
"name" : "port_num",
"bitwidth" : 9
},
{
"name" : "smac",
"bitwidth" : 48
},
{
"name" : "dmac",
"bitwidth" : 48
},
{
"name" : "label",
"bitwidth" : 20
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.ethernet.src_addr = smac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.ethernet.dst_addr = dmac; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 149,
"column" : 8,
"source_fragment" : "standard_metadata.egress_spec = port_num; ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "mpls"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 46,
"column" : 8,
"source_fragment" : "hdr.mpls.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
},
{
"type" : "hexstr",
"value" : "0x8847"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 90,
"column" : 31,
"source_fragment" : "0x8847; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "label"]
},
{
"type" : "runtime_data",
"value" : 3
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 48,
"column" : 8,
"source_fragment" : "hdr.mpls.label = label; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "tc"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 49,
"column" : 8,
"source_fragment" : "hdr.mpls.tc = tc; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "bos"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 50,
"column" : 8,
"source_fragment" : "hdr.mpls.bos = 1w1"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["mpls", "ttl"]
},
{
"type" : "hexstr",
"value" : "0x40"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 113,
"column" : 32,
"source_fragment" : "64; ..."
}
}
]
},
{
"name" : "FabricIngress.next.set_mcast_group",
"id" : 34,
"runtime_data" : [
{
"name" : "gid",
"bitwidth" : 16
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "mcast_grp"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 202,
"column" : 8,
"source_fragment" : "standard_metadata.mcast_grp = gid"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.is_multicast"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 203,
"column" : 8,
"source_fragment" : "fabric_metadata.is_multicast = true"
}
}
]
},
{
"name" : "act",
"id" : 35,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
{
"type" : "field",
"value" : ["packet_out", "egress_port"]
}
],
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 26,
"column" : 12,
"source_fragment" : "standard_metadata.egress_spec = hdr.packet_out.egress_port"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "packet_out"
}
],
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 27,
"column" : 12,
"source_fragment" : "hdr.packet_out.setInvalid()"
}
}
]
},
{
"name" : "act_0",
"id" : 36,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "filtering_tmp_0"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
]
}
]
},
{
"name" : "act_1",
"id" : 37,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "filtering_tmp_0"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : false
}
}
}
}
]
}
]
},
{
"name" : "act_2",
"id" : 38,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.fwd_type"]
},
{
"type" : "hexstr",
"value" : "0x07"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 109,
"column" : 31,
"source_fragment" : "7; ..."
}
}
]
},
{
"name" : "act_3",
"id" : 39,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
},
{
"type" : "hexstr",
"value" : "0x0800"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 92,
"column" : 31,
"source_fragment" : "0x0800; ..."
}
}
]
},
{
"name" : "act_4",
"id" : 40,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_hasReturned_0"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : false
}
}
}
}
]
}
]
},
{
"name" : "act_5",
"id" : 41,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_tmp_4"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
]
}
]
},
{
"name" : "act_6",
"id" : 42,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_tmp_4"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : false
}
}
}
}
]
}
]
},
{
"name" : "act_7",
"id" : 43,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_tmp_3"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
]
}
]
},
{
"name" : "act_8",
"id" : 44,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_tmp_3"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : false
}
}
}
}
]
}
]
},
{
"name" : "act_9",
"id" : 45,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_tmp_2"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
]
}
]
},
{
"name" : "act_10",
"id" : 46,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_tmp_2"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : false
}
}
}
}
]
}
]
},
{
"name" : "act_11",
"id" : 47,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "next_hasReturned_0"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 223,
"column" : 20,
"source_fragment" : "return"
}
}
]
},
{
"name" : "act_12",
"id" : 48,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ipv4", "ttl"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["ipv4", "ttl"]
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
}
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 230,
"column" : 16,
"source_fragment" : "hdr.ipv4.ttl = hdr.ipv4.ttl - 1"
}
}
]
},
{
"name" : "act_13",
"id" : 49,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "tmp_3"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 28,
"column" : 38,
"source_fragment" : "(bit<32>)standard_metadata.egress_spec"
}
},
{
"op" : "count",
"parameters" : [
{
"type" : "counter_array",
"value" : "FabricIngress.port_counters_control.egress_port_counter"
},
{
"type" : "field",
"value" : ["scalars", "tmp_3"]
}
],
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 28,
"column" : 12,
"source_fragment" : "egress_port_counter.count((bit<32>)standard_metadata.egress_spec)"
}
}
]
},
{
"name" : "act_14",
"id" : 50,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "tmp_4"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 31,
"column" : 39,
"source_fragment" : "(bit<32>)standard_metadata.ingress_port"
}
},
{
"op" : "count",
"parameters" : [
{
"type" : "counter_array",
"value" : "FabricIngress.port_counters_control.ingress_port_counter"
},
{
"type" : "field",
"value" : ["scalars", "tmp_4"]
}
],
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 31,
"column" : 12,
"source_fragment" : "ingress_port_counter.count((bit<32>)standard_metadata.ingress_port)"
}
}
]
},
{
"name" : "act_15",
"id" : 51,
"runtime_data" : [],
"primitives" : [
{
"op" : "clone_ingress_pkt_to_egress",
"parameters" : [
{
"type" : "hexstr",
"value" : "0x000001f4"
},
{
"type" : "hexstr",
"value" : "0x1"
}
]
}
]
},
{
"name" : "NoAction",
"id" : 52,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 53,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 54,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 55,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "NoAction",
"id" : 56,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "nop",
"id" : 57,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "drop_now",
"id" : 58,
"runtime_data" : [],
"primitives" : [
{
"op" : "drop",
"parameters" : [],
"source_info" : {
"filename" : "include/control/../action.p4",
"line" : 24,
"column" : 4,
"source_fragment" : "mark_to_drop()"
}
},
{
"op" : "exit",
"parameters" : [],
"source_info" : {
"filename" : "include/control/../action.p4",
"line" : 25,
"column" : 4,
"source_fragment" : "exit"
}
}
]
},
{
"name" : "drop_now",
"id" : 59,
"runtime_data" : [],
"primitives" : [
{
"op" : "drop",
"parameters" : [],
"source_info" : {
"filename" : "include/control/../action.p4",
"line" : 24,
"column" : 4,
"source_fragment" : "mark_to_drop()"
}
},
{
"op" : "exit",
"parameters" : [],
"source_info" : {
"filename" : "include/control/../action.p4",
"line" : 25,
"column" : 4,
"source_fragment" : "exit"
}
}
]
},
{
"name" : "FabricEgress.process_int_source.int_source_dscp",
"id" : 60,
"runtime_data" : [
{
"name" : "max_hop",
"bitwidth" : 8
},
{
"name" : "ins_cnt",
"bitwidth" : 5
},
{
"name" : "ins_mask0003",
"bitwidth" : 4
},
{
"name" : "ins_mask0407",
"bitwidth" : 4
}
],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "intl4_shim"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 31,
"column" : 8,
"source_fragment" : "hdr.intl4_shim.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["intl4_shim", "int_type"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 33,
"column" : 8,
"source_fragment" : "hdr.intl4_shim.int_type = 1"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["intl4_shim", "len"]
},
{
"type" : "hexstr",
"value" : "0x04"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 127,
"column" : 35,
"source_fragment" : "4; ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_header"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.int_header.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "ver"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 38,
"column" : 8,
"source_fragment" : "hdr.int_header.ver = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "rep"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 39,
"column" : 8,
"source_fragment" : "hdr.int_header.rep = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "c"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_header.c = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "e"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_header.e = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "rsvd1"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 42,
"column" : 8,
"source_fragment" : "hdr.int_header.rsvd1 = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "ins_cnt"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 43,
"column" : 8,
"source_fragment" : "hdr.int_header.ins_cnt = ins_cnt; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "max_hop_cnt"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_header.max_hop_cnt = max_hop; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "total_hop_cnt"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_header.total_hop_cnt = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "instruction_mask_0003"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 46,
"column" : 8,
"source_fragment" : "hdr.int_header.instruction_mask_0003 = ins_mask0003; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "instruction_mask_0407"]
},
{
"type" : "runtime_data",
"value" : 3
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_header.instruction_mask_0407 = ins_mask0407; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "instruction_mask_0811"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 48,
"column" : 8,
"source_fragment" : "hdr.int_header.instruction_mask_0811 = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "instruction_mask_1215"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 49,
"column" : 8,
"source_fragment" : "hdr.int_header.instruction_mask_1215 = 0"
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "intl4_tail"
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.intl4_tail.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["intl4_tail", "next_proto"]
},
{
"type" : "field",
"value" : ["ipv4", "protocol"]
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 53,
"column" : 8,
"source_fragment" : "hdr.intl4_tail.next_proto = hdr.ipv4.protocol"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["intl4_tail", "dest_port"]
},
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.l4_dst_port"]
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 54,
"column" : 8,
"source_fragment" : "hdr.intl4_tail.dest_port = fabric_metadata.l4_dst_port"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["intl4_tail", "dscp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["ipv4", "dscp"]
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 55,
"column" : 8,
"source_fragment" : "hdr.intl4_tail.dscp = (bit<8>) hdr.ipv4.dscp"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ipv4", "total_len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["ipv4", "total_len"]
},
"right" : {
"type" : "hexstr",
"value" : "0x0010"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.ipv4.total_len = hdr.ipv4.total_len + 16"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["udp", "len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["udp", "len"]
},
"right" : {
"type" : "hexstr",
"value" : "0x0010"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 59,
"column" : 8,
"source_fragment" : "hdr.udp.len = hdr.udp.len + 16"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ipv4", "dscp"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 125,
"column" : 24,
"source_fragment" : "0x1; ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_update_total_hop_cnt",
"id" : 61,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_header", "total_hop_cnt"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["int_header", "total_hop_cnt"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 30,
"column" : 8,
"source_fragment" : "hdr.int_header.total_hop_cnt = hdr.int_header.total_hop_cnt + 1"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_transit",
"id" : 62,
"runtime_data" : [
{
"name" : "switch_id",
"bitwidth" : 32
}
],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 34,
"column" : 8,
"source_fragment" : "fabric_metadata.int_meta.switch_id = switch_id"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["userMetadata.int_meta", "insert_byte_cnt"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "<<",
"left" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["int_header", "ins_cnt"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0x2"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 35,
"column" : 8,
"source_fragment" : "fabric_metadata.int_meta.insert_byte_cnt = (bit<16>) hdr.int_header.ins_cnt << 2"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i0",
"id" : 63,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i1",
"id" : 64,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i2",
"id" : 65,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i3",
"id" : 66,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i4",
"id" : 67,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i5",
"id" : 68,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i6",
"id" : 69,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i7",
"id" : 70,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i8",
"id" : 71,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i9",
"id" : 72,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i10",
"id" : 73,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i11",
"id" : 74,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i12",
"id" : 75,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i13",
"id" : 76,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i14",
"id" : 77,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0003_i15",
"id" : 78,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_occupancy", "q_occupancy"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "deq_qdepth"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 61,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.q_occupancy = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_hop_latency", "hop_latency"]
},
{
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.hop_latency = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "ingress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.ingress_port_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_port_ids", "egress_port_id"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 47,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.egress_port_id = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_switch_id", "switch_id"]
},
{
"type" : "field",
"value" : ["userMetadata.int_meta", "switch_id"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.switch_id = fabric_metadata.int_meta.switch_id"
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i0",
"id" : 79,
"runtime_data" : [],
"primitives" : []
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i1",
"id" : 80,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i2",
"id" : 81,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i3",
"id" : 82,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i4",
"id" : 83,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i5",
"id" : 84,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i6",
"id" : 85,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i7",
"id" : 86,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i8",
"id" : 87,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i9",
"id" : 88,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i10",
"id" : 89,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i11",
"id" : 90,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i12",
"id" : 91,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i13",
"id" : 92,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i14",
"id" : 93,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_transit.int_set_header_0407_i15",
"id" : 94,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 88,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tx_util", "egress_port_tx_util"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 89,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.egress_port_tx_util = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 78,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_id"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 79,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_id = ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_q_congestion", "q_congestion"]
},
{
"type" : "hexstr",
"value" : "0x000000"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 82,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.q_congestion = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_egress_tstamp", "egress_tstamp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "deq_timedelta"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffffffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.egress_tstamp = ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["int_ingress_tstamp", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_outer_encap.int_update_ipv4",
"id" : 95,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ipv4", "total_len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["ipv4", "total_len"]
},
"right" : {
"type" : "field",
"value" : ["userMetadata.int_meta", "insert_byte_cnt"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 304,
"column" : 8,
"source_fragment" : "hdr.ipv4.total_len = hdr.ipv4.total_len + fabric_metadata.int_meta.insert_byte_cnt"
}
}
]
},
{
"name" : "FabricEgress.process_int_outer_encap.int_update_udp",
"id" : 96,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["udp", "len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["udp", "len"]
},
"right" : {
"type" : "field",
"value" : ["userMetadata.int_meta", "insert_byte_cnt"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 307,
"column" : 8,
"source_fragment" : "hdr.udp.len = hdr.udp.len + fabric_metadata.int_meta.insert_byte_cnt"
}
}
]
},
{
"name" : "FabricEgress.process_int_outer_encap.int_update_shim",
"id" : 97,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["intl4_shim", "len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "field",
"value" : ["intl4_shim", "len"]
},
"right" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["int_header", "ins_cnt"]
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 310,
"column" : 8,
"source_fragment" : "hdr.intl4_shim.len = hdr.intl4_shim.len + (bit<8>)hdr.int_header.ins_cnt"
}
}
]
},
{
"name" : "FabricEgress.process_int_report.do_report_encapsulation",
"id" : 98,
"runtime_data" : [
{
"name" : "src_mac",
"bitwidth" : 48
},
{
"name" : "mon_mac",
"bitwidth" : 48
},
{
"name" : "src_ip",
"bitwidth" : 32
},
{
"name" : "mon_ip",
"bitwidth" : 32
},
{
"name" : "mon_port",
"bitwidth" : 16
}
],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "report_ethernet"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 50,
"column" : 8,
"source_fragment" : "hdr.report_ethernet.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ethernet", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 1
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 51,
"column" : 8,
"source_fragment" : "hdr.report_ethernet.dst_addr = mon_mac"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ethernet", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 0
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 52,
"column" : 8,
"source_fragment" : "hdr.report_ethernet.src_addr = src_mac"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ethernet", "ether_type"]
},
{
"type" : "hexstr",
"value" : "0x0800"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 92,
"column" : 31,
"source_fragment" : "0x0800; ..."
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "report_ipv4"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 56,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "version"]
},
{
"type" : "hexstr",
"value" : "0x04"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 57,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.version = 4w4"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "ihl"]
},
{
"type" : "hexstr",
"value" : "0x05"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 58,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.ihl = 4w5"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "dscp"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 59,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.dscp = 6w0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "ecn"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 60,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.ecn = 2w0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "total_len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "hexstr",
"value" : "0x0036"
},
"right" : {
"type" : "field",
"value" : ["ipv4", "total_len"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 62,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.total_len = (bit<16>) IPV4_MIN_HEAD_LEN + (bit<16>) UDP_HEADER_LEN + ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "identification"]
},
{
"type" : "hexstr",
"value" : "0x0000"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 65,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.identification = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "flags"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 66,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.flags = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "frag_offset"]
},
{
"type" : "hexstr",
"value" : "0x0000"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 67,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.frag_offset = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "ttl"]
},
{
"type" : "hexstr",
"value" : "0xff"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 68,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.ttl = 0xFF"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "protocol"]
},
{
"type" : "hexstr",
"value" : "0x11"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 98,
"column" : 25,
"source_fragment" : "17; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "src_addr"]
},
{
"type" : "runtime_data",
"value" : 2
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 70,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.src_addr = src_ip"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_ipv4", "dst_addr"]
},
{
"type" : "runtime_data",
"value" : 3
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 71,
"column" : 8,
"source_fragment" : "hdr.report_ipv4.dst_addr = mon_ip"
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "report_udp"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 74,
"column" : 8,
"source_fragment" : "hdr.report_udp.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_udp", "src_port"]
},
{
"type" : "hexstr",
"value" : "0x0000"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 75,
"column" : 8,
"source_fragment" : "hdr.report_udp.src_port = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_udp", "dst_port"]
},
{
"type" : "runtime_data",
"value" : 4
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 76,
"column" : 8,
"source_fragment" : "hdr.report_udp.dst_port = mon_port"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_udp", "len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "+",
"left" : {
"type" : "hexstr",
"value" : "0x0022"
},
"right" : {
"type" : "field",
"value" : ["ipv4", "total_len"]
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 77,
"column" : 8,
"source_fragment" : "hdr.report_udp.len = (bit<16>) UDP_HEADER_LEN + (bit<16>) REPORT_FIXED_HEADER_LEN + ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.compute_checksum"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "b2d",
"left" : null,
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 80,
"column" : 8,
"source_fragment" : "fabric_metadata.compute_checksum = true"
}
},
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "report_fixed_header"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 30,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "ver"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 31,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.ver = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "nproto"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 132,
"column" : 31,
"source_fragment" : "0; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "d"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 34,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.d = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "q"]
},
{
"type" : "hexstr",
"value" : "0x00"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 35,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.q = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "f"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 36,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.f = 1"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "rsvd"]
},
{
"type" : "hexstr",
"value" : "0x0000"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.rsvd = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "hw_id"]
},
{
"type" : "hexstr",
"value" : "0x01"
}
],
"source_info" : {
"filename" : "include/control/../define.p4",
"line" : 136,
"column" : 21,
"source_fragment" : "1; ..."
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "seq_no"]
},
{
"type" : "hexstr",
"value" : "0x00000000"
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.seq_no = 0"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["report_fixed_header", "ingress_tstamp"]
},
{
"type" : "field",
"value" : ["standard_metadata", "enq_timestamp"]
}
],
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 43,
"column" : 8,
"source_fragment" : "hdr.report_fixed_header.ingress_tstamp = ..."
}
}
]
},
{
"name" : "FabricEgress.process_int_sink.restore_header",
"id" : 99,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["udp", "dst_port"]
},
{
"type" : "field",
"value" : ["intl4_tail", "dest_port"]
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 26,
"column" : 8,
"source_fragment" : "hdr.udp.dst_port = hdr.intl4_tail.dest_port"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ipv4", "dscp"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "field",
"value" : ["intl4_tail", "dscp"]
},
"right" : {
"type" : "hexstr",
"value" : "0x3f"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 27,
"column" : 8,
"source_fragment" : "hdr.ipv4.dscp = (bit<6>)hdr.intl4_tail.dscp"
}
}
]
},
{
"name" : "FabricEgress.process_int_sink.int_sink",
"id" : 100,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ipv4", "total_len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "-",
"left" : {
"type" : "field",
"value" : ["ipv4", "total_len"]
},
"right" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "<<",
"left" : {
"type" : "field",
"value" : ["intl4_shim", "len"]
},
"right" : {
"type" : "hexstr",
"value" : "0x2"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 32,
"column" : 8,
"source_fragment" : "hdr.ipv4.total_len = hdr.ipv4.total_len - (bit<16>)(hdr.intl4_shim.len << 2)"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["udp", "len"]
},
{
"type" : "expression",
"value" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "-",
"left" : {
"type" : "field",
"value" : ["udp", "len"]
},
"right" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "&",
"left" : {
"type" : "expression",
"value" : {
"op" : "<<",
"left" : {
"type" : "field",
"value" : ["intl4_shim", "len"]
},
"right" : {
"type" : "hexstr",
"value" : "0x2"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xff"
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
},
"right" : {
"type" : "hexstr",
"value" : "0xffff"
}
}
}
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 33,
"column" : 8,
"source_fragment" : "hdr.udp.len = hdr.udp.len - (bit<16>)(hdr.intl4_shim.len << 2)"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_header"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 35,
"column" : 8,
"source_fragment" : "hdr.int_header.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_data"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 36,
"column" : 8,
"source_fragment" : "hdr.int_data.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "intl4_shim"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 37,
"column" : 8,
"source_fragment" : "hdr.intl4_shim.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "intl4_tail"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 38,
"column" : 8,
"source_fragment" : "hdr.intl4_tail.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_switch_id"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 39,
"column" : 8,
"source_fragment" : "hdr.int_switch_id.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_port_ids"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "hdr.int_port_ids.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_hop_latency"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 41,
"column" : 8,
"source_fragment" : "hdr.int_hop_latency.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_occupancy"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 42,
"column" : 8,
"source_fragment" : "hdr.int_q_occupancy.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_ingress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 43,
"column" : 8,
"source_fragment" : "hdr.int_ingress_tstamp.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tstamp"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 44,
"column" : 8,
"source_fragment" : "hdr.int_egress_tstamp.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_q_congestion"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 45,
"column" : 8,
"source_fragment" : "hdr.int_q_congestion.setInvalid()"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "int_egress_tx_util"
}
],
"source_info" : {
"filename" : "include/int_sink.p4",
"line" : 46,
"column" : 8,
"source_fragment" : "hdr.int_egress_tx_util.setInvalid()"
}
}
]
},
{
"name" : "FabricEgress.pkt_io_egress.pop_vlan",
"id" : 101,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "ether_type"]
},
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
}
],
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 38,
"column" : 8,
"source_fragment" : "hdr.ethernet.ether_type = hdr.vlan_tag.ether_type"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "vlan_tag"
}
],
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 39,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.setInvalid()"
}
}
]
},
{
"name" : "FabricEgress.egress_next.pop_vlan",
"id" : 102,
"runtime_data" : [],
"primitives" : [
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["ethernet", "ether_type"]
},
{
"type" : "field",
"value" : ["vlan_tag", "ether_type"]
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 253,
"column" : 8,
"source_fragment" : "hdr.ethernet.ether_type = hdr.vlan_tag.ether_type"
}
},
{
"op" : "remove_header",
"parameters" : [
{
"type" : "header",
"value" : "vlan_tag"
}
],
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 254,
"column" : 8,
"source_fragment" : "hdr.vlan_tag.setInvalid()"
}
}
]
},
{
"name" : "act_16",
"id" : 103,
"runtime_data" : [],
"primitives" : [
{
"op" : "add_header",
"parameters" : [
{
"type" : "header",
"value" : "packet_in"
}
],
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 51,
"column" : 12,
"source_fragment" : "hdr.packet_in.setValid()"
}
},
{
"op" : "assign",
"parameters" : [
{
"type" : "field",
"value" : ["packet_in", "ingress_port"]
},
{
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
}
],
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 52,
"column" : 12,
"source_fragment" : "hdr.packet_in.ingress_port = standard_metadata.ingress_port"
}
}
]
}
],
"pipelines" : [
{
"name" : "ingress",
"id" : 0,
"source_info" : {
"filename" : "fabric.p4",
"line" : 40,
"column" : 8,
"source_fragment" : "FabricIngress"
},
"init_table" : "node_2",
"tables" : [
{
"name" : "tbl_act",
"id" : 0,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [35],
"actions" : ["act"],
"base_default_next" : null,
"next_tables" : {
"act" : null
},
"default_entry" : {
"action_id" : 35,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.filtering.ingress_port_vlan",
"id" : 1,
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 66,
"column" : 10,
"source_fragment" : "ingress_port_vlan"
},
"key" : [
{
"match_type" : "exact",
"name" : "standard_metadata.ingress_port",
"target" : ["standard_metadata", "ingress_port"],
"mask" : null
},
{
"match_type" : "exact",
"name" : "hdr.vlan_tag.is_valid",
"target" : ["vlan_tag", "$valid$"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.vlan_tag.vlan_id",
"target" : ["vlan_tag", "vlan_id"],
"mask" : null
}
],
"match_type" : "ternary",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [13, 12, 11, 14],
"actions" : ["FabricIngress.filtering.push_internal_vlan", "FabricIngress.filtering.set_vlan", "FabricIngress.filtering.drop", "FabricIngress.filtering.nop_ingress_port_vlan"],
"base_default_next" : null,
"next_tables" : {
"__HIT__" : "tbl_act_0",
"__MISS__" : "tbl_act_1"
},
"default_entry" : {
"action_id" : 13,
"action_const" : true,
"action_data" : ["0xffe"],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_0",
"id" : 2,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [36],
"actions" : ["act_0"],
"base_default_next" : "node_7",
"next_tables" : {
"act_0" : "node_7"
},
"default_entry" : {
"action_id" : 36,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_1",
"id" : 3,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [37],
"actions" : ["act_1"],
"base_default_next" : "node_7",
"next_tables" : {
"act_1" : "node_7"
},
"default_entry" : {
"action_id" : 37,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.filtering.fwd_classifier",
"id" : 4,
"source_info" : {
"filename" : "include/control/filtering.p4",
"line" : 103,
"column" : 10,
"source_fragment" : "fwd_classifier"
},
"key" : [
{
"match_type" : "exact",
"name" : "standard_metadata.ingress_port",
"target" : ["standard_metadata", "ingress_port"],
"mask" : null
},
{
"match_type" : "exact",
"name" : "hdr.ethernet.dst_addr",
"target" : ["ethernet", "dst_addr"],
"mask" : null
},
{
"match_type" : "exact",
"name" : "hdr.vlan_tag.ether_type",
"target" : ["vlan_tag", "ether_type"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [15],
"actions" : ["FabricIngress.filtering.set_forwarding_type"],
"base_default_next" : "node_10",
"next_tables" : {
"FabricIngress.filtering.set_forwarding_type" : "node_10"
},
"default_entry" : {
"action_id" : 15,
"action_const" : true,
"action_data" : ["0x0"],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_2",
"id" : 5,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [38],
"actions" : ["act_2"],
"base_default_next" : "node_10",
"next_tables" : {
"act_2" : "node_10"
},
"default_entry" : {
"action_id" : 38,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.forwarding.bridging",
"id" : 6,
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 41,
"column" : 10,
"source_fragment" : "bridging"
},
"key" : [
{
"match_type" : "exact",
"name" : "hdr.vlan_tag.vlan_id",
"target" : ["vlan_tag", "vlan_id"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.ethernet.dst_addr",
"target" : ["ethernet", "dst_addr"],
"mask" : null
}
],
"match_type" : "ternary",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [16, 2],
"actions" : ["FabricIngress.forwarding.set_next_id_bridging", "NoAction"],
"base_default_next" : "FabricIngress.forwarding.acl",
"next_tables" : {
"FabricIngress.forwarding.set_next_id_bridging" : "FabricIngress.forwarding.acl",
"NoAction" : "FabricIngress.forwarding.acl"
},
"default_entry" : {
"action_id" : 2,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "FabricIngress.forwarding.mpls",
"id" : 7,
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 65,
"column" : 10,
"source_fragment" : "mpls"
},
"key" : [
{
"match_type" : "exact",
"name" : "hdr.mpls.label",
"target" : ["mpls", "label"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [17, 3],
"actions" : ["FabricIngress.forwarding.pop_mpls_and_next", "NoAction"],
"base_default_next" : "tbl_act_3",
"next_tables" : {
"FabricIngress.forwarding.pop_mpls_and_next" : "tbl_act_3",
"NoAction" : "tbl_act_3"
},
"default_entry" : {
"action_id" : 3,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "tbl_act_3",
"id" : 8,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [39],
"actions" : ["act_3"],
"base_default_next" : "FabricIngress.forwarding.acl",
"next_tables" : {
"act_3" : "FabricIngress.forwarding.acl"
},
"default_entry" : {
"action_id" : 39,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.forwarding.unicast_v4",
"id" : 9,
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 87,
"column" : 10,
"source_fragment" : "unicast_v4"
},
"key" : [
{
"match_type" : "lpm",
"name" : "hdr.ipv4.dst_addr",
"target" : ["ipv4", "dst_addr"],
"mask" : null
}
],
"match_type" : "lpm",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [18, 4],
"actions" : ["FabricIngress.forwarding.set_next_id_unicast_v4", "NoAction"],
"base_default_next" : "FabricIngress.forwarding.acl",
"next_tables" : {
"FabricIngress.forwarding.set_next_id_unicast_v4" : "FabricIngress.forwarding.acl",
"NoAction" : "FabricIngress.forwarding.acl"
},
"default_entry" : {
"action_id" : 4,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "FabricIngress.forwarding.acl",
"id" : 10,
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 131,
"column" : 10,
"source_fragment" : "acl"
},
"key" : [
{
"match_type" : "ternary",
"name" : "standard_metadata.ingress_port",
"target" : ["standard_metadata", "ingress_port"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "fabric_metadata.ip_proto",
"target" : ["scalars", "fabric_metadata_t.ip_proto"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "fabric_metadata.l4_src_port",
"target" : ["scalars", "fabric_metadata_t.l4_src_port"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "fabric_metadata.l4_dst_port",
"target" : ["scalars", "fabric_metadata_t.l4_dst_port"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.ethernet.dst_addr",
"target" : ["ethernet", "dst_addr"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.ethernet.src_addr",
"target" : ["ethernet", "src_addr"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.vlan_tag.vlan_id",
"target" : ["vlan_tag", "vlan_id"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.vlan_tag.ether_type",
"target" : ["vlan_tag", "ether_type"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.ipv4.src_addr",
"target" : ["ipv4", "src_addr"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.ipv4.dst_addr",
"target" : ["ipv4", "dst_addr"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.icmp.icmp_type",
"target" : ["icmp", "icmp_type"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.icmp.icmp_code",
"target" : ["icmp", "icmp_code"],
"mask" : null
}
],
"match_type" : "ternary",
"type" : "simple",
"max_size" : 128,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [19, 20, 21, 22, 23],
"actions" : ["FabricIngress.forwarding.set_next_id_acl", "FabricIngress.forwarding.punt_to_cpu", "FabricIngress.forwarding.clone_to_cpu", "FabricIngress.forwarding.drop", "FabricIngress.forwarding.nop_acl"],
"base_default_next" : "tbl_act_4",
"next_tables" : {
"FabricIngress.forwarding.set_next_id_acl" : "tbl_act_4",
"FabricIngress.forwarding.punt_to_cpu" : "tbl_act_4",
"FabricIngress.forwarding.clone_to_cpu" : "tbl_act_4",
"FabricIngress.forwarding.drop" : "tbl_act_4",
"FabricIngress.forwarding.nop_acl" : "tbl_act_4"
},
"default_entry" : {
"action_id" : 23,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_4",
"id" : 11,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [40],
"actions" : ["act_4"],
"base_default_next" : "FabricIngress.next.vlan_meta",
"next_tables" : {
"act_4" : "FabricIngress.next.vlan_meta"
},
"default_entry" : {
"action_id" : 40,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.next.vlan_meta",
"id" : 12,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 65,
"column" : 10,
"source_fragment" : "vlan_meta"
},
"key" : [
{
"match_type" : "exact",
"name" : "fabric_metadata.next_id",
"target" : ["scalars", "fabric_metadata_t.next_id"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [24, 8],
"actions" : ["FabricIngress.next.set_vlan", "nop"],
"base_default_next" : "FabricIngress.next.simple",
"next_tables" : {
"FabricIngress.next.set_vlan" : "FabricIngress.next.simple",
"nop" : "FabricIngress.next.simple"
},
"default_entry" : {
"action_id" : 8,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "FabricIngress.next.simple",
"id" : 13,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 122,
"column" : 10,
"source_fragment" : "simple"
},
"key" : [
{
"match_type" : "exact",
"name" : "fabric_metadata.next_id",
"target" : ["scalars", "fabric_metadata_t.next_id"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [25, 26, 27, 28, 29, 30, 5],
"actions" : ["FabricIngress.next.output_simple", "FabricIngress.next.set_vlan_output", "FabricIngress.next.l3_routing_simple", "FabricIngress.next.mpls_routing_v4_simple", "FabricIngress.next.mpls_routing_v6_simple", "FabricIngress.next.l3_routing_vlan", "NoAction"],
"base_default_next" : null,
"next_tables" : {
"__HIT__" : "tbl_act_5",
"__MISS__" : "tbl_act_6"
},
"default_entry" : {
"action_id" : 5,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "tbl_act_5",
"id" : 14,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [41],
"actions" : ["act_5"],
"base_default_next" : "node_23",
"next_tables" : {
"act_5" : "node_23"
},
"default_entry" : {
"action_id" : 41,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_6",
"id" : 15,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [42],
"actions" : ["act_6"],
"base_default_next" : "node_23",
"next_tables" : {
"act_6" : "node_23"
},
"default_entry" : {
"action_id" : 42,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.next.hashed",
"id" : 16,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 175,
"column" : 10,
"source_fragment" : "hashed"
},
"key" : [
{
"match_type" : "exact",
"name" : "fabric_metadata.next_id",
"target" : ["scalars", "fabric_metadata_t.next_id"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "indirect_ws",
"action_profile" : "FabricIngress.next.ecmp_selector",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [31, 32, 33, 6],
"actions" : ["FabricIngress.next.l3_routing_hashed", "FabricIngress.next.mpls_routing_v4_hashed", "FabricIngress.next.mpls_routing_v6_hashed", "NoAction"],
"base_default_next" : null,
"next_tables" : {
"__HIT__" : "tbl_act_7",
"__MISS__" : "tbl_act_8"
}
},
{
"name" : "tbl_act_7",
"id" : 17,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [43],
"actions" : ["act_7"],
"base_default_next" : "node_27",
"next_tables" : {
"act_7" : "node_27"
},
"default_entry" : {
"action_id" : 43,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_8",
"id" : 18,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [44],
"actions" : ["act_8"],
"base_default_next" : "node_27",
"next_tables" : {
"act_8" : "node_27"
},
"default_entry" : {
"action_id" : 44,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.next.multicast",
"id" : 19,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 207,
"column" : 10,
"source_fragment" : "multicast"
},
"key" : [
{
"match_type" : "exact",
"name" : "fabric_metadata.next_id",
"target" : ["scalars", "fabric_metadata_t.next_id"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [34, 7],
"actions" : ["FabricIngress.next.set_mcast_group", "NoAction"],
"base_default_next" : null,
"next_tables" : {
"__HIT__" : "tbl_act_9",
"__MISS__" : "tbl_act_10"
},
"default_entry" : {
"action_id" : 7,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "tbl_act_9",
"id" : 20,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [45],
"actions" : ["act_9"],
"base_default_next" : "node_31",
"next_tables" : {
"act_9" : "node_31"
},
"default_entry" : {
"action_id" : 45,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_10",
"id" : 21,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [46],
"actions" : ["act_10"],
"base_default_next" : "node_31",
"next_tables" : {
"act_10" : "node_31"
},
"default_entry" : {
"action_id" : 46,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_11",
"id" : 22,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [47],
"actions" : ["act_11"],
"base_default_next" : "node_33",
"next_tables" : {
"act_11" : "node_33"
},
"default_entry" : {
"action_id" : 47,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_12",
"id" : 23,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [48],
"actions" : ["act_12"],
"base_default_next" : "node_37",
"next_tables" : {
"act_12" : "node_37"
},
"default_entry" : {
"action_id" : 48,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_13",
"id" : 24,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [49],
"actions" : ["act_13"],
"base_default_next" : "node_39",
"next_tables" : {
"act_13" : "node_39"
},
"default_entry" : {
"action_id" : 49,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_14",
"id" : 25,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [50],
"actions" : ["act_14"],
"base_default_next" : "FabricIngress.process_set_source_sink.tb_set_source",
"next_tables" : {
"act_14" : "FabricIngress.process_set_source_sink.tb_set_source"
},
"default_entry" : {
"action_id" : 50,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricIngress.process_set_source_sink.tb_set_source",
"id" : 26,
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 101,
"column" : 10,
"source_fragment" : "tb_set_source"
},
"key" : [
{
"match_type" : "exact",
"name" : "standard_metadata.ingress_port",
"target" : ["standard_metadata", "ingress_port"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 256,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [9, 0],
"actions" : ["FabricIngress.process_set_source_sink.int_set_source", "NoAction"],
"base_default_next" : "FabricIngress.process_set_source_sink.tb_set_sink",
"next_tables" : {
"FabricIngress.process_set_source_sink.int_set_source" : "FabricIngress.process_set_source_sink.tb_set_sink",
"NoAction" : "FabricIngress.process_set_source_sink.tb_set_sink"
},
"default_entry" : {
"action_id" : 0,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "FabricIngress.process_set_source_sink.tb_set_sink",
"id" : 27,
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 111,
"column" : 10,
"source_fragment" : "tb_set_sink"
},
"key" : [
{
"match_type" : "exact",
"name" : "standard_metadata.egress_spec",
"target" : ["standard_metadata", "egress_spec"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 256,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [10, 1],
"actions" : ["FabricIngress.process_set_source_sink.int_set_sink", "NoAction"],
"base_default_next" : "node_43",
"next_tables" : {
"FabricIngress.process_set_source_sink.int_set_sink" : "node_43",
"NoAction" : "node_43"
},
"default_entry" : {
"action_id" : 1,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "tbl_act_15",
"id" : 28,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [51],
"actions" : ["act_15"],
"base_default_next" : null,
"next_tables" : {
"act_15" : null
},
"default_entry" : {
"action_id" : 51,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
}
],
"action_profiles" : [
{
"name" : "FabricIngress.next.ecmp_selector",
"id" : 0,
"max_size" : 64,
"selector" : {
"algo" : "crc16",
"input" : [
{
"type" : "field",
"value" : ["ipv4", "dst_addr"]
},
{
"type" : "field",
"value" : ["ipv4", "src_addr"]
},
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.ip_proto"]
},
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.l4_src_port"]
},
{
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.l4_dst_port"]
}
]
}
}
],
"conditionals" : [
{
"name" : "node_2",
"id" : 0,
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 25,
"column" : 12,
"source_fragment" : "hdr.packet_out.isValid()"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["packet_out", "$valid$"]
}
}
},
"true_next" : "tbl_act",
"false_next" : "FabricIngress.filtering.ingress_port_vlan"
},
{
"name" : "node_7",
"id" : 1,
"expression" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "filtering_tmp_0"]
}
}
},
"true_next" : "FabricIngress.filtering.fwd_classifier",
"false_next" : "tbl_act_2"
},
{
"name" : "node_10",
"id" : 2,
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 235,
"column" : 11,
"source_fragment" : "fabric_metadata.fwd_type == FWD_BRIDGING"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.fwd_type"]
},
"right" : {
"type" : "hexstr",
"value" : "0x00"
}
}
},
"true_next" : "FabricIngress.forwarding.bridging",
"false_next" : "node_12"
},
{
"name" : "node_12",
"id" : 3,
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 236,
"column" : 17,
"source_fragment" : "fabric_metadata.fwd_type == FWD_MPLS"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.fwd_type"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
},
"true_next" : "FabricIngress.forwarding.mpls",
"false_next" : "node_15"
},
{
"name" : "node_15",
"id" : 4,
"source_info" : {
"filename" : "include/control/forwarding.p4",
"line" : 250,
"column" : 17,
"source_fragment" : "fabric_metadata.fwd_type == FWD_IPV4_UNICAST"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.fwd_type"]
},
"right" : {
"type" : "hexstr",
"value" : "0x02"
}
}
},
"true_next" : "FabricIngress.forwarding.unicast_v4",
"false_next" : "FabricIngress.forwarding.acl"
},
{
"name" : "node_23",
"id" : 5,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 219,
"column" : 12,
"source_fragment" : "!simple.apply().hit"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "not",
"left" : null,
"right" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "next_tmp_4"]
}
}
}
}
},
"true_next" : "FabricIngress.next.hashed",
"false_next" : "node_33"
},
{
"name" : "node_27",
"id" : 6,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 220,
"column" : 16,
"source_fragment" : "!hashed.apply().hit"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "not",
"left" : null,
"right" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "next_tmp_3"]
}
}
}
}
},
"true_next" : "FabricIngress.next.multicast",
"false_next" : "node_33"
},
{
"name" : "node_31",
"id" : 7,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 221,
"column" : 20,
"source_fragment" : "!multicast.apply().hit"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "not",
"left" : null,
"right" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "next_tmp_2"]
}
}
}
}
},
"true_next" : "tbl_act_11",
"false_next" : "node_33"
},
{
"name" : "node_33",
"id" : 8,
"expression" : {
"type" : "expression",
"value" : {
"op" : "not",
"left" : null,
"right" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "next_hasReturned_0"]
}
}
}
}
},
"true_next" : "node_34",
"false_next" : "node_37"
},
{
"name" : "node_34",
"id" : 9,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 228,
"column" : 12,
"source_fragment" : "!hdr.mpls.isValid()"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "not",
"left" : null,
"right" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["mpls", "$valid$"]
}
}
}
}
},
"true_next" : "node_35",
"false_next" : "node_37"
},
{
"name" : "node_35",
"id" : 10,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 229,
"column" : 15,
"source_fragment" : "hdr.ipv4.isValid()"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["ipv4", "$valid$"]
}
}
},
"true_next" : "tbl_act_12",
"false_next" : "node_37"
},
{
"name" : "node_37",
"id" : 11,
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 27,
"column" : 12,
"source_fragment" : "standard_metadata.egress_spec < 511"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "<",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_spec"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01ff"
}
}
},
"true_next" : "tbl_act_13",
"false_next" : "node_39"
},
{
"name" : "node_39",
"id" : 12,
"source_info" : {
"filename" : "include/control/port_counter.p4",
"line" : 30,
"column" : 12,
"source_fragment" : "standard_metadata.ingress_port < 511"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "<",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01ff"
}
}
},
"true_next" : "tbl_act_14",
"false_next" : "FabricIngress.process_set_source_sink.tb_set_source"
},
{
"name" : "node_43",
"id" : 13,
"source_info" : {
"filename" : "fabric.p4",
"line" : 70,
"column" : 11,
"source_fragment" : "fabric_metadata.int_meta.sink == 1"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["userMetadata.int_meta", "sink"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
},
"false_next" : null,
"true_next" : "tbl_act_15"
}
]
},
{
"name" : "egress",
"id" : 1,
"source_info" : {
"filename" : "fabric.p4",
"line" : 80,
"column" : 8,
"source_fragment" : "FabricEgress"
},
"init_table" : "node_47",
"tables" : [
{
"name" : "tbl_drop_now",
"id" : 29,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [58],
"actions" : ["drop_now"],
"base_default_next" : "FabricEgress.egress_next.egress_vlan",
"next_tables" : {
"drop_now" : "FabricEgress.egress_next.egress_vlan"
},
"default_entry" : {
"action_id" : 58,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricEgress.egress_next.egress_vlan",
"id" : 30,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 258,
"column" : 10,
"source_fragment" : "egress_vlan"
},
"key" : [
{
"match_type" : "exact",
"name" : "hdr.vlan_tag.vlan_id",
"target" : ["vlan_tag", "vlan_id"],
"mask" : null
},
{
"match_type" : "exact",
"name" : "standard_metadata.egress_port",
"target" : ["standard_metadata", "egress_port"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [102, 57],
"actions" : ["FabricEgress.egress_next.pop_vlan", "nop"],
"base_default_next" : "node_50",
"next_tables" : {
"FabricEgress.egress_next.pop_vlan" : "node_50",
"nop" : "node_50"
},
"default_entry" : {
"action_id" : 57,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "tbl_pkt_io_egress_pop_vlan",
"id" : 31,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [101],
"actions" : ["FabricEgress.pkt_io_egress.pop_vlan"],
"base_default_next" : "node_53",
"next_tables" : {
"FabricEgress.pkt_io_egress.pop_vlan" : "node_53"
},
"default_entry" : {
"action_id" : 101,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_drop_now_0",
"id" : 32,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [59],
"actions" : ["drop_now"],
"base_default_next" : "tbl_act_16",
"next_tables" : {
"drop_now" : "tbl_act_16"
},
"default_entry" : {
"action_id" : 59,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_act_16",
"id" : 33,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [103],
"actions" : ["act_16"],
"base_default_next" : "node_56",
"next_tables" : {
"act_16" : "node_56"
},
"default_entry" : {
"action_id" : 103,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricEgress.process_int_source.tb_int_source",
"id" : 34,
"source_info" : {
"filename" : "include/int_source.p4",
"line" : 66,
"column" : 10,
"source_fragment" : "tb_int_source"
},
"key" : [
{
"match_type" : "ternary",
"name" : "hdr.ipv4.src_addr",
"target" : ["ipv4", "src_addr"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "hdr.ipv4.dst_addr",
"target" : ["ipv4", "dst_addr"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "fabric_metadata.l4_src_port",
"target" : ["scalars", "fabric_metadata_t.l4_src_port"],
"mask" : null
},
{
"match_type" : "ternary",
"name" : "fabric_metadata.l4_dst_port",
"target" : ["scalars", "fabric_metadata_t.l4_dst_port"],
"mask" : null
}
],
"match_type" : "ternary",
"type" : "simple",
"max_size" : 1024,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [60, 52],
"actions" : ["FabricEgress.process_int_source.int_source_dscp", "NoAction"],
"base_default_next" : "node_59",
"next_tables" : {
"FabricEgress.process_int_source.int_source_dscp" : "node_59",
"NoAction" : "node_59"
},
"default_entry" : {
"action_id" : 52,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "FabricEgress.process_int_transit.tb_int_insert",
"id" : 35,
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 227,
"column" : 10,
"source_fragment" : "tb_int_insert"
},
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 2,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [62, 53],
"actions" : ["FabricEgress.process_int_transit.int_transit", "NoAction"],
"base_default_next" : "FabricEgress.process_int_transit.tb_int_inst_0003",
"next_tables" : {
"FabricEgress.process_int_transit.int_transit" : "FabricEgress.process_int_transit.tb_int_inst_0003",
"NoAction" : "FabricEgress.process_int_transit.tb_int_inst_0003"
},
"default_entry" : {
"action_id" : 53,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "FabricEgress.process_int_transit.tb_int_inst_0003",
"id" : 36,
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 237,
"column" : 10,
"source_fragment" : "tb_int_inst_0003"
},
"key" : [
{
"match_type" : "exact",
"name" : "hdr.int_header.instruction_mask_0003",
"target" : ["int_header", "instruction_mask_0003"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 16,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 54],
"actions" : ["FabricEgress.process_int_transit.int_set_header_0003_i0", "FabricEgress.process_int_transit.int_set_header_0003_i1", "FabricEgress.process_int_transit.int_set_header_0003_i2", "FabricEgress.process_int_transit.int_set_header_0003_i3", "FabricEgress.process_int_transit.int_set_header_0003_i4", "FabricEgress.process_int_transit.int_set_header_0003_i5", "FabricEgress.process_int_transit.int_set_header_0003_i6", "FabricEgress.process_int_transit.int_set_header_0003_i7", "FabricEgress.process_int_transit.int_set_header_0003_i8", "FabricEgress.process_int_transit.int_set_header_0003_i9", "FabricEgress.process_int_transit.int_set_header_0003_i10", "FabricEgress.process_int_transit.int_set_header_0003_i11", "FabricEgress.process_int_transit.int_set_header_0003_i12", "FabricEgress.process_int_transit.int_set_header_0003_i13", "FabricEgress.process_int_transit.int_set_header_0003_i14", "FabricEgress.process_int_transit.int_set_header_0003_i15", "NoAction"],
"base_default_next" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"next_tables" : {
"FabricEgress.process_int_transit.int_set_header_0003_i0" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i1" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i2" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i3" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i4" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i5" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i6" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i7" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i8" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i9" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i10" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i11" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i12" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i13" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i14" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"FabricEgress.process_int_transit.int_set_header_0003_i15" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"NoAction" : "FabricEgress.process_int_transit.tb_int_inst_0407"
},
"default_entry" : {
"action_id" : 54,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "FabricEgress.process_int_transit.tb_int_inst_0407",
"id" : 37,
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 264,
"column" : 10,
"source_fragment" : "tb_int_inst_0407"
},
"key" : [
{
"match_type" : "exact",
"name" : "hdr.int_header.instruction_mask_0407",
"target" : ["int_header", "instruction_mask_0407"],
"mask" : null
}
],
"match_type" : "exact",
"type" : "simple",
"max_size" : 16,
"with_counters" : true,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 55],
"actions" : ["FabricEgress.process_int_transit.int_set_header_0407_i0", "FabricEgress.process_int_transit.int_set_header_0407_i1", "FabricEgress.process_int_transit.int_set_header_0407_i2", "FabricEgress.process_int_transit.int_set_header_0407_i3", "FabricEgress.process_int_transit.int_set_header_0407_i4", "FabricEgress.process_int_transit.int_set_header_0407_i5", "FabricEgress.process_int_transit.int_set_header_0407_i6", "FabricEgress.process_int_transit.int_set_header_0407_i7", "FabricEgress.process_int_transit.int_set_header_0407_i8", "FabricEgress.process_int_transit.int_set_header_0407_i9", "FabricEgress.process_int_transit.int_set_header_0407_i10", "FabricEgress.process_int_transit.int_set_header_0407_i11", "FabricEgress.process_int_transit.int_set_header_0407_i12", "FabricEgress.process_int_transit.int_set_header_0407_i13", "FabricEgress.process_int_transit.int_set_header_0407_i14", "FabricEgress.process_int_transit.int_set_header_0407_i15", "NoAction"],
"base_default_next" : "tbl_process_int_transit_int_update_total_hop_cnt",
"next_tables" : {
"FabricEgress.process_int_transit.int_set_header_0407_i0" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i1" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i2" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i3" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i4" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i5" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i6" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i7" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i8" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i9" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i10" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i11" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i12" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i13" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i14" : "tbl_process_int_transit_int_update_total_hop_cnt",
"FabricEgress.process_int_transit.int_set_header_0407_i15" : "tbl_process_int_transit_int_update_total_hop_cnt",
"NoAction" : "tbl_process_int_transit_int_update_total_hop_cnt"
},
"default_entry" : {
"action_id" : 55,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "tbl_process_int_transit_int_update_total_hop_cnt",
"id" : 38,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [61],
"actions" : ["FabricEgress.process_int_transit.int_update_total_hop_cnt"],
"base_default_next" : "node_64",
"next_tables" : {
"FabricEgress.process_int_transit.int_update_total_hop_cnt" : "node_64"
},
"default_entry" : {
"action_id" : 61,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_process_int_outer_encap_int_update_ipv4",
"id" : 39,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [95],
"actions" : ["FabricEgress.process_int_outer_encap.int_update_ipv4"],
"base_default_next" : "node_66",
"next_tables" : {
"FabricEgress.process_int_outer_encap.int_update_ipv4" : "node_66"
},
"default_entry" : {
"action_id" : 95,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_process_int_outer_encap_int_update_udp",
"id" : 40,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [96],
"actions" : ["FabricEgress.process_int_outer_encap.int_update_udp"],
"base_default_next" : "node_68",
"next_tables" : {
"FabricEgress.process_int_outer_encap.int_update_udp" : "node_68"
},
"default_entry" : {
"action_id" : 96,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_process_int_outer_encap_int_update_shim",
"id" : 41,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [97],
"actions" : ["FabricEgress.process_int_outer_encap.int_update_shim"],
"base_default_next" : "node_70",
"next_tables" : {
"FabricEgress.process_int_outer_encap.int_update_shim" : "node_70"
},
"default_entry" : {
"action_id" : 97,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "FabricEgress.process_int_report.tb_generate_report",
"id" : 42,
"source_info" : {
"filename" : "include/int_report.p4",
"line" : 87,
"column" : 10,
"source_fragment" : "tb_generate_report"
},
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [98, 56],
"actions" : ["FabricEgress.process_int_report.do_report_encapsulation", "NoAction"],
"base_default_next" : "node_72",
"next_tables" : {
"FabricEgress.process_int_report.do_report_encapsulation" : "node_72",
"NoAction" : "node_72"
},
"default_entry" : {
"action_id" : 56,
"action_const" : false,
"action_data" : [],
"action_entry_const" : false
}
},
{
"name" : "tbl_process_int_sink_restore_header",
"id" : 43,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [99],
"actions" : ["FabricEgress.process_int_sink.restore_header"],
"base_default_next" : "tbl_process_int_sink_int_sink",
"next_tables" : {
"FabricEgress.process_int_sink.restore_header" : "tbl_process_int_sink_int_sink"
},
"default_entry" : {
"action_id" : 99,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
},
{
"name" : "tbl_process_int_sink_int_sink",
"id" : 44,
"key" : [],
"match_type" : "exact",
"type" : "simple",
"max_size" : 1024,
"with_counters" : false,
"support_timeout" : false,
"direct_meters" : null,
"action_ids" : [100],
"actions" : ["FabricEgress.process_int_sink.int_sink"],
"base_default_next" : null,
"next_tables" : {
"FabricEgress.process_int_sink.int_sink" : null
},
"default_entry" : {
"action_id" : 100,
"action_const" : true,
"action_data" : [],
"action_entry_const" : true
}
}
],
"action_profiles" : [],
"conditionals" : [
{
"name" : "node_47",
"id" : 14,
"source_info" : {
"filename" : "include/control/next.p4",
"line" : 272,
"column" : 12,
"source_fragment" : "fabric_metadata.is_multicast == true ..."
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "and",
"left" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.is_multicast"]
}
}
},
"right" : {
"type" : "bool",
"value" : true
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
}
}
}
}
},
"true_next" : "tbl_drop_now",
"false_next" : "FabricEgress.egress_next.egress_vlan"
},
{
"name" : "node_50",
"id" : 15,
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 42,
"column" : 12,
"source_fragment" : "standard_metadata.egress_port == 255"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0x00ff"
}
}
},
"true_next" : "node_51",
"false_next" : "node_56"
},
{
"name" : "node_51",
"id" : 16,
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 43,
"column" : 16,
"source_fragment" : "hdr.vlan_tag.isValid() && fabric_metadata.pop_vlan_when_packet_in == true"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "and",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["vlan_tag", "$valid$"]
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.pop_vlan_when_packet_in"]
}
}
},
"right" : {
"type" : "bool",
"value" : true
}
}
}
}
},
"true_next" : "tbl_pkt_io_egress_pop_vlan",
"false_next" : "node_53"
},
{
"name" : "node_53",
"id" : 17,
"source_info" : {
"filename" : "include/control/packetio.p4",
"line" : 46,
"column" : 16,
"source_fragment" : "fabric_metadata.is_multicast == true && ..."
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "and",
"left" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.is_multicast"]
}
}
},
"right" : {
"type" : "bool",
"value" : true
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["scalars", "fabric_metadata_t.clone_to_cpu"]
}
}
},
"right" : {
"type" : "bool",
"value" : false
}
}
}
}
},
"true_next" : "tbl_drop_now_0",
"false_next" : "tbl_act_16"
},
{
"name" : "node_56",
"id" : 18,
"source_info" : {
"filename" : "fabric.p4",
"line" : 94,
"column" : 12,
"source_fragment" : "standard_metadata.ingress_port != 255 && ..."
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "and",
"left" : {
"type" : "expression",
"value" : {
"op" : "and",
"left" : {
"type" : "expression",
"value" : {
"op" : "!=",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "ingress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0x00ff"
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "!=",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "egress_port"]
},
"right" : {
"type" : "hexstr",
"value" : "0x00ff"
}
}
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "or",
"left" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["udp", "$valid$"]
}
}
},
"right" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["tcp", "$valid$"]
}
}
}
}
}
}
},
"false_next" : null,
"true_next" : "node_57"
},
{
"name" : "node_57",
"id" : 19,
"source_info" : {
"filename" : "fabric.p4",
"line" : 97,
"column" : 16,
"source_fragment" : "fabric_metadata.int_meta.source == 1"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["userMetadata.int_meta", "source"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
},
"true_next" : "FabricEgress.process_int_source.tb_int_source",
"false_next" : "node_59"
},
{
"name" : "node_59",
"id" : 20,
"source_info" : {
"filename" : "fabric.p4",
"line" : 100,
"column" : 15,
"source_fragment" : "hdr.int_header.isValid()"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["int_header", "$valid$"]
}
}
},
"false_next" : null,
"true_next" : "FabricEgress.process_int_transit.tb_int_insert"
},
{
"name" : "node_64",
"id" : 21,
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 314,
"column" : 12,
"source_fragment" : "hdr.ipv4.isValid()"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["ipv4", "$valid$"]
}
}
},
"true_next" : "tbl_process_int_outer_encap_int_update_ipv4",
"false_next" : "node_66"
},
{
"name" : "node_66",
"id" : 22,
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 317,
"column" : 12,
"source_fragment" : "hdr.udp.isValid()"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["udp", "$valid$"]
}
}
},
"true_next" : "tbl_process_int_outer_encap_int_update_udp",
"false_next" : "node_68"
},
{
"name" : "node_68",
"id" : 23,
"source_info" : {
"filename" : "include/int_transit.p4",
"line" : 320,
"column" : 12,
"source_fragment" : "hdr.intl4_shim.isValid()"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["intl4_shim", "$valid$"]
}
}
},
"true_next" : "tbl_process_int_outer_encap_int_update_shim",
"false_next" : "node_70"
},
{
"name" : "node_70",
"id" : 24,
"source_info" : {
"filename" : "fabric.p4",
"line" : 104,
"column" : 20,
"source_fragment" : "standard_metadata.instance_type == 1"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["standard_metadata", "instance_type"]
},
"right" : {
"type" : "hexstr",
"value" : "0x00000001"
}
}
},
"true_next" : "FabricEgress.process_int_report.tb_generate_report",
"false_next" : "node_72"
},
{
"name" : "node_72",
"id" : 25,
"source_info" : {
"filename" : "fabric.p4",
"line" : 108,
"column" : 20,
"source_fragment" : "fabric_metadata.int_meta.sink == 1"
},
"expression" : {
"type" : "expression",
"value" : {
"op" : "==",
"left" : {
"type" : "field",
"value" : ["userMetadata.int_meta", "sink"]
},
"right" : {
"type" : "hexstr",
"value" : "0x01"
}
}
},
"false_next" : null,
"true_next" : "tbl_process_int_sink_restore_header"
}
]
}
],
"checksums" : [
{
"name" : "cksum",
"id" : 0,
"target" : ["ipv4", "hdr_checksum"],
"type" : "generic",
"calculation" : "calc",
"if_cond" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["ipv4", "$valid$"]
}
}
}
},
{
"name" : "cksum_0",
"id" : 1,
"target" : ["ipv4", "hdr_checksum"],
"type" : "generic",
"calculation" : "calc_0",
"if_cond" : {
"type" : "expression",
"value" : {
"op" : "d2b",
"left" : null,
"right" : {
"type" : "field",
"value" : ["ipv4", "$valid$"]
}
}
}
}
],
"force_arith" : [],
"extern_instances" : [],
"field_aliases" : [
[
"queueing_metadata.enq_timestamp",
["standard_metadata", "enq_timestamp"]
],
[
"queueing_metadata.enq_qdepth",
["standard_metadata", "enq_qdepth"]
],
[
"queueing_metadata.deq_timedelta",
["standard_metadata", "deq_timedelta"]
],
[
"queueing_metadata.deq_qdepth",
["standard_metadata", "deq_qdepth"]
],
[
"intrinsic_metadata.ingress_global_timestamp",
["standard_metadata", "ingress_global_timestamp"]
],
[
"intrinsic_metadata.egress_global_timestamp",
["standard_metadata", "egress_global_timestamp"]
],
[
"intrinsic_metadata.lf_field_list",
["standard_metadata", "lf_field_list"]
],
[
"intrinsic_metadata.mcast_grp",
["standard_metadata", "mcast_grp"]
],
[
"intrinsic_metadata.resubmit_flag",
["standard_metadata", "resubmit_flag"]
],
[
"intrinsic_metadata.egress_rid",
["standard_metadata", "egress_rid"]
],
[
"intrinsic_metadata.recirculate_flag",
["standard_metadata", "recirculate_flag"]
]
],
"program" : "fabric.p4",
"__meta__" : {
"version" : [2, 18],
"compiler" : "https://github.com/p4lang/p4c"
}
}