1. 13 1月, 2017 2 次提交
    • N
      ipmr: improve hash scalability · 8fb472c0
      Nikolay Aleksandrov 提交于
      Recently we started using ipmr with thousands of entries and easily hit
      soft lockups on smaller devices. The reason is that the hash function
      uses the high order bits from the src and dst, but those don't change in
      many common cases, also the hash table  is only 64 elements so with
      thousands it doesn't scale at all.
      This patch migrates the hash table to rhashtable, and in particular the
      rhl interface which allows for duplicate elements to be chained because
      of the MFC_PROXY support (*,G; *,*,oif cases) which allows for multiple
      duplicate entries to be added with different interfaces (IMO wrong, but
      it's been in for a long time).
      
      And here are some results from tests I've run in a VM:
       mr_table size (default, allocated for all namespaces):
        Before                    After
         49304 bytes               2400 bytes
      
       Add 65000 routes (the diff is much larger on smaller devices):
        Before                    After
         1m42s                     58s
      
       Forwarding 256 byte packets with 65000 routes (test done in a VM):
        Before                    After
         3 Mbps / ~1465 pps        122 Mbps / ~59000 pps
      
      As a bonus we no longer see the soft lockups on smaller devices which
      showed up even with 2000 entries before.
      Signed-off-by: NNikolay Aleksandrov <nikolay@cumulusnetworks.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      8fb472c0
    • E
      secure_seq: fix sparse errors · c1ce1560
      Eric Dumazet 提交于
      Fixes following warnings :
      
      net/core/secure_seq.c:125:28: warning: incorrect type in argument 1
      (different base types)
      net/core/secure_seq.c:125:28:    expected unsigned int const [unsigned]
      [usertype] a
      net/core/secure_seq.c:125:28:    got restricted __be32 [usertype] saddr
      net/core/secure_seq.c:125:35: warning: incorrect type in argument 2
      (different base types)
      net/core/secure_seq.c:125:35:    expected unsigned int const [unsigned]
      [usertype] b
      net/core/secure_seq.c:125:35:    got restricted __be32 [usertype] daddr
      net/core/secure_seq.c:125:43: warning: cast from restricted __be16
      net/core/secure_seq.c:125:61: warning: restricted __be16 degrades to
      integer
      
      Fixes: 7cd23e53 ("secure_seq: use SipHash in place of MD5")
      Signed-off-by: NEric Dumazet <edumazet@google.com>
      Reviewed-by: NJason A. Donenfeld <Jason@zx2c4.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      c1ce1560
  2. 12 1月, 2017 8 次提交
  3. 11 1月, 2017 17 次提交
  4. 10 1月, 2017 13 次提交