mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-11 04:18:39 +08:00
lib/iov_iter: initialize "flags" in new pipe_buffer
commit9d2231c5d7
upstream. The functions copy_page_to_iter_pipe() and push_pipe() can both allocate a new pipe_buffer, but the "flags" member initializer is missing. Fixes:241699cd72
("new iov_iter flavour: pipe-backed") To: Alexander Viro <viro@zeniv.linux.org.uk> To: linux-fsdevel@vger.kernel.org To: linux-kernel@vger.kernel.org Cc: stable@vger.kernel.org Signed-off-by: Max Kellermann <max.kellermann@ionos.com> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
0b296fa588
commit
a162b11c97
@ -393,6 +393,7 @@ static size_t copy_page_to_iter_pipe(struct page *page, size_t offset, size_t by
|
|||||||
return 0;
|
return 0;
|
||||||
pipe->nrbufs++;
|
pipe->nrbufs++;
|
||||||
buf->ops = &page_cache_pipe_buf_ops;
|
buf->ops = &page_cache_pipe_buf_ops;
|
||||||
|
buf->flags = 0;
|
||||||
get_page(buf->page = page);
|
get_page(buf->page = page);
|
||||||
buf->offset = offset;
|
buf->offset = offset;
|
||||||
buf->len = bytes;
|
buf->len = bytes;
|
||||||
@ -517,6 +518,7 @@ static size_t push_pipe(struct iov_iter *i, size_t size,
|
|||||||
break;
|
break;
|
||||||
pipe->nrbufs++;
|
pipe->nrbufs++;
|
||||||
pipe->bufs[idx].ops = &default_pipe_buf_ops;
|
pipe->bufs[idx].ops = &default_pipe_buf_ops;
|
||||||
|
pipe->bufs[idx].flags = 0;
|
||||||
pipe->bufs[idx].page = page;
|
pipe->bufs[idx].page = page;
|
||||||
pipe->bufs[idx].offset = 0;
|
pipe->bufs[idx].offset = 0;
|
||||||
if (left <= PAGE_SIZE) {
|
if (left <= PAGE_SIZE) {
|
||||||
|
Loading…
Reference in New Issue
Block a user