drm/xe: Use max wopcm size when validating the preset GuC wopcm size
authorBalasubramani Vivekanandan <balasubramani.vivekanandan@intel.com>
Fri, 17 Mar 2023 16:53:35 +0000 (22:23 +0530)
committerRodrigo Vivi <rodrigo.vivi@intel.com>
Tue, 19 Dec 2023 23:30:20 +0000 (18:30 -0500)
When the GuC wopcm base and size registers are populated by BIOS/IFWI,
validate the parameters against the maximum allowed wopcm size.

Bpsec: 44982

Signed-off-by: Balasubramani Vivekanandan <balasubramani.vivekanandan@intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
drivers/gpu/drm/xe/xe_wopcm.c

index 7bb880355f6ba157b99c2c4010c15034fdf09fff..c8cc3f5e6154add60ffe946b1b60e1e084834a6b 100644 (file)
@@ -54,6 +54,8 @@
                                                   for MTL, do a proper probe
                                                   sooner or later */
 #define GEN11_WOPCM_SIZE               SZ_2M
+
+#define GEN12_MAX_WOPCM_SIZE            SZ_8M
 /* 16KB WOPCM (RSVD WOPCM) is reserved from HuC firmware top. */
 #define WOPCM_RESERVED_SIZE            SZ_16K
 
@@ -221,6 +223,13 @@ int xe_wopcm_init(struct xe_wopcm *wopcm)
        if (locked) {
                drm_dbg(&xe->drm, "GuC WOPCM is already locked [%uK, %uK)\n",
                        guc_wopcm_base / SZ_1K, guc_wopcm_size / SZ_1K);
+               /*
+                * When the GuC wopcm base and size are preprogrammed by
+                * BIOS/IFWI, check against the max allowed wopcm size to
+                * validate if the programmed values align to the wopcm layout.
+                */
+               wopcm->size = GEN12_MAX_WOPCM_SIZE;
+
                goto check;
        }