Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4828046imm; Wed, 30 May 2018 12:51:04 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJyiLExMtifOIs8lGjUUs+fpfsfwmutYO122Lh38nlQSu8uRBWDHZ77+67CZEGEiQfRT/u9 X-Received: by 2002:a62:ca98:: with SMTP id y24-v6mr3949551pfk.187.1527709863968; Wed, 30 May 2018 12:51:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527709863; cv=none; d=google.com; s=arc-20160816; b=cFhsEKthRbbB1uJHk6kYRl7XtnJochyYPreWW9Sw31XtrMSvSp4PkqMMn6ZKpz91wo /b+xQ/r4iOsvvletsljbsn7ZqR69ZWxbzwxCDjckGcE6vCaVuAVwEc86HkAKNllbna38 MQ6Q0LOBa6k73QwtxkOl5S3tw75hKqSUWFP6COKvf0OLl8dxzVyrNQbqdn/tDRFyW1eo Pl6yaQe6ZOLXK0Bq3FYFlgC5kH5Lw1dPSe+otBNkBycLO2GguikCfqTaiQXjAjDdHgYv EOvPa65ktUq2EVgcj2XXF9XrawDQDiOSm4UH3aAlhF3wIv6xPlChxGoHlNle10bseIK4 lbUA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:reply-to:references:in-reply-to :message-id:date:subject:cc:to:from:arc-authentication-results; bh=dDgUVTuHo0AxfjH4uALrlDJ1y8Z1v9i9aPhQsnG3nw0=; b=Gm/IESAMXWrru3FXI72vDjY0O0fzMzLjP4Vgwh+DUfgbe3ZYRenneePThDpni6FbJ/ isDMgo8Q6diJX+NcUsV5xLILyiqCgv9/Fe2emxYDuGSS5OzdNYsMjJSax35qqqa82oZ8 I1PPCMfmBT9FLxYqDdMV0RK5amDanWcsyMjX5O5dA1v2jH7clVx1gGXw2IRWqOfNfK7c aR4vLYZYgpRxuF3+BtvpuMGrlQSlQmP8WSQhLToGTwVBXmPSh+JoMxcdTzfufUU0HK0W b2+QlkLIPc/WwiyCJT0ulMoMn2t38TM/e0vYuSbwb3wrpdjBRSIOEgGT8Hv/yoY55f2r MJtA== 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 a6-v6si35574883plp.175.2018.05.30.12.50.50; Wed, 30 May 2018 12:51:03 -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 S932344AbeE3TuK (ORCPT + 99 others); Wed, 30 May 2018 15:50:10 -0400 Received: from a2nlsmtp01-05.prod.iad2.secureserver.net ([198.71.225.49]:37634 "EHLO a2nlsmtp01-05.prod.iad2.secureserver.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932246AbeE3TuC (ORCPT ); Wed, 30 May 2018 15:50:02 -0400 Received: from linuxonhyperv2.linuxonhyperv.com ([107.180.71.197]) by : HOSTING RELAY : with SMTP id O75hf7hi0F1fmO75hfIEW5; Wed, 30 May 2018 12:49:01 -0700 x-originating-ip: 107.180.71.197 Received: from longli by linuxonhyperv2.linuxonhyperv.com with local (Exim 4.91) (envelope-from ) id 1fO75h-0008GV-FG; Wed, 30 May 2018 12:49:01 -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 12/15] CIFS: Pass page offset for encrypting Date: Wed, 30 May 2018 12:48:04 -0700 Message-Id: <20180530194807.31657-13-longli@linuxonhyperv.com> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180530194807.31657-1-longli@linuxonhyperv.com> References: <20180530194807.31657-1-longli@linuxonhyperv.com> Reply-To: longli@microsoft.com X-CMAE-Envelope: MS4wfAn3YKoohboZ4kBQO0p1jn6WfOA4Mt3/PBMV3NVdeAzof2PdaKxw46LF8OTiK7Cy6jA/BFFL9e1r+xMXP1BOZ13Au7CQBu4PQRYCh3rkBIlrl3Ctxxh6 crF9XUkxMzEeOhaN0ufj21xk/4Z7sRAr4XPc2teAGS8ebH7Epnp5rIpXS8PBy5iuU4Bc4csayuQzyIWS+Yk8UaK20YId16bzl8PTk+T/1FNiRYyLtV/0wVsX YIFA02mPID8pdIQg5fOIf43HM9LM5PLqkwjaqbMw+H4q64qtYKN6Edgqivfk1cAeFoAmMGOQREP0KrV/fBPPaVmRUw6/xzlKW0epiZN+rupHPZl1zzygYr0g 6ivjoyrX1NpWJFAzEKHtlHqnnb/E101mBFWN4URXY/S5BHiX2xcRBvwstYPzLwxfh9YBbbXL Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Long Li Encryption function needs to read data starting page offset from input buffer. This doesn't affect decryption path since it allocates its own page buffers. Signed-off-by: Long Li --- fs/cifs/smb2ops.c | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c index 1fa1c29..38d19b6 100644 --- a/fs/cifs/smb2ops.c +++ b/fs/cifs/smb2ops.c @@ -2189,9 +2189,10 @@ init_sg(struct smb_rqst *rqst, u8 *sign) smb2_sg_set_buf(&sg[i], rqst->rq_iov[i].iov_base, rqst->rq_iov[i].iov_len); for (j = 0; i < sg_len - 1; i++, j++) { - unsigned int len = (j < rqst->rq_npages - 1) ? rqst->rq_pagesz - : rqst->rq_tailsz; - sg_set_page(&sg[i], rqst->rq_pages[j], len, 0); + unsigned int len, offset; + + rqst_page_get_length(rqst, j, &len, &offset); + sg_set_page(&sg[i], rqst->rq_pages[j], len, offset); } smb2_sg_set_buf(&sg[sg_len - 1], sign, SMB2_SIGNATURE_SIZE); return sg; @@ -2332,6 +2333,7 @@ smb3_init_transform_rq(struct TCP_Server_Info *server, struct smb_rqst *new_rq, return rc; new_rq->rq_pages = pages; + new_rq->rq_offset = old_rq->rq_offset; new_rq->rq_npages = old_rq->rq_npages; new_rq->rq_pagesz = old_rq->rq_pagesz; new_rq->rq_tailsz = old_rq->rq_tailsz; @@ -2363,10 +2365,14 @@ smb3_init_transform_rq(struct TCP_Server_Info *server, struct smb_rqst *new_rq, /* copy pages form the old */ for (i = 0; i < npages; i++) { - char *dst = kmap(new_rq->rq_pages[i]); - char *src = kmap(old_rq->rq_pages[i]); - unsigned int len = (i < npages - 1) ? new_rq->rq_pagesz : - new_rq->rq_tailsz; + char *dst, *src; + unsigned int offset, len; + + rqst_page_get_length(new_rq, i, &len, &offset); + + dst = (char *) kmap(new_rq->rq_pages[i]) + offset; + src = (char *) kmap(old_rq->rq_pages[i]) + offset; + memcpy(dst, src, len); kunmap(new_rq->rq_pages[i]); kunmap(old_rq->rq_pages[i]); -- 2.7.4