Bluetooth Driver

  • In this section, you are going to learn

  • Bluetooth driver

Term

Expansion

Explanation

BT

Bluetooth

Short-range wireless technology standard that is used for exchanging data between devices over short distances

BLE

Bluetooth Low Energy

Designed to be a version of Bluetooth with a lower energy consumption rate

DSP

Digital Signal Processors

Take real-world signals like voice, audio, video, temperature, pressure, or position that have been digitized and then mathematically manipulate them

HCI

Host Controller Interface

Thin layer which transports commands and events between the host and controller elements of the Bluetooth protocol stack

OSS

Open Sound System

Interface for making and capturing sound in Unix and Unix-like operating systems

USB

Universal Serial Bus

Industry standard that allows data exchange and delivery of power between many types of electronics

HDA

High Definition Audio

Audio files with greater than 44.1 kHz sample rate or higher than 16-bit audio bit depth

PCM

Pulse-Code Modulation

Method for converting analog audio into digital audio

#

Version

Freebsd

14.1.0

Diagram
Diagram

Kernel Modules

Description

ng_ubt.ko

Driver for Bluetooth USB devices

netgraph.ko

Netgraph control utility. It creates a new netgraph node of type socket which can be used to issue netgraph commands

ng_hci.ko

Bluetooth Host Controller Interface (HCI) layer

ng_bluetooth.ko

Placeholder for global Bluetooth variables

ng_btsocket.ko

Bluetooth sockets layer

ng_l2cap.ko

Bluetooth Logical Link Control and Adaptation Protocol (L2CAP)

usb.ko

Interfaces for directly managing a usb device

xhci.ko

USB extensible Host Controller driver

sound.ko

FreeBSD PCM audio device infrastructure

cuse.ko

Userland character device driver

Library Modules

Description

libnetgraph.so.4

Library for supporting user-mode programs that wish to interact with the netgraph system

libedit.so.8

Provides command line editing functionality

libthr.so.3

POSIX threads library

libc.so.7

Standard C libraries

libbluetooth.so.4

Bluetooth User Library

libnv.so.1

Name/value pairs library

libsdp.so.4

Bluetooth Service Discovery Protocol User Library

libfftw3.so.3

 Library designed to compute discrete Fourier transforms

libm.so.5

The math library

libsamplerate.so.0

Sample Rate Converter for audio.

libcuse.so.1

Userland character device library

Commands

Description

ngctl

Netgraph control utility. It creates a new netgraph node of type socket which can be used to issue netgraph commands

hcsecd

Daemon that controls link keys and PIN codes for Bluetooth devices

hccontrol

Bluetooth HCI configuration utility

usbconfig

Utility to configure and dump information about the USB subsystem

virtual_oss

Audio mixing application that multiplexes and demultiplexes a single OSS device into multiple customizable OSS compatible devices using character devices from userspace

snd_hda

Intel High Definition Audio bridge device driver

Laptop OS:

FreeBSD 14.1-Release

Bluetooth chipset:

Intel Dual Band Wireless-AC 3168NGW with Bluetooth integrated

Headphones:

OnePlus Buds

Diagram

Chipset

Intel Wireless-AC 3168 Bluetooth

Vendor ID

0x8087

Product ID

0x0aa7

Interface

ubt0

Chipset

Intel XHCI root HUB

Vendor ID

0x0000

Product ID

0x0000

Interface

uhub0

Chipset

Intel Xeon E3-1200 v6/7th Gen Core Processor Host Bridge/DRAM Registers

Vendor ID

0x8086

Device ID

0x5914

Interface

hostb0

  • Bluetooth setup script

  • Netgraph control utility. It creates a new netgraph node of type socket which can be used to issue netgraph commands

Binary Name :

ngctl

Version :

ngctl.8,v 1.6

Size :

21K

Source path :

/usr/src/usr.sbin/ngctl

Binary path :

/usr/obj/usr/src/amd64.amd64/usr.sbin/ngctl/ngctl

List of c files :

  • main.c

  • mkpeer.c

  • config.c

  • connect.c

  • dot.c

  • name.c

  • show.c

  • list.c

  • msg.c

  • debug.c

  • shutdown.c

  • rmhook.c

  • status.c

  • types.c

  • write.c

