intel/common: initialize format of aux mapping on GFX12
authorJianxun Zhang <jianxun.zhang@intel.com>
Fri, 11 Nov 2022 22:51:04 +0000 (14:51 -0800)
committerMarge Bot <emma+marge@anholt.net>
Fri, 9 Dec 2022 09:49:42 +0000 (09:49 +0000)
Signed-off-by: Jianxun Zhang <jianxun.zhang@intel.com>
Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20167>

src/intel/common/intel_aux_map.c

index 1b162e3bee4c9b1eec44cb32cebe8b98ba6e9882..385d4759adf221822260e5c172c05bf20d6f795f 100644 (file)
@@ -213,6 +213,13 @@ get_format(enum intel_aux_map_format format)
    return &aux_formats[format];
 }
 
+static enum intel_aux_map_format
+select_format(const struct intel_device_info *devinfo)
+{
+   return devinfo->verx10 ==
+         120 ? INTEL_AUX_MAP_GFX12_64KB : INTEL_AUX_MAP_LAST;
+}
+
 static bool
 add_buffer(struct intel_aux_map_context *ctx)
 {
@@ -306,7 +313,9 @@ intel_aux_map_init(void *driver_ctx,
                    const struct intel_device_info *devinfo)
 {
    struct intel_aux_map_context *ctx;
-   if (devinfo->ver < 12)
+
+   enum intel_aux_map_format format = select_format(devinfo);
+   if (format == INTEL_AUX_MAP_LAST)
       return NULL;
 
    ctx = ralloc(NULL, struct intel_aux_map_context);
@@ -316,6 +325,7 @@ intel_aux_map_init(void *driver_ctx,
    if (pthread_mutex_init(&ctx->mutex, NULL))
       return NULL;
 
+   ctx->format = get_format(format);
    ctx->driver_ctx = driver_ctx;
    ctx->buffer_alloc = buffer_alloc;
    ctx->num_buffers = 0;