Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2184348ybv; Mon, 24 Feb 2020 00:34:07 -0800 (PST) X-Google-Smtp-Source: APXvYqyyD3NGd3TEsL8slj3OUAXlnaFcJmlwhJI6JynfA8N7QM21ri3kM3mPrIk64ck/JBOsMV5K X-Received: by 2002:a9d:6184:: with SMTP id g4mr36944617otk.223.1582533247330; Mon, 24 Feb 2020 00:34:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582533247; cv=none; d=google.com; s=arc-20160816; b=MX282Z2Yl8UR+aDEpYbsq8JUl9W/IsPAmlmDIgFRdilI45KXsjsoD67/BxONpJ22a+ e8nV3PduZO8cptgNUhVEw9wENrr8YzwuNveDukXEJ9he2CzvNtyXfgcbuOxmMQaCRuD7 DIlAg4kFuF8oMhiGjVyR13mjtqoIBot3uWkhIVyNTEfNJupWaC/0oW9+JVZuLSIGf5vt j7plWxwRC79EtQdWZTGBSrS5dm64peXCwTW8eF5t8FZXEgptM5pyqLNaQNVtYARvHJcC RtboHFAnDH9KCThCOAOPij2+lpRyFVLeC+BOFIwUEPr9+YlSwc2HnHt/5TGzh8ak1igV tmFw== 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 :message-id:date:subject:to:from:dkim-signature; bh=nymHRd519oEr/2Ol/xDdmyiQN5tOm+qHNfWBj7Ts3V0=; b=JTBzqdn86wj5qN37VQIgSmCYSu33erXv0Y6ihHFzUfDKLK3q6UhZ29Ru+FteKuHGCb H9ANSFEgFTj5/DT7QONeuwSqB4K/7Cc1FQwymiAqWUBHICpsagjNZwe8/9K4B36R+GhN LmfS2XseHhPuhC2pH4d/wv+VJtDzKDijvI1dSRhq4IBjHB+WXTr4c1XtXKIWjFvx8X0I gdcde42etB9MaCW3M7VIlaxasQapyKYv0+Bc4EmELKFNvWpIHHzVufwgtfK0gkVN/ea2 +sPKfvqv3uKXfJ5tE/aiWYakZG/lu4N+mgizlR0EQW1Bc5TSQl4vhhUsyxrp7aizGTlU f7cw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=f9F5h86U; 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 a64si4869365oif.256.2020.02.24.00.33.50; Mon, 24 Feb 2020 00:34:07 -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=f9F5h86U; 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 S1727256AbgBXIdn (ORCPT + 99 others); Mon, 24 Feb 2020 03:33:43 -0500 Received: from mail-wr1-f67.google.com ([209.85.221.67]:37262 "EHLO mail-wr1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726216AbgBXIdn (ORCPT ); Mon, 24 Feb 2020 03:33:43 -0500 Received: by mail-wr1-f67.google.com with SMTP id l5so5015994wrx.4; Mon, 24 Feb 2020 00:33:41 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:subject:date:message-id:mime-version :content-transfer-encoding; bh=nymHRd519oEr/2Ol/xDdmyiQN5tOm+qHNfWBj7Ts3V0=; b=f9F5h86Uonh3ZWKSL+1FCIP03WC4MMNfKcSmK25Xr0N791WFzTrf2v66QMzZh2Jfl9 JJNRhxQtuh72EIjk5glA0KYpFknjSsmDgXCRxV//qj1aAnqZSz+OEkXCOrraCMjLaNy6 XCOBCAyjmwAKvaPw9tQthGqqYUfvGj/GBTygchwX9h0wtS5TU/QpZdOqfs28gPUTXoH9 cUlfNSRBU2wZTpG7pZUbwN5auFruRHJxmqiNg4eP1Im9ntsdt96Nt3EmxPhjDL0cpBM6 WHE/7/FCLs2HNCePWMYlDYQtBqfZe5HVqsCbbkpHwEIrrNBG/lqeu6shzgkl+kngVmOC FkkQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:mime-version :content-transfer-encoding; bh=nymHRd519oEr/2Ol/xDdmyiQN5tOm+qHNfWBj7Ts3V0=; b=KjnuwkLxMmN6qxHmbXqZopXN6NmSscNZ96BAHcfWt+0NGJhjby6o1kHqII7frnfwfQ mR+XFa+BnHMEE3GXH9e/Swo92m3JlFwMi0X9Xt991MYCfqvBv3VgVQlBKbDoTD4OzLlo eWzijsyq4Rpc/nKWY3XWC1sNNgLkiV2cr+9YGdc+IN/gYyqH1oDRpWS5HzxQaKJ/XIFR 0l2pYm8Bp9/+3sr8wjGkAXHrQHcF+kYnv6F1ZIjvwIXDPAyVgthMNLrQioyt523fy9mL z8fx6O0gXM6VcaIv9WFWdzPafJxpdTW1Hf1NtPvOGGnS86FReT2WDr8B2A/pOUAbJN63 69Pw== X-Gm-Message-State: APjAAAXlUMa3LMnmrB7Uz5GTVx7AGq9bgTtWDiK643oti6Minl1xXA+b UnLnf0HUUI/MxC01nL+FveE= X-Received: by 2002:adf:f744:: with SMTP id z4mr60283849wrp.318.1582533220739; Mon, 24 Feb 2020 00:33:40 -0800 (PST) Received: from localhost.localdomain ([109.126.137.65]) by smtp.gmail.com with ESMTPSA id p15sm16695353wma.40.2020.02.24.00.33.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 24 Feb 2020 00:33:40 -0800 (PST) From: Pavel Begunkov To: Jens Axboe , Alexander Viro , Stefan Metzmacher , io-uring@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v4 0/3] io_uring: add splice(2) support Date: Mon, 24 Feb 2020 11:32:42 +0300 Message-Id: X-Mailer: git-send-email 2.24.0 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 *on top of for-5.6 + async patches* Not the fastets implementation, but I'd need to stir up/duplicate splice.c bits to do it more efficiently. note: rebase on top of the recent inflight patchset. v2: - u32 len and SQE layout changes (Jens) - output file is in sqe->fd for automatic hash_reg_file support - handle unbound_nonreg_file for the second fd - file leaks fixed with REQ_F_NEED_CLEANUP - place SPLICE_F_FD_IN_FIXED in splice flags (Jens) - loff_t* -> loff_t, -1 means not specified offset v3: [PATCH 3/3] changes - fd u32 -> s32 (Stefan Metzmacher) - add BUILD_BUG_SQE_ELEM() (Stefan Metzmacher) - accept and ignore ioprio (Stefan Metzmacher) - off_in -> splice_off_in v4: - rebase + a bit of function renaming - make file_get/put accept req instead of ctx (Jens) - fix lost REQ_F_FIXED_FILE Pavel Begunkov (3): splice: make do_splice public io_uring: add interface for getting files io_uring: add splice(2) support fs/io_uring.c | 181 ++++++++++++++++++++++++++++------ fs/splice.c | 6 +- include/linux/splice.h | 3 + include/uapi/linux/io_uring.h | 14 ++- 4 files changed, 171 insertions(+), 33 deletions(-) -- 2.24.0