NM symbol list

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8IqykoT5KqDMrKz38oKnIo4ijIIzABCZGAyxNn90joIW2YkiPOyeaWyJDCSLJKp9Bi1kLcPUMNmxIPGcKHBSPqrnasx7Amcp2hXN9DWm53gbvAS2m000=

# ldd ngctl ngctl: libnetgraph.so.4 => /usr/lib/libnetgraph.so.4 (0x3d5fc6ac000) libedit.so.8 => /lib/libedit.so.8 (0x3d5fc7c9000) libthr.so.3 => /lib/libthr.so.3 (0x3d5fd1ba000) libc.so.7 => /lib/libc.so.7 (0x3d5ff716000) libtinfow.so.9 => /lib/libtinfow.so.9 (0x3d5fe069000) [vdso] (0x3d5fc609000)

# ldd /usr/lib/libnetgraph.so.4 /usr/lib/libnetgraph.so.4: libc.so.7 => /lib/libc.so.7 (0x2167ea4d2000)

# ldd /lib/libedit.so.8 /lib/libedit.so.8: libtinfow.so.9 => /lib/libtinfow.so.9 (0x2ea4cbfeb000) libc.so.7 => /lib/libc.so.7 (0x2ea4ca0c7000)

# ldd /lib/libtinfow.so.9 /lib/libtinfow.so.9: libc.so.7 => /lib/libc.so.7 (0x1928bc8e7000)

# ldd /lib/libthr.so.3 /lib/libthr.so.3: libc.so.7 => /lib/libc.so.7 (0x33b2a4033000)

  • Daemon that controls link keys and PIN codes for Bluetooth devices

Binary Name :

hcsecd

Version :

hcsecd.8,v 1.8

Size :

21K

Source path :

/usr/src/usr.sbin/bluetooth/hcsecd

Binary path :

/usr/obj/usr/src/amd64.amd64/usr.sbin/bluetooth/hcsecd/hcsecd

List of c files :

  • hcsecd.c

NM symbol list

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8I2vEJKxHLD3LjLFGoCbCIiefJIt9po_9q2lErpFHn5IG398m1qfWAbRGBSfCpoX1K-YGcfS2j0e0

# ldd hcsecd hcsecd: libbluetooth.so.4 => /usr/lib/libbluetooth.so.4 (0x2153c55f2000) libc.so.7 => /lib/libc.so.7 (0x2153c4c0a000) [vdso] (0x2153c3641000)

# ldd /usr/lib/libbluetooth.so.4 /usr/lib/libbluetooth.so.4: libc.so.7 => /lib/libc.so.7 (0x3babfdc9a000)

  • Bluetooth HCI configuration utility

Binary Name:

hccontrol

Version

hccontrol.8,v 1.6

Size

117K

Source path

/usr/src/usr.sbin/bluetooth/hccontrol

Binary path

/usr/obj/usr/src/amd64.amd64/usr.sbin/bluetooth/hccontrol/hccontrol

List of C files:

  • send_recv.c

  • link_policy.c

  • link_control.c

  • le.c

  • host_controller_baseband.c

  • info.c

  • status.c

  • node.c

  • hccontrol.c

  • util.c

  • adv_data.c

NM symbols list:

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8I4xEpoifoi_HLD3LjLFGoCbCIiefJIt9po_9q2lErpFHnAec6IHd3fJ3LA-WMvIPdb62fj0XDIy5Q240

# ldd hccontrol hccontrol: libbluetooth.so.4 => /usr/lib/libbluetooth.so.4 (0x1b8411853000) libc.so.7 => /lib/libc.so.7 (0x1b84132b9000) [vdso] (0x1b840ffd6000)

# ldd /usr/lib/libbluetooth.so.4 /usr/lib/libbluetooth.so.4: libc.so.7 => /lib/libc.so.7 (0x78d2302d000)

  • Utility used to configure and dump information about the USB subsystem

Binary Name:

usbconfig

Size

21K

Source path

/usr/src/usr.sbin/usbconfig

Binary path

usr/sbin/usbconfig /usr/obj/usr/src/amd64.amd64/usr.sbin/usbconfig/usbconfig

List of C files:

  • usbconfig.c

  • dump.c

NM symbols list:

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuT8eBKvApizBoqpNLD3LjLFGoCbC0Whf5UVh6MjYbIt9A8B98gjLq2tAJCye8QG8AfyCufj3PE5gCMMnM0-JSqZDIm5w000=

