Checksums: ipv4 diff not needed; minip4: enable icmp, arp
This commit is contained in:
parent
6a9daa500e
commit
ce212ed9e1
4 changed files with 183 additions and 135 deletions
|
@ -27,6 +27,9 @@ def checksum_scapy(pkt):
|
||||||
# Only the diff between v4 and v6 "counts"
|
# Only the diff between v4 and v6 "counts"
|
||||||
#
|
#
|
||||||
|
|
||||||
|
# b)
|
||||||
|
# Not needed
|
||||||
|
|
||||||
def sum_for_udp(packet):
|
def sum_for_udp(packet):
|
||||||
sums = ""
|
sums = ""
|
||||||
sums += struct.pack("H", packet[UDP].sport)
|
sums += struct.pack("H", packet[UDP].sport)
|
||||||
|
@ -78,6 +81,30 @@ def sum_for_v4(packet):
|
||||||
|
|
||||||
return sums
|
return sums
|
||||||
|
|
||||||
|
def sum_for_v4_from_v6(packet):
|
||||||
|
# update_checksum(meta.chk_ipv4 == 1,
|
||||||
|
# {
|
||||||
|
# hdr.ipv4.version,
|
||||||
|
# hdr.ipv4.ihl,
|
||||||
|
# hdr.ipv4.diff_serv,
|
||||||
|
# hdr.ipv4.ecn,
|
||||||
|
# hdr.ipv4.totalLen,
|
||||||
|
# hdr.ipv4.identification,
|
||||||
|
# hdr.ipv4.flags,
|
||||||
|
# hdr.ipv4.fragOffset,
|
||||||
|
# hdr.ipv4.ttl,
|
||||||
|
# hdr.ipv4.protocol,
|
||||||
|
# hdr.ipv4.src_addr,
|
||||||
|
# hdr.ipv4.dst_addr
|
||||||
|
# },
|
||||||
|
# hdr.ipv4.hdrChecksum,
|
||||||
|
# HashAlgorithm.csum16
|
||||||
|
# );
|
||||||
|
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
p = []
|
p = []
|
||||||
|
|
||||||
|
@ -174,3 +201,5 @@ if __name__ == '__main__':
|
||||||
|
|
||||||
print("Translating v4 to v6, expected v6 UDP checksum: {}".format(
|
print("Translating v4 to v6, expected v6 UDP checksum: {}".format(
|
||||||
checksums["ipv4"] + header_diff_from_v6))
|
checksums["ipv4"] + header_diff_from_v6))
|
||||||
|
|
||||||
|
# Generate the IPv4 header checksum from IPv6:
|
||||||
|
|
22
doc/plan.org
22
doc/plan.org
|
@ -387,8 +387,22 @@
|
||||||
| 2019-07-01 | | |
|
| 2019-07-01 | | |
|
||||||
| | Meeting Laurent | |
|
| | Meeting Laurent | |
|
||||||
| | | |
|
| | | |
|
||||||
| | - Diff'ing in python | |
|
| | - Diff'ing in python: | |
|
||||||
| | - Phasing in netpfga code | |
|
| | * offsetting works | |
|
||||||
|
| | * Need to adjust to actual translation code | |
|
||||||
|
| | | |
|
||||||
|
| | - Phasing in netpfga code / copy & compile & fix | |
|
||||||
|
| | * Code structure w/o apply logic | |
|
||||||
|
| | * DIFF: Output port selection | |
|
||||||
|
| | * DIFF: Sending to CPU | |
|
||||||
|
| | | |
|
||||||
|
| | - Diff'ing in P4 | |
|
||||||
|
| | * IPv4 checksum is w/o payload | |
|
||||||
|
| | | |
|
||||||
|
| | | |
|
||||||
|
| | Next steps: | |
|
||||||
|
| | - Implement in BMV2 diff | |
|
||||||
|
| | - | |
|
||||||
| | | |
|
| | | |
|
||||||
| 2019-07-11 | | |
|
| 2019-07-11 | | |
|
||||||
| | Integrated org-documentation into latex / export working | |
|
| | Integrated org-documentation into latex / export working | |
|
||||||
|
@ -3918,6 +3932,10 @@ Linux package management, handling updates, etc.
|
||||||
*** TODO Code sharing (controller, switch)
|
*** TODO Code sharing (controller, switch)
|
||||||
Many constants double defined. Easy to make errors.
|
Many constants double defined. Easy to make errors.
|
||||||
|
|
||||||
|
*** Checksum handling: v6->v4 adding, not checking
|
||||||
|
Currently checksums are NOT checked. For translation v6->v4 this means
|
||||||
|
we add a checksum without ever checking v4 checksum before.
|
||||||
|
|
||||||
** Implementation description and limitations
|
** Implementation description and limitations
|
||||||
*** Implementation description [move todos here]
|
*** Implementation description [move todos here]
|
||||||
**** TODO Support (non-) fragmentation
|
**** TODO Support (non-) fragmentation
|
||||||
|
|
|
@ -412,168 +412,168 @@ control TopPipe(inout Parsed_packet hdr,
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// /********************** ICMP6 + NDP + ICMP ***********************************/
|
/********************** ICMP6 + NDP + ICMP ***********************************/
|
||||||
|
|
||||||
// /* old/unused action -- is it??*/
|
/* old/unused action -- is it??*/
|
||||||
// action icmp6_answer() {
|
action icmp6_answer() {
|
||||||
// if(hdr.icmp6.isValid()) {
|
if(hdr.icmp6.isValid()) {
|
||||||
// if(hdr.icmp6.code == ICMP6_ECHO_REQUEST) {
|
if(hdr.icmp6.code == ICMP6_ECHO_REQUEST) {
|
||||||
// ipv6_addr_t tmp = hdr.ipv6.src_addr;
|
ipv6_addr_t tmp = hdr.ipv6.src_addr;
|
||||||
// hdr.ipv6.src_addr = hdr.ipv6.dst_addr;
|
hdr.ipv6.src_addr = hdr.ipv6.dst_addr;
|
||||||
// hdr.ipv6.dst_addr = tmp;
|
hdr.ipv6.dst_addr = tmp;
|
||||||
// hdr.icmp6.code = ICMP6_ECHO_REPLY;
|
hdr.icmp6.code = ICMP6_ECHO_REPLY;
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
|
|
||||||
// action icmp6_neighbor_solicitation(ipv6_addr_t addr, mac_addr_t mac_addr) {
|
action icmp6_neighbor_solicitation(ipv6_addr_t addr, mac_addr_t mac_addr) {
|
||||||
// /* egress = ingress */
|
/* egress = ingress */
|
||||||
// standard_metadata.egress_spec = standard_metadata.ingress_port;
|
standard_metadata.egress_spec = standard_metadata.ingress_port;
|
||||||
|
|
||||||
// /* 1. IPv6 changes */
|
/* 1. IPv6 changes */
|
||||||
// hdr.ipv6.dst_addr = hdr.ipv6.src_addr;
|
hdr.ipv6.dst_addr = hdr.ipv6.src_addr;
|
||||||
// hdr.ipv6.src_addr = addr;
|
hdr.ipv6.src_addr = addr;
|
||||||
|
|
||||||
// /* 2. ICMP6 changes */
|
/* 2. ICMP6 changes */
|
||||||
// hdr.icmp6.type = ICMP6_NA;
|
hdr.icmp6.type = ICMP6_NA;
|
||||||
// hdr.icmp6.code = 0;
|
hdr.icmp6.code = 0;
|
||||||
// hdr.icmp6.checksum = 42; // checksum is calculated in deparser - marking with 42 to see whether it is calculated
|
hdr.icmp6.checksum = 42; // checksum is calculated in deparser - marking with 42 to see whether it is calculated
|
||||||
|
|
||||||
// /* 3. icmp6/neighbor advertisement: values taken from real world answers */
|
/* 3. icmp6/neighbor advertisement: values taken from real world answers */
|
||||||
// hdr.icmp6_na_ns.router = 0;
|
hdr.icmp6_na_ns.router = 0;
|
||||||
// hdr.icmp6_na_ns.solicitated = 1;
|
hdr.icmp6_na_ns.solicitated = 1;
|
||||||
// hdr.icmp6_na_ns.override = 1;
|
hdr.icmp6_na_ns.override = 1;
|
||||||
// hdr.icmp6_na_ns.reserved = 0;
|
hdr.icmp6_na_ns.reserved = 0;
|
||||||
// hdr.icmp6_na_ns.target_addr = addr;
|
hdr.icmp6_na_ns.target_addr = addr;
|
||||||
|
|
||||||
// /* 4. Link layer options */
|
/* 4. Link layer options */
|
||||||
// hdr.icmp6_option_link_layer_addr.type = ICMP6_NDP_OPT_TARGET_LL;
|
hdr.icmp6_option_link_layer_addr.type = ICMP6_NDP_OPT_TARGET_LL;
|
||||||
// hdr.icmp6_option_link_layer_addr.ll_length = 1; /* 1* 64 bit */
|
hdr.icmp6_option_link_layer_addr.ll_length = 1; /* 1* 64 bit */
|
||||||
// hdr.icmp6_option_link_layer_addr.mac_addr = mac_addr;
|
hdr.icmp6_option_link_layer_addr.mac_addr = mac_addr;
|
||||||
|
|
||||||
// /* 5. Checksum trigger/info */
|
/* 5. Checksum trigger/info */
|
||||||
// meta.chk_icmp6_na_ns = 1;
|
meta.chk_icmp6_na_ns = 1;
|
||||||
// meta.cast_length = (bit<32>) hdr.ipv6.payload_length;
|
meta.cast_length = (bit<32>) hdr.ipv6.payload_length;
|
||||||
// }
|
}
|
||||||
|
|
||||||
// action icmp6_echo_reply() {
|
action icmp6_echo_reply() {
|
||||||
// mac_addr_t mac_tmp = hdr.ethernet.dst_addr;
|
mac_addr_t mac_tmp = hdr.ethernet.dst_addr;
|
||||||
// hdr.ethernet.dst_addr = hdr.ethernet.src_addr;
|
hdr.ethernet.dst_addr = hdr.ethernet.src_addr;
|
||||||
// hdr.ethernet.src_addr = mac_tmp;
|
hdr.ethernet.src_addr = mac_tmp;
|
||||||
|
|
||||||
// ipv6_addr_t addr_tmp = hdr.ipv6.dst_addr;
|
ipv6_addr_t addr_tmp = hdr.ipv6.dst_addr;
|
||||||
// hdr.ipv6.dst_addr = hdr.ipv6.src_addr;
|
hdr.ipv6.dst_addr = hdr.ipv6.src_addr;
|
||||||
// hdr.ipv6.src_addr = addr_tmp;
|
hdr.ipv6.src_addr = addr_tmp;
|
||||||
|
|
||||||
// hdr.icmp6.type = ICMP6_ECHO_REPLY;
|
hdr.icmp6.type = ICMP6_ECHO_REPLY;
|
||||||
|
|
||||||
// meta.chk_icmp6 = 1;
|
meta.chk_icmp6 = 1;
|
||||||
|
|
||||||
// meta.cast_length = (bit<32>) hdr.ipv6.payload_length;
|
meta.cast_length = (bit<32>) hdr.ipv6.payload_length;
|
||||||
// }
|
}
|
||||||
|
|
||||||
// table icmp6 {
|
table icmp6 {
|
||||||
// key = {
|
key = {
|
||||||
// hdr.ipv6.dst_addr: lpm;
|
hdr.ipv6.dst_addr: lpm;
|
||||||
// hdr.icmp6.type: exact;
|
hdr.icmp6.type: exact;
|
||||||
// }
|
}
|
||||||
// actions = {
|
actions = {
|
||||||
// controller_debug;
|
controller_debug;
|
||||||
// icmp6_neighbor_solicitation;
|
icmp6_neighbor_solicitation;
|
||||||
// icmp6_echo_reply;
|
icmp6_echo_reply;
|
||||||
// controller_debug_table_id;
|
controller_debug_table_id;
|
||||||
// NoAction;
|
NoAction;
|
||||||
// }
|
}
|
||||||
// size = ICMP6_TABLE_SIZE;
|
size = ICMP6_TABLE_SIZE;
|
||||||
// default_action = controller_debug_table_id(TABLE_ICMP6);
|
default_action = controller_debug_table_id(TABLE_ICMP6);
|
||||||
// }
|
}
|
||||||
|
|
||||||
// action icmp_echo_reply() {
|
action icmp_echo_reply() {
|
||||||
// mac_addr_t mac_tmp = hdr.ethernet.dst_addr;
|
mac_addr_t mac_tmp = hdr.ethernet.dst_addr;
|
||||||
// ipv4_addr_t ipv4_tmp = hdr.ipv4.src_addr;
|
ipv4_addr_t ipv4_tmp = hdr.ipv4.src_addr;
|
||||||
|
|
||||||
// /* swap ethernet addresses */
|
/* swap ethernet addresses */
|
||||||
// hdr.ethernet.dst_addr = hdr.ethernet.src_addr;
|
hdr.ethernet.dst_addr = hdr.ethernet.src_addr;
|
||||||
// hdr.ethernet.src_addr = mac_tmp;
|
hdr.ethernet.src_addr = mac_tmp;
|
||||||
|
|
||||||
// /* swap ipv4 addresses */
|
/* swap ipv4 addresses */
|
||||||
// hdr.ipv4.src_addr = hdr.ipv4.dst_addr;
|
hdr.ipv4.src_addr = hdr.ipv4.dst_addr;
|
||||||
// hdr.ipv4.dst_addr = ipv4_tmp;
|
hdr.ipv4.dst_addr = ipv4_tmp;
|
||||||
|
|
||||||
// /* set correct type */
|
/* set correct type */
|
||||||
// hdr.icmp.type = ICMP_ECHO_REPLY;
|
hdr.icmp.type = ICMP_ECHO_REPLY;
|
||||||
|
|
||||||
// meta.chk_icmp = 1;
|
meta.chk_icmp = 1;
|
||||||
// }
|
}
|
||||||
|
|
||||||
// table icmp {
|
table icmp {
|
||||||
// key = {
|
key = {
|
||||||
// hdr.ipv4.dst_addr: lpm;
|
hdr.ipv4.dst_addr: lpm;
|
||||||
// hdr.icmp.type: exact;
|
hdr.icmp.type: exact;
|
||||||
// }
|
}
|
||||||
// actions = {
|
actions = {
|
||||||
// icmp_echo_reply;
|
icmp_echo_reply;
|
||||||
// controller_debug_table_id;
|
controller_debug_table_id;
|
||||||
// NoAction;
|
NoAction;
|
||||||
// }
|
}
|
||||||
// size = ICMP_TABLE_SIZE;
|
size = ICMP_TABLE_SIZE;
|
||||||
// // default_action = controller_debug_table_id(TABLE_ICMP);
|
// default_action = controller_debug_table_id(TABLE_ICMP);
|
||||||
// default_action = NoAction; /* do not clone on miss */
|
default_action = NoAction; /* do not clone on miss */
|
||||||
// }
|
}
|
||||||
|
|
||||||
// /********************** ARP ***********************************/
|
// /********************** ARP ***********************************/
|
||||||
|
|
||||||
// action arp_reply(mac_addr_t mac_addr) {
|
action arp_reply(mac_addr_t mac_addr) {
|
||||||
// /* swap */
|
/* swap */
|
||||||
// ipv4_addr_t ipv4_src = hdr.arp.dst_ipv4_addr;
|
ipv4_addr_t ipv4_src = hdr.arp.dst_ipv4_addr;
|
||||||
// ipv4_addr_t ipv4_dst = hdr.arp.src_ipv4_addr;
|
ipv4_addr_t ipv4_dst = hdr.arp.src_ipv4_addr;
|
||||||
|
|
||||||
// /* swap/add */
|
/* swap/add */
|
||||||
// mac_addr_t mac_src = mac_addr;
|
mac_addr_t mac_src = mac_addr;
|
||||||
// mac_addr_t mac_dst = hdr.arp.src_mac_addr;
|
mac_addr_t mac_dst = hdr.arp.src_mac_addr;
|
||||||
|
|
||||||
// /* fill the ethernet header */
|
/* fill the ethernet header */
|
||||||
// hdr.ethernet.dst_addr = mac_dst;
|
hdr.ethernet.dst_addr = mac_dst;
|
||||||
// hdr.ethernet.src_addr = mac_src;
|
hdr.ethernet.src_addr = mac_src;
|
||||||
|
|
||||||
// /* fill the arp header */
|
/* fill the arp header */
|
||||||
// hdr.arp.dst_mac_addr = mac_dst;
|
hdr.arp.dst_mac_addr = mac_dst;
|
||||||
// hdr.arp.src_mac_addr = mac_src;
|
hdr.arp.src_mac_addr = mac_src;
|
||||||
|
|
||||||
// /* swapping */
|
/* swapping */
|
||||||
// hdr.arp.dst_ipv4_addr = ipv4_dst;
|
hdr.arp.dst_ipv4_addr = ipv4_dst;
|
||||||
// hdr.arp.src_ipv4_addr = ipv4_src;
|
hdr.arp.src_ipv4_addr = ipv4_src;
|
||||||
|
|
||||||
// hdr.arp.opcode = ARP_REPLY;
|
hdr.arp.opcode = ARP_REPLY;
|
||||||
// }
|
}
|
||||||
|
|
||||||
// table v4_arp {
|
table v4_arp {
|
||||||
// key = {
|
key = {
|
||||||
// hdr.ethernet.dst_addr: exact;
|
hdr.ethernet.dst_addr: exact;
|
||||||
// hdr.arp.opcode: exact;
|
hdr.arp.opcode: exact;
|
||||||
// hdr.arp.dst_ipv4_addr: lpm;
|
hdr.arp.dst_ipv4_addr: lpm;
|
||||||
// }
|
}
|
||||||
// actions = {
|
actions = {
|
||||||
// controller_debug_table_id;
|
controller_debug_table_id;
|
||||||
// arp_reply;
|
arp_reply;
|
||||||
// NoAction;
|
NoAction;
|
||||||
// }
|
}
|
||||||
// size = ICMP6_TABLE_SIZE;
|
size = ICMP6_TABLE_SIZE;
|
||||||
// default_action = controller_debug_table_id(TABLE_ARP);
|
default_action = controller_debug_table_id(TABLE_ARP);
|
||||||
// }
|
}
|
||||||
|
|
||||||
// table v4_arp_egress {
|
table v4_arp_egress {
|
||||||
// key = {
|
key = {
|
||||||
// hdr.arp.dst_ipv4_addr: lpm;
|
hdr.arp.dst_ipv4_addr: lpm;
|
||||||
// }
|
}
|
||||||
// actions = {
|
actions = {
|
||||||
// controller_debug_table_id;
|
controller_debug_table_id;
|
||||||
// set_egress_port;
|
set_egress_port;
|
||||||
// NoAction;
|
NoAction;
|
||||||
// }
|
}
|
||||||
// size = ICMP6_TABLE_SIZE;
|
size = ICMP6_TABLE_SIZE;
|
||||||
// default_action = controller_debug_table_id(TABLE_ARP_EGRESS);
|
default_action = controller_debug_table_id(TABLE_ARP_EGRESS);
|
||||||
// }
|
}
|
||||||
|
|
||||||
|
|
||||||
// /********************** ROUTING (egress definiton) TABLES ***********************************/
|
// /********************** ROUTING (egress definiton) TABLES ***********************************/
|
||||||
|
|
1
p4src/minip4.p4
Symbolic link
1
p4src/minip4.p4
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../netpfga/minip4/src/minip4_solution-nat64.p4
|
Loading…
Reference in a new issue