diff options
| author | 2017-11-28 16:19:52 +0000 | |
|---|---|---|
| committer | 2017-11-28 16:19:52 +0000 | |
| commit | 69830d3909849dee33b9a2de88ece3d59c75a1b8 (patch) | |
| tree | 67e22ac989e782ddc104f186dee54d1675e76923 /drivers/gpu/drm/amd/amdgpu/cz_ih.c | |
| parent | ASoC: rk3399_gru_sound: Map BTN_0 to KEY_PLAYPAUSE (diff) | |
| parent | ASoC: add snd_soc_disconnect_sync() (diff) | |
| download | linux-dev-69830d3909849dee33b9a2de88ece3d59c75a1b8.tar.xz linux-dev-69830d3909849dee33b9a2de88ece3d59c75a1b8.zip | |
Merge branch 'topic/disconnect' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into asoc-rcar
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/cz_ih.c')
| -rw-r--r-- | drivers/gpu/drm/amd/amdgpu/cz_ih.c | 29 | 
1 files changed, 29 insertions, 0 deletions
| diff --git a/drivers/gpu/drm/amd/amdgpu/cz_ih.c b/drivers/gpu/drm/amd/amdgpu/cz_ih.c index 0c1209cdd1cb..fa61d649bb44 100644 --- a/drivers/gpu/drm/amd/amdgpu/cz_ih.c +++ b/drivers/gpu/drm/amd/amdgpu/cz_ih.c @@ -208,6 +208,34 @@ static u32 cz_ih_get_wptr(struct amdgpu_device *adev)  }  /** + * cz_ih_prescreen_iv - prescreen an interrupt vector + * + * @adev: amdgpu_device pointer + * + * Returns true if the interrupt vector should be further processed. + */ +static bool cz_ih_prescreen_iv(struct amdgpu_device *adev) +{ +	u32 ring_index = adev->irq.ih.rptr >> 2; +	u16 pasid; + +	switch (le32_to_cpu(adev->irq.ih.ring[ring_index]) & 0xff) { +	case 146: +	case 147: +		pasid = le32_to_cpu(adev->irq.ih.ring[ring_index + 2]) >> 16; +		if (!pasid || amdgpu_vm_pasid_fault_credit(adev, pasid)) +			return true; +		break; +	default: +		/* Not a VM fault */ +		return true; +	} + +	adev->irq.ih.rptr += 16; +	return false; +} + +/**   * cz_ih_decode_iv - decode an interrupt vector   *   * @adev: amdgpu_device pointer @@ -414,6 +442,7 @@ static const struct amd_ip_funcs cz_ih_ip_funcs = {  static const struct amdgpu_ih_funcs cz_ih_funcs = {  	.get_wptr = cz_ih_get_wptr, +	.prescreen_iv = cz_ih_prescreen_iv,  	.decode_iv = cz_ih_decode_iv,  	.set_rptr = cz_ih_set_rptr  }; | 
