rt2x00: use simple_read_from_buffer()
authorDan Carpenter <dan.carpenter@oracle.com>
Wed, 22 Aug 2018 10:41:26 +0000 (13:41 +0300)
committerKalle Valo <kvalo@codeaurora.org>
Fri, 31 Aug 2018 15:47:29 +0000 (18:47 +0300)
The problem with this copy_to_user() calls is that they don't ensure
that "size" is less than the "length" which the user provided.

Obviously, this is debugfs and "size" is normally going to be very small
so it probably doesn't matter, but this is the correct thing to do.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Acked-by: Stanislaw Gruszka <sgruszka@redhat.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/ralink/rt2x00/rt2x00debug.c

index acc399b5574e021de4e9767be7c18937b14caf69..61ba573e8bf13910f3892aa72153725e4311d663 100644 (file)
@@ -464,11 +464,7 @@ static ssize_t rt2x00debug_read_##__name(struct file *file,        \
                                                                \
        size = sprintf(line, __format, value);                  \
                                                                \
-       if (copy_to_user(buf, line, size))                      \
-               return -EFAULT;                                 \
-                                                               \
-       *offset += size;                                        \
-       return size;                                            \
+       return simple_read_from_buffer(buf, length, offset, line, size); \
 }
 
 #define RT2X00DEBUGFS_OPS_WRITE(__name, __type)                        \
@@ -545,11 +541,7 @@ static ssize_t rt2x00debug_read_dev_flags(struct file *file,
 
        size = sprintf(line, "0x%.8x\n", (unsigned int)intf->rt2x00dev->flags);
 
-       if (copy_to_user(buf, line, size))
-               return -EFAULT;
-
-       *offset += size;
-       return size;
+       return simple_read_from_buffer(buf, length, offset, line, size);
 }
 
 static const struct file_operations rt2x00debug_fop_dev_flags = {
@@ -574,11 +566,7 @@ static ssize_t rt2x00debug_read_cap_flags(struct file *file,
 
        size = sprintf(line, "0x%.8x\n", (unsigned int)intf->rt2x00dev->cap_flags);
 
-       if (copy_to_user(buf, line, size))
-               return -EFAULT;
-
-       *offset += size;
-       return size;
+       return simple_read_from_buffer(buf, length, offset, line, size);
 }
 
 static const struct file_operations rt2x00debug_fop_cap_flags = {