[Bf-blender-cvs] [2822744b0be] blender-v2.83-release: Fix T77095: fix Cycles performance regression with AMD RX cards

Brecht Van Lommel noreply at git.blender.org
Thu Jul 2 09:33:39 CEST 2020


Commit: 2822744b0bee0200fd345afca984f496bd0e058e
Author: Brecht Van Lommel
Date:   Fri Jun 26 17:43:32 2020 +0200
Branches: blender-v2.83-release
https://developer.blender.org/rB2822744b0bee0200fd345afca984f496bd0e058e

Fix T77095: fix Cycles performance regression with AMD RX cards

Apply the workaround only for known problematic drivers. The latest pro driver
appears to work correctly, hopefully the regular driver will as well once it
is updated to the same OpenCL driver version (3075.13).

===================================================================

M	intern/cycles/device/opencl/device_opencl_impl.cpp

===================================================================

diff --git a/intern/cycles/device/opencl/device_opencl_impl.cpp b/intern/cycles/device/opencl/device_opencl_impl.cpp
index f9a6552d484..df524ed1a5d 100644
--- a/intern/cycles/device/opencl/device_opencl_impl.cpp
+++ b/intern/cycles/device/opencl/device_opencl_impl.cpp
@@ -1892,10 +1892,8 @@ void OpenCLDevice::shader(DeviceTask &task)
   }
 }
 
-string OpenCLDevice::kernel_build_options(const string *debug_src)
+static bool kernel_build_opencl_2(cl_device_id cdDevice)
 {
-  string build_options = "-cl-no-signed-zeros -cl-mad-enable ";
-
   /* Build with OpenCL 2.0 if available, this improves performance
    * with AMD OpenCL drivers on Windows and Linux (legacy drivers).
    * Note that OpenCL selects the highest 1.x version by default,
@@ -1903,18 +1901,36 @@ string OpenCLDevice::kernel_build_options(const string *debug_src)
   int version_major, version_minor;
   if (OpenCLInfo::get_device_version(cdDevice, &version_major, &version_minor)) {
     if (version_major >= 2) {
-      /* This appears to trigger a driver bug in Radeon RX cards, so we
-       * don't use OpenCL 2.0 for those. */
+      /* This appears to trigger a driver bug in Radeon RX cards with certain
+       * driver version, so don't use OpenCL 2.0 for those. */
       string device_name = OpenCLInfo::get_readable_device_name(cdDevice);
-      if (!(string_startswith(device_name, "Radeon RX 4") ||
-            string_startswith(device_name, "Radeon (TM) RX 4") ||
-            string_startswith(device_name, "Radeon RX 5") ||
-            string_startswith(device_name, "Radeon (TM) RX 5"))) {
-        build_options += "-cl-std=CL2.0 ";
+      if (string_startswith(device_name, "Radeon RX 4") ||
+          string_startswith(device_name, "Radeon (TM) RX 4") ||
+          string_startswith(device_name, "Radeon RX 5") ||
+          string_startswith(device_name, "Radeon (TM) RX 5")) {
+        char version[256] = "";
+        int driver_major, driver_minor;
+        clGetDeviceInfo(cdDevice, CL_DEVICE_VERSION, sizeof(version), &version, NULL);
+        if (sscanf(version, "OpenCL 2.0 AMD-APP (%d.%d)", &driver_major, &driver_minor) == 2) {
+          return !(driver_major == 3075 && driver_minor <= 12);
+        }
       }
+
+      return true;
     }
   }
 
+  return false;
+}
+
+string OpenCLDevice::kernel_build_options(const string *debug_src)
+{
+  string build_options = "-cl-no-signed-zeros -cl-mad-enable ";
+
+  if (kernel_build_opencl_2(cdDevice)) {
+    build_options += "-cl-std=CL2.0 ";
+  }
+
   if (platform_name == "NVIDIA CUDA") {
     build_options +=
         "-D__KERNEL_OPENCL_NVIDIA__ "



More information about the Bf-blender-cvs mailing list