RE: [PATCH v13 12/12] Bluetooth: Allow usb to auto-suspend when SCO use non-HCI transport

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

 



Hi Luiz,

> -----Original Message-----
> From: Luiz Augusto von Dentz <luiz.dentz@xxxxxxxxx>
> Sent: Thursday, September 2, 2021 5:24 AM
> To: K, Kiran <kiran.k@xxxxxxxxx>
> Cc: linux-bluetooth@xxxxxxxxxxxxxxx; Tumkur Narayan, Chethan
> <chethan.tumkur.narayan@xxxxxxxxx>
> Subject: Re: [PATCH v13 12/12] Bluetooth: Allow usb to auto-suspend when SCO
> use non-HCI transport
> 
> Hi Kiran,
> 
> On Tue, Aug 31, 2021 at 4:54 AM Kiran K <kiran.k@xxxxxxxxx> wrote:
> >
> > From: Chethan T N <chethan.tumkur.narayan@xxxxxxxxx>
> >
> > Currently usb tranport is not allowed to suspend when SCO over HCI
> > tranport is active.
> >
> > This patch shall enable the usb tranport to suspend when SCO link use
> > non-HCI transport
> >
> > Signed-off-by: Chethan T N <chethan.tumkur.narayan@xxxxxxxxx>
> > Signed-off-by: Kiran K <kiran.k@xxxxxxxxx>
> > ---
> >
> > Notes:
> >     changes in v13:
> >     - suspend usb in HFP offload use case
> >
> >  drivers/bluetooth/btintel.c       |  2 +-
> >  include/net/bluetooth/bluetooth.h |  4 ++++
> >  net/bluetooth/hci_event.c         | 20 +++++++++++---------
> >  net/bluetooth/sco.c               |  2 +-
> >  4 files changed, 17 insertions(+), 11 deletions(-)
> >
> > diff --git a/drivers/bluetooth/btintel.c b/drivers/bluetooth/btintel.c
> > index 6091b691ddc2..2d64e289cf6e 100644
> > --- a/drivers/bluetooth/btintel.c
> > +++ b/drivers/bluetooth/btintel.c
> > @@ -2215,7 +2215,7 @@ static int btintel_get_codec_config_data(struct
> > hci_dev *hdev,  static int btintel_get_data_path_id(struct hci_dev
> > *hdev, __u8 *data_path_id)  {
> >         /* Intel uses 1 as data path id for all the usecases */
> > -       *data_path_id = 1;
> > +       *data_path_id = BT_SCO_PCM_PATH;
> >         return 0;
> >  }
> >
> > diff --git a/include/net/bluetooth/bluetooth.h
> > b/include/net/bluetooth/bluetooth.h
> > index c1fa90fb7502..9e2745863b33 100644
> > --- a/include/net/bluetooth/bluetooth.h
> > +++ b/include/net/bluetooth/bluetooth.h
> > @@ -177,6 +177,10 @@ struct bt_codecs {
> >  #define CODING_FORMAT_TRANSPARENT      0x03
> >  #define CODING_FORMAT_MSBC             0x05
> >
> > +/* Audio data transport path used for SCO */ #define BT_SCO_HCI_PATH
> > +0x00 #define BT_SCO_PCM_PATH 0x01
> 
> If this is in fact vendor specific perhaps you should be declared in btintel.h not
> here.
This is defined the Host Controller Interface assigned numbers, page no.3 "Transport Layer"- https://btprodspecificationrefs.blob.core.windows.net/assigned-numbers/Assigned%20Number%20Types/Host%20Controller%20Interface.pdf. So defined in bluetooth.h, let me know if you think otherwise.

> 
> > +
> >  __printf(1, 2)
> >  void bt_info(const char *fmt, ...);
> >  __printf(1, 2)
> > diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c
> > index b48e24629fa4..7ff11cba89cf 100644
> > --- a/net/bluetooth/hci_event.c
> > +++ b/net/bluetooth/hci_event.c
> > @@ -4516,15 +4516,17 @@ static void hci_sync_conn_complete_evt(struct
> > hci_dev *hdev,
> >
> >         bt_dev_dbg(hdev, "SCO connected with air mode: %02x",
> > ev->air_mode);
> >
> > -       switch (ev->air_mode) {
> > -       case 0x02:
> > -               if (hdev->notify)
> > -                       hdev->notify(hdev, HCI_NOTIFY_ENABLE_SCO_CVSD);
> > -               break;
> > -       case 0x03:
> > -               if (hdev->notify)
> > -                       hdev->notify(hdev, HCI_NOTIFY_ENABLE_SCO_TRANSP);
> > -               break;
> > +       if (conn->codec.data_path == BT_SCO_HCI_PATH) {
> > +               switch (ev->air_mode) {
> > +               case 0x02:
> > +                       if (hdev->notify)
> > +                               hdev->notify(hdev, HCI_NOTIFY_ENABLE_SCO_CVSD);
> > +                       break;
> > +               case 0x03:
> > +                       if (hdev->notify)
> > +                               hdev->notify(hdev, HCI_NOTIFY_ENABLE_SCO_TRANSP);
> > +                       break;
> > +               }
> 
> Hmm I think we might need to notify the driver to enable PCM routing so the
> likes of btusb can call usb_disable_endpoint/usb_enable_endpoint for example
> since in theory userspace may choose to switch from 
> offload and vice-versa, note without calling usb_disable_endpoint there might
> not be much power saving after all since the endpoint will remain active or do
> we actually have a good explanation why it shall not be called when using PCM
> routing? Note that usb_set_interface will call usb_enable_interface that will
> then call usb_enable_endpoint so perhaps we need to call
> usb_disable_interface, either way we can't assume the platform will be
> restricted to only use one or the other.
Ack, Does it make sense to define and notify events "HCI_NOTIFY_DISABLE_SCO_USB_INTF ", "HCI_NOTIFY_ENABLE_SCO_USB_INTF " accordingly and handle this in btusb driver by disabling/enabling the ISOC endpoint respectively. That will serve the purpose or switch between software to hardware.
> 
> >         }
> >
> >         hci_connect_cfm(conn, ev->status); diff --git
> > a/net/bluetooth/sco.c b/net/bluetooth/sco.c index
> > 004bce2b5eca..f35c12ca6aa5 100644
> > --- a/net/bluetooth/sco.c
> > +++ b/net/bluetooth/sco.c
> > @@ -506,7 +506,7 @@ static struct sock *sco_sock_alloc(struct net *net,
> struct socket *sock,
> >         sco_pi(sk)->codec.id = CODING_FORMAT_CVSD;
> >         sco_pi(sk)->codec.cid = 0xffff;
> >         sco_pi(sk)->codec.vid = 0xffff;
> > -       sco_pi(sk)->codec.data_path = 0x00;
> > +       sco_pi(sk)->codec.data_path = BT_SCO_HCI_PATH;
> >
> >         bt_sock_link(&sco_sk_list, sk);
> >         return sk;
> > --
> > 2.17.1
> >
> 
> 
> --
> Luiz Augusto von Dentz




[Index of Archives]     [Bluez Devel]     [Linux Wireless Networking]     [Linux Wireless Personal Area Networking]     [Linux ATH6KL]     [Linux USB Devel]     [Linux Media Drivers]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Big List of Linux Books]

  Powered by Linux