Max level shown:
1 
2 CLOT Allocation (ingress):
3 +------+-------------------------------------------------+---------------+-----------+
4 | CLOT | Fields | Bits | Property |
5 +------+-------------------------------------------------+---------------+-----------+
6 | 0 | state ingress::parse_arp | 28 bytes | |
7 | | | | |
8 | | ingress::hdr.arp.hw_type | 16 [0..15] | |
9 | | ingress::hdr.arp.proto_type | 16 [16..31] | |
10 | | ingress::hdr.arp.hw_addr_len | 8 [32..39] | |
11 | | ingress::hdr.arp.proto_addr_len | 8 [40..47] | |
12 | | ingress::hdr.arp.opcode | 16 [48..63] | |
13 | | ingress::hdr.arp.sender_mac | 48 [64..111] | |
14 | | ingress::hdr.arp.sender_ip | 32 [112..143] | |
15 | | ingress::hdr.arp.target_mac | 48 [144..191] | |
16 | | ingress::hdr.arp.target_ip | 32 [192..223] | |
17 +------+-------------------------------------------------+---------------+-----------+
18 | 1 | state ingress::parse_geneve_mss_tag | 8 bytes | |
19 | | | | |
20 | | ingress::hdr.geneve_opts.oxg_mss_tag.class | 16 [0..15] | |
21 | | ingress::hdr.geneve_opts.oxg_mss_tag.crit | 1 [16..16] | |
22 | | ingress::hdr.geneve_opts.oxg_mss_tag.type | 7 [17..23] | |
23 | | ingress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 [24..26] | |
24 | | ingress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 [27..31] | |
25 | | ingress::hdr.geneve_opts.oxg_mss.mss | 32 [32..63] | |
26 +------+-------------------------------------------------+---------------+-----------+
27 | 2 | state ingress::parse_geneve_mcast_tag | 8 bytes | |
28 | | | | |
29 | | ingress::hdr.geneve_opts.oxg_mcast_tag.class | 16 [0..15] | |
30 | | ingress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 [16..16] | |
31 | | ingress::hdr.geneve_opts.oxg_mcast_tag.type | 7 [17..23] | |
32 | | ingress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 [24..26] | |
33 | | ingress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 [27..31] | |
34 | | ingress::hdr.geneve_opts.oxg_mcast.mcast_tag | 2 [32..33] | ( phv ) |
35 | | ingress::hdr.geneve_opts.oxg_mcast.reserved | 30 [34..63] | |
36 +------+-------------------------------------------------+---------------+-----------+
37 | | Total Bits | 352 | |
38 +------+-------------------------------------------------+---------------+-----------+
39 
40 Packets will use up to 1 CLOTs.
41 The parser path(s) that will use the most CLOTs contain the following states:
42 ingress::parse_inner_tcp (0 CLOTs)
43 ingress::parse_inner_udp (0 CLOTs)
44 ingress::parse_inner_icmp (0 CLOTs)
45 ingress::parse_inner_ipv4 (0 CLOTs)
46 ingress::parse_inner_ipv6 (0 CLOTs)
47 ingress::parse_inner_eth (0 CLOTs)
48 ingress::geneve_parsed (0 CLOTs)
49 ingress::geneve_bad_size (0 CLOTs)
50 ingress::geneve_opt_parsed (0 CLOTs)
51 ingress::geneve_malformed (0 CLOTs)
52 ingress::parse_geneve_mcast_tag (1 CLOTs)
53 ingress::parse_geneve_mss_tag (1 CLOTs)
54 ingress::parse_geneve_ox_opt (0 CLOTs)
55 ingress::parse_geneve_opt (0 CLOTs)
56 ingress::parse_geneve (0 CLOTs)
57 ingress::parse_udp (0 CLOTs)
58 ingress::goto_proto_ipv4 (0 CLOTs)
59 ingress::set_mcast_ipv4 (0 CLOTs)
60 ingress::validate_ipv4_mcast_3 (0 CLOTs)
61 ingress::validate_ipv4_mcast1_2 (0 CLOTs)
62 ingress::validate_ttl (0 CLOTs)
63 ingress::parse_ipv4 (0 CLOTs)
64 ingress::goto_proto_ipv6 (0 CLOTs)
65 ingress::set_link_local_mcast (0 CLOTs)
66 ingress::set_mcast_ipv6 (0 CLOTs)
67 ingress::validate_hop_limit (0 CLOTs)
68 ingress::check_ipv6_mcast (0 CLOTs)
69 ingress::parse_ipv6 (0 CLOTs)
70 ingress::parse_arp (1 CLOTs)
71 ingress::parse_vlan (0 CLOTs)
72 ingress::parse_sidecar (0 CLOTs)
73 $entry_point.start (0 CLOTs)
74 
75 CLOT Allocation (egress):
76 +------+------------------------------------------------+----------------+------------+
77 | CLOT | Fields | Bits | Property |
78 +------+------------------------------------------------+----------------+------------+
79 | 0 | state egress::parse_ipv6 | 40 bytes | |
80 | | | | |
81 | | egress::hdr.ipv6.version | 4 [0..3] | |
82 | | egress::hdr.ipv6.traffic_class | 8 [4..11] | |
83 | | egress::hdr.ipv6.flow_label | 20 [12..31] | |
84 | | egress::hdr.ipv6.payload_len | 16 [32..47] | |
85 | | egress::hdr.ipv6.next_hdr | 8 [48..55] | |
86 | | egress::hdr.ipv6.hop_limit | 8 [56..63] | |
87 | | egress::hdr.ipv6.src_addr | 128 [64..191] | |
88 | | egress::hdr.ipv6.dst_addr | 128 [192..319] | ( phv ) |
89 +------+------------------------------------------------+----------------+------------+
90 | 1 | state egress::parse_inner_ipv6 | 40 bytes | |
91 | | | | |
92 | | egress::hdr.inner_ipv6.version | 4 [0..3] | |
93 | | egress::hdr.inner_ipv6.traffic_class | 8 [4..11] | |
94 | | egress::hdr.inner_ipv6.flow_label | 20 [12..31] | |
95 | | egress::hdr.inner_ipv6.payload_len | 16 [32..47] | |
96 | | egress::hdr.inner_ipv6.next_hdr | 8 [48..55] | |
97 | | egress::hdr.inner_ipv6.hop_limit | 8 [56..63] | ( phv* ) |
98 | | egress::hdr.inner_ipv6.src_addr | 128 [64..191] | |
99 | | egress::hdr.inner_ipv6.dst_addr | 128 [192..319] | ( phv ) |
100 +------+------------------------------------------------+----------------+------------+
101 | 2 | state egress::parse_inner_tcp | 20 bytes | |
102 | | | | |
103 | | egress::hdr.inner_tcp.src_port | 16 [0..15] | |
104 | | egress::hdr.inner_tcp.dst_port | 16 [16..31] | |
105 | | egress::hdr.inner_tcp.seq_no | 32 [32..63] | |
106 | | egress::hdr.inner_tcp.ack_no | 32 [64..95] | |
107 | | egress::hdr.inner_tcp.data_offset | 4 [96..99] | |
108 | | egress::hdr.inner_tcp.res | 4 [100..103] | |
109 | | egress::hdr.inner_tcp.flags | 8 [104..111] | |
110 | | egress::hdr.inner_tcp.window | 16 [112..127] | |
111 | | egress::hdr.inner_tcp.checksum | 16 [128..143] | |
112 | | egress::hdr.inner_tcp.urgent_ptr | 16 [144..159] | |
113 +------+------------------------------------------------+----------------+------------+
114 | 3 | state egress::parse_ipv4 | 20 bytes | |
115 | | | | |
116 | | egress::hdr.ipv4.version | 4 [0..3] | |
117 | | egress::hdr.ipv4.ihl | 4 [4..7] | |
118 | | egress::hdr.ipv4.diffserv | 8 [8..15] | |
119 | | egress::hdr.ipv4.total_len | 16 [16..31] | |
120 | | egress::hdr.ipv4.identification | 16 [32..47] | |
121 | | egress::hdr.ipv4.flags | 3 [48..50] | |
122 | | egress::hdr.ipv4.frag_offset | 13 [51..63] | |
123 | | egress::hdr.ipv4.ttl | 8 [64..71] | |
124 | | egress::hdr.ipv4.protocol | 8 [72..79] | |
125 | | egress::hdr.ipv4.hdr_checksum | 16 [80..95] | |
126 | | egress::hdr.ipv4.src_addr | 32 [96..127] | |
127 | | egress::hdr.ipv4.dst_addr | 32 [128..159] | ( phv ) |
128 +------+------------------------------------------------+----------------+------------+
129 | 4 | state egress::parse_inner_eth | 11 bytes | |
130 | | | | |
131 | | egress::hdr.inner_eth.dst_mac | 48 [0..47] | |
132 | | egress::hdr.inner_eth.src_mac[47:8] | 40 [48..87] | |
133 +------+------------------------------------------------+----------------+------------+
134 | 5 | state egress::parse_inner_ipv4 | 10 bytes | |
135 | | | | |
136 | | egress::hdr.inner_ipv4.version | 4 [0..3] | |
137 | | egress::hdr.inner_ipv4.ihl | 4 [4..7] | |
138 | | egress::hdr.inner_ipv4.diffserv | 8 [8..15] | |
139 | | egress::hdr.inner_ipv4.total_len | 16 [16..31] | |
140 | | egress::hdr.inner_ipv4.identification | 16 [32..47] | |
141 | | egress::hdr.inner_ipv4.flags | 3 [48..50] | |
142 | | egress::hdr.inner_ipv4.frag_offset | 13 [51..63] | |
143 | | egress::hdr.inner_ipv4.ttl | 8 [64..71] | ( phv* ) |
144 | | egress::hdr.inner_ipv4.protocol | 8 [72..79] | |
145 +------+------------------------------------------------+----------------+------------+
146 | 6 | state egress::parse_inner_udp | 8 bytes | |
147 | | | | |
148 | | egress::hdr.inner_udp.src_port | 16 [0..15] | |
149 | | egress::hdr.inner_udp.dst_port | 16 [16..31] | |
150 | | egress::hdr.inner_udp.hdr_length | 16 [32..47] | |
151 | | egress::hdr.inner_udp.checksum | 16 [48..63] | |
152 +------+------------------------------------------------+----------------+------------+
153 | 7 | state egress::parse_udp | 8 bytes | |
154 | | | | |
155 | | egress::hdr.udp.src_port | 16 [0..15] | |
156 | | egress::hdr.udp.dst_port | 16 [16..31] | |
157 | | egress::hdr.udp.hdr_length | 16 [32..47] | |
158 | | egress::hdr.udp.checksum | 16 [48..63] | |
159 +------+------------------------------------------------+----------------+------------+
160 | 8 | state egress::parse_icmp | 5 bytes | |
161 | | | | |
162 | | egress::hdr.icmp.hdr_checksum[7:0] | 8 [0..7] | |
163 | | egress::hdr.icmp.data | 32 [8..39] | |
164 +------+------------------------------------------------+----------------+------------+
165 | 9 | state egress::parse_geneve | 5 bytes | |
166 | | | | |
167 | | egress::hdr.geneve.version | 2 [0..1] | |
168 | | egress::hdr.geneve.opt_len | 6 [2..7] | |
169 | | egress::hdr.geneve.ctrl | 1 [8..8] | |
170 | | egress::hdr.geneve.crit | 1 [9..9] | |
171 | | egress::hdr.geneve.reserved | 6 [10..15] | |
172 | | egress::hdr.geneve.protocol | 16 [16..31] | |
173 | | egress::hdr.geneve.vni[23:16] | 8 [32..39] | |
174 +------+------------------------------------------------+----------------+------------+
175 | 10 | state egress::parse_geneve_mss_tag | 4 bytes | |
176 | | | | |
177 | | egress::hdr.geneve_opts.oxg_mss_tag.class | 16 [0..15] | |
178 | | egress::hdr.geneve_opts.oxg_mss_tag.crit | 1 [16..16] | |
179 | | egress::hdr.geneve_opts.oxg_mss_tag.type | 7 [17..23] | |
180 | | egress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 [24..26] | |
181 | | egress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 [27..31] | |
182 +------+------------------------------------------------+----------------+------------+
183 | 11 | state egress::parse_geneve_mcast_tag | 4 bytes | |
184 | | | | |
185 | | egress::hdr.geneve_opts.oxg_mcast_tag.class | 16 [0..15] | |
186 | | egress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 [16..16] | |
187 | | egress::hdr.geneve_opts.oxg_mcast_tag.type | 7 [17..23] | |
188 | | egress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 [24..26] | |
189 | | egress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 [27..31] | |
190 +------+------------------------------------------------+----------------+------------+
191 | 12 | state egress::parse_inner_ipv4 | 7 bytes | |
192 | | | | |
193 | | egress::hdr.inner_ipv4.src_addr[23:0] | 24 [0..23] | |
194 | | egress::hdr.inner_ipv4.dst_addr | 32 [24..55] | ( phv ) |
195 +------+------------------------------------------------+----------------+------------+
196 | | Total Bits | 1456 | |
197 +------+------------------------------------------------+----------------+------------+
198 
199 Packets will use up to 8 CLOTs.
200 The parser path(s) that will use the most CLOTs contain the following states:
201 egress::parse_inner_tcp (1 CLOTs)
202 egress::parse_inner_udp (1 CLOTs)
203 egress::parse_inner_ipv4 (2 CLOTs)
204 egress::parse_inner_eth (1 CLOTs)
205 egress::geneve_parsed (0 CLOTs)
206 egress::geneve_opt_parsed (0 CLOTs)
207 egress::parse_geneve_mcast_tag (1 CLOTs)
208 egress::parse_geneve_mss_tag (1 CLOTs)
209 egress::parse_geneve_ox_opt (0 CLOTs)
210 egress::parse_geneve_opt (0 CLOTs)
211 egress::parse_geneve (1 CLOTs)
212 egress::parse_udp (1 CLOTs)
213 egress::parse_ipv4 (1 CLOTs)
214 egress::parse_ipv6 (1 CLOTs)
215 egress::parse_vlan (0 CLOTs)
216 $entry_point.start (0 CLOTs)
217 
218 All fields:
219 +-------------------------------------------------+------+-------+-----------+
220 | Field | Bits | CLOTs | Property |
221 +-------------------------------------------------+------+-------+-----------+
222 | ingress::ig_intr_md.ingress_port | 9 | | read-only |
223 | ingress::meta.bridge_hdr.ingress_port | 9 | | unused |
224 | ingress::hdr.ethernet.dst_mac | 48 | | modified |
225 | ingress::hdr.ethernet.src_mac | 48 | | modified |
226 | ingress::hdr.ethernet.ether_type | 16 | | modified |
227 | ingress::meta.orig_src_mac | 48 | | read-only |
228 | ingress::hdr.sidecar.sc_code | 8 | | modified |
229 | ingress::hdr.sidecar.sc_pad | 8 | | unused |
230 | ingress::hdr.sidecar.sc_ingress | 16 | | modified |
231 | ingress::hdr.sidecar.sc_egress | 16 | | modified |
232 | ingress::hdr.sidecar.sc_ether_type | 16 | | modified |
233 | ingress::hdr.sidecar.sc_payload | 128 | | modified |
234 | ingress::hdr.vlan.pcp | 3 | | modified |
235 | ingress::hdr.vlan.dei | 1 | | modified |
236 | ingress::hdr.vlan.vlan_id | 12 | | modified |
237 | ingress::hdr.vlan.ether_type | 16 | | modified |
238 | ingress::hdr.ipv4.version | 4 | | modified |
239 | ingress::hdr.ipv4.ihl | 4 | | modified |
240 | ingress::hdr.ipv4.diffserv | 8 | | modified |
241 | ingress::hdr.ipv4.total_len | 16 | | modified |
242 | ingress::hdr.ipv4.identification | 16 | | modified |
243 | ingress::hdr.ipv4.flags | 3 | | modified |
244 | ingress::hdr.ipv4.frag_offset | 13 | | modified |
245 | ingress::hdr.ipv4.ttl | 8 | | modified |
246 | ingress::hdr.ipv4.protocol | 8 | | modified |
247 | ingress::hdr.ipv4.hdr_checksum | 16 | | checksum |
248 | ingress::hdr.ipv4.src_addr | 32 | | modified |
249 | ingress::hdr.ipv4.dst_addr | 32 | | modified |
250 | ingress::meta.orig_src_ipv4 | 32 | | read-only |
251 | ingress::meta.orig_dst_ipv4 | 32 | | read-only |
252 | ingress::hdr.icmp.type | 8 | | modified |
253 | ingress::hdr.icmp.code | 8 | | modified |
254 | ingress::hdr.icmp.hdr_checksum | 16 | | checksum |
255 | ingress::hdr.icmp.data | 32 | | modified |
256 | ingress::hdr.tcp.src_port | 16 | | modified |
257 | ingress::hdr.tcp.dst_port | 16 | | modified |
258 | ingress::hdr.tcp.seq_no | 32 | | modified |
259 | ingress::hdr.tcp.ack_no | 32 | | modified |
260 | ingress::hdr.tcp.data_offset | 4 | | modified |
261 | ingress::hdr.tcp.res | 4 | | modified |
262 | ingress::hdr.tcp.flags | 8 | | modified |
263 | ingress::hdr.tcp.window | 16 | | modified |
264 | ingress::hdr.tcp.checksum | 16 | | modified |
265 | ingress::hdr.tcp.urgent_ptr | 16 | | modified |
266 | ingress::meta.l4_src_port | 16 | | read-only |
267 | ingress::meta.l4_dst_port | 16 | | modified |
268 | ingress::hdr.udp.src_port | 16 | | modified |
269 | ingress::hdr.udp.dst_port | 16 | | modified |
270 | ingress::hdr.udp.hdr_length | 16 | | modified |
271 | ingress::hdr.udp.checksum | 16 | | checksum |
272 | ingress::hdr.geneve.version | 2 | | modified |
273 | ingress::hdr.geneve.opt_len | 6 | | modified |
274 | ingress::hdr.geneve.ctrl | 1 | | modified |
275 | ingress::hdr.geneve.crit | 1 | | modified |
276 | ingress::hdr.geneve.reserved | 6 | | modified |
277 | ingress::hdr.geneve.protocol | 16 | | modified |
278 | ingress::hdr.geneve.vni | 24 | | modified |
279 | ingress::hdr.geneve.reserved2 | 8 | | modified |
280 | ingress::hdr.inner_eth.dst_mac | 48 | | modified |
281 | ingress::hdr.inner_eth.src_mac | 48 | | modified |
282 | ingress::hdr.inner_eth.ether_type | 16 | | modified |
283 | ingress::hdr.inner_ipv4.version | 4 | | modified |
284 | ingress::hdr.inner_ipv4.ihl | 4 | | modified |
285 | ingress::hdr.inner_ipv4.diffserv | 8 | | modified |
286 | ingress::hdr.inner_ipv4.total_len | 16 | | modified |
287 | ingress::hdr.inner_ipv4.identification | 16 | | modified |
288 | ingress::hdr.inner_ipv4.flags | 3 | | modified |
289 | ingress::hdr.inner_ipv4.frag_offset | 13 | | modified |
290 | ingress::hdr.inner_ipv4.ttl | 8 | | modified |
291 | ingress::hdr.inner_ipv4.protocol | 8 | | modified |
292 | ingress::hdr.inner_ipv4.hdr_checksum | 16 | | modified |
293 | ingress::hdr.inner_ipv4.src_addr | 32 | | modified |
294 | ingress::hdr.inner_ipv4.dst_addr | 32 | | modified |
295 | ingress::hdr.inner_tcp.src_port | 16 | | modified |
296 | ingress::hdr.inner_tcp.dst_port | 16 | | modified |
297 | ingress::hdr.inner_tcp.seq_no | 32 | | modified |
298 | ingress::hdr.inner_tcp.ack_no | 32 | | modified |
299 | ingress::hdr.inner_tcp.data_offset | 4 | | modified |
300 | ingress::hdr.inner_tcp.res | 4 | | modified |
301 | ingress::hdr.inner_tcp.flags | 8 | | modified |
302 | ingress::hdr.inner_tcp.window | 16 | | modified |
303 | ingress::hdr.inner_tcp.checksum | 16 | | modified |
304 | ingress::hdr.inner_tcp.urgent_ptr | 16 | | modified |
305 | ingress::hdr.inner_udp.src_port | 16 | | modified |
306 | ingress::hdr.inner_udp.dst_port | 16 | | modified |
307 | ingress::hdr.inner_udp.hdr_length | 16 | | modified |
308 | ingress::hdr.inner_udp.checksum | 16 | | modified |
309 | ingress::hdr.inner_icmp.type | 8 | | modified |
310 | ingress::hdr.inner_icmp.code | 8 | | modified |
311 | ingress::hdr.inner_icmp.hdr_checksum | 16 | | modified |
312 | ingress::hdr.inner_icmp.data | 32 | | modified |
313 | ingress::hdr.inner_ipv6.version | 4 | | modified |
314 | ingress::hdr.inner_ipv6.traffic_class | 8 | | modified |
315 | ingress::hdr.inner_ipv6.flow_label | 20 | | modified |
316 | ingress::hdr.inner_ipv6.payload_len | 16 | | modified |
317 | ingress::hdr.inner_ipv6.next_hdr | 8 | | modified |
318 | ingress::hdr.inner_ipv6.hop_limit | 8 | | modified |
319 | ingress::hdr.inner_ipv6.src_addr | 128 | | modified |
320 | ingress::hdr.inner_ipv6.dst_addr | 128 | | modified |
321 | ingress::hdr.geneve_opts.oxg_ext_tag.class | 16 | | modified |
322 | ingress::hdr.geneve_opts.oxg_ext_tag.crit | 1 | | modified |
323 | ingress::hdr.geneve_opts.oxg_ext_tag.type | 7 | | modified |
324 | ingress::hdr.geneve_opts.oxg_ext_tag.reserved | 3 | | modified |
325 | ingress::hdr.geneve_opts.oxg_ext_tag.opt_len | 5 | | modified |
326 | ingress::hdr.geneve_opts.oxg_mcast_tag.class | 16 | 2 | unused |
327 | ingress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 | 2 | unused |
328 | ingress::hdr.geneve_opts.oxg_mcast_tag.type | 7 | 2 | unused |
329 | ingress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 | 2 | unused |
330 | ingress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 | 2 | unused |
331 | ingress::hdr.geneve_opts.oxg_mcast.mcast_tag | 2 | 2 | read-only |
332 | ingress::hdr.geneve_opts.oxg_mcast.reserved | 30 | 2 | unused |
333 | ingress::hdr.geneve_opts.oxg_mss_tag.class | 16 | 1 | unused |
334 | ingress::hdr.geneve_opts.oxg_mss_tag.crit | 1 | 1 | unused |
335 | ingress::hdr.geneve_opts.oxg_mss_tag.type | 7 | 1 | unused |
336 | ingress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 | 1 | unused |
337 | ingress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 | 1 | unused |
338 | ingress::hdr.geneve_opts.oxg_mss.mss | 32 | 1 | unused |
339 | ingress::hdr.ipv6.version | 4 | | modified |
340 | ingress::hdr.ipv6.traffic_class | 8 | | modified |
341 | ingress::hdr.ipv6.flow_label | 20 | | modified |
342 | ingress::hdr.ipv6.payload_len | 16 | | modified |
343 | ingress::hdr.ipv6.next_hdr | 8 | | modified |
344 | ingress::hdr.ipv6.hop_limit | 8 | | modified |
345 | ingress::hdr.ipv6.src_addr | 128 | | modified |
346 | ingress::hdr.ipv6.dst_addr | 128 | | modified |
347 | ingress::hdr.arp.hw_type | 16 | 0 | unused |
348 | ingress::hdr.arp.proto_type | 16 | 0 | unused |
349 | ingress::hdr.arp.hw_addr_len | 8 | 0 | unused |
350 | ingress::hdr.arp.proto_addr_len | 8 | 0 | unused |
351 | ingress::hdr.arp.opcode | 16 | 0 | unused |
352 | ingress::hdr.arp.sender_mac | 48 | 0 | unused |
353 | ingress::hdr.arp.sender_ip | 32 | 0 | unused |
354 | ingress::hdr.arp.target_mac | 48 | 0 | unused |
355 | ingress::hdr.arp.target_ip | 32 | 0 | unused |
356 | egress::eg_intr_md.egress_port | 9 | | read-only |
357 | egress::eg_intr_md.egress_rid | 16 | | read-only |
358 | egress::eg_intr_md.egress_rid_first | 1 | | read-only |
359 | egress::meta.bridge_hdr.ingress_port | 9 | | read-only |
360 | egress::hdr.ethernet.dst_mac | 48 | | modified |
361 | egress::hdr.ethernet.src_mac | 48 | | modified |
362 | egress::hdr.ethernet.ether_type | 16 | | modified |
363 | egress::hdr.vlan.pcp | 3 | | modified |
364 | egress::hdr.vlan.dei | 1 | | modified |
365 | egress::hdr.vlan.vlan_id | 12 | | modified |
366 | egress::hdr.vlan.ether_type | 16 | | modified |
367 | egress::hdr.ipv4.version | 4 | 3 | unused |
368 | egress::hdr.ipv4.ihl | 4 | 3 | unused |
369 | egress::hdr.ipv4.diffserv | 8 | 3 | unused |
370 | egress::hdr.ipv4.total_len | 16 | 3 | unused |
371 | egress::hdr.ipv4.identification | 16 | 3 | unused |
372 | egress::hdr.ipv4.flags | 3 | 3 | unused |
373 | egress::hdr.ipv4.frag_offset | 13 | 3 | unused |
374 | egress::hdr.ipv4.ttl | 8 | 3 | unused |
375 | egress::hdr.ipv4.protocol | 8 | 3 | unused |
376 | egress::hdr.ipv4.hdr_checksum | 16 | 3 | unused |
377 | egress::hdr.ipv4.src_addr | 32 | 3 | unused |
378 | egress::hdr.ipv4.dst_addr | 32 | 3 | read-only |
379 | egress::hdr.icmp.type | 8 | | unused |
380 | egress::hdr.icmp.code | 8 | | unused |
381 | egress::hdr.icmp.hdr_checksum | 16 | 8 | unused |
382 | egress::hdr.icmp.data | 32 | 8 | unused |
383 | egress::hdr.udp.src_port | 16 | 7 | unused |
384 | egress::hdr.udp.dst_port | 16 | 7 | unused |
385 | egress::hdr.udp.hdr_length | 16 | 7 | unused |
386 | egress::hdr.udp.checksum | 16 | 7 | unused |
387 | egress::hdr.geneve.version | 2 | 9 | unused |
388 | egress::hdr.geneve.opt_len | 6 | 9 | unused |
389 | egress::hdr.geneve.ctrl | 1 | 9 | unused |
390 | egress::hdr.geneve.crit | 1 | 9 | unused |
391 | egress::hdr.geneve.reserved | 6 | 9 | unused |
392 | egress::hdr.geneve.protocol | 16 | 9 | unused |
393 | egress::hdr.geneve.vni | 24 | 9 | unused |
394 | egress::hdr.geneve.reserved2 | 8 | | unused |
395 | egress::hdr.inner_eth.dst_mac | 48 | 4 | unused |
396 | egress::hdr.inner_eth.src_mac | 48 | 4 | unused |
397 | egress::hdr.inner_eth.ether_type | 16 | | unused |
398 | egress::hdr.inner_ipv4.version | 4 | 5 | unused |
399 | egress::hdr.inner_ipv4.ihl | 4 | 5 | unused |
400 | egress::hdr.inner_ipv4.diffserv | 8 | 5 | unused |
401 | egress::hdr.inner_ipv4.total_len | 16 | 5 | unused |
402 | egress::hdr.inner_ipv4.identification | 16 | 5 | unused |
403 | egress::hdr.inner_ipv4.flags | 3 | 5 | unused |
404 | egress::hdr.inner_ipv4.frag_offset | 13 | 5 | unused |
405 | egress::hdr.inner_ipv4.ttl | 8 | 5 | modified |
406 | egress::hdr.inner_ipv4.protocol | 8 | 5 | unused |
407 | egress::hdr.inner_ipv4.hdr_checksum | 16 | | checksum |
408 | egress::hdr.inner_ipv4.src_addr | 32 | 12 | unused |
409 | egress::hdr.inner_ipv4.dst_addr | 32 | 12 | read-only |
410 | egress::hdr.inner_tcp.src_port | 16 | 2 | unused |
411 | egress::hdr.inner_tcp.dst_port | 16 | 2 | unused |
412 | egress::hdr.inner_tcp.seq_no | 32 | 2 | unused |
413 | egress::hdr.inner_tcp.ack_no | 32 | 2 | unused |
414 | egress::hdr.inner_tcp.data_offset | 4 | 2 | unused |
415 | egress::hdr.inner_tcp.res | 4 | 2 | unused |
416 | egress::hdr.inner_tcp.flags | 8 | 2 | unused |
417 | egress::hdr.inner_tcp.window | 16 | 2 | unused |
418 | egress::hdr.inner_tcp.checksum | 16 | 2 | unused |
419 | egress::hdr.inner_tcp.urgent_ptr | 16 | 2 | unused |
420 | egress::hdr.inner_udp.src_port | 16 | 6 | unused |
421 | egress::hdr.inner_udp.dst_port | 16 | 6 | unused |
422 | egress::hdr.inner_udp.hdr_length | 16 | 6 | unused |
423 | egress::hdr.inner_udp.checksum | 16 | 6 | unused |
424 | egress::hdr.inner_ipv6.version | 4 | 1 | unused |
425 | egress::hdr.inner_ipv6.traffic_class | 8 | 1 | unused |
426 | egress::hdr.inner_ipv6.flow_label | 20 | 1 | unused |
427 | egress::hdr.inner_ipv6.payload_len | 16 | 1 | unused |
428 | egress::hdr.inner_ipv6.next_hdr | 8 | 1 | unused |
429 | egress::hdr.inner_ipv6.hop_limit | 8 | 1 | modified |
430 | egress::hdr.inner_ipv6.src_addr | 128 | 1 | unused |
431 | egress::hdr.inner_ipv6.dst_addr | 128 | 1 | read-only |
432 | egress::hdr.geneve_opts.oxg_ext_tag.class | 16 | | unused |
433 | egress::hdr.geneve_opts.oxg_ext_tag.crit | 1 | | unused |
434 | egress::hdr.geneve_opts.oxg_ext_tag.type | 7 | | unused |
435 | egress::hdr.geneve_opts.oxg_ext_tag.reserved | 3 | | unused |
436 | egress::hdr.geneve_opts.oxg_ext_tag.opt_len | 5 | | unused |
437 | egress::hdr.geneve_opts.oxg_mcast_tag.class | 16 | 11 | unused |
438 | egress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 | 11 | unused |
439 | egress::hdr.geneve_opts.oxg_mcast_tag.type | 7 | 11 | unused |
440 | egress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 | 11 | unused |
441 | egress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 | 11 | unused |
442 | egress::hdr.geneve_opts.oxg_mcast.mcast_tag | 2 | | read-only |
443 | egress::hdr.geneve_opts.oxg_mcast.reserved | 30 | | unused |
444 | egress::hdr.geneve_opts.oxg_mss_tag.class | 16 | 10 | unused |
445 | egress::hdr.geneve_opts.oxg_mss_tag.crit | 1 | 10 | unused |
446 | egress::hdr.geneve_opts.oxg_mss_tag.type | 7 | 10 | unused |
447 | egress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 | 10 | unused |
448 | egress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 | 10 | unused |
449 | egress::hdr.geneve_opts.oxg_mss.mss | 32 | | unused |
450 | egress::hdr.ipv6.version | 4 | 0 | unused |
451 | egress::hdr.ipv6.traffic_class | 8 | 0 | unused |
452 | egress::hdr.ipv6.flow_label | 20 | 0 | unused |
453 | egress::hdr.ipv6.payload_len | 16 | 0 | unused |
454 | egress::hdr.ipv6.next_hdr | 8 | 0 | unused |
455 | egress::hdr.ipv6.hop_limit | 8 | 0 | unused |
456 | egress::hdr.ipv6.src_addr | 128 | 0 | unused |
457 | egress::hdr.ipv6.dst_addr | 128 | 0 | read-only |
458 +-------------------------------------------------+------+-------+-----------+
459 | Unused fields | 106 | | |
460 | Unused bits | 1661 | | |
461 | Unused CLOT-allocated fields | 93 | | |
462 | Unused CLOT-allocated bits | 1470 | | |
463 +-------------------------------------------------+------+-------+-----------+
464 
465 
466 CLOT Allocation (ingress):
467 +------+-------------------------------------------------+---------------+-----------+
468 | CLOT | Fields | Bits | Property |
469 +------+-------------------------------------------------+---------------+-----------+
470 | 0 | state ingress::parse_arp | 28 bytes | |
471 | | | | |
472 | | ingress::hdr.arp.hw_type | 16 [0..15] | |
473 | | ingress::hdr.arp.proto_type | 16 [16..31] | |
474 | | ingress::hdr.arp.hw_addr_len | 8 [32..39] | |
475 | | ingress::hdr.arp.proto_addr_len | 8 [40..47] | |
476 | | ingress::hdr.arp.opcode | 16 [48..63] | |
477 | | ingress::hdr.arp.sender_mac | 48 [64..111] | |
478 | | ingress::hdr.arp.sender_ip | 32 [112..143] | |
479 | | ingress::hdr.arp.target_mac | 48 [144..191] | |
480 | | ingress::hdr.arp.target_ip | 32 [192..223] | |
481 +------+-------------------------------------------------+---------------+-----------+
482 | 1 | state ingress::parse_geneve_mss_tag | 8 bytes | |
483 | | | | |
484 | | ingress::hdr.geneve_opts.oxg_mss_tag.class | 16 [0..15] | |
485 | | ingress::hdr.geneve_opts.oxg_mss_tag.crit | 1 [16..16] | |
486 | | ingress::hdr.geneve_opts.oxg_mss_tag.type | 7 [17..23] | |
487 | | ingress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 [24..26] | |
488 | | ingress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 [27..31] | |
489 | | ingress::hdr.geneve_opts.oxg_mss.mss | 32 [32..63] | |
490 +------+-------------------------------------------------+---------------+-----------+
491 | 2 | state ingress::parse_geneve_mcast_tag | 8 bytes | |
492 | | | | |
493 | | ingress::hdr.geneve_opts.oxg_mcast_tag.class | 16 [0..15] | |
494 | | ingress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 [16..16] | |
495 | | ingress::hdr.geneve_opts.oxg_mcast_tag.type | 7 [17..23] | |
496 | | ingress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 [24..26] | |
497 | | ingress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 [27..31] | |
498 | | ingress::hdr.geneve_opts.oxg_mcast.mcast_tag | 2 [32..33] | ( phv ) |
499 | | ingress::hdr.geneve_opts.oxg_mcast.reserved | 30 [34..63] | |
500 +------+-------------------------------------------------+---------------+-----------+
501 | | Total Bits | 352 | |
502 +------+-------------------------------------------------+---------------+-----------+
503 
504 Packets will use up to 1 CLOTs.
505 The parser path(s) that will use the most CLOTs contain the following states:
506 ingress::parse_inner_tcp (0 CLOTs)
507 ingress::parse_inner_udp (0 CLOTs)
508 ingress::parse_inner_icmp (0 CLOTs)
509 ingress::parse_inner_ipv4 (0 CLOTs)
510 ingress::parse_inner_ipv6 (0 CLOTs)
511 ingress::parse_inner_eth (0 CLOTs)
512 ingress::geneve_parsed (0 CLOTs)
513 ingress::geneve_bad_size (0 CLOTs)
514 ingress::geneve_opt_parsed (0 CLOTs)
515 ingress::geneve_malformed (0 CLOTs)
516 ingress::parse_geneve_mcast_tag (1 CLOTs)
517 ingress::parse_geneve_mss_tag (1 CLOTs)
518 ingress::parse_geneve_ox_opt (0 CLOTs)
519 ingress::parse_geneve_opt (0 CLOTs)
520 ingress::parse_geneve (0 CLOTs)
521 ingress::parse_udp (0 CLOTs)
522 ingress::goto_proto_ipv4 (0 CLOTs)
523 ingress::set_mcast_ipv4 (0 CLOTs)
524 ingress::validate_ipv4_mcast_3 (0 CLOTs)
525 ingress::validate_ipv4_mcast1_2 (0 CLOTs)
526 ingress::validate_ttl (0 CLOTs)
527 ingress::parse_ipv4 (0 CLOTs)
528 ingress::goto_proto_ipv6 (0 CLOTs)
529 ingress::set_link_local_mcast (0 CLOTs)
530 ingress::set_mcast_ipv6 (0 CLOTs)
531 ingress::validate_hop_limit (0 CLOTs)
532 ingress::check_ipv6_mcast (0 CLOTs)
533 ingress::parse_ipv6 (0 CLOTs)
534 ingress::parse_arp (1 CLOTs)
535 ingress::parse_vlan (0 CLOTs)
536 ingress::parse_sidecar (0 CLOTs)
537 $entry_point.start (0 CLOTs)
538 
539 CLOT Allocation (egress):
540 +------+------------------------------------------------+----------------+------------+
541 | CLOT | Fields | Bits | Property |
542 +------+------------------------------------------------+----------------+------------+
543 | 0 | state egress::parse_ipv6 | 40 bytes | |
544 | | | | |
545 | | egress::hdr.ipv6.version | 4 [0..3] | |
546 | | egress::hdr.ipv6.traffic_class | 8 [4..11] | |
547 | | egress::hdr.ipv6.flow_label | 20 [12..31] | |
548 | | egress::hdr.ipv6.payload_len | 16 [32..47] | |
549 | | egress::hdr.ipv6.next_hdr | 8 [48..55] | |
550 | | egress::hdr.ipv6.hop_limit | 8 [56..63] | |
551 | | egress::hdr.ipv6.src_addr | 128 [64..191] | |
552 | | egress::hdr.ipv6.dst_addr | 128 [192..319] | ( phv ) |
553 +------+------------------------------------------------+----------------+------------+
554 | 1 | state egress::parse_inner_ipv6 | 40 bytes | |
555 | | | | |
556 | | egress::hdr.inner_ipv6.version | 4 [0..3] | |
557 | | egress::hdr.inner_ipv6.traffic_class | 8 [4..11] | |
558 | | egress::hdr.inner_ipv6.flow_label | 20 [12..31] | |
559 | | egress::hdr.inner_ipv6.payload_len | 16 [32..47] | |
560 | | egress::hdr.inner_ipv6.next_hdr | 8 [48..55] | |
561 | | egress::hdr.inner_ipv6.hop_limit | 8 [56..63] | ( phv* ) |
562 | | egress::hdr.inner_ipv6.src_addr | 128 [64..191] | |
563 | | egress::hdr.inner_ipv6.dst_addr | 128 [192..319] | ( phv ) |
564 +------+------------------------------------------------+----------------+------------+
565 | 2 | state egress::parse_inner_tcp | 20 bytes | |
566 | | | | |
567 | | egress::hdr.inner_tcp.src_port | 16 [0..15] | |
568 | | egress::hdr.inner_tcp.dst_port | 16 [16..31] | |
569 | | egress::hdr.inner_tcp.seq_no | 32 [32..63] | |
570 | | egress::hdr.inner_tcp.ack_no | 32 [64..95] | |
571 | | egress::hdr.inner_tcp.data_offset | 4 [96..99] | |
572 | | egress::hdr.inner_tcp.res | 4 [100..103] | |
573 | | egress::hdr.inner_tcp.flags | 8 [104..111] | |
574 | | egress::hdr.inner_tcp.window | 16 [112..127] | |
575 | | egress::hdr.inner_tcp.checksum | 16 [128..143] | |
576 | | egress::hdr.inner_tcp.urgent_ptr | 16 [144..159] | |
577 +------+------------------------------------------------+----------------+------------+
578 | 3 | state egress::parse_ipv4 | 20 bytes | |
579 | | | | |
580 | | egress::hdr.ipv4.version | 4 [0..3] | |
581 | | egress::hdr.ipv4.ihl | 4 [4..7] | |
582 | | egress::hdr.ipv4.diffserv | 8 [8..15] | |
583 | | egress::hdr.ipv4.total_len | 16 [16..31] | |
584 | | egress::hdr.ipv4.identification | 16 [32..47] | |
585 | | egress::hdr.ipv4.flags | 3 [48..50] | |
586 | | egress::hdr.ipv4.frag_offset | 13 [51..63] | |
587 | | egress::hdr.ipv4.ttl | 8 [64..71] | |
588 | | egress::hdr.ipv4.protocol | 8 [72..79] | |
589 | | egress::hdr.ipv4.hdr_checksum | 16 [80..95] | |
590 | | egress::hdr.ipv4.src_addr | 32 [96..127] | |
591 | | egress::hdr.ipv4.dst_addr | 32 [128..159] | ( phv ) |
592 +------+------------------------------------------------+----------------+------------+
593 | 4 | state egress::parse_inner_eth | 11 bytes | |
594 | | | | |
595 | | egress::hdr.inner_eth.dst_mac | 48 [0..47] | |
596 | | egress::hdr.inner_eth.src_mac[47:8] | 40 [48..87] | |
597 +------+------------------------------------------------+----------------+------------+
598 | 5 | state egress::parse_inner_ipv4 | 10 bytes | |
599 | | | | |
600 | | egress::hdr.inner_ipv4.version | 4 [0..3] | |
601 | | egress::hdr.inner_ipv4.ihl | 4 [4..7] | |
602 | | egress::hdr.inner_ipv4.diffserv | 8 [8..15] | |
603 | | egress::hdr.inner_ipv4.total_len | 16 [16..31] | |
604 | | egress::hdr.inner_ipv4.identification | 16 [32..47] | |
605 | | egress::hdr.inner_ipv4.flags | 3 [48..50] | |
606 | | egress::hdr.inner_ipv4.frag_offset | 13 [51..63] | |
607 | | egress::hdr.inner_ipv4.ttl | 8 [64..71] | ( phv* ) |
608 | | egress::hdr.inner_ipv4.protocol | 8 [72..79] | |
609 +------+------------------------------------------------+----------------+------------+
610 | 6 | state egress::parse_inner_udp | 8 bytes | |
611 | | | | |
612 | | egress::hdr.inner_udp.src_port | 16 [0..15] | |
613 | | egress::hdr.inner_udp.dst_port | 16 [16..31] | |
614 | | egress::hdr.inner_udp.hdr_length | 16 [32..47] | |
615 | | egress::hdr.inner_udp.checksum | 16 [48..63] | |
616 +------+------------------------------------------------+----------------+------------+
617 | 7 | state egress::parse_udp | 8 bytes | |
618 | | | | |
619 | | egress::hdr.udp.src_port | 16 [0..15] | |
620 | | egress::hdr.udp.dst_port | 16 [16..31] | |
621 | | egress::hdr.udp.hdr_length | 16 [32..47] | |
622 | | egress::hdr.udp.checksum | 16 [48..63] | |
623 +------+------------------------------------------------+----------------+------------+
624 | 8 | state egress::parse_icmp | 5 bytes | |
625 | | | | |
626 | | egress::hdr.icmp.hdr_checksum[7:0] | 8 [0..7] | |
627 | | egress::hdr.icmp.data | 32 [8..39] | |
628 +------+------------------------------------------------+----------------+------------+
629 | 9 | state egress::parse_geneve | 5 bytes | |
630 | | | | |
631 | | egress::hdr.geneve.version | 2 [0..1] | |
632 | | egress::hdr.geneve.opt_len | 6 [2..7] | |
633 | | egress::hdr.geneve.ctrl | 1 [8..8] | |
634 | | egress::hdr.geneve.crit | 1 [9..9] | |
635 | | egress::hdr.geneve.reserved | 6 [10..15] | |
636 | | egress::hdr.geneve.protocol | 16 [16..31] | |
637 | | egress::hdr.geneve.vni[23:16] | 8 [32..39] | |
638 +------+------------------------------------------------+----------------+------------+
639 | 10 | state egress::parse_geneve_mss_tag | 4 bytes | |
640 | | | | |
641 | | egress::hdr.geneve_opts.oxg_mss_tag.class | 16 [0..15] | |
642 | | egress::hdr.geneve_opts.oxg_mss_tag.crit | 1 [16..16] | |
643 | | egress::hdr.geneve_opts.oxg_mss_tag.type | 7 [17..23] | |
644 | | egress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 [24..26] | |
645 | | egress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 [27..31] | |
646 +------+------------------------------------------------+----------------+------------+
647 | 11 | state egress::parse_geneve_mcast_tag | 4 bytes | |
648 | | | | |
649 | | egress::hdr.geneve_opts.oxg_mcast_tag.class | 16 [0..15] | |
650 | | egress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 [16..16] | |
651 | | egress::hdr.geneve_opts.oxg_mcast_tag.type | 7 [17..23] | |
652 | | egress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 [24..26] | |
653 | | egress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 [27..31] | |
654 +------+------------------------------------------------+----------------+------------+
655 | 12 | state egress::parse_inner_ipv4 | 7 bytes | |
656 | | | | |
657 | | egress::hdr.inner_ipv4.src_addr[23:0] | 24 [0..23] | |
658 | | egress::hdr.inner_ipv4.dst_addr | 32 [24..55] | ( phv ) |
659 +------+------------------------------------------------+----------------+------------+
660 | | Total Bits | 1456 | |
661 +------+------------------------------------------------+----------------+------------+
662 
663 Packets will use up to 8 CLOTs.
664 The parser path(s) that will use the most CLOTs contain the following states:
665 egress::parse_inner_tcp (1 CLOTs)
666 egress::parse_inner_udp (1 CLOTs)
667 egress::parse_inner_ipv4 (2 CLOTs)
668 egress::parse_inner_eth (1 CLOTs)
669 egress::geneve_parsed (0 CLOTs)
670 egress::geneve_opt_parsed (0 CLOTs)
671 egress::parse_geneve_mcast_tag (1 CLOTs)
672 egress::parse_geneve_mss_tag (1 CLOTs)
673 egress::parse_geneve_ox_opt (0 CLOTs)
674 egress::parse_geneve_opt (0 CLOTs)
675 egress::parse_geneve (1 CLOTs)
676 egress::parse_udp (1 CLOTs)
677 egress::parse_ipv4 (1 CLOTs)
678 egress::parse_ipv6 (1 CLOTs)
679 egress::parse_vlan (0 CLOTs)
680 $entry_point.start (0 CLOTs)
681 
682 All fields:
683 +-------------------------------------------------+------+-------+-----------+
684 | Field | Bits | CLOTs | Property |
685 +-------------------------------------------------+------+-------+-----------+
686 | ingress::ig_intr_md.ingress_port | 9 | | read-only |
687 | ingress::meta.bridge_hdr.ingress_port | 9 | | unused |
688 | ingress::hdr.ethernet.dst_mac | 48 | | modified |
689 | ingress::hdr.ethernet.src_mac | 48 | | modified |
690 | ingress::hdr.ethernet.ether_type | 16 | | modified |
691 | ingress::meta.orig_src_mac | 48 | | read-only |
692 | ingress::hdr.sidecar.sc_code | 8 | | modified |
693 | ingress::hdr.sidecar.sc_pad | 8 | | unused |
694 | ingress::hdr.sidecar.sc_ingress | 16 | | modified |
695 | ingress::hdr.sidecar.sc_egress | 16 | | modified |
696 | ingress::hdr.sidecar.sc_ether_type | 16 | | modified |
697 | ingress::hdr.sidecar.sc_payload | 128 | | modified |
698 | ingress::hdr.vlan.pcp | 3 | | modified |
699 | ingress::hdr.vlan.dei | 1 | | modified |
700 | ingress::hdr.vlan.vlan_id | 12 | | modified |
701 | ingress::hdr.vlan.ether_type | 16 | | modified |
702 | ingress::hdr.ipv4.version | 4 | | modified |
703 | ingress::hdr.ipv4.ihl | 4 | | modified |
704 | ingress::hdr.ipv4.diffserv | 8 | | modified |
705 | ingress::hdr.ipv4.total_len | 16 | | modified |
706 | ingress::hdr.ipv4.identification | 16 | | modified |
707 | ingress::hdr.ipv4.flags | 3 | | modified |
708 | ingress::hdr.ipv4.frag_offset | 13 | | modified |
709 | ingress::hdr.ipv4.ttl | 8 | | modified |
710 | ingress::hdr.ipv4.protocol | 8 | | modified |
711 | ingress::hdr.ipv4.hdr_checksum | 16 | | checksum |
712 | ingress::hdr.ipv4.src_addr | 32 | | modified |
713 | ingress::hdr.ipv4.dst_addr | 32 | | modified |
714 | ingress::meta.orig_src_ipv4 | 32 | | read-only |
715 | ingress::meta.orig_dst_ipv4 | 32 | | read-only |
716 | ingress::hdr.icmp.type | 8 | | modified |
717 | ingress::hdr.icmp.code | 8 | | modified |
718 | ingress::hdr.icmp.hdr_checksum | 16 | | checksum |
719 | ingress::hdr.icmp.data | 32 | | modified |
720 | ingress::hdr.tcp.src_port | 16 | | modified |
721 | ingress::hdr.tcp.dst_port | 16 | | modified |
722 | ingress::hdr.tcp.seq_no | 32 | | modified |
723 | ingress::hdr.tcp.ack_no | 32 | | modified |
724 | ingress::hdr.tcp.data_offset | 4 | | modified |
725 | ingress::hdr.tcp.res | 4 | | modified |
726 | ingress::hdr.tcp.flags | 8 | | modified |
727 | ingress::hdr.tcp.window | 16 | | modified |
728 | ingress::hdr.tcp.checksum | 16 | | modified |
729 | ingress::hdr.tcp.urgent_ptr | 16 | | modified |
730 | ingress::meta.l4_src_port | 16 | | read-only |
731 | ingress::meta.l4_dst_port | 16 | | modified |
732 | ingress::hdr.udp.src_port | 16 | | modified |
733 | ingress::hdr.udp.dst_port | 16 | | modified |
734 | ingress::hdr.udp.hdr_length | 16 | | modified |
735 | ingress::hdr.udp.checksum | 16 | | checksum |
736 | ingress::hdr.geneve.version | 2 | | modified |
737 | ingress::hdr.geneve.opt_len | 6 | | modified |
738 | ingress::hdr.geneve.ctrl | 1 | | modified |
739 | ingress::hdr.geneve.crit | 1 | | modified |
740 | ingress::hdr.geneve.reserved | 6 | | modified |
741 | ingress::hdr.geneve.protocol | 16 | | modified |
742 | ingress::hdr.geneve.vni | 24 | | modified |
743 | ingress::hdr.geneve.reserved2 | 8 | | modified |
744 | ingress::hdr.inner_eth.dst_mac | 48 | | modified |
745 | ingress::hdr.inner_eth.src_mac | 48 | | modified |
746 | ingress::hdr.inner_eth.ether_type | 16 | | modified |
747 | ingress::hdr.inner_ipv4.version | 4 | | modified |
748 | ingress::hdr.inner_ipv4.ihl | 4 | | modified |
749 | ingress::hdr.inner_ipv4.diffserv | 8 | | modified |
750 | ingress::hdr.inner_ipv4.total_len | 16 | | modified |
751 | ingress::hdr.inner_ipv4.identification | 16 | | modified |
752 | ingress::hdr.inner_ipv4.flags | 3 | | modified |
753 | ingress::hdr.inner_ipv4.frag_offset | 13 | | modified |
754 | ingress::hdr.inner_ipv4.ttl | 8 | | modified |
755 | ingress::hdr.inner_ipv4.protocol | 8 | | modified |
756 | ingress::hdr.inner_ipv4.hdr_checksum | 16 | | modified |
757 | ingress::hdr.inner_ipv4.src_addr | 32 | | modified |
758 | ingress::hdr.inner_ipv4.dst_addr | 32 | | modified |
759 | ingress::hdr.inner_tcp.src_port | 16 | | modified |
760 | ingress::hdr.inner_tcp.dst_port | 16 | | modified |
761 | ingress::hdr.inner_tcp.seq_no | 32 | | modified |
762 | ingress::hdr.inner_tcp.ack_no | 32 | | modified |
763 | ingress::hdr.inner_tcp.data_offset | 4 | | modified |
764 | ingress::hdr.inner_tcp.res | 4 | | modified |
765 | ingress::hdr.inner_tcp.flags | 8 | | modified |
766 | ingress::hdr.inner_tcp.window | 16 | | modified |
767 | ingress::hdr.inner_tcp.checksum | 16 | | modified |
768 | ingress::hdr.inner_tcp.urgent_ptr | 16 | | modified |
769 | ingress::hdr.inner_udp.src_port | 16 | | modified |
770 | ingress::hdr.inner_udp.dst_port | 16 | | modified |
771 | ingress::hdr.inner_udp.hdr_length | 16 | | modified |
772 | ingress::hdr.inner_udp.checksum | 16 | | modified |
773 | ingress::hdr.inner_icmp.type | 8 | | modified |
774 | ingress::hdr.inner_icmp.code | 8 | | modified |
775 | ingress::hdr.inner_icmp.hdr_checksum | 16 | | modified |
776 | ingress::hdr.inner_icmp.data | 32 | | modified |
777 | ingress::hdr.inner_ipv6.version | 4 | | modified |
778 | ingress::hdr.inner_ipv6.traffic_class | 8 | | modified |
779 | ingress::hdr.inner_ipv6.flow_label | 20 | | modified |
780 | ingress::hdr.inner_ipv6.payload_len | 16 | | modified |
781 | ingress::hdr.inner_ipv6.next_hdr | 8 | | modified |
782 | ingress::hdr.inner_ipv6.hop_limit | 8 | | modified |
783 | ingress::hdr.inner_ipv6.src_addr | 128 | | modified |
784 | ingress::hdr.inner_ipv6.dst_addr | 128 | | modified |
785 | ingress::hdr.geneve_opts.oxg_ext_tag.class | 16 | | modified |
786 | ingress::hdr.geneve_opts.oxg_ext_tag.crit | 1 | | modified |
787 | ingress::hdr.geneve_opts.oxg_ext_tag.type | 7 | | modified |
788 | ingress::hdr.geneve_opts.oxg_ext_tag.reserved | 3 | | modified |
789 | ingress::hdr.geneve_opts.oxg_ext_tag.opt_len | 5 | | modified |
790 | ingress::hdr.geneve_opts.oxg_mcast_tag.class | 16 | 2 | unused |
791 | ingress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 | 2 | unused |
792 | ingress::hdr.geneve_opts.oxg_mcast_tag.type | 7 | 2 | unused |
793 | ingress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 | 2 | unused |
794 | ingress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 | 2 | unused |
795 | ingress::hdr.geneve_opts.oxg_mcast.mcast_tag | 2 | 2 | read-only |
796 | ingress::hdr.geneve_opts.oxg_mcast.reserved | 30 | 2 | unused |
797 | ingress::hdr.geneve_opts.oxg_mss_tag.class | 16 | 1 | unused |
798 | ingress::hdr.geneve_opts.oxg_mss_tag.crit | 1 | 1 | unused |
799 | ingress::hdr.geneve_opts.oxg_mss_tag.type | 7 | 1 | unused |
800 | ingress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 | 1 | unused |
801 | ingress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 | 1 | unused |
802 | ingress::hdr.geneve_opts.oxg_mss.mss | 32 | 1 | unused |
803 | ingress::hdr.ipv6.version | 4 | | modified |
804 | ingress::hdr.ipv6.traffic_class | 8 | | modified |
805 | ingress::hdr.ipv6.flow_label | 20 | | modified |
806 | ingress::hdr.ipv6.payload_len | 16 | | modified |
807 | ingress::hdr.ipv6.next_hdr | 8 | | modified |
808 | ingress::hdr.ipv6.hop_limit | 8 | | modified |
809 | ingress::hdr.ipv6.src_addr | 128 | | modified |
810 | ingress::hdr.ipv6.dst_addr | 128 | | modified |
811 | ingress::hdr.arp.hw_type | 16 | 0 | unused |
812 | ingress::hdr.arp.proto_type | 16 | 0 | unused |
813 | ingress::hdr.arp.hw_addr_len | 8 | 0 | unused |
814 | ingress::hdr.arp.proto_addr_len | 8 | 0 | unused |
815 | ingress::hdr.arp.opcode | 16 | 0 | unused |
816 | ingress::hdr.arp.sender_mac | 48 | 0 | unused |
817 | ingress::hdr.arp.sender_ip | 32 | 0 | unused |
818 | ingress::hdr.arp.target_mac | 48 | 0 | unused |
819 | ingress::hdr.arp.target_ip | 32 | 0 | unused |
820 | egress::eg_intr_md.egress_port | 9 | | read-only |
821 | egress::eg_intr_md.egress_rid | 16 | | read-only |
822 | egress::eg_intr_md.egress_rid_first | 1 | | read-only |
823 | egress::meta.bridge_hdr.ingress_port | 9 | | read-only |
824 | egress::hdr.ethernet.dst_mac | 48 | | modified |
825 | egress::hdr.ethernet.src_mac | 48 | | modified |
826 | egress::hdr.ethernet.ether_type | 16 | | modified |
827 | egress::hdr.vlan.pcp | 3 | | modified |
828 | egress::hdr.vlan.dei | 1 | | modified |
829 | egress::hdr.vlan.vlan_id | 12 | | modified |
830 | egress::hdr.vlan.ether_type | 16 | | modified |
831 | egress::hdr.ipv4.version | 4 | 3 | unused |
832 | egress::hdr.ipv4.ihl | 4 | 3 | unused |
833 | egress::hdr.ipv4.diffserv | 8 | 3 | unused |
834 | egress::hdr.ipv4.total_len | 16 | 3 | unused |
835 | egress::hdr.ipv4.identification | 16 | 3 | unused |
836 | egress::hdr.ipv4.flags | 3 | 3 | unused |
837 | egress::hdr.ipv4.frag_offset | 13 | 3 | unused |
838 | egress::hdr.ipv4.ttl | 8 | 3 | unused |
839 | egress::hdr.ipv4.protocol | 8 | 3 | unused |
840 | egress::hdr.ipv4.hdr_checksum | 16 | 3 | unused |
841 | egress::hdr.ipv4.src_addr | 32 | 3 | unused |
842 | egress::hdr.ipv4.dst_addr | 32 | 3 | read-only |
843 | egress::hdr.icmp.type | 8 | | unused |
844 | egress::hdr.icmp.code | 8 | | unused |
845 | egress::hdr.icmp.hdr_checksum | 16 | 8 | unused |
846 | egress::hdr.icmp.data | 32 | 8 | unused |
847 | egress::hdr.udp.src_port | 16 | 7 | unused |
848 | egress::hdr.udp.dst_port | 16 | 7 | unused |
849 | egress::hdr.udp.hdr_length | 16 | 7 | unused |
850 | egress::hdr.udp.checksum | 16 | 7 | unused |
851 | egress::hdr.geneve.version | 2 | 9 | unused |
852 | egress::hdr.geneve.opt_len | 6 | 9 | unused |
853 | egress::hdr.geneve.ctrl | 1 | 9 | unused |
854 | egress::hdr.geneve.crit | 1 | 9 | unused |
855 | egress::hdr.geneve.reserved | 6 | 9 | unused |
856 | egress::hdr.geneve.protocol | 16 | 9 | unused |
857 | egress::hdr.geneve.vni | 24 | 9 | unused |
858 | egress::hdr.geneve.reserved2 | 8 | | unused |
859 | egress::hdr.inner_eth.dst_mac | 48 | 4 | unused |
860 | egress::hdr.inner_eth.src_mac | 48 | 4 | unused |
861 | egress::hdr.inner_eth.ether_type | 16 | | unused |
862 | egress::hdr.inner_ipv4.version | 4 | 5 | unused |
863 | egress::hdr.inner_ipv4.ihl | 4 | 5 | unused |
864 | egress::hdr.inner_ipv4.diffserv | 8 | 5 | unused |
865 | egress::hdr.inner_ipv4.total_len | 16 | 5 | unused |
866 | egress::hdr.inner_ipv4.identification | 16 | 5 | unused |
867 | egress::hdr.inner_ipv4.flags | 3 | 5 | unused |
868 | egress::hdr.inner_ipv4.frag_offset | 13 | 5 | unused |
869 | egress::hdr.inner_ipv4.ttl | 8 | 5 | modified |
870 | egress::hdr.inner_ipv4.protocol | 8 | 5 | unused |
871 | egress::hdr.inner_ipv4.hdr_checksum | 16 | | checksum |
872 | egress::hdr.inner_ipv4.src_addr | 32 | 12 | unused |
873 | egress::hdr.inner_ipv4.dst_addr | 32 | 12 | read-only |
874 | egress::hdr.inner_tcp.src_port | 16 | 2 | unused |
875 | egress::hdr.inner_tcp.dst_port | 16 | 2 | unused |
876 | egress::hdr.inner_tcp.seq_no | 32 | 2 | unused |
877 | egress::hdr.inner_tcp.ack_no | 32 | 2 | unused |
878 | egress::hdr.inner_tcp.data_offset | 4 | 2 | unused |
879 | egress::hdr.inner_tcp.res | 4 | 2 | unused |
880 | egress::hdr.inner_tcp.flags | 8 | 2 | unused |
881 | egress::hdr.inner_tcp.window | 16 | 2 | unused |
882 | egress::hdr.inner_tcp.checksum | 16 | 2 | unused |
883 | egress::hdr.inner_tcp.urgent_ptr | 16 | 2 | unused |
884 | egress::hdr.inner_udp.src_port | 16 | 6 | unused |
885 | egress::hdr.inner_udp.dst_port | 16 | 6 | unused |
886 | egress::hdr.inner_udp.hdr_length | 16 | 6 | unused |
887 | egress::hdr.inner_udp.checksum | 16 | 6 | unused |
888 | egress::hdr.inner_ipv6.version | 4 | 1 | unused |
889 | egress::hdr.inner_ipv6.traffic_class | 8 | 1 | unused |
890 | egress::hdr.inner_ipv6.flow_label | 20 | 1 | unused |
891 | egress::hdr.inner_ipv6.payload_len | 16 | 1 | unused |
892 | egress::hdr.inner_ipv6.next_hdr | 8 | 1 | unused |
893 | egress::hdr.inner_ipv6.hop_limit | 8 | 1 | modified |
894 | egress::hdr.inner_ipv6.src_addr | 128 | 1 | unused |
895 | egress::hdr.inner_ipv6.dst_addr | 128 | 1 | read-only |
896 | egress::hdr.geneve_opts.oxg_ext_tag.class | 16 | | unused |
897 | egress::hdr.geneve_opts.oxg_ext_tag.crit | 1 | | unused |
898 | egress::hdr.geneve_opts.oxg_ext_tag.type | 7 | | unused |
899 | egress::hdr.geneve_opts.oxg_ext_tag.reserved | 3 | | unused |
900 | egress::hdr.geneve_opts.oxg_ext_tag.opt_len | 5 | | unused |
901 | egress::hdr.geneve_opts.oxg_mcast_tag.class | 16 | 11 | unused |
902 | egress::hdr.geneve_opts.oxg_mcast_tag.crit | 1 | 11 | unused |
903 | egress::hdr.geneve_opts.oxg_mcast_tag.type | 7 | 11 | unused |
904 | egress::hdr.geneve_opts.oxg_mcast_tag.reserved | 3 | 11 | unused |
905 | egress::hdr.geneve_opts.oxg_mcast_tag.opt_len | 5 | 11 | unused |
906 | egress::hdr.geneve_opts.oxg_mcast.mcast_tag | 2 | | read-only |
907 | egress::hdr.geneve_opts.oxg_mcast.reserved | 30 | | unused |
908 | egress::hdr.geneve_opts.oxg_mss_tag.class | 16 | 10 | unused |
909 | egress::hdr.geneve_opts.oxg_mss_tag.crit | 1 | 10 | unused |
910 | egress::hdr.geneve_opts.oxg_mss_tag.type | 7 | 10 | unused |
911 | egress::hdr.geneve_opts.oxg_mss_tag.reserved | 3 | 10 | unused |
912 | egress::hdr.geneve_opts.oxg_mss_tag.opt_len | 5 | 10 | unused |
913 | egress::hdr.geneve_opts.oxg_mss.mss | 32 | | unused |
914 | egress::hdr.ipv6.version | 4 | 0 | unused |
915 | egress::hdr.ipv6.traffic_class | 8 | 0 | unused |
916 | egress::hdr.ipv6.flow_label | 20 | 0 | unused |
917 | egress::hdr.ipv6.payload_len | 16 | 0 | unused |
918 | egress::hdr.ipv6.next_hdr | 8 | 0 | unused |
919 | egress::hdr.ipv6.hop_limit | 8 | 0 | unused |
920 | egress::hdr.ipv6.src_addr | 128 | 0 | unused |
921 | egress::hdr.ipv6.dst_addr | 128 | 0 | read-only |
922 +-------------------------------------------------+------+-------+-----------+
923 | Unused fields | 106 | | |
924 | Unused bits | 1661 | | |
925 | Unused CLOT-allocated fields | 93 | | |
926 | Unused CLOT-allocated bits | 1470 | | |
927 +-------------------------------------------------+------+-------+-----------+
928