Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4830751imm; Wed, 30 May 2018 12:54:48 -0700 (PDT) X-Google-Smtp-Source: ADUXVKLU+wqnaWYLMIooQhm5tg4PsitnFMVSyx6nZHx3JRFca1aqVnfMmXeatYVlweVhX8Yq93k4 X-Received: by 2002:a65:48c9:: with SMTP id o9-v6mr3302500pgs.106.1527710088736; Wed, 30 May 2018 12:54:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527710088; cv=none; d=google.com; s=arc-20160816; b=LkwTwTEQlZiG1xLg1fJlOXvWdg9+TRZA0Se0Q0VdNepZKXAx50yJ94ULyO5orRkTFB uq7FUX5IR5ccPf+KA9SNMpazFyzQD8BB2GlG6vrBsdcgEDfC2YRI0ZvNIu18x05UuRfe dPC5q+uwZH96KQqbNpCytrUGws2Xl5kwqhmN/bYiVA8sfftgHr2XzIHVPTcJrI9QJNmC Z27q4NNxruliIArvGP6I2tIVgvh192TA0xHN54Jn3OelQWsQOUkJO92nipbMZiHP614E yGGU6hI/U6oEbMqei1Kq/W/CBV4hTdAop6cjKoV6ibUDin27mHcGrOs6KImOPAHUxIoN kG4Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:reply-to:message-id:date:subject:cc:to :from:arc-authentication-results; bh=E9e+JIKsXEjC+8eSiDElkdnPlAnqNCrpiQXFjGK5D78=; b=quA8eypk2zzkEMobJdiO8baSgs811v4i2ZapHqs+VtULZVDeePd53iR1EbCRvAO9GE C5p7Qzut5M7XCErVg+7zs2C+6CIiQ14PDonC/iFg3WXhdRjbYoutlR5pae81urw7TSou e2l++C+ZlKG594kLhKLosDDcZx8/+ir/buM7qLVVOfbNDFyVdo8XSczd/yh6BXu18u1V QODh+/X0j/VdZHlYXCpbRxp+Ily8PLs1XYvOOoOyG9UaPwNEh25i50olc4JcBUN9k8M/ t5f42ZrPtm964zWap/Mv1uEeK51xiXDUiqvHCYgYQoByEwWdiI1hSEyX1TrKPMTPacZp 0Bcw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 91-v6si35009290ply.55.2018.05.30.12.54.34; Wed, 30 May 2018 12:54:48 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932255AbeE3Tw0 (ORCPT + 99 others); Wed, 30 May 2018 15:52:26 -0400 Received: from a2nlsmtp01-04.prod.iad2.secureserver.net ([198.71.225.38]:60154 "EHLO a2nlsmtp01-04.prod.iad2.secureserver.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932248AbeE3Ttv (ORCPT ); Wed, 30 May 2018 15:49:51 -0400 Received: from linuxonhyperv2.linuxonhyperv.com ([107.180.71.197]) by : HOSTING RELAY : with SMTP id O75Cf6FKPN7esO75Cf2xgf; Wed, 30 May 2018 12:48:50 -0700 x-originating-ip: 107.180.71.197 Received: from longli by linuxonhyperv2.linuxonhyperv.com with local (Exim 4.91) (envelope-from ) id 1fO75C-0008FH-2i; Wed, 30 May 2018 12:48:30 -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 v2 00/15] CIFS: Add direct I/O support Date: Wed, 30 May 2018 12:47:52 -0700 Message-Id: <20180530194807.31657-1-longli@linuxonhyperv.com> X-Mailer: git-send-email 2.17.0 Reply-To: longli@microsoft.com X-CMAE-Envelope: MS4wfOXTRW/GUneQYLoecZdiasFtUNNpaLz/S4ZgqJTHTd47qxTI9hnEpOeZuC3eJfSjt+3HCyi7Xh8iGB7Q73GOCL/4yhlKfWu5dEKGWxcRadQzcMXOxlXd lPIyqCpuY3Fpk5GlN27fT/4RbBc0B//xwgIYBEpHh61YbXPQZH9qNQ0SFm9+zY23JX9QyDmh09Lvr526uu96D7CNyE7TXgRakqRr/NRMXz96JGtn/uOElhXq M2ZH3M+W6JmHn7pHE/2e7SgJfcvwrOKphbHscKRUo3LkP/RXske6Gvh00LaKe3acLBJjpWx8lp/Rwiremo1/KidT/AWevz1iZl6ZPygNImcHJad4Cs+PaBJ2 bcGEATleor/q1coFObJGUz+zC/Eu7P5xdGxb7g6wZRzx6okCjfRi5dJ2S08bNb1u6redKPed Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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. Long Li (15): CIFS: Introduce offset for the 1st page in data transfer structures CIFS: Add support for direct pages in rdata CIFS: Use offset when reading pages CIFS: Add support for direct pages in wdata 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: 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 | 5 +- fs/cifs/cifsfs.h | 2 + fs/cifs/cifsglob.h | 7 +- fs/cifs/cifsproto.h | 9 +- fs/cifs/cifssmb.c | 17 ++- fs/cifs/connect.c | 5 +- fs/cifs/file.c | 389 +++++++++++++++++++++++++++++++++++++++++++++++--- fs/cifs/misc.c | 17 +++ fs/cifs/smb2ops.c | 22 +-- fs/cifs/smb2pdu.c | 20 ++- fs/cifs/smbdirect.c | 121 ++++++++++------ fs/cifs/smbdirect.h | 2 +- fs/cifs/transport.c | 34 +++-- 14 files changed, 554 insertions(+), 105 deletions(-) -- 2.7.4