提交 fbe4d456 编写于 作者: Z Zhi Yong Wu 提交者: David S. Miller

tun, rfs: fix the incorrect hash value

The code incorrectly save the queue index as the hash, so this patch
is fixing it with the hash received in the stack receive path.
Signed-off-by: NZhi Yong Wu <wuzhy@linux.vnet.ibm.com>
Acked-by: NJason Wang <jasowang@redhat.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 56022a8f
...@@ -378,8 +378,8 @@ static u16 tun_select_queue(struct net_device *dev, struct sk_buff *skb) ...@@ -378,8 +378,8 @@ static u16 tun_select_queue(struct net_device *dev, struct sk_buff *skb)
if (txq) { if (txq) {
e = tun_flow_find(&tun->flows[tun_hashfn(txq)], txq); e = tun_flow_find(&tun->flows[tun_hashfn(txq)], txq);
if (e) { if (e) {
txq = e->queue_index;
tun_flow_save_rps_rxhash(e, txq); tun_flow_save_rps_rxhash(e, txq);
txq = e->queue_index;
} else } else
/* use multiply and shift instead of expensive divide */ /* use multiply and shift instead of expensive divide */
txq = ((u64)txq * numqueues) >> 32; txq = ((u64)txq * numqueues) >> 32;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册