diff options
author | Lv Yunlong <lyl2019@mail.ustc.edu.cn> | 2021-03-11 07:46:36 +0100 |
---|---|---|
committer | Martin K. Petersen <martin.petersen@oracle.com> | 2021-03-16 03:50:49 +0100 |
commit | c8c165dea4c8f5ad67b1240861e4f6c5395fa4ac (patch) | |
tree | 3c856f5652495b01837d926807af944a5de4e988 | |
parent | scsi: myrs: Fix a double free in myrs_cleanup() (diff) | |
download | linux-c8c165dea4c8f5ad67b1240861e4f6c5395fa4ac.tar.xz linux-c8c165dea4c8f5ad67b1240861e4f6c5395fa4ac.zip |
scsi: st: Fix a use after free in st_open()
In st_open(), if STp->in_use is true, STp will be freed by
scsi_tape_put(). However, STp is still used by DEBC_printk() after. It is
better to DEBC_printk() before scsi_tape_put().
Link: https://lore.kernel.org/r/20210311064636.10522-1-lyl2019@mail.ustc.edu.cn
Acked-by: Kai Mäkisara <kai.makisara@kolumbus.fi>
Signed-off-by: Lv Yunlong <lyl2019@mail.ustc.edu.cn>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
-rw-r--r-- | drivers/scsi/st.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/scsi/st.c b/drivers/scsi/st.c index 841ad2fc369a..9ca536aae784 100644 --- a/drivers/scsi/st.c +++ b/drivers/scsi/st.c @@ -1269,8 +1269,8 @@ static int st_open(struct inode *inode, struct file *filp) spin_lock(&st_use_lock); if (STp->in_use) { spin_unlock(&st_use_lock); - scsi_tape_put(STp); DEBC_printk(STp, "Device already in use.\n"); + scsi_tape_put(STp); return (-EBUSY); } |