From: Al Viro Date: Thu, 24 Dec 2015 05:12:09 +0000 (-0500) Subject: cciss: switch to memdup_user_nul() X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=e4e85bb091d13afef7b1a10b4bd209b442be8863;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git cciss: switch to memdup_user_nul() all we do to buffer is strncmp()... Signed-off-by: Al Viro --- diff --git a/drivers/block/cciss.c b/drivers/block/cciss.c index 0422c47261c3..b38bd06d564c 100644 --- a/drivers/block/cciss.c +++ b/drivers/block/cciss.c @@ -514,14 +514,9 @@ cciss_proc_write(struct file *file, const char __user *buf, if (!buf || length > PAGE_SIZE - 1) return -EINVAL; - buffer = (char *)__get_free_page(GFP_KERNEL); - if (!buffer) - return -ENOMEM; - - err = -EFAULT; - if (copy_from_user(buffer, buf, length)) - goto out; - buffer[length] = '\0'; + buffer = memdup_user_nul(buf, length); + if (IS_ERR(buffer)) + return PTR_ERR(buffer); #ifdef CONFIG_CISS_SCSI_TAPE if (strncmp(ENGAGE_SCSI, buffer, sizeof ENGAGE_SCSI - 1) == 0) { @@ -537,8 +532,7 @@ cciss_proc_write(struct file *file, const char __user *buf, /* might be nice to have "disengage" too, but it's not safely possible. (only 1 module use count, lock issues.) */ -out: - free_page((unsigned long)buffer); + kfree(buffer); return err; }