Differences between revisions 66 and 68 (spanning 2 versions)
Revision 66 as of 2019-09-15 12:14:53
Size: 12575
Editor: nodiscc
Comment: formatting
Revision 68 as of 2019-09-28 15:06:30
Size: 12281
Editor: nodiscc
Comment: formatting
Deletions are marked like this. Additions are marked like this.
Line 11: Line 11:
Line 12: Line 13:
Line 23: Line 25:
Line 24: Line 27:
Line 34: Line 38:

If you're using SysV-style init scripts:

# /etc/init.d/bluetooth status
# service bluetooth status
Line 43: Line 44:
# /etc/init.d/bluetooth start

If you're using systemd:

$ systemctl status bluetooth
● bluetooth.service - Bluetooth service
   Loaded: loaded (/lib/systemd/system/bluetooth.service; enabled)
   Active: active (running) since Fri 2015-01-16 21:25:19 JST; 1 day 16h ago

$ sudo systemctl start bluetooth
# service bluetooth start
Line 68: Line 57:
Line 101: Line 91:
Line 102: Line 93:
Line 105: Line 97:
Line 124: Line 117:
Line 125: Line 119:
Line 137: Line 132:
Line 180: Line 176:
sudo /etc/init.d/bluetooth restart sudo service bluetooth restart
Line 187: Line 183:
Line 203: Line 200:
Line 220: Line 218:
# /etc/init.d/bluetooth restart # service bluetooth restart
Line 229: Line 227:
Line 230: Line 229:
Line 239: Line 239:
Line 260: Line 261:
Line 287: Line 289:
Line 309: Line 312:
Line 313: Line 317:
Line 314: Line 319:
Line 320: Line 326:
Line 321: Line 328:
 * WikiPedia:Bluetooth
* [[WikiPedia:Bluetooth|Bluetooth- Wikipedia]]

Translation(s): English - Français - Italiano - 日本語 (Nihongo)

Using Bluetooth in a Debian system

Note: This page describes Debian Bluetooth information for end users. For developer information see the Bluetooth page.


We assume you have a Bluetooth adapter in your computer and a Bluetooth device (such as a mobile phone or PDA). This documents describes what you need to do to use Bluetooth to communicate with other Bluetooth devices.

The steps described below are required before you can use the services Bluetooth offers. Once you have setup Bluetooth, you can for example

  • exchange data with devices, such as sending music or videos to/from your phone
  • use a mobile phone to give your computer mobile internet access
  • use Bluetooth peripherals with your computer, such as a Bluetooth wireless mouse

See the links below for details.


Install Bluetooth support (package bluetooth) :

aptitude install bluetooth

Read /usr/share/doc/bluez/README.Debian.gz to get some understanding of what's going on.

Make sure the Bluetooth daemon is running. If it's not running, start it.

# service bluetooth status
bluetooth is running

# service bluetooth start


For security reasons, Bluetooth devices will only talk to each other if they have been "introduced" first (a bit like in real life :-)). This is referred to as Pairing.

Note that pairing is usually only required the first time two devices interact. Afterwards, they will remember each other, and no exchange of PINs is necessary. This will however depend on the devices involved (on some devices this may be configurable).

To pair devices, you need a passkey-agent. Options are:

Pairing using a GUI tool

Install one of the following packages:

Log out of your desktop session and log back in - this is required for the pairing pop-up in the next step to appear correctly.

On your Bluetooth device you can now try to pair. On the device you need to choose something like the "setup", "connect" or "Bluetooth" menu and then search for Bluetooth devices. You should find your Debian system, called something like debian-0, where debian is the hostname of your Debian system. On your device, select the Debian system. The device will then ask for a PIN, you can make one up, (choose four digits, say 2309 ).

On your computer you will get a pop-up information balloon asking for the PIN, something like Pairing request from Phone (xx:xx:xx:xx:xx:xx) where Phone is the name of your phone and xx:xx:xx:xx:xx:xx is its MAC address.

Click on the information balloon.

Another window will pop-up. It asks for the PIN, enter the one you just made up. (e.g. 2309 ) and press [Enter].

Your phone sees that the PIN matches and shows it on its display.

Both devices are now paired.

Pairing using CLI

If you do not want to or cannot use Gnome or KDE, you can also use bluetooth-agent or bluetoothctl for the pairing.

Using bluetooth-agent

Bluetooth-agent is part of package bluez. So, if you use Debian testing or unstable, it should already be installed.

Just start bluetooth-agent (as root), giving an arbitrary PIN, such as 4835:

# bluetooth-agent 4835

Then, as described above, choose something like the "setup", "connect" or "Bluetooth" menu on the device to be paired, and search for Bluetooth devices. Select your computer once found; the device should prompt you for a PIN. Now enter the PIN you gave to bluetooth-agent, and pairing is completed.

Note: Instead of initiating the pairing process from the phone, you can also initiate it from the computer. Start bluetoogh-agent as explained above, then run a command that will try to connect to the phone, e.g.

rfcomm connect hci0 <phone address>

where <phone address> is your phone's bluetooth address, as shown by hcitool scan (note that this will only work if the phone is discoverable, though the computer need not be). This will force a connection from computer to phone, which should cause the phone to ask you to confirm the connection attempt by prompting for a PIN. Enter the pin you used with bluetooth-agent.

Using bluetoothctl

If bluetooth-agent is not available, try bluetoothctl:

