Re: [PATCH BlueZ] btio: Fix not translation mode to L2CAP mode

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

 



Hi,

On Fri, Jun 5, 2020 at 10:59 AM Luiz Augusto von Dentz
<luiz.dentz@xxxxxxxxx> wrote:
>
> From: Luiz Augusto von Dentz <luiz.von.dentz@xxxxxxxxx>
>
> When using L2CAP_OPTIONS legacy modes need to be used since they are
> not compatible with BT_MODE.
> ---
>  btio/btio.c | 24 ++++++++++++++++++++++--
>  1 file changed, 22 insertions(+), 2 deletions(-)
>
> diff --git a/btio/btio.c b/btio/btio.c
> index 13c731062..844d6007f 100644
> --- a/btio/btio.c
> +++ b/btio/btio.c
> @@ -597,6 +597,20 @@ static gboolean get_key_size(int sock, int *size, GError **err)
>         return FALSE;
>  }
>
> +static uint8_t mode_l2mode(uint8_t mode)
> +{
> +       switch (mode) {
> +       case BT_IO_MODE_BASIC:
> +               return L2CAP_MODE_BASIC;
> +       case BT_IO_MODE_ERTM:
> +               return L2CAP_MODE_ERTM;
> +       case BT_IO_MODE_STREAMING:
> +               return L2CAP_MODE_STREAMING;
> +       default:
> +               return UINT8_MAX;
> +       }
> +}
> +
>  static gboolean set_l2opts(int sock, uint16_t imtu, uint16_t omtu,
>                                                 uint8_t mode, GError **err)
>  {
> @@ -614,8 +628,14 @@ static gboolean set_l2opts(int sock, uint16_t imtu, uint16_t omtu,
>                 l2o.imtu = imtu;
>         if (omtu)
>                 l2o.omtu = omtu;
> -       if (mode)
> -               l2o.mode = mode;
> +
> +       if (mode) {
> +               l2o.mode = mode_l2mode(mode);
> +               if (l2o.mode == UINT8_MAX) {
> +                       ERROR_FAILED(err, "Unsupported mode", errno);
> +                       return FALSE;
> +               }
> +       }
>
>         if (setsockopt(sock, SOL_L2CAP, L2CAP_OPTIONS, &l2o, sizeof(l2o)) < 0) {
>                 ERROR_FAILED(err, "setsockopt(L2CAP_OPTIONS)", errno);
> --
> 2.25.3

Pushed.

-- 
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