# ldd usbconfig usbconfig: libusb.so.3 => /usr/lib/libusb.so.3 (0x18598f581000) libc.so.7 => /lib/libc.so.7 (0x185991585000) libthr.so.3 => /lib/libthr.so.3 (0x18598f8c4000) [vdso] (0x18598e801000)

# ldd /usr/lib/libusb.so.3 /usr/lib/libusb.so.3: libthr.so.3 => /lib/libthr.so.3 (0x2db61263f000) libc.so.7 => /lib/libc.so.7 (0x2db6110cf000)

# ldd /lib/libthr.so.3 /lib/libthr.so.3: libc.so.7 => /lib/libc.so.7 (0x379a82570000)

  • Audio mixing application that multiplexes and demultiplexes a single OSS device into multiple customizable OSS compatible devices using character devices from userspace

Binary Name:

virtual_oss

Size

73K

Source path

/usr/ports/audio/virtual_oss/work/virtual_oss-1.3.1

Binary path

/usr/local/sbin/virtual_oss

List of C files:

  • virtual_audio_delay.c

  • virtual_compressor.c

  • virtual_ctl.c

  • virtual_eq.c

  • virtual_format.c

  • virtual_main.c

  • virtual_mul.c

  • virtual_oss.c

  • virtual_ring.c

  • backend_oss.c

  • backend_null.c

  • backend_bt.c

  • avdtp.c

  • sbc_encode.c

  • bt_speaker.c

  • virtual_equalizer.c

  • virtual_command.c

NM symbols list:

https://www.plantuml.com/plantuml/svg/ZP913eCW44NtFOLBNMZQsAQxnfiqMB6Ge1WOxFKBjbI5qNH7yXx3dnag3KI1wSGX7Raz476NMcT9hlYJGNvBKi5hJRf1K4M05beMnonq1MszMWj3GKfWpZn7fhKchHyTFs5yUh0PDkyx_Z2QxXO0fXmljtZRmglSDJf7BvOY_SSIdjBHwwV4d7WUmYBaEX8Umi_ad_eX_XP2sIy6IlscK1Xi6tMmlfOy7kxQgMZVsF_v1W==

# ldd virtual_oss virtual_oss: libnv.so.1 => /lib/libnv.so.1 (0x197b142fc000) libbluetooth.so.4 => /usr/lib/libbluetooth.so.4 (0x197b14403000) libsdp.so.4 => /usr/lib/libsdp.so.4 (0x197b14dea000) libfftw3.so.3 => /usr/local/lib/libfftw3.so.3 (0x197b1546f000) libthr.so.3 => /lib/libthr.so.3 (0x197b1709e000) libm.so.5 => /lib/libm.so.5 (0x197b15fa3000) libsamplerate.so.0 => /usr/local/lib/libsamplerate.so.0 (0x197b181d0000) libcuse.so.1 => /usr/lib/libcuse.so.1 (0x197b160a0000) libc.so.7 => /lib/libc.so.7 (0x197b18b55000) [vdso] (0x197b12d91000)

# ldd /lib/libnv.so.1 /lib/libnv.so.1: libc.so.7 => /lib/libc.so.7 (0xbdae7d16000)

# ldd /usr/lib/libbluetooth.so.4 /usr/lib/libbluetooth.so.4: libc.so.7 => /lib/libc.so.7 (0x3ec976949000)

# ldd /usr/lib/libsdp.so.4 /usr/lib/libsdp.so.4: libc.so.7 => /lib/libc.so.7 (0x31858168d000)

# ldd /usr/local/lib/libfftw3.so.3 /usr/local/lib/libfftw3.so.3: libm.so.5 => /lib/libm.so.5 (0x2522dafbe000) libc.so.7 => /lib/libc.so.7 (0x2522da99c000)

# ldd /usr/local/lib/libsamplerate.so.0 /usr/local/lib/libsamplerate.so.0: libm.so.5 => /lib/libm.so.5 (0x27ae39c94000) libc.so.7 => /lib/libc.so.7 (0x27ae3a994000)

# ldd /usr/lib/libcuse.so.1 /usr/lib/libcuse.so.1: libthr.so.3 => /lib/libthr.so.3 (0x10ba031b9000) libc.so.7 => /lib/libc.so.7 (0x10ba010e3000)

