gt->steering[SQIDI_PSMI].instance_target = select & 0x1;
 }
 
-static void init_steering_inst0(struct xe_gt *gt)
-{
-       gt->steering[INSTANCE0].group_target = 0;       /* unused */
-       gt->steering[INSTANCE0].instance_target = 0;    /* unused */
-}
-
 static const struct {
        const char *name;
        void (*init)(struct xe_gt *gt);
        [DSS] =         { "DSS",        init_steering_dss },
        [OADDRM] =      { "OADDRM / GPMXMT", init_steering_oaddrm },
        [SQIDI_PSMI] =  { "SQIDI_PSMI", init_steering_sqidi_psmi },
-       [INSTANCE0] =   { "INSTANCE 0", init_steering_inst0 },
+       [INSTANCE0] =   { "INSTANCE 0", NULL },
        [IMPLICIT_STEERING] = { "IMPLICIT", NULL },
 };
 
  *
  * Perform early software only initialization of the MCR lock to allow
  * the synchronization on accessing the STEER_SEMAPHORE register and
- * use the xe_gt_mcr_multicast_write() function.
+ * use the xe_gt_mcr_multicast_write() function, plus the minimum
+ * safe MCR registers required for VRAM/CCS probing.
  */
 void xe_gt_mcr_init_early(struct xe_gt *gt)
 {
+       struct xe_device *xe = gt_to_xe(gt);
+
        BUILD_BUG_ON(IMPLICIT_STEERING + 1 != NUM_STEERING_TYPES);
        BUILD_BUG_ON(ARRAY_SIZE(xe_steering_types) != NUM_STEERING_TYPES);
 
        spin_lock_init(>->mcr_lock);
-}
-
-/**
- * xe_gt_mcr_init - Normal initialization of the MCR support
- * @gt: GT structure
- *
- * Perform normal initialization of the MCR for all usages.
- */
-void xe_gt_mcr_init(struct xe_gt *gt)
-{
-       struct xe_device *xe = gt_to_xe(gt);
 
        if (IS_SRIOV_VF(xe))
                return;
                }
        }
 
+       /* Mark instance 0 as initialized, we need this early for VRAM and CCS probe. */
+       gt->steering[INSTANCE0].initialized = true;
+}
+
+/**
+ * xe_gt_mcr_init - Normal initialization of the MCR support
+ * @gt: GT structure
+ *
+ * Perform normal initialization of the MCR for all usages.
+ */
+void xe_gt_mcr_init(struct xe_gt *gt)
+{
+       if (IS_SRIOV_VF(gt_to_xe(gt)))
+               return;
+
        /* Select non-terminated steering target for each type */
-       for (int i = 0; i < NUM_STEERING_TYPES; i++)
+       for (int i = 0; i < NUM_STEERING_TYPES; i++) {
+               gt->steering[i].initialized = true;
                if (gt->steering[i].ranges && xe_steering_types[i].init)
                        xe_steering_types[i].init(gt);
+       }
 }
 
 /**
 
                for (int i = 0; gt->steering[type].ranges[i].end > 0; i++) {
                        if (xe_mmio_in_range(>->mmio, >->steering[type].ranges[i], reg)) {
+                               drm_WARN(>_to_xe(gt)->drm, !gt->steering[type].initialized,
+                                        "Uninitialized usage of MCR register %s/%#x\n",
+                                        xe_steering_types[type].name, reg.addr);
+
                                *group = gt->steering[type].group_target;
                                *instance = gt->steering[type].instance_target;
                                return true;