Checksums: ipv4 diff not needed; minip4: enable icmp, arp

This commit is contained in:
Nico Schottelius 2019-07-01 11:03:10 +02:00
parent 6a9daa500e
commit ce212ed9e1
4 changed files with 183 additions and 135 deletions

View file

@ -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:

View file

@ -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

View file

@ -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
View file

@ -0,0 +1 @@
../netpfga/minip4/src/minip4_solution-nat64.p4