virtio: Make vp_set_vq_affinity() take a mask.
Make vp_set_vq_affinity() take a cpumask instead of taking a single CPU. If there are fewer queues than cores, queue affinity should be able to map to multiple cores. Link: https://patchwork.ozlabs.org/patch/948149/ Suggested-by: Willem de Bruijn <willemb@google.com> Signed-off-by: Caleb Raitto <caraitto@google.com> Acked-by: Gonglei <arei.gonglei@huawei.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
07624df1c9
commit
19e226e8cc
@@ -1878,8 +1878,8 @@ static void virtnet_clean_affinity(struct virtnet_info *vi, long hcpu)
|
||||
|
||||
if (vi->affinity_hint_set) {
|
||||
for (i = 0; i < vi->max_queue_pairs; i++) {
|
||||
virtqueue_set_affinity(vi->rq[i].vq, -1);
|
||||
virtqueue_set_affinity(vi->sq[i].vq, -1);
|
||||
virtqueue_set_affinity(vi->rq[i].vq, NULL);
|
||||
virtqueue_set_affinity(vi->sq[i].vq, NULL);
|
||||
}
|
||||
|
||||
vi->affinity_hint_set = false;
|
||||
@@ -1905,8 +1905,8 @@ static void virtnet_set_affinity(struct virtnet_info *vi)
|
||||
for_each_online_cpu(cpu) {
|
||||
const unsigned long *mask = cpumask_bits(cpumask_of(cpu));
|
||||
|
||||
virtqueue_set_affinity(vi->rq[i].vq, cpu);
|
||||
virtqueue_set_affinity(vi->sq[i].vq, cpu);
|
||||
virtqueue_set_affinity(vi->rq[i].vq, cpumask_of(cpu));
|
||||
virtqueue_set_affinity(vi->sq[i].vq, cpumask_of(cpu));
|
||||
__netif_set_xps_queue(vi->dev, mask, i, false);
|
||||
i++;
|
||||
}
|
||||
|
Reference in New Issue
Block a user