2019-04-30 14:42:39 -04:00
// SPDX-License-Identifier: GPL-2.0
2017-02-05 18:15:24 +01:00
/*
* Copyright ( c ) 2016 Christoph Hellwig .
*/
# include <linux/device.h>
# include <linux/blk-mq.h>
# include <linux/blk-mq-virtio.h>
# include <linux/virtio_config.h>
# include <linux/module.h>
# include "blk-mq.h"
/**
* blk_mq_virtio_map_queues - provide a default queue mapping for virtio device
* @ set : tagset to provide the mapping for
* @ vdev : virtio device associated with @ set .
* @ first_vec : first interrupt vectors to use for queues ( usually 0 )
*
* This function assumes the virtio device @ vdev has at least as many available
* interrupt vetors as @ set has queues . It will then queuery the vector
* corresponding to each queue for it ' s affinity mask and built queue mapping
* that maps a queue to the CPUs that have irq affinity for the corresponding
* vector .
*/
2018-10-29 13:06:14 -06:00
int blk_mq_virtio_map_queues ( struct blk_mq_queue_map * qmap ,
2017-02-05 18:15:24 +01:00
struct virtio_device * vdev , int first_vec )
{
const struct cpumask * mask ;
unsigned int queue , cpu ;
if ( ! vdev - > config - > get_vq_affinity )
goto fallback ;
2018-10-29 13:06:14 -06:00
for ( queue = 0 ; queue < qmap - > nr_queues ; queue + + ) {
2017-02-05 18:15:24 +01:00
mask = vdev - > config - > get_vq_affinity ( vdev , first_vec + queue ) ;
if ( ! mask )
goto fallback ;
for_each_cpu ( cpu , mask )
2018-10-24 13:16:11 -06:00
qmap - > mq_map [ cpu ] = qmap - > queue_offset + queue ;
2017-02-05 18:15:24 +01:00
}
return 0 ;
fallback :
2018-10-29 13:06:14 -06:00
return blk_mq_map_queues ( qmap ) ;
2017-02-05 18:15:24 +01:00
}
EXPORT_SYMBOL_GPL ( blk_mq_virtio_map_queues ) ;