rps: optimize rps_get_cpu()
optimize rps_get_cpu(). don't initialize ports when we can get the ports. one memory access for ports than two. Signed-off-by: Changli Gao <xiaosuo@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
bf73130d7f
commit
8c52d509e8
@@ -2229,7 +2229,11 @@ static int get_rps_cpu(struct net_device *dev, struct sk_buff *skb,
|
|||||||
int cpu = -1;
|
int cpu = -1;
|
||||||
u8 ip_proto;
|
u8 ip_proto;
|
||||||
u16 tcpu;
|
u16 tcpu;
|
||||||
u32 addr1, addr2, ports, ihl;
|
u32 addr1, addr2, ihl;
|
||||||
|
union {
|
||||||
|
u32 v32;
|
||||||
|
u16 v16[2];
|
||||||
|
} ports;
|
||||||
|
|
||||||
if (skb_rx_queue_recorded(skb)) {
|
if (skb_rx_queue_recorded(skb)) {
|
||||||
u16 index = skb_get_rx_queue(skb);
|
u16 index = skb_get_rx_queue(skb);
|
||||||
@@ -2275,7 +2279,6 @@ static int get_rps_cpu(struct net_device *dev, struct sk_buff *skb,
|
|||||||
default:
|
default:
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
ports = 0;
|
|
||||||
switch (ip_proto) {
|
switch (ip_proto) {
|
||||||
case IPPROTO_TCP:
|
case IPPROTO_TCP:
|
||||||
case IPPROTO_UDP:
|
case IPPROTO_UDP:
|
||||||
@@ -2285,25 +2288,20 @@ static int get_rps_cpu(struct net_device *dev, struct sk_buff *skb,
|
|||||||
case IPPROTO_SCTP:
|
case IPPROTO_SCTP:
|
||||||
case IPPROTO_UDPLITE:
|
case IPPROTO_UDPLITE:
|
||||||
if (pskb_may_pull(skb, (ihl * 4) + 4)) {
|
if (pskb_may_pull(skb, (ihl * 4) + 4)) {
|
||||||
__be16 *hports = (__be16 *) (skb->data + (ihl * 4));
|
ports.v32 = * (__force u32 *) (skb->data + (ihl * 4));
|
||||||
u32 sport, dport;
|
if (ports.v16[1] < ports.v16[0])
|
||||||
|
swap(ports.v16[0], ports.v16[1]);
|
||||||
sport = (__force u16) hports[0];
|
break;
|
||||||
dport = (__force u16) hports[1];
|
|
||||||
if (dport < sport)
|
|
||||||
swap(sport, dport);
|
|
||||||
ports = (sport << 16) + dport;
|
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
ports.v32 = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get a consistent hash (same value on both flow directions) */
|
/* get a consistent hash (same value on both flow directions) */
|
||||||
if (addr2 < addr1)
|
if (addr2 < addr1)
|
||||||
swap(addr1, addr2);
|
swap(addr1, addr2);
|
||||||
skb->rxhash = jhash_3words(addr1, addr2, ports, hashrnd);
|
skb->rxhash = jhash_3words(addr1, addr2, ports.v32, hashrnd);
|
||||||
if (!skb->rxhash)
|
if (!skb->rxhash)
|
||||||
skb->rxhash = 1;
|
skb->rxhash = 1;
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user