diff options
| author | subashab@codeaurora.org <subashab@codeaurora.org> | 2017-03-23 13:34:16 -0600 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2017-03-24 13:17:07 -0700 | 
| commit | dddb64bcb34615bf48a2c9cb9881eb76795cc5c5 (patch) | |
| tree | dff7f083a71c3016dd2d09c0f9fac18546e9eddf /include/net/protocol.h | |
| parent | 8fa96e3bf6c04af61fc0a32ad64d648322c4d29d (diff) | |
net: Add sysctl to toggle early demux for tcp and udp
Certain system process significant unconnected UDP workload.
It would be preferrable to disable UDP early demux for those systems
and enable it for TCP only.
By disabling UDP demux, we see these slight gains on an ARM64 system-
782 -> 788Mbps unconnected single stream UDPv4
633 -> 654Mbps unconnected UDPv4 different sources
The performance impact can change based on CPU architecure and cache
sizes. There will not much difference seen if entire UDP hash table
is in cache.
Both sysctls are enabled by default to preserve existing behavior.
v1->v2: Change function pointer instead of adding conditional as
suggested by Stephen.
v2->v3: Read once in callers to avoid issues due to compiler
optimizations. Also update commit message with the tests.
v3->v4: Store and use read once result instead of querying pointer
again incorrectly.
v4->v5: Refactor to avoid errors due to compilation with IPV6={m,n}
Signed-off-by: Subash Abhinov Kasiviswanathan <subashab@codeaurora.org>
Suggested-by: Eric Dumazet <edumazet@google.com>
Cc: Stephen Hemminger <stephen@networkplumber.org>
Cc: Tom Herbert <tom@herbertland.com>
Cc: David Miller <davem@davemloft.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net/protocol.h')
| -rw-r--r-- | include/net/protocol.h | 7 | 
1 files changed, 4 insertions, 3 deletions
| diff --git a/include/net/protocol.h b/include/net/protocol.h index bf36ca34af7a..65ba335b0e7e 100644 --- a/include/net/protocol.h +++ b/include/net/protocol.h @@ -40,6 +40,7 @@  /* This is used to register protocols. */  struct net_protocol {  	void			(*early_demux)(struct sk_buff *skb); +	void                    (*early_demux_handler)(struct sk_buff *skb);  	int			(*handler)(struct sk_buff *skb);  	void			(*err_handler)(struct sk_buff *skb, u32 info);  	unsigned int		no_policy:1, @@ -54,7 +55,7 @@ struct net_protocol {  #if IS_ENABLED(CONFIG_IPV6)  struct inet6_protocol {  	void	(*early_demux)(struct sk_buff *skb); - +	void    (*early_demux_handler)(struct sk_buff *skb);  	int	(*handler)(struct sk_buff *skb);  	void	(*err_handler)(struct sk_buff *skb, @@ -92,12 +93,12 @@ struct inet_protosw {  #define INET_PROTOSW_PERMANENT 0x02  /* Permanent protocols are unremovable. */  #define INET_PROTOSW_ICSK      0x04  /* Is this an inet_connection_sock? */ -extern const struct net_protocol __rcu *inet_protos[MAX_INET_PROTOS]; +extern struct net_protocol __rcu *inet_protos[MAX_INET_PROTOS];  extern const struct net_offload __rcu *inet_offloads[MAX_INET_PROTOS];  extern const struct net_offload __rcu *inet6_offloads[MAX_INET_PROTOS];  #if IS_ENABLED(CONFIG_IPV6) -extern const struct inet6_protocol __rcu *inet6_protos[MAX_INET_PROTOS]; +extern struct inet6_protocol __rcu *inet6_protos[MAX_INET_PROTOS];  #endif  int inet_add_protocol(const struct net_protocol *prot, unsigned char num); | 
