Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp3389368ybl; Mon, 20 Jan 2020 23:15:27 -0800 (PST) X-Google-Smtp-Source: APXvYqxxjGjw6qvLaC53OAiLVUEceVL72fEN4NCG3q0FPW4oAd5mJnOM5lFHorcHZKGzLExLBGCO X-Received: by 2002:a9d:73d9:: with SMTP id m25mr2572319otk.350.1579590927785; Mon, 20 Jan 2020 23:15:27 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579590927; cv=none; d=google.com; s=arc-20160816; b=0EQrNKcAq51qjZhZuVBwxC4s+vBiVWlXTP9OZaraqOkhq0O5UtwrBCDw8rI0AOTZns foiVpZmT9LqQ6Y4gdSJFWATjxeC/ff+2VUmwoX67zGZL/AzXWg91IwwTThMMh/8dq+nN 7k6M4Cn1ruRPBagD/inspISy82dUVf/CXESF664n8uUrjKacSoHnAOSv3HwL+zLFekCd Sb1a6ABnPb3SIKk2Lc8wtKwy+vIMWpDFoauvZ1WG6r0UCAVPa6IuES/fwzn1IDPO++Wr UjvgNnjrV17cAx0d8gxNwxLA+a8ndHvWM96v+6s9ch9pAs5xRhJ6WBe1cXuLeFimiwWs QWOg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=qB7s2A/aIOac8xGoOGk+ZLX+c/1yZplIaIhGdyTw+uo=; b=SVfXatXo4PnvCLk53dEgJXFjUv3vepjD6G4N4xU694cjSzOz3mDnTlnjyfByZH4Nom ddwErlk02gnTRi/e+DVfA+4bYiiuABZTDw8BNVVShf3R1nxtbaT02sffEjjkBtLei4Xf 0rFNrOCni5UuDMpPupbmbtOB3dhoBVQ/PWIiAWYqiV6CAMqOaZjRL5Ng3A4AQzomW+Kt rbGq5tu8OPYqSn312D8GvYYMHRW1RVDps2rCHi3lwgHbhZc23alanVvyBn8/y/76qMot H46hHQj5yO+6xeuV6p2XF7lg7L7fcUR4M0vhCmWUBY+pOProfXR4uH1n8PbCN44WuITq lMxg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-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 l84si18310514oig.5.2020.01.20.23.14.58; Mon, 20 Jan 2020 23:15:27 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-wireless-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-wireless-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728829AbgAUHOJ (ORCPT + 99 others); Tue, 21 Jan 2020 02:14:09 -0500 Received: from alexa-out-blr-01.qualcomm.com ([103.229.18.197]:18844 "EHLO alexa-out-blr-01.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725789AbgAUHOJ (ORCPT ); Tue, 21 Jan 2020 02:14:09 -0500 Received: from ironmsg01-blr.qualcomm.com ([10.86.208.130]) by alexa-out-blr-01.qualcomm.com with ESMTP/TLS/AES256-SHA; 21 Jan 2020 12:42:39 +0530 Received: from pillair-linux.qualcomm.com ([10.204.116.193]) by ironmsg01-blr.qualcomm.com with ESMTP; 21 Jan 2020 12:42:33 +0530 Received: by pillair-linux.qualcomm.com (Postfix, from userid 452944) id A2C2838EF; Tue, 21 Jan 2020 12:42:32 +0530 (IST) From: Rakesh Pillai To: ath10k@lists.infradead.org Cc: linux-wireless@vger.kernel.org, Rakesh Pillai Subject: [PATCH] ath10k: Correct the DMA direction for management tx buffers Date: Tue, 21 Jan 2020 12:42:28 +0530 Message-Id: <1579590748-17883-1-git-send-email-pillair@codeaurora.org> X-Mailer: git-send-email 2.7.4 Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org The management packets, send to firmware via WMI, are mapped using the direction DMA_TO_DEVICE. Currently in case of wmi cleanup, these buffers are being unmapped using an incorrect DMA direction. This can cause unwanted behavior when the host driver is handling a restart of the wlan firmware. We might see a trace like below [] __dma_inv_area+0x28/0x58 [] ath10k_wmi_mgmt_tx_clean_up_pending+0x60/0xb0 [ath10k_core] [] idr_for_each+0x78/0xe4 [] ath10k_wmi_detach+0x4c/0x7c [ath10k_core] [] ath10k_core_stop+0x58/0x68 [ath10k_core] [] ath10k_halt+0xec/0x13c [ath10k_core] [] ath10k_core_restart+0x11c/0x1a8 [ath10k_core] [] process_one_work+0x16c/0x31c Fix the incorrect DMA direction during the wmi management tx buffer cleanup. Tested HW: WCN3990 Tested FW: WLAN.HL.3.1-00784-QCAHLSWMTPLZ-1 Fixes: dc405152bb6 ("ath10k: handle mgmt tx completion event") Signed-off-by: Rakesh Pillai --- drivers/net/wireless/ath/ath10k/wmi.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/wireless/ath/ath10k/wmi.c b/drivers/net/wireless/ath/ath10k/wmi.c index 13f7531..61885d4 100644 --- a/drivers/net/wireless/ath/ath10k/wmi.c +++ b/drivers/net/wireless/ath/ath10k/wmi.c @@ -9490,7 +9490,7 @@ static int ath10k_wmi_mgmt_tx_clean_up_pending(int msdu_id, void *ptr, msdu = pkt_addr->vaddr; dma_unmap_single(ar->dev, pkt_addr->paddr, - msdu->len, DMA_FROM_DEVICE); + msdu->len, DMA_TO_DEVICE); ieee80211_free_txskb(ar->hw, msdu); return 0; -- 2.7.4