Trying to setup the Bluetooth on FreeBSD...

Hello to everyone.

with some coworkers we are trying to create the first mobile phone powered with FreeBSD. The keyboard that we have chosen for the moment is the Bluetooth LILYGO T-Watch and the BT dongle that I'm using now on my PC is this one :


Code:
ubt0: <Broadcom Corp Bluetooth Dongle V2.0+EDR, class 224/1, rev 2.00/1.00, addr 19> on usbus1

I want to setup the bluetooth on FreeBSD to be able to use this keyboard on the FreeBSD / raspberry pi based mobile phone that will be born. I read everywhere that the configuration of the Bluetooth on FreeBSD is tricky. Ok,I want to try to tinker with it.
 
According with this post :


this is what I did :

Code:
marietto# pkg install iwmbt-firmware

marietto# service devd restart      

marietto# pkg install virtual_oss   

marietto# kldload cuse              

marietto# sysrc kld_list+="cuse"    

marietto# service hcsecd onestart   

marietto# service bluetooth start ubt0

marietto# hccontrol -n ubt0hci inquiry

Inquiry complete. Status: No error [00]

log :

ubt0: <Broadcom Corp Bluetooth Dongle V2.0+EDR, class 224/1, rev 2.00/1.00, addr 19> on usbus1
Cuse v0.1.37 @ /dev/cuse
ng_hci_process_command_timeout: ubt0hci - unable to complete HCI command OGF=0x3, OCF=0x3. Timeout
 
marietto# pkg install iwmbt-firmware
Why are you installing Intel Wireless module BT firmware?

You mentioned you had Broadcom Bluetooth. I dont think you are loading the right bluetooth module.

I'm using now on my PC is this one :
Please show usbconfig for the device.

Something like this:
ugen0.5: <Dell Wireless 1802 Bluetooth 4.0 LE Qualcomm Atheros Communications> at usbus0, cfg=0 md=HOST spd=FULL (12Mbps) pwr=ON (100mA)
 
Because the guy on the post used this dongle :

dongle from : Amazon (Broadcom BCM20702A0)

and my dongle is Broadcom :

marietto# usbconfig
ugen1.5: <BCM2210 Bluetooth Broadcom Corp.> at usbus1, cfg=0 md=HOST spd=FULL (12Mbps) pwr=ON (100mA)

UPDATE : ok,he said that he bought a Broadcom dongle but he didn't use it . I didn't read well...
 
I would suggest you figure out the USB Bluetooth Dongle on amd64 and then carry the work to arm64. Never assume that things just work there.

Plus plug and play might not work the same so take notes what amd64 uses for modules. It should autoload them. Plug it in after boot and see what messages show is loading.
 
I would suggest you figure out the USB Bluetooth Dongle on amd64 and then carry the work to arm64. Never assume that things just work there,

He said that he bought a Broadcom dongle but he didn't use it . I didn't read well...I'm doing exactly what you are suggesting.
I've modified the body of my post,please refresh the page. Before to try on the raspi,I'm trying to set it up on my PC.
 
So,this is the procedure to follow generated by the AI :

AI Overview
Learn more

For Broadcom BCM2033-based Bluetooth devices in FreeBSD, you'll use the ubtbcmfw(4) and ng_ubt(4) drivers, loading them with kldload or adding them to /boot/loader.conf for automatic loading at boot.


Here's a more detailed breakdown:
  • Driver: Broadcom BCM2033-based Bluetooth devices are supported by the ubtbcmfw(4) and ng_ubt(4) drivers.

  • Loading the Driver:
    • Manually: Use the command kldload ng_ubt to load the ng_ubt driver.

  • Automatically at Boot: Add the following line to /boot/loader.conf: ng_ubt_load="YES".

  • Starting Bluetooth: Use the command service bluetooth start ubt0 to start the Bluetooth stack.


  • Stopping Bluetooth: Use the command service bluetooth stop ubt0 to stop the Bluetooth stack.


  • Troubleshooting: If you encounter issues, check the console output and /var/log/messages for error messages related to driver loading.


  • Other Bluetooth Devices: For other Bluetooth USB dongles, the ng_ubt(4) driver is used. Serial and UART-based Bluetooth devices use ng_h4(4) and hcseriald(8).


  • Bluetooth Stack: The Bluetooth stack in FreeBSD is implemented using the Netgraph framework.


  • RFCOMM Profiles: In FreeBSD, profiles like serial port and network are implemented with ppp(8) and rfcomm_pppd(8), which converts RFCOMM Bluetooth connections into something PPP can use.


  • PPP Configuration: Before using any profile, create a new PPP label in /etc/ppp/ppp.conf.
 
Code:
marietto# pkg install iwmbt-firmware
OK

marietto# service hcsecd onestart
Starting hcsecd.

marietto# service devd restart
OK
  
marietto# service bluetooth start ng_ubt
/etc/rc.d/bluetooth: ERROR: Unsupported device: ng_ubt