# ldd /lib/libm.so.5 /lib/libm.so.5: libc.so.7 => /lib/libc.so.7 (0x2ad1690ce000)

# ldd /lib/libthr.so.3 /lib/libthr.so.3: libc.so.7 => /lib/libc.so.7 (0x24d65707c000)

  • Driver for Bluetooth USB devices

Size:

21K

Source path:

/usr/src/sys/netgraph/bluetooth/drivers/ubt

Module path:

usr/obj/usr/src/amd64.amd64/sys/modules/netgraph/bluetooth/ubt/ng_ubt.ko

List of C files:

  • ng_ubt.c

  • ng_ubt_intel.c

NM symbols list:

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8IuylJIhHoyxNLD3LjLFGo4ijIIzABCW0YN2Xy23osQb5UQavcbWqfiSdvPIcbkJdby0qewaeBKx2Be5i9eePQD9G0r157LBpKe0-0G0=
  • The netgraph system provides a uniform and modular system for the implementation of kernel objects which perform various networking function

Size:

57K

Source path:

/usr/src/sys/netgraph

Binary path:

/usr/obj/usr/src/amd64.amd64/sys/modules/netgraph/netgraph/netgraph.ko

List of C files:

  • ng_base.c

  • ng_parse.c

NM symbols list:

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8Ior9BqeioD3BpjTKqDMrKz38JYtAIytHv798pKi1AW40
  • Bluetooth Host Controller Interface (HCI) layer

Size :

41K

Source path :

/usr/src/sys/netgraph/bluetooth/hci

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/netgraph/bluetooth/hci/ng_hci.ko

List of C files :

  • ng_hci_main.c

  • ng_hci_cmds.c

  • ng_hci_evnt.c

  • ng_hci_ulpi.c

  • ng_hci_misc.c

NM symbols list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8Iu_FICxKoyxNLD3LjLFGo4ijIIzABCW0YM3APgSMvQNcO940yfDoIbDBylDBO5gH3CBKZA8OLTeXDIy5w3G0
  • Placeholder for global Bluetooth variables

Size :

8.5K

Source path :

/usr/src/sys/netgraph/bluetooth/common

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/netgraph/bluetooth/bluetooth/ng_bluetooth.ko

List of C files :

  • ng_bluetooth.c

NM symbols list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8IuzFoYbDBSdFBydGoyxNLD3LjLFGo4ujoalDqUHoICrB0Ie300==
  • Bluetooth sockets layer. The ng_btsocket module implements three Netgraph node types. Each type in its turn implements one protocol within PF_BLUETOOTH domain.

Binary Name :

ng_btsocket.ko

Size :

101K

Source path :

/usr/src/sys/netgraph/bluetooth/socket

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/netgraph/bluetooth/socket/ng_btsocket.ko

List of c files :

  • ng_btsocket.c

  • ng_btsocket_hci_raw.c

  • ng_btsocket_l2cap_raw.c

  • ng_btsocket_l2cap.c

  • ng_btsocket_rfcomm.c

  • ng_btsocket_sco.c

NM symbol list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8IuzFAYdEJyvEBT7BpjTKqDMrKz38Ior9Bqeio029u52IdLgKbvg3InOac5EQMfAVNm8p1Cb8B2OWAqQLTaZDIm6w500=
  • Bluetooth Logical Link Control and Adaptation Protocol (L2CAP)

Binary Name :

ng_l2cap.ko

Size :

41K

Source path :

/usr/src/sys/netgraph/bluetooth/l2cap

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/netgraph/bluetooth/l2cap/ng_l2cap.ko

List of c files :

  • ng_l2cap_main.c

  • ng_l2cap_cmds.c

  • ng_l2cap_evnt.c

  • ng_l2cap_ulpi.c

  • ng_l2cap_llpi.c

  • ng_l2cap_misc.c

NM symbol list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTB8Iu_FCKfEBD3BpjTKqDMrKz38Ior9Bqeio029O9FFJYtAIyt1AWKKISefJIt9po-1QKSo35CxYc9KQOVKl1IW0m4=
  • Interfaces for directly managing a usb device

Binary Name :

usb.ko

Size :

129K

Source path :

/usr/src/sys/dev/usb

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/usb/usb/usb.ko

