Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4830436imm; Wed, 30 May 2018 12:54:20 -0700 (PDT) X-Google-Smtp-Source: ADUXVKIsjmq00Ta+JZcWzw2SsHgv9NqznQBKQgsc2unuNCekhET0ugiJN+LykfGXJSgxiXyKlK4K X-Received: by 2002:a62:2281:: with SMTP id p1-v6mr4046501pfj.53.1527710060126; Wed, 30 May 2018 12:54:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527710060; cv=none; d=google.com; s=arc-20160816; b=xn1ACtuEENoMs5F6qS4JukmaHTwDjSN1oncDxEJJthIxLxg6/HQSoQ+UilOKFiBnuZ YEsr/rv6yB6C08wsVMk2W8jiTvHBtp+jB0EPYcrBJ69HeN4xUZPlzWFTnf6GZfLGTYBy naQ3h+XaOYxDRZDsohtRpQlxZOkIhTEHhZ2fbt2t7ejCs0lsHx7dqH8wPDCNOC9YbQuY Lx8UeMPipQUDjlOzLARaLd1HV0kLSWkdFyQYUCg+eITNh4mljmgzFelJQaxhWzn201Fo 3DRR8c5as0TIMFAiGhb+ZZl8hPrG8PRn2SS/AWqYGhyHkjt6/Joz2XlfSTVz3F2DHXWv 3nBg== 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=CVCm9K9I94yqBW6/N+mynd69U1LSEUm/7eoBFhpBYzg=; b=worIS55BAViGWrzyvOXANhjQCyZWlNImI0iIAKdFW243J1E2g16sMTO83QSj/5+HQd FR48i1mGMjD74vwkWQBel3EX/9aoRpvPnWc43BjKPY0EVXH2ZB2R064ItxqVmzaEKF7h hgCVjH3w6MFmtUJhnwwk0lH5PnbLsFWwqnJhLpgFYoXi9xcih0kxKEvDxHA7HF3q3u/7 aS/F5Kxi/FNxN1FxAQEiczqIaK/re4JkYBmnxedU9D6rsCrtalxjxwz/m59U4qHd19C4 Lz6Be10xjVzs7nodg3uQmHL+rbQrJYlP66BZVIepHaeOhX+VgvPPuVKDflSOarSi72Eh 8cfA== 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 f7-v6si35175771pfa.78.2018.05.30.12.54.06; Wed, 30 May 2018 12:54:20 -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 S932324AbeE3TwL (ORCPT + 99 others); Wed, 30 May 2018 15:52:11 -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 S932251AbeE3Ttw (ORCPT ); Wed, 30 May 2018 15:49:52 -0400 Received: from linuxonhyperv2.linuxonhyperv.com ([107.180.71.197]) by : HOSTING RELAY : with SMTP id O75Sf7hbLF1fmO75SfIEQZ; Wed, 30 May 2018 12:48:51 -0700 x-originating-ip: 107.180.71.197 Received: from longli by linuxonhyperv2.linuxonhyperv.com with local (Exim 4.91) (envelope-from ) id 1fO75S-0008Fz-5G; Wed, 30 May 2018 12:48:46 -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 07/15] CIFS: When sending data on socket, pass the correct page offset Date: Wed, 30 May 2018 12:47:59 -0700 Message-Id: <20180530194807.31657-8-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: MS4wfO8CRb4B9gkMMC+3Kk7nmLvb1eLbHisriOoSpwinepjpeNH3pTC19tHDS3ndrePv3yW3mFFJOd8WeXKhjnfbFnVfs59BMXf8RGEpkI0tXES25Dm9xyYt z5IZzT7YLNhg3A5RM8z9HkALCDyggSU3iS2nSrJSwgzvjEaazCKPcRM9+9Yd7vGQhBTnDk5y32XJ9ifldv5M4RmnVqwfHmZpu/ppR1O6N09Z99HGg/fyARPj ciiGSlaiHBXjrq2fXzhaZ/DzboNn7P3q2Eyxwko8H6HhUewLiwmkpEJcF80dZ8LnxBfIQo7ofjm2T/KBjg1ot6Kj2pmHqI1uhCeg7k97tJu8PqfueAok2ZeV CTANKB0T8hXUEk3WH3gUhdvFBvboiHyl4ZrEwpijCTA/+4/gKN1VsQZ9crtiyUq1GXgHdT1K Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Long Li It's possible that the offset is non-zero in the page to send, change the function to pass this offset to socket. Signed-off-by: Long Li --- fs/cifs/transport.c | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/fs/cifs/transport.c b/fs/cifs/transport.c index d6b5523..5c96ee8 100644 --- a/fs/cifs/transport.c +++ b/fs/cifs/transport.c @@ -288,15 +288,13 @@ __smb_send_rqst(struct TCP_Server_Info *server, struct smb_rqst *rqst) /* now walk the page array and send each page in it */ for (i = 0; i < rqst->rq_npages; i++) { - size_t len = i == rqst->rq_npages - 1 - ? rqst->rq_tailsz - : rqst->rq_pagesz; - struct bio_vec bvec = { - .bv_page = rqst->rq_pages[i], - .bv_len = len - }; + struct bio_vec bvec; + + bvec.bv_page = rqst->rq_pages[i]; + rqst_page_get_length(rqst, i, &bvec.bv_len, &bvec.bv_offset); + iov_iter_bvec(&smb_msg.msg_iter, WRITE | ITER_BVEC, - &bvec, 1, len); + &bvec, 1, bvec.bv_len); rc = smb_send_kvec(server, &smb_msg, &sent); if (rc < 0) break; -- 2.7.4