drm/amdkfd: Module option to disable CRAT table
authorFelix Kuehling <Felix.Kuehling@amd.com>
Sat, 9 Dec 2017 04:09:03 +0000 (23:09 -0500)
committerOded Gabbay <oded.gabbay@gmail.com>
Sat, 9 Dec 2017 04:09:03 +0000 (23:09 -0500)
Some systems have broken CRAT tables. Add a module option to ignore
a CRAT table.

Signed-off-by: Felix Kuehling <Felix.Kuehling@amd.com>
Reviewed-by: Oded Gabbay <oded.gabbay@gmail.com>
Signed-off-by: Oded Gabbay <oded.gabbay@gmail.com>
drivers/gpu/drm/amd/amdkfd/kfd_crat.c
drivers/gpu/drm/amd/amdkfd/kfd_module.c
drivers/gpu/drm/amd/amdkfd/kfd_priv.h

index d00061b751935eed56d378fcdd4c13dcb4e20062..2bc2816767a7bbda4ea85fce39c83e05c9215058 100644 (file)
@@ -696,6 +696,11 @@ int kfd_create_crat_image_acpi(void **crat_image, size_t *size)
                return -EINVAL;
        }
 
+       if (ignore_crat) {
+               pr_info("CRAT table disabled by module option\n");
+               return -ENODATA;
+       }
+
        pcrat_image = kmalloc(crat_table->length, GFP_KERNEL);
        if (!pcrat_image)
                return -ENOMEM;
index f50e4949a2ed27eaf5785efc32a0d74f0e7425ee..3ac72bed4f310a803b426a2483e40161020d5e41 100644 (file)
@@ -69,6 +69,11 @@ module_param(send_sigterm, int, 0444);
 MODULE_PARM_DESC(send_sigterm,
        "Send sigterm to HSA process on unhandled exception (0 = disable, 1 = enable)");
 
+int ignore_crat;
+module_param(ignore_crat, int, 0444);
+MODULE_PARM_DESC(ignore_crat,
+       "Ignore CRAT table during KFD initialization (0 = use CRAT (default), 1 = ignore CRAT)");
+
 static int amdkfd_init_completed;
 
 int kgd2kfd_init(unsigned int interface_version,
index f0327c219879559ea391e40c09eb5985ffd9f9b9..6a48d29ada47eefc4ea755cbd635d531bdbffb49 100644 (file)
@@ -104,6 +104,12 @@ extern int cwsr_enable;
  */
 extern int send_sigterm;
 
+/*
+ * Ignore CRAT table during KFD initialization, can be used to work around
+ * broken CRAT tables on some AMD systems
+ */
+extern int ignore_crat;
+
 /**
  * enum kfd_sched_policy
  *