]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/xe/guc: Add more GuC load error status codes
authorJohn Harrison <John.C.Harrison@Intel.com>
Sat, 26 Jul 2025 02:43:37 +0000 (19:43 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 13 Nov 2025 20:34:09 +0000 (15:34 -0500)
[ Upstream commit 45fbb51050e72723c2bdcedc1ce32305256c70ed ]

The GuC load process will abort if certain status codes (which are
indicative of a fatal error) are reported. Otherwise, it keeps waiting
until the 'success' code is returned. New error codes have been added
in recent GuC releases, so add support for aborting on those as well.

v2: Shuffle HWCONFIG_START to the front of the switch to keep the
ordering as per the enum define for clarity (review feedback by
Jonathan). Also add a description for the basic 'invalid init data'
code which was missing.

Signed-off-by: John Harrison <John.C.Harrison@Intel.com>
Reviewed-by: Stuart Summers <stuart.summers@intel.com>
Link: https://lore.kernel.org/r/20250726024337.4056272-1-John.C.Harrison@Intel.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/gpu/drm/xe/abi/guc_errors_abi.h
drivers/gpu/drm/xe/xe_guc.c

index 2c627a21648f76077443d02166de754c7d1644f5..9260f4a1997d95046acd07613c55f3ec480c55c0 100644 (file)
@@ -55,6 +55,7 @@ enum xe_guc_load_status {
        XE_GUC_LOAD_STATUS_HWCONFIG_START                   = 0x05,
        XE_GUC_LOAD_STATUS_HWCONFIG_DONE                    = 0x06,
        XE_GUC_LOAD_STATUS_HWCONFIG_ERROR                   = 0x07,
+       XE_GUC_LOAD_STATUS_BOOTROM_VERSION_MISMATCH         = 0x08,
        XE_GUC_LOAD_STATUS_GDT_DONE                         = 0x10,
        XE_GUC_LOAD_STATUS_IDT_DONE                         = 0x20,
        XE_GUC_LOAD_STATUS_LAPIC_DONE                       = 0x30,
@@ -67,6 +68,8 @@ enum xe_guc_load_status {
        XE_GUC_LOAD_STATUS_INVALID_INIT_DATA_RANGE_START,
        XE_GUC_LOAD_STATUS_MPU_DATA_INVALID                 = 0x73,
        XE_GUC_LOAD_STATUS_INIT_MMIO_SAVE_RESTORE_INVALID   = 0x74,
+       XE_GUC_LOAD_STATUS_KLV_WORKAROUND_INIT_ERROR        = 0x75,
+       XE_GUC_LOAD_STATUS_INVALID_FTR_FLAG                 = 0x76,
        XE_GUC_LOAD_STATUS_INVALID_INIT_DATA_RANGE_END,
 
        XE_GUC_LOAD_STATUS_READY                            = 0xF0,
index 96373cdb366be580687fc2959d16af01579027f4..907a458c9eff5d6d2f6f5f549efd45318688c519 100644 (file)
@@ -527,11 +527,14 @@ static int guc_load_done(u32 status)
        case XE_GUC_LOAD_STATUS_GUC_PREPROD_BUILD_MISMATCH:
        case XE_GUC_LOAD_STATUS_ERROR_DEVID_INVALID_GUCTYPE:
        case XE_GUC_LOAD_STATUS_HWCONFIG_ERROR:
+       case XE_GUC_LOAD_STATUS_BOOTROM_VERSION_MISMATCH:
        case XE_GUC_LOAD_STATUS_DPC_ERROR:
        case XE_GUC_LOAD_STATUS_EXCEPTION:
        case XE_GUC_LOAD_STATUS_INIT_DATA_INVALID:
        case XE_GUC_LOAD_STATUS_MPU_DATA_INVALID:
        case XE_GUC_LOAD_STATUS_INIT_MMIO_SAVE_RESTORE_INVALID:
+       case XE_GUC_LOAD_STATUS_KLV_WORKAROUND_INIT_ERROR:
+       case XE_GUC_LOAD_STATUS_INVALID_FTR_FLAG:
                return -1;
        }
 
@@ -670,17 +673,29 @@ static void guc_wait_ucode(struct xe_guc *guc)
                }
 
                switch (ukernel) {
+               case XE_GUC_LOAD_STATUS_HWCONFIG_START:
+                       xe_gt_err(gt, "still extracting hwconfig table.\n");
+                       break;
+
                case XE_GUC_LOAD_STATUS_EXCEPTION:
                        xe_gt_err(gt, "firmware exception. EIP: %#x\n",
                                  xe_mmio_read32(gt, SOFT_SCRATCH(13)));
                        break;
 
+               case XE_GUC_LOAD_STATUS_INIT_DATA_INVALID:
+                       xe_gt_err(gt, "illegal init/ADS data\n");
+                       break;
+
                case XE_GUC_LOAD_STATUS_INIT_MMIO_SAVE_RESTORE_INVALID:
                        xe_gt_err(gt, "illegal register in save/restore workaround list\n");
                        break;
 
-               case XE_GUC_LOAD_STATUS_HWCONFIG_START:
-                       xe_gt_err(gt, "still extracting hwconfig table.\n");
+               case XE_GUC_LOAD_STATUS_KLV_WORKAROUND_INIT_ERROR:
+                       xe_gt_err(gt, "illegal workaround KLV data\n");
+                       break;
+
+               case XE_GUC_LOAD_STATUS_INVALID_FTR_FLAG:
+                       xe_gt_err(gt, "illegal feature flag specified\n");
                        break;
                }