1 // SPDX-License-Identifier: GPL-2.0-only
3 * VDUSE: vDPA Device in Userspace
5 * Copyright (C) 2020-2021 Bytedance Inc. and/or its affiliates. All rights reserved.
11 #include <linux/init.h>
12 #include <linux/module.h>
13 #include <linux/cdev.h>
14 #include <linux/device.h>
15 #include <linux/eventfd.h>
16 #include <linux/slab.h>
17 #include <linux/wait.h>
18 #include <linux/dma-map-ops.h>
19 #include <linux/poll.h>
20 #include <linux/file.h>
21 #include <linux/uio.h>
22 #include <linux/vdpa.h>
23 #include <linux/nospec.h>
24 #include <linux/vmalloc.h>
25 #include <linux/sched/mm.h>
26 #include <uapi/linux/vduse.h>
27 #include <uapi/linux/vdpa.h>
28 #include <uapi/linux/virtio_config.h>
29 #include <uapi/linux/virtio_ids.h>
30 #include <uapi/linux/virtio_blk.h>
31 #include <linux/mod_devicetable.h>
33 #include "iova_domain.h"
36 #define DRV_DESC "vDPA Device in Userspace"
37 #define DRV_LICENSE "GPL v2"
39 #define VDUSE_DEV_MAX (1U << MINORBITS)
40 #define VDUSE_MAX_BOUNCE_SIZE (1024 * 1024 * 1024)
41 #define VDUSE_MIN_BOUNCE_SIZE (1024 * 1024)
42 #define VDUSE_BOUNCE_SIZE (64 * 1024 * 1024)
43 /* 128 MB reserved for virtqueue creation */
44 #define VDUSE_IOVA_SIZE (VDUSE_MAX_BOUNCE_SIZE + 128 * 1024 * 1024)
45 #define VDUSE_MSG_DEFAULT_TIMEOUT 30
47 #define IRQ_UNBOUND -1
49 struct vduse_virtqueue {
56 struct vdpa_vq_state state;
61 struct eventfd_ctx *kickfd;
62 struct vdpa_callback cb;
63 struct work_struct inject;
64 struct work_struct kick;
65 int irq_effective_cpu;
66 struct cpumask irq_affinity;
73 struct vdpa_device vdpa;
74 struct vduse_dev *dev;
85 struct vduse_vdpa *vdev;
87 struct vduse_virtqueue **vqs;
88 struct vduse_iova_domain *domain;
94 wait_queue_head_t waitq;
95 struct list_head send_list;
96 struct list_head recv_list;
97 struct vdpa_callback config_cb;
98 struct work_struct inject;
100 struct rw_semaphore rwsem;
115 struct vduse_umem *umem;
116 struct mutex mem_lock;
117 unsigned int bounce_size;
118 struct mutex domain_lock;
121 struct vduse_dev_msg {
122 struct vduse_dev_request req;
123 struct vduse_dev_response resp;
124 struct list_head list;
125 wait_queue_head_t waitq;
129 struct vduse_control {
133 static DEFINE_MUTEX(vduse_lock);
134 static DEFINE_IDR(vduse_idr);
136 static dev_t vduse_major;
137 static struct class *vduse_class;
138 static struct cdev vduse_ctrl_cdev;
139 static struct cdev vduse_cdev;
140 static struct workqueue_struct *vduse_irq_wq;
141 static struct workqueue_struct *vduse_irq_bound_wq;
143 static u32 allowed_device_id[] = {
147 static inline struct vduse_dev *vdpa_to_vduse(struct vdpa_device *vdpa)
149 struct vduse_vdpa *vdev = container_of(vdpa, struct vduse_vdpa, vdpa);
154 static inline struct vduse_dev *dev_to_vduse(struct device *dev)
156 struct vdpa_device *vdpa = dev_to_vdpa(dev);
158 return vdpa_to_vduse(vdpa);
161 static struct vduse_dev_msg *vduse_find_msg(struct list_head *head,
164 struct vduse_dev_msg *msg;
166 list_for_each_entry(msg, head, list) {
167 if (msg->req.request_id == request_id) {
168 list_del(&msg->list);
176 static struct vduse_dev_msg *vduse_dequeue_msg(struct list_head *head)
178 struct vduse_dev_msg *msg = NULL;
180 if (!list_empty(head)) {
181 msg = list_first_entry(head, struct vduse_dev_msg, list);
182 list_del(&msg->list);
188 static void vduse_enqueue_msg(struct list_head *head,
189 struct vduse_dev_msg *msg)
191 list_add_tail(&msg->list, head);
194 static void vduse_dev_broken(struct vduse_dev *dev)
196 struct vduse_dev_msg *msg, *tmp;
198 if (unlikely(dev->broken))
201 list_splice_init(&dev->recv_list, &dev->send_list);
202 list_for_each_entry_safe(msg, tmp, &dev->send_list, list) {
203 list_del(&msg->list);
205 msg->resp.result = VDUSE_REQ_RESULT_FAILED;
206 wake_up(&msg->waitq);
209 wake_up(&dev->waitq);
212 static int vduse_dev_msg_sync(struct vduse_dev *dev,
213 struct vduse_dev_msg *msg)
217 if (unlikely(dev->broken))
220 init_waitqueue_head(&msg->waitq);
221 spin_lock(&dev->msg_lock);
222 if (unlikely(dev->broken)) {
223 spin_unlock(&dev->msg_lock);
226 msg->req.request_id = dev->msg_unique++;
227 vduse_enqueue_msg(&dev->send_list, msg);
228 wake_up(&dev->waitq);
229 spin_unlock(&dev->msg_lock);
230 if (dev->msg_timeout)
231 ret = wait_event_killable_timeout(msg->waitq, msg->completed,
232 (long)dev->msg_timeout * HZ);
234 ret = wait_event_killable(msg->waitq, msg->completed);
236 spin_lock(&dev->msg_lock);
237 if (!msg->completed) {
238 list_del(&msg->list);
239 msg->resp.result = VDUSE_REQ_RESULT_FAILED;
240 /* Mark the device as malfunction when there is a timeout */
242 vduse_dev_broken(dev);
244 ret = (msg->resp.result == VDUSE_REQ_RESULT_OK) ? 0 : -EIO;
245 spin_unlock(&dev->msg_lock);
250 static int vduse_dev_get_vq_state_packed(struct vduse_dev *dev,
251 struct vduse_virtqueue *vq,
252 struct vdpa_vq_state_packed *packed)
254 struct vduse_dev_msg msg = { 0 };
257 msg.req.type = VDUSE_GET_VQ_STATE;
258 msg.req.vq_state.index = vq->index;
260 ret = vduse_dev_msg_sync(dev, &msg);
264 packed->last_avail_counter =
265 msg.resp.vq_state.packed.last_avail_counter & 0x0001;
266 packed->last_avail_idx =
267 msg.resp.vq_state.packed.last_avail_idx & 0x7FFF;
268 packed->last_used_counter =
269 msg.resp.vq_state.packed.last_used_counter & 0x0001;
270 packed->last_used_idx =
271 msg.resp.vq_state.packed.last_used_idx & 0x7FFF;
276 static int vduse_dev_get_vq_state_split(struct vduse_dev *dev,
277 struct vduse_virtqueue *vq,
278 struct vdpa_vq_state_split *split)
280 struct vduse_dev_msg msg = { 0 };
283 msg.req.type = VDUSE_GET_VQ_STATE;
284 msg.req.vq_state.index = vq->index;
286 ret = vduse_dev_msg_sync(dev, &msg);
290 split->avail_index = msg.resp.vq_state.split.avail_index;
295 static int vduse_dev_set_status(struct vduse_dev *dev, u8 status)
297 struct vduse_dev_msg msg = { 0 };
299 msg.req.type = VDUSE_SET_STATUS;
300 msg.req.s.status = status;
302 return vduse_dev_msg_sync(dev, &msg);
305 static int vduse_dev_update_iotlb(struct vduse_dev *dev,
308 struct vduse_dev_msg msg = { 0 };
313 msg.req.type = VDUSE_UPDATE_IOTLB;
314 msg.req.iova.start = start;
315 msg.req.iova.last = last;
317 return vduse_dev_msg_sync(dev, &msg);
320 static ssize_t vduse_dev_read_iter(struct kiocb *iocb, struct iov_iter *to)
322 struct file *file = iocb->ki_filp;
323 struct vduse_dev *dev = file->private_data;
324 struct vduse_dev_msg *msg;
325 int size = sizeof(struct vduse_dev_request);
328 if (iov_iter_count(to) < size)
331 spin_lock(&dev->msg_lock);
333 msg = vduse_dequeue_msg(&dev->send_list);
338 if (file->f_flags & O_NONBLOCK)
341 spin_unlock(&dev->msg_lock);
342 ret = wait_event_interruptible_exclusive(dev->waitq,
343 !list_empty(&dev->send_list));
347 spin_lock(&dev->msg_lock);
349 spin_unlock(&dev->msg_lock);
350 ret = copy_to_iter(&msg->req, size, to);
351 spin_lock(&dev->msg_lock);
354 vduse_enqueue_msg(&dev->send_list, msg);
357 vduse_enqueue_msg(&dev->recv_list, msg);
359 spin_unlock(&dev->msg_lock);
364 static bool is_mem_zero(const char *ptr, int size)
368 for (i = 0; i < size; i++) {
375 static ssize_t vduse_dev_write_iter(struct kiocb *iocb, struct iov_iter *from)
377 struct file *file = iocb->ki_filp;
378 struct vduse_dev *dev = file->private_data;
379 struct vduse_dev_response resp;
380 struct vduse_dev_msg *msg;
383 ret = copy_from_iter(&resp, sizeof(resp), from);
384 if (ret != sizeof(resp))
387 if (!is_mem_zero((const char *)resp.reserved, sizeof(resp.reserved)))
390 spin_lock(&dev->msg_lock);
391 msg = vduse_find_msg(&dev->recv_list, resp.request_id);
397 memcpy(&msg->resp, &resp, sizeof(resp));
399 wake_up(&msg->waitq);
401 spin_unlock(&dev->msg_lock);
406 static __poll_t vduse_dev_poll(struct file *file, poll_table *wait)
408 struct vduse_dev *dev = file->private_data;
411 poll_wait(file, &dev->waitq, wait);
413 spin_lock(&dev->msg_lock);
415 if (unlikely(dev->broken))
417 if (!list_empty(&dev->send_list))
418 mask |= EPOLLIN | EPOLLRDNORM;
419 if (!list_empty(&dev->recv_list))
420 mask |= EPOLLOUT | EPOLLWRNORM;
422 spin_unlock(&dev->msg_lock);
427 static void vduse_dev_reset(struct vduse_dev *dev)
430 struct vduse_iova_domain *domain = dev->domain;
432 /* The coherent mappings are handled in vduse_dev_free_coherent() */
433 if (domain && domain->bounce_map)
434 vduse_domain_reset_bounce_map(domain);
436 down_write(&dev->rwsem);
439 dev->driver_features = 0;
441 spin_lock(&dev->irq_lock);
442 dev->config_cb.callback = NULL;
443 dev->config_cb.private = NULL;
444 spin_unlock(&dev->irq_lock);
445 flush_work(&dev->inject);
447 for (i = 0; i < dev->vq_num; i++) {
448 struct vduse_virtqueue *vq = dev->vqs[i];
455 memset(&vq->state, 0, sizeof(vq->state));
457 spin_lock(&vq->kick_lock);
460 eventfd_ctx_put(vq->kickfd);
462 spin_unlock(&vq->kick_lock);
464 spin_lock(&vq->irq_lock);
465 vq->cb.callback = NULL;
466 vq->cb.private = NULL;
467 vq->cb.trigger = NULL;
468 spin_unlock(&vq->irq_lock);
469 flush_work(&vq->inject);
470 flush_work(&vq->kick);
473 up_write(&dev->rwsem);
476 static int vduse_vdpa_set_vq_address(struct vdpa_device *vdpa, u16 idx,
477 u64 desc_area, u64 driver_area,
480 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
481 struct vduse_virtqueue *vq = dev->vqs[idx];
483 vq->desc_addr = desc_area;
484 vq->driver_addr = driver_area;
485 vq->device_addr = device_area;
490 static void vduse_vq_kick(struct vduse_virtqueue *vq)
492 spin_lock(&vq->kick_lock);
497 eventfd_signal(vq->kickfd, 1);
501 spin_unlock(&vq->kick_lock);
504 static void vduse_vq_kick_work(struct work_struct *work)
506 struct vduse_virtqueue *vq = container_of(work,
507 struct vduse_virtqueue, kick);
512 static void vduse_vdpa_kick_vq(struct vdpa_device *vdpa, u16 idx)
514 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
515 struct vduse_virtqueue *vq = dev->vqs[idx];
517 if (!eventfd_signal_allowed()) {
518 schedule_work(&vq->kick);
524 static void vduse_vdpa_set_vq_cb(struct vdpa_device *vdpa, u16 idx,
525 struct vdpa_callback *cb)
527 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
528 struct vduse_virtqueue *vq = dev->vqs[idx];
530 spin_lock(&vq->irq_lock);
531 vq->cb.callback = cb->callback;
532 vq->cb.private = cb->private;
533 vq->cb.trigger = cb->trigger;
534 spin_unlock(&vq->irq_lock);
537 static void vduse_vdpa_set_vq_num(struct vdpa_device *vdpa, u16 idx, u32 num)
539 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
540 struct vduse_virtqueue *vq = dev->vqs[idx];
545 static void vduse_vdpa_set_vq_ready(struct vdpa_device *vdpa,
548 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
549 struct vduse_virtqueue *vq = dev->vqs[idx];
554 static bool vduse_vdpa_get_vq_ready(struct vdpa_device *vdpa, u16 idx)
556 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
557 struct vduse_virtqueue *vq = dev->vqs[idx];
562 static int vduse_vdpa_set_vq_state(struct vdpa_device *vdpa, u16 idx,
563 const struct vdpa_vq_state *state)
565 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
566 struct vduse_virtqueue *vq = dev->vqs[idx];
568 if (dev->driver_features & BIT_ULL(VIRTIO_F_RING_PACKED)) {
569 vq->state.packed.last_avail_counter =
570 state->packed.last_avail_counter;
571 vq->state.packed.last_avail_idx = state->packed.last_avail_idx;
572 vq->state.packed.last_used_counter =
573 state->packed.last_used_counter;
574 vq->state.packed.last_used_idx = state->packed.last_used_idx;
576 vq->state.split.avail_index = state->split.avail_index;
581 static int vduse_vdpa_get_vq_state(struct vdpa_device *vdpa, u16 idx,
582 struct vdpa_vq_state *state)
584 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
585 struct vduse_virtqueue *vq = dev->vqs[idx];
587 if (dev->driver_features & BIT_ULL(VIRTIO_F_RING_PACKED))
588 return vduse_dev_get_vq_state_packed(dev, vq, &state->packed);
590 return vduse_dev_get_vq_state_split(dev, vq, &state->split);
593 static u32 vduse_vdpa_get_vq_align(struct vdpa_device *vdpa)
595 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
597 return dev->vq_align;
600 static u64 vduse_vdpa_get_device_features(struct vdpa_device *vdpa)
602 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
604 return dev->device_features;
607 static int vduse_vdpa_set_driver_features(struct vdpa_device *vdpa, u64 features)
609 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
611 dev->driver_features = features;
615 static u64 vduse_vdpa_get_driver_features(struct vdpa_device *vdpa)
617 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
619 return dev->driver_features;
622 static void vduse_vdpa_set_config_cb(struct vdpa_device *vdpa,
623 struct vdpa_callback *cb)
625 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
627 spin_lock(&dev->irq_lock);
628 dev->config_cb.callback = cb->callback;
629 dev->config_cb.private = cb->private;
630 spin_unlock(&dev->irq_lock);
633 static u16 vduse_vdpa_get_vq_num_max(struct vdpa_device *vdpa)
635 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
639 for (i = 0; i < dev->vq_num; i++)
640 if (num_max < dev->vqs[i]->num_max)
641 num_max = dev->vqs[i]->num_max;
646 static u32 vduse_vdpa_get_device_id(struct vdpa_device *vdpa)
648 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
650 return dev->device_id;
653 static u32 vduse_vdpa_get_vendor_id(struct vdpa_device *vdpa)
655 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
657 return dev->vendor_id;
660 static u8 vduse_vdpa_get_status(struct vdpa_device *vdpa)
662 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
667 static void vduse_vdpa_set_status(struct vdpa_device *vdpa, u8 status)
669 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
671 if (vduse_dev_set_status(dev, status))
674 dev->status = status;
677 static size_t vduse_vdpa_get_config_size(struct vdpa_device *vdpa)
679 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
681 return dev->config_size;
684 static void vduse_vdpa_get_config(struct vdpa_device *vdpa, unsigned int offset,
685 void *buf, unsigned int len)
687 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
689 /* Initialize the buffer in case of partial copy. */
692 if (offset > dev->config_size)
695 if (len > dev->config_size - offset)
696 len = dev->config_size - offset;
698 memcpy(buf, dev->config + offset, len);
701 static void vduse_vdpa_set_config(struct vdpa_device *vdpa, unsigned int offset,
702 const void *buf, unsigned int len)
704 /* Now we only support read-only configuration space */
707 static int vduse_vdpa_reset(struct vdpa_device *vdpa)
709 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
710 int ret = vduse_dev_set_status(dev, 0);
712 vduse_dev_reset(dev);
717 static u32 vduse_vdpa_get_generation(struct vdpa_device *vdpa)
719 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
721 return dev->generation;
724 static int vduse_vdpa_set_vq_affinity(struct vdpa_device *vdpa, u16 idx,
725 const struct cpumask *cpu_mask)
727 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
729 cpumask_copy(&dev->vqs[idx]->irq_affinity, cpu_mask);
733 static const struct cpumask *
734 vduse_vdpa_get_vq_affinity(struct vdpa_device *vdpa, u16 idx)
736 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
738 return &dev->vqs[idx]->irq_affinity;
741 static int vduse_vdpa_set_map(struct vdpa_device *vdpa,
743 struct vhost_iotlb *iotlb)
745 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
748 ret = vduse_domain_set_map(dev->domain, iotlb);
752 ret = vduse_dev_update_iotlb(dev, 0ULL, ULLONG_MAX);
754 vduse_domain_clear_map(dev->domain, iotlb);
761 static void vduse_vdpa_free(struct vdpa_device *vdpa)
763 struct vduse_dev *dev = vdpa_to_vduse(vdpa);
768 static const struct vdpa_config_ops vduse_vdpa_config_ops = {
769 .set_vq_address = vduse_vdpa_set_vq_address,
770 .kick_vq = vduse_vdpa_kick_vq,
771 .set_vq_cb = vduse_vdpa_set_vq_cb,
772 .set_vq_num = vduse_vdpa_set_vq_num,
773 .set_vq_ready = vduse_vdpa_set_vq_ready,
774 .get_vq_ready = vduse_vdpa_get_vq_ready,
775 .set_vq_state = vduse_vdpa_set_vq_state,
776 .get_vq_state = vduse_vdpa_get_vq_state,
777 .get_vq_align = vduse_vdpa_get_vq_align,
778 .get_device_features = vduse_vdpa_get_device_features,
779 .set_driver_features = vduse_vdpa_set_driver_features,
780 .get_driver_features = vduse_vdpa_get_driver_features,
781 .set_config_cb = vduse_vdpa_set_config_cb,
782 .get_vq_num_max = vduse_vdpa_get_vq_num_max,
783 .get_device_id = vduse_vdpa_get_device_id,
784 .get_vendor_id = vduse_vdpa_get_vendor_id,
785 .get_status = vduse_vdpa_get_status,
786 .set_status = vduse_vdpa_set_status,
787 .get_config_size = vduse_vdpa_get_config_size,
788 .get_config = vduse_vdpa_get_config,
789 .set_config = vduse_vdpa_set_config,
790 .get_generation = vduse_vdpa_get_generation,
791 .set_vq_affinity = vduse_vdpa_set_vq_affinity,
792 .get_vq_affinity = vduse_vdpa_get_vq_affinity,
793 .reset = vduse_vdpa_reset,
794 .set_map = vduse_vdpa_set_map,
795 .free = vduse_vdpa_free,
798 static dma_addr_t vduse_dev_map_page(struct device *dev, struct page *page,
799 unsigned long offset, size_t size,
800 enum dma_data_direction dir,
803 struct vduse_dev *vdev = dev_to_vduse(dev);
804 struct vduse_iova_domain *domain = vdev->domain;
806 return vduse_domain_map_page(domain, page, offset, size, dir, attrs);
809 static void vduse_dev_unmap_page(struct device *dev, dma_addr_t dma_addr,
810 size_t size, enum dma_data_direction dir,
813 struct vduse_dev *vdev = dev_to_vduse(dev);
814 struct vduse_iova_domain *domain = vdev->domain;
816 return vduse_domain_unmap_page(domain, dma_addr, size, dir, attrs);
819 static void *vduse_dev_alloc_coherent(struct device *dev, size_t size,
820 dma_addr_t *dma_addr, gfp_t flag,
823 struct vduse_dev *vdev = dev_to_vduse(dev);
824 struct vduse_iova_domain *domain = vdev->domain;
828 *dma_addr = DMA_MAPPING_ERROR;
829 addr = vduse_domain_alloc_coherent(domain, size,
830 (dma_addr_t *)&iova, flag, attrs);
834 *dma_addr = (dma_addr_t)iova;
839 static void vduse_dev_free_coherent(struct device *dev, size_t size,
840 void *vaddr, dma_addr_t dma_addr,
843 struct vduse_dev *vdev = dev_to_vduse(dev);
844 struct vduse_iova_domain *domain = vdev->domain;
846 vduse_domain_free_coherent(domain, size, vaddr, dma_addr, attrs);
849 static size_t vduse_dev_max_mapping_size(struct device *dev)
851 struct vduse_dev *vdev = dev_to_vduse(dev);
852 struct vduse_iova_domain *domain = vdev->domain;
854 return domain->bounce_size;
857 static const struct dma_map_ops vduse_dev_dma_ops = {
858 .map_page = vduse_dev_map_page,
859 .unmap_page = vduse_dev_unmap_page,
860 .alloc = vduse_dev_alloc_coherent,
861 .free = vduse_dev_free_coherent,
862 .max_mapping_size = vduse_dev_max_mapping_size,
865 static unsigned int perm_to_file_flags(u8 perm)
867 unsigned int flags = 0;
870 case VDUSE_ACCESS_WO:
873 case VDUSE_ACCESS_RO:
876 case VDUSE_ACCESS_RW:
880 WARN(1, "invalidate vhost IOTLB permission\n");
887 static int vduse_kickfd_setup(struct vduse_dev *dev,
888 struct vduse_vq_eventfd *eventfd)
890 struct eventfd_ctx *ctx = NULL;
891 struct vduse_virtqueue *vq;
894 if (eventfd->index >= dev->vq_num)
897 index = array_index_nospec(eventfd->index, dev->vq_num);
898 vq = dev->vqs[index];
899 if (eventfd->fd >= 0) {
900 ctx = eventfd_ctx_fdget(eventfd->fd);
903 } else if (eventfd->fd != VDUSE_EVENTFD_DEASSIGN)
906 spin_lock(&vq->kick_lock);
908 eventfd_ctx_put(vq->kickfd);
910 if (vq->ready && vq->kicked && vq->kickfd) {
911 eventfd_signal(vq->kickfd, 1);
914 spin_unlock(&vq->kick_lock);
919 static bool vduse_dev_is_ready(struct vduse_dev *dev)
923 for (i = 0; i < dev->vq_num; i++)
924 if (!dev->vqs[i]->num_max)
930 static void vduse_dev_irq_inject(struct work_struct *work)
932 struct vduse_dev *dev = container_of(work, struct vduse_dev, inject);
934 spin_lock_irq(&dev->irq_lock);
935 if (dev->config_cb.callback)
936 dev->config_cb.callback(dev->config_cb.private);
937 spin_unlock_irq(&dev->irq_lock);
940 static void vduse_vq_irq_inject(struct work_struct *work)
942 struct vduse_virtqueue *vq = container_of(work,
943 struct vduse_virtqueue, inject);
945 spin_lock_irq(&vq->irq_lock);
946 if (vq->ready && vq->cb.callback)
947 vq->cb.callback(vq->cb.private);
948 spin_unlock_irq(&vq->irq_lock);
951 static bool vduse_vq_signal_irqfd(struct vduse_virtqueue *vq)
958 spin_lock_irq(&vq->irq_lock);
959 if (vq->ready && vq->cb.trigger) {
960 eventfd_signal(vq->cb.trigger, 1);
963 spin_unlock_irq(&vq->irq_lock);
968 static int vduse_dev_queue_irq_work(struct vduse_dev *dev,
969 struct work_struct *irq_work,
970 int irq_effective_cpu)
974 down_read(&dev->rwsem);
975 if (!(dev->status & VIRTIO_CONFIG_S_DRIVER_OK))
979 if (irq_effective_cpu == IRQ_UNBOUND)
980 queue_work(vduse_irq_wq, irq_work);
982 queue_work_on(irq_effective_cpu,
983 vduse_irq_bound_wq, irq_work);
985 up_read(&dev->rwsem);
990 static int vduse_dev_dereg_umem(struct vduse_dev *dev,
995 mutex_lock(&dev->mem_lock);
1004 if (dev->umem->iova != iova || size != dev->domain->bounce_size)
1007 vduse_domain_remove_user_bounce_pages(dev->domain);
1008 unpin_user_pages_dirty_lock(dev->umem->pages,
1009 dev->umem->npages, true);
1010 atomic64_sub(dev->umem->npages, &dev->umem->mm->pinned_vm);
1011 mmdrop(dev->umem->mm);
1012 vfree(dev->umem->pages);
1017 mutex_unlock(&dev->mem_lock);
1021 static int vduse_dev_reg_umem(struct vduse_dev *dev,
1022 u64 iova, u64 uaddr, u64 size)
1024 struct page **page_list = NULL;
1025 struct vduse_umem *umem = NULL;
1027 unsigned long npages, lock_limit;
1030 if (!dev->domain || !dev->domain->bounce_map ||
1031 size != dev->domain->bounce_size ||
1032 iova != 0 || uaddr & ~PAGE_MASK)
1035 mutex_lock(&dev->mem_lock);
1041 npages = size >> PAGE_SHIFT;
1042 page_list = __vmalloc(array_size(npages, sizeof(struct page *)),
1043 GFP_KERNEL_ACCOUNT);
1044 umem = kzalloc(sizeof(*umem), GFP_KERNEL);
1045 if (!page_list || !umem)
1048 mmap_read_lock(current->mm);
1050 lock_limit = PFN_DOWN(rlimit(RLIMIT_MEMLOCK));
1051 if (npages + atomic64_read(¤t->mm->pinned_vm) > lock_limit)
1054 pinned = pin_user_pages(uaddr, npages, FOLL_LONGTERM | FOLL_WRITE,
1056 if (pinned != npages) {
1057 ret = pinned < 0 ? pinned : -ENOMEM;
1061 ret = vduse_domain_add_user_bounce_pages(dev->domain,
1066 atomic64_add(npages, ¤t->mm->pinned_vm);
1068 umem->pages = page_list;
1069 umem->npages = pinned;
1071 umem->mm = current->mm;
1072 mmgrab(current->mm);
1076 if (ret && pinned > 0)
1077 unpin_user_pages(page_list, pinned);
1079 mmap_read_unlock(current->mm);
1085 mutex_unlock(&dev->mem_lock);
1089 static void vduse_vq_update_effective_cpu(struct vduse_virtqueue *vq)
1091 int curr_cpu = vq->irq_effective_cpu;
1094 curr_cpu = cpumask_next(curr_cpu, &vq->irq_affinity);
1095 if (cpu_online(curr_cpu))
1098 if (curr_cpu >= nr_cpu_ids)
1099 curr_cpu = IRQ_UNBOUND;
1102 vq->irq_effective_cpu = curr_cpu;
1105 static long vduse_dev_ioctl(struct file *file, unsigned int cmd,
1108 struct vduse_dev *dev = file->private_data;
1109 void __user *argp = (void __user *)arg;
1112 if (unlikely(dev->broken))
1116 case VDUSE_IOTLB_GET_FD: {
1117 struct vduse_iotlb_entry entry;
1118 struct vhost_iotlb_map *map;
1119 struct vdpa_map_file *map_file;
1120 struct file *f = NULL;
1123 if (copy_from_user(&entry, argp, sizeof(entry)))
1127 if (entry.start > entry.last)
1130 mutex_lock(&dev->domain_lock);
1132 mutex_unlock(&dev->domain_lock);
1135 spin_lock(&dev->domain->iotlb_lock);
1136 map = vhost_iotlb_itree_first(dev->domain->iotlb,
1137 entry.start, entry.last);
1139 map_file = (struct vdpa_map_file *)map->opaque;
1140 f = get_file(map_file->file);
1141 entry.offset = map_file->offset;
1142 entry.start = map->start;
1143 entry.last = map->last;
1144 entry.perm = map->perm;
1146 spin_unlock(&dev->domain->iotlb_lock);
1147 mutex_unlock(&dev->domain_lock);
1153 if (copy_to_user(argp, &entry, sizeof(entry))) {
1157 ret = receive_fd(f, perm_to_file_flags(entry.perm));
1161 case VDUSE_DEV_GET_FEATURES:
1163 * Just mirror what driver wrote here.
1164 * The driver is expected to check FEATURE_OK later.
1166 ret = put_user(dev->driver_features, (u64 __user *)argp);
1168 case VDUSE_DEV_SET_CONFIG: {
1169 struct vduse_config_data config;
1170 unsigned long size = offsetof(struct vduse_config_data,
1174 if (copy_from_user(&config, argp, size))
1178 if (config.offset > dev->config_size ||
1179 config.length == 0 ||
1180 config.length > dev->config_size - config.offset)
1184 if (copy_from_user(dev->config + config.offset, argp + size,
1191 case VDUSE_DEV_INJECT_CONFIG_IRQ:
1192 ret = vduse_dev_queue_irq_work(dev, &dev->inject, IRQ_UNBOUND);
1194 case VDUSE_VQ_SETUP: {
1195 struct vduse_vq_config config;
1199 if (copy_from_user(&config, argp, sizeof(config)))
1203 if (config.index >= dev->vq_num)
1206 if (!is_mem_zero((const char *)config.reserved,
1207 sizeof(config.reserved)))
1210 index = array_index_nospec(config.index, dev->vq_num);
1211 dev->vqs[index]->num_max = config.max_size;
1215 case VDUSE_VQ_GET_INFO: {
1216 struct vduse_vq_info vq_info;
1217 struct vduse_virtqueue *vq;
1221 if (copy_from_user(&vq_info, argp, sizeof(vq_info)))
1225 if (vq_info.index >= dev->vq_num)
1228 index = array_index_nospec(vq_info.index, dev->vq_num);
1229 vq = dev->vqs[index];
1230 vq_info.desc_addr = vq->desc_addr;
1231 vq_info.driver_addr = vq->driver_addr;
1232 vq_info.device_addr = vq->device_addr;
1233 vq_info.num = vq->num;
1235 if (dev->driver_features & BIT_ULL(VIRTIO_F_RING_PACKED)) {
1236 vq_info.packed.last_avail_counter =
1237 vq->state.packed.last_avail_counter;
1238 vq_info.packed.last_avail_idx =
1239 vq->state.packed.last_avail_idx;
1240 vq_info.packed.last_used_counter =
1241 vq->state.packed.last_used_counter;
1242 vq_info.packed.last_used_idx =
1243 vq->state.packed.last_used_idx;
1245 vq_info.split.avail_index =
1246 vq->state.split.avail_index;
1248 vq_info.ready = vq->ready;
1251 if (copy_to_user(argp, &vq_info, sizeof(vq_info)))
1257 case VDUSE_VQ_SETUP_KICKFD: {
1258 struct vduse_vq_eventfd eventfd;
1261 if (copy_from_user(&eventfd, argp, sizeof(eventfd)))
1264 ret = vduse_kickfd_setup(dev, &eventfd);
1267 case VDUSE_VQ_INJECT_IRQ: {
1271 if (get_user(index, (u32 __user *)argp))
1275 if (index >= dev->vq_num)
1279 index = array_index_nospec(index, dev->vq_num);
1280 if (!vduse_vq_signal_irqfd(dev->vqs[index])) {
1281 vduse_vq_update_effective_cpu(dev->vqs[index]);
1282 ret = vduse_dev_queue_irq_work(dev,
1283 &dev->vqs[index]->inject,
1284 dev->vqs[index]->irq_effective_cpu);
1288 case VDUSE_IOTLB_REG_UMEM: {
1289 struct vduse_iova_umem umem;
1292 if (copy_from_user(&umem, argp, sizeof(umem)))
1296 if (!is_mem_zero((const char *)umem.reserved,
1297 sizeof(umem.reserved)))
1300 mutex_lock(&dev->domain_lock);
1301 ret = vduse_dev_reg_umem(dev, umem.iova,
1302 umem.uaddr, umem.size);
1303 mutex_unlock(&dev->domain_lock);
1306 case VDUSE_IOTLB_DEREG_UMEM: {
1307 struct vduse_iova_umem umem;
1310 if (copy_from_user(&umem, argp, sizeof(umem)))
1314 if (!is_mem_zero((const char *)umem.reserved,
1315 sizeof(umem.reserved)))
1317 mutex_lock(&dev->domain_lock);
1318 ret = vduse_dev_dereg_umem(dev, umem.iova,
1320 mutex_unlock(&dev->domain_lock);
1323 case VDUSE_IOTLB_GET_INFO: {
1324 struct vduse_iova_info info;
1325 struct vhost_iotlb_map *map;
1328 if (copy_from_user(&info, argp, sizeof(info)))
1332 if (info.start > info.last)
1335 if (!is_mem_zero((const char *)info.reserved,
1336 sizeof(info.reserved)))
1339 mutex_lock(&dev->domain_lock);
1341 mutex_unlock(&dev->domain_lock);
1344 spin_lock(&dev->domain->iotlb_lock);
1345 map = vhost_iotlb_itree_first(dev->domain->iotlb,
1346 info.start, info.last);
1348 info.start = map->start;
1349 info.last = map->last;
1350 info.capability = 0;
1351 if (dev->domain->bounce_map && map->start == 0 &&
1352 map->last == dev->domain->bounce_size - 1)
1353 info.capability |= VDUSE_IOVA_CAP_UMEM;
1355 spin_unlock(&dev->domain->iotlb_lock);
1356 mutex_unlock(&dev->domain_lock);
1361 if (copy_to_user(argp, &info, sizeof(info)))
1375 static int vduse_dev_release(struct inode *inode, struct file *file)
1377 struct vduse_dev *dev = file->private_data;
1379 mutex_lock(&dev->domain_lock);
1381 vduse_dev_dereg_umem(dev, 0, dev->domain->bounce_size);
1382 mutex_unlock(&dev->domain_lock);
1383 spin_lock(&dev->msg_lock);
1384 /* Make sure the inflight messages can processed after reconncection */
1385 list_splice_init(&dev->recv_list, &dev->send_list);
1386 spin_unlock(&dev->msg_lock);
1387 dev->connected = false;
1392 static struct vduse_dev *vduse_dev_get_from_minor(int minor)
1394 struct vduse_dev *dev;
1396 mutex_lock(&vduse_lock);
1397 dev = idr_find(&vduse_idr, minor);
1398 mutex_unlock(&vduse_lock);
1403 static int vduse_dev_open(struct inode *inode, struct file *file)
1406 struct vduse_dev *dev = vduse_dev_get_from_minor(iminor(inode));
1412 mutex_lock(&dev->lock);
1417 dev->connected = true;
1418 file->private_data = dev;
1420 mutex_unlock(&dev->lock);
1425 static const struct file_operations vduse_dev_fops = {
1426 .owner = THIS_MODULE,
1427 .open = vduse_dev_open,
1428 .release = vduse_dev_release,
1429 .read_iter = vduse_dev_read_iter,
1430 .write_iter = vduse_dev_write_iter,
1431 .poll = vduse_dev_poll,
1432 .unlocked_ioctl = vduse_dev_ioctl,
1433 .compat_ioctl = compat_ptr_ioctl,
1434 .llseek = noop_llseek,
1437 static ssize_t irq_cb_affinity_show(struct vduse_virtqueue *vq, char *buf)
1439 return sprintf(buf, "%*pb\n", cpumask_pr_args(&vq->irq_affinity));
1442 static ssize_t irq_cb_affinity_store(struct vduse_virtqueue *vq,
1443 const char *buf, size_t count)
1445 cpumask_var_t new_value;
1448 if (!zalloc_cpumask_var(&new_value, GFP_KERNEL))
1451 ret = cpumask_parse(buf, new_value);
1456 if (!cpumask_intersects(new_value, cpu_online_mask))
1459 cpumask_copy(&vq->irq_affinity, new_value);
1462 free_cpumask_var(new_value);
1466 struct vq_sysfs_entry {
1467 struct attribute attr;
1468 ssize_t (*show)(struct vduse_virtqueue *vq, char *buf);
1469 ssize_t (*store)(struct vduse_virtqueue *vq, const char *buf,
1473 static struct vq_sysfs_entry irq_cb_affinity_attr = __ATTR_RW(irq_cb_affinity);
1475 static struct attribute *vq_attrs[] = {
1476 &irq_cb_affinity_attr.attr,
1479 ATTRIBUTE_GROUPS(vq);
1481 static ssize_t vq_attr_show(struct kobject *kobj, struct attribute *attr,
1484 struct vduse_virtqueue *vq = container_of(kobj,
1485 struct vduse_virtqueue, kobj);
1486 struct vq_sysfs_entry *entry = container_of(attr,
1487 struct vq_sysfs_entry, attr);
1492 return entry->show(vq, buf);
1495 static ssize_t vq_attr_store(struct kobject *kobj, struct attribute *attr,
1496 const char *buf, size_t count)
1498 struct vduse_virtqueue *vq = container_of(kobj,
1499 struct vduse_virtqueue, kobj);
1500 struct vq_sysfs_entry *entry = container_of(attr,
1501 struct vq_sysfs_entry, attr);
1506 return entry->store(vq, buf, count);
1509 static const struct sysfs_ops vq_sysfs_ops = {
1510 .show = vq_attr_show,
1511 .store = vq_attr_store,
1514 static void vq_release(struct kobject *kobj)
1516 struct vduse_virtqueue *vq = container_of(kobj,
1517 struct vduse_virtqueue, kobj);
1521 static const struct kobj_type vq_type = {
1522 .release = vq_release,
1523 .sysfs_ops = &vq_sysfs_ops,
1524 .default_groups = vq_groups,
1527 static void vduse_dev_deinit_vqs(struct vduse_dev *dev)
1534 for (i = 0; i < dev->vq_num; i++)
1535 kobject_put(&dev->vqs[i]->kobj);
1539 static int vduse_dev_init_vqs(struct vduse_dev *dev, u32 vq_align, u32 vq_num)
1543 dev->vq_align = vq_align;
1544 dev->vq_num = vq_num;
1545 dev->vqs = kcalloc(dev->vq_num, sizeof(*dev->vqs), GFP_KERNEL);
1549 for (i = 0; i < vq_num; i++) {
1550 dev->vqs[i] = kzalloc(sizeof(*dev->vqs[i]), GFP_KERNEL);
1556 dev->vqs[i]->index = i;
1557 dev->vqs[i]->irq_effective_cpu = IRQ_UNBOUND;
1558 INIT_WORK(&dev->vqs[i]->inject, vduse_vq_irq_inject);
1559 INIT_WORK(&dev->vqs[i]->kick, vduse_vq_kick_work);
1560 spin_lock_init(&dev->vqs[i]->kick_lock);
1561 spin_lock_init(&dev->vqs[i]->irq_lock);
1562 cpumask_setall(&dev->vqs[i]->irq_affinity);
1564 kobject_init(&dev->vqs[i]->kobj, &vq_type);
1565 ret = kobject_add(&dev->vqs[i]->kobj,
1566 &dev->dev->kobj, "vq%d", i);
1576 kobject_put(&dev->vqs[i]->kobj);
1582 static struct vduse_dev *vduse_dev_create(void)
1584 struct vduse_dev *dev = kzalloc(sizeof(*dev), GFP_KERNEL);
1589 mutex_init(&dev->lock);
1590 mutex_init(&dev->mem_lock);
1591 mutex_init(&dev->domain_lock);
1592 spin_lock_init(&dev->msg_lock);
1593 INIT_LIST_HEAD(&dev->send_list);
1594 INIT_LIST_HEAD(&dev->recv_list);
1595 spin_lock_init(&dev->irq_lock);
1596 init_rwsem(&dev->rwsem);
1598 INIT_WORK(&dev->inject, vduse_dev_irq_inject);
1599 init_waitqueue_head(&dev->waitq);
1604 static void vduse_dev_destroy(struct vduse_dev *dev)
1609 static struct vduse_dev *vduse_find_dev(const char *name)
1611 struct vduse_dev *dev;
1614 idr_for_each_entry(&vduse_idr, dev, id)
1615 if (!strcmp(dev->name, name))
1621 static int vduse_destroy_dev(char *name)
1623 struct vduse_dev *dev = vduse_find_dev(name);
1628 mutex_lock(&dev->lock);
1629 if (dev->vdev || dev->connected) {
1630 mutex_unlock(&dev->lock);
1633 dev->connected = true;
1634 mutex_unlock(&dev->lock);
1636 vduse_dev_reset(dev);
1637 device_destroy(vduse_class, MKDEV(MAJOR(vduse_major), dev->minor));
1638 idr_remove(&vduse_idr, dev->minor);
1639 kvfree(dev->config);
1640 vduse_dev_deinit_vqs(dev);
1642 vduse_domain_destroy(dev->domain);
1644 vduse_dev_destroy(dev);
1645 module_put(THIS_MODULE);
1650 static bool device_is_allowed(u32 device_id)
1654 for (i = 0; i < ARRAY_SIZE(allowed_device_id); i++)
1655 if (allowed_device_id[i] == device_id)
1661 static bool features_is_valid(u64 features)
1663 if (!(features & (1ULL << VIRTIO_F_ACCESS_PLATFORM)))
1666 /* Now we only support read-only configuration space */
1667 if (features & (1ULL << VIRTIO_BLK_F_CONFIG_WCE))
1673 static bool vduse_validate_config(struct vduse_dev_config *config)
1675 if (!is_mem_zero((const char *)config->reserved,
1676 sizeof(config->reserved)))
1679 if (config->vq_align > PAGE_SIZE)
1682 if (config->config_size > PAGE_SIZE)
1685 if (config->vq_num > 0xffff)
1688 if (!device_is_allowed(config->device_id))
1691 if (!features_is_valid(config->features))
1697 static ssize_t msg_timeout_show(struct device *device,
1698 struct device_attribute *attr, char *buf)
1700 struct vduse_dev *dev = dev_get_drvdata(device);
1702 return sysfs_emit(buf, "%u\n", dev->msg_timeout);
1705 static ssize_t msg_timeout_store(struct device *device,
1706 struct device_attribute *attr,
1707 const char *buf, size_t count)
1709 struct vduse_dev *dev = dev_get_drvdata(device);
1712 ret = kstrtouint(buf, 10, &dev->msg_timeout);
1719 static DEVICE_ATTR_RW(msg_timeout);
1721 static ssize_t bounce_size_show(struct device *device,
1722 struct device_attribute *attr, char *buf)
1724 struct vduse_dev *dev = dev_get_drvdata(device);
1726 return sysfs_emit(buf, "%u\n", dev->bounce_size);
1729 static ssize_t bounce_size_store(struct device *device,
1730 struct device_attribute *attr,
1731 const char *buf, size_t count)
1733 struct vduse_dev *dev = dev_get_drvdata(device);
1734 unsigned int bounce_size;
1738 mutex_lock(&dev->domain_lock);
1742 ret = kstrtouint(buf, 10, &bounce_size);
1747 if (bounce_size > VDUSE_MAX_BOUNCE_SIZE ||
1748 bounce_size < VDUSE_MIN_BOUNCE_SIZE)
1751 dev->bounce_size = bounce_size & PAGE_MASK;
1754 mutex_unlock(&dev->domain_lock);
1758 static DEVICE_ATTR_RW(bounce_size);
1760 static struct attribute *vduse_dev_attrs[] = {
1761 &dev_attr_msg_timeout.attr,
1762 &dev_attr_bounce_size.attr,
1766 ATTRIBUTE_GROUPS(vduse_dev);
1768 static int vduse_create_dev(struct vduse_dev_config *config,
1769 void *config_buf, u64 api_version)
1772 struct vduse_dev *dev;
1775 if (vduse_find_dev(config->name))
1779 dev = vduse_dev_create();
1783 dev->api_version = api_version;
1784 dev->device_features = config->features;
1785 dev->device_id = config->device_id;
1786 dev->vendor_id = config->vendor_id;
1787 dev->name = kstrdup(config->name, GFP_KERNEL);
1791 dev->bounce_size = VDUSE_BOUNCE_SIZE;
1792 dev->config = config_buf;
1793 dev->config_size = config->config_size;
1795 ret = idr_alloc(&vduse_idr, dev, 1, VDUSE_DEV_MAX, GFP_KERNEL);
1800 dev->msg_timeout = VDUSE_MSG_DEFAULT_TIMEOUT;
1801 dev->dev = device_create_with_groups(vduse_class, NULL,
1802 MKDEV(MAJOR(vduse_major), dev->minor),
1803 dev, vduse_dev_groups, "%s", config->name);
1804 if (IS_ERR(dev->dev)) {
1805 ret = PTR_ERR(dev->dev);
1809 ret = vduse_dev_init_vqs(dev, config->vq_align, config->vq_num);
1813 __module_get(THIS_MODULE);
1817 device_destroy(vduse_class, MKDEV(MAJOR(vduse_major), dev->minor));
1819 idr_remove(&vduse_idr, dev->minor);
1823 vduse_dev_destroy(dev);
1828 static long vduse_ioctl(struct file *file, unsigned int cmd,
1832 void __user *argp = (void __user *)arg;
1833 struct vduse_control *control = file->private_data;
1835 mutex_lock(&vduse_lock);
1837 case VDUSE_GET_API_VERSION:
1838 ret = put_user(control->api_version, (u64 __user *)argp);
1840 case VDUSE_SET_API_VERSION: {
1844 if (get_user(api_version, (u64 __user *)argp))
1848 if (api_version > VDUSE_API_VERSION)
1852 control->api_version = api_version;
1855 case VDUSE_CREATE_DEV: {
1856 struct vduse_dev_config config;
1857 unsigned long size = offsetof(struct vduse_dev_config, config);
1861 if (copy_from_user(&config, argp, size))
1865 if (vduse_validate_config(&config) == false)
1868 buf = vmemdup_user(argp + size, config.config_size);
1873 config.name[VDUSE_NAME_MAX - 1] = '\0';
1874 ret = vduse_create_dev(&config, buf, control->api_version);
1879 case VDUSE_DESTROY_DEV: {
1880 char name[VDUSE_NAME_MAX];
1883 if (copy_from_user(name, argp, VDUSE_NAME_MAX))
1886 name[VDUSE_NAME_MAX - 1] = '\0';
1887 ret = vduse_destroy_dev(name);
1894 mutex_unlock(&vduse_lock);
1899 static int vduse_release(struct inode *inode, struct file *file)
1901 struct vduse_control *control = file->private_data;
1907 static int vduse_open(struct inode *inode, struct file *file)
1909 struct vduse_control *control;
1911 control = kmalloc(sizeof(struct vduse_control), GFP_KERNEL);
1915 control->api_version = VDUSE_API_VERSION;
1916 file->private_data = control;
1921 static const struct file_operations vduse_ctrl_fops = {
1922 .owner = THIS_MODULE,
1924 .release = vduse_release,
1925 .unlocked_ioctl = vduse_ioctl,
1926 .compat_ioctl = compat_ptr_ioctl,
1927 .llseek = noop_llseek,
1930 static char *vduse_devnode(const struct device *dev, umode_t *mode)
1932 return kasprintf(GFP_KERNEL, "vduse/%s", dev_name(dev));
1935 struct vduse_mgmt_dev {
1936 struct vdpa_mgmt_dev mgmt_dev;
1940 static struct vduse_mgmt_dev *vduse_mgmt;
1942 static int vduse_dev_init_vdpa(struct vduse_dev *dev, const char *name)
1944 struct vduse_vdpa *vdev;
1950 vdev = vdpa_alloc_device(struct vduse_vdpa, vdpa, dev->dev,
1951 &vduse_vdpa_config_ops, 1, 1, name, true);
1953 return PTR_ERR(vdev);
1957 vdev->vdpa.dev.dma_mask = &vdev->vdpa.dev.coherent_dma_mask;
1958 ret = dma_set_mask_and_coherent(&vdev->vdpa.dev, DMA_BIT_MASK(64));
1960 put_device(&vdev->vdpa.dev);
1963 set_dma_ops(&vdev->vdpa.dev, &vduse_dev_dma_ops);
1964 vdev->vdpa.dma_dev = &vdev->vdpa.dev;
1965 vdev->vdpa.mdev = &vduse_mgmt->mgmt_dev;
1970 static int vdpa_dev_add(struct vdpa_mgmt_dev *mdev, const char *name,
1971 const struct vdpa_dev_set_config *config)
1973 struct vduse_dev *dev;
1976 mutex_lock(&vduse_lock);
1977 dev = vduse_find_dev(name);
1978 if (!dev || !vduse_dev_is_ready(dev)) {
1979 mutex_unlock(&vduse_lock);
1982 ret = vduse_dev_init_vdpa(dev, name);
1983 mutex_unlock(&vduse_lock);
1987 mutex_lock(&dev->domain_lock);
1989 dev->domain = vduse_domain_create(VDUSE_IOVA_SIZE - 1,
1991 mutex_unlock(&dev->domain_lock);
1993 put_device(&dev->vdev->vdpa.dev);
1997 ret = _vdpa_register_device(&dev->vdev->vdpa, dev->vq_num);
1999 put_device(&dev->vdev->vdpa.dev);
2000 mutex_lock(&dev->domain_lock);
2001 vduse_domain_destroy(dev->domain);
2003 mutex_unlock(&dev->domain_lock);
2010 static void vdpa_dev_del(struct vdpa_mgmt_dev *mdev, struct vdpa_device *dev)
2012 _vdpa_unregister_device(dev);
2015 static const struct vdpa_mgmtdev_ops vdpa_dev_mgmtdev_ops = {
2016 .dev_add = vdpa_dev_add,
2017 .dev_del = vdpa_dev_del,
2020 static struct virtio_device_id id_table[] = {
2021 { VIRTIO_ID_BLOCK, VIRTIO_DEV_ANY_ID },
2025 static void vduse_mgmtdev_release(struct device *dev)
2027 struct vduse_mgmt_dev *mgmt_dev;
2029 mgmt_dev = container_of(dev, struct vduse_mgmt_dev, dev);
2033 static int vduse_mgmtdev_init(void)
2037 vduse_mgmt = kzalloc(sizeof(*vduse_mgmt), GFP_KERNEL);
2041 ret = dev_set_name(&vduse_mgmt->dev, "vduse");
2047 vduse_mgmt->dev.release = vduse_mgmtdev_release;
2049 ret = device_register(&vduse_mgmt->dev);
2053 vduse_mgmt->mgmt_dev.id_table = id_table;
2054 vduse_mgmt->mgmt_dev.ops = &vdpa_dev_mgmtdev_ops;
2055 vduse_mgmt->mgmt_dev.device = &vduse_mgmt->dev;
2056 ret = vdpa_mgmtdev_register(&vduse_mgmt->mgmt_dev);
2058 device_unregister(&vduse_mgmt->dev);
2063 put_device(&vduse_mgmt->dev);
2067 static void vduse_mgmtdev_exit(void)
2069 vdpa_mgmtdev_unregister(&vduse_mgmt->mgmt_dev);
2070 device_unregister(&vduse_mgmt->dev);
2073 static int vduse_init(void)
2078 vduse_class = class_create("vduse");
2079 if (IS_ERR(vduse_class))
2080 return PTR_ERR(vduse_class);
2082 vduse_class->devnode = vduse_devnode;
2084 ret = alloc_chrdev_region(&vduse_major, 0, VDUSE_DEV_MAX, "vduse");
2086 goto err_chardev_region;
2088 /* /dev/vduse/control */
2089 cdev_init(&vduse_ctrl_cdev, &vduse_ctrl_fops);
2090 vduse_ctrl_cdev.owner = THIS_MODULE;
2091 ret = cdev_add(&vduse_ctrl_cdev, vduse_major, 1);
2095 dev = device_create(vduse_class, NULL, vduse_major, NULL, "control");
2101 /* /dev/vduse/$DEVICE */
2102 cdev_init(&vduse_cdev, &vduse_dev_fops);
2103 vduse_cdev.owner = THIS_MODULE;
2104 ret = cdev_add(&vduse_cdev, MKDEV(MAJOR(vduse_major), 1),
2110 vduse_irq_wq = alloc_workqueue("vduse-irq",
2111 WQ_HIGHPRI | WQ_SYSFS | WQ_UNBOUND, 0);
2115 vduse_irq_bound_wq = alloc_workqueue("vduse-irq-bound", WQ_HIGHPRI, 0);
2116 if (!vduse_irq_bound_wq)
2119 ret = vduse_domain_init();
2123 ret = vduse_mgmtdev_init();
2129 vduse_domain_exit();
2131 destroy_workqueue(vduse_irq_bound_wq);
2133 destroy_workqueue(vduse_irq_wq);
2135 cdev_del(&vduse_cdev);
2137 device_destroy(vduse_class, vduse_major);
2139 cdev_del(&vduse_ctrl_cdev);
2141 unregister_chrdev_region(vduse_major, VDUSE_DEV_MAX);
2143 class_destroy(vduse_class);
2146 module_init(vduse_init);
2148 static void vduse_exit(void)
2150 vduse_mgmtdev_exit();
2151 vduse_domain_exit();
2152 destroy_workqueue(vduse_irq_bound_wq);
2153 destroy_workqueue(vduse_irq_wq);
2154 cdev_del(&vduse_cdev);
2155 device_destroy(vduse_class, vduse_major);
2156 cdev_del(&vduse_ctrl_cdev);
2157 unregister_chrdev_region(vduse_major, VDUSE_DEV_MAX);
2158 class_destroy(vduse_class);
2160 module_exit(vduse_exit);
2162 MODULE_LICENSE(DRV_LICENSE);
2163 MODULE_AUTHOR(DRV_AUTHOR);
2164 MODULE_DESCRIPTION(DRV_DESC);