diff options
author | Tom Zanussi <zanussi@us.ibm.com> | 2007-07-12 02:12:04 -0400 |
---|---|---|
committer | Jens Axboe <jens.axboe@oracle.com> | 2007-07-13 08:14:26 -0400 |
commit | 24da24de2eae0c277b85836e2b4b09cfafeea995 (patch) | |
tree | c7025d1fd59c116584e166d8e2c7e455718fd056 /kernel | |
parent | 773208946a132fb733ba273ee8562814f828cc28 (diff) |
relay: fix bogus cast in subbuf_splice_actor()
The current code that sets the read position in subbuf_splice_actor may
give erroneous results if the buffer size isn't a power of 2. This
patch fixes the problem.
Signed-off-by: Tom Zanussi <zanussi@us.ibm.com>
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/relay.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/kernel/relay.c b/kernel/relay.c index 3b299fb3855c..780269765f25 100644 --- a/kernel/relay.c +++ b/kernel/relay.c | |||
@@ -1074,7 +1074,9 @@ static int subbuf_splice_actor(struct file *in, | |||
1074 | unsigned int pidx, poff, total_len, subbuf_pages, ret; | 1074 | unsigned int pidx, poff, total_len, subbuf_pages, ret; |
1075 | struct rchan_buf *rbuf = in->private_data; | 1075 | struct rchan_buf *rbuf = in->private_data; |
1076 | unsigned int subbuf_size = rbuf->chan->subbuf_size; | 1076 | unsigned int subbuf_size = rbuf->chan->subbuf_size; |
1077 | size_t read_start = ((size_t)*ppos) % rbuf->chan->alloc_size; | 1077 | uint64_t pos = (uint64_t) *ppos; |
1078 | uint32_t alloc_size = (uint32_t) rbuf->chan->alloc_size; | ||
1079 | size_t read_start = (size_t) do_div(pos, alloc_size); | ||
1078 | size_t read_subbuf = read_start / subbuf_size; | 1080 | size_t read_subbuf = read_start / subbuf_size; |
1079 | size_t padding = rbuf->padding[read_subbuf]; | 1081 | size_t padding = rbuf->padding[read_subbuf]; |
1080 | size_t nonpad_end = read_subbuf * subbuf_size + subbuf_size - padding; | 1082 | size_t nonpad_end = read_subbuf * subbuf_size + subbuf_size - padding; |