mirror of https://gitee.com/openkylin/linux.git
rt2x00: use simple_read_from_buffer()
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>
This commit is contained in:
parent
33a164fa8a
commit
f483039cf5
|
@ -464,11 +464,7 @@ static ssize_t rt2x00debug_read_##__name(struct file *file, \
|
||||||
\
|
\
|
||||||
size = sprintf(line, __format, value); \
|
size = sprintf(line, __format, value); \
|
||||||
\
|
\
|
||||||
if (copy_to_user(buf, line, size)) \
|
return simple_read_from_buffer(buf, length, offset, line, size); \
|
||||||
return -EFAULT; \
|
|
||||||
\
|
|
||||||
*offset += size; \
|
|
||||||
return size; \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define RT2X00DEBUGFS_OPS_WRITE(__name, __type) \
|
#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);
|
size = sprintf(line, "0x%.8x\n", (unsigned int)intf->rt2x00dev->flags);
|
||||||
|
|
||||||
if (copy_to_user(buf, line, size))
|
return simple_read_from_buffer(buf, length, offset, line, size);
|
||||||
return -EFAULT;
|
|
||||||
|
|
||||||
*offset += size;
|
|
||||||
return size;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct file_operations rt2x00debug_fop_dev_flags = {
|
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);
|
size = sprintf(line, "0x%.8x\n", (unsigned int)intf->rt2x00dev->cap_flags);
|
||||||
|
|
||||||
if (copy_to_user(buf, line, size))
|
return simple_read_from_buffer(buf, length, offset, line, size);
|
||||||
return -EFAULT;
|
|
||||||
|
|
||||||
*offset += size;
|
|
||||||
return size;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct file_operations rt2x00debug_fop_cap_flags = {
|
static const struct file_operations rt2x00debug_fop_cap_flags = {
|
||||||
|
|
Loading…
Reference in New Issue