From patchwork Sun May 28 09:48:06 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Christoph Hellwig X-Patchwork-Id: 9752243 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id 2FA0B6038E for ; Sun, 28 May 2017 09:48:25 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 20FC328446 for ; Sun, 28 May 2017 09:48:25 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 15FC728458; Sun, 28 May 2017 09:48:25 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=2.0 tests=BAYES_00,DKIM_SIGNED, RCVD_IN_DNSWL_HI,T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 6BBB428455 for ; Sun, 28 May 2017 09:48:24 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751062AbdE1JsV (ORCPT ); Sun, 28 May 2017 05:48:21 -0400 Received: from bombadil.infradead.org ([65.50.211.133]:37870 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751011AbdE1JsV (ORCPT ); Sun, 28 May 2017 05:48:21 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=References:In-Reply-To:Message-Id: Date:Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=/Tj5uZ0d7b5p3oqSorlY0HJ/LSxnEY14E5BWPiQDoR4=; b=BNGd4PreC5Qz50XftIoAP2xe3 j2QuHShfR3VLc40zskp+zq2h/v4dVjRqTNhwKjzzoqAYUHc2hWqNGKYg2Gc6ziIrxu9uPBFDQG6MI 6zJ9SYbRQsGlhb4Q4dyS98HXHWUyh8fEumxAA8b41TiWq+lz0fwj7HGsG4MF2ENSdOUXxKpGA67PG rQXldhI2aY4m61BqN3hMQcB5XzEBTAUGszXQZc29bWGCvTPB3JEOaW66HWF5uj3rydzCsp4vpXAlz BzIJlTn1Up9DjM9CfeqMbVV6koOhLyrRzzS/Eg7evJTu9pD/ZnYGbHVuPFBG+Z7iUl1QRGushwKVs oiKnrGBiw==; Received: from shol69.static.otenet.gr ([83.235.170.67] helo=localhost) by bombadil.infradead.org with esmtpsa (Exim 4.87 #1 (Red Hat Linux)) id 1dEuo7-00030j-TV; Sun, 28 May 2017 09:48:20 +0000 From: Christoph Hellwig To: viro@zeniv.linux.org.uk Cc: linux-fsdevel@vger.kernel.org Subject: [PATCH 2/3] splice: remove the old default splice_read/splice_write implementations Date: Sun, 28 May 2017 12:48:06 +0300 Message-Id: <20170528094807.26801-3-hch@lst.de> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20170528094807.26801-1-hch@lst.de> References: <20170528094807.26801-1-hch@lst.de> X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-fsdevel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-fsdevel@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP Everything sensible now either has explicit splice_read/write methods or implements ->read_iter/->write_iter. Remove the old default implementations and just return -EINVAL in that case. Signed-off-by: Christoph Hellwig --- fs/splice.c | 112 ++---------------------------------------------------------- 1 file changed, 2 insertions(+), 110 deletions(-) diff --git a/fs/splice.c b/fs/splice.c index ecf8d6edbb30..1117db47376b 100644 --- a/fs/splice.c +++ b/fs/splice.c @@ -347,22 +347,6 @@ const struct pipe_buf_operations nosteal_pipe_buf_ops = { }; EXPORT_SYMBOL(nosteal_pipe_buf_ops); -static ssize_t kernel_readv(struct file *file, const struct kvec *vec, - unsigned long vlen, loff_t offset) -{ - mm_segment_t old_fs; - loff_t pos = offset; - ssize_t res; - - old_fs = get_fs(); - set_fs(get_ds()); - /* The cast to a user pointer is valid due to the set_fs() */ - res = vfs_readv(file, (const struct iovec __user *)vec, vlen, &pos, 0); - set_fs(old_fs); - - return res; -} - ssize_t kernel_write(struct file *file, const char *buf, size_t count, loff_t pos) { @@ -379,71 +363,6 @@ ssize_t kernel_write(struct file *file, const char *buf, size_t count, } EXPORT_SYMBOL(kernel_write); -static ssize_t default_file_splice_read(struct file *in, loff_t *ppos, - struct pipe_inode_info *pipe, size_t len, - unsigned int flags) -{ - struct kvec *vec, __vec[PIPE_DEF_BUFFERS]; - struct iov_iter to; - struct page **pages; - unsigned int nr_pages; - size_t offset, base, copied = 0; - ssize_t res; - int i; - - if (pipe->nrbufs == pipe->buffers) - return -EAGAIN; - - /* - * Try to keep page boundaries matching to source pagecache ones - - * it probably won't be much help, but... - */ - offset = *ppos & ~PAGE_MASK; - - iov_iter_pipe(&to, ITER_PIPE | READ, pipe, len + offset); - - res = iov_iter_get_pages_alloc(&to, &pages, len + offset, &base); - if (res <= 0) - return -ENOMEM; - - nr_pages = DIV_ROUND_UP(res + base, PAGE_SIZE); - - vec = __vec; - if (nr_pages > PIPE_DEF_BUFFERS) { - vec = kmalloc(nr_pages * sizeof(struct kvec), GFP_KERNEL); - if (unlikely(!vec)) { - res = -ENOMEM; - goto out; - } - } - - pipe->bufs[to.idx].offset = offset; - pipe->bufs[to.idx].len -= offset; - - for (i = 0; i < nr_pages; i++) { - size_t this_len = min_t(size_t, len, PAGE_SIZE - offset); - vec[i].iov_base = page_address(pages[i]) + offset; - vec[i].iov_len = this_len; - len -= this_len; - offset = 0; - } - - res = kernel_readv(in, vec, nr_pages, *ppos); - if (res > 0) { - copied = res; - *ppos += res; - } - - if (vec != __vec) - kfree(vec); -out: - for (i = 0; i < nr_pages; i++) - put_page(pages[i]); - kvfree(pages); - iov_iter_advance(&to, copied); /* truncates and discards */ - return res; -} - /* * Send 'sd->len' bytes to socket from 'sd->file' at position 'sd->pos' * using sendpage(). Return the number of bytes sent. @@ -801,33 +720,6 @@ iter_file_splice_write(struct pipe_inode_info *pipe, struct file *out, EXPORT_SYMBOL(iter_file_splice_write); -static int write_pipe_buf(struct pipe_inode_info *pipe, struct pipe_buffer *buf, - struct splice_desc *sd) -{ - int ret; - void *data; - loff_t tmp = sd->pos; - - data = kmap(buf->page); - ret = __kernel_write(sd->u.file, data + buf->offset, sd->len, &tmp); - kunmap(buf->page); - - return ret; -} - -static ssize_t default_file_splice_write(struct pipe_inode_info *pipe, - struct file *out, loff_t *ppos, - size_t len, unsigned int flags) -{ - ssize_t ret; - - ret = splice_from_pipe(pipe, out, ppos, len, flags, write_pipe_buf); - if (ret > 0) - *ppos += ret; - - return ret; -} - /** * generic_splice_sendpage - splice data from a pipe to a socket * @pipe: pipe to splice from @@ -863,7 +755,7 @@ static long do_splice_from(struct pipe_inode_info *pipe, struct file *out, else if (out->f_op->write_iter) splice_write = iter_file_splice_write; else - splice_write = default_file_splice_write; + return -EINVAL; return splice_write(pipe, out, ppos, len, flags); } @@ -894,7 +786,7 @@ static long do_splice_to(struct file *in, loff_t *ppos, else if (in->f_op->read_iter) splice_read = iter_file_splice_read; else - splice_read = default_file_splice_read; + return -EINVAL; return splice_read(in, ppos, pipe, len, flags); }