drm/amdgpu/discovery: init reg base offset via ip discovery for navi14
authorXiaojie Yuan <xiaojie.yuan@amd.com>
Wed, 5 Jun 2019 09:58:57 +0000 (17:58 +0800)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 18 Jul 2019 19:17:58 +0000 (14:17 -0500)
Add IP discovery for navi14.

Signed-off-by: Xiaojie Yuan <xiaojie.yuan@amd.com>
Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/navi14_reg_init.c

index 28f3d6490649be6cdd425fb2a27c11c8d1d3a5ce..864668a7f1d2501e3992d17a026c12b61e7f66b6 100644 (file)
 
 int navi14_reg_base_init(struct amdgpu_device *adev)
 {
-       /* HW has more IP blocks,  only initialized the blocke needed by driver */
-       uint32_t i;
+       int r, i;
+
+       if (amdgpu_discovery) {
+               r = amdgpu_discovery_reg_base_init(adev);
+               if (r) {
+                       DRM_WARN("failed to init reg base from ip discovery table, "
+                                       "fallback to legacy init method\n");
+                       goto legacy_init;
+               }
+
+               return 0;
+       }
+
+legacy_init:
        for (i = 0 ; i < MAX_INSTANCE ; ++i) {
                adev->reg_offset[GC_HWIP][i] = (uint32_t *)(&(GC_BASE.instance[i]));
                adev->reg_offset[HDP_HWIP][i] = (uint32_t *)(&(HDP_BASE.instance[i]));
@@ -49,5 +61,6 @@ int navi14_reg_base_init(struct amdgpu_device *adev)
                adev->reg_offset[THM_HWIP][i] = (uint32_t *)(&(THM_BASE.instance[i]));
                adev->reg_offset[CLK_HWIP][i] = (uint32_t *)(&(CLK_BASE.instance[i]));
        }
+
        return 0;
 }