[PATCH 04/11] splice: lift pipe_lock out of splice_to_pipe()
Linus Torvalds
torvalds at linux-foundation.org
Fri Sep 23 14:45:53 CDT 2016
On Fri, Sep 23, 2016 at 12:03 PM, Al Viro <viro at zeniv.linux.org.uk> wrote:
> @@ -1421,8 +1406,25 @@ static long do_splice(struct file *in, loff_t __user *off_in,
> + ret = 0;
> + pipe_lock(opipe);
> + bogus_count = opipe->buffers;
> + do {
> + bogus_count += opipe->nrbufs;
> + ret = do_splice_to(in, &offset, opipe, len, flags);
> + if (ret > 0) {
> + total += ret;
> + len -= ret;
> + }
> + bogus_count -= opipe->nrbufs;
> + if (bogus_count <= 0)
> + break;
I was like "oh, I'm sure this is some temporary hack, it will be gone
by the end of the series".
It wasn't gone by the end.
There's two copies of that pattern, and at the very least it needs a
big comment about what this pattern does and why.
But other than that reaction, I didn't get any hives from this. I
didn't *test* it, only looking at patches, but no red flags I could
notice.
Linus
More information about the xfs
mailing list