Hi Satish, > notifying HCI_NOTIFY_CONN_ADD for SCO connection is generic in > case of msbc audio. To differnetiate SCO air mode audio introducing > HCI_NOTIFY_SCO_CVSD and HCI_NOTIFY_SCO_TRASP. > > Signed-off-by: Sathish Narsimman <sathish.narasimman@xxxxxxxxx> > --- > include/net/bluetooth/hci.h | 3 +++ > include/net/bluetooth/hci_core.h | 3 +++ > net/bluetooth/hci_conn.c | 19 +++++++++++++++---- > net/bluetooth/hci_event.c | 9 +++++++++ > 4 files changed, 30 insertions(+), 4 deletions(-) > > diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h > index 5bc1e30dedde..bfaaef1aa4d6 100644 > --- a/include/net/bluetooth/hci.h > +++ b/include/net/bluetooth/hci.h > @@ -52,6 +52,9 @@ > #define HCI_NOTIFY_CONN_ADD 1 > #define HCI_NOTIFY_CONN_DEL 2 > #define HCI_NOTIFY_VOICE_SETTING 3 > +#define HCI_NOTIFY_ENABLE_SCO_CVSD 4 > +#define HCI_NOTIFY_ENABLE_SCO_TRANSP 5 > +#define HCI_NOTIFY_DISABLE_SCO 6 > > /* HCI bus types */ > #define HCI_VIRTUAL 0 > diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h > index b689aceb636b..9258e19f8cc5 100644 > --- a/include/net/bluetooth/hci_core.h > +++ b/include/net/bluetooth/hci_core.h > @@ -1604,4 +1604,7 @@ void hci_copy_identity_address(struct hci_dev *hdev, bdaddr_t *bdaddr, > #define SCO_AIRMODE_CVSD 0x0000 > #define SCO_AIRMODE_TRANSP 0x0003 > > +#define SCO_CODED_CVSD 0x02 > +#define SCO_CODED_TRANSP 0x03 > + why is this needed. And more important, what is wrong with SCO_AIRMODE_CVSD above? > #endif /* __HCI_CORE_H */ > diff --git a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c > index 87691404d0c6..097a179418d6 100644 > --- a/net/bluetooth/hci_conn.c > +++ b/net/bluetooth/hci_conn.c > @@ -122,8 +122,13 @@ static void hci_conn_cleanup(struct hci_conn *conn) > > hci_conn_hash_del(hdev, conn); > > - if (hdev->notify) > - hdev->notify(hdev, HCI_NOTIFY_CONN_DEL); > + if (conn->type == SCO_LINK || conn->type == ESCO_LINK) { > + if (hdev->notify) > + hdev->notify(hdev, HCI_NOTIFY_DISABLE_SCO); > + } else { > + if (hdev->notify) > + hdev->notify(hdev, HCI_NOTIFY_CONN_DEL); > + } > > hci_conn_del_sysfs(conn); > > @@ -561,8 +566,14 @@ struct hci_conn *hci_conn_add(struct hci_dev *hdev, int type, bdaddr_t *dst, > hci_dev_hold(hdev); > > hci_conn_hash_add(hdev, conn); > - if (hdev->notify) > - hdev->notify(hdev, HCI_NOTIFY_CONN_ADD); > + > + /* As HCI_NOTIFY_ENABLE_SCO_CVSD & HCI_NOTIFY_ENABLE_SCO_TRANSP is > + * used to notify SCO connections during sync_conn_complete event > + */ > + if (conn->type != SCO_LINK && conn->type != ESCO_LINK) { > + if (hdev->notify) > + hdev->notify(hdev, HCI_NOTIFY_CONN_ADD); > + } > > hci_conn_init_sysfs(conn); > > diff --git a/net/bluetooth/hci_event.c b/net/bluetooth/hci_event.c > index c1d3a303d97f..ecad696db139 100644 > --- a/net/bluetooth/hci_event.c > +++ b/net/bluetooth/hci_event.c > @@ -4231,6 +4231,15 @@ static void hci_sync_conn_complete_evt(struct hci_dev *hdev, > break; > } > > + BT_DBG("sco connected with air mode: %02x", ev->air_mode); > + if (ev->air_mode == SCO_CODED_CVSD) { > + if (hdev->notify) > + hdev->notify(hdev, HCI_NOTIFY_ENABLE_SCO_CVSD); > + } else if (ev->air_mode == SCO_CODED_TRANSP) { > + if (hdev->notify) > + hdev->notify(hdev, HCI_NOTIFY_ENABLE_SCO_TRANSP); > + } > + You are however forgetting the old hci_conn_complete for legacy SCO setup. Regards Marcel