diff options
| author | Horace Chen <horace.chen@amd.com> | 2017-10-09 16:17:16 +0800 | 
|---|---|---|
| committer | Alex Deucher <alexander.deucher@amd.com> | 2017-10-19 15:26:59 -0400 | 
| commit | 2dc8f81e4f822cfe8f6475da968ab2dd5881b8d8 (patch) | |
| tree | 6598c1b183930a262552b4609172d97c690fc543 /drivers/gpu/drm/amd/amdgpu/mxgpu_ai.c | |
| parent | 0ae94444c08a0adf2fab4aab26be0646ee445a19 (diff) | |
| download | blackbird-op-linux-2dc8f81e4f822cfe8f6475da968ab2dd5881b8d8.tar.gz blackbird-op-linux-2dc8f81e4f822cfe8f6475da968ab2dd5881b8d8.zip | |
drm/amdgpu: SR-IOV data exchange between PF&VF
SR-IOV need to exchange some data between PF&VF through shared VRAM
PF will copy some necessary firmware and information to the shared
VRAM. It also requires some information from VF. PF will send a
key through mailbox2 to help guest calculate checksum so that it can
verify whether the data is correct.
So check the data on the specified offset of the shared VRAM, if the
checksum is right, read values from it and write some VF information
next to the data from PF.
Signed-off-by: Horace Chen <horace.chen@amd.com>
Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/mxgpu_ai.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/mxgpu_ai.c | 6 | 
1 files changed, 6 insertions, 0 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/mxgpu_ai.c b/drivers/gpu/drm/amd/amdgpu/mxgpu_ai.c index 2812d88a8bdd..b4906d2f30d3 100644 --- a/drivers/gpu/drm/amd/amdgpu/mxgpu_ai.c +++ b/drivers/gpu/drm/amd/amdgpu/mxgpu_ai.c @@ -183,6 +183,12 @@ static int xgpu_ai_send_access_requests(struct amdgpu_device *adev,  			pr_err("Doesn't get READY_TO_ACCESS_GPU from pf, give up\n");  			return r;  		} +		/* Retrieve checksum from mailbox2 */ +		if (req == IDH_REQ_GPU_INIT_ACCESS) { +			adev->virt.fw_reserve.checksum_key = +				RREG32_NO_KIQ(SOC15_REG_OFFSET(NBIO, 0, +					mmBIF_BX_PF0_MAILBOX_MSGBUF_RCV_DW2)); +		}  	}  	return 0; | 

