Re: [PATCH v4 2/3] Bluetooth: hci_qca: Add support for Qualcomm Bluetooth chip wcn3990.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Balakrishna,

On Wed, May 09, 2018 at 03:37:34PM +0530, Balakrishna Godavarthi wrote:
> Hi,
> Please find my comments inline.
> 
> On 2018-05-05 06:47, Matthias Kaehlcke wrote:
> > Hi,
> > 
> > On Fri, May 04, 2018 at 09:05:05PM +0530, Balakrishna Godavarthi wrote:
> > > Add support to set voltage/current of various regulators
> > > to power up/down Bluetooth chip wcn3990.
> > > Add support to read baudrate from dts.
> > > 
> > > Signed-off-by: Balakrishna Godavarthi <bgodavar@xxxxxxxxxxxxxx>
> > > ---
> > >  drivers/bluetooth/hci_qca.c | 555
> > > ++++++++++++++++++++++++++++++++++++++------
> > >  1 file changed, 483 insertions(+), 72 deletions(-)
> > > 
> > > diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c
> > > index f05382b..075fab7 100644
> > > --- a/drivers/bluetooth/hci_qca.c
> > > +++ b/drivers/bluetooth/hci_qca.c
> > > ...
> > > -	bt_dev_info(hdev, "ROME setup");
> > > +		/* disable flow control, as chip is still not turned on */
> > > +		hci_uart_set_flow_control(hu, true);
> > 
> > The interface of this function is confusing. enable = true disables
> > flow control ... Not the fault of this driver though :)
> [Bala]: yes it is bit confusing. i taught to update.. but not sure of
> impact.
>         so instead of updating, using the same function and written a
> comment above.

Sure, not much you can do about it. Just mentioned it since I was
about to comment that things are done inversely, but tean checked
hci_uart_set_flow_control() and saw that it has this odd
interface. Folks more familiar with the Bluetooth subsystem are
probably already used to it ;-)

> > > -	if (speed)
> > > -		host_set_baudrate(hu, speed);
> > > +		/* Enable flow control */
> > > +		hci_uart_set_flow_control(hu, false);
> > > +		/*  wait until flow control settled */
> > > +		mdelay(100);
> > 
> > A busy wait of 100ms doesn't seem a good idea. Use msleep()
> > instead. Is it really necessary to wait that long?
> [Bala]: yes this delay is required for BT Soc to bootup and settle down.

:(

> > What follows looks similar to the Cherokee path. I didn't look at all
> > the details, but it's probably possible to share some more code.
> [Bala]: yes these are two different chip.
>         we also have difference in setup. the follwing are major differences
>         Cherokee uses flow control. where ROME flow control is disabled.
>         ON sequence also varies.

Ok, I'll give it another pass in the next revision to see if I have
suggestions to make it at least a bit less redundant.

> > > +static const struct btqca_vreg_data cherokee_data = {
> > > +	.soc_type = BTQCA_CHEROKEE,
> > > +	.vregs = (struct btqca_vreg []) {
> > > +		{ "vddio",   1352000, 1352000,  0 },
> > > +		{ "vddxtal", 1904000, 2040000,  0 },
> > > +		{ "vddcore", 1800000, 1800000,  1 },
> > > +		{ "vddpa",   130400,  1304000,  1 },
> > 
> > 0 missing for min_v?
> 
> [Bala]: min_v is  the minimum voltage required for BT chip.

I referred to the value '130400', which happens to be exactly 1/10 of
the max_v '1304000', so I suspect the voltages are the same and a zero
is missing.

> > > +			regulator_set_voltage(qca->vreg_bulk[i].consumer,
> > > +					      vregs[i].min_v,
> > > +					      vregs[i].max_v);
> > 
> > Check return value.
> [Bala]: i am checking the status for regulator enable
>         do we really require to check the status. as this same regulators
> are used by different sub systems.
>         we will get an error during regulator enable when voltages are not
> settled down.

regulator_set_voltage() could fail due to requesting a voltage range
not supported by the regulator. In this case regulator_enable() could
still succeed, but not supply the requested voltage.

Thanks

Matthias
--
To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [Linux for Sparc]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux