Skip to content

Commit 020c76d

Browse files
hongkzha-amdalexdeucher
authored andcommitted
drm/amdgpu: add RAS POISON interrupt funcs for vcn_v4_0
Add ras_poison_irq and functions. And fix the amdgpu_irq_put call trace in vcn_v4_0_hw_fini. [ 44.563572] RIP: 0010:amdgpu_irq_put+0xa4/0xc0 [amdgpu] [ 44.563629] RSP: 0018:ffffb36740edfc90 EFLAGS: 00010246 [ 44.563630] RAX: 0000000000000000 RBX: 0000000000000001 RCX: 0000000000000000 [ 44.563630] RDX: 0000000000000000 RSI: 0000000000000000 RDI: 0000000000000000 [ 44.563631] RBP: ffffb36740edfcb0 R08: 0000000000000000 R09: 0000000000000000 [ 44.563631] R10: 0000000000000000 R11: 0000000000000000 R12: ffff954c568e2ea8 [ 44.563631] R13: 0000000000000000 R14: ffff954c568c0000 R15: ffff954c568e2ea8 [ 44.563632] FS: 0000000000000000(0000) GS:ffff954f584c0000(0000) knlGS:0000000000000000 [ 44.563632] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 [ 44.563633] CR2: 00007f028741ba70 CR3: 000000026ca10000 CR4: 0000000000750ee0 [ 44.563633] PKRU: 55555554 [ 44.563633] Call Trace: [ 44.563634] <TASK> [ 44.563634] vcn_v4_0_hw_fini+0x62/0x160 [amdgpu] [ 44.563700] vcn_v4_0_suspend+0x13/0x30 [amdgpu] [ 44.563755] amdgpu_device_ip_suspend_phase2+0x240/0x470 [amdgpu] [ 44.563806] amdgpu_device_ip_suspend+0x41/0x80 [amdgpu] [ 44.563858] amdgpu_device_pre_asic_reset+0xd9/0x4a0 [amdgpu] [ 44.563909] amdgpu_device_gpu_recover.cold+0x548/0xcf1 [amdgpu] [ 44.564006] amdgpu_debugfs_reset_work+0x4c/0x80 [amdgpu] [ 44.564061] process_one_work+0x21f/0x400 [ 44.564062] worker_thread+0x200/0x3f0 [ 44.564063] ? process_one_work+0x400/0x400 [ 44.564064] kthread+0xee/0x120 [ 44.564065] ? kthread_complete_and_exit+0x20/0x20 [ 44.564066] ret_from_fork+0x22/0x30 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 6889f28 commit 020c76d

File tree

1 file changed

+30
-6
lines changed

1 file changed

+30
-6
lines changed

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

Lines changed: 30 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -139,7 +139,7 @@ static int vcn_v4_0_sw_init(void *handle)
139139

140140
/* VCN POISON TRAP */
141141
r = amdgpu_irq_add_id(adev, amdgpu_ih_clientid_vcns[i],
142-
VCN_4_0__SRCID_UVD_POISON, &adev->vcn.inst[i].irq);
142+
VCN_4_0__SRCID_UVD_POISON, &adev->vcn.inst[i].ras_poison_irq);
143143
if (r)
144144
return r;
145145

@@ -305,8 +305,8 @@ static int vcn_v4_0_hw_fini(void *handle)
305305
vcn_v4_0_set_powergating_state(adev, AMD_PG_STATE_GATE);
306306
}
307307
}
308-
309-
amdgpu_irq_put(adev, &adev->vcn.inst[i].irq, 0);
308+
if (amdgpu_ras_is_supported(adev, AMDGPU_RAS_BLOCK__VCN))
309+
amdgpu_irq_put(adev, &adev->vcn.inst[i].ras_poison_irq, 0);
310310
}
311311

312312
return 0;
@@ -1975,6 +1975,24 @@ static int vcn_v4_0_set_interrupt_state(struct amdgpu_device *adev, struct amdgp
19751975
return 0;
19761976
}
19771977

1978+
/**
1979+
* vcn_v4_0_set_ras_interrupt_state - set VCN block RAS interrupt state
1980+
*
1981+
* @adev: amdgpu_device pointer
1982+
* @source: interrupt sources
1983+
* @type: interrupt types
1984+
* @state: interrupt states
1985+
*
1986+
* Set VCN block RAS interrupt state
1987+
*/
1988+
static int vcn_v4_0_set_ras_interrupt_state(struct amdgpu_device *adev,
1989+
struct amdgpu_irq_src *source,
1990+
unsigned int type,
1991+
enum amdgpu_interrupt_state state)
1992+
{
1993+
return 0;
1994+
}
1995+
19781996
/**
19791997
* vcn_v4_0_process_interrupt - process VCN block interrupt
19801998
*
@@ -2007,9 +2025,6 @@ static int vcn_v4_0_process_interrupt(struct amdgpu_device *adev, struct amdgpu_
20072025
case VCN_4_0__SRCID__UVD_ENC_GENERAL_PURPOSE:
20082026
amdgpu_fence_process(&adev->vcn.inst[ip_instance].ring_enc[0]);
20092027
break;
2010-
case VCN_4_0__SRCID_UVD_POISON:
2011-
amdgpu_vcn_process_poison_irq(adev, source, entry);
2012-
break;
20132028
default:
20142029
DRM_ERROR("Unhandled interrupt: %d %d\n",
20152030
entry->src_id, entry->src_data[0]);
@@ -2024,6 +2039,11 @@ static const struct amdgpu_irq_src_funcs vcn_v4_0_irq_funcs = {
20242039
.process = vcn_v4_0_process_interrupt,
20252040
};
20262041

2042+
static const struct amdgpu_irq_src_funcs vcn_v4_0_ras_irq_funcs = {
2043+
.set = vcn_v4_0_set_ras_interrupt_state,
2044+
.process = amdgpu_vcn_process_poison_irq,
2045+
};
2046+
20272047
/**
20282048
* vcn_v4_0_set_irq_funcs - set VCN block interrupt irq functions
20292049
*
@@ -2041,6 +2061,9 @@ static void vcn_v4_0_set_irq_funcs(struct amdgpu_device *adev)
20412061

20422062
adev->vcn.inst[i].irq.num_types = adev->vcn.num_enc_rings + 1;
20432063
adev->vcn.inst[i].irq.funcs = &vcn_v4_0_irq_funcs;
2064+
2065+
adev->vcn.inst[i].ras_poison_irq.num_types = adev->vcn.num_enc_rings + 1;
2066+
adev->vcn.inst[i].ras_poison_irq.funcs = &vcn_v4_0_ras_irq_funcs;
20442067
}
20452068
}
20462069

@@ -2114,6 +2137,7 @@ const struct amdgpu_ras_block_hw_ops vcn_v4_0_ras_hw_ops = {
21142137
static struct amdgpu_vcn_ras vcn_v4_0_ras = {
21152138
.ras_block = {
21162139
.hw_ops = &vcn_v4_0_ras_hw_ops,
2140+
.ras_late_init = amdgpu_vcn_ras_late_init,
21172141
},
21182142
};
21192143

0 commit comments

Comments
 (0)