marietto# service bluetooth start ng_ubt0
/etc/rc.d/bluetooth: ERROR: Unsupported device: ng_ubt0

marietto# service bluetooth start ubtbcmfw
/etc/rc.d/bluetooth: ERROR: Unable to get ubt unit number: ubtbcmfw

marietto# service bluetooth start ubt0
/etc/rc.d/bluetooth: ERROR: Unable to setup Bluetooth stack for device ubt0

marietto# service bluetooth start ubt0
/etc/rc.d/bluetooth: ERROR: Unable to setup Bluetooth stack for device ubt0

marietto# service bluetooth start ubt0
OK

marietto# service bluetooth start iwmbt
/etc/rc.d/bluetooth: ERROR: Unsupported device: iwmbt

marietto# dmesg
ng_hci_process_command_timeout: ubt0hci - unable to complete HCI command OGF=0x3, OCF=0x3. Timeout
 
Code:
nano /etc/rc.conf :

kld_list="i915kms linux linux64 ext2fs ng_hci"
blued_enable="YES"
sdpd_enable="YES"
devd_enable="YES"
moused_enable="YES"
bluetooth_enable="YES"

nano /boot/loader.conf :

netgraph_load="YES"
ng_ubt_load="YES"
vkbd_load="YES"

marietto# kldstat

Id Refs Address                Size Name
 1  154 0xffffffff80200000  1f3c6c0 kernel
 2    1 0xffffffff8213e000     97f8 nullfs.ko
 3    1 0xffffffff82148000   5da658 zfs.ko
 4    7 0xffffffff82723000    16cc0 netgraph.ko
 5    1 0xffffffff8273a000    117f8 linprocfs.ko
 6    5 0xffffffff8274c000    20230 linux_common.ko
 7    2 0xffffffff8276d000     8978 bridgestp.ko
 9    1 0xffffffff8278c000     ade0 vkbd.ko
10    1 0xffffffff82797000    274a8 fusefs.ko
11    1 0xffffffff827bf000     5f08 fdescfs.ko
12    1 0xffffffff827c5000     4650 utouch.ko
13    1 0xffffffff827ca000     a2e0 ng_ubt.ko
14    3 0xffffffff827d5000    14018 ng_hci.ko
15    5 0xffffffff827ea000     4318 ng_bluetooth.ko
16    1 0xffffffff827ef000     3988 nmdm.ko
17    1 0xffffffff827f3000     96c8 linsysfs.ko
18    1 0xffffffff827fd000     77d8 cryptodev.ko
19    1 0xffffffff82805000     9438 acpi_video.ko
20    1 0xffffffff8280f000     eaa0 if_bridge.ko
21    1 0xffffffff83310000   1e61e9 i915kms.ko
22    2 0xffffffff834f7000    8605a drm.ko
23    1 0xffffffff8357e000     22b8 iic.ko
24    2 0xffffffff83581000     4120 linuxkpi_video.ko
25    3 0xffffffff83586000     7320 dmabuf.ko
26    3 0xffffffff8358e000     3378 lindebugfs.ko
27    1 0xffffffff83592000     d310 ttm.ko
28    1 0xffffffff835a0000    30a80 linux.ko
29    1 0xffffffff835d1000    2de10 linux64.ko
30    1 0xffffffff835ff000    1aec0 ext2fs.ko
31    1 0xffffffff8361a000     3390 acpi_wmi.ko
32    1 0xffffffff8361e000     4250 ichsmb.ko
33    1 0xffffffff83623000     2178 smbus.ko
34    1 0xffffffff83626000     2110 pchtherm.ko
35    1 0xffffffff83629000     3360 uhid.ko
36    1 0xffffffff8362d000     4364 ums.ko
37    1 0xffffffff83632000     e5b0 snd_uaudio.ko
38    1 0xffffffff83641000     3360 wmt.ko
39    1 0xffffffff83645000     3480 if_axge.ko
40    1 0xffffffff83649000     3190 uether.ko
41    1 0xffffffff8364d000     e268 ng_l2cap.ko
42    1 0xffffffff8365c000    1bf68 ng_btsocket.ko
43    1 0xffffffff83678000     38f8 ng_socket.ko
44    1 0xffffffff8367c000    4f538 pf.ko
45    1 0xffffffff836cc000     2a68 mac_ntpd.ko
46    1 0xffffffff836cf000     b0b0 tmpfs.ko

marietto# service bluetooth start ubt0
OK

marietto# hccontrol -n ubt0hci inquiry
Inquiry complete. Status: No error [00]

marietto# dmesg
ng_hci_process_command_timeout: ubt0hci - unable to complete HCI command OGF=0x3, OCF=0x3. Timeout

marietto# usbconfig
ugen1.5: <BCM2210 Bluetooth Broadcom Corp.> at usbus1, cfg=0 md=HOST spd=FULL (12Mbps) pwr=ON (100mA)
 
Back
Top