List of c files :

  • usb_if.c

  • usb_busdma.c

  • usb_controller.c

  • usb_core.c

  • usb_debug.c

  • usb_dev.c

  • usb_device.c

  • usb_dynamic.c

  • usb_error.c

  • usb_generic.c

  • usb_handle_request.c

  • usb_hid.c

  • usb_hub.c

  • usb_lookup.c

  • usb_mbuf.c

  • usb_msctest.c

  • usb_parse.c

  • usb_pf.c

  • usb_process.c

  • usb_request.c

  • usb_transfer.c

  • usb_util.c

NM symbol list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuT8eBKxIoyxNLD3LjLFGo4ujoalDqUHoICrB0Se200==
  • USB extensible host controller driver

Binary Name :

xhci.ko

Size :

33K

Source path :

/usr/src/sys/dev/usb/controller

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/usb/xhci.ko

List of c files :

  • xhci_pci.c

  • xhci.c

NM symbol list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuTAeo4ZErClErrJGrRLJq2WjJW9nq8MpKuloKdE0mb1v1TsYpFIC4cGfXzIy5A2100==
  • FreeBSD PCM audio device infrastructure

  • The sound drivers may create the following device nodes:

    1. /dev/dsp%d: Audio device. The number represents the unit number of the device.

    1. /dev/dsp: Alias of /dev/dsp${hw.snd.default_unit}. Available only if hw.snd.basename_clone is set.

    1. /dev/sndstat: Current sound status, including all channels and drivers

  • sndstat : nvlist-based PCM audio device enumeration interface. The ioctl interface provided by /dev/sndstat device allows callers to enumerate PCM audio devices available for use.

Binary Name :

sound.ko

Size :

233K

Source path :

/usr/src/sys/dev/sound

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/sound/sound/sound.ko

List of c files :

  • ac97.c

  • ac97_if.c

  • ac97_patch.c

  • buffer.c

  • channel.c

  • channel_if.c

  • dsp.c

  • feeder.c

  • feeder_chain.c

  • feeder_eq.c

  • feeder_format.c

  • feeder_if.c

  • feeder_matrix.c

  • feeder_mixer.c

  • feeder_rate.c

  • feeder_volume.c

  • midi.c

  • mixer.c

  • mixer_if.c

  • mpu401.c

  • mpu_if.c

  • mpufoi_if.c

  • sequencer.c

  • sndstat.c

  • sound.c

  • synth_if.c

  • unit.c

  • vchan.c

NM symbol list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuT8epY_DIz7BpjTKqDMrKz38JYtAIytHv798pKi1oWC0
  • Intel High Definition Audio bridge device driver

Binary Name :

snd_hda.ko

Size :

145K

Source path :

/usr/src/sys/dev/sound/pci/hda

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/sound/driver/hda/snd_hda.ko

List of c files :

  • hdaa.c

  • hdaa_patches.c

  • hdac.c

  • hdac_if.c

  • hdac_if.c

  • hdacc.c

NM symbol list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuT8epak9pqX9rClErrJGrRLJq2ZEByrB0N6no6Md5kMbvcXoEQJcfG1r0m0=
  • Userland character device driver

Binary Name :

cuse.ko

Size :

41K

Source path :

/usr/src/sys/fs/cuse

Binary path :

/usr/obj/usr/src/amd64.amd64/sys/modules/cuse/cuse.ko

List of c files :

  • cuse.c

NM symbol list :

https://www.plantuml.com/plantuml/svg/SoWkIImgAStDuT98BYrErSlErrJGrRLJqCXEBSfBpT7aSaZDIm5A0m0=
test:~$ usbconfig
ugen0.1: <Intel XHCI root HUB> at usbus0, cfg=0 md=HOST spd=SUPER (5.0Gbps) pwr=SAVE (0mA)
ugen0.2: <Chicony HP Wide Vision HD Camera> at usbus0, cfg=0 md=HOST spd=HIGH (480Mbps) pwr=ON (500mA)
ugen0.3: <Wireless-AC 3168 Bluetooth Intel Corp.> at usbus0, cfg=0 md=HOST spd=FULL (12Mbps) pwr=ON (100mA)
ugen0.4: <ELAN Touchscreen> at usbus0, cfg=0 md=HOST spd=FULL (12Mbps) pwr=ON (100mA)
  • From above output we know ‘Wireless-AC 3168 Bluetooth Intel Corp’ chip and ‘Intel XHCI root HUB’ is used

