drm/amdkfd: Conditionally enable PCIe atomics
authorFelix Kuehling <Felix.Kuehling@amd.com>
Thu, 4 Jan 2018 22:17:41 +0000 (17:17 -0500)
committerOded Gabbay <oded.gabbay@gmail.com>
Thu, 4 Jan 2018 22:17:41 +0000 (17:17 -0500)
This will be needed for most dGPUs.

CC: linux-pci@vger.kernel.org
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_device.c
drivers/gpu/drm/amd/amdkfd/kfd_priv.h

index a8fa33a08de301fde244f1584e8a9edeeea40775..fafe971d1d49daaf38a3d354b671ef84a2c479be 100644 (file)
@@ -41,6 +41,7 @@ static const struct kfd_device_info kaveri_device_info = {
        .num_of_watch_points = 4,
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .supports_cwsr = false,
+       .needs_pci_atomics = false,
 };
 
 static const struct kfd_device_info carrizo_device_info = {
@@ -53,6 +54,7 @@ static const struct kfd_device_info carrizo_device_info = {
        .num_of_watch_points = 4,
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .supports_cwsr = true,
+       .needs_pci_atomics = false,
 };
 
 struct kfd_deviceid {
@@ -127,6 +129,21 @@ struct kfd_dev *kgd2kfd_probe(struct kgd_dev *kgd,
                return NULL;
        }
 
+       if (device_info->needs_pci_atomics) {
+               /* Allow BIF to recode atomics to PCIe 3.0
+                * AtomicOps. 32 and 64-bit requests are possible and
+                * must be supported.
+                */
+               if (pci_enable_atomic_ops_to_root(pdev,
+                               PCI_EXP_DEVCAP2_ATOMIC_COMP32 |
+                               PCI_EXP_DEVCAP2_ATOMIC_COMP64) < 0) {
+                       dev_info(kfd_device,
+                               "skipped device %x:%x, PCI rejects atomics",
+                                pdev->vendor, pdev->device);
+                       return NULL;
+               }
+       }
+
        kfd = kzalloc(sizeof(*kfd), GFP_KERNEL);
        if (!kfd)
                return NULL;
index 0bedcf9cc08c7945deaf86e6019505ed43aab6d1..e5b16209f069609de0222cd30c879b5dc3f57b55 100644 (file)
@@ -158,6 +158,7 @@ struct kfd_device_info {
        uint8_t num_of_watch_points;
        uint16_t mqd_size_aligned;
        bool supports_cwsr;
+       bool needs_pci_atomics;
 };
 
 struct kfd_mem_obj {