serial: mfd: snprintf() returns largish values
snprintf() returns the number of bytes which would have been written so it can be larger than the size of the buffer. In this case it's fine, but people copy and paste this code so I've fixed it. Signed-off-by: Dan Carpenter <error27@gmail.com> Acked-by: Feng Tang <feng.tang@intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
de838a93cb
commit
a958981140
@ -172,6 +172,9 @@ static ssize_t port_show_regs(struct file *file, char __user *user_buf,
|
||||
len += snprintf(buf + len, HSU_REGS_BUFSIZE - len,
|
||||
"DIV: \t\t0x%08x\n", serial_in(up, UART_DIV));
|
||||
|
||||
if (len > HSU_REGS_BUFSIZE)
|
||||
len = HSU_REGS_BUFSIZE;
|
||||
|
||||
ret = simple_read_from_buffer(user_buf, count, ppos, buf, len);
|
||||
kfree(buf);
|
||||
return ret;
|
||||
@ -219,6 +222,9 @@ static ssize_t dma_show_regs(struct file *file, char __user *user_buf,
|
||||
len += snprintf(buf + len, HSU_REGS_BUFSIZE - len,
|
||||
"D0TSR: \t\t0x%08x\n", chan_readl(chan, HSU_CH_D3TSR));
|
||||
|
||||
if (len > HSU_REGS_BUFSIZE)
|
||||
len = HSU_REGS_BUFSIZE;
|
||||
|
||||
ret = simple_read_from_buffer(user_buf, count, ppos, buf, len);
|
||||
kfree(buf);
|
||||
return ret;
|
||||
|
Loading…
Reference in New Issue
Block a user