mirror of
https://github.com/torvalds/linux.git
synced 2024-12-28 13:51:44 +00:00
relay: simplify relay_file_read()
to hell with actors... Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
523ac9afc7
commit
a7c2242166
@ -1121,51 +1121,23 @@ static size_t relay_file_read_end_pos(struct rchan_buf *buf,
|
|||||||
return end_pos;
|
return end_pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static ssize_t relay_file_read(struct file *filp,
|
||||||
* subbuf_read_actor - read up to one subbuf's worth of data
|
char __user *buffer,
|
||||||
*/
|
size_t count,
|
||||||
static int subbuf_read_actor(size_t read_start,
|
loff_t *ppos)
|
||||||
struct rchan_buf *buf,
|
|
||||||
size_t avail,
|
|
||||||
read_descriptor_t *desc)
|
|
||||||
{
|
|
||||||
void *from;
|
|
||||||
int ret = 0;
|
|
||||||
|
|
||||||
from = buf->start + read_start;
|
|
||||||
ret = avail;
|
|
||||||
if (copy_to_user(desc->arg.buf, from, avail)) {
|
|
||||||
desc->error = -EFAULT;
|
|
||||||
ret = 0;
|
|
||||||
}
|
|
||||||
desc->arg.data += ret;
|
|
||||||
desc->written += ret;
|
|
||||||
desc->count -= ret;
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef int (*subbuf_actor_t) (size_t read_start,
|
|
||||||
struct rchan_buf *buf,
|
|
||||||
size_t avail,
|
|
||||||
read_descriptor_t *desc);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* relay_file_read_subbufs - read count bytes, bridging subbuf boundaries
|
|
||||||
*/
|
|
||||||
static ssize_t relay_file_read_subbufs(struct file *filp, loff_t *ppos,
|
|
||||||
subbuf_actor_t subbuf_actor,
|
|
||||||
read_descriptor_t *desc)
|
|
||||||
{
|
{
|
||||||
struct rchan_buf *buf = filp->private_data;
|
struct rchan_buf *buf = filp->private_data;
|
||||||
size_t read_start, avail;
|
size_t read_start, avail;
|
||||||
|
size_t written = 0;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!desc->count)
|
if (!count)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
inode_lock(file_inode(filp));
|
inode_lock(file_inode(filp));
|
||||||
do {
|
do {
|
||||||
|
void *from;
|
||||||
|
|
||||||
if (!relay_file_read_avail(buf, *ppos))
|
if (!relay_file_read_avail(buf, *ppos))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1174,32 +1146,22 @@ static ssize_t relay_file_read_subbufs(struct file *filp, loff_t *ppos,
|
|||||||
if (!avail)
|
if (!avail)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
avail = min(desc->count, avail);
|
avail = min(count, avail);
|
||||||
ret = subbuf_actor(read_start, buf, avail, desc);
|
from = buf->start + read_start;
|
||||||
if (desc->error < 0)
|
ret = avail;
|
||||||
|
if (copy_to_user(buffer, from, avail))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if (ret) {
|
buffer += ret;
|
||||||
|
written += ret;
|
||||||
|
count -= ret;
|
||||||
|
|
||||||
relay_file_read_consume(buf, read_start, ret);
|
relay_file_read_consume(buf, read_start, ret);
|
||||||
*ppos = relay_file_read_end_pos(buf, read_start, ret);
|
*ppos = relay_file_read_end_pos(buf, read_start, ret);
|
||||||
}
|
} while (count);
|
||||||
} while (desc->count && ret);
|
|
||||||
inode_unlock(file_inode(filp));
|
inode_unlock(file_inode(filp));
|
||||||
|
|
||||||
return desc->written;
|
return written;
|
||||||
}
|
|
||||||
|
|
||||||
static ssize_t relay_file_read(struct file *filp,
|
|
||||||
char __user *buffer,
|
|
||||||
size_t count,
|
|
||||||
loff_t *ppos)
|
|
||||||
{
|
|
||||||
read_descriptor_t desc;
|
|
||||||
desc.written = 0;
|
|
||||||
desc.count = count;
|
|
||||||
desc.arg.buf = buffer;
|
|
||||||
desc.error = 0;
|
|
||||||
return relay_file_read_subbufs(filp, ppos, subbuf_read_actor, &desc);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void relay_consume_bytes(struct rchan_buf *rbuf, int bytes_consumed)
|
static void relay_consume_bytes(struct rchan_buf *rbuf, int bytes_consumed)
|
||||||
|
Loading…
Reference in New Issue
Block a user