1. 08 12月, 2012 1 次提交
    • Y
      tipc: eliminate aggregate sk_receive_queue limit · 9da3d475
      Ying Xue 提交于
      As a complement to the per-socket sk_recv_queue limit, TIPC keeps a
      global atomic counter for the sum of sk_recv_queue sizes across all
      tipc sockets. When incremented, the counter is compared to an upper
      threshold value, and if this is reached, the message is rejected
      with error code TIPC_OVERLOAD.
      
      This check was originally meant to protect the node against
      buffer exhaustion and general CPU overload. However, all experience
      indicates that the feature not only is redundant on Linux, but even
      harmful. Users run into the limit very often, causing disturbances
      for their applications, while removing it seems to have no negative
      effects at all. We have also seen that overall performance is
      boosted significantly when this bottleneck is removed.
      
      Furthermore, we don't see any other network protocols maintaining
      such a mechanism, something strengthening our conviction that this
      control can be eliminated.
      
      As a result, the atomic variable tipc_queue_size is now unused
      and so it can be deleted.  There is a getsockopt call that used
      to allow reading it; we retain that but just return zero for
      maximum compatibility.
      Signed-off-by: NYing Xue <ying.xue@windriver.com>
      Signed-off-by: NJon Maloy <jon.maloy@ericsson.com>
      Cc: Neil Horman <nhorman@tuxdriver.com>
      [PG: phase out tipc_queue_size as pointed out by Neil Horman]
      Signed-off-by: NPaul Gortmaker <paul.gortmaker@windriver.com>
      9da3d475
  2. 07 12月, 2012 1 次提交
    • E
      tipc: remove obsolete flush of stale reassembly buffer · c0084138
      Erik Hugne 提交于
      Each link instance has a periodic job checking if there is a stale
      ongoing message reassembly associated to the link. If no new
      fragment has been received during the last 4*[link_tolerance] period,
      it is assumed the missing fragment will never arrive. As a consequence,
      the reassembly buffer is discarded, and a gap in the message sequence
      occurs.
      
      This assumption is wrong. After we abandoned our ambition to develop
      packet routing for multi-cluster networks, only single-hop packet
      transfer remains as an option. For those, all packets are guaranteed
      to be delivered in sequence to the defragmentation layer. Any failure
      to achieve sequenced delivery will eventually lead to link reset, and
      the reassembly buffer will be flushed anyway.
      
      So we just remove this periodic check, which is now obsolete.
      Signed-off-by: NErik Hugne <erik.hugne@ericsson.com>
      Acked-by: NYing Xue <ying.xue@windriver.com>
      Signed-off-by: NJon Maloy <jon.maloy@ericsson.com>
      [PG: also delete get/inc_timer count, since they are now unused]
      Signed-off-by: NPaul Gortmaker <paul.gortmaker@windriver.com>
      c0084138
  3. 06 12月, 2012 11 次提交
  4. 05 12月, 2012 24 次提交
  5. 04 12月, 2012 3 次提交
    • D
      Merge tag 'dev_removal' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/net-next · 682d7978
      David S. Miller 提交于
      Networking:  Remove __dev* markings from the networking drivers
      
      This is a series of patches that remove the dev* attributes for all
      networking drivers, with the exception of wireless drivers, those are in
      a different branch.
      
      Use of __devinit, __devexit_p, __devinitdata, __devinitconst, and
      __devexit are no longer needed since CONFIG_HOTPLUG is being removed as
      an option.
      
      Note, there are some devinit compiler section mismatch warnings due to
      this series, but they are fixed up when merged with my driver-next
      branch, which fixes the PCI device id warnings, and removes the modpost
      detection, as it's no longer needed.
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      682d7978
    • P
      ipv6: Fix default route failover when CONFIG_IPV6_ROUTER_PREF=n · a5a81f0b
      Paul Marks 提交于
      I believe this commit from 2008 was incorrect:
      http://git.kernel.org/?p=linux/kernel/git/torvalds/linux.git;a=commitdiff;h=398bcbebb6f721ac308df1e3d658c0029bb74503
      
      When CONFIG_IPV6_ROUTER_PREF is disabled, the kernel should follow
      RFC4861 section 6.3.6: if no route is NUD_VALID, then traffic should be
      sprayed across all routers (indirectly triggering NUD) until one of them
      becomes NUD_VALID.
      
      However, the following experiment demonstrates that this does not work:
      
      1) Connect to an IPv6 network.
      2) Change the router's MAC (and link-local) address.
      
      The kernel will lock onto the first router and never try the new one, even
      if the first becomes unreachable.  This patch fixes the problem by
      allowing rt6_check_neigh() to return 0; if all routers return 0, then
      rt6_select() will fall back to round-robin behavior.
      
      This patch should have no effect when CONFIG_IPV6_ROUTER_PREF=y.
      
      Note that rt6_check_neigh() is only used in a boolean context, so I've
      changed its return type accordingly.
      Signed-off-by: NPaul Marks <pmarks@google.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      a5a81f0b
    • M
      tun: only queue packets on device · 5d097109
      Michael S. Tsirkin 提交于
      Historically tun supported two modes of operation:
      - in default mode, a small number of packets would get queued
        at the device, the rest would be queued in qdisc
      - in one queue mode, all packets would get queued at the device
      
      This might have made sense up to a point where we made the
      queue depth for both modes the same and set it to
      a huge value (500) so unless the consumer
      is stuck the chance of losing packets is small.
      
      Thus in practice both modes behave the same, but the
      default mode has some problems:
      - if packets are never consumed, fragments are never orphaned
        which cases a DOS for sender using zero copy transmit
      - overrun errors are hard to diagnose: fifo error is incremented
        only once so you can not distinguish between
        userspace that is stuck and a transient failure,
        tcpdump on the device does not show any traffic
      
      Userspace solves this simply by enabling IFF_ONE_QUEUE
      but there seems to be little point in not doing the
      right thing for everyone, by default.
      Signed-off-by: NMichael S. Tsirkin <mst@redhat.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      5d097109