mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-08 23:04:35 +08:00
drm/nv50-/disp: allow dumping core channel state at first supervisor intr
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
This commit is contained in:
parent
d67d92c066
commit
b62b9ec2eb
@ -1520,12 +1520,14 @@ nv50_disp_intr_supervisor(struct work_struct *work)
|
||||
{
|
||||
struct nv50_disp_priv *priv =
|
||||
container_of(work, struct nv50_disp_priv, supervisor);
|
||||
struct nv50_disp_impl *impl = (void *)nv_object(priv)->oclass;
|
||||
u32 super = nv_rd32(priv, 0x610030);
|
||||
int head;
|
||||
|
||||
nv_debug(priv, "supervisor 0x%08x 0x%08x\n", priv->super, super);
|
||||
|
||||
if (priv->super & 0x00000010) {
|
||||
nv50_disp_mthd_chan(priv, NV_DBG_DEBUG, 0, impl->mthd.core);
|
||||
for (head = 0; head < priv->head.nr; head++) {
|
||||
if (!(super & (0x00000020 << head)))
|
||||
continue;
|
||||
|
@ -1174,6 +1174,7 @@ nvd0_disp_intr_supervisor(struct work_struct *work)
|
||||
{
|
||||
struct nv50_disp_priv *priv =
|
||||
container_of(work, struct nv50_disp_priv, supervisor);
|
||||
struct nv50_disp_impl *impl = (void *)nv_object(priv)->oclass;
|
||||
u32 mask[4];
|
||||
int head;
|
||||
|
||||
@ -1184,6 +1185,7 @@ nvd0_disp_intr_supervisor(struct work_struct *work)
|
||||
}
|
||||
|
||||
if (priv->super & 0x00000001) {
|
||||
nv50_disp_mthd_chan(priv, NV_DBG_DEBUG, 0, impl->mthd.core);
|
||||
for (head = 0; head < priv->head.nr; head++) {
|
||||
if (!(mask[head] & 0x00001000))
|
||||
continue;
|
||||
|
Loading…
Reference in New Issue
Block a user