Bluetooth (Русский)
Bluetooth является стандартом для беспроводных соединений малой дальности сотовых телефонов, компьютеров и других электронных устройств. В Linux канонической реализацией стека протоколов Bluetooth является BlueZ.
Установка
- Установите пакет bluez, который предоставляет стек Bluetooth протокола.
- Установите bluez-utils, предоставляющий утилиту
bluetoothctl
. В качестве альтернативы можно установить bluez-utils-compatAUR, который содержит устаревшие инструменты BlueZ. - Универсальный драйвер Bluetooth находится в модуле ядра
btusb
. Проверьте, что он загружен. Если нет, то загрузите его вручную. -
Запустите и включите службу
bluetooth.service
.
- По умолчанию демон bluetooth разрешит использовать устройства bnep0 только пользователям, входящим в группу
lp
. Удостоверьтесь, что учетная запись обычного пользователя добавлена в нее, если вы намереваетесь подключаться по bluetooth. Вы можете изменить группу, требуемую для этого, в файле/etc/dbus-1/system.d/bluetooth.conf
. - Некоторые адаптеры Bluetooth встроены в платы Wi-Fi (например, Intel Centrino). В этих случаях необходимо, чтобы сперва была включена плата Wi-Fi (обычно при помощи клавиш(и) на ноутбуке), после чего ядро сможет увидеть адаптер Bluetooth.
- Некоторые адаптеры Bluetooth (например, Broadcom) конфликтуют с сетевыми адаптерами. В этом случае вам необходимо удостовериться, что устройство Bluetooth подключается до начала загрузки сетевых служб.
- Некоторые утилиты вроде hcitool и hciconfig объявлены устаревшими и больше не поставляются в пакете bluez-utils. Так как они не получают обновления, рекомендуется избегать их использования. Если они вам всё ещё нужны, установите bluez-utils-compatAUR. Подробнее смотрите FS#53110 и the Bluez mailing list.
Фронтенды
Консольные
- bluetoothctl — Сопряжение устройств через командную строку является одним из самых простых и надежных вариантов.
echo -e "команда1\nкоманда2\n" | bluetoothctl
или bluetoothctl -- команда
.Графические
Следующие пакеты позволяют настраивать Bluetooth с помощью графического интерфейса.
-
GNOME Bluetooth — Инструмент Bluetooth в GNOME.
- gnome-bluetooth предоставляет бэкенд
- gnome-shell предоставляет апплет мониторинга статуса
-
gnome-control-center предоставляет графический интерфейс настройки, для открытия которого можно ввести Bluetooth в поиске или выполнить команду
gnome-control-center bluetooth
. - Также можно использовать команду
bluetooth-sendto
напрямую для отправки файлов на удалённое устройство. - nautilus-bluetoothAUR добавляет пункт отправки по Bluetooth в контекстное меню файлов
- Для получения файлов откройте панель настроек Bluetooth; принимать файлы можно только при открытых настройка.
- Для добавления пункта отправки файла по Bluetooth в контекстном меню Thunar смотрите инструкции here. (укажите команду
bluetooth-sendto %F
).
- Bluedevil — Инструмент Bluetooth в KDE. Если нет иконки в Dolphin и системном трее, включите её в настройках трея или добавьте виджет. Настроить Bluedevel и обнаружить устройства Bluetooth можно кликом по иконке. Интерфейс также доступен через настройки KDE.
- Blueberry — Инструмент в Linux Mint, надстройка над GNOME Bluetooth, работает во всех окружениях рабочего стола. Blueberry не поддерживает приём файлов через Obex Object Push.
- Blueman — Полнофункциональный менеджер Bluetooth.
- ObexFTP — Инструмент для обмена файлами с устройствами через OBEX.
Сопряжение
Этот раздел описывает прямую настройку bluez5 через утилиту командной строки bluetoothctl. Это необязательно, если вы используете какой-нибудь другой инструмент (например, GNOME Bluetooth).
Точная процедура зависит от особенностей конкретного устройства; эта инструкция описывает сопряжение с устройством при помощи /usr/bin/bluetoothctl
лишь в общих чертах.
Запустите интерактивную команду bluetoothctl
. После этого можно ввести help
для получения списка доступных команд.
- (необязательно) Выберите контроллер по умолчанию командой
select MAC-адрес
. - Включите питание контроллера, введя
power on
. По умолчанию оно отключено и отключается при каждой перезагрузке; смотрите #Автоматическое включение после загрузки. - Введите
devices
, чтобы увидеть MAC-адрес устройства для сопряжения. - Войдите в режим обнаружения устройств при помощи команды
scan on
, если нужного вам устройства нет в списке. - Включите агент при помощи
agent on
или выберите конкретный агент: если вы введётеagent
и дважды нажмёте Tab, будет отображён список доступных вариантов. Агент Bluetooth управляет кодом сопряжения.default-agent
должен подойти в большинстве случаев. [1] - Введите
pair MAC-адрес
, чтобы осуществить сопряжение (работает автодополнение по tab). - При использовании устройства без PIN, возможно, потребуется подтверждение, прежде чем оно сможет успешно переподключиться. Для этого введите
trust MAC-адрес
. - Наконец, используйте
connect MAC-адрес
для установки соединения.
Ваша сессия будет выглядеть примерно так:
# bluetoothctl [NEW] Controller 00:10:20:30:40:50 pi [default] [bluetooth]# agent KeyboardOnly Agent registered [bluetooth]# default-agent Default agent request successful [bluetooth]# scan on Discovery started [CHG] Controller 00:10:20:30:40:50 Discovering: yes [NEW] Device 00:12:34:56:78:90 myLino [CHG] Device 00:12:34:56:78:90 LegacyPairing: yes [bluetooth]# pair 00:12:34:56:78:90 Attempting to pair with 00:12:34:56:78:90 [CHG] Device 00:12:34:56:78:90 Connected: yes [CHG] Device 00:12:34:56:78:90 Connected: no [CHG] Device 00:12:34:56:78:90 Connected: yes Request PIN code [agent] Enter PIN code: 1234 [CHG] Device 00:12:34:56:78:90 Paired: yes Pairing successful [CHG] Device 00:12:34:56:78:90 Connected: no
Сопряжение при Dual boot
Чтобы сопряжение работало во всех установленных операционных системах, необходимо изменить ключи сопряжения так, чтобы они были одинаковыми во всех системах.
Установка
Чтобы следать это, сперва сделайте сопряжение в вашем Arch Linux. Потом перезагрузитесь в другую ОС и сделайте сопряжение там. Теперь нужно извлечь ключи сопряжения, но сперва отключите Bluetooth-устройства, чтобы не было ненужных попыток подключения до завершения настройки.
Для Windows
Извлечение ключей в Windows
Запись реестра, содержащая ключи, доступна только пользователю SYSTEM, в которого нельзя выполнить вход. Поэтому понадобится утилита PsExec с официального сайта Windows Sysinternals для запуска regedit.exe
от имени SYSTEM
.
Скачайте архив PsTools и извлеките из него файл PsExec64.exe
.
Запустите командную строку от имени администратора, перейдите в папку с извлечённым exe-файлом и запустите редактор реестра:
.\PsExec64.exe -s -i regedit.exe
Откройте эту ветку реестра:
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\BTHPORT\Parameters\Keys
В ней содержатся подветки для каждого Bluetooth-адаптера по их MAC-адресам. Если их несколько и вы не знаете, какой из них вам нужен, смотрите эту инструкцию для выяснения MAC-адреса нужного вам Bluetooth-адаптера.
В ветках каждого адаптера лежат записи для каждого сопряжённого устройства аналогично по MAC-адресам с ключами в бинарном виде.
Для каждого устройства, которое вы хотите сделать доступным во всех ОС, нажмите правой кнопкой мыши на соответствующий ключ в реестре и экспортируйте его в .reg. Как вариант, можно скопировать hex-значение.
Если есть записи LTK
, ERand
и EDIV
, значит это Bluetooth 5.1 устройство и эти записи тоже нужно экспортировать.
Извлечение ключей в Linux
Перезагрузитесь в Arch. Установите chntpw. Примонтируйте ваш Windows-раздел.
$ cd /путь/к/windows/диску/Windows/System32/config $ chntpw -e SYSTEM
В окружении chntpw
выполните
> cd CurrentControlSet\Services\BTHPORT\Parameters\Keys
Затем узнайте MAC-адрес вашего Bluetooth-адаптера и перейдите в соответствующую папку
> ls > cd mac-адрес
Сделайте то же самое с сопряжёнными устройствами:
> ls
Node has 0 subkeys and 1 values size type value name [value if type DWORD] 16 REG_BINARY <123456789876>
Теперь можно получить ключ устройства через hex
:
> hex 123456789876
:00000 XX XX XX XX XX XX XX XX XX XX XX XX XX XX XX XX (всякие другие символы)
«XX»ы и являются ключом сопряжения. Запомните, какие ключи каким MAC-адресам соответствуют.
В случае BT5.1 вы можете увидеть такой вывод:
Node has 0 subkeys and 8 values size type value name [value if type DWORD] 16 3 REG_BINARY <LTK> 4 4 REG_DWORD <KeyLength> 16 [0x10] 8 b REG_QWORD <ERand> 4 4 REG_DWORD <EDIV> 37520 [0x9290] 16 3 REG_BINARY <IRK> 8 b REG_QWORD <Address> 4 4 REG_DWORD <AddressType> 1 [0x1] 4 4 REG_DWORD <AuthReq> 45 [0x2d]
Здесь нужно сохранить LTK
, ERand
и EDIV
.
Подготовка ключей Bluetooth 5.1
Если в реестре для нужного устройства были ключи LTK
, ERand
и EDIV
, они должны быть сконвертированы для использования в Linux. LTK
соответствует LongTermKey.Key
, ERand
— Rand
, EDIV
— EDiv
. Значение ERand
должно быть развёрнуто и преобразовано в десятичное число. ННапример:
- Из
LTK
со значением48 4D AF CD 0F 92 22 88 0A 52 9A F4 76 DA 8B 94
получаетсяLongTermKey.Key
со значением484DAFCD0F9222880A529AF476DA8B94
. - Из
ERand
со значением63 02 84 B8 5D 40 44 DF
получаетсяRand
со значением16088054540146049635
. - Из
EDIV
со значением37520
получаетсяEDiv
со значением37520
.
ERand
:
>>> ERand=' 63 02 84 B8 5D 40 44 DF ' >>> ERand=list(reversed(ERand.strip().split())) >>> int("".join(ERand), 16) 16088054540146049635
Для macOS
Загрузитесь в macOS, откройте терминал.
- Если у вас Sierra или старее, выполните
$ sudo defaults read /private/var/root/Library/Preferences/blued.plist LinkKeys > ~/bt_keys.txt
- Если у вас High Sierra или новее, выполните
$ sudo defaults read /private/var/root/Library/Preferences/com.apple.bluetoothd.plist LinkKeys > ~/bt_keys.txt
Для старых версий macOS (High Sierra и более ранние) нужно развернуть ключи. Например, 98 54 2f aa bb cc dd ee ff gg hh ii jj kk ll mm
преобразуется в MM LL KK JJ GG FF EE DD CC BB AA 2F 54 98
.
Скопируйте файл bt_keys.txt
на диск, который можно будет прочитать в Arch Linux, и перезагрузитесь в Arch Linux.
Завершение
Теперь, когда у вас есть нужные ключи, войдите как root и перейдите в каталог:
# cd /var/lib/bluetooth/MAC-адрес-адаптера
Здесь вы найдёте подкаталоги для каждого сопряжённого устройства. Для каждого нужного устройства перейдите в его подкаталог:
# cd MAC-адрес-устройства
Измените файл info
и подставьте ключ под [LinkKey]
, например:
info
[LinkKey] Key=XXXXXXXXXXXXXXX
Затем перезапустите bluetooth.service
и pulseaudio
(командой pulseaudio -k && pulseaudio --start
).
Теперь устройство должно успешно подключаться.
Настройка
Автоматическое включение после загрузки
По умолчанию адаптер Bluetooth не включается после перезагрузки. Если вам это нужно, добавьте строку AutoEnable=true
в файле конфигурации /etc/bluetooth/main.conf
в разделе [Policy]
:
/etc/bluetooth/main.conf
[Policy] AutoEnable=true
Видимость при запуске системы
Если вы хотите, чтобы ваше устройство всегда было видимо и доступно для подключения:
/etc/bluetooth/main.conf
[General] DiscoverableTimeout = 0
Аудио
Обычно нужны дополнительные шаги для интеграции аудиосервера с Bluetooth. Подробнее это описано ниже.
Смотрите также Bluetooth headset для информации о подключении Bluetooth-гарнитуры.
PulseAudio
Установите пакет pulseaudio-bluetooth. Не забудьте перезапустить PulseAudio после переустановки: pulseaudio -k
. При стандартной установке PulseAudio после этого у вас сразу должна появиться возможность использования Bluetooth-устройств.
Если ваш PulseAudio работает как общесистемная служба, убедитесь, что пользователь, от имени которого запущен демон (обычно pulse
), состоит в группе lp
, и не забудьте загрузить нужные модули:
/etc/pulse/system.pa
... load-module module-bluetooth-policy load-module module-bluetooth-discover ...
PipeWire
PipeWire с версии 0.3.19 включает свою поддержку Bluetooth по умолчанию, смотрите Config Bluetooth.
ALSA
Сперва убедитесь, что ваше аудиоустройство Bluetooth подключено и сопряжено с системой.
Затем установите bluez-alsa-gitAUR, запустите (и включите) службу bluealsa
и добавьте своего пользователя в группу audio
.
Выполните следующую команду для проверки, что всё работает (замените XX:XX:XX:XX:XX:XX
и ФАЙЛ.wav
на нужные значения):
$ aplay -D bluealsa:SRV=org.bluealsa,DEV=XX:XX:XX:XX:XX:XX,PROFILE=a2dp ФАЙЛ.wav
В завершение добавьте эти строки в ~/.asoundrc
:
~/.asoundrc
defaults.bluealsa { service "org.bluealsa" device "XX:XX:XX:XX:XX:XX" profile "a2dp" }
Теперь можно использовать устройство bluealsa
для доступа к аудиоустройству Bluetooth. Управление объемом обычно осуществляется через alsamixer
с опцией -D bluealsa
.
Bluetooth serial
Чтобы получить последовательную связь на Bluetooth-to-Serial модулях (HC-05, HC-06), выполните следующие шаги:
Выполните сопряжение с вашим устройством Bluetooth с помощью bluetoothctl
как описано выше.
Установите bluez-rfcommAUR и bluez-utils-compatAUR, так как они предоставляют функции, отсутствующие в более новых инструментах.
Привяжите MAC-адрес сопряжённого устройства к терминула tty:
# rfcomm bind rfcomm0 MAC-адрес-устройства
Теперь можно открыть /dev/rfcomm0
для последовательной связи:
picocom /dev/rfcomm0 -b 115200
Решение проблем
Отладка
Для отладки сперва остановите bluetooth.service
.
Затем запустите его напрямую с параметром -d
:
# /usr/lib/bluetooth/bluetoothd -n -d
Другой вариант — использовать инструмент btmon
.
Устаревшие инструменты BlueZ
Восемь инструментов BlueZ объявлены устаревшими и удалены из bluez-utils, хотя не для всех из них есть замена среди новых инструментов. Пакет bluez-utils-compatAUR предоставляет альтернативный вариант bluez-utils, включающий в себя устаревшие инструменты.
Устаревший инструмент | Ближайшая замена |
---|---|
gatttool | btgatt-client, D-Bus Gatt API |
hciattach | btattach |
hciconfig | btmgmt (и bluetoothctl?) |
hcidump | btmon (и btsnoop) |
hcitool | отсутствует, есть D-Bus Device API |
rfcomm | отсутствует, сделать с D-Bus Profile1 API? |
ciptool | |
sdptool | отсутствует, функциональность кажется разбросанной по разным объектам DBus: Profile, Advertising, и массивы UUID в device и adapter. |
gnome-bluetooth
Если вы видите это при попытке включить получение файлов в настройках bluetooth:
Bluetooth OBEX start failed: Invalid path Bluetooth FTP start failed: Invalid path
То убедитесь, что пользовательские каталоги XDG существуют.
Bluetooth USB донгл
Если вы пользуетесь USB донглом, вы должны проверить, что ваш Bluetooth донгл распознан системой. Это можно сделать с помощью команды journalctl -f
, после того как вы воткнёте USB донгл (или заглянув в /var/log/messages.log
). Должно появиться что-то вроде следующего (ищите hci):
Feb 20 15:00:24 hostname kernel: [ 2661.349823] usb 4-1: new full-speed USB device number 3 using uhci_hcd Feb 20 15:00:24 hostname bluetoothd[4568]: HCI dev 0 registered Feb 20 15:00:24 hostname bluetoothd[4568]: Listening for HCI events on hci0 Feb 20 15:00:25 hostname bluetoothd[4568]: HCI dev 0 up Feb 20 15:00:25 hostname bluetoothd[4568]: Adapter /org/bluez/4568/hci0 has been enabled
Если вы получили только первые две строки, значит донгл распознан, но вам необходимо его активировать (поднять). Пример:
# btmgmt
[mgmt]# info
Index list with 1 item hci0: Primary controller addr 00:1A:7D:DA:71:10 version 6 manufacturer 10 class 0x000000 supported settings: powered connectable fast-connectable discoverable bondable link-security ssp br/edr hs le advertising secure-conn debug-keys privacy static-addr current settings: connectable discoverable bondable ssp br/edr le secure-conn name Mozart short name
[mgmt]# select hci0
Selected index 0
[hci0]# power up
hci0 Set Powered complete, settings: powered connectable discoverable bondable ssp br/edr le secure-conn
[hci0]# info
hci0: Primary controller addr 00:1A:7D:DA:71:10 version 6 manufacturer 10 class 0x1c0104 supported settings: powered connectable fast-connectable discoverable bondable link-security ssp br/edr hs le advertising secure-conn debug-keys privacy static-addr current settings: powered connectable discoverable bondable ssp br/edr le secure-conn
Или
# bluetoothctl
[bluetooth]# show
Controller 00:1A:7D:DA:71:10 (public) Name: Mozart Alias: Mozart Class: 0x0000095c Powered: no Discoverable: yes Pairable: yes
[bluetooth]# power on
[CHG] Controller 00:1A:7D:DA:71:10 Class: 0x001c0104 Changing power on succeeded [CHG] Controller 00:1A:7D:DA:71:10 Powered: yes
[bluetooth]# show
Controller 00:1A:7D:DA:71:10 (public) Name: Mozart Alias: Mozart Class: 0x001c0104 Powered: yes Discoverable: yes Pairable: yes
Чтобы убедиться, что устройство было определено, вы можете использовать hcitool
, являющуюся частью bluez-utils
. Вы можете получить список доступных устройств, их идентификаторов и MAC-адресов, используя:
$ btmgmt info
Index list with 1 item hci0: Primary controller addr 00:1A:7D:DA:71:10 version 6 manufacturer 10 class 0x1c0104 supported settings: powered connectable fast-connectable discoverable bondable link-security ssp br/edr hs le advertising secure-conn debug-keys privacy static-addr current settings: powered connectable discoverable bondable ssp br/edr le secure-conn
Для проверки версии Bluetooth можно сопоставить её с версией HCI по таблице из официальной спецификации. Например, в предыдущем выводе HCI version 6 означает Bluetooth 4.0.
Более детальная информация об устройстве может быть получена с помощью устаревшего инструмента hciconfig
. (bluez-utils-compatAUR)
$ hciconfig -a hci0
hci0: Type: USB BD Address: 00:1B:DC:0F:DB:40 ACL MTU: 310:10 SCO MTU: 64:8 UP RUNNING PSCAN ISCAN RX bytes:1226 acl:0 sco:0 events:27 errors:0 TX bytes:351 acl:0 sco:0 commands:26 errors:0 Features: 0xff 0xff 0x8f 0xfe 0x9b 0xf9 0x00 0x80 Packet type: DM1 DM3 DM5 DH1 DH3 DH5 HV1 HV2 HV3 Link policy: RSWITCH HOLD SNIFF PARK Link mode: SLAVE ACCEPT Name: 'BlueZ (0)' Class: 0x000100 Service Classes: Unspecified Device Class: Computer, Uncategorized HCI Ver: 2.0 (0x3) HCI Rev: 0xc5c LMP Ver: 2.0 (0x3) LMP Subver: 0xc5c Manufacturer: Cambridge Silicon Radio (10)
Устройства аудио начинают пропускать звук на небольшом расстоянии от донгла
Если другие устройства работают через тот же USB-хост, они могут прерывать связь с устройствами аудио. Убедитесь, что только Bluetooth-устройство подключено к соответствующей USB-шине. Например:
$ lsusb
Bus 002 Device 002: ID 0a12:0001 Cambridge Silicon Radio, Ltd Bluetooth Dongle (HCI mode) Bus 002 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub Bus 001 Device 004: ID 048d:1345 Integrated Technology Express, Inc. Multi Cardreader Bus 001 Device 003: ID 0424:a700 Standard Microsystems Corp. 2 Port Hub Bus 001 Device 002: ID 8087:0024 Intel Corp. Integrated Rate Matching Hub Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
CSR Dongle 0a12:0001
С устройством ID 0a12:0001 Cambridge Silicon Radio, Ltd Bluetooth Dongle (HCI mode)
есть баг, и оно сейчас работает только в версиях ядра ≤ 3.9.11. Есть патч для новых версий. Подробнее смотрите Kernel Bug 60824.
Logitech Bluetooth USB донгл
Существуют Logitech донглы (например, Logitech MX5000), которые могут работать в двух режимах: встроенный (Embedded) и HCI. Во встроенном режиме донгл эмулирует устройство USB так, что ваш компьютер думает, что вы используете обычную USB мышь/клавиатуру.
Если вы нажмёте маленькую красную кнопку на USB BT мини-приёмнике, включится другой режим. Удерживайте красную кнопку на BT донгле и вставьте его в компьютер, и через 3-5 секунд удерживания кнопки в системном трее появится иконка Bluetooth (Обсуждение).
В качестве альтернативы, вы можете установить пакет bluez-hid2hci. Когда вы подключите ваш Logitech донгл, он автоматически переключится.
hcitool scan: Устройство не найдено
- На некоторых ноутбуках Dell (например, Studio 15) вы должны переключить режим Bluetooth с HID на HCI. Установите пакет bluez-hid2hci, после чего udev будет делать это автоматически. В качестве альтернативы вы можете выполнить эту команду для переключения на HCI вручную:
# /usr/lib/udev/hid2hci
- Если устройство не появится, а на вашей машине есть операционная система Windows, попробуйте загрузить её и включить адаптер bluetooth в windows.
- Иногда также помогает эта простая команда:
# bluetoothctl power on
bluetoothctl: No default controller available
Эта ошибка может случаться, если устройство заблокировано через rfkill.
Также это случается с некоторыми картами intel (такими как 8260), которые не распознаются корректно службой Bluetooth. Иногда использование устаревшего bluez-utils-compatAUR взамен bluez-utils, как сообщалось, решает проблему.
Это также может быть вызвано мерами по энергосбережению, тогда добавление параметра ядра btusb.enable_autosuspend=n
может помочь. Смотрите также Red Hat Bugzilla – Bug 1573562.
systemd: Condition check resulted in Bluetooth service being skipped
bluetooth.service
требует только существование каталога /sys/class/bluetooth
, который создаётся модулем ядра bluetooth
, который автоматически загружается через systemd-udev
, если он находит работающее устройство Bluetooth.
Если у вас /sys/class/bluetooth
не существует, проверьте, что модуль Bluetooth загружен, с помощью lsmod
. Если нет, и вы уверены, что у вас есть устройство Bluetooth, попробуйте загрузить его вручную и перезапустить службу bluetooth.service
.
Также нужно загрузить соответствующий драйвер Bluetooth, чаще всего btusb
, но иногда могут понадобиться btrtl,btintel,btbcm,bnep,btusb
и т.д.
Проверьте статус bluetooth.service
, чтобы убедиться, что он запущен.
Смотрите также Debian Bug report logs - #853207.
Если bluetooth.service
успешно запущен, есть шанс, что использовать Bluetooth нормально всё равно не получится (например, bluetoothctl
говорит что-то вроде org.Bluez.Error.NotReady
при выполнении scan on
). Если такое случается, попробуйте перезагрузить компьютер и дважды проверьте: каталог /sys/class/bluetooth
существует; lsmod
содержит нужные модули Bluetooth; сообщения в журнале; и т.д. systemd-udev
должен подхватить ваше устройство Bluetooth автоматически.
rfkill unblock: не происходит разблокировка
Если ваше устройство по-прежнему программно блокируется и у вас запущен connman, попробуйте это:
$ connmanctl enable bluetooth
Мой компьютер невидим
Включите режим обнаружения:
# bluetoothctl discoverable on
Убедитесь, что он включен:
# bluetoothctl show
Powered: yes Discoverable: yes Pairable: yes
/etc/bluetooth/main.conf
Если компьютер всё равно невидим, попробуйте изменить класс устройства в /etc/bluetooth/main.conf, как здесь:
# Default device class. Only the major and minor device class bits are # considered. #Class = 0x000100 # Computer Type (from default config) Class = 0x100100 # (Object-Transfer Service & Computer Type)
Class
в файле main.conf
оказывается переопределён после инициализации устройства, так что попробуйте установить класс напрямую с помощью hciconfig hci0 class 100100
.Пользователь сообщал, что это было единственное решение, сделавшее его компьютер видимым для телефона. Телевизоры LG (и некоторые другие) видимы с других устройств аудио, так что использование класса 000414
(soundbar) заставит такие устройства появиться.
Смотрите https://bluetooth-pentest.narod.ru/software/bluetooth_class_of_device-service_generator.html для генерации классов устройств/служб Bluetooth.
Foxconn / Hon Hai / Lite-On Broadcom
Некоторые из этих устройств необходимо прошивать при загрузке. Файлы прошивок не предоставляются, но их можно сконвертировать из Windows-файлов .hex в .hcd с помощью hex2hcd (который устанавливается с bluez-utils).
Чтобы получить нужный .hex файл, попробуйте поискать vendor:product (производитель:продукт) из lsusb, например:
... Bus 002 Device 004: ID 04ca:2006 Lite-On Technology Corp. Broadcom BCM43142A0 Bluetooth Device ...
или
Bus 004 Device 004: Id 0489:e031 Foxconn / Hon Hai
В качестве альтернативы, вы можете загрузиться в Windows (можете использовать виртуальную машину) и узнать название прошивки из утилиты Диспетчер Устройств. Если вы хотите знать модель устройста, но не видите его в lsusb, его можно увидеть в lsusb -v как iProduct
.
Файл .hex можно извлечь из скачанного драйвера Windows без необходимости загружать Windows. Скачайте правильный драйвер, например Bluetooth Widcomm (перечислен среди драйверов для Lifebook P771), который содержит драйверы для многих устройств Broadcomm. В случае Widcomm драйвер является самораспаковывающимя RAR-архивом, так что его можно распаковать с помощью unrar x. Чтобы найти, какой из .hex файлов нужен вам, смотрите Win32/bcbtums-win7x86-brcm.inf
и ищите [RAMUSBE031.CopyList]
, где E031
следует заменить на product code вашего устройства (второе hex-число из lsusb) в верхнем регистре.
Когда вы сконвертируете его в .hcd, скопируйте его в /lib/firmware/brcm/BCM.hcd
— это имя файла предлагает dmesg и может быть другим, так что проверьте вывод dmesg у себя. Затем перезагрузите модуль
# rmmod btusb # modprobe btusb
Теперь устройство должно быть доступно. Смотрите BBS#162688 для информации о том, как сделать эти изменения постоянными.
Комбинированные WiFi-Bluetooth карты Intel
See Wireless network configuration (Русский)#Bluetooth Coexistence.
Устройство подключается и затем отключается спустя мгновение
Если вы видите в журнале подобные сообщения и устройство не может подключиться или отключается вскоре после подключения:
bluetoothd: Unable to get connect data for Headset Voice gateway: getpeername: Transport endpoint is not connected (107) bluetoothd: connect error: Connection refused (111)
Это может быть из-за того, что вы уже настроили сопряжение с этим устройством в другой операционной системе с тем же Bluetooth-адаптером (например, в случае dual-booting). Некоторые устройства не могут обрабатывать несколько сопряжений с одним и тем же MAC-адресом. Смотрите #Сопряжение при Dual boot для решения этой проблемы.
Устройство не подключается и пишет ошибку в журнал
Если при попытке подключения вы видите в журнале сообщение вроде такого:
a2dp-source profile connect failed for 9C:64:40:22:E1:3F: Protocol not available
попробуйте установить pulseaudio-bluetooth и перезапустить PulseAudio. Эта ошибка может проявиться даже при использовании только передачи файлов.
Устройство не видно в scan
Некоторые устройства с Bluetooth low energy не отображаются при сканировании в bluetoothctl, например Logitech MX Master. Самым простым найдённым путём для соединения может быть установка bluez-utils-compatAUR, запуск bluetooth.service
и выполнение:
# bluetoothctl
[NEW] Controller (MAC) myhostname [default]
[bluetooth]# power on
[CHG] Controller (MAC) Class: 0x0c010c Changing power on succeeded [CHG] Controller (MAC) Powered: yes
[bluetooth]# scan on
Discovery started [CHG] Controller (MAC) Discovering: yes
В другом терминале:
# hcitool lescan
Дождитесь появления устройства и затем прервите hcitool с помощью Ctrl+c
. Теперь bluetoothctl должен увидеть ваше устройство и позволить нормально настроить сопряжение.
Не удаётся получить файлы из-за символьной ссылки
Если передача файла обрывается при успешно работающем соединении Bluetooth, проблема может быть из-за символьных ссылок в пути. В журнале могут появиться примерно такие записи:
Jun 18 11:18:13 ember obexd[3338969]: open(/home/me/.cache/obexd/MOC740): Operation not permitted (1)
Если показанный здесь путь содержит символьную ссылку, то obexd по умолчанию не примет его. Поведение можно переопределить с помощью drop-in файла для пользовательской службы obex.service
:
~/.config/systemd/user/obex.service.d/10-symlink.conf
[Service] ExecStart= ExecStart=/usr/lib/bluetooth/obexd --symlinks
Затем выполните systemctl daemon-reload --user
от имени нужного пользователя и перезапустите пользовательский юнит obex.service
.
Интерференция между наушниками и мышью
Если аудио заикается при одновременном использовании Bluetooth мыши и клавиатуры, попробуйте это, как указано в #23 https://bugs.launchpad.net/ubuntu/+source/bluez/+bug/424215
# hciconfig hci0 lm ACCEPT,MASTER # hciconfig hci0 lp HOLD,SNIFF,PARK
Bluetooth мышь двигается с задержкой
Попробуйте изменить файл /var/lib/bluetooth/XX:XX:XX:XX:XX:XX/YY:YY:YY:YY:YY:YY/info
(где XX:XX:XX:XX:XX:XX
- MAC-адрес вашего Bluetooth-адаптера, YY:YY:YY:YY:YY:YY
- MAC-адрес вашей мыши), добавив туда следующие строки:
[ConnectionParameters] MinInterval=6 MaxInterval=9 Latency=44 Timeout=216
Вы можете посмотреть MAC-адрес адаптера командой hcitool dev
, а MAC-адреса подключенных устройств командой hcitool con
Адаптер пропадает после ждущего режима
Сперва найдите product ID адаптера. Например:
$ lsusb -tv
/: Bus 01.Port 1: Dev 1, Class=root_hub, Driver=xhci_hcd/12p, 480M ID 1d6b:0002 Linux Foundation 2.0 root hub ... |__ Port 3: Dev 3, If 0, Class=Wireless, Driver=btusb, 12M ID 8087:0025 Intel Corp. |__ Port 3: Dev 3, If 1, Class=Wireless, Driver=btusb, 12M ID 8087:0025 Intel Corp. ...
В данном случае vendor ID — 8087, product ID — 0025.
Затем используйте usb_modeswitch для сброса адаптера:
# usb_modeswitch -R -v vendor_ID -p product_ID
Проблемы со всеми устройствами BLE на ядре 5.9+
С версии 5.9 стек Bluetooth в ядре пытается использовать link-layer privacy на BLE соединениях. Если устройство работает после сопряжения, но не переносит перезагрузку или ждущий режим — вероятно, из-за этого.
Чтобы обойти [2] эту проблему, откройте /var/lib/bluetooth/mac_адаптера/mac_устройства/info
, удалите следующие строки и перезапустите bluetooth.service
:
[IdentityResolvingKey] Key=...
Смотрите связанное обсуждение на форуме Arch.