* [PATCH] sg: protect against races between mmap() and SG_SET_RESERVED_SIZE
@ 2017-08-16 5:41 Todd Poynor
2017-08-23 1:48 ` Douglas Gilbert
2017-08-23 2:21 ` Martin K. Petersen
0 siblings, 2 replies; 3+ messages in thread
From: Todd Poynor @ 2017-08-16 5:41 UTC (permalink / raw)
To: Doug Gilbert, James E.J. Bottomley, Martin K. Petersen
Cc: linux-scsi, linux-kernel, Hannes Reinecke, Todd Poynor
Take f_mutex around mmap() processing to protect against races with
the SG_SET_RESERVED_SIZE ioctl. Ensure the reserve buffer length
remains consistent during the mapping operation, and set the
"mmap called" flag to prevent further changes to the reserved buffer
size as an atomic operation with the mapping.
Signed-off-by: Todd Poynor <toddpoynor@google.com>
---
drivers/scsi/sg.c | 12 +++++++++---
1 file changed, 9 insertions(+), 3 deletions(-)
diff --git a/drivers/scsi/sg.c b/drivers/scsi/sg.c
index 3a44b4bc872b..a20718e9f1f4 100644
--- a/drivers/scsi/sg.c
+++ b/drivers/scsi/sg.c
@@ -1233,6 +1233,7 @@ sg_mmap(struct file *filp, struct vm_area_struct *vma)
unsigned long req_sz, len, sa;
Sg_scatter_hold *rsv_schp;
int k, length;
+ int ret = 0;
if ((!filp) || (!vma) || (!(sfp = (Sg_fd *) filp->private_data)))
return -ENXIO;
@@ -1243,8 +1244,11 @@ sg_mmap(struct file *filp, struct vm_area_struct *vma)
if (vma->vm_pgoff)
return -EINVAL; /* want no offset */
rsv_schp = &sfp->reserve;
- if (req_sz > rsv_schp->bufflen)
- return -ENOMEM; /* cannot map more than reserved buffer */
+ mutex_lock(&sfp->f_mutex);
+ if (req_sz > rsv_schp->bufflen) {
+ ret = -ENOMEM; /* cannot map more than reserved buffer */
+ goto out;
+ }
sa = vma->vm_start;
length = 1 << (PAGE_SHIFT + rsv_schp->page_order);
@@ -1258,7 +1262,9 @@ sg_mmap(struct file *filp, struct vm_area_struct *vma)
vma->vm_flags |= VM_IO | VM_DONTEXPAND | VM_DONTDUMP;
vma->vm_private_data = sfp;
vma->vm_ops = &sg_mmap_vm_ops;
- return 0;
+out:
+ mutex_unlock(&sfp->f_mutex);
+ return ret;
}
static void
--
2.14.1.480.gb18f417b89-goog
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] sg: protect against races between mmap() and SG_SET_RESERVED_SIZE
2017-08-16 5:41 [PATCH] sg: protect against races between mmap() and SG_SET_RESERVED_SIZE Todd Poynor
@ 2017-08-23 1:48 ` Douglas Gilbert
2017-08-23 2:21 ` Martin K. Petersen
1 sibling, 0 replies; 3+ messages in thread
From: Douglas Gilbert @ 2017-08-23 1:48 UTC (permalink / raw)
To: Todd Poynor, James E.J. Bottomley, Martin K. Petersen
Cc: linux-scsi, linux-kernel, Hannes Reinecke
On 2017-08-16 01:41 AM, Todd Poynor wrote:
> Take f_mutex around mmap() processing to protect against races with
> the SG_SET_RESERVED_SIZE ioctl. Ensure the reserve buffer length
> remains consistent during the mapping operation, and set the
> "mmap called" flag to prevent further changes to the reserved buffer
> size as an atomic operation with the mapping.
>
> Signed-off-by: Todd Poynor <toddpoynor@google.com>
Acked-by: Douglas Gilbert <dgilbert@interlog.com>
Thanks.
> ---
> drivers/scsi/sg.c | 12 +++++++++---
> 1 file changed, 9 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/scsi/sg.c b/drivers/scsi/sg.c
> index 3a44b4bc872b..a20718e9f1f4 100644
> --- a/drivers/scsi/sg.c
> +++ b/drivers/scsi/sg.c
> @@ -1233,6 +1233,7 @@ sg_mmap(struct file *filp, struct vm_area_struct *vma)
> unsigned long req_sz, len, sa;
> Sg_scatter_hold *rsv_schp;
> int k, length;
> + int ret = 0;
>
> if ((!filp) || (!vma) || (!(sfp = (Sg_fd *) filp->private_data)))
> return -ENXIO;
> @@ -1243,8 +1244,11 @@ sg_mmap(struct file *filp, struct vm_area_struct *vma)
> if (vma->vm_pgoff)
> return -EINVAL; /* want no offset */
> rsv_schp = &sfp->reserve;
> - if (req_sz > rsv_schp->bufflen)
> - return -ENOMEM; /* cannot map more than reserved buffer */
> + mutex_lock(&sfp->f_mutex);
> + if (req_sz > rsv_schp->bufflen) {
> + ret = -ENOMEM; /* cannot map more than reserved buffer */
> + goto out;
> + }
>
> sa = vma->vm_start;
> length = 1 << (PAGE_SHIFT + rsv_schp->page_order);
> @@ -1258,7 +1262,9 @@ sg_mmap(struct file *filp, struct vm_area_struct *vma)
> vma->vm_flags |= VM_IO | VM_DONTEXPAND | VM_DONTDUMP;
> vma->vm_private_data = sfp;
> vma->vm_ops = &sg_mmap_vm_ops;
> - return 0;
> +out:
> + mutex_unlock(&sfp->f_mutex);
> + return ret;
> }
>
> static void
>
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] sg: protect against races between mmap() and SG_SET_RESERVED_SIZE
2017-08-16 5:41 [PATCH] sg: protect against races between mmap() and SG_SET_RESERVED_SIZE Todd Poynor
2017-08-23 1:48 ` Douglas Gilbert
@ 2017-08-23 2:21 ` Martin K. Petersen
1 sibling, 0 replies; 3+ messages in thread
From: Martin K. Petersen @ 2017-08-23 2:21 UTC (permalink / raw)
To: Todd Poynor
Cc: Doug Gilbert, James E.J. Bottomley, Martin K. Petersen,
linux-scsi, linux-kernel, Hannes Reinecke
Todd,
> Take f_mutex around mmap() processing to protect against races with
> the SG_SET_RESERVED_SIZE ioctl. Ensure the reserve buffer length
> remains consistent during the mapping operation, and set the
> "mmap called" flag to prevent further changes to the reserved buffer
> size as an atomic operation with the mapping.
Applied to 4.14/scsi-queue (with a slight whitespace fix). Thanks!
--
Martin K. Petersen Oracle Linux Engineering
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2017-08-23 2:21 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-08-16 5:41 [PATCH] sg: protect against races between mmap() and SG_SET_RESERVED_SIZE Todd Poynor
2017-08-23 1:48 ` Douglas Gilbert
2017-08-23 2:21 ` Martin K. Petersen
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox