media: saa7134: fix use after free bug in saa7134_finidev due to race condition
ANBZ: #7019 commit30cf57da17
upstream. In saa7134_initdev, it will call saa7134_hwinit1. There are three function invoking here: saa7134_video_init1, saa7134_ts_init1 and saa7134_vbi_init1. All of them will init a timer with same function. Take saa7134_video_init1 as an example. It'll bound &dev->video_q.timeout with saa7134_buffer_timeout. In buffer_activate, the timer funtcion is started. If we remove the module or device which will call saa7134_finidev to make cleanup, there may be a unfinished work. The possible sequence is as follows, which will cause a typical UAF bug. Fix it by canceling the timer works accordingly before cleanup in saa7134_finidev. CPU0 CPU1 |saa7134_buffer_timeout saa7134_finidev | kfree(dev); | | | saa7134_buffer_next | //use dev Fixes:1e7126b4a8
("media: saa7134: Convert timers to use timer_setup()") Signed-off-by: Zheng Wang <zyytlz.wz@163.com> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Sasha Levin <sashal@kernel.org> Fixes: CVE-2023-35823 Signed-off-by: Xiao Long <xiaolong@openanolis.org> Signed-off-by: Qinyun Tan <qinyuntan@linux.alibaba.com> Reviewed-by: Xunlei Pang <xlpang@linux.alibaba.com> Link: https://gitee.com/anolis/cloud-kernel/pulls/2367
This commit is contained in:
parent
887bab7f65
commit
3412cade86
|
@ -309,6 +309,7 @@ int saa7134_ts_start(struct saa7134_dev *dev)
|
|||
|
||||
int saa7134_ts_fini(struct saa7134_dev *dev)
|
||||
{
|
||||
del_timer_sync(&dev->ts_q.timeout);
|
||||
saa7134_pgtable_free(dev->pci, &dev->ts_q.pt);
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -194,6 +194,7 @@ int saa7134_vbi_init1(struct saa7134_dev *dev)
|
|||
int saa7134_vbi_fini(struct saa7134_dev *dev)
|
||||
{
|
||||
/* nothing */
|
||||
del_timer_sync(&dev->vbi_q.timeout);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -2213,6 +2213,7 @@ int saa7134_video_init1(struct saa7134_dev *dev)
|
|||
|
||||
void saa7134_video_fini(struct saa7134_dev *dev)
|
||||
{
|
||||
del_timer_sync(&dev->video_q.timeout);
|
||||
/* free stuff */
|
||||
vb2_queue_release(&dev->video_vbq);
|
||||
saa7134_pgtable_free(dev->pci, &dev->video_q.pt);
|
||||
|
|
Loading…
Reference in New Issue