dmaengine: idxd: add per DSA wq workqueue for processing cr faults
authorDave Jiang <dave.jiang@intel.com>
Fri, 7 Apr 2023 20:31:33 +0000 (13:31 -0700)
committerVinod Koul <vkoul@kernel.org>
Wed, 12 Apr 2023 17:48:45 +0000 (23:18 +0530)
Add a workqueue for user submitted completion record fault processing.
The workqueue creation and destruction lifetime will be tied to the user
sub-driver since it will only be used when the wq is a user type.

Tested-by: Tony Zhu <tony.zhu@intel.com>
Signed-off-by: Dave Jiang <dave.jiang@intel.com>
Co-developed-by: Fenghua Yu <fenghua.yu@intel.com>
Signed-off-by: Fenghua Yu <fenghua.yu@intel.com>
Link: https://lore.kernel.org/r/20230407203143.2189681-7-fenghua.yu@intel.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/idxd/cdev.c
drivers/dma/idxd/idxd.h

index 674bfefca088db7a8908866a44615343611e20be..cbe29e1a6a449cded24f68343fdf9bac10770d92 100644 (file)
@@ -330,6 +330,13 @@ static int idxd_user_drv_probe(struct idxd_dev *idxd_dev)
        }
 
        mutex_lock(&wq->wq_lock);
+
+       wq->wq = create_workqueue(dev_name(wq_confdev(wq)));
+       if (!wq->wq) {
+               rc = -ENOMEM;
+               goto wq_err;
+       }
+
        wq->type = IDXD_WQT_USER;
        rc = drv_enable_wq(wq);
        if (rc < 0)
@@ -348,7 +355,9 @@ static int idxd_user_drv_probe(struct idxd_dev *idxd_dev)
 err_cdev:
        drv_disable_wq(wq);
 err:
+       destroy_workqueue(wq->wq);
        wq->type = IDXD_WQT_NONE;
+wq_err:
        mutex_unlock(&wq->wq_lock);
        return rc;
 }
@@ -361,6 +370,8 @@ static void idxd_user_drv_remove(struct idxd_dev *idxd_dev)
        idxd_wq_del_cdev(wq);
        drv_disable_wq(wq);
        wq->type = IDXD_WQT_NONE;
+       destroy_workqueue(wq->wq);
+       wq->wq = NULL;
        mutex_unlock(&wq->wq_lock);
 }
 
index b923b90b729975768c71f1ee1534688ef823a1b8..6e56361ae658b557348860eec0c789833ee388eb 100644 (file)
@@ -185,6 +185,7 @@ struct idxd_wq {
        struct idxd_dev idxd_dev;
        struct idxd_cdev *idxd_cdev;
        struct wait_queue_head err_queue;
+       struct workqueue_struct *wq;
        struct idxd_device *idxd;
        int id;
        struct idxd_irq_entry ie;