Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp750757pxb; Thu, 30 Sep 2021 16:52:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyrmrxlwnBr0acvoH/uc+aV3GDcAjP7walXBT/flnirW+Z3w0csm1ak0LzOtRNgrdPBvCkO X-Received: by 2002:a17:902:6ac7:b0:13e:1fec:2bbc with SMTP id i7-20020a1709026ac700b0013e1fec2bbcmr6733670plt.82.1633045958010; Thu, 30 Sep 2021 16:52:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633045958; cv=none; d=google.com; s=arc-20160816; b=M9wnmJNdG8A8hwGPGo7IsQn87WDOaiUNvvsDdvZIPzMbXLstfnfKBDSQtcNPUzdn7c 3c1P4pufkiVTp+uc/E99X7CdIvo8AIfM2lzTN46pvVanYfw14wvLq042OI/aUY+t/ocK 6XHYqETof+HV47sOpK/wwqUVxpMB+vlHHGJvIde42mYRc/w1mWu1vkbBV9Nh/bF/TG3B 2HJpRiXYZm2z0qITP7ymyxDTQhhKqYDhqr1YGTeIRa9V1cJAU514dt5btohZ+ldwVK78 Uo8JkY/xsTbzqdJF6onEja62fysEyaClKsd+nsNqRaw0vxTgXrI6UZhLgAT9Go3X+2lB jGLQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=ZXUSp6UW9pgmzBrfRX2N9y2OLCyGxpHjJJt38yDzsq4=; b=LAa92liK1zXdJJHJSkb7ds31jTqXGzCH+kYN+HanPHoRdLVEXj50XDUsDiD15TCjGf 2if+bsSTLg6TskxF5iW3Z+Pg03H6Mo5CXCcJ+25ilY31M02KnU+pzLi2z3a8n71uKm4R eejDJsbzs8awqYDOyzElHWdRAnTsfNalcHjClJl1/RjjMwJpYunxKxJKyrkWchvB3Pfb ppjrPy/RJFYoZJDZkXJrLYGoFcLjoWnmy9KUC3aZDbyvI/thhswlynYeeaNvHWQ6Beh5 dVRXem9SP9kmWD55Ti3//QXaiMKxHrcHztijYVQwb0JD4plENnU6COjoqL0AkhREkksT gvWw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g123si5292149pfb.111.2021.09.30.16.52.26; Thu, 30 Sep 2021 16:52:38 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mediatek.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1350654AbhI3Xvw (ORCPT + 78 others); Thu, 30 Sep 2021 19:51:52 -0400 Received: from mailgw01.mediatek.com ([216.200.240.184]:33710 "EHLO mailgw01.mediatek.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350111AbhI3Xvv (ORCPT ); Thu, 30 Sep 2021 19:51:51 -0400 X-UUID: 388ab7a245bc43648172853571670dc4-20210930 X-UUID: 388ab7a245bc43648172853571670dc4-20210930 Received: from mtkcas66.mediatek.inc [(172.29.193.44)] by mailgw01.mediatek.com (envelope-from ) (musrelay.mediatek.com ESMTP with TLSv1.2 ECDHE-RSA-AES256-SHA384 256/256) with ESMTP id 1137673985; Thu, 30 Sep 2021 16:50:06 -0700 Received: from mtkcas11.mediatek.inc (172.21.101.40) by MTKMBS62N2.mediatek.inc (172.29.193.42) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Thu, 30 Sep 2021 16:48:30 -0700 Received: from mtkswgap22.mediatek.inc (172.21.77.33) by mtkcas11.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Fri, 1 Oct 2021 07:48:29 +0800 From: To: , CC: , , , , , , , , , , , , , , , , , , , , , Subject: [PATCH v3 06/16] mt76: connac: move mcu reg access utility routines in mt76_connac_lib module Date: Fri, 1 Oct 2021 07:47:53 +0800 Message-ID: X-Mailer: git-send-email 1.7.9.5 In-Reply-To: References: MIME-Version: 1.0 Content-Type: text/plain X-MTK: N Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Sean Wang Move mcu reg access shared between mt7663s and mt7921s in mt76_connac_lib module. Tested-by: Deren Wu Acked-by: Lorenzo Bianconi Signed-off-by: Sean Wang --- .../wireless/mediatek/mt76/mt76_connac_mcu.c | 27 +++++++++++++++++++ .../wireless/mediatek/mt76/mt76_connac_mcu.h | 2 ++ 2 files changed, 29 insertions(+) diff --git a/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.c b/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.c index ae692052de97..a53f6344a184 100644 --- a/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.c +++ b/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.c @@ -2406,6 +2406,33 @@ void mt76_connac_mcu_set_suspend_iter(void *priv, u8 *mac, } EXPORT_SYMBOL_GPL(mt76_connac_mcu_set_suspend_iter); +u32 mt76_connac_mcu_reg_rr(struct mt76_dev *dev, u32 offset) +{ + struct { + __le32 addr; + __le32 val; + } __packed req = { + .addr = cpu_to_le32(offset), + }; + + return mt76_mcu_send_msg(dev, MCU_CMD_REG_READ, &req, sizeof(req), + true); +} +EXPORT_SYMBOL_GPL(mt76_connac_mcu_reg_rr); + +void mt76_connac_mcu_reg_wr(struct mt76_dev *dev, u32 offset, u32 val) +{ + struct { + __le32 addr; + __le32 val; + } __packed req = { + .addr = cpu_to_le32(offset), + .val = cpu_to_le32(val), + }; + + mt76_mcu_send_msg(dev, MCU_CMD_REG_WRITE, &req, sizeof(req), false); +} +EXPORT_SYMBOL_GPL(mt76_connac_mcu_reg_wr); #endif /* CONFIG_PM */ MODULE_AUTHOR("Lorenzo Bianconi "); diff --git a/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h b/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h index ea46dde364e1..6c410c4a8d6e 100644 --- a/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h +++ b/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h @@ -1111,4 +1111,6 @@ void mt76_connac_mcu_coredump_event(struct mt76_dev *dev, struct sk_buff *skb, int mt76_connac_mcu_set_rate_txpower(struct mt76_phy *phy); int mt76_connac_mcu_set_p2p_oppps(struct ieee80211_hw *hw, struct ieee80211_vif *vif); +u32 mt76_connac_mcu_reg_rr(struct mt76_dev *dev, u32 offset); +void mt76_connac_mcu_reg_wr(struct mt76_dev *dev, u32 offset, u32 val); #endif /* __MT76_CONNAC_MCU_H */ -- 2.25.1