blk-mq-virtio.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (c) 2016 Christoph Hellwig.
  4. */
  5. #include <linux/device.h>
  6. #include <linux/blk-mq-virtio.h>
  7. #include <linux/virtio_config.h>
  8. #include <linux/module.h>
  9. #include "blk-mq.h"
  10. /**
  11. * blk_mq_virtio_map_queues - provide a default queue mapping for virtio device
  12. * @qmap: CPU to hardware queue map.
  13. * @vdev: virtio device to provide a mapping for.
  14. * @first_vec: first interrupt vectors to use for queues (usually 0)
  15. *
  16. * This function assumes the virtio device @vdev has at least as many available
  17. * interrupt vectors as @set has queues. It will then query the vector
  18. * corresponding to each queue for it's affinity mask and built queue mapping
  19. * that maps a queue to the CPUs that have irq affinity for the corresponding
  20. * vector.
  21. */
  22. void blk_mq_virtio_map_queues(struct blk_mq_queue_map *qmap,
  23. struct virtio_device *vdev, int first_vec)
  24. {
  25. const struct cpumask *mask;
  26. unsigned int queue, cpu;
  27. if (!vdev->config->get_vq_affinity)
  28. goto fallback;
  29. for (queue = 0; queue < qmap->nr_queues; queue++) {
  30. mask = vdev->config->get_vq_affinity(vdev, first_vec + queue);
  31. if (!mask)
  32. goto fallback;
  33. for_each_cpu(cpu, mask)
  34. qmap->mq_map[cpu] = qmap->queue_offset + queue;
  35. }
  36. return;
  37. fallback:
  38. blk_mq_map_queues(qmap);
  39. }
  40. EXPORT_SYMBOL_GPL(blk_mq_virtio_map_queues);