Skip to content

Commit 6889f28

Browse files
hongkzha-amdalexdeucher
authored andcommitted
drm/amdgpu: add RAS POISON interrupt funcs for vcn_v2_6
Add ras_poison_irq and functions. Suggested-by: Hawking Zhang <[email protected]> Signed-off-by: Horatio Zhang <[email protected]> Reviewed-by: Tao Zhou <[email protected]> Signed-off-by: Alex Deucher <[email protected]>
1 parent ac1d8e2 commit 6889f28

File tree

1 file changed

+21
-4
lines changed

1 file changed

+21
-4
lines changed

drivers/gpu/drm/amd/amdgpu/vcn_v2_5.c

Lines changed: 21 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -143,7 +143,7 @@ static int vcn_v2_5_sw_init(void *handle)
143143

144144
/* VCN POISON TRAP */
145145
r = amdgpu_irq_add_id(adev, amdgpu_ih_clientid_vcns[j],
146-
VCN_2_6__SRCID_UVD_POISON, &adev->vcn.inst[j].irq);
146+
VCN_2_6__SRCID_UVD_POISON, &adev->vcn.inst[j].ras_poison_irq);
147147
if (r)
148148
return r;
149149
}
@@ -354,6 +354,9 @@ static int vcn_v2_5_hw_fini(void *handle)
354354
(adev->vcn.cur_state != AMD_PG_STATE_GATE &&
355355
RREG32_SOC15(VCN, i, mmUVD_STATUS)))
356356
vcn_v2_5_set_powergating_state(adev, AMD_PG_STATE_GATE);
357+
358+
if (amdgpu_ras_is_supported(adev, AMDGPU_RAS_BLOCK__VCN))
359+
amdgpu_irq_put(adev, &adev->vcn.inst[i].ras_poison_irq, 0);
357360
}
358361

359362
return 0;
@@ -1807,6 +1810,14 @@ static int vcn_v2_5_set_interrupt_state(struct amdgpu_device *adev,
18071810
return 0;
18081811
}
18091812

1813+
static int vcn_v2_6_set_ras_interrupt_state(struct amdgpu_device *adev,
1814+
struct amdgpu_irq_src *source,
1815+
unsigned int type,
1816+
enum amdgpu_interrupt_state state)
1817+
{
1818+
return 0;
1819+
}
1820+
18101821
static int vcn_v2_5_process_interrupt(struct amdgpu_device *adev,
18111822
struct amdgpu_irq_src *source,
18121823
struct amdgpu_iv_entry *entry)
@@ -1837,9 +1848,6 @@ static int vcn_v2_5_process_interrupt(struct amdgpu_device *adev,
18371848
case VCN_2_0__SRCID__UVD_ENC_LOW_LATENCY:
18381849
amdgpu_fence_process(&adev->vcn.inst[ip_instance].ring_enc[1]);
18391850
break;
1840-
case VCN_2_6__SRCID_UVD_POISON:
1841-
amdgpu_vcn_process_poison_irq(adev, source, entry);
1842-
break;
18431851
default:
18441852
DRM_ERROR("Unhandled interrupt: %d %d\n",
18451853
entry->src_id, entry->src_data[0]);
@@ -1854,6 +1862,11 @@ static const struct amdgpu_irq_src_funcs vcn_v2_5_irq_funcs = {
18541862
.process = vcn_v2_5_process_interrupt,
18551863
};
18561864

1865+
static const struct amdgpu_irq_src_funcs vcn_v2_6_ras_irq_funcs = {
1866+
.set = vcn_v2_6_set_ras_interrupt_state,
1867+
.process = amdgpu_vcn_process_poison_irq,
1868+
};
1869+
18571870
static void vcn_v2_5_set_irq_funcs(struct amdgpu_device *adev)
18581871
{
18591872
int i;
@@ -1863,6 +1876,9 @@ static void vcn_v2_5_set_irq_funcs(struct amdgpu_device *adev)
18631876
continue;
18641877
adev->vcn.inst[i].irq.num_types = adev->vcn.num_enc_rings + 1;
18651878
adev->vcn.inst[i].irq.funcs = &vcn_v2_5_irq_funcs;
1879+
1880+
adev->vcn.inst[i].ras_poison_irq.num_types = adev->vcn.num_enc_rings + 1;
1881+
adev->vcn.inst[i].ras_poison_irq.funcs = &vcn_v2_6_ras_irq_funcs;
18661882
}
18671883
}
18681884

@@ -1965,6 +1981,7 @@ const struct amdgpu_ras_block_hw_ops vcn_v2_6_ras_hw_ops = {
19651981
static struct amdgpu_vcn_ras vcn_v2_6_ras = {
19661982
.ras_block = {
19671983
.hw_ops = &vcn_v2_6_ras_hw_ops,
1984+
.ras_late_init = amdgpu_vcn_ras_late_init,
19681985
},
19691986
};
19701987

0 commit comments

Comments
 (0)