|
@@ -421,7 +421,7 @@ const char *vp_bus_name(struct virtio_device *vdev)
|
|
* - OR over all affinities for shared MSI
|
|
* - OR over all affinities for shared MSI
|
|
* - ignore the affinity request if we're using INTX
|
|
* - ignore the affinity request if we're using INTX
|
|
*/
|
|
*/
|
|
-int vp_set_vq_affinity(struct virtqueue *vq, int cpu)
|
|
|
|
|
|
+int vp_set_vq_affinity(struct virtqueue *vq, const struct cpumask *cpu_mask)
|
|
{
|
|
{
|
|
struct virtio_device *vdev = vq->vdev;
|
|
struct virtio_device *vdev = vq->vdev;
|
|
struct virtio_pci_device *vp_dev = to_vp_device(vdev);
|
|
struct virtio_pci_device *vp_dev = to_vp_device(vdev);
|
|
@@ -435,11 +435,10 @@ int vp_set_vq_affinity(struct virtqueue *vq, int cpu)
|
|
if (vp_dev->msix_enabled) {
|
|
if (vp_dev->msix_enabled) {
|
|
mask = vp_dev->msix_affinity_masks[info->msix_vector];
|
|
mask = vp_dev->msix_affinity_masks[info->msix_vector];
|
|
irq = pci_irq_vector(vp_dev->pci_dev, info->msix_vector);
|
|
irq = pci_irq_vector(vp_dev->pci_dev, info->msix_vector);
|
|
- if (cpu == -1)
|
|
|
|
|
|
+ if (!cpu_mask)
|
|
irq_set_affinity_hint(irq, NULL);
|
|
irq_set_affinity_hint(irq, NULL);
|
|
else {
|
|
else {
|
|
- cpumask_clear(mask);
|
|
|
|
- cpumask_set_cpu(cpu, mask);
|
|
|
|
|
|
+ cpumask_copy(mask, cpu_mask);
|
|
irq_set_affinity_hint(irq, mask);
|
|
irq_set_affinity_hint(irq, mask);
|
|
}
|
|
}
|
|
}
|
|
}
|