drm/xe: Stash GMD_ID value in xe_gt
authorMatt Roper <matthew.d.roper@intel.com>
Tue, 23 Jan 2024 20:44:49 +0000 (12:44 -0800)
committerJosé Roberto de Souza <jose.souza@intel.com>
Wed, 24 Jan 2024 19:08:18 +0000 (11:08 -0800)
Although we've stored the major and minor versions for graphics/media in
xe_device, it will be simpler to implement the uapi version query if we
also stash the raw register value in the GT itself.

Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Reviewed-by: Lucas De Marchi <lucas.demarchi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240123204454.246788-4-jose.souza@intel.com
Signed-off-by: José Roberto de Souza <jose.souza@intel.com>
drivers/gpu/drm/xe/xe_gt.c
drivers/gpu/drm/xe/xe_gt_types.h

index 1fe4d54409d3449164c2f1dfb95a701173b4adf9..47cb87f599e463ea1c2c9c74116c33c766c6fa60 100644 (file)
@@ -399,6 +399,12 @@ static int gt_fw_domain_init(struct xe_gt *gt)
        /* Initialize CCS mode sysfs after early initialization of HW engines */
        xe_gt_ccs_mode_sysfs_init(gt);
 
+       /*
+        * Stash hardware-reported version.  Since this register does not exist
+        * on pre-MTL platforms, reading it there will (correctly) return 0.
+        */
+       gt->info.gmdid = xe_mmio_read32(gt, GMD_ID);
+
        err = xe_force_wake_put(gt_to_fw(gt), XE_FW_GT);
        XE_WARN_ON(err);
        xe_device_mem_access_put(gt_to_xe(gt));
index 3caaea2ff908a8433d7fcb29166a3b684438970e..70c615dd14986599324a2fb68f766889761c7eb1 100644 (file)
@@ -117,6 +117,8 @@ struct xe_gt {
                 * hwconfig blob.
                 */
                u64 __engine_mask;
+               /** @info.gmdid: raw GMD_ID value from hardware */
+               u32 gmdid;
        } info;
 
        /**