* [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 @ 2018-09-19 15:21 Balakrishna Godavarthi 2018-09-19 15:21 ` [PATCH v2 1/1] Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 Balakrishna Godavarthi 2018-09-19 17:26 ` [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 Matthias Kaehlcke 0 siblings, 2 replies; 5+ messages in thread From: Balakrishna Godavarthi @ 2018-09-19 15:21 UTC (permalink / raw) To: marcel, johan.hedberg Cc: mka, linux-kernel, linux-bluetooth, hemantg, linux-arm-msm, Balakrishna Godavarthi This patch will power off regulators while hci0 down and turn on them back on hci0 up. Every time we power off we call proto specific close function, so that we will free the memory of Qualcomm BT specific buffers. Will call proto open to assign the memory and turn on the regulators, before calling qualcomm setup. v2: * Removed vendor specific hdev->open and close functions. * Added hdev->shutdown function to turn off the regs. v1: * initial patch. Balakrishna Godavarthi (1): Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 drivers/bluetooth/hci_qca.c | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project ^ permalink raw reply [flat|nested] 5+ messages in thread
* [PATCH v2 1/1] Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 2018-09-19 15:21 [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 Balakrishna Godavarthi @ 2018-09-19 15:21 ` Balakrishna Godavarthi 2018-09-19 17:21 ` Matthias Kaehlcke 2018-09-19 17:26 ` [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 Matthias Kaehlcke 1 sibling, 1 reply; 5+ messages in thread From: Balakrishna Godavarthi @ 2018-09-19 15:21 UTC (permalink / raw) To: marcel, johan.hedberg Cc: mka, linux-kernel, linux-bluetooth, hemantg, linux-arm-msm, Balakrishna Godavarthi This patch enables power off support for hci down and power on support for hci up. As wcn3990 power sources are ignited by regulators, we will turn off them during hci down, i.e. an complete power off of wcn3990. So while hci up, we will call vendor specific open/close and setup which will turn on the regulators, requests BT chip version and download the firmware. Signed-off-by: Balakrishna Godavarthi <bgodavar@codeaurora.org> --- drivers/bluetooth/hci_qca.c | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c index 74f5fede0274..c3038afa42af 100644 --- a/drivers/bluetooth/hci_qca.c +++ b/drivers/bluetooth/hci_qca.c @@ -168,6 +168,7 @@ struct qca_serdev { static int qca_power_setup(struct hci_uart *hu, bool on); static void qca_power_shutdown(struct hci_uart *hu); +static int qca_power_off(struct hci_dev *hdev); static void __serial_clock_on(struct tty_struct *tty) { @@ -1099,8 +1100,26 @@ static int qca_set_speed(struct hci_uart *hu, enum qca_speed_type speed_type) static int qca_wcn3990_init(struct hci_uart *hu) { struct hci_dev *hdev = hu->hdev; + struct qca_serdev *qcadev; int ret; + /* Check for vregs status, may be hci0 down has turned + * off the vregs. + */ + qcadev = serdev_device_get_drvdata(hu->serdev); + if (qcadev->bt_power->vregs_on == false) { + serdev_device_close(hu->serdev); + ret = qca_power_setup(hu, true); + if (ret) + return ret; + + ret = serdev_device_open(hu->serdev); + if (ret) { + bt_dev_err(hu->hdev, "failed to open port"); + return ret; + } + } + /* Forcefully enable wcn3990 to enter in to boot mode. */ host_set_baudrate(hu, 2400); ret = qca_send_power_pulse(hdev, QCA_WCN3990_POWEROFF_PULSE); @@ -1152,6 +1171,12 @@ static int qca_setup(struct hci_uart *hu) if (qcadev->btsoc_type == QCA_WCN3990) { bt_dev_info(hdev, "setting up wcn3990"); + + /* Enable NON_PERSISTENT_SETUP QUIRK to ensure to execute + * setup for every hci0 up. + */ + set_bit(HCI_QUIRK_NON_PERSISTENT_SETUP, &hdev->quirks); + hu->hdev->shutdown = qca_power_off; ret = qca_wcn3990_init(hu); if (ret) return ret; @@ -1242,6 +1267,14 @@ static void qca_power_shutdown(struct hci_uart *hu) qca_power_setup(hu, false); } +static int qca_power_off(struct hci_dev *hdev) +{ + struct hci_uart *hu = hci_get_drvdata(hdev); + + qca_power_shutdown(hu); + return 0; +} + static int qca_enable_regulator(struct qca_vreg vregs, struct regulator *regulator) { -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project ^ permalink raw reply related [flat|nested] 5+ messages in thread
* Re: [PATCH v2 1/1] Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 2018-09-19 15:21 ` [PATCH v2 1/1] Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 Balakrishna Godavarthi @ 2018-09-19 17:21 ` Matthias Kaehlcke 2018-09-20 13:48 ` Balakrishna Godavarthi 0 siblings, 1 reply; 5+ messages in thread From: Matthias Kaehlcke @ 2018-09-19 17:21 UTC (permalink / raw) To: Balakrishna Godavarthi Cc: marcel, johan.hedberg, linux-kernel, linux-bluetooth, hemantg, linux-arm-msm On Wed, Sep 19, 2018 at 08:51:13PM +0530, Balakrishna Godavarthi wrote: > This patch enables power off support for hci down and power on support > for hci up. As wcn3990 power sources are ignited by regulators, we will > turn off them during hci down, i.e. an complete power off of wcn3990. > So while hci up, we will call vendor specific open/close and setup which > will turn on the regulators, requests BT chip version and download the > firmware. > > Signed-off-by: Balakrishna Godavarthi <bgodavar@codeaurora.org> > --- > drivers/bluetooth/hci_qca.c | 33 +++++++++++++++++++++++++++++++++ > 1 file changed, 33 insertions(+) > > diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c > index 74f5fede0274..c3038afa42af 100644 > --- a/drivers/bluetooth/hci_qca.c > +++ b/drivers/bluetooth/hci_qca.c > @@ -168,6 +168,7 @@ struct qca_serdev { > > static int qca_power_setup(struct hci_uart *hu, bool on); > static void qca_power_shutdown(struct hci_uart *hu); > +static int qca_power_off(struct hci_dev *hdev); > > static void __serial_clock_on(struct tty_struct *tty) > { > @@ -1099,8 +1100,26 @@ static int qca_set_speed(struct hci_uart *hu, enum qca_speed_type speed_type) > static int qca_wcn3990_init(struct hci_uart *hu) > { > struct hci_dev *hdev = hu->hdev; > + struct qca_serdev *qcadev; > int ret; > > + /* Check for vregs status, may be hci0 down has turned > + * off the vregs. > + */ nit: it's not necessarily 'hci0', there may be systems with more than one Bluetooth controller. You could say hciN instead, you might also want to put quotes around 'hciN down' to make clearer this is referring to a command. > + qcadev = serdev_device_get_drvdata(hu->serdev); > + if (qcadev->bt_power->vregs_on == false) { nit: if (!qcadev->bt_power->vregs_on) { is more common and easier to read IMO > + serdev_device_close(hu->serdev); > + ret = qca_power_setup(hu, true); > + if (ret) > + return ret; > + > + ret = serdev_device_open(hu->serdev); > + if (ret) { > + bt_dev_err(hu->hdev, "failed to open port"); switch the regulators off again? > + return ret; > + } > + } > + > /* Forcefully enable wcn3990 to enter in to boot mode. */ > host_set_baudrate(hu, 2400); > ret = qca_send_power_pulse(hdev, QCA_WCN3990_POWEROFF_PULSE); > @@ -1152,6 +1171,12 @@ static int qca_setup(struct hci_uart *hu) > > if (qcadev->btsoc_type == QCA_WCN3990) { > bt_dev_info(hdev, "setting up wcn3990"); > + > + /* Enable NON_PERSISTENT_SETUP QUIRK to ensure to execute > + * setup for every hci0 up. nit: 'hciN up'? > + */ > + set_bit(HCI_QUIRK_NON_PERSISTENT_SETUP, &hdev->quirks); > + hu->hdev->shutdown = qca_power_off; > ret = qca_wcn3990_init(hu); > if (ret) > return ret; > @@ -1242,6 +1267,14 @@ static void qca_power_shutdown(struct hci_uart *hu) > qca_power_setup(hu, false); > } > > +static int qca_power_off(struct hci_dev *hdev) > +{ > + struct hci_uart *hu = hci_get_drvdata(hdev); > + > + qca_power_shutdown(hu); Would it make sense to add a return value qca_power_shutdown() now that it is called by a non-void function? Might not be worth the hassle though, hci_dev_do_close() - the only caller of hdev->shutdown() - doesn't check the return value either. Cheers Matthias ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH v2 1/1] Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 2018-09-19 17:21 ` Matthias Kaehlcke @ 2018-09-20 13:48 ` Balakrishna Godavarthi 0 siblings, 0 replies; 5+ messages in thread From: Balakrishna Godavarthi @ 2018-09-20 13:48 UTC (permalink / raw) To: Matthias Kaehlcke Cc: marcel, johan.hedberg, linux-kernel, linux-bluetooth, hemantg, linux-arm-msm Hi Matthias, On 2018-09-19 22:51, Matthias Kaehlcke wrote: > On Wed, Sep 19, 2018 at 08:51:13PM +0530, Balakrishna Godavarthi wrote: >> This patch enables power off support for hci down and power on support >> for hci up. As wcn3990 power sources are ignited by regulators, we >> will >> turn off them during hci down, i.e. an complete power off of wcn3990. >> So while hci up, we will call vendor specific open/close and setup >> which >> will turn on the regulators, requests BT chip version and download the >> firmware. >> >> Signed-off-by: Balakrishna Godavarthi <bgodavar@codeaurora.org> >> --- >> drivers/bluetooth/hci_qca.c | 33 +++++++++++++++++++++++++++++++++ >> 1 file changed, 33 insertions(+) >> >> diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c >> index 74f5fede0274..c3038afa42af 100644 >> --- a/drivers/bluetooth/hci_qca.c >> +++ b/drivers/bluetooth/hci_qca.c >> @@ -168,6 +168,7 @@ struct qca_serdev { >> >> static int qca_power_setup(struct hci_uart *hu, bool on); >> static void qca_power_shutdown(struct hci_uart *hu); >> +static int qca_power_off(struct hci_dev *hdev); >> >> static void __serial_clock_on(struct tty_struct *tty) >> { >> @@ -1099,8 +1100,26 @@ static int qca_set_speed(struct hci_uart *hu, >> enum qca_speed_type speed_type) >> static int qca_wcn3990_init(struct hci_uart *hu) >> { >> struct hci_dev *hdev = hu->hdev; >> + struct qca_serdev *qcadev; >> int ret; >> >> + /* Check for vregs status, may be hci0 down has turned >> + * off the vregs. >> + */ > > nit: it's not necessarily 'hci0', there may be systems with more than > one Bluetooth controller. You could say hciN instead, you might also > want to put quotes around 'hciN down' to make clearer this is > referring to a command. > [Bala]: will update. >> + qcadev = serdev_device_get_drvdata(hu->serdev); >> + if (qcadev->bt_power->vregs_on == false) { > > nit: > if (!qcadev->bt_power->vregs_on) { > > is more common and easier to read IMO > [Bala]: will update. >> + serdev_device_close(hu->serdev); >> + ret = qca_power_setup(hu, true); >> + if (ret) >> + return ret; >> + >> + ret = serdev_device_open(hu->serdev); >> + if (ret) { >> + bt_dev_err(hu->hdev, "failed to open port"); > > switch the regulators off again? [Bala]: it is not required to call the regulators off, when the serdev open fails. as the non zero return status will call the hci_dev_do_close() i.e. hdev->shutdown() > >> + return ret; >> + } >> + } >> + >> /* Forcefully enable wcn3990 to enter in to boot mode. */ >> host_set_baudrate(hu, 2400); >> ret = qca_send_power_pulse(hdev, QCA_WCN3990_POWEROFF_PULSE); >> @@ -1152,6 +1171,12 @@ static int qca_setup(struct hci_uart *hu) >> >> if (qcadev->btsoc_type == QCA_WCN3990) { >> bt_dev_info(hdev, "setting up wcn3990"); >> + >> + /* Enable NON_PERSISTENT_SETUP QUIRK to ensure to execute >> + * setup for every hci0 up. > > nit: 'hciN up'? [Bala]: will update. > >> + */ >> + set_bit(HCI_QUIRK_NON_PERSISTENT_SETUP, &hdev->quirks); >> + hu->hdev->shutdown = qca_power_off; >> ret = qca_wcn3990_init(hu); >> if (ret) >> return ret; >> @@ -1242,6 +1267,14 @@ static void qca_power_shutdown(struct hci_uart >> *hu) >> qca_power_setup(hu, false); >> } >> >> +static int qca_power_off(struct hci_dev *hdev) >> +{ >> + struct hci_uart *hu = hci_get_drvdata(hdev); >> + >> + qca_power_shutdown(hu); > > Would it make sense to add a return value qca_power_shutdown() now > that it is called by a non-void function? Might not be worth the > hassle though, hci_dev_do_close() - the only caller of > hdev->shutdown() - doesn't check the return value either. > [Bala]: even i felt the same, but hci_dev_do_close() is not checking for the status. > Cheers > > Matthias -- Regards Balakrishna. ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 2018-09-19 15:21 [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 Balakrishna Godavarthi 2018-09-19 15:21 ` [PATCH v2 1/1] Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 Balakrishna Godavarthi @ 2018-09-19 17:26 ` Matthias Kaehlcke 1 sibling, 0 replies; 5+ messages in thread From: Matthias Kaehlcke @ 2018-09-19 17:26 UTC (permalink / raw) To: Balakrishna Godavarthi Cc: marcel, johan.hedberg, linux-kernel, linux-bluetooth, hemantg, linux-arm-msm nit: Not sure there is much value in a cover letter for a 'series' with a single patch. The changelog and additional comments (if needed) can be placed in the post with the patch below '---'. On Wed, Sep 19, 2018 at 08:51:12PM +0530, Balakrishna Godavarthi wrote: > This patch will power off regulators while hci0 down and turn on them > back on hci0 up. Every time we power off we call proto specific close > function, so that we will free the memory of Qualcomm BT specific buffers. > Will call proto open to assign the memory and turn on the regulators, before > calling qualcomm setup. > > v2: > * Removed vendor specific hdev->open and close functions. > * Added hdev->shutdown function to turn off the regs. > > v1: > * initial patch. > > Balakrishna Godavarthi (1): > Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 > > drivers/bluetooth/hci_qca.c | 33 +++++++++++++++++++++++++++++++++ > 1 file changed, 33 insertions(+) > ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2018-09-20 13:48 UTC | newest] Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2018-09-19 15:21 [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 Balakrishna Godavarthi 2018-09-19 15:21 ` [PATCH v2 1/1] Bluetooth: hci_qca: Add poweroff support during hci down for wcn3990 Balakrishna Godavarthi 2018-09-19 17:21 ` Matthias Kaehlcke 2018-09-20 13:48 ` Balakrishna Godavarthi 2018-09-19 17:26 ` [PATCH v2 0/1] Cold on & off support for Qualcomm BT chip wcn3990 Matthias Kaehlcke
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).