Le 03/07/2025 à 01:28, Matthew Brost a écrit :
Rather than returning ERR_PTR or NULL on failure, replace the NULL
return with ERR_PTR(-ENOMEM). This simplifies error handling at the
caller. While here, add kernel documentation for
drmm_alloc_ordered_workqueue.

Cc: Louis Chauvet <[email protected]>
Signed-off-by: Matthew Brost <[email protected]>

Reviewed-by: Louis Chauvet <[email protected]>

As you need it in xe, I don't know the process to apply the patch. Should I apply it on drm-misc-next?

Thanks,
Louis Chauvet

---
  drivers/gpu/drm/vkms/vkms_crtc.c |  2 --
  include/drm/drm_managed.h        | 15 +++++++++++++--
  2 files changed, 13 insertions(+), 4 deletions(-)

diff --git a/drivers/gpu/drm/vkms/vkms_crtc.c b/drivers/gpu/drm/vkms/vkms_crtc.c
index 8c9898b9055d..e60573e0f3e9 100644
--- a/drivers/gpu/drm/vkms/vkms_crtc.c
+++ b/drivers/gpu/drm/vkms/vkms_crtc.c
@@ -302,8 +302,6 @@ struct vkms_output *vkms_crtc_init(struct drm_device *dev, 
struct drm_plane *pri
        vkms_out->composer_workq = drmm_alloc_ordered_workqueue(dev, 
"vkms_composer", 0);
        if (IS_ERR(vkms_out->composer_workq))
                return ERR_CAST(vkms_out->composer_workq);
-       if (!vkms_out->composer_workq)
-               return ERR_PTR(-ENOMEM);
return vkms_out;
  }
diff --git a/include/drm/drm_managed.h b/include/drm/drm_managed.h
index 53017cc609ac..72bfac002c06 100644
--- a/include/drm/drm_managed.h
+++ b/include/drm/drm_managed.h
@@ -129,14 +129,25 @@ void __drmm_mutex_release(struct drm_device *dev, void 
*res);
void __drmm_workqueue_release(struct drm_device *device, void *wq); +/**
+ * drmm_alloc_ordered_workqueue - &drm_device managed alloc_ordered_workqueue()
+ * @dev: DRM device
+ * @fmt: printf format for the name of the workqueue
+ * @flags: WQ_* flags (only WQ_FREEZABLE and WQ_MEM_RECLAIM are meaningful)
+ * @args: args for @fmt
+ *
+ * This is a &drm_device-managed version of alloc_ordered_workqueue(). The
+ * allocated workqueue is automatically destroyed on the final drm_dev_put().
+ *
+ * Returns: workqueue on success, negative ERR_PTR otherwise.
+ */
  #define drmm_alloc_ordered_workqueue(dev, fmt, flags, args...)                
                        \
        ({                                                                      
                \
                struct workqueue_struct *wq = alloc_ordered_workqueue(fmt, 
flags, ##args);      \
                wq ? ({                                                         
                \
                        int ret = drmm_add_action_or_reset(dev, 
__drmm_workqueue_release, wq);  \
                        ret ? ERR_PTR(ret) : wq;                                
                \
-               }) :                                                            
                \
-                       wq;                                                     
                \
+               }) : ERR_PTR(-ENOMEM);                                          
                \
        })
#endif

--
Louis Chauvet, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com

Reply via email to