rocker
play

Rocker Scott Feldman netdev 0.1 2015 Ottawa Proceedings of netdev - PowerPoint PPT Presentation

Rocker Scott Feldman netdev 0.1 2015 Ottawa Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada Network OS Mgmt Control Monitoring CLI Protocols Power Forwarding


  1. Rocker Scott Feldman netdev 0.1 2015 Ottawa Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  2. Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  3. Network OS Mgmt Control Monitoring CLI Protocols Power Forwarding Automation Mgmt Databases Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  4. Network OS Mgmt Control Monitoring CLI Protocols Power Forwarding Automation Mgmt Databases NDA SDK $$$ Hardware Access Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  5. Linux Mgmt Control Monitoring CLI Protocols Power Forwarding Automation Mgmt Databases NDA SDK $$$ Hardware Access Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  6. Linux Mgmt Control Monitoring CLI Protocols Power Forwarding Automation Mgmt Databases Switchdev driver Hardware Access Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  7. Linux Mgmt Control Monitoring CLI Protocols Power Forwarding Automation Mgmt Databases Switchdev rocker driver Hardware Access Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  8. Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  9. Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  10. guest system Qemu VM PCI rocker device host system -device rocker,name=sw1,len-ports=4,ports[0]=dev1,ports[1]=dev2, \ Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada ports[2]=dev3,ports[3]=dev4

  11. guest system rocker device tap0 tap1 tap2 tap3 -netdev tap,ifname=tap1,dev=dev1 -netdev tap,ifname=tap2,dev=dev2 -netdev \ tap, Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada ifname=tap3,dev=dev3 -netdev tap,ifname=tap4,dev=dev4

  12. guest system rocker device world 1 world 2 tap1 tap2 tap3 tap4 Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  13. Unicast OF-DPA* World Routing Flow Table Apply Termination Multicast ACL VLAN Actions Egress MAC Routing Policy Flow -push/pop Port Flow Flow Flow Table -edits Table Table Table -output Ingress Ingress Port Port Flow Table Group Table Entries Bridging Flow L2 Interface Table L2 Multicast L2 Flood L3 Interface L3 Unicast L3 Multicast L3 ECMP L2 Overlay Multicast *OpenFlow™ Data Plane Abstraction (OF-DPA), version 1.0 L2 Overlay Flood http://www.broadcom.com/collateral/etp/OFDPA_OASS-ETP101-R.pdf Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  14. guest system Linux eth1 eth2 eth3 eth4 kernel rocker driver rocker device tap1 tap2 tap3 tap4 Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  15. L2 Offload guest system Linux offloaded forwarding data br0 FDB path STP BPDU control path eth1 eth2 eth3 eth4 kernel rocker driver rocker device FDB tap1 tap2 tap3 tap4 Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  16. $ /sbin/bridge fdb 33:33:00:00:00:01 dev eth0 self permanent 01:00:5e:00:00:01 dev eth0 self permanent 33:33:ff:00:00:00 dev eth0 self permanent 01:80:c2:00:00:0e dev eth0 self permanent Learned by switch 52:54:00:12:35:01 dev swp1 master br0 permanent 00:02:00:00:02:00 dev swp1 master br0 external 00:02:00:00:02:00 dev swp1 self 52:54:00:12:35:02 dev swp2 master br0 permanent 00:02:00:00:03:00 dev swp2 master br0 external 00:02:00:00:03:00 dev swp2 self 33:33:00:00:00:01 dev br0 self permanent 01:00:5e:00:00:01 dev br0 self permanent 33:33:ff:12:35:01 dev br0 self permanent Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  17. (qemu) info rocker-of-dpa-flows sw1 prio tbl hits key(mask) --> actions 3 50 10 vlan 3840 dst 00:02:00:00:03:00 --> write group 0x0f000002 goto tbl 60 3 50 13 vlan 3840 dst 00:02:00:00:02:00 --> write group 0x0f000001 goto tbl 60 1 30 IP dst 11.0.0.0/32 --> write group 0x0f000000 goto tbl 60 1 30 IP dst 11.0.0.0/24 --> write group 0x0f000000 goto tbl 60 1 30 IP dst 11.0.0.255/32 --> write group 0x0f000000 goto tbl 60 1 30 10 IP dst 11.0.0.3/32 --> write group 0x0f000000 goto tbl 60 0 20 pport 2 vlan 3840 IPv6 dst 52:54:00:12:35:02 --> goto tbl 30 0 20 pport 2 vlan 3840 IP dst 52:54:00:12:35:02 --> goto tbl 30 1 20 8 pport 2 vlan 3840 IPv6 dst 33:33:00:00:00:00(ff:ff:00:00:00:00) --> goto tbl 40 1 20 pport 2 vlan 3840 IP dst 01:00:5e:00:00:00(ff:ff:ff:80:00:00) --> goto tbl 40 3 60 1 pport 2 vlan 3840 dst 01:80:c2:00:00:00(ff:ff:ff:ff:ff:f0) --> write group 0x0f000000 0 20 pport 1 vlan 3840 IPv6 dst 52:54:00:12:35:01 --> goto tbl 30 0 20 10 pport 1 vlan 3840 IP dst 52:54:00:12:35:01 --> goto tbl 30 1 50 6 vlan 3840 --> write group 0x4f000000 goto tbl 60 1 20 8 pport 1 vlan 3840 IPv6 dst 33:33:00:00:00:00(ff:ff:00:00:00:00) --> goto tbl 40 1 20 pport 1 vlan 3840 IP dst 01:00:5e:00:00:00(ff:ff:ff:80:00:00) --> goto tbl 40 3 60 1 pport 1 vlan 3840 dst 01:80:c2:00:00:00(ff:ff:ff:ff:ff:f0) --> write group 0x0f000000 1 10 22 pport 2 vlan 0 --> apply new vlan 3840 goto tbl 20 1 10 33 pport 1 vlan 0 --> apply new vlan 3840 goto tbl 20 1 0 55 pport 0(0xffff0000) --> goto tbl 10 (qemu) info rocker-of-dpa-groups sw1 id (decode) --> buckets 0x0f000002 (type L2 interface vlan 3840 pport 2) --> pop vlan out pport 2 0x0f000001 (type L2 interface vlan 3840 pport 1) --> pop vlan out pport 1 0x4f000000 (type L2 flood vlan 3840 index 0) --> groups [0x0f000002,0x0f000001] Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada 0x0f000000 (type L2 interface vlan 3840 pport 0) --> pop vlan out pport 0

  18. L3 Offload guest system Linux offloaded forwarding data path OSPF BGP FIB control path eth1 eth2 eth3 eth4 kernel rocker driver rocker device FIB tap1 tap2 tap3 tap4 Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  19. Future Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  20. ACL Offload guest system Linux offloaded traffic nftables control path eth1 eth2 eth3 eth4 kernel rocker driver rocker device ACL tap1 tap2 tap3 tap4 Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  21. Remote Controller OVS Offload Linux OVS OVSDB openvswitch eth1 eth2 eth3 eth4 kernel rocker driver rocker device FDB Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada tap1 tap2 tap3 tap4

  22. guest system rocker device world 1 world 2 tap1 tap2 tap3 tap4 Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

  23. P4 eBPF blah { struct blah { bpf_insn prog blah blah [] = { } BLAH(blah), } } rocker device P4 world eBPF world Fixed pipeline, c. 2014 Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada tap1 tap2 tap3 tap4

  24. Questions? Answers? Proceedings of netdev 0.1, Feb 14-17, 2015, Ottawa, On, Canada

Recommend


More recommend