diff options
| author | Michael Ellerman <mpe@ellerman.id.au> | 2022-10-31 17:37:21 +1100 | 
|---|---|---|
| committer | Michael Ellerman <mpe@ellerman.id.au> | 2022-10-31 17:37:21 +1100 | 
| commit | f98b4d13717a58b15c00880d2ccd24972316b430 (patch) | |
| tree | c3b50090ee3ef4b15b7874ae237d76710108674c /drivers/gpu/drm/amd/amdgpu/soc15.c | |
| parent | 65722736c3baf29e02e964a09e85c9ef71c48e8d (diff) | |
| parent | 247f34f7b80357943234f93f247a1ae6b6c3a740 (diff) | |
Merge tag 'v6.1-rc2' into fixes
Merge rc2 into our fixes branch, which was based on rc1 but wasn't
merged until rc3, so that for the remainder of the release our fixes
branch will be based on rc2 for the purposes of resolving conflicts with
other trees (if necessary).
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/soc15.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/soc15.c | 21 | 
1 files changed, 21 insertions, 0 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/soc15.c b/drivers/gpu/drm/amd/amdgpu/soc15.c index 183024d7c184..e3b2b6b4f1a6 100644 --- a/drivers/gpu/drm/amd/amdgpu/soc15.c +++ b/drivers/gpu/drm/amd/amdgpu/soc15.c @@ -1211,6 +1211,20 @@ static int soc15_common_sw_fini(void *handle)  	return 0;  } +static void soc15_sdma_doorbell_range_init(struct amdgpu_device *adev) +{ +	int i; + +	/* sdma doorbell range is programed by hypervisor */ +	if (!amdgpu_sriov_vf(adev)) { +		for (i = 0; i < adev->sdma.num_instances; i++) { +			adev->nbio.funcs->sdma_doorbell_range(adev, i, +				true, adev->doorbell_index.sdma_engine[i] << 1, +				adev->doorbell_index.sdma_doorbell_range); +		} +	} +} +  static int soc15_common_hw_init(void *handle)  {  	struct amdgpu_device *adev = (struct amdgpu_device *)handle; @@ -1230,6 +1244,13 @@ static int soc15_common_hw_init(void *handle)  	/* enable the doorbell aperture */  	soc15_enable_doorbell_aperture(adev, true); +	/* HW doorbell routing policy: doorbell writing not +	 * in SDMA/IH/MM/ACV range will be routed to CP. So +	 * we need to init SDMA doorbell range prior +	 * to CP ip block init and ring test.  IH already +	 * happens before CP. +	 */ +	soc15_sdma_doorbell_range_init(adev);  	return 0;  } | 
