Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp419900pxb; Thu, 19 Nov 2020 04:53:33 -0800 (PST) X-Google-Smtp-Source: ABdhPJwwGB3BkYyrWapGHyIQtvsb7lgIL/HXyCofflNjEem8O59GMNTvTjWftLLVYLgrwR4FpSPr X-Received: by 2002:a50:858a:: with SMTP id a10mr25206801edh.190.1605790413414; Thu, 19 Nov 2020 04:53:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605790413; cv=none; d=google.com; s=arc-20160816; b=NndOK1DIh6x7Kw45aUPdmzr0z0klubhAI/3492l869uTV9rDpHkfP7GRDkX5CO8Om+ FcUScyFclPSf0Vo+E+BfilmD2cpRTrvfrP4voN3IeAC0JPOb3fl2ZeZCC4S7UtGdJCU4 v3WrdlVUrlIlQf5vXI+6hMA4GOIQvG1FL0tXFpexqDHSbm8GcybURZJ9/DmvQh4CK3F8 O4ll4n6UGQZ/Kh6XzYNmPOx4ywSBdlYnyCuN8LTmgbKs6UpcBNZpGVRFaDmBJFhBQeF8 EJsldVyZMox1cj1iCdrvINH4rccRjegbqK9LHaZqltYVUu4dBf/tLpQw0bvrU5ntu6Ed xFqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:message-id:references:in-reply-to :subject:cc:to:from:date:content-transfer-encoding:mime-version :sender:dkim-signature; bh=YS1srtHny5nfchKhU+xc88MnY/ZZxicoLWKjXneyYUk=; b=Y5IOEG47eTIHeIg6pi3GQVAgUq3zNDTDd28O7hYGQFzujCNu26sNgi0Swob/4iAf9/ vZuwHcLpHwzaLtm08qiXF+KOzwx28oqOIaEmhxNk+Rq+phQAjOgCGZBXH/4p9nS52C2A QtI5wKLWbdgiiAgWZnlhMRHjqnZFAtlY4Kz2NAi9CF8PSP0Vp6HhGJjgUjJTR7kXjSpz bPzZLsNmPjeaZ+e1jxrxLzekf6w+sIcDcq2D9ZRXdhMSUV4qoTPWmBIWwROZBZiBpVWV kdkbZ/tu7Mhakw/d+rW3z/85PElLBPVI5vn41iPPLa9muyZyQjxmM53n4BOsy/J9jHhK Q6cQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=pyFQpZIY; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b15si17040086eja.538.2020.11.19.04.53.07; Thu, 19 Nov 2020 04:53:33 -0800 (PST) Received-SPF: pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@mg.codeaurora.org header.s=smtp header.b=pyFQpZIY; spf=pass (google.com: domain of linux-bluetooth-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-bluetooth-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727426AbgKSMw7 (ORCPT + 99 others); Thu, 19 Nov 2020 07:52:59 -0500 Received: from z5.mailgun.us ([104.130.96.5]:34681 "EHLO z5.mailgun.us" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727293AbgKSMw6 (ORCPT ); Thu, 19 Nov 2020 07:52:58 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1605790377; h=Message-ID: References: In-Reply-To: Subject: Cc: To: From: Date: Content-Transfer-Encoding: Content-Type: MIME-Version: Sender; bh=YS1srtHny5nfchKhU+xc88MnY/ZZxicoLWKjXneyYUk=; b=pyFQpZIYXSFt2c1F5cy2Je2Jdfx96SCMknzGJHwEA7Vj+mvzpDlyKhIwCOmyGj3IpZxCwM1g PHwG9sF/ySmXGXH2MmaydhZpqTEH/79aIyf6lfxrlHhJqs9JvH4bfx9P04qw/BBqrQ3RU96w bjFL8TqVcn9kyoqaDYqmbFD1HXU= X-Mailgun-Sending-Ip: 104.130.96.5 X-Mailgun-Sid: WyI2MTA3ZSIsICJsaW51eC1ibHVldG9vdGhAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by smtp-out-n06.prod.us-west-2.postgun.com with SMTP id 5fb66aa822377520ee2bba81 (version=TLS1.2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256); Thu, 19 Nov 2020 12:52:56 GMT Sender: gubbaven=codeaurora.org@mg.codeaurora.org Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 54702C43462; Thu, 19 Nov 2020 12:52:56 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.9 required=2.0 tests=ALL_TRUSTED,BAYES_00, URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) (using TLSv1 with cipher ECDHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) (Authenticated sender: gubbaven) by smtp.codeaurora.org (Postfix) with ESMTPSA id 2A3D9C433C6; Thu, 19 Nov 2020 12:52:55 +0000 (UTC) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Thu, 19 Nov 2020 18:22:55 +0530 From: gubbaven@codeaurora.org To: Marcel Holtmann Cc: Johan Hedberg , Matthias Kaehlcke , open list , linux-bluetooth , Hemantg , MSM , Balakrishna Godavarthi , Rocky Liao , hbandi@codeaurora.org, abhishekpandit@chromium.org Subject: Re: [PATCH v1] Bluetooth: Use NVM files based on SoC ID for WCN3991 In-Reply-To: References: <1600184605-31611-1-git-send-email-gubbaven@codeaurora.org> Message-ID: X-Sender: gubbaven@codeaurora.org User-Agent: Roundcube Webmail/1.3.9 Precedence: bulk List-ID: X-Mailing-List: linux-bluetooth@vger.kernel.org Hi Marcel, On 2020-09-16 19:57, Marcel Holtmann wrote: > Hi Venkata, > >> This change will allow to use different NVM file based >> on WCN3991 BT SoC ID.Need to use different NVM file based on >> fab location for WCN3991 BT SoC. >> >> Signed-off-by: Venkata Lakshmi Narayana Gubba >> >> --- >> drivers/bluetooth/btqca.c | 41 >> +++++++++++++++++++++++++---------------- >> drivers/bluetooth/btqca.h | 13 ++++++++----- >> drivers/bluetooth/hci_qca.c | 11 +++++------ >> 3 files changed, 38 insertions(+), 27 deletions(-) >> >> diff --git a/drivers/bluetooth/btqca.c b/drivers/bluetooth/btqca.c >> index ce9dcff..a7e72f1 100644 >> --- a/drivers/bluetooth/btqca.c >> +++ b/drivers/bluetooth/btqca.c >> @@ -14,12 +14,11 @@ >> >> #define VERSION "0.1" >> >> -int qca_read_soc_version(struct hci_dev *hdev, u32 *soc_version, >> +int qca_read_soc_version(struct hci_dev *hdev, struct >> qca_btsoc_version *ver, >> enum qca_btsoc_type soc_type) >> { >> struct sk_buff *skb; >> struct edl_event_hdr *edl; >> - struct qca_btsoc_version *ver; >> char cmd; >> int err = 0; >> u8 event_type = HCI_EV_VENDOR; >> @@ -70,9 +69,9 @@ int qca_read_soc_version(struct hci_dev *hdev, u32 >> *soc_version, >> } >> >> if (soc_type >= QCA_WCN3991) >> - memmove(&edl->data, &edl->data[1], sizeof(*ver)); >> - >> - ver = (struct qca_btsoc_version *)(edl->data); >> + memcpy(ver, &edl->data[1], sizeof(*ver)); > > any reason to use &edl->data[1] and not just edl->data + 1? [Venkata]: I will use edl->data + 1 and will update in next patchset. > >> + else >> + memcpy(ver, &edl->data, sizeof(*ver)); >> >> bt_dev_info(hdev, "QCA Product ID :0x%08x", >> le32_to_cpu(ver->product_id)); >> @@ -83,13 +82,7 @@ int qca_read_soc_version(struct hci_dev *hdev, u32 >> *soc_version, >> bt_dev_info(hdev, "QCA Patch Version:0x%08x", >> le16_to_cpu(ver->patch_ver)); >> >> - /* QCA chipset version can be decided by patch and SoC >> - * version, combination with upper 2 bytes from SoC >> - * and lower 2 bytes from patch will be used. >> - */ >> - *soc_version = (le32_to_cpu(ver->soc_id) << 16) | >> - (le16_to_cpu(ver->rom_ver) & 0x0000ffff); >> - if (*soc_version == 0) >> + if (le32_to_cpu(ver->soc_id) == 0 || le16_to_cpu(ver->rom_ver) == 0) >> err = -EILSEQ; >> >> out: >> @@ -446,15 +439,25 @@ int qca_set_bdaddr_rome(struct hci_dev *hdev, >> const bdaddr_t *bdaddr) >> EXPORT_SYMBOL_GPL(qca_set_bdaddr_rome); >> >> int qca_uart_setup(struct hci_dev *hdev, uint8_t baudrate, >> - enum qca_btsoc_type soc_type, u32 soc_ver, >> + enum qca_btsoc_type soc_type, struct qca_btsoc_version ver, >> const char *firmware_name) >> { >> struct qca_fw_config config; >> int err; >> u8 rom_ver = 0; >> + u32 soc_ver; >> >> bt_dev_dbg(hdev, "QCA setup on UART"); >> >> + /* QCA chipset version can be decided by patch and SoC >> + * version, combination with upper 2 bytes from SoC >> + * and lower 2 bytes from patch will be used. >> + */ >> + soc_ver = (le32_to_cpu(ver.soc_id) << 16) | >> + (le16_to_cpu(ver.rom_ver) & 0x0000ffff); > > Please indent this properly. > [Venkat]: Sure.I will update in next patchset. > I am also confused about the 0x0000ffff since it is just 16-bit value > in the first place. Also where do you want to shift the 32-bit value > to. > > Frankly, I find all this version magic kinda questionable. > >> + >> + bt_dev_info(hdev, "QCA controller version 0x%08x", soc_ver); >> + >> config.user_baud_rate = baudrate; >> >> /* Download rampatch file */ >> @@ -491,9 +494,15 @@ int qca_uart_setup(struct hci_dev *hdev, uint8_t >> baudrate, >> if (firmware_name) >> snprintf(config.fwname, sizeof(config.fwname), >> "qca/%s", firmware_name); >> - else if (qca_is_wcn399x(soc_type)) >> - snprintf(config.fwname, sizeof(config.fwname), >> - "qca/crnv%02x.bin", rom_ver); >> + else if (qca_is_wcn399x(soc_type)) { >> + if (ver.soc_id == QCA_WCN3991_SOC_ID) { >> + snprintf(config.fwname, sizeof(config.fwname), >> + "qca/crnv%02xu.bin", rom_ver); >> + } else { >> + snprintf(config.fwname, sizeof(config.fwname), >> + "qca/crnv%02x.bin", rom_ver); >> + } >> + } >> else if (soc_type == QCA_QCA6390) >> snprintf(config.fwname, sizeof(config.fwname), >> "qca/htnv%02x.bin", rom_ver); >> diff --git a/drivers/bluetooth/btqca.h b/drivers/bluetooth/btqca.h >> index d81b74c..d01a9f5 100644 >> --- a/drivers/bluetooth/btqca.h >> +++ b/drivers/bluetooth/btqca.h >> @@ -34,6 +34,8 @@ >> #define QCA_HCI_CC_OPCODE 0xFC00 >> #define QCA_HCI_CC_SUCCESS 0x00 >> >> +#define QCA_WCN3991_SOC_ID (0x40014320) >> + >> enum qca_baudrate { >> QCA_BAUDRATE_115200 = 0, >> QCA_BAUDRATE_57600, >> @@ -136,9 +138,9 @@ enum qca_btsoc_type { >> >> int qca_set_bdaddr_rome(struct hci_dev *hdev, const bdaddr_t *bdaddr); >> int qca_uart_setup(struct hci_dev *hdev, uint8_t baudrate, >> - enum qca_btsoc_type soc_type, u32 soc_ver, >> + enum qca_btsoc_type soc_type, struct qca_btsoc_version ver, >> const char *firmware_name); >> -int qca_read_soc_version(struct hci_dev *hdev, u32 *soc_version, >> +int qca_read_soc_version(struct hci_dev *hdev, struct >> qca_btsoc_version *ver, >> enum qca_btsoc_type); >> int qca_set_bdaddr(struct hci_dev *hdev, const bdaddr_t *bdaddr); >> int qca_send_pre_shutdown_cmd(struct hci_dev *hdev); >> @@ -155,13 +157,14 @@ static inline int qca_set_bdaddr_rome(struct >> hci_dev *hdev, const bdaddr_t *bdad >> } >> >> static inline int qca_uart_setup(struct hci_dev *hdev, uint8_t >> baudrate, >> - enum qca_btsoc_type soc_type, u32 soc_ver, >> - const char *firmware_name) >> + enum qca_btsoc_type soc_type, struct qca_btsoc_version ver, >> + const char *firmware_name) > > Please use proper indentation. > [Venkat]: Sure.I will update in next patchset. >> { >> return -EOPNOTSUPP; >> } >> >> -static inline int qca_read_soc_version(struct hci_dev *hdev, u32 >> *soc_version, >> +static inline int qca_read_soc_version(struct hci_dev *hdev, >> + struct qca_btsoc_version *ver, >> enum qca_btsoc_type) >> { >> return -EOPNOTSUPP; >> diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c >> index 244b8fe..4c32c60 100644 >> --- a/drivers/bluetooth/hci_qca.c >> +++ b/drivers/bluetooth/hci_qca.c >> @@ -1649,7 +1649,7 @@ static int qca_setup(struct hci_uart *hu) >> enum qca_btsoc_type soc_type = qca_soc_type(hu); >> const char *firmware_name = qca_get_firmware_name(hu); >> int ret; >> - int soc_ver = 0; >> + struct qca_btsoc_version ver; >> >> ret = qca_check_speeds(hu); >> if (ret) >> @@ -1678,7 +1678,7 @@ static int qca_setup(struct hci_uart *hu) >> if (qca_is_wcn399x(soc_type)) { >> set_bit(HCI_QUIRK_USE_BDADDR_PROPERTY, &hdev->quirks); >> >> - ret = qca_read_soc_version(hdev, &soc_ver, soc_type); >> + ret = qca_read_soc_version(hdev, &ver, soc_type); >> if (ret) >> return ret; >> } else { >> @@ -1697,15 +1697,14 @@ static int qca_setup(struct hci_uart *hu) >> >> if (!qca_is_wcn399x(soc_type)) { >> /* Get QCA version information */ >> - ret = qca_read_soc_version(hdev, &soc_ver, soc_type); >> + ret = qca_read_soc_version(hdev, &ver, soc_type); >> if (ret) >> return ret; >> } >> >> - bt_dev_info(hdev, "QCA controller version 0x%08x", soc_ver); >> /* Setup patch / NVM configurations */ >> - ret = qca_uart_setup(hdev, qca_baudrate, soc_type, soc_ver, >> - firmware_name); >> + ret = qca_uart_setup(hdev, qca_baudrate, soc_type, ver, >> + firmware_name); >> if (!ret) { >> set_bit(QCA_IBS_ENABLED, &qca->flags); >> qca_debugfs_init(hdev); > > Regards > > Marcel