another meta fix

This commit is contained in:
Nico Schottelius 2019-07-10 13:43:37 +02:00
parent ebda2acbdc
commit 7cec2b635d

View file

@ -4,37 +4,37 @@
action v4sum() { action v4sum() {
meta.v4sum = 0; meta.v4sum = 0;
meta.v4sum = meta.v4sum + ipv4.src_addr[15:0]; // 16 bit meta.v4sum = meta.v4sum + hdr.ipv4.src_addr[15:0]; // 16 bit
meta.v4sum = meta.v4sum + ipv4.src_addr[31:16]; // 16 bit meta.v4sum = meta.v4sum + hdr.ipv4.src_addr[31:16]; // 16 bit
meta.v4sum = meta.v4sum + ipv4.dst_addr[15:0]; // 16 bit meta.v4sum = meta.v4sum + hdr.ipv4.dst_addr[15:0]; // 16 bit
meta.v4sum = meta.v4sum + ipv4.dst_addr[31:16]; // 16 bit meta.v4sum = meta.v4sum + hdr.ipv4.dst_addr[31:16]; // 16 bit
meta.v4sum = meta.v4sum + ipv4.totalLen -20; // 16 bit meta.v4sum = meta.v4sum + hdr.ipv4.totalLen -20; // 16 bit
meta.v4sum = meta.v4sum + (bit<16>) ipv4.protocol; // 8 bit meta.v4sum = meta.v4sum + (bit<16>) hdr.ipv4.protocol; // 8 bit
} }
action v6sum() { action v6sum() {
meta.v6sum = 0; meta.v6sum = 0;
meta.v6sum = meta.v6sum + ipv6.src_addr[15:0]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[15:0]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.src_addr[31:16]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[31:16]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.src_addr[47:32]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[47:32]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.src_addr[63:48]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[63:48]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.src_addr[79:64]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[79:64]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.src_addr[95:80]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[95:80]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.src_addr[111:96]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[111:96]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.src_addr[127:112]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.src_addr[127:112]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[15:0]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[15:0]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[31:16]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[31:16]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[47:32]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[47:32]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[63:48]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[63:48]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[79:64]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[79:64]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[95:80]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[95:80]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[111:96]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[111:96]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.dst_addr[127:112]; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.dst_addr[127:112]; // 16 bit
meta.v6sum = meta.v6sum + ipv6.payload_length; // 16 bit meta.v6sum = meta.v6sum + hdr.ipv6.payload_length; // 16 bit
meta.v6sum = meta.v6sum + (bit<16>) ipv6.next_header; // 8 bit meta.v6sum = meta.v6sum + (bit<16>) hdr.ipv6.next_header; // 8 bit
} }
#endif #endif