Re: [PATCH] btio: Fix registering Object Push, File Transfer and other L2CAP profiles

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

 



Hi Pali,

On Thu, Jun 4, 2020 at 4:18 PM Pali Rohár <pali@xxxxxxxxxx> wrote:
>
> When bluetoothd daemon is starting, it prints following error messages:
>
> bluetoothd[19117]: src/profile.c:ext_start_servers() L2CAP server failed for Message Notification: setsockopt(L2CAP_OPTIONS): Invalid argument (22)
> bluetoothd[19117]: src/profile.c:ext_start_servers() L2CAP server failed for Message Access: setsockopt(L2CAP_OPTIONS): Invalid argument (22)
> bluetoothd[19117]: src/profile.c:ext_start_servers() L2CAP server failed for Phone Book Access: setsockopt(L2CAP_OPTIONS): Invalid argument (22)
> bluetoothd[19117]: src/profile.c:ext_start_servers() L2CAP server failed for File Transfer: setsockopt(L2CAP_OPTIONS): Invalid argument (22)
> bluetoothd[19117]: src/profile.c:ext_start_servers() L2CAP server failed for Object Push: setsockopt(L2CAP_OPTIONS): Invalid argument (22)
>
> Result is that Object Push and File Transfer profiles do not work at all.
>
> Debugging set_l2opts() function showed me that src/profile.c calls it with
> L2CAP mode 0x01 (L2CAP_MODE_RETRANS). But kernel bluetooth code in function
> l2cap_sock_setsockopt_old() for L2CAP_OPTIONS option disallows to set L2CAP
> method to 0x01 (L2CAP_MODE_RETRANS) and just returns -EINVAL (22).
>
> These bluetooth profiles have in src/profile.c file defined L2CAP mode to
> BT_IO_MODE_ERTM and not to RETRANS. So it means that BT_IO_MODE_ERTM value
> defined in 'enum BtIOMode' must be incorrect.
>
> Digging into git history, it appears that 'enum BtIOMode' was broken in
> commit f2418bf97d ("btio: Add mode to for Enhanced Credit Mode") which
> basically broke all those Object Push, File Transfer, Phone Book Access,
> Message Access and Message Notification L2CAP profiles. That commit removed
> some values from 'enum BtIOMode' and therefore broke all bluetooth code
> which uses 'enum BtIOMode' for communication with kernel.
>
> This patch fixes 'enum BtIOMode' by reverting back BT_IO_MODE_RETRANS and
> BT_IO_MODE_FLOWCTL modes, so BT_IO_MODE_ERTM has again correct value 0x03.
>
> After applying this patch, Object Push and File Transfer profiles work
> again.
>
> Fixes: f2418bf97d ("btio: Add mode to for Enhanced Credit Mode")
> ---
>
> Hello Luiz, could you please review this patch? As that problematic commit
> f2418bf97d was introduced by you.
>
> I'm curious why nobody else reported this issue about broken Object Push
> and File Transfer profile as it should print those error messages... Or
> maybe error message is visible only in debug build and nobody is using
> Bluetooth File Transfer anymore?

Looks like you are right but, see bellow.

> ---
>  btio/btio.h | 2 ++
>  1 file changed, 2 insertions(+)
>
> diff --git a/btio/btio.h b/btio/btio.h
> index 23e0ef72b..0d183e3ce 100644
> --- a/btio/btio.h
> +++ b/btio/btio.h
> @@ -68,6 +68,8 @@ typedef enum {
>
>  typedef enum {
>         BT_IO_MODE_BASIC = 0,
> +       BT_IO_MODE_RETRANS,
> +       BT_IO_MODE_FLOWCTL,
>         BT_IO_MODE_ERTM,
>         BT_IO_MODE_STREAMING,
>         BT_IO_MODE_LE_FLOWCTL,
> --
> 2.20.1

These modes were never supported by the kernel thus why Ive dropped
them, so might want to translate them to the old L2CAP modes when
set_l2opts is called.


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