1. 12 7月, 2013 1 次提交
    • P
      vxlan: Fix kernel crash on rmmod. · f89e57c4
      Pravin B Shelar 提交于
      vxlan exit module unregisters vxlan net and then it unregisters
      rtnl ops which triggers vxlan_dellink() from __rtnl_kill_links().
      vxlan_dellink() deletes vxlan-dev from vxlan_list which has
      list-head in vxlan-net-struct but that is already gone due to
      net-unregister. That is how we are getting following crash.
      
      Following commit fixes the crash by fixing module exit path.
      
      BUG: unable to handle kernel paging request at ffff8804102c8000
      IP: [<ffffffff812cc5e9>] __list_del_entry+0x29/0xd0
      PGD 2972067 PUD 83e019067 PMD 83df97067 PTE 80000004102c8060
      Oops: 0000 [#1] SMP DEBUG_PAGEALLOC
      Modules linked in: ---
      CPU: 19 PID: 6712 Comm: rmmod Tainted: GF            3.10.0+ #95
      Hardware name: Dell Inc. PowerEdge R620/0KCKR5, BIOS 1.4.8 10/25/2012
      task: ffff88080c47c580 ti: ffff88080ac50000 task.ti: ffff88080ac50000
      RIP: 0010:[<ffffffff812cc5e9>]  [<ffffffff812cc5e9>]
      __list_del_entry+0x29/0xd0
      RSP: 0018:ffff88080ac51e08  EFLAGS: 00010206
      RAX: ffff8804102c8000 RBX: ffff88040f0d4b10 RCX: dead000000200200
      RDX: ffff8804102c8000 RSI: ffff88080ac51e58 RDI: ffff88040f0d4b10
      RBP: ffff88080ac51e08 R08: 0000000000000001 R09: 2222222222222222
      R10: 2222222222222222 R11: 2222222222222222 R12: ffff88080ac51e58
      R13: ffffffffa07b8840 R14: ffffffff81ae48c0 R15: ffff88080ac51e58
      FS:  00007f9ef105c700(0000) GS:ffff88082a800000(0000)
      knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: ffff8804102c8000 CR3: 00000008227e5000 CR4: 00000000000407e0
      DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
      DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
      Stack:
       ffff88080ac51e28 ffffffff812cc6a1 2222222222222222 ffff88040f0d4000
       ffff88080ac51e48 ffffffffa07b3311 ffff88040f0d4000 ffffffff81ae49c8
       ffff88080ac51e98 ffffffff81492fc2 ffff88080ac51e58 ffff88080ac51e58
      Call Trace:
       [<ffffffff812cc6a1>] list_del+0x11/0x40
       [<ffffffffa07b3311>] vxlan_dellink+0x51/0x70 [vxlan]
       [<ffffffff81492fc2>] __rtnl_link_unregister+0xa2/0xb0
       [<ffffffff8149448e>] rtnl_link_unregister+0x1e/0x30
       [<ffffffffa07b7b7c>] vxlan_cleanup_module+0x1c/0x2f [vxlan]
       [<ffffffff810c9b31>] SyS_delete_module+0x1d1/0x2c0
       [<ffffffff812b8a0e>] ? trace_hardirqs_on_thunk+0x3a/0x3f
       [<ffffffff81582f42>] system_call_fastpath+0x16/0x1b
      Code: eb 9f 55 48 8b 17 48 b9 00 01 10 00 00 00 ad de 48 8b 47 08 48 89
      e5 48 39 ca 74 29 48 b9 00 02 20 00 00 00 ad de 48 39 c8 74 7a <4c> 8b
      00 4c 39 c7 75 53 4c 8b 42 08 4c 39 c7 75 2b 48 89 42 08
      RIP  [<ffffffff812cc5e9>] __list_del_entry+0x29/0xd0
       RSP <ffff88080ac51e08>
      CR2: ffff8804102c8000
      Signed-off-by: NPravin B Shelar <pshelar@nicira.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      f89e57c4
  2. 26 6月, 2013 7 次提交
  3. 24 6月, 2013 11 次提交
  4. 20 6月, 2013 1 次提交
  5. 19 6月, 2013 1 次提交
  6. 18 6月, 2013 3 次提交
  7. 29 5月, 2013 3 次提交
  8. 19 5月, 2013 1 次提交
  9. 18 5月, 2013 1 次提交
    • S
      vxlan: listen on multiple ports · 553675fb
      stephen hemminger 提交于
      The commit 823aa873
        Author: stephen hemminger <stephen@networkplumber.org>
        Date:   Sat Apr 27 11:31:57 2013 +0000
      
          vxlan: allow choosing destination port per vxlan
      
      introduced per-vxlan UDP port configuration but only did half of the
      necessary work.  It added per vxlan destination for sending, but
      overlooked the handling of multiple ports for incoming traffic.
      
      This patch changes the listening port management to handle multiple
      incoming UDP ports. The earlier per-namespace structure is now a hash
      list per namespace.
      
      It is also now possible to define the same virtual network id
      but with different UDP port values which can be useful for migration.
      Signed-off-by: NStephen Hemminger <stephen@networkplumber.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      553675fb
  10. 30 4月, 2013 1 次提交
  11. 29 4月, 2013 6 次提交
  12. 23 4月, 2013 1 次提交
    • D
      VXLAN: Allow L2 redirection with L3 switching · ae884082
      David Stevens 提交于
      Allow L2 redirection when VXLAN L3 switching is enabled
      
      This patch restricts L3 switching to destination MAC addresses that are
      marked as routers in order to allow virtual IP appliances that do L2
      redirection to function with VXLAN L3 switching enabled.
      
      We use L3 switching on VXLAN networks to avoid extra hops when the nominal
      router for cross-subnet traffic for a VM is remote and the ultimate
      destination may be local, or closer to the local node. Currently, the
      destination IP address takes precedence over the MAC address in all cases.
      Some network appliances receive packets for a virtualized IP address and
      redirect by changing the destination MAC address (only) to be the final
      destination for packet processing. VXLAN tunnel endpoints with L3 switching
      enabled may then overwrite this destination MAC address based on the packet IP
      address, resulting in potential loops and, at least, breaking L2 redirections
      that travel through tunnel endpoints.
      
      This patch limits L3 switching to the intended case where the original
      destination MAC address is a next-hop router and relies on the destination
      MAC address for all other cases, thus allowing L2 redirection and L3 switching
      to coexist peacefully.
      Signed-Off-By: NDavid L Stevens <dlstevens@us.ibm.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      ae884082
  13. 17 4月, 2013 1 次提交
  14. 16 4月, 2013 1 次提交
  15. 15 4月, 2013 1 次提交