# Debug Bluetooth issues

To debug Bluetooth issues, use host logs or over-the-air (OTA) logs. Host logs include Logcat and BTSnoop (stack)/HCI logs. You can use these logs for initial debugging.

The following table lists the logs required to debug different Bluetooth issues.

| Issue type | Logcat | BTSnoop/HCI | Kernel logs | OTA | PulseAudio | Subsystem restart (SSR) logs |
| --- | --- | --- | --- | --- | --- | --- |
| General | Required | Required | Not required | Recommended | Not required | Not required |
| Bluetooth controller | Not required | Recommended | Not required | Required | Not required | Required |
| Bluetooth on/off | Required | Not required | Not required | Not required | Not required | Required |
| Crash | Required | Not required | Required | Not required | Not required | Required |
| Audio | Not required | Required | Not required | Required | Required | Not required |

## Debug BlueZ stack

Before you enable or collect logs, do the following:

1. Enable SSH to access your host device. For instructions, see [Sign in using SSH](https://docs.qualcomm.com/bundle/publicresource/topics/80-70023-254/how_to.html#use-ssh).
2. Place the DUT and the remote device in the Bluetooth vicinity.
3. Run the SSH in command prompt using the following command:

ssh root@<device_IP_address>
        Copy to clipboard

    **Example**

    If the IP address of the device is `10.92.160.222`, run the following command:

ssh root@10.92.160.222
        Copy to clipboard
4. Connect to the SSH by entering the following password:

oelinux123
        Copy to clipboard

### Enable BlueZ logs

To enable BlueZ logs, do the following in SSH:

1. Enable read and write permissions by running the following command:

mount -o remount rw /
        Copy to clipboard
2. Open the Bluetooth service file in a text editor.

    **Example**

    To open the `bluetooth.service` file in a VI editor, run the following command:

vi /lib/systemd/system/bluetooth.service
        Copy to clipboard
3. Append `-d` option to the following line in the file:

ExecStart=/usr/libexec/bluetooth/bluetoothd -d
        Copy to clipboard
4. Save the file.
5. Reload the Bluetooth daemon by running the following command:

systemctl daemon-reload
        Copy to clipboard
6. Restart Bluetooth by running the following command:

systemctl restart bluetooth
        Copy to clipboard

### Collect BlueZ logs

- To collect BlueZ user space logs, run the following command in SSH:

journalctl -f -u bluetooth.service > /var/log/bluetooth.log
        Copy to clipboard
- To collect all logs, run the following command in SSH:

journalctl -f > /var/log/full.log
        Copy to clipboard

### Collect snoop logs

To collect snoop logs, do the following in SSH:

1. Run the `hcidump` tool.
2. Save the file by running the following command:

hcidump --save-dump=<filename.log>
        Copy to clipboard

    **Example**

    To save the snoop logs to `snoop.log` file, run the following command:

hcidump --save-dump=/var/log/snoop.log
        Copy to clipboard

### Enable PulseAudio logs

To enable PulseAudio logs, do the following in SSH:

1. Verify the status of PulseAudio by running the following command:

systemctl status pulseaudio
        Copy to clipboard

    **Sample output**

sh-5.1# systemctl status pulseaudio
        * pulseaudio.service - PulseAudio Sound Service
           Loaded: loaded (/lib/systemd/system/pulseaudio.service; enabled; vendor preset: enabled)
           Active: active (running) since Sun 1980-01-06 00:00:10 UTC; 27min ago
           Main PID: 1607 (pulseaudio)
           Tasks: 14 (limit: 6234)
           Memory: 19.8M
           CGroup: /system.slice/pulseaudio.service
                    '- 1607 /usr/bin/pulseaudio -- system -- daemonize=no -v
        
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: session_close: 1376 exit, ret e
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: freeFrontEndIds: 7243: stream ty .. .110
        Jan 06 00:80:11 qcm6490 pulseaudio[1607]: close: 514: Enter. deviceCount 1 ... ER)
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: Reset path: speaker-vbat
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: close: 528: Exit. deviceCount e ... s 0
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: GetConcurrencyInfo: 5471: stream ... wed
        Jan 06 00:80:11 qcm6490 pulseaudio[1607]: GetConcurrencyInfo: 5471: stream ... wed
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: GetConcurrencyInfo: 5471: stream ... wed
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: deregisterStream: 3690: stream type 1
        Jan 06 00:00:11 qcm6490 pulseaudio[1607]: pal_stream_close: 306: Exit. status 0
        Hint: Some lines were ellipsized, use -l to show in full.
        sh-5.1#
        Copy to clipboard
2. Open the PulseAudio service file in a text editor.

    **Example**

    To open the `pulseaudio.service` file in a VI editor, run the following command:

vi /lib/systemd/system/pulseaudio.service
        Copy to clipboard
3. Append `-vvvv` option to the following line in the file:

/usr/bin/pulseaudio --system --daemonize=no -vvvv
        Copy to clipboard
4. Save the file.
5. Reload the Bluetooth daemon by running the following command:

