]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/xe: Fix the warning conditions
authorHimal Prasad Ghimiray <himal.prasad.ghimiray@intel.com>
Wed, 8 May 2024 15:22:16 +0000 (20:52 +0530)
committerRodrigo Vivi <rodrigo.vivi@intel.com>
Tue, 14 May 2024 15:26:40 +0000 (11:26 -0400)
The maximum timeout display uses in xe_pcode_request is 3 msec, add the
warning in cases the function is misused with higher timeouts.

Add a warning if pcode_try_request is not passed the timeout parameter
greater than 0.

Cc: Lucas De Marchi <lucas.demarchi@intel.com>
Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: Himal Prasad Ghimiray <himal.prasad.ghimiray@intel.com>
Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240508152216.3263109-3-himal.prasad.ghimiray@intel.com
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
drivers/gpu/drm/xe/xe_pcode.c

index a5e7da8cf94416669458e21dc8b0ade051fefa51..9c4eefdf6642846430faa1286e9e8bfc2dec0296 100644 (file)
@@ -10,6 +10,7 @@
 
 #include <drm/drm_managed.h>
 
+#include "xe_assert.h"
 #include "xe_device.h"
 #include "xe_gt.h"
 #include "xe_mmio.h"
@@ -124,6 +125,8 @@ static int pcode_try_request(struct xe_gt *gt, u32 mbox,
 {
        int slept, wait = 10;
 
+       xe_gt_assert(gt, timeout_us > 0);
+
        for (slept = 0; slept < timeout_us; slept += wait) {
                if (locked)
                        *status = pcode_mailbox_rw(gt, mbox, &request, NULL, 1, true,
@@ -169,6 +172,8 @@ int xe_pcode_request(struct xe_gt *gt, u32 mbox, u32 request,
        u32 status;
        int ret;
 
+       xe_gt_assert(gt, timeout_base_ms <= 3);
+
        mutex_lock(&gt->pcode.lock);
 
        ret = pcode_try_request(gt, mbox, request, reply_mask, reply, &status,
@@ -188,7 +193,6 @@ int xe_pcode_request(struct xe_gt *gt, u32 mbox, u32 request,
         */
        drm_err(&gt_to_xe(gt)->drm,
                "PCODE timeout, retrying with preemption disabled\n");
-       drm_WARN_ON_ONCE(&gt_to_xe(gt)->drm, timeout_base_ms > 1);
        preempt_disable();
        ret = pcode_try_request(gt, mbox, request, reply_mask, reply, &status,
                                true, 50 * 1000, true);