bond: performance harvesting 45/12545/9
authorSteven <sluong@cisco.com>
Fri, 11 May 2018 18:06:23 +0000 (11:06 -0700)
committerDamjan Marion <dmarion.lists@gmail.com>
Fri, 25 May 2018 11:46:05 +0000 (11:46 +0000)
commit0d88301a576191a0e330e539cf1dcb3837ee1bf6
tree2bf42dd2935161d6cdb982371015e94a52d74e62
parent0053de63ec4bf8b9bce7817f1b61c9791baf6c26
bond: performance harvesting

- hash is great. But it is a bit too slow for the DP. Use direct array indexing
to quickly retrieve the slave interface.
- the algorithm used by flow hash is great. But it is a bit too slow for the DP.
Use l2_hash_hash() extracted from lb_hash.h which ECMP is using. It makes use
of intrinsic crc32 instruction set.
- shortcut modulo arithmetic when the operand is 2**x (where x up to 4) to
avoid division instruction.
- special case for link count == 1 in bond_tx_fn()
- use clib_mem_unaligned to access data for the packet to avoid alignment error
- Fix some typos for packet tracing.

Change-Id: I8eae3ad497061c5473aa675ba894ee0211120d25
Signed-off-by: Steven <sluong@cisco.com>
src/plugins/lacp/lacp_doc.md
src/plugins/lb/lbhash.h
src/vnet/bonding/cli.c
src/vnet/bonding/device.c
src/vnet/bonding/node.c
src/vnet/bonding/node.h
src/vppinfra.am
src/vppinfra/crc32.h
src/vppinfra/lb_hash_hash.h [new file with mode: 0644]
test/test_bond.py