2019-07-10 07:07:17 +00:00
|
|
|
#ifndef NICO_DELTA_CHECKSUM
|
|
|
|
#define NICO_DELTA_CHECKSUM
|
|
|
|
|
2019-07-10 11:38:59 +00:00
|
|
|
action v4sum() {
|
2019-07-15 12:18:35 +00:00
|
|
|
bit<32> tmp = 0;
|
|
|
|
bit<32> carryover = 0;
|
2019-07-10 11:38:59 +00:00
|
|
|
|
2019-07-15 12:18:35 +00:00
|
|
|
tmp = tmp + (bit<32>) hdr.ipv4.src_addr[15:0]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv4.src_addr[31:16]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv4.dst_addr[15:0]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv4.dst_addr[31:16]; // 16 bit
|
2019-07-10 11:38:59 +00:00
|
|
|
|
2019-07-15 12:18:35 +00:00
|
|
|
tmp = tmp + (bit<32>) hdr.ipv4.totalLen -20; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv4.protocol; // 8 bit
|
|
|
|
|
2019-07-15 14:11:21 +00:00
|
|
|
/* filtering code copied from scapy */
|
2019-07-15 14:20:51 +00:00
|
|
|
tmp = (tmp >> 16) + (tmp & 0xffff);
|
|
|
|
tmp = tmp + (tmp >> 16);
|
|
|
|
tmp = ~tmp;
|
|
|
|
meta.v4sum = (bit<16>) ((((tmp>>8) & 0xff)|tmp<<8) & 0xffff);
|
|
|
|
|
2019-07-10 11:38:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
action v6sum() {
|
2019-07-15 12:18:35 +00:00
|
|
|
bit<32> tmp = 0;
|
|
|
|
bit<32> carryover = 0;
|
|
|
|
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[15:0]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[31:16]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[47:32]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[63:48]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[79:64]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[95:80]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[111:96]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.src_addr[127:112]; // 16 bit
|
|
|
|
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[15:0]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[31:16]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[47:32]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[63:48]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[79:64]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[95:80]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[111:96]; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.dst_addr[127:112]; // 16 bit
|
|
|
|
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.payload_length; // 16 bit
|
|
|
|
tmp = tmp + (bit<32>) hdr.ipv6.next_header; // 8 bit
|
|
|
|
|
2019-07-15 14:11:21 +00:00
|
|
|
/* filtering code copied from scapy */
|
2019-07-15 14:20:51 +00:00
|
|
|
tmp = (tmp >> 16) + (tmp & 0xffff);
|
|
|
|
tmp = tmp + (tmp >> 16);
|
|
|
|
tmp = ~tmp;
|
2019-07-15 14:11:21 +00:00
|
|
|
meta.v6sum = (bit<16>) ((((tmp>>8) & 0xff)|tmp<<8) & 0xffff) ;
|
2019-07-10 11:38:59 +00:00
|
|
|
}
|
2019-07-10 07:07:17 +00:00
|
|
|
|
2019-07-15 14:20:51 +00:00
|
|
|
|
2019-07-13 16:05:50 +00:00
|
|
|
action delta_prepare()
|
2019-07-11 06:47:34 +00:00
|
|
|
{
|
|
|
|
v4sum();
|
|
|
|
v6sum();
|
2019-07-13 16:05:50 +00:00
|
|
|
if(meta.v6sum > meta.v4sum) {
|
|
|
|
meta.headerdiff = meta.v6sum - meta.v4sum;
|
|
|
|
} else {
|
|
|
|
meta.headerdiff = meta.v4sum - meta.v6sum;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
action delta_udp_from_v4_to_v6()
|
|
|
|
{
|
|
|
|
delta_prepare();
|
2019-07-15 14:20:51 +00:00
|
|
|
hdr.udp.checksum = hdr.udp.checksum + meta.headerdiff;
|
2019-07-11 06:47:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
action delta_tcp_from_v4_to_v6()
|
|
|
|
{
|
2019-07-15 14:48:24 +00:00
|
|
|
v4sum();
|
|
|
|
v6sum();
|
|
|
|
|
|
|
|
/* here is also a possible overflow in both directions */
|
|
|
|
hdr.tcp.checksum = hdr.tcp.checksum + meta.v6sum - meta.v4sum;
|
2019-07-11 06:47:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
action delta_ipv4_from_v6_to_v4()
|
|
|
|
{
|
2019-07-13 16:05:50 +00:00
|
|
|
delta_prepare();
|
2019-07-15 14:48:24 +00:00
|
|
|
/* TO BE DONE! */
|
|
|
|
|
2019-07-11 06:47:34 +00:00
|
|
|
}
|
|
|
|
|
2019-07-10 07:07:17 +00:00
|
|
|
#endif
|