Commit 4c4a5cf6 authored by Akinobu Mita's avatar Akinobu Mita Committed by Benjamin Herrenschmidt

powerpc/rtas_flash: Use simple_read_from_buffer

Simplify read file operation for /proc/powerpc/rtas/* interface
by using simple_read_from_buffer.
Signed-off-by: default avatarAkinobu Mita <akinobu.mita@gmail.com>
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent 63c3b9d7
...@@ -256,31 +256,16 @@ static ssize_t rtas_flash_read(struct file *file, char __user *buf, ...@@ -256,31 +256,16 @@ static ssize_t rtas_flash_read(struct file *file, char __user *buf,
struct proc_dir_entry *dp = PDE(file->f_path.dentry->d_inode); struct proc_dir_entry *dp = PDE(file->f_path.dentry->d_inode);
struct rtas_update_flash_t *uf; struct rtas_update_flash_t *uf;
char msg[RTAS_MSG_MAXLEN]; char msg[RTAS_MSG_MAXLEN];
int msglen;
uf = (struct rtas_update_flash_t *) dp->data; uf = dp->data;
if (!strcmp(dp->name, FIRMWARE_FLASH_NAME)) { if (!strcmp(dp->name, FIRMWARE_FLASH_NAME)) {
get_flash_status_msg(uf->status, msg); get_flash_status_msg(uf->status, msg);
} else { /* FIRMWARE_UPDATE_NAME */ } else { /* FIRMWARE_UPDATE_NAME */
sprintf(msg, "%d\n", uf->status); sprintf(msg, "%d\n", uf->status);
} }
msglen = strlen(msg);
if (msglen > count)
msglen = count;
if (ppos && *ppos != 0)
return 0; /* be cheap */
if (!access_ok(VERIFY_WRITE, buf, msglen))
return -EINVAL;
if (copy_to_user(buf, msg, msglen)) return simple_read_from_buffer(buf, count, ppos, msg, strlen(msg));
return -EFAULT;
if (ppos)
*ppos = msglen;
return msglen;
} }
/* constructor for flash_block_cache */ /* constructor for flash_block_cache */
...@@ -394,26 +379,13 @@ static ssize_t manage_flash_read(struct file *file, char __user *buf, ...@@ -394,26 +379,13 @@ static ssize_t manage_flash_read(struct file *file, char __user *buf,
char msg[RTAS_MSG_MAXLEN]; char msg[RTAS_MSG_MAXLEN];
int msglen; int msglen;
args_buf = (struct rtas_manage_flash_t *) dp->data; args_buf = dp->data;
if (args_buf == NULL) if (args_buf == NULL)
return 0; return 0;
msglen = sprintf(msg, "%d\n", args_buf->status); msglen = sprintf(msg, "%d\n", args_buf->status);
if (msglen > count)
msglen = count;
if (ppos && *ppos != 0) return simple_read_from_buffer(buf, count, ppos, msg, msglen);
return 0; /* be cheap */
if (!access_ok(VERIFY_WRITE, buf, msglen))
return -EINVAL;
if (copy_to_user(buf, msg, msglen))
return -EFAULT;
if (ppos)
*ppos = msglen;
return msglen;
} }
static ssize_t manage_flash_write(struct file *file, const char __user *buf, static ssize_t manage_flash_write(struct file *file, const char __user *buf,
...@@ -495,24 +467,11 @@ static ssize_t validate_flash_read(struct file *file, char __user *buf, ...@@ -495,24 +467,11 @@ static ssize_t validate_flash_read(struct file *file, char __user *buf,
char msg[RTAS_MSG_MAXLEN]; char msg[RTAS_MSG_MAXLEN];
int msglen; int msglen;
args_buf = (struct rtas_validate_flash_t *) dp->data; args_buf = dp->data;
if (ppos && *ppos != 0)
return 0; /* be cheap */
msglen = get_validate_flash_msg(args_buf, msg); msglen = get_validate_flash_msg(args_buf, msg);
if (msglen > count)
msglen = count;
if (!access_ok(VERIFY_WRITE, buf, msglen))
return -EINVAL;
if (copy_to_user(buf, msg, msglen))
return -EFAULT;
if (ppos) return simple_read_from_buffer(buf, count, ppos, msg, msglen);
*ppos = msglen;
return msglen;
} }
static ssize_t validate_flash_write(struct file *file, const char __user *buf, static ssize_t validate_flash_write(struct file *file, const char __user *buf,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment