Hello!
On 22.02.2019 6:52, [email protected] wrote:
From: wenxu <[email protected]>
Current fib_multipath_hash_policy can make hash based on the L3 or
L4. But it only work on the outer IP. So a specific tunnel always
has the same hash value. But a specific tunnel may contain so many
inner connection. However there is no good ways for tunnel packet.
Connections? Way?
A specific tunnel route based on the percpu dst_cache, It will not
lookup route table each packet.
For each packet?
This patch provide a based cpu id hash policy. The different
connection run on differnt cpu and There will differnet hash
Different. Will be?
value for percpu dst_cache.
Signed-off-by: wenxu <[email protected]>
---
net/ipv4/route.c | 6 ++++++
net/ipv4/sysctl_net_ipv4.c | 2 +-
2 files changed, 7 insertions(+), 1 deletion(-)
diff --git a/net/ipv4/route.c b/net/ipv4/route.c
index ecc12a7..6cf2fd4 100644
--- a/net/ipv4/route.c
+++ b/net/ipv4/route.c
[...]
@@ -1834,6 +1835,8 @@ int fib_multipath_hash(const struct net *net, const
struct flowi4 *fl4,
hash_keys.addrs.v4addrs.dst = fl4->daddr;
}
break;
+ case 2:
+ cpu = smp_processor_id() + 1;
Should be a comment /* fall through */ if this fall thru isn't in error.
case 1:
/* skb is currently provided only when forwarding */
if (skb) {
[...]
MBR, Sergei