Re: Extending BlueZ's HAL protocol

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

 



Hi Thomas,

> On Mozilla's Firefox OS, we use a daemon for running Bluedroid drivers
> in their own address space, and communicate with the daemon via BlueZ's
> HAL protocol. [1]
> 
> We'd like to use the HAL protocol as-is, but several commands are not
> defined in the spec. We especially ran into this problem with
> Bluedroid's |bt_interface_t::config_hci_snoop_log|. BlueZ has a
> completely different mechanism for handling the command and probably
> won't ever require an opcode for it. Just adding an opcode for
> |config_hci_snoop_log| to our code base will probably collide with BlueZ
> official spec in the long run.
> 
> Our proposal is to reserve two opcodes per service for extensions to
> commands and notifications. This would allow us to add the missing
> pieces without opcode collisions.

when you are using BlueZ for Android, we run the bluetoothd-snoop daemon to collect the traces. The reason why it is not in bluetoothd that provides all the other functionality is pretty simple. We do not have to and that is why we never bothered to define an opcode for it. That is the advantage of not being a huge monolithic block like Bluedroid.

We rely on the Bluetooth subsystem and its monitor (snooping) functionality. The big advantage having this in a separate process is that it will not interfere with any other operation bluetoothd has to do. The kernel can schedule bluetoothd and bluetoothd-snoop individually.

So bluetoothd-snoop is essentially a mini version of btmon where its only feature is to store traces in the old BTSnoop format (Frontline compatible). That said, nothing is stopping you from actually running btmon or hcidump on the target platform or multiple of them. We could even write a USB gadget driver that exports the traces over USB and you could run btmon / Wireshark on a PC to collect them.

Can you just run bluetoothd-snoop as well and get the tracing feature that way? If you build BlueZ for Android and run it that way, that is what happens through the developer menu. It is fully integrated into the Android UI and we have been running it that way for a long time now.

Regards

Marcel

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




[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