Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp5916741yba; Mon, 13 May 2019 21:05:34 -0700 (PDT) X-Google-Smtp-Source: APXvYqwiP3T4pFIPVNSJrovTLfuCWosXKzsotof6SfYVFha5FPjukUzKS4ZVgEtgG/YLx37LenbB X-Received: by 2002:a63:1b56:: with SMTP id b22mr35011871pgm.87.1557806734165; Mon, 13 May 2019 21:05:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557806734; cv=none; d=google.com; s=arc-20160816; b=H17RZvq8/mjZYb46aP13nSzXpOzvamr5cTHlHmd74qOdWHfrDuhzmef5micH1R/OEf iGtOc40jeHEULxxGyoG8Z3F6tM1el0yEHHZGe6VpH5B03dKptem2CCPPPJ2EAgdxu89a IqsschdSo6IR1De8vj1zIBhEC5j0B0kP612TlSeVBLxdrnzRQZ4MPj1g8D+Xt9Kcojx6 ZAT8w8I/sWF2UMB3A446puyjA9LqVfnmJuenfdjIRwjEskJXs07YxjhukkExuvQWAQpS fLQ1cmXb5U0i54f0UZdsfccrjNJkS1eJ9Ekz5S9E4VTCCxChKNMxz3nzs37L2iWKJ12J G8nw== 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; bh=RVO/4I6ci3uR0yZ+nIL87hWys14oPxHzYpE0wLDHf2s=; b=Yn5xMcvPn8QdaQ/4VvY8Jz622bT4KZoPlXIZu/ViVtBkmNQZtYB/Vt0V8cD6/PeM/Y 8tsTcqFrx8vKkUdUtdKB5Xh7txGWWWvv3E2t3UwwqB601BHs5y+LOPdLgHk+FEuSf3tQ tpwDM6thkbVSwhP15X+dJfKgLQgiT3tnRTfP7kCsrKs958kYXqYeJdGp1cxd0ELMy9W4 E+l8IwzXO9K3ZnYkP0QaZ5YnSVpYAuawcuwooBQPATWh4QU137sPZ46+sWiN3Hwu0tCy x1rF2kfqC9LMqqww3jt8hduZH8ujSwyoY8ehEQmlyRq+asOUWF/iGtI6DSF3joSI6BPF HbEg== 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 x64si3022746pgd.20.2019.05.13.21.05.17; Mon, 13 May 2019 21:05:34 -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 S1726212AbfENECF (ORCPT + 99 others); Tue, 14 May 2019 00:02:05 -0400 Received: from linux.microsoft.com ([13.77.154.182]:37134 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726025AbfENECF (ORCPT ); Tue, 14 May 2019 00:02:05 -0400 Received: by linux.microsoft.com (Postfix, from userid 1004) id AD89B20D4DFA; Mon, 13 May 2019 21:02:04 -0700 (PDT) From: longli@linuxonhyperv.com To: Steve French , linux-cifs@vger.kernel.org, samba-technical@lists.samba.org, linux-kernel@vger.kernel.org Cc: Long Li Subject: [PATCH 2/2] cifs:smbd Use the correct DMA direction when sending data Date: Mon, 13 May 2019 21:01:29 -0700 Message-Id: <1557806489-11272-2-git-send-email-longli@linuxonhyperv.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1557806489-11272-1-git-send-email-longli@linuxonhyperv.com> References: <1557806489-11272-1-git-send-email-longli@linuxonhyperv.com> Reply-To: longli@microsoft.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Long Li When sending data, use the DMA_TO_DEVICE to map buffers. Also log the number of requests in a compounding request from upper layer. Signed-off-by: Long Li --- fs/cifs/smbdirect.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/fs/cifs/smbdirect.c b/fs/cifs/smbdirect.c index 251ef1223206..caac37b1de8c 100644 --- a/fs/cifs/smbdirect.c +++ b/fs/cifs/smbdirect.c @@ -903,7 +903,7 @@ static int smbd_create_header(struct smbd_connection *info, request->sge[0].addr = ib_dma_map_single(info->id->device, (void *)packet, header_length, - DMA_BIDIRECTIONAL); + DMA_TO_DEVICE); if (ib_dma_mapping_error(info->id->device, request->sge[0].addr)) { mempool_free(request, info->request_mempool); rc = -EIO; @@ -1005,7 +1005,7 @@ static int smbd_post_send_sgl(struct smbd_connection *info, for_each_sg(sgl, sg, num_sgs, i) { request->sge[i+1].addr = ib_dma_map_page(info->id->device, sg_page(sg), - sg->offset, sg->length, DMA_BIDIRECTIONAL); + sg->offset, sg->length, DMA_TO_DEVICE); if (ib_dma_mapping_error( info->id->device, request->sge[i+1].addr)) { rc = -EIO; @@ -2110,8 +2110,10 @@ int smbd_send(struct TCP_Server_Info *server, goto done; } - rqst_idx = 0; + log_write(INFO, "num_rqst=%d total length=%u\n", + num_rqst, remaining_data_length); + rqst_idx = 0; next_rqst: rqst = &rqst_array[rqst_idx]; iov = rqst->rq_iov; -- 2.17.1