drm/xe/vf: Mark supported firmwares as preloaded
authorMichal Wajdeczko <michal.wajdeczko@intel.com>
Thu, 4 Apr 2024 17:38:14 +0000 (19:38 +0200)
committerMichal Wajdeczko <michal.wajdeczko@intel.com>
Mon, 8 Apr 2024 12:58:52 +0000 (14:58 +0200)
On current platforms supported firmwares, like GuC and HuC, must
be loaded by the PF driver.  Mark those firmwares as 'preloaded'
so we will skip fetching and loading them on the VF drivers but
still correctly report them as 'running'.

Signed-off-by: Michal Wajdeczko <michal.wajdeczko@intel.com>
Reviewed-by: Piotr PiĆ³rkowski <piotr.piorkowski@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240404173814.715-1-michal.wajdeczko@intel.com
drivers/gpu/drm/xe/xe_uc_fw.c
drivers/gpu/drm/xe/xe_uc_fw.h
drivers/gpu/drm/xe/xe_uc_fw_types.h

index ec62296aec33881849a12fc495a9670c9229769b..186f81640cefcafe485dbebcee487403dce2d874 100644 (file)
@@ -17,6 +17,7 @@
 #include "xe_map.h"
 #include "xe_mmio.h"
 #include "xe_module.h"
+#include "xe_sriov.h"
 #include "xe_uc_fw.h"
 
 /*
@@ -650,7 +651,17 @@ static int uc_fw_request(struct xe_uc_fw *uc_fw, const struct firmware **firmwar
        xe_assert(xe, !uc_fw->path);
 
        uc_fw_auto_select(xe, uc_fw);
+
+       if (IS_SRIOV_VF(xe)) {
+               /* VF will support only firmwares that driver can autoselect */
+               xe_uc_fw_change_status(uc_fw, uc_fw->path ?
+                                      XE_UC_FIRMWARE_PRELOADED :
+                                      XE_UC_FIRMWARE_NOT_SUPPORTED);
+               return 0;
+       }
+
        uc_fw_override(uc_fw);
+
        xe_uc_fw_change_status(uc_fw, uc_fw->path ?
                               XE_UC_FIRMWARE_SELECTED :
                               XE_UC_FIRMWARE_NOT_SUPPORTED);
index 85c20795d1f8c4e6f405a5e49e93e4509af411a0..35078038797e7ef3e51d77d403cb519cf3f75ccd 100644 (file)
@@ -59,6 +59,8 @@ const char *xe_uc_fw_status_repr(enum xe_uc_fw_status status)
                return "TRANSFERRED";
        case XE_UC_FIRMWARE_RUNNING:
                return "RUNNING";
+       case XE_UC_FIRMWARE_PRELOADED:
+               return "PRELOADED";
        }
        return "<invalid>";
 }
@@ -85,6 +87,7 @@ static inline int xe_uc_fw_status_to_error(enum xe_uc_fw_status status)
        case XE_UC_FIRMWARE_LOADABLE:
        case XE_UC_FIRMWARE_TRANSFERRED:
        case XE_UC_FIRMWARE_RUNNING:
+       case XE_UC_FIRMWARE_PRELOADED:
                return 0;
        }
        return -EINVAL;
@@ -134,7 +137,8 @@ static inline bool xe_uc_fw_is_available(struct xe_uc_fw *uc_fw)
 
 static inline bool xe_uc_fw_is_loadable(struct xe_uc_fw *uc_fw)
 {
-       return __xe_uc_fw_status(uc_fw) >= XE_UC_FIRMWARE_LOADABLE;
+       return __xe_uc_fw_status(uc_fw) >= XE_UC_FIRMWARE_LOADABLE &&
+               __xe_uc_fw_status(uc_fw) != XE_UC_FIRMWARE_PRELOADED;
 }
 
 static inline bool xe_uc_fw_is_loaded(struct xe_uc_fw *uc_fw)
@@ -144,7 +148,7 @@ static inline bool xe_uc_fw_is_loaded(struct xe_uc_fw *uc_fw)
 
 static inline bool xe_uc_fw_is_running(struct xe_uc_fw *uc_fw)
 {
-       return __xe_uc_fw_status(uc_fw) == XE_UC_FIRMWARE_RUNNING;
+       return __xe_uc_fw_status(uc_fw) >= XE_UC_FIRMWARE_RUNNING;
 }
 
 static inline bool xe_uc_fw_is_overridden(const struct xe_uc_fw *uc_fw)
index bc800b6968662885420c618e261bcb77e08853e2..0d8caa0e7354840184a9ba64da328ac22f37ea0b 100644 (file)
@@ -50,7 +50,8 @@ enum xe_uc_fw_status {
        XE_UC_FIRMWARE_LOADABLE, /* all fw-required objects are ready */
        XE_UC_FIRMWARE_LOAD_FAIL, /* failed to xfer or init/auth the fw */
        XE_UC_FIRMWARE_TRANSFERRED, /* dma xfer done */
-       XE_UC_FIRMWARE_RUNNING /* init/auth done */
+       XE_UC_FIRMWARE_RUNNING, /* init/auth done */
+       XE_UC_FIRMWARE_PRELOADED, /* preloaded by the PF driver */
 };
 
 enum xe_uc_fw_type {