test:~$ pkg install iwmbt-firmware
test:~$ service devd restart
test:~$ pkg install virtual_oss
  • Load it manually and enable loading for every boot

test:~$ kldload cuse

test:~$ sysrc kld_list+="cuse"
test:~$ service hcsecd onestart
  • If this fails, do it again

test:~$ service bluetooth start ubt0
  • If Bluetooth is started successfully, below logs should be seen in dmesg

test:~$ dmesg | grep ubt0
ubt0 on uhub0
ubt0: <vendor 0x8087 product 0x0aa7, class 224/1, rev 2.00/0.01, addr 3> on usbus0
  • Output of ngctl

test:~$ ngctl list
There are 8 total nodes:
  Name: ubt0            Type: ubt             ID: 00000001   Num hooks: 1
  Name: btsock_l2c      Type: btsock_l2c      ID: 00000002   Num hooks: 1
  Name: ubt0hci         Type: hci             ID: 00000023   Num hooks: 3
  Name: btsock_l2c_raw  Type: btsock_l2c_raw  ID: 00000003   Num hooks: 1
  Name: btsock_hci_raw  Type: btsock_hci_raw  ID: 00000004   Num hooks: 1
  Name: btsock_sco      Type: btsock_sco      ID: 00000005   Num hooks: 0
  Name: ubt0l2cap       Type: l2cap           ID: 00000027   Num hooks: 3
  Name: ngctl3789       Type: socket          ID: 0000002d   Num hooks: 0
test:~$ hccontrol -n ubt0hci inquiry
Inquiry result, num_responses=1
Inquiry result #0
        BD_ADDR: f8:9e:94:ee:99:c3
        Page Scan Rep. Mode: 0x1
        Page Scan Period Mode: 00
        Page Scan Mode: 00
        Class: 2a:01:0c
        Clock offset: 0x333b
Inquiry complete. Status: No error [00]
test:~$ hccontrol -n ubt0hci remote_name_request f8:9e:94:ee:99:c3
BD_ADDR: f8:9e:94:ee:99:c3
Name: OnePlus Buds
  • Headphones does not require a key or pin so I add nokey and 0000 as the pin

test:~$ vim /etc/bluetooth/hcsecd.conf

device {
    bdaddr  f8:9e:94:ee:99:c3;
    name    "OnePlus Buds";
    key     nokey;
    pin     "0000";
}
  • This step is optional, ‘/etc/bluetooth/hosts’ allows you to alias BD_ADDR addresses to names making it much easier to remember

test:~$ vim /etc/bluetooth/hosts

f8:9e:94:ee:99:c3 headphones
test:~$ hccontrol -n ubt0hci create_connection headphones
  • Note:  Enable “write_authentication” on the HCI node, if you observe below error

  • Error message:

test:~$ hccontrol -n ubt0hci create_connection headphones
BD_ADDR: headphones
Connection handle: 256
Encryption mode: Disabled [0]
  • Resolution:

test:~$ hccontrol -n ubt0hci write_authentication_enable 1

test:~$ hccontrol -n ubt0hci create_connection headphones
test:~$ hccontrol -n ubt0hci read_connection_list
Remote BD_ADDR    Handle Type Mode Role Encrypt Pending Queue State
headphones           256  ACL    0 MAST    NONE       0     0 OPEN
  • Meaning of the below command:

  • To expose virtual device to other apps, install entry in /dev/sndstat. (-T /dev/sndstat)

  • Enabled automatic resampling to fix bad sound quality when playing audio with a different sample-rate than default. (-S)

  • If the default volume is too high, set a negative output amplification. (-a o,-4)

  • Sample rate of 44100 Hz is chosen, you can use 48000 Hz instead if that’s better for your hardware. (-r 44100)

  • To use laptop’s internal mic simultaneously while using my headphones. ( -R /dev/dsp0). You can disable the recording device by setting “-R /dev/null” instead.

test:~$ virtual_oss -T /dev/sndstat -S -a o,-4 -C 2 -c 2 -r 44100 -b 16 -s 1024 -R /dev/dsp0 -P /dev/bluetooth/headphones -d dsp -t vdsp.ctl
  • Now we should have another DSP device listed in /dev/sndstat