systemctl daemon-reload
        Copy to clipboard
6. Restart PulseAudio by running the following command:

systemctl restart pulseaudio
        Copy to clipboard

### Enable logs of ofono service

To enable logs of ofono service, do the following in SSH:

1. Verify the status of the ofono service by running the following command:

systemctl status ofono
        Copy to clipboard

    **Sample output**

sh-5.1# systemctl status ofono
        * ofono.service - Telephony service
           Loaded: loaded (/lib/systemd/system/ofono.service; enabled; vendor preset: enabled)
           Active: active (running) since Sun 1980-01-06 00:00:00 UTC; 30min ago
           Main PID: 990 (ofonod)
           Tasks: 1 (limit: 6234)
           Memory: 3.8M
           CGroup: /system.slice/ofono.service
                    `- 990 /usr/sbin/ofonod -n
        
        Jan 06 00:00:00 qcm6490 systemd[1]: Started Telephony service.
        sh-5.1# |
        Copy to clipboard
2. Open the ofono service file in a text editor.

    **Example**

    To open the `ofono.service` file in a VI editor, run the following command:

vi /lib/systemd/system/ofono.service
        Copy to clipboard
3. Append `-d` option to the following line in the file:

ExecStart=/usr/sbin/ofonod -n -d
        Copy to clipboard
4. Save the file.
5. Reload the Bluetooth daemon by running the following command:

systemctl daemon-reload
        Copy to clipboard
6. Restart ofono service by running the following command:

systemctl restart ofono
        Copy to clipboard
7. Validate the status of the service to verify if it’s running with the specified flags.

### Collect SSR dump logs

In Qualcomm Linux software, if any Bluetooth subsystem module crashes, the SSR functionality collects the required firmware crash dumps in the Bluetooth driver. It then restarts the Bluetooth subsystem. The crash dump file is at the `/var/spool/crash/` directory.

Consider the following points about SSR logging:

- To verify if SSR logs are enabled or disabled, run the following command:

cat /sys/class/devcoredump/disabled
        Copy to clipboard

    Return:

    - `1`: SSR logging is disabled.
    - `0`: SSR logging is enabled.
- To enable SSR logs, run the following command:

echo 0 > /sys/class/devcoredump/disabled
        Copy to clipboard
- To collect SSR logs manually, do the following:

Note

To collect the SSR crash dump manually, ensure that the device Bluetooth is on.

    1. Run the `hcitool` tool.
    2. Send the crash command to the controller by running the following command:

hcitool cmd 0x3f 0c 26
            Copy to clipboard

        **Sample output**

hcitool cmd 0x3f 0c 26
            < HCI Command: ogf 0x3f, ocf 0x000c, plen 1
               26
            > HCI Event: 0xff plen 246
               01 09 A5 7A 01 02 84 BD 4C 00 00 00 00 7C 0C 01 10 0C 8B 00
               00 00 02 00 61 0C 8B 00 00 0C FC 00 00 AC 08 02 00 B8 04 02
               00 08 08 08 08 09 09 09 09 10 10 10 10 11 11 11 11 04 00 00
               00 80 FF 06 00 CC DE 06 00 67 0C 01 10 4A 0F 01 10 00 00 00
               00 02 00 00 00 A0 E8 DE 06 00 0C 8B 00 00 0C FC 00 00 AC 08
               02 00 84 16 02 00 3F 42 01 10 04 00 00 00 06 00 00 00 0C 8B
               00 00 0C FC 00 00 3F 00 00 00 BD AE 02 00 04 00 00 00 FF FF
               00 00 0C 8B 00 00 0C FC 00 00 3F 00 00 00 B1 BB 0D 10 90 FD
               01 00 90 2B 01 00 10 36 01 00 4C 09 02 00 90 FD 01 00 15 C6
               0D 10 90 2B 01 00 49 E2 02 10 00 00 00 00 00 00 00 10 35 D5
               A5 2D 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02
               02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02 02
               02 02 02 02 02 02
            Copy to clipboard

        The crash triggered generates a BIN file at the `/var/spool/crash/` directory.

        **Sample output**

ls -l /var/spool/crash/
            total 904
            -r--------. 1 root root 458888 Jan  1 00:53 hci0_1970-01-01_00-53-36.bin
            -r--------. 1 root root 458888 Jan  1 00:58 hci0_1970-01-01_00-58-18.bin
            Copy to clipboard
    3. Ensure that the BIN file is generated at the `/var/spool/crash/` directory.

Note

- Only the advanced build version supports the SSR feature.
- If you observe any timeout or Bluetooth hardware error, contact Qualcomm and share the BIN file.

Last Published: Dec 15, 2025

[Previous Topic
Perform Bluetooth MAP client functions](https://docs.qualcomm.com/bundle/publicresource/80-70023-13/topics/bluez-perform-bluetooth-map-client-functions.md) [Next Topic
References](https://docs.qualcomm.com/bundle/publicresource/80-70023-13/topics/references_acronyms.md)