mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-11 04:18:39 +08:00
dma-buf/sw-sync: don't enable IRQ from sync_print_obj()
Since commita6aa8fca4d
("dma-buf/sw-sync: Reduce irqsave/irqrestore from known context") by error replaced spin_unlock_irqrestore() with spin_unlock_irq() for both sync_debugfs_show() and sync_print_obj() despite sync_print_obj() is called from sync_debugfs_show(), lockdep complains inconsistent lock state warning. Use plain spin_{lock,unlock}() for sync_print_obj(), for sync_debugfs_show() is already using spin_{lock,unlock}_irq(). Reported-by: syzbot <syzbot+a225ee3df7e7f9372dbe@syzkaller.appspotmail.com> Closes: https://syzkaller.appspot.com/bug?extid=a225ee3df7e7f9372dbe Fixes:a6aa8fca4d
("dma-buf/sw-sync: Reduce irqsave/irqrestore from known context") Signed-off-by: Tetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp> Reviewed-by: Christian König <christian.koenig@amd.com> Link: https://patchwork.freedesktop.org/patch/msgid/c2e46020-aaa6-4e06-bf73-f05823f913f0@I-love.SAKURA.ne.jp Signed-off-by: Christian König <christian.koenig@amd.com>
This commit is contained in:
parent
39bc27bd68
commit
b794918961
@ -110,12 +110,12 @@ static void sync_print_obj(struct seq_file *s, struct sync_timeline *obj)
|
|||||||
|
|
||||||
seq_printf(s, "%s: %d\n", obj->name, obj->value);
|
seq_printf(s, "%s: %d\n", obj->name, obj->value);
|
||||||
|
|
||||||
spin_lock_irq(&obj->lock);
|
spin_lock(&obj->lock); /* Caller already disabled IRQ. */
|
||||||
list_for_each(pos, &obj->pt_list) {
|
list_for_each(pos, &obj->pt_list) {
|
||||||
struct sync_pt *pt = container_of(pos, struct sync_pt, link);
|
struct sync_pt *pt = container_of(pos, struct sync_pt, link);
|
||||||
sync_print_fence(s, &pt->base, false);
|
sync_print_fence(s, &pt->base, false);
|
||||||
}
|
}
|
||||||
spin_unlock_irq(&obj->lock);
|
spin_unlock(&obj->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void sync_print_sync_file(struct seq_file *s,
|
static void sync_print_sync_file(struct seq_file *s,
|
||||||
|
Loading…
Reference in New Issue
Block a user