Start the bluetoothctl interactive command. Enter "help" to get a list of available commands.

  • Turn the power to the controller on by entering "power on". It is off by default.
  • Enter "devices" to get the MAC Address of the device with which to pair.
  • Enter device discovery mode with "scan on" command if device is not yet on the list.
  • Turn the agent on with "agent on".
  • Enter "pair MAC Address" to do the pairing (tab completion works).

  • If using a device without a PIN, one may need to manually trust the device before it can reconnect successfully. Enter "trust MAC Address" to do so.

  • Finally, use "connect MAC address" to establish a connection.


General pairing issues

In order for the pairing to work as described above, your computer's bluetooth interfaces must be discoverable. A bluetooth dongle may start off in hidden mode (bug report here)

To fix this you can run:

# dbus-send --system --dest=org.bluez /org/bluez/hci0 org.bluez.Adapter.SetMode string:discoverable

Or using hciconfig:

# hciconfig hci0 piscan

Then hciconfig should show the flags ISCAN PSCAN, indicating bluetooth is discoverable (i.e. can be scanned). After you finished pairing, it's best to make your computer hidden again:

# dbus-send --system --dest=org.bluez /org/bluez/hci0 org.bluez.Adapter.SetMode string:off

Or using hciconfig:

# hciconfig hci0 noscan

Helpful Commands

Display your Bluetooth device (for proof that it was installed properly)

hcitool dev

Search for remote Bluetooth devices

hcitool scan

Restart the Bluetooth services

sudo service bluetooth restart

Force connection to device

sudo hidd --connect <BT_Address>

Helpful Configuration Files

/etc/default/bluetooth - Default HID bluez setting - enable for mice and keyboards


/etc/bluetooth/hcid.conf - HCI bluez settings - configure static device information

device 00:1E:52:FB:68:55 {
    name "Apple Wireless Keyboard";
    auth enable;
    encrypt enable;}

KDE Issues

Since the PIN should be implemented on a user level, we need to make some changes to /etc/bluetooth/hcid.conf

comment out the line

passkey "2309";

and add the following line directly below it (Note: kdebluetooth includes the program kbluepin):

# passkey "2309";
pin_helper /usr/bin/bluez-pin;

KDE also expects a file /etc/bluetooth/link_key to be present.

# touch /etc/bluetooth/link_key
# chmod 644 /etc/bluetooth/link_key
# service bluetooth restart

In KDE, run kbluetoothd. Click on the Bluetooth icon in the system tray, this loads Konqueror with the Bluetooth:// URL. You should be able to see your device and do some simple file transfers by clicking on the device and choosing the proper transfer protocol.

Scanning for the PC from your device should bring up a window in KDE that asks you for a PIN. Now you can send files to your PC (KDE should bring up a program to handle this).

GNOME topics

In DebianWheezy with GnomeShell the settings for Bluetooth can be found at

  • System Settings > Bluetooth: Lists paired devices, allows sending of data

  • in Nautilus in the ~/public folder: When opening this folder, you find a notification bar to define the sharing of data. This includes the sharing via WebDAV, but also via Bluetooth. Furthermore, one can enable receiving files via Bluetooth. These files are stored in ~/downloads.

  • in order to be able to receive files from a paired device enable the following options in "Personal File Sharing Preferences" (/usr/bin/gnome-file-share-properties):
    • Receive Files over Bluetooth / Receive files in Downloads folder over Bluetooth
    • Receive Files over Bluetooth / Notify about received files


Impossible to connect to HSP/HFP

The version 3.6 of Bluez is buggy, and cannot switch from A2DP to HSP/HFP. This protocole allows the user to use microphone (but the sound has a lower quality). You can see /var/log/syslog:

[pulseaudio] module-bluez5-device.c: Refused to switch profile to headset_head_unit: Not connected

To solve this problem, you should downgrade into Bluez 3.5 or update it. Here is an example to install the version which stands in the experimental repo (3.40 when I write this article). First add in /etc/apt/sources.list the line

deb http://httpredir.debian.org/debian experimental main

and then run

sudo apt-get update && sudo apt-get -t experimental install bluez 

After a restart of pulseaudio or a reboot, you should be able to use HSP/HFP.

Can't reconnect after sleep

You may notice that you can't automatically reconnect to a device after it goes to sleep. You would for example notice the following errors in your logs:

bluetoothd[487]: Authentication attempt without agent
bluetoothd[487]: Access denied: org.bluez.Error.Rejected

This could be because the device is not marked as "trusted". To fix this, try the following command in a bluetoothctl shell:

trust 00:1D:43:6D:03:26

... where 00:1D:43:6D:03:26 is the device identifier for the speaker.

You may also want to have Pulseaudio automatically connect to the newly discovered output, by adding this to ~/.config/pulse/default.pa:

# automatically switch to newly-connected devices
load-module module-switch-on-connect

Note: this fix was found in the Arch Linux wiki.

Can connect, but not to audio

If you get this error:

Connection Failed: blueman.bluez.errors.DBusFailedError: Protocol Not available

It is because the Pulseaudio backend cannot talk with Bluetooth because of a missing package. Install the package:

sudo apt-get install pulseaudio-module-bluetooth

... then make sure the module is loaded:

pactl load-module module-bluetooth-discover

Once that is done, delete the Bluetooth device from your configuration and pair it again.

Quality / A2DP issues

See BluetoothUser/a2dp for more information.

See also

CategoryHardware CategoryModem