Skip to content

Sample project to echo sound on bluetooth HSP/HFP device with direct bluetooth connection.

License

Notifications You must be signed in to change notification settings

Nikolay-Kha/BluetoothAudio

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Description

This project shows how to capture and play audio with bluetooth HSP/HFP device without pulseaudio or any other sound sy1stem, i.e. directly via bluetooth. It initialise bluetooth audio device and playback microphone data back in loop. HSP/HFP profile actually is a two connections via Bluetooth, service and audio. Service is a bluetooth RFCOMM connection which operates with AT commands. Audio connection is a bluetooth SCO connection.

Hardware

Please note that not all bluetooth adapters support HSP/HFP. For example, BCM20702 does support A2DP pefrectly, but there is no sound with HSP/HFP.
Upd: BCM20702 need proprietary firmware on Linux - http://plugable.com/2014/06/23/plugable-usb-bluetooth-adapter-solving-hfphsp-profile-issues-on-linux/
This project was tested with CSR bluetooth 4.0 USB dongle.

Usage

Turn your headset/handsfree device into advertisement mode. Run ./bluetooth_audio.py scan and wait for scan results which would be like:

[('00:12:34:56:78:F5', 'SBH-100'), ('12:33:44:55:66:4A', 'ABRC-100')]

find you device MAC address in this list. You need to do it just once. Having MAC, just run ./bluetooth_audio.py 00:12:34:56:78:F5 to run loopback sound in your device.
Also it's totally possible to import bluetooth_audio.py into your project and use BluetoothAudio class.

Specs

HFP v1.7 specs https://www.bluetooth.org/docman/handlers/downloaddoc.ashx?doc_id=292287
AT command specs http://www.3gpp.org/ftp/Specs/archive/07_series/07.07/0707-780.zip

Dependencies

sudo apt install libbluetooth-dev gcc python3-dev python3-pip
sudo pip3 install pybluez

About

Sample project to echo sound on bluetooth HSP/HFP device with direct bluetooth connection.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages