1. 07 1月, 2014 2 次提交
  2. 22 11月, 2013 5 次提交
  3. 21 11月, 2013 5 次提交
    • H
      net: add BUG_ON if kernel advertises msg_namelen > sizeof(struct sockaddr_storage) · 68c6beb3
      Hannes Frederic Sowa 提交于
      In that case it is probable that kernel code overwrote part of the
      stack. So we should bail out loudly here.
      
      The BUG_ON may be removed in future if we are sure all protocols are
      conformant.
      Suggested-by: NEric Dumazet <eric.dumazet@gmail.com>
      Signed-off-by: NHannes Frederic Sowa <hannes@stressinduktion.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      68c6beb3
    • H
      net: rework recvmsg handler msg_name and msg_namelen logic · f3d33426
      Hannes Frederic Sowa 提交于
      This patch now always passes msg->msg_namelen as 0. recvmsg handlers must
      set msg_namelen to the proper size <= sizeof(struct sockaddr_storage)
      to return msg_name to the user.
      
      This prevents numerous uninitialized memory leaks we had in the
      recvmsg handlers and makes it harder for new code to accidentally leak
      uninitialized memory.
      
      Optimize for the case recvfrom is called with NULL as address. We don't
      need to copy the address at all, so set it to NULL before invoking the
      recvmsg handler. We can do so, because all the recvmsg handlers must
      cope with the case a plain read() is called on them. read() also sets
      msg_name to NULL.
      
      Also document these changes in include/linux/net.h as suggested by David
      Miller.
      
      Changes since RFC:
      
      Set msg->msg_name = NULL if user specified a NULL in msg_name but had a
      non-null msg_namelen in verify_iovec/verify_compat_iovec. This doesn't
      affect sendto as it would bail out earlier while trying to copy-in the
      address. It also more naturally reflects the logic by the callers of
      verify_iovec.
      
      With this change in place I could remove "
      if (!uaddr || msg_sys->msg_namelen == 0)
      	msg->msg_name = NULL
      ".
      
      This change does not alter the user visible error logic as we ignore
      msg_namelen as long as msg_name is NULL.
      
      Also remove two unnecessary curly brackets in ___sys_recvmsg and change
      comments to netdev style.
      
      Cc: David Miller <davem@davemloft.net>
      Suggested-by: NEric Dumazet <eric.dumazet@gmail.com>
      Signed-off-by: NHannes Frederic Sowa <hannes@stressinduktion.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      f3d33426
    • D
      bridge: flush br's address entry in fdb when remove the · f8730420
      Ding Tianhong 提交于
       bridge dev
      
      When the following commands are executed:
      
      brctl addbr br0
      ifconfig br0 hw ether <addr>
      rmmod bridge
      
      The calltrace will occur:
      
      [  563.312114] device eth1 left promiscuous mode
      [  563.312188] br0: port 1(eth1) entered disabled state
      [  563.468190] kmem_cache_destroy bridge_fdb_cache: Slab cache still has objects
      [  563.468197] CPU: 6 PID: 6982 Comm: rmmod Tainted: G           O 3.12.0-0.7-default+ #9
      [  563.468199] Hardware name: Bochs Bochs, BIOS Bochs 01/01/2007
      [  563.468200]  0000000000000880 ffff88010f111e98 ffffffff814d1c92 ffff88010f111eb8
      [  563.468204]  ffffffff81148efd ffff88010f111eb8 0000000000000000 ffff88010f111ec8
      [  563.468206]  ffffffffa062a270 ffff88010f111ed8 ffffffffa063ac76 ffff88010f111f78
      [  563.468209] Call Trace:
      [  563.468218]  [<ffffffff814d1c92>] dump_stack+0x6a/0x78
      [  563.468234]  [<ffffffff81148efd>] kmem_cache_destroy+0xfd/0x100
      [  563.468242]  [<ffffffffa062a270>] br_fdb_fini+0x10/0x20 [bridge]
      [  563.468247]  [<ffffffffa063ac76>] br_deinit+0x4e/0x50 [bridge]
      [  563.468254]  [<ffffffff810c7dc9>] SyS_delete_module+0x199/0x2b0
      [  563.468259]  [<ffffffff814e0922>] system_call_fastpath+0x16/0x1b
      [  570.377958] Bridge firewalling registered
      
      --------------------------- cut here -------------------------------
      
      The reason is that when the bridge dev's address is changed, the
      br_fdb_change_mac_address() will add new address in fdb, but when
      the bridge was removed, the address entry in the fdb did not free,
      the bridge_fdb_cache still has objects when destroy the cache, Fix
      this by flushing the bridge address entry when removing the bridge.
      
      v2: according to the Toshiaki Makita and Vlad's suggestion, I only
          delete the vlan0 entry, it still have a leak here if the vlan id
          is other number, so I need to call fdb_delete_by_port(br, NULL, 1)
          to flush all entries whose dst is NULL for the bridge.
      Suggested-by: NToshiaki Makita <toshiaki.makita1@gmail.com>
      Suggested-by: NVlad Yasevich <vyasevich@gmail.com>
      Signed-off-by: NDing Tianhong <dingtianhong@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      f8730420
    • V
      net: core: Always propagate flag changes to interfaces · d2615bf4
      Vlad Yasevich 提交于
      The following commit:
          b6c40d68
          net: only invoke dev->change_rx_flags when device is UP
      
      tried to fix a problem with VLAN devices and promiscuouse flag setting.
      The issue was that VLAN device was setting a flag on an interface that
      was down, thus resulting in bad promiscuity count.
      This commit blocked flag propagation to any device that is currently
      down.
      
      A later commit:
          deede2fa
          vlan: Don't propagate flag changes on down interfaces
      
      fixed VLAN code to only propagate flags when the VLAN interface is up,
      thus fixing the same issue as above, only localized to VLAN.
      
      The problem we have now is that if we have create a complex stack
      involving multiple software devices like bridges, bonds, and vlans,
      then it is possible that the flags would not propagate properly to
      the physical devices.  A simple examle of the scenario is the
      following:
      
        eth0----> bond0 ----> bridge0 ---> vlan50
      
      If bond0 or eth0 happen to be down at the time bond0 is added to
      the bridge, then eth0 will never have promisc mode set which is
      currently required for operation as part of the bridge.  As a
      result, packets with vlan50 will be dropped by the interface.
      
      The only 2 devices that implement the special flag handling are
      VLAN and DSA and they both have required code to prevent incorrect
      flag propagation.  As a result we can remove the generic solution
      introduced in b6c40d68 and leave
      it to the individual devices to decide whether they will block
      flag propagation or not.
      Reported-by: NStefan Priebe <s.priebe@profihost.ag>
      Suggested-by: NVeaceslav Falico <vfalico@redhat.com>
      Signed-off-by: NVlad Yasevich <vyasevic@redhat.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      d2615bf4
    • A
      ipv4: fix race in concurrent ip_route_input_slow() · dcdfdf56
      Alexei Starovoitov 提交于
      CPUs can ask for local route via ip_route_input_noref() concurrently.
      if nh_rth_input is not cached yet, CPUs will proceed to allocate
      equivalent DSTs on 'lo' and then will try to cache them in nh_rth_input
      via rt_cache_route()
      Most of the time they succeed, but on occasion the following two lines:
      	orig = *p;
      	prev = cmpxchg(p, orig, rt);
      in rt_cache_route() do race and one of the cpus fails to complete cmpxchg.
      But ip_route_input_slow() doesn't check the return code of rt_cache_route(),
      so dst is leaking. dst_destroy() is never called and 'lo' device
      refcnt doesn't go to zero, which can be seen in the logs as:
      	unregister_netdevice: waiting for lo to become free. Usage count = 1
      Adding mdelay() between above two lines makes it easily reproducible.
      Fix it similar to nh_pcpu_rth_output case.
      
      Fixes: d2d68ba9 ("ipv4: Cache input routes in fib_info nexthops.")
      Signed-off-by: NAlexei Starovoitov <ast@plumgrid.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      dcdfdf56
  4. 20 11月, 2013 12 次提交
  5. 19 11月, 2013 6 次提交
  6. 18 11月, 2013 5 次提交
    • P
      netfilter: nf_conntrack: decrement global counter after object release · 0c3c6c00
      Pablo Neira Ayuso 提交于
      nf_conntrack_free() decrements our counter (net->ct.count)
      before releasing the conntrack object. That counter is used in the
      nf_conntrack_cleanup_net_list path to check if it's time to
      kmem_cache_destroy our cache of conntrack objects. I think we have
      a race there that should be easier to trigger (although still hard)
      with CONFIG_DEBUG_OBJECTS_FREE as object releases become slowier
      according to the following splat:
      
      [ 1136.321305] WARNING: CPU: 2 PID: 2483 at lib/debugobjects.c:260
      debug_print_object+0x83/0xa0()
      [ 1136.321311] ODEBUG: free active (active state 0) object type:
      timer_list hint: delayed_work_timer_fn+0x0/0x20
      ...
      [ 1136.321390] Call Trace:
      [ 1136.321398]  [<ffffffff8160d4a2>] dump_stack+0x45/0x56
      [ 1136.321405]  [<ffffffff810514e8>] warn_slowpath_common+0x78/0xa0
      [ 1136.321410]  [<ffffffff81051557>] warn_slowpath_fmt+0x47/0x50
      [ 1136.321414]  [<ffffffff812f8883>] debug_print_object+0x83/0xa0
      [ 1136.321420]  [<ffffffff8106aa90>] ? execute_in_process_context+0x90/0x90
      [ 1136.321424]  [<ffffffff812f99fb>] debug_check_no_obj_freed+0x20b/0x250
      [ 1136.321429]  [<ffffffff8112e7f2>] ? kmem_cache_destroy+0x92/0x100
      [ 1136.321433]  [<ffffffff8115d945>] kmem_cache_free+0x125/0x210
      [ 1136.321436]  [<ffffffff8112e7f2>] kmem_cache_destroy+0x92/0x100
      [ 1136.321443]  [<ffffffffa046b806>] nf_conntrack_cleanup_net_list+0x126/0x160 [nf_conntrack]
      [ 1136.321449]  [<ffffffffa046c43d>] nf_conntrack_pernet_exit+0x6d/0x80 [nf_conntrack]
      [ 1136.321453]  [<ffffffff81511cc3>] ops_exit_list.isra.3+0x53/0x60
      [ 1136.321457]  [<ffffffff815124f0>] cleanup_net+0x100/0x1b0
      [ 1136.321460]  [<ffffffff8106b31e>] process_one_work+0x18e/0x430
      [ 1136.321463]  [<ffffffff8106bf49>] worker_thread+0x119/0x390
      [ 1136.321467]  [<ffffffff8106be30>] ? manage_workers.isra.23+0x2a0/0x2a0
      [ 1136.321470]  [<ffffffff8107210b>] kthread+0xbb/0xc0
      [ 1136.321472]  [<ffffffff81072050>] ? kthread_create_on_node+0x110/0x110
      [ 1136.321477]  [<ffffffff8161b8fc>] ret_from_fork+0x7c/0xb0
      [ 1136.321479]  [<ffffffff81072050>] ? kthread_create_on_node+0x110/0x110
      [ 1136.321481] ---[ end trace 25f53c192da70825 ]---
      Reported-by: NLinus Torvalds <torvalds@linux-foundation.org>
      Signed-off-by: NPablo Neira Ayuso <pablo@netfilter.org>
      0c3c6c00
    • P
      netfilter: nft_compat: fix error path in nft_parse_compat() · 8691a9a3
      Pablo Neira Ayuso 提交于
      The patch 0ca743a5: "netfilter: nf_tables: add compatibility
      layer for x_tables", leads to the following Smatch
      
       warning: "net/netfilter/nft_compat.c:140 nft_parse_compat()
                warn: signedness bug returning '(-34)'"
      
      This nft_parse_compat function returns error codes but the return
      type is u8 so the error codes are transformed into small positive
      values. The callers don't check the return.
      Reported-by: NDan Carpenter <dan.carpenter@oracle.com>
      Signed-off-by: NPablo Neira Ayuso <pablo@netfilter.org>
      8691a9a3
    • P
      netfilter: fix wrong byte order in nf_ct_seqadj_set internal information · 23dfe136
      Phil Oester 提交于
      In commit 41d73ec0, sequence number adjustments were moved to a
      separate file. Unfortunately, the sequence numbers that are stored
      in the nf_ct_seqadj structure are expressed in host byte order. The
      necessary ntohl call was removed when the call to adjust_tcp_sequence
      was collapsed into nf_ct_seqadj_set. This broke the FTP NAT helper.
      Fix it by adding back the byte order conversions.
      Reported-by: NDawid Stawiarski <dawid.stawiarski@netart.pl>
      Signed-off-by: NPhil Oester <kernel@linuxace.com>
      Signed-off-by: NPablo Neira Ayuso <pablo@netfilter.org>
      23dfe136
    • M
      netfilter: synproxy: correct wscale option passing · c1898c4c
      Martin Topholm 提交于
      Timestamp are used to store additional syncookie parameters such as sack,
      ecn, and wscale. The wscale value we need to encode is the client's
      wscale, since we can't recover that later in the session. Next overwrite
      the wscale option so the later synproxy_send_client_synack will send
      the backend's wscale to the client.
      Signed-off-by: NMartin Topholm <mph@one.com>
      Reviewed-by: NJesper Dangaard Brouer <brouer@redhat.com>
      Signed-off-by: NPablo Neira Ayuso <pablo@netfilter.org>
      c1898c4c
    • M
      netfilter: synproxy: send mss option to backend · a6441b7a
      Martin Topholm 提交于
      When the synproxy_parse_options is called on the client ack the mss
      option will not be present. Consequently mss wont be included in the
      backend syn packet, which falls back to 536 bytes mss.
      
      Therefore XT_SYNPROXY_OPT_MSS is explicitly flagged when recovering mss
      value from cookie.
      Signed-off-by: NMartin Topholm <mph@one.com>
      Reviewed-by: NJesper Dangaard Brouer <brouer@redhat.com>
      Signed-off-by: NPablo Neira Ayuso <pablo@netfilter.org>
      a6441b7a
  7. 16 11月, 2013 5 次提交
新手
引导
客服 返回
顶部