aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorJulia Lawall <julia@diku.dk>2010-08-10 21:01:27 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2010-08-11 11:59:02 -0400
commit3094141c6532a4f748425c21c091001f218da8ae (patch)
tree20428f86de4fb7d6f8a57a4e9c35a6f2f2c02d37 /drivers
parenta737b88df8d0b4476ae53daaa6db137df0541203 (diff)
drivers/scsi: use memdup_user
Use memdup_user when user data is immediately copied into the allocated region. The semantic patch that makes this change is as follows: (http://coccinelle.lip6.fr/) // <smpl> @@ expression from,to,size,flag; position p; identifier l1,l2; @@ - to = \(kmalloc@p\|kzalloc@p\)(size,flag); + to = memdup_user(from,size); if ( - to==NULL + IS_ERR(to) || ...) { <+... when != goto l1; - -ENOMEM + PTR_ERR(to) ...+> } - if (copy_from_user(to, from, size) != 0) { - <+... when != goto l2; - -EFAULT - ...+> - } // </smpl> Signed-off-by: Julia Lawall <julia@diku.dk> Cc: Doug Gilbert <dgilbert@interlog.com> Cc: Boaz Harrosh <bharrosh@panasas.com> Cc: James Bottomley <James.Bottomley@HansenPartnership.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/scsi/sg.c11
1 files changed, 3 insertions, 8 deletions
diff --git a/drivers/scsi/sg.c b/drivers/scsi/sg.c
index 2968c6b83dd..78d616315d8 100644
--- a/drivers/scsi/sg.c
+++ b/drivers/scsi/sg.c
@@ -1686,14 +1686,9 @@ static int sg_start_req(Sg_request *srp, unsigned char *cmd)
1686 int len, size = sizeof(struct sg_iovec) * iov_count; 1686 int len, size = sizeof(struct sg_iovec) * iov_count;
1687 struct iovec *iov; 1687 struct iovec *iov;
1688 1688
1689 iov = kmalloc(size, GFP_ATOMIC); 1689 iov = memdup_user(hp->dxferp, size);
1690 if (!iov) 1690 if (IS_ERR(iov))
1691 return -ENOMEM; 1691 return PTR_ERR(iov);
1692
1693 if (copy_from_user(iov, hp->dxferp, size)) {
1694 kfree(iov);
1695 return -EFAULT;
1696 }
1697 1692
1698 len = iov_length(iov, iov_count); 1693 len = iov_length(iov, iov_count);
1699 if (hp->dxfer_len < len) { 1694 if (hp->dxfer_len < len) {