test:~$ cat /dev/sndstat
Installed devices:
pcm0: <Realtek ALC257 (Analog 2.0+HP/2.0)> (play/rec) default
pcm1: <Realtek ALC257 (Right Analog Mic)> (rec)
pcm2: <Intel Kaby Lake (HDMI/DP 8ch)> (play)
Installed devices from userspace:
dsp: <Virtual OSS> (play/rec)
  • Above steps works great for programs that use OSS as sound backend. However, other backends need additional steps

test:~$  sysrc sndiod_enable=YES

test:~$ service sndiod start
  • Method-1: Configure firefox to use OSS instead of pulseaudio

  • Open up firefox and put about:config in the URL line

  • Then add the following entry

  • media.cubeb.backend: oss

  • Method-2: Redirect all OSS output into pulseaudio. It adds latency to the audio but works

test:~$ pacat --record -d oss_output.dsp0.monitor
test:~$
test:~$
  • Abstract representation of a device

  • Defined in /usr/src/stand/kshim/bsd_kernel.h

typedef struct device *device_t;

struct device {
        TAILQ_HEAD(device_list, device) dev_children;
        TAILQ_ENTRY(device) dev_link;

        struct device *dev_parent;
        const struct module_data *dev_module;
        void   *dev_sc;
        void   *dev_aux;
        driver_filter_t *dev_irq_filter;
        driver_intr_t *dev_irq_fn;
        void   *dev_irq_arg;

        uint16_t dev_unit;

        char    dev_nameunit[64];
        char    dev_desc[64];

        uint8_t dev_res_alloc:1;
        uint8_t dev_quiet:1;
        uint8_t dev_softc_set:1;
        uint8_t dev_softc_alloc:1;
        uint8_t dev_attached:1;
        uint8_t dev_fixed_class:1;
        uint8_t dev_unit_manual:1;
};
  • The device object represents a piece of hardware attached to the system.

  • Ex: expansion card, the bus which that card is plugged into, disk drives attached to the expansion card, …

  • The system defines one device, - root_bus.

  • All other devices are created dynamically during auto configuration.

  • device_probe_and_attach()

    • initialise a device

    • This function is called during autoconfiguration to initialise the devices in the system.

    • For each device, the DEVICE_PROBE method of each suitable driver is called and if a probe succeeds, a description of the device is printed and the DEVICE_ATTACH method is called

  • DEVICE_PROBE

    • probe for device existence

    • method should probe to see if the device is present.

  • DEVICE_ATTACH

    • attach a device

    • Attach a device to the system after the DEVICE_PROBE() method has been called and has indicated that the device exists

  • structure describing a device driver

  • Defined in /usr/src/stand/kshim/bsd_kernel.h

typedef struct driver driver_t;

struct driver {
        const char * name;
        const struct device_method *methods;
        uint32_t size;
};
  • Driver is registered with the system by the DRIVER_MODULE macro

  • Each driver will implement one or more sets of methods called interfaces.

  • Ex: methods from Device interface, methods from Bus interface

  • ng_ubt(BT driver/host controller) –> usb.ko(USB client driver) –> xhci.ko(USB host controller) –> pci(client driver) –> pci host controller

device_probe_and_attach()
        device_probe()
                pci_probe() // pci controller
                xhci_probe() // USB host controller
                uhub_probe() // hub connected to usb
                ubt_probe() // USB Bluetooth device
        device_attach()
                pci_attach() // pci controller
                xhci_attach() // USB host controller
                ubt_attach() // // USB Bluetooth device
                uhub_attach() // hub connected to usb
                        uhub_explore_sub()
                                usb_probe_and_attach()
test:~$
test:~$
test:~$
test:~$
test:~$
test:~$
test:~$
    1. Which codec?

    1. Which BT version?

    1. Which Freebsd version?

    1. Which BT profile is being used? HSP/HFP?

    1. Are you using AVRCP?

    1. Downloaded audio file is played? different audio file formats?

    1. File play to listening — sw modules and HW modules involved(Including BT and Audio)

    1. Are we using BLE here?

    1. Frames exchanged for device pairing, unpair? can we confirm using prints Tx/Rx in application or driver?

    1. How is Reliability achieved? similar to Ack mechanism in wifi is reliablity maintainted at Application level(VLC media player/Youtube) or at BT level?

    1. The BT driver modules, are they native to FreeBSD or ported from Linux?