From patchwork Sat Sep 8 02:13:32 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Long Li X-Patchwork-Id: 10592869 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id CCA6B921 for ; Sat, 8 Sep 2018 02:16:51 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id C022A2B684 for ; Sat, 8 Sep 2018 02:16:51 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id B3F8E2B68A; Sat, 8 Sep 2018 02:16:51 +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=-7.9 required=2.0 tests=BAYES_00,MAILING_LIST_MULTI, RCVD_IN_DNSWL_HI 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 5A8E22B684 for ; Sat, 8 Sep 2018 02:16:51 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726443AbeIHG7G (ORCPT ); Sat, 8 Sep 2018 02:59:06 -0400 Received: from a2nlsmtp01-03.prod.iad2.secureserver.net ([198.71.225.37]:36584 "EHLO a2nlsmtp01-03.prod.iad2.secureserver.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726032AbeIHG7F (ORCPT ); Sat, 8 Sep 2018 02:59:05 -0400 Received: from linuxonhyperv2.linuxonhyperv.com ([107.180.71.197]) by : HOSTING RELAY : with ESMTP id ySl5fa5TKTEX4ySl5f1l1a; Fri, 07 Sep 2018 19:14:19 -0700 x-originating-ip: 107.180.71.197 Received: from longli by linuxonhyperv2.linuxonhyperv.com with local (Exim 4.91) (envelope-from ) id 1fySl5-0005DL-K8; Fri, 07 Sep 2018 19:13:59 -0700 From: Long Li To: Steve French , linux-cifs@vger.kernel.org, samba-technical@lists.samba.org, linux-kernel@vger.kernel.org, linux-rdma@vger.kernel.org Cc: Long Li Subject: [Patch v3 00/16] CIFS: add support for direct I/O Date: Sat, 8 Sep 2018 02:13:32 +0000 Message-Id: <20180908021348.19956-1-longli@linuxonhyperv.com> X-Mailer: git-send-email 2.18.0 Reply-To: longli@microsoft.com X-CMAE-Envelope: MS4wfJqy+5iG24CzfnCPxNSaHjaUBkur9CrCdYfcww1FU1IuXVCk2RJQ6s0In35BHNrgJPYYwK3jq1weVTgaF1SHlhhMRn6IQ0gl8H2QVVtKDj3zQQTgQrF5 yg1/cesE3NIMgja5Pfjb0XC9owv/WU1LWEDaMEohHccDyZeLhYZeTR67QV5H1zQcVs2PkKCQw6E5v9NTW1c81TkmBVw4T0PKqAFSwmyuCCrfQvW/wqT63QcP NVk23bpe03sDWHyzpMgn4CFfbR7fyQmIbJKF/7qlFmMpWAh70g8rudCLVgjs28bEbSNU6GmGJjhnddzZ28GyjqAFOElRWH8oDMWRXsa+7q0A18QJ7IKePcEH gHxu3xfL6k+MUUEHbmzJ8T2gxWDnEsK33FAd3XyWMNDCQ6WThRr5aYRLDANAxVpyqEhWg15q Sender: linux-cifs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-cifs@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP From: Long Li This patch set implements direct I/O. In normal code path (even with cache=none), CIFS copies I/O data from user-space to kernel-space for security reasons of possible protocol required signing and encryption on user data. With this patch set, CIFS passes the I/O data directly from user-space buffer to the transport layer, when file system is mounted with "cache-none". Patch v2 addressed comments from Christoph Hellwig and Tom Talpey to implement direct I/O for both socket and RDMA. Patch v3 added support for kernel AIO. Long Li (16): CIFS: Add support for direct pages in rdata CIFS: Use offset when reading pages CIFS: Add support for direct pages in wdata CIFS: pass page offset when issuing SMB write CIFS: Calculate the correct request length based on page offset and tail size CIFS: Introduce helper function to get page offset and length in smb_rqst CIFS: When sending data on socket, pass the correct page offset CIFS: SMBD: Support page offset in RDMA send CIFS: SMBD: Support page offset in RDMA recv CIFS: SMBD: Do not call ib_dereg_mr on invalidated memory registration CIFS: SMBD: Support page offset in memory registration CIFS: Pass page offset for calculating signature CIFS: Pass page offset for encrypting CIFS: Add support for direct I/O read CIFS: Add support for direct I/O write CIFS: Add direct I/O functions to file_operations fs/cifs/cifsencrypt.c | 9 +- fs/cifs/cifsfs.c | 10 +- fs/cifs/cifsfs.h | 2 + fs/cifs/cifsglob.h | 11 +- fs/cifs/cifsproto.h | 9 +- fs/cifs/cifssmb.c | 19 +- fs/cifs/connect.c | 5 +- fs/cifs/file.c | 477 ++++++++++++++++++++++++++++++++++++++++++-------- fs/cifs/misc.c | 17 ++ fs/cifs/smb2ops.c | 22 ++- fs/cifs/smb2pdu.c | 20 ++- fs/cifs/smbdirect.c | 156 ++++++++++------- fs/cifs/smbdirect.h | 2 +- fs/cifs/transport.c | 34 ++-- 14 files changed, 606 insertions(+), 187 deletions(-)