Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4249996ybl; Tue, 21 Jan 2020 16:08:30 -0800 (PST) X-Google-Smtp-Source: APXvYqxsRwf/Bq7Y05F/sv18j1amXrvMJZ+a2EFw9GtynSEpZ7lvGSjMg6tCi1ZyFpAO6VBuWbEC X-Received: by 2002:aca:1111:: with SMTP id 17mr4754055oir.37.1579651710196; Tue, 21 Jan 2020 16:08:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579651710; cv=none; d=google.com; s=arc-20160816; b=ZQ+Q/CqUKEwvBL3ceJGuIZO/mbqPIGVIrswYl5ZPqB6QcE475zyHuRXW754TqYxfKt 2y6dpfO2JgdLRQbTfwrk7SlcY24yDCI4t1gzcFZHqo2Zci6l9IRJ4TKAFjESAyaXnVtS z/Ufw+6J8nEVt9i364ws1mC6pWl6XFBwML8zTEYwKhpDfFiCtsAdnjgZM1rSfSKpNhLq /8o9EAXpvdwVOtXXYksYU6bomMlYEl5ATGN7fcvvgbOyskJzB14lmy3NdlUQH406CsAr 4Sv5nUbbDXky7NIb6WSzhK9dQZOhl7zMJz8w+IMbktdPCd3Y+fiiaTY6yjZ76rw/unpM npXQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=foKquxBAIMXjAR3tdf5BNsaZnzetsrzrXlbRi9LRBb4=; b=cXcUGm0546Fc4CMgJHkV+f656EVZRD6JZEYVtSSywl3n7oLe3uEIDeCFptrAXNXvU1 bLBidv1XJMfcHal7qkea/Q9FZoT2DjcpkqpnGW8Yjk14a5R1I6j3p99ugHxGLNvcutDB dWOb40ecm4EPBICZNhil4s54A6qch8C/CCyr8rmH4tbzdbuXd1QvyvFWn2wnZWW7Vv9K dXUhkUy+T/5I1lXDrB6AhC0u5YrgqZjoGX76YCzOf6waTh7L+XfPGcqlIOs7LI/GF8DS GajWYtgRqQDM7sU5CBa7Ghv0jNUK3xy6CZSPpcDi4pmZJk+13kYM7Gbujcl8f/B818Rv 8dVg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=U4MDQ+MD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m24si19212160oic.11.2020.01.21.16.08.17; Tue, 21 Jan 2020 16:08:30 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=U4MDQ+MD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729031AbgAVAGO (ORCPT + 99 others); Tue, 21 Jan 2020 19:06:14 -0500 Received: from mail-wr1-f68.google.com ([209.85.221.68]:41947 "EHLO mail-wr1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728912AbgAVAGM (ORCPT ); Tue, 21 Jan 2020 19:06:12 -0500 Received: by mail-wr1-f68.google.com with SMTP id c9so5395697wrw.8; Tue, 21 Jan 2020 16:06:11 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=foKquxBAIMXjAR3tdf5BNsaZnzetsrzrXlbRi9LRBb4=; b=U4MDQ+MDFZ4+2VQMTW1Z2qxQ0J5lVSlfpS0Ugvi7MKull33Mv3+LI6Pu0vEhpl1j55 pXL3y8RB7AumVU9f5hDAnyiu1VI7uDcNkjJW06UZmOKWY7kWy7e4K0xQd4PIcde0I3dV u90jbXknx9egI5Qt5QqYbfSZBbMixLEYPnO1L8t5tFyi6d4k2yyQ1YS2jWVGF4hCvdsP A4yGRE/5YTTPOUkNAnMruf06GBg7XlAKPwwV2fbGYtvSxn3xxkoCqKMr0J3hk+dkA0Jh P9Z+1gga6DqXVT+G2Ncxtb9H9xu0RvJQuNyE1pN9GDIKwHaNjAIGsH8EZoEZJH+ggLNv P2Eg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=foKquxBAIMXjAR3tdf5BNsaZnzetsrzrXlbRi9LRBb4=; b=ZoA3CFXXPDo7e7e8KdmFs8QEiI1NuK1w6bOfzn7FLoQZjzTblhO9ocITCLLs1w9ojo AtHkUFvF+DPuaOLdfCFdwP/KzA7e0IRnmEMreY1YBW8jHONcBepoQUJ/0BK02EmfaxdM DFiLOnQWUcxVq72z44iKVzadoBdYUUFfLntMzZjfdIhMGv1+CJZxcDNlk4he7gWtBZSC ufJCDTgErvTbawrQ+R0eRSzIzWjISH/XPOosKpSV5IXdUQnPrZaHBwvM7FNdoBHCJom7 hmC70qp84Hi5dibkUBjF7mT75OAbXA7BwhCN0dx0Hk4QdB1gxL+1PBKMuHz5HdTGf4D5 SWUA== X-Gm-Message-State: APjAAAVi9mV9Kon+wT7XvFJwYH/UGz2RxPbBDWOQ7e5nsrpTbViu1T5C pkadHejG/Mnlm1u/rVakS72qUiJE X-Received: by 2002:a5d:44cd:: with SMTP id z13mr7840658wrr.104.1579651570339; Tue, 21 Jan 2020 16:06:10 -0800 (PST) Received: from localhost.localdomain ([109.126.145.157]) by smtp.gmail.com with ESMTPSA id o4sm54527068wrw.97.2020.01.21.16.06.08 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 21 Jan 2020 16:06:09 -0800 (PST) From: Pavel Begunkov To: Jens Axboe , io-uring@vger.kernel.org, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org Cc: Alexander Viro Subject: [PATCH 1/3] splice: make do_splice public Date: Wed, 22 Jan 2020 03:05:17 +0300 Message-Id: <525cb9fc7d729a96fd7ea57d88e8f82337973bfa.1579649589.git.asml.silence@gmail.com> X-Mailer: git-send-email 2.24.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Make do_splice(), so other kernel parts can reuse it Signed-off-by: Pavel Begunkov --- fs/splice.c | 6 +++--- include/linux/splice.h | 3 +++ 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/fs/splice.c b/fs/splice.c index 3009652a41c8..6a6f30432688 100644 --- a/fs/splice.c +++ b/fs/splice.c @@ -1109,9 +1109,9 @@ static int splice_pipe_to_pipe(struct pipe_inode_info *ipipe, /* * Determine where to splice to/from. */ -static long do_splice(struct file *in, loff_t __user *off_in, - struct file *out, loff_t __user *off_out, - size_t len, unsigned int flags) +long do_splice(struct file *in, loff_t __user *off_in, + struct file *out, loff_t __user *off_out, + size_t len, unsigned int flags) { struct pipe_inode_info *ipipe; struct pipe_inode_info *opipe; diff --git a/include/linux/splice.h b/include/linux/splice.h index 74b4911ac16d..ebbbfea48aa0 100644 --- a/include/linux/splice.h +++ b/include/linux/splice.h @@ -78,6 +78,9 @@ extern ssize_t add_to_pipe(struct pipe_inode_info *, struct pipe_buffer *); extern ssize_t splice_direct_to_actor(struct file *, struct splice_desc *, splice_direct_actor *); +extern long do_splice(struct file *in, loff_t __user *off_in, + struct file *out, loff_t __user *off_out, + size_t len, unsigned int flags); /* * for dynamic pipe sizing -- 2.24.0