「Bluetooth ヘッドセット」の版間の差分

提供: ArchWiki
ナビゲーションに移動 検索に移動
(関連記事を同期)
 
(5人の利用者による、間の32版が非表示)
3行目: 3行目:
 
[[en:Bluetooth headset]]
 
[[en:Bluetooth headset]]
 
[[ru:Bluetooth headset]]
 
[[ru:Bluetooth headset]]
  +
[[zh-hans:Bluetooth headset]]
 
{{Related articles start}}
 
{{Related articles start}}
 
{{Related|Bluetooth}}
 
{{Related|Bluetooth}}
{{Related|Bluez4}}
 
 
{{Related articles end}}
 
{{Related articles end}}
  +
Bluetooth オーディオシステムには次の 3 つがあります:
  +
* A2DP (高度なオーディオ配信) は、通常は入力 (ソース) なしで、音楽グレードのステレオ出力 (シンク) を提供します。
  +
** A2DP はさまざまなコーデックを使用できます。標準の SBC には品質とビットレートのトレードオフが劣りますが、はるかに優れた代替手段としてオープンソースの (LDAC、AptX) が普及しています。
  +
** AVRCP は、再生制御を提供するために A2DP の上で使用されます。
  +
* HFP/HSP (ハンズフリー/ヘッドセット) は音声グレードのモノラル出力と入力を提供します。HFP は HSP の上に構築されます。
  +
* LE Audio は 2020 年に発表された低エネルギーオーディオ規格です。標準コーデックは LC3 です。
   
  +
カーネル、BlueZ5、および PipeWire は、3 つのプロファイルすべてをサポートします。PulseAudio や ALSA などの古いサウンドサーバーは、A2DP と HFP/HSP のみをサポートします。Bluetooth は信頼性が低いことで悪名が高い [https://xkcd.com/2055/] ですが、多くの実装では大幅な改善が見られ、Intel Bluetooth チップのような確立されたハードウェアでの耐え難いエクスペリエンスが多少軽減されています。
現在、Arch Linux のデフォルト環境ではリモートオーディオ再生の A2DP プロファイル (Audio Sink) をサポートしています。
 
   
  +
== PipeWire 経由のヘッドセット ==
{{Tip|
 
* 最新版の [[Bluez]] はヘッドセット/ハンズフリープロファイルをサポートしていません。そのためマイク入力は動作せず、A2DP プロファイルをサポートしていないヘッドセットには音声が出力されません。ヘッドセット/ハンズフリープロファイルのヘッドセットを使うときは、[[AUR]] を利用して他のパッケージを取得する旧式の方法を使用する必要があります。
 
* Bluez5 は [[PulseAudio]] しかサポートしておらず [[ALSA]] はサポートしていません。PulseAudio を使いたくない場合は AUR から昔のバージョンの Bluez をインストールする必要があります。}}
 
   
  +
[[PipeWire]] は [[PulseAudio]] のドロップイン代替品として機能し、Bluetooth ヘッドセットをセットアップする簡単な方法を提供します。これには、SBC/SBC-XQ、AptX、LDAC または AAC コーデック、および HFP/HSP を使用した A2DP シンクプロファイルのすぐに使えるサポートが含まれています。
== Bluez5/PulseAudio (git) ==
 
   
  +
{{Pkg|pipewire-pulse}} ({{Pkg|pulseaudio}} と {{Pkg|pulseaudio-bluetooth}} を [[インストール]] して置き換えます)
PulseAudio 5.x はデフォルトで A2DP をサポートしています。また、git 版では HFP もサポートされています。以下のパッケージをインストールしてください:
 
   
  +
デーモンは [[systemd/ユーザー|user service]] として自動的に起動されます。設定には、{{Pkg|pavucontrol}} またはデスクトップ環境の設定を使用します。詳細については、[[PipeWire#Bluetooth デバイス]] を参照してください。
# pacman -S pulseaudio-alsa bluez bluez-libs bluez-utils bluez-firmware
 
  +
  +
== Bluez5/PulseAudio 経由のヘッドセット ==
  +
  +
PulseAudio 5.x はデフォルトで A2DP をサポートしています。以下のパッケージを[[インストール]]してください: {{Pkg|pulseaudio-alsa}}, {{Pkg|pulseaudio-bluetooth}}, {{Pkg|bluez}}, {{Pkg|bluez-libs}}, {{Pkg|bluez-utils}}, {{AUR|bluez-firmware}}。{{Pkg|pulseaudio-bluetooth}} がないとペアリングした後に接続することができなくなります。エラーメッセージは表示されません。
   
 
Bluetooth システムを起動:
 
Bluetooth システムを起動:
35行目: 43行目:
 
# scan on
 
# scan on
   
  +
ヘッドセットをペアリングモードにします。ヘッドセットは簡単に確認できます。例えば:
Now make sure that your headset is in pairing mode. It should be discovered shortly. For example,
 
 
[NEW] Device 00:1D:43:6D:03:26 Lasmex LBT10
 
[NEW] Device 00:1D:43:6D:03:26 Lasmex LBT10
shows a device that calls itself "Lasmex LBT10" and has MAC address ''00:1D:43:6D:03:26''. We will now use that MAC address to initiate the pairing:
+
上記の場合、デバイスの名前は "Lasmex LBT10" MAC アドレスは ''00:1D:43:6D:03:26'' です。この MAC アドレスを使ってペアリングを開始します:
   
 
# pair 00:1D:43:6D:03:26
 
# pair 00:1D:43:6D:03:26
   
  +
ペアリングが完了したら、デバイスを明示的に接続する必要があります (every time?):
After pairing, you also need to explicitly connect the device (every time?):
 
   
 
# connect 00:1D:43:6D:03:26
 
# connect 00:1D:43:6D:03:26
   
  +
全てが上手くいけば、[[PulseAudio]] にアウトプットデバイスが新しく作られます。
If everything works correctly, you now have a separate output device in [[PulseAudio]].
 
  +
{{Note|デバイスはデフォルトではオフになっています。{{Pkg|pavucontrol}} の "Configuration" タブでオーディオプロファイル (''OFF'', A2DP, HFP) を選択してください。}}
{{Note|The device may be off by default. Select it's audio profile (''OFF'', A2DP, HFP) in the "Configuration" tab of {{Pkg|pavucontrol}}.}}
 
  +
{{Pkg|pavucontrol}} の "Playback" や "Recording" タブを使うことでデバイスに音声を転送することができます。
You can now redirect any audio through that device using the "Playback" and "Recording" tabs of {{Pkg|pavucontrol}}.
 
   
  +
スキャンを無効化してプログラムを終了:
You can now disable scanning again and exit the program:
 
 
# scan off
 
# scan off
 
# exit
 
# exit
  +
  +
=== CLI による設定 ===
  +
  +
{{ic|bluetooth.service}} を [[起動]] します。
  +
  +
これで、''bluetoothctl'' コマンド ラインユーティリティを使用してペアリングして接続できるようになりました。''bluetoothctl'' のトラブルシューティングと詳細な説明については、[[Bluetooth]] の記事を参照してください。
  +
  +
$ bluetoothctl
  +
  +
内部コマンドプロンプトが表示されます。次に、次のように入力します。
  +
  +
[bluetooth]# power on
  +
[bluetooth]# agent on
  +
[bluetooth]# default-agent
  +
[bluetooth]# scan on
  +
  +
次に、ヘッドセットがペアリングモードになっていることを確認します。それはすぐに発見されるはずです。例えば、
  +
  +
[NEW] Device 00:1D:43:6D:03:26 Lasmex LBT10
  +
  +
は、自身を ''"Lasmex LBT10"'' と呼び、MAC アドレス ''"00:1D:43:6D:03:26"'' を持つデバイスを示しています。次に、その MAC アドレスを使用してペアリングを開始します。
  +
  +
[bluetooth]# pair 00:1D:43:6D:03:26
  +
  +
ペアリング後、デバイスを明示的に接続する必要もあります (これが機能しない場合は、接続を試行する ''前に'' 以下の {{ic|trust}} コマンドを試してください。)
  +
  +
[bluetooth]# connect 00:1D:43:6D:03:26
  +
  +
接続エラー {{ic|org.bluez.Error.Failed}} が発生した場合は、まず既存の PulseAudio デーモンを強制終了して再試行してください。
  +
  +
$ pulseaudio -k
  +
[bluetooth]# connect 00:1D:43:6D:03:26
  +
  +
最後に、今後このデバイスに自動的に接続する場合は、次のようにします。
  +
  +
[bluetooth]# trust 00:1D:43:6D:03:26
  +
  +
すべてが正しく動作すれば、[[PulseAudio]] に別の出力デバイスが作成されます。
  +
  +
{{Note|デバイスはデフォルトでオフになっている可能性があります。{{Pkg|pavucontrol}} の "設定" タブでオーディオプロファイル ({{ic|OFF}}、{{ic|A2DP}}、{{ic|HFP}}) を選択します。}}
  +
  +
{{Pkg|pavucontrol}} の "再生" タブと "録音" タブを使用して、そのデバイス経由でオーディオをリダイレクトできるようになりました。
  +
  +
ここで、スキャンを再度無効にしてプログラムを終了できます。
  +
  +
[bluetooth]# scan off
  +
[bluetooth]# exit
  +
  +
==== 自動接続の設定 ====
  +
  +
ヘッドセットを自動接続するには、PulseAudio のスイッチオン接続モジュールを有効にする必要があります。これを行うには、次の行を {{ic|/etc/pulse/default.pa}} に追加します。
  +
  +
{{hc|/etc/pulse/default.pa|
  +
### Automatically switch to newly-connected devices
  +
load-module module-switch-on-connect
  +
}}
  +
  +
{{Note|Bluetooth オーディオ デバイスが "信頼" されていることを確認してください。そうでない場合、ペアリングを繰り返しても失敗します。詳細については、[[Bluetooth#ペアリング]] を参照してください。}}
  +
  +
=== GNOME Bluetooth 経由の設定 ===
  +
  +
{{Note| 現在進行中のバグのため、pulseaudio 9/10 ではこの方法を使用しても A2DP プロファイルがアクティブ化されず、低品質のモノラルサウンドが発生する可能性があります。考えられる解決策については、[[Bluetooth ヘッドセット#PulseAudio で A2DP が動作しない|PulseAudio で A2DP が動作しない]] を参照してください。}}
  +
  +
[[Bluetooth#グラフィカル|GNOME Bluetooth]] グラフィカルフロントエンドを使用して、Bluetooth ヘッドセットを簡単に設定できます。
  +
  +
まず、{{ic|bluetooth.service}} systemd ユニットが実行されていることを確認する必要があります。
  +
  +
GNOME Bluetooth を開き、Bluetooth をアクティブにします。デバイスをスキャンした後、デバイスリストでヘッドセットを選択して接続できます。デバイスメニューからサウンド設定パネルに直接アクセスして。デバイスが接続されると、サウンドパネルに新しいシンクが表示されます。
  +
  +
=== LDAC/aptX ===
  +
  +
[[Wikipedia:LDAC_(codec)|LDAC]]/[[Wikipedia:aptX|aptX]] コーデックは [https://www.freedesktop.org/wiki/Software/PulseAudio/Notes/15.0/#supportforldacandaptxbluetoothcodecsplussbcxqsbcwithhigher-qualityparameters PulseAudio 15.0] 以降でサポートされています。接続に使用しているコーデックは次のように確認できます。
  +
  +
$ pactl list | grep a2dp_codec
   
 
=== トラブルシューティング ===
 
=== トラブルシューティング ===
   
  +
{{Note|A2DP/Bluetooth ヘッドセットが動作しないという報告は多数存在します。細については、[[Bluetooth ヘッドセット#HSV と A2DP の設定の切り替え|HSV と A2DP の設定の切り替え]] を参照してください。}}
Many users report frustration with getting A2DP/Bluetooth Headsets to work.
 
   
  +
==== 異音 / 雑音 / "濁った音" ====
==== Selected audio profile, but headset inactive and audio cannot be redirected ====
 
   
  +
ヘッドセットの音質が悪い場合は、ヘッドセットが正しいプロファイルに設定されていないことが原因である可能性が高くなります。
Deceptively, this menu is available before the device has been connected; annoyingly it will have no effect. The menu seems to be created as soon as the receiver recognizes the device.
 
  +
問題を解決するには、[[Bluetooth ヘッドセット#HSV と A2DP の設定の切り替え|HSV と A2DP の設定の切り替え]] を参照してください。
   
  +
==== オーディオプロファイルが選択されていますが、ヘッドセットが非アクティブであり、オーディオをリダイレクトできません ====
Make sure to run bluetoothctl (with sudo/as root) and connect the device manually. There may be configuration options to remove the need to do this each time, but neither pairing nor trusting induce automatic connecting for me.
 
  +
  +
一見、このメニューはデバイスが接続される前から利用可能です。面倒なことに効果はありません。受信機がデバイスを認識するとすぐにメニューが作成されるようです。
  +
  +
必ず {{ic|bluetoothctl}} を root として実行し、デバイスを手動で接続してください。毎回これを行う必要をなくす設定オプションがあるかもしれませんが、ペアリングも信頼も自動接続を誘発しません。
   
 
==== AuthenticationFailed でペアリングが失敗する ====
 
==== AuthenticationFailed でペアリングが失敗する ====
   
ペアリングが失敗する場合、次のコマンドで [https://stackoverflow.com/questions/12888589/linux-command-line-howto-accept-pairing-for-bluetooth-device-without-pin SSPMode を無効化] してみてください:
+
ペアリングが失敗する場合、次のコマンドで [https://stackoverflow.com/questions/12888589/linux-command-line-howto-accept-pairing-for-bluetooth-device-without-pin SSPMode を無効化] または有効化してみてください:
  +
# btmgmt ssp off
# hciconfig hci0 sspmode 0
 
  +
または
  +
# btmgmt ssp on
  +
  +
これらのコマンドを実行する間、Bluetooth 機器の電源を OFF にする必要がある可能性があります。
   
 
==== ペアリングは成功するが、接続が失敗する ====
 
==== ペアリングは成功するが、接続が失敗する ====
85行目: 176行目:
 
bluetoothd[5556]: a2dp-sink profile connect failed for 00:1D:43:6D:03:26: Protocol not available
 
bluetoothd[5556]: a2dp-sink profile connect failed for 00:1D:43:6D:03:26: Protocol not available
   
  +
おそらく {{Pkg|pulseaudio-bluetooth}} パッケージがインストールされていないのが原因です。インストールしたら、pulseaudio を再起動してください。
The problem in this case is that PulseAudio is not catching up. A common solution to this problem is to restart PulseAudio. Note that it is perfectly fine to run ''bluetoothctl'' as root while PulseAudio runs as user. After restarting PulseAudio, retry to connect. It is not necessary to repeat the pairing.
 
   
  +
パッケージが欠けていることが問題ではない場合、PulseAudio が上手く起動していないのが原因です。一般的に PulseAudio を再起動することで問題は解決します。PulseAudio をユーザーで実行している場合に ''bluetoothctl'' を root で実行することは全く問題ありません。PulseAudio の再起動後、接続を再試行してください。ペアリングを繰り返す必要はありません。
If restarting PulseAudio does not work, you need to load module-bluetooth-discover.
 
  +
  +
PulseAudio の再起動で問題が直らないときは、module-bluetooth-discover をロードしてください:
   
 
# pactl load-module module-bluetooth-discover
 
# pactl load-module module-bluetooth-discover
   
The same load-module command can be added to {{ic|/etc/pulse/default.pa}}.
+
上記の load-module コマンドは {{ic|/etc/pulse/default.pa}} に追加することができます。
   
  +
それでも問題が修正されない場合、あるいは PulseAudio の system-wide モードを使っていない場合、以下の PulseAudio モジュールもロードしてください (以下のモジュールも {{ic|default.pa}} や {{ic|system.pa}} でロードすることができます):
If that still does not work, or you are using PulseAudio's system-wide mode, also load the following PulseAudio modules (again these can be loaded via your default.pa or system.pa):
 
   
 
module-bluetooth-policy
 
module-bluetooth-policy
99行目: 192行目:
 
module-bluez5-discover
 
module-bluez5-discover
   
  +
==== 接続は機能しますが、常に音の不具合が発生します ====
To have your headset auto connect you need to enable PulseAudio's switch-on-connect module. Add the following:
 
{{hc|/etc/pulse/default.pa|
 
# automatically switch to newly-connected devices
 
load-module module-switch-on-connect
 
}}
 
   
  +
これは、Bluetooth と WiFi が同じ物理アンテナとおそらく帯域範囲 (2.4GHz) を共有しているため、同じチップを共有している場合に発生する可能性が非常に高くなります。これは Windows ではシームレスに機能しますが、Linux ではそうではありません。
You then need to tell ''bluetoothctl'' to trust your Bluetooth headset, or you will see errors like this:
 
bluetoothd[487]: Authentication attempt without agent
 
bluetoothd[487]: Access denied: org.bluez.Error.Rejected
 
   
  +
考えられる解決策は、干渉が発生しないように WiFi ネットワークを 5GHz に移行することです。カード/ルーターがこれをサポートしていない場合は、WiFi ドライバー/ファームウェアをアップグレードできます。このアプローチは、Realtek 8723BE および AUR のこのチップ用の最新の rtl ドライバーで機能します。
[bluetooth]# trust 00:1D:43:6D:03:26
 
   
  +
上記の方法が何も不可能な場合は、フラグメントサイズと PulseAudio 出力ポートの遅延を微調整して干渉を補償することにより、あまり効果的ではありません。これらの設定によりオーディオが同期しなくなる可能性があるため (ビデオの再生時など)、適切な値を選択する必要があります。Bluetooth ヘッドセットのポートの遅延を変更するには (たとえば、次の例では 125000 マイクロ秒に):
After a reboot, your Bluetooth adapter will not power on by default. You need to add a udev rule to power it on:
 
  +
{{hc|/etc/udev/rules.d/10-local.rules|2=
 
  +
$ pactl set-port-latency-offset <bluez_card> headset-output '''125000'''
# Set bluetooth power up
 
  +
ACTION=="add", SUBSYSTEM=="bluetooth", KERNEL=="hci[0-9]*", RUN+="/usr/bin/hciconfig %k up"
 
  +
カードの識別子は次のようになります。
  +
  +
$ pacmd list-sinks | grep -Eo 'bluez_card[^>]*'
  +
  +
フラグメントサイズは {{ic|/etc/pulse/daemon.conf}} で設定でき、PulseAudio の再起動後に有効になります (詳細については、[[PulseAudio/トラブルシューティング#Pulseaudio におけるデフォルトのフラグメント・バッファサイズを設定する]] を参照してください)
  +
おそらく、(適切な Bluetooth アダプターを使用して) {{ic|1=options ath9k btcoex_enable=1}} を {{ic|/etc/modprobe.d/ath9k.conf}} に追加すると役立つでしょう。
  +
  +
{{hc|1=/etc/modprobe.d/ath9k.conf|2=
  +
# possibly fix for sound glitches
  +
options ath9k btcoex_enable=1
 
}}
 
}}
  +
  +
その後、再起動します。
   
 
==== 接続は成功するが、音が聞こえない ====
 
==== 接続は成功するが、音が聞こえない ====
124行目: 223行目:
 
bluetoothd[5556]: Endpoint registered: sender=:1.83 path=/MediaEndpoint/A2DPSink
 
bluetoothd[5556]: Endpoint registered: sender=:1.83 path=/MediaEndpoint/A2DPSink
   
  +
上記のようなメッセージがある場合、PulseAudio の設定を確認してください。もしくは、一度戻って接続が成功するかどうか確かめてください。
If you see a message similar to this, you can go on and investigate your PulseAudio configuration. Otherwise, go back and ensure the connection is successful.
 
  +
  +
[[GDM]] を使っている場合、PulseAudio のインスタンスが起動して、bluetooth デバイスの接続を奪っている可能性があります。以下のコマンドを実行して GDM ユーザーで pulseaudio ソケットを[[systemd#ユニットを使う|マスク]]することで問題は解決します:
  +
  +
# mkdir -p ~gdm/.config/systemd/user
  +
# ln -s /dev/null ~gdm/.config/systemd/user/pulseaudio.socket
  +
  +
再起動すれば PulseAudio のインスタンスが起動しなくなるはずです。
  +
  +
bluez がヘッドセットを a2dp に対応していると認識してくれない場合もあります。そのようなときは、以下のコマンドで bluetooth デバイスのインデックスを検索してください:
  +
  +
$ pacmd ls
  +
  +
以下のように bluetooth ヘッドセットに関連するセクションが出力されます:
  +
  +
{{hc
  +
|1=pacmd ls
  +
|2=index: 2
  +
name: <bluez_card.XX_XX_XX_XX_XX_XX>
  +
driver: <module-bluez5-device.c>
  +
owner module: 27
  +
properties:
  +
device.description = "SONY MDR-100ABN"
  +
device.string = "XX:XX:XX:XX:XX:XX"
  +
device.api = "bluez"
  +
device.class = "sound"
  +
...}}
  +
  +
プロファイルを手動で設定するには、以下のコマンドを実行 ({{ic|2}} は {{ic|pacmd ls}} で確認したデバイスのインデックスに置き換えてください):
  +
  +
$ pacmd set-card-profile 2 a2dp_sink
  +
  +
==== 接続は機能しますが、デバイスが PulseAudio シンクに表示されません ====
  +
  +
ヘッドフォンが正常に接続された ({{ic|bluetoothctl}} 経由で [[Bluetooth#ペアリング|確認済み]] である可能性がある) が、{{ic|pavucontrol}} で出力/入力シンクとして表示されない場合は、次のことを試してください。次のポリシーを Bluetooth 構成ファイル {{ic|/etc/bluetooth/main.conf}} に追加します。
  +
  +
{{hc|/etc/bluetooth/main.conf|2=
  +
[General]
  +
Enable=Control,Gateway,Headset,Media,Sink,Socket,Source
  +
}}
  +
  +
これで問題が解決したと報告しているユーザーもいます [https://bbs.archlinux.org/viewtopic.php?id=234790 報告]
  +
  +
==== 接続は機能し、ヘッドフォンがアイドル状態になるまでサウンドは正常に再生されますが、その後途切れます。 ====
  +
  +
ヘッドホンがアイドル状態になるまでサウンドを正しく再生し、再開時に音が途切れる場合 (たとえば、サウンドが一時停止されている、またはしばらくサウンドが再生されないため)、アイドル時の PulseAudio の自動シンク/ソース サスペンションを無効にしてみてください。
  +
  +
Bluetooth 接続でデータが送信されない場合、一部のユーザー [https://bbs.archlinux.org/viewtopic.php?id=117420 が報告] に大幅な遅延が発生したり、音声が聞こえなくなったりすることがあります。これは、アイドル時にシンク/ソースを自動的に一時停止する {{ic|module-suspend-on-idle}} モジュールによるものです。これによりヘッドセットに問題が発生する可能性があるため、責任のあるモジュールを無効にすることができます。
  +
  +
{{ic|module-suspend-on-idle}} モジュールの読み込みを無効にするには、使用中の設定ファイル ({{ic|~/.config/pulse/default.pa}} または {{ic|/etc/pulse/default.pa}}):
  +
  +
{{hc|~/.config/pulse/default.pa|
  +
### Automatically suspend sinks/sources that become idle for too long
  +
#load-module module-suspend-on-idle
  +
}}
  +
  +
最後に PulseAudio を再起動して、変更を適用します。
   
 
==== UUIDs has unsupported type ====
 
==== UUIDs has unsupported type ====
134行目: 289行目:
 
このメッセージは無視してかまいません。
 
このメッセージは無視してかまいません。
   
  +
==== PC からはデバイスがペアリング済みと認識されるがデバイスから PC が認識されていない ====
== 旧式の方法: ALSA-BTSCO ==
 
   
  +
デバイスが bluetooth LE のペアリングに対応していない可能性があります。
It is much easier to set up your bluetooth headset today, with bluez >= 3.16. You may want to try the out-of-box python script in [http://fosswire.com/2008/01/11/a2dp-stereo-linux/ this blog] (you need edit the script to work with gconftool-2). There is also a piece of equivalent bash script [http://lymanrb.blogspot.com/2008/05/linux.html here].
 
   
  +
{{ic|/etc/bluetooth/main.conf}} で {{ic|1=ControllerMode = bredr}} を設定してみてください。詳しくは [https://unix.stackexchange.com/questions/292189/pairing-bose-qc-35-over-bluetooth-on-fedora] を参照。
You need your headset's bdaddr. It is of the form ''12:34:56:78:9A:BC''. Either find it in the documentation of your headset, on the headset itself or with the '''hcitool scan''' command.
 
   
  +
==== デバイスが接続され、しばらくすると切断される ====
{{AUR|btsco}} をインストールしてください。
 
   
  +
[[systemd/ジャーナル|ジャーナル]] に次のようなメッセージが表示され、デバイスが接続に失敗するか、接続後すぐに切断される場合:
To load the kernel module, type:
 
# modprobe snd-bt-sco
 
There will now be an extra audio device. Use {{ic|alsamixer -cN}} (where N is most likely 1) to set the volume. You can access the device with any alsa-capable application by choosing the device ''BT headset'', or with any OSS application by using {{ic|/dev/dspN}} as the audio device.
 
   
  +
bluetoothd: Unable to get connect data for Headset Voice gateway: getpeername: Transport endpoint is not connected (107)
But to actually get any sound, you have to connect your headset to the computer first.
 
  +
bluetoothd: connect error: Connection refused (111)
   
  +
これは、同じ Bluetooth アダプタを使用してデバイスを別のオペレーティングシステムとすでにペアリングしていることが考えられます (デュアルブートなど) 一部のデバイス (Bluetooth アダプターなど) は、同じ MAC アドレスに関連付けられた複数のペアリングを処理できません。この問題は、デバイスを再ペアリングすることで修正できます、まずデバイスを削除します。
=== ヘッドセットを接続 ===
 
   
  +
$ bluetoothctl
If you connect your headset for the first time, read the section about pairing first. To connect to your headset to the computer, use the command
 
  +
[bluetooth]# devices
$ btsco -f <bdaddr>
 
  +
Device XX:XX:XX:XX:XX:XX My Device
for example
 
  +
[bluetooth]# remove XX:XX:XX:XX:XX:XX
$ btsco -f 12:34:56:78:9A:BC
 
   
  +
次に、{{ic|bluetooth.service}} を [[再起動]] して Bluetooth アダプターの電源を入れ、デバイスを検出可能にして、デバイスを再スキャンして、デバイスを再ペアリングします。Bluetooth マネージャーによっては、デバイスを再検出するために完全な再起動を実行する必要がある場合があります。
==== ヘッドセットとコンピュータをペアリング ====
 
   
  +
==== Apple AirPodsの音量が小さい ====
The first time you connect the headset, you have to pair it with the computer. To do this, you need your headset's PIN. Depending on your headset you may have to reset the headset and repeat the pairing everytime you used the headset with another bluetooth device.
 
   
  +
次の内容で {{ic|bluetooth.service}} の [[ドロップインファイル]] を作成します。
There are two ways to pair your headset with the computer:
 
   
  +
{{hc|/etc/systemd/system/bluetooth.service.d/noplugin-avrc.conf|2=
===== ''bluez-gnome'' を使う =====
 
  +
[Service]
  +
ExecStart=
  +
ExecStart=/usr/lib/bluetooth/bluetoothd --noplugin=avrcp
  +
}}
   
  +
次に、{{ic|bluetooth.service}}、を [[再起動]] して設定を [[リロード]] し、ヘッドセットを再接続します。
Install the ''bluez-gnome'' package from the community repository. Then start the '''bt-applet''' program. Once you try to connect to the headset, a window will open and ask for the PIN.
 
   
  +
さらに、AirPods Pro の場合は、iPhone の設定で空間オーディオを無効にし、モノラルを有効にします。
===== ''passkey-agent'' を使う =====
 
   
  +
これにより、AVRCP を通じて制御できない一部のデバイスの問題も解決できます。
Before connecting to the headset, enter the command
 
$ passkey-agent --default <pin>
 
where ''<pin>'' is your headset's PIN. Then try to connect to the headset.
 
   
  +
==== Apple AirPods Pro は A2DP シンクとして PulseAudio で動作しますが、HSP/HFP では動作しません ====
=== ヘッドセットと ALSA デバイス ===
 
   
  +
AirPods Pro が PulseAudio で動作しているものの、HSP/HFP 構成を使用できない場合 (''pavucontrol''<nowiki/> の ''設定'' タブで、通常は使用不可として表示されます) に切り替えてみてください。{{Pkg|pipewire-pulse}}
1. まず[[公式リポジトリ]]から {{Pkg|bluez}} を[[インストール]]してください。
 
   
  +
''pipewire-pulse'' に切り替えると (コンピューターまたは適切なユーザーレベルの ''systemd'' サービスを再起動すると)、HSP/HFP が有効になりますが、A2DP が無効になる可能性があることに注意してください。(''設定'' タブで ''A2DP シンク'' を選択すると、オプションは即座に選択解除され、''オフ'' になります。) この問題が発生した場合は、次のように {{ic|/var/lib/bluetooth}} フォルダーを削除または名前変更します。
2. デバイスをスキャン。
 
$ hcitool (-i <optional hci#>***) scan
 
   
  +
# mv /var/lib/bluetooth /var/lib/bluetooth.bak
3. Pair your headset with your device:
 
$ bluez-simple-agent (optional hci# ***) XX:XX:XX:XX:XX:XX
 
and put in your pin (0000 or 1234, etc)
 
   
  +
その後、AirPods Pro (およびその他のデバイス) を再ペアリングします。これにより、すべての設定 (HSP/HFP および A2DP) が再び利用可能になり、''pavucontrol'' および ''pacmd'' から簡単にアクセスできるようになります。
4. Make sure your {{ic|/etc/bluetooth/audio.conf}} allows A2DP Audio Sinks. Place this line just bellow the [General] heading:
 
Enable=Source,Sink,Media,Socket
 
   
  +
==== HSP の問題: Bluetooth シンクとソースは作成されましたが、オーディオが送信されません ====
5. Add this to your {{ic|/etc/asound.conf}} file:
 
#/etc/asound.conf
 
 
pcm.btheadset {
 
type plug
 
slave {
 
pcm {
 
type bluetooth
 
device XX:XX:XX:XX:XX:XX
 
profile "auto"
 
}
 
}
 
hint {
 
show on
 
description "BT Headset"
 
}
 
}
 
ctl.btheadset {
 
type bluetooth
 
}
 
   
  +
ファームウェアが不足しているか、SCO (HSP および HFP のオーディオ プロトコル) ルーティングが間違っている可能性があります。[https://www.freedesktop.org/wiki/Software/PulseAudio/Documentation/User/Bluetooth/#index10h3] を参照してください。BCM20702 のファームウェアは、AUR 経由でインストールできます。{{AUR|bcm20702a1-firmware}} または {{AUR|bcm20702b0-firmware}}
6. Check to see if it has been added to alsa devices
 
$ aplay -L
 
   
  +
==== Error: Failed to start discovery org.bluez.Error.InProgress ====
7. Now play with aplay:
 
$ aplay -D btheadset /path/to/audio/file
 
   
  +
ヘッドセットは検出されたものの、"Error: Failed to start discovery org.bluez.Error.InProgress" というエラーが表示されて接続に失敗した場合は、{{AUR|bluez-hciconfig}} をインストールして実行してください。
or Mplayer:
 
$ mplayer -ao alsa:device=btheadset /path/to/audio/or/video/file
 
   
  +
$ hciconfig hci''X'' up
{{Tip|To find hci# for a usb dongle, type in
 
  +
$ hciconfig hci''X'' reset
$ hcitool dev
 
}}
 
   
  +
ここで、''X'' はコンピュータの Bluetooth デバイスの識別子 (通常は 0) です。
=== ヘッドセットのマルチメディアボタン ===
 
   
  +
[[Bluetooth ヘッドセット#CLI による設定|CLI による設定]] の手順に従って接続できるようになります。
In order to get your bluetooth headset's multimedia buttons (play, pause, next, previous) working you need to create {{ic|/etc/modules-load.d/uinput.conf}} containing {{ic|uinput}}.
 
   
== 旧式の方法: PulseAudio ==
+
==== ヘッドフォンと PulseAudio 間の同期による大音量 ====
   
  +
[https://www.freedesktop.org/wiki/Software/PulseAudio/Notes/15.0/#supportforbluetootha2dpavrcpabsolutevolume PulseAudio 15] 以降、''絶対音量'' はヘッドフォンのオーディオ音量を PulseAudio と連動させるため、PulseAudio なしで音量を変更することは不可能になります。もう一方。Hoco W25 などの一部のヘッドフォンでは、不快な音量が発生する可能性があります。''絶対音量'' を無効にするには、{{ic|/etc/pulse/default.pa}} を編集して次の行を変更します。
This one is much easier and more elegant. PulseAudio will seamlessly switch between output devices when the headset is turned on. If you have ALSA as the sound server, you need the following packages installed:
 
  +
load-module module-bluetooth-discover
{{Pkg|pulseaudio}} and {{Pkg|pulseaudio-alsa}}.
 
  +
から
  +
load-module module-bluetooth-discover avrcp_absolute_volume=false
   
  +
== HSV と A2DP の設定の切り替え ==
Now, to configure the audio output to use bluetooth, just install {{Pkg|pavucontrol}} and run it to configure the audio output:
 
$ pavucontrol
 
Make sure to take a look at the [[PulseAudio]] wiki entry for setting up PulseAudio, especially if you are running KDE.
 
   
  +
これは、次のコマンドで簡単に実現できます。{{ic|''card_number''}} は、{{ic|pacmd list-cards}} を実行することで取得できます。
=== トラブルシューティング ===
 
   
  +
$ pacmd set-card-profile ''card_number'' a2dp_sink
==== Audio sink fails ====
 
   
  +
ロールが設定されていない録画ストリームが表示されたときに A2DP から HSP へのプロファイルの自動切り替えを有効にするには、{{ic|1=auto_switch=2}} を {{ic|load-module module-bluetooth-policy}} に追加します。{{ic|/etc/pulse/default.pa}}
Bluetooth headset is connected, but ALSA/PulseAudio fails to pick up the connected device. You will get "Audio sink fails".
 
According to [http://wiki.gentoo.org/wiki/Bluetooth_Headset gentoo wiki], you have to verify than in {{ic|/etc/bluetooth/audio.conf}} there is {{ic|<nowiki>Enable=Socket</nowiki>}} under the {{ic|[General]}} section heading.
 
   
  +
PulseAudio プロファイルの詳細については、[https://freedesktop.org/wiki/Software/PulseAudio/Documentation/User/Bluetooth/#index1h2 PulseAudio Documentation] を参照してください。
Just do a {{ic|# systemctl restart bluetooth}} to apply it.
 
   
  +
=== PulseAudio で A2DP が動作しない ===
==== Page timeout issue ====
 
   
  +
==== Socket インターフェイスの問題 ====
If you receive this error whilst trying to pair your headset with your system using bluez-simple-agent, then you can try to restart your system and use the graphical bluez applet of your desktop environment.
 
   
  +
bluez 4.1+ と PulseAudio 3.0+ を使っていて、PulseAudio でプロファイルを A2DP に切り替えられない場合、{{ic|/etc/bluetooth/audio.conf}} を編集して {{ic|1=Enable=Socket}} という行を削除して {{ic|1=Disable=Socket}} という行を追加することで Socket インターフェイスを無効化できます。
== 旧式のドキュメント: ALSA, bluez5, PulseAudio の方法 ==
 
   
  +
==== A2DP シンクプロファイルが使用できません ====
[[ALSA]], [[bluez|bluez5]], and [[PulseAudio]] work together to allow a wireless [[Bluetooth]] headset to play audio. The following method works with a Lenovo T61p laptop and SoundBot SB220 wireless bluetooth headset. The required software stack is extensive and failure to include all components can produce errors which are difficult to understand. The following list of software packages might not be the minimum required set and needs to be examined more closely.
 
   
  +
A2DP シンクプロファイルが利用できない場合、PulseAudio フロントエンドを備えた A2DP シンク (出力) に切り替えることはできず、A2DP シンクはリストにも表示されません。これは、{{ic|pactl}} で確認できます。
Bluez5 has a regression causing HSP/HFP Telephone profile to not be available. This regression is documented in the [http://www.freedesktop.org/wiki/Software/PulseAudio/Notes/5.0/ draft release notes for Pulseaudio 5.0] which say (in "Notes for packagers"): "PulseAudio now supports BlueZ 5, but only the A2DP profile. BlueZ 4 is still the only way to make HSP/HFP work." ([https://fedoraproject.org/wiki/Common_F20_bugs#bluez5-profile from here])
 
   
  +
$ pactl list | grep -C2 A2DP
=== ソフトウェアパッケージのインストール ===
 
  +
Profiles:
  +
headset_head_unit: Headset Head Unit (HSP/HFP) (sinks: 1, sources: 1, priority: 30, available: yes)
  +
a2dp_sink: High Fidelity Playback (A2DP Sink) (sinks: 1, sources: 0, priority: 40, available: no)
  +
off: Off (sinks: 0, sources: 0, priority: 0, available: yes)
  +
Active Profile: headset_head_unit
   
  +
{{ic|pacmd}} を使用してカードプロファイルを手動で設定しようとすると失敗します。
The core software components are [[ALSA]], Bluez5, [[PulseAudio]]. However there are additional libraries which are required. As well as a player which can play audio files. The following section lists the software packages installed in order to connect the headset and play audio over the headset.
 
   
  +
$ pacmd set-card-profile bluez_card.C4_45_67_09_12_00 a2dp_sink
==== ALSA と関連ライブラリのインストール ====
 
  +
Failed to set card profile to 'a2dp_sink'.
   
  +
これは、Bluedevil または別の BlueZ フロントエンドを介して Bluetooth ヘッドフォンに接続するときに PulseAudio のバージョン 10.0 から発生することが知られています。[https://gitlab.freedesktop.org/pulseaudio/pulseaudio/issues/525 関連のバグレポート] を参照してください。
[[ALSA]] works with the linux kernel to provide audio services to user mode software. The following packages are used with the [[Bluetooth]] headset: {{Pkg|alsa-utils}}, {{Pkg|alsa-plugins}}, {{Pkg|alsa-tools}}.
 
   
  +
この問題は、デフォルトで {{ic|Handsfree}} または {{ic|Headset - HS}} に設定される可能性がある一部の Bluetooth コントローラ (例: {{ic|0a12:0001、Cambridge Silicon Radio}}) とヘッドフォンを最初にペアリングした後にも発生します。サービスを必要とするため、{{ic|AudioSink}} サービスを必要とする A2DP PulseAudio シンクへの切り替えは許可されません。
==== Bluez5 のインストール ====
 
   
  +
可能な解決策:
Bluez5 is the latest [[Bluetooth]] stack. It is required for [[PulseAudio]] to interface with wireless headsets. Required packages: {{Pkg|bluez}}, {{Pkg|bluez-utils}}, {{Pkg|bluez-libs}}.
 
   
  +
* 一部のヘッドセットでは、接続中にヘッドセットの音量または再生/一時停止コントロールを使用すると、A2DP プロファイルが使用可能になる可能性があります。
==== Audacious のインストール ====
 
  +
* {{pkg|bluez-utils}} から {{ic|bluetoothctl}} 経由でヘッドセットに接続すると、A2DP シンクプロファイルが利用可能になる可能性があります。Bluetooth デバイスが接続されるたびに、これが自動化されます: {{AUR|fix-bt-a2dp}} ([https://github.com/pastleo/fix-bt-a2dp#usage 詳細な使用法])
   
  +
[bluetooth]# connect ''headset_MAC_address''
[[Audacious]] is a program which plays audio files. It can work directly with [[ALSA]] or with [[PulseAudio]]. Required packages: {{Pkg|audacious}}, {{Pkg|audacious-plugins}}.
 
   
  +
* Bluetooth の {{ic|AudioSink}} サービスに手動で切り替えると、A2DP プロファイルとその A2DP PulseAudio シンクが利用可能になります。これは、{{pkg|blueman}} に含まれる blueman-manager を使用するか、AudioSink サービスの UUID を {{ic|bluetoothctl}} に登録することで実行できます。
=== Procedure ===
 
   
  +
$ bluetoothctl
Once the required packages are installed, use this procedure to play audio with a bluetooth headset. The high level overview of the procedure is to pair the headset, connect the headset, configure the player and pulse audio controller and then play audio.
 
  +
[bluetooth]# menu gatt
  +
[bluetooth]# register-service 0000110b-0000-1000-8000-00805f9b34fb
  +
[bluetooth]# quit
   
  +
* ヘッドセットプロファイルを無効にする
Start the bluetooth service as root:
 
# systemctl start bluetooth
 
   
  +
{{hc|/etc/bluetooth/main.conf|2=
Verify Bluetooth is started
 
  +
[General]
# systemctl status bluetooth
 
  +
Disable=Headset
bluetooth.service - Bluetooth service
 
  +
}}
Loaded: loaded (/usr/lib/systemd/system/bluetooth.service; disabled)
 
Active: active (running) since Sat 2013-12-07 12:31:14 PST; 12s ago
 
Docs: man:bluetoothd(8)
 
Main PID: 3136 (bluetoothd)
 
Status: "Running"
 
CGroup: /system.slice/bluetooth.service
 
└─3136 /usr/lib/bluetooth/bluetoothd
 
 
Dec 07 12:31:14 t61p systemd[1]: Starting Bluetooth service...
 
Dec 07 12:31:14 t61p bluetoothd[3136]: Bluetooth daemon 5.11
 
Dec 07 12:31:14 t61p systemd[1]: Started Bluetooth service.
 
Dec 07 12:31:14 t61p bluetoothd[3136]: Starting SDP server
 
Dec 07 12:31:14 t61p bluetoothd[3136]: Bluetooth management interface 1.3 i...ed
 
Hint: Some lines were ellipsized, use -l to show in full.
 
   
  +
* マルチプロファイルのサポートを有効にします。これは、A2DP およびヘッドセットオーディオをサポートするヘッドセットで役立つ場合があります。
Start the PulseAudio daemon. This must be done after X windows is started and as a normal user.
 
$ pulseaudio -D
 
   
  +
{{hc|/etc/bluetooth/main.conf|2=
Verify the PulseAudio daemon is running.
 
  +
[General]
$ pulseaudio --check -v
 
  +
MultiProfile=multiple
I: [pulseaudio] main.c: Daemon running as PID 3186
 
  +
}}
   
  +
* 場合によっては、上記の手順がどれも機能しない場合があります。再起動したり、Bluetooth の電源をオフにしたりオンにしたりしてみても効果が無い可能性があります。この場合、{{ic|bluetooth.service}} を [[再起動]] してみてください。
Start up bluetoothctl as root and pair and connect your headset. As a regular user, bluetoothctl will pair but not connect. Perhaps this is related to the config file (shown below) which is setup for what appears to be the root user.
 
  +
* オーディオコントロールパネルを備えた一部のヘッドフォンモデルでは、パネルの ''再生/一時停止'' ボタンを押して A2DP プロファイルを有効にする必要があります。
Note: the procedure shown below is for an initial pair and connect of the headphone. If the headset is already paired, then the procedure below can be shortened to: power on, agent on, default-agent, connect <mac address>. The mac address can be seen from the devices command output.
 
   
  +
==== GDM を使用した Gnome ====
$ bluetoothctl
 
[NEW] Controller 00:1E:4C:F4:98:5B t61p-0 [default]
 
[NEW] Device 00:1A:7D:12:36:B9 SoundBot SB220
 
[bluetooth]# show
 
Controller 00:1E:4C:F4:98:5B
 
Name: t61p
 
Alias: t61p-0
 
Class: 0x000000
 
Powered: no
 
Discoverable: no
 
Pairable: yes
 
UUID: PnP Information (00001200-0000-1000-8000-00805f9b34fb)
 
UUID: Generic Access Profile (00001800-0000-1000-8000-00805f9b34fb)
 
UUID: Generic Attribute Profile (00001801-0000-1000-8000-00805f9b34fb)
 
UUID: A/V Remote Control (0000110e-0000-1000-8000-00805f9b34fb)
 
UUID: A/V Remote Control Target (0000110c-0000-1000-8000-00805f9b34fb)
 
UUID: Audio Source (0000110a-0000-1000-8000-00805f9b34fb)
 
UUID: Audio Sink (0000110b-0000-1000-8000-00805f9b34fb)
 
Modalias: usb:v1D6Bp0246d050B
 
Discovering: no
 
[bluetooth]# power on
 
[CHG] Controller 00:1E:4C:F4:98:5B Class: 0x0c010c
 
Changing power on succeeded
 
[CHG] Controller 00:1E:4C:F4:98:5B Powered: yes
 
[bluetooth]# agent on
 
Agent registered
 
[bluetooth]# default-agent
 
Default agent request successful
 
   
  +
{{Merge|#Connecting works, but I cannot play sound|duplicate instructions}}
<power on your headset in pairing mode. Eventually you will see what appears to be a mac address.>
 
[bluetooth]# scan on
 
Discovery started
 
[CHG] Controller 00:1E:4C:F4:98:5B Discovering: yes
 
[CHG] Device 00:1A:7D:12:36:B9 RSSI: -61
 
[bluetooth]# pair 00:1A:7D:12:36:B9
 
Attempting to pair with 00:1A:7D:12:36:B9
 
[CHG] Device 00:1A:7D:12:36:B9 Connected: yes
 
[CHG] Device 00:1A:7D:12:36:B9 UUIDs has unsupported type
 
[CHG] Device 00:1A:7D:12:36:B9 Paired: yes
 
Pairing successful
 
[bluetooth]# connect 00:1A:7D:12:36:B9
 
[CHG] Device 00:1A:7D:12:36:B9 Connected: yes
 
Connection successful
 
[bluetooth]# info 00:1A:7D:12:36:B9
 
Device 00:1A:7D:12:36:B9
 
Name: SoundBot SB220
 
Alias: SoundBot SB220
 
Class: 0x240404
 
Icon: audio-card
 
Paired: yes
 
Trusted: no
 
Blocked: no
 
Connected: yes
 
LegacyPairing: yes
 
UUID: Headset (00001108-0000-1000-8000-00805f9b34fb)
 
UUID: Audio Sink (0000110b-0000-1000-8000-00805f9b34fb)
 
UUID: A/V Remote Control Target (0000110c-0000-1000-8000-00805f9b34fb)
 
UUID: A/V Remote Control (0000110e-0000-1000-8000-00805f9b34fb)
 
UUID: Handsfree (0000111e-0000-1000-8000-00805f9b34fb)
 
   
  +
以下の手順は Gnome 3.24.2 および PulseAudio 10.0 でテストされましたが、他のバージョンにも適用でき、役立つ可能性があります。
Start up alsamixer, for simplicity un-mute all your outputs. Oddly enough some can be muted though. The ones I had muted during playback were:
 
* Headphones
 
* SPIDF
 
   
  +
GDM で GNOME を使用しているときにプロファイルを A2DP に変更すると PulseAudio が失敗する場合は、GDM が独自の PulseAudio インスタンスを開始しないようにする必要があります。
Start up audacious. Use the menu to select PulseAudio as your output. Somewhere I read that bluez5 requires pulseaudio-git and this jives with my experience.
 
   
  +
* 以下を追加することで、サーバーが実行されていない場合に PulseAudio クライアントがサーバーを自動的に起動しないようにします。
Start up pavucontrol in a terminal. In the Outputs tab select the bluetooth headset.
 
   
  +
{{hc|/var/lib/gdm/.config/pulse/client.conf|2=
[http://netskink.blogspot.com/2013/12/pulseaudio-pavucontrol-and-audacious.html screenshot of application settings]
 
  +
autospawn = no
  +
daemon-binary = /bin/true
  +
}}
   
  +
* ソケットをアクティブ化しても systemd が PulseAudio を開始しないようにします。
==== Miscellaneous configuration files ====
 
   
  +
$ sudo -ugdm mkdir -p /var/lib/gdm/.config/systemd/user
For reference, these settings were also done.
 
  +
$ sudo -ugdm ln -s /dev/null /var/lib/gdm/.config/systemd/user/pulseaudio.socket
   
  +
* 再起動し、次のコマンドを使用して、{{ic|gdm}} ユーザーの PulseAudio プロセスがないことを確認します。
===== ALSA /etc/asound.conf =====
 
   
  +
$ pgrep -u gdm pulseaudio
The settings shown at the top of this page was used, but the additional modification for Intel laptop sound cards.
 
   
  +
この問題と代替修正に関する詳細な議論は、[https://bbs.archlinux.org/viewtopic.php?id=194006] および [https://bbs.archlinux.org/viewtopic.php?id=196689] で参照できます。あるいは、{{AUR|fix-bt-a2dp}} をインストールしてみることもできます。
{{bc|<nowiki>
 
pcm.btheadset {
 
type plug
 
slave {
 
pcm {
 
type bluetooth
 
device 00:1A:7D:12:36:B9
 
profile "auto"
 
}
 
}
 
hint {
 
show on
 
description "BT Headset"
 
}
 
}
 
ctl.btheadset {
 
type bluetooth
 
}
 
options snd-hda-intel model=laptop
 
</nowiki>}}
 
   
  +
=== HFP が PulseAudio で動作しない ===
===== /etc/dbus-1/system.d/bluetooth.conf =====
 
   
  +
{{Note|一部のユーザーは、Bluetooth サポートのために PulseAudio を PipeWire に置き換えることで HFP サポートを有効にすることに成功したと報告しています。[https://www.reddit.com/r/archlinux/comments/w69mij/hfp_audio_is_no_longer_available_stuck_on/] インストール手順については、[[Bluetooth ヘッドセット#PipeWire 経由のヘッドセット]] を参照してください。}}
The settings here seem to be enabled for root only. See the policy user="root" section. However, if a regular user is specified here, the system fails to start. Someone with more knowledge could explain why.
 
   
  +
HFP 専用 Bluetooth ヘッドセットは、PulseAudio の標準構成では使用できない場合があります。それぞれのプロファイルが存在しますが、使用できません。
{{hc|/etc/dbus-1/system.d/bluetooth.conf|<nowiki>
 
<!-- This configuration file specifies the required security policies for Bluetooth core daemon to work. -->
 
   
  +
{{hc|bluetoothctl info|
<!DOCTYPE busconfig PUBLIC "-//freedesktop//DTD D-BUS Bus Configuration 1.0//EN"
 
  +
UUID: Audio Sink (0000110b-0000-1000-8000-00805f9b34fb)
"http://www.freedesktop.org/standards/dbus/1.0/busconfig.dtd">
 
  +
UUID: A/V Remote Control Target (0000110c-0000-1000-8000-00805f9b34fb)
<busconfig>
 
  +
UUID: A/V Remote Control (0000110e-0000-1000-8000-00805f9b34fb)
  +
UUID: Handsfree (0000111e-0000-1000-8000-00805f9b34fb)
  +
}}
   
  +
{{hc|pactl list|
<!-- ../system.conf have denied everything, so we just punch some holes -->
 
  +
...
  +
Profiles:
  +
...
  +
headset_head_unit: Headset Head Unit (HSP/HFP) (sinks: 1, sources: 1, priority: 30, available: no)
  +
}}
   
  +
それぞれの問題を解決するには、PulseAudio と BlueZ を最新バージョンに更新します。次に、{{AUR|ofono}} と {{AUR|phonesim}} を [[インストール]] ここ [https://www.freedesktop.org/wiki/Software/PulseAudio/Documentation/User/Bluetooth/#index1h3] の説明に従って偽のモデム​​を作成/アクティブ化します。:
<policy user="root">
 
<allow own="org.bluez"/>
 
<allow send_destination="org.bluez"/>
 
<allow send_interface="org.bluez.Agent1"/>
 
<allow send_interface="org.bluez.MediaEndpoint1"/>
 
<allow send_interface="org.bluez.MediaPlayer1"/>
 
<allow send_interface="org.bluez.ThermometerWatcher1"/>
 
<allow send_interface="org.bluez.AlertAgent1"/>
 
<allow send_interface="org.bluez.Profile1"/>
 
<allow send_interface="org.bluez.HeartRateWatcher1"/>
 
<allow send_interface="org.bluez.CyclingSpeedWatcher1"/>
 
</policy>
 
   
  +
{{Note|{{ic|phonesim.conf}} の作成後の手順は、ヘッドセットを接続する ''たびに'' 実行する必要があります}}
<policy at_console="true">
 
<allow send_destination="org.bluez"/>
 
</policy>
 
   
  +
* 以下を使用して {{ic|/etc/ofono/phonesim.conf}} を作成します。
<!-- allow users of lp group (printing subsystem) to communicate with bluetoothd -->
 
<policy group="lp">
 
<allow send_destination="org.bluez"/>
 
</policy>
 
   
  +
[phonesim]
<policy context="default">
 
  +
Address=127.0.0.1
<deny send_destination="org.bluez"/>
 
  +
Driver=phonesim
</policy>
 
  +
Port=12345
   
  +
* ユーザーとして開始:
</busconfig>
 
</nowiki>}}
 
   
  +
$ phonesim -p 12345 /usr/share/phonesim/default.xml &
===== テスト済みのアプリケーション =====
 
   
  +
* {{ic|ofono.service}} を [[起動/有効化]] します。
As noted above this will work easily with audacious. YouTube videos with Chromium and Flash Player will work on some videos. If the video has ads it will not work, but if the video does not have ads it will work. Just make sure that after audacious is working with Bluetooth headset, start Chromium, and navigate to YouTube. Find a video without leading ads, and it should play the audio. If the settings icon has the a menu with two drop-down combo boxes for Speed and Quality it will play.
 
  +
* パワーモデム:
   
  +
$ dbus-send --print-reply --system --dest=org.ofono /phonesim org.ofono.Modem.SetProperty string:"Powered" variant:boolean:true
== HSV と A2DP の設定の切り替え ==
 
   
  +
* モデムをアクティブ化します:
This can easily be achieved by the following command where 2 needs to be changed with the correct device number.
 
   
  +
$ dbus-send --print-reply --system --dest=org.ofono /phonesim org.ofono.Modem.SetProperty string:"Online" variant:boolean:true
pacmd set-card-profile 2 a2dp_sink
 
   
  +
* 結果を確認するには、{{ic|/usr/lib/ofono/test/}} にインストールされている {{AUR|ofono}} のテストコマンドを使用します。モデムの電源を投入、アクティブ化、テストするには、以下を使用できます。
=== PulseAudio で A2DP が動作しない ===
 
  +
  +
$ /usr/lib/ofono/test/enable-modem /phonesim
  +
$ /usr/lib/ofono/test/online-modem /phonesim
  +
$ /usr/lib/ofono/test/list-modems
  +
  +
それぞれのモデムセクションの出力は次のようになります。
  +
  +
...
  +
[ /phonesim ]
  +
Online = 1
  +
Powered = 1
  +
Lockdown = 0
  +
Emergency = 0
  +
Manufacturer = MeeGo
  +
...
  +
  +
* 最後に、PulseAudio を再起動し、ヘッドセットを再接続します。これで、HFP が利用可能になるはずです。
  +
  +
headset_head_unit: ヘッドセットヘッドユニット (HSP/HFP) (sinks: 1, sources: 1, priority: 30, available: yes)
  +
  +
{{Note|HFP サポートは安定していないため、A2DP への切り替え時に問題が発生する可能性があります。必要なモードが利用できない場合は、再接続してみてください}}
  +
  +
=== PulseAudio ヘッドセットの HSP/HFP への自動切り替えを無効にする ===
  +
  +
複数のプロファイルをサポートする Bluetooth ヘッドセットを使用すると、一部のアプリケーションは自動的に HSP/HFP プロファイルに切り替わります。この動作を望まない場合は、auto_switch=false パラメータを Bluetooth ポリシーモジュールに追加することでこれを無効にできます。
  +
  +
{{hc|/etc/pulse/default.pa|2=
  +
load-module module-bluetooth-policy auto_switch=false
  +
}}
  +
  +
=== PipeWire HSP/HFP プロファイルを無効にする ===
  +
  +
PulseAudio とは異なり、[[PipeWire#プロファイルの自動選択機能|PipeWire は入力イベントに応じて A2DP と HSP/HFP を自動的に切り替えません]] ただし、A2DP が失敗した場合に (低音質の) HSP/HFP プロファイルへの自動的な切り替えを有効にするのではなく、前者を完全に無効にした方がよい場合もあります。これを行うには、{{ic|/usr/share/wireplumber/bluetooth.lua.d/50-bluez-config.lua}} のコピーを作成します。以下に示すように、[https://www.reddit.com/r/archlinux/comments/x29emb/purge_hsphfp_support/]
  +
  +
{{Note|内蔵マイクが動作するには HSP モードが必要です [https://www.reddit.com/r/pop_os/comments/otofgt/bluetooth_headphone_switches_to_hsphfp_when/]}}
  +
  +
{{hc|/etc/wireplumber/bluetooth.lua.d/50-bluez-config.lua (or ~/.config/wireplumber/bluetooth.lua.d/50-bluez-config.lua)|2=
  +
...
  +
bluez_monitor.properties = {
  +
...
  +
'''["bluez5.headset-roles"] = "[ ]",'''
  +
...
  +
'''["bluez5.hfphsp-backend"] = "none",'''
  +
}
  +
...
  +
bluez_monitor.rules = {
  +
{
  +
...
  +
apply_properties = {
  +
...
  +
'''["bluez5.auto-connect"] = "[ a2dp_sink ]",'''
  +
...
  +
''' ["bluez5.hw-volume"] = "[ a2dp_sink ]",'''
  +
},
  +
...
  +
},
  +
}
  +
}}
  +
  +
== ヒントとテクニック ==
  +
  +
以下は PipeWire と PulseAudio の両方に適用されます。
  +
  +
=== バッテリーレベルのレポート ===
  +
  +
{{Note|これは実験的な機能です。これを有効にすると、一部の Bluetooth マウスが自動的に接続されなくなる可能性があります ([https://github.com/bluez/bluez/issues/236 GitHub issue] を参照)}}
  +
  +
{{Pkg|upower}} に報告されているヘッドセットの現在のバッテリー レベルを取得するには、[[Bluetooth#実験的な機能を有効化する]] で説明されているように、bluez の D-Bus 実験的機能を有効にする必要があります。
  +
  +
=== メディアコントロール ===
  +
  +
メディアコントロールを使用するために、MPRIS に転送して、そこで MPRIS をサポートするメディアプレーヤーが外部コントロールのためにピックアップする必要があります。詳しくは [[MPRIS#Bluetooth]] を参照してください。
  +
  +
=== 代替: A2DP 二重チャネル ===
  +
  +
FastStream、AptX LL、および "Opus 05 Pro" ([https://gitlab.freedesktop.org/pipewire/pipewire/-/merge_requests/1322 a pipewire invention]) には、マイクの音声を送り返すことができる "二重" チャネルがあります。 HSP/HFP を使用する必要がなく、音質の劣化を許容できます。PipeWire はこの機能をサポートしていますが、PulseAudio はサポートしていません。サポートは機能が検出されると自動的に行われます。既存のプロファイルスイッチャー (WirePlumber) との相互作用は不明です。
  +
  +
これはデバイスの切断と再接続時にリセットされるため、次のような [[udev]] ルールを介して自動的に設定することが望ましいと考えられます:
  +
  +
SUBSYSTEM=="input" ATTR{name}=="Soundcore Life P3 (AVRCP)" ATTR{inhibited}="1"
   
  +
通常のユーザーとしてこの属性を変更できるようにしたい場合は、[[udev#通常ユーザーにデバイスの使用を許可する]] を参照してください。
If PulseAudio fails when changing the profile to A2DP with bluez 4.1+ and PulseAudio 3.0+, you can try disabling the Socket interface from {{ic|/etc/bluetooth/audio.conf}} by removing the line {{ic|1=Enable=Socket}} and adding line {{ic|1=Disable=Socket}}.
 
   
 
== テスト済みのヘッドセット ==
 
== テスト済みのヘッドセット ==
465行目: 588行目:
 
! 対応状況
 
! 対応状況
 
|-
 
|-
| '''Philips SHB9150'''
+
| '''Philips SHB3060'''
  +
| bluez 5.40, PulseAudio 9.0
| bluez5, pulseaudio 5
 
  +
| ボタンが機能しません。対応プロファイル: HSP (マイクロフォンも動作) と A2DP。
| Pause and resume does not work. With at least mpv and Banshee hitting the pause button stops audio output but does not pause the player.
 
  +
| {{Yes}}
  +
|-
  +
| '''Philips SHB4000WT'''
  +
| bluez5
  +
| A2DP で動作、HDP は問題あり。
  +
| {{Yes}}
  +
|-
  +
| '''Philips SHB5500BK/00'''
  +
| bluez 5.28, PulseAudio 6.0
  +
| 停止・再生が機能せず。
 
| {{R|Limited}}
 
| {{R|Limited}}
  +
|-
  +
| '''Philips SHB7000'''
  +
|
  +
| 停止・再生がおかしい。
  +
| {{R|Limited}}
  +
|-
  +
| '''Philips SHB7100'''
  +
| bluez 5.32, pulseaudio 6.0
  +
| 次へ・前へボタンも動作。停止・再生は微妙 (VLC では動くこともあるが、Audacious では全く機能しない)。A2DP と Handsfree の音声出力のみで確認。マイクは機能せず。
  +
| {{R|Limited}}
  +
|-
  +
| '''Philips SHB7150'''
  +
| bluez 5.32, pulseaudio 6.0
  +
| 次へ・前へボタンも動作。停止・再生は VLC では動作。A2DP プロファイルでのみ確認。
  +
| {{Yes}}
 
|-
 
|-
 
| '''Philips SHB9100'''
 
| '''Philips SHB9100'''
 
|
 
|
| Pause and resume is flaky. See [https://bbs.archlinux.org/viewtopic.php?pid=1315428#p1315428] for the underlying issue and a temporary solution to improve audio quality.
+
| 停止・再生がおかしい。音質を改善する一時的な方法は [https://bbs.archlinux.org/viewtopic.php?pid=1315428#p1315428] を参照。
 
| {{R|Limited}}
 
| {{R|Limited}}
 
|-
 
|-
| '''Philips SHB7000'''
+
| '''Philips SHB9150'''
  +
| bluez5, pulseaudio 9
 
|
 
|
  +
| {{Yes}}
| Pause and resume is flaky.
 
  +
|-
  +
| '''Philips AEA2000/12'''
  +
| bluez5
  +
|
  +
| {{Yes}}
  +
|-
  +
| '''Parrot Zik'''
  +
|
  +
| マイクは認識されますが機能しません (HSP プロファイルは使えません)。Bluetooth 接続が切れると、音声に遅延が発生します。Bluetooth 接続を初期化することで解決します。
 
| {{R|Limited}}
 
| {{R|Limited}}
 
|-
 
|-
| '''Philips SHB5500BK/00'''
+
| '''Parrot Zik 2.0'''
  +
|
| bluez 5.28, PulseAudio 6.0
 
  +
| マイクは認識されますが機能しません (HSP プロファイルは使えません)。Bluetooth 接続が切れると、音声に遅延が発生します。Bluetooth 接続を初期化することで解決します。
| Pause and resume is not working.
 
 
| {{R|Limited}}
 
| {{R|Limited}}
 
|-
 
|-
| '''Parrot Zik'''
+
| '''Parrot Zik 3.0'''
 
|
 
|
  +
| マイクは認識されますが機能しません (HSP プロファイルは使えません)。遅延の問題はありません。
| Firmware 1.04. The microphone is detected, but does not work. Sometimes it lags (but does not stutter); usually this is not noticeable unless playing games, in which case you may switch to a wired connection.
 
 
| {{R|Limited}}
 
| {{R|Limited}}
 
|-
 
|-
 
| '''Sony DR-BT50'''
 
| '''Sony DR-BT50'''
 
| bluez{4,5}
 
| bluez{4,5}
| Works for a2dp, see [http://vlsd.blogspot.com/2013/11/bluetooth-headphones-and-arch-linux.html]). Adapter: D-Link DBT-120 USB dongle.
+
| a2dp で動作。[http://vlsd.blogspot.com/2013/11/bluetooth-headphones-and-arch-linux.html] を参照。アダプタ: D-Link DBT-120 USB ドングル。
  +
| {{Yes}}
  +
|-
  +
| '''Sony SBH20'''
  +
| bluez 5.30, pulseaudio 6.0
  +
| A2DP プロファイルで問題なく動作。
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
 
| '''Sony SBH50'''
 
| '''Sony SBH50'''
 
| bluez5
 
| bluez5
| Works for a2dp, Adapter: Broadcom Bluetooth 2.1 Device (Vendor=0a5c ProdID=219b Rev=03.43). Requires the {{ic|btusb}} [[modprobe|module]].
+
| a2dp で動作。アダプタ: Broadcom Bluetooth 2.1 Device (Vendor=0a5c ProdID=219b Rev=03.43){{ic|btusb}} [[modprobe|モジュール]]が必要。
  +
| {{Yes}}
  +
|-
  +
| '''Sony SBH80'''
  +
| bluez 5.36, pulseaudio 7.1
  +
| メディアボタンは機能せず。blueman でプロファイルを無効化して A2DP を有効化することで動作。
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
 
| '''Sony MDR-XB950BT'''
 
| '''Sony MDR-XB950BT'''
 
| pulseaudio
 
| pulseaudio
  +
| a2dp でテスト済み。アダプタ: Grand-X BT40G。自動で接続されない場合、手動で接続する必要があります。他の機能は問題なく動作。
| Tested a2dp. Adapter: Grand-X BT40G. Doesn't auto-connect, need to connect manually. Other functionality works fine.
 
 
| {{R|Limited}}
 
| {{R|Limited}}
  +
|-
  +
| '''Sony MDR-ZX330BT'''
  +
| bluez 5.31, pulseaudio 6.0
  +
| 何も設定しなくても動作 (HSP/HFP と A2DP)。ボタンは特定のアプリで動作。
  +
| {{Yes}}
 
|-
 
|-
 
| '''Sony MUC-M1BT1'''
 
| '''Sony MUC-M1BT1'''
 
| bluez5, {{AUR|pulseaudio-git}}
 
| bluez5, {{AUR|pulseaudio-git}}
| Both A2DP & HSP/HFP work fine.
+
| A2DP & HSP/HFP どちらも問題なく動作。
  +
| {{Yes}}
  +
|-
  +
| '''Sony WH-1000XM3'''
  +
| bluez5, {{AUR|pulseaudio-git}}
  +
| A2DP & HSP/HFP どちらも動作。マイク、側面のタッチコントロールも使用可能です。
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
517行目: 695行目:
 
| '''Auna Air 300'''
 
| '''Auna Air 300'''
 
| bluez5, pulseaudio-git
 
| bluez5, pulseaudio-git
  +
| 何らかの理由で、再起動が必要ですが、それで問題なく起動します。
| For some reason, a few restarts were required, and eventually it just started working.
 
 
| {{R|Limited}}
 
| {{R|Limited}}
 
|-
 
|-
527行目: 705行目:
 
| '''Sennheiser MM 550-X Travel'''
 
| '''Sennheiser MM 550-X Travel'''
 
| bluez 5.27-1, pulseaudio 5.0-1
 
| bluez 5.27-1, pulseaudio 5.0-1
  +
| 次・前ボタンは何も設定しなくても動作しますが、再生・停止ボタンは動作しません。
| Next/Previous buttons work out-of-the-box, Play/Pause does not
 
  +
| {{Yes}}
  +
|-
  +
| '''Sennheiser URBANITE XL Wireless'''
  +
| bluez 5.37-2, pulseaudio 7.1-3
  +
| A2DP 高音質再生。再生・停止・次へ・前へも問題なく動作。
  +
| {{Yes}}
  +
|-
  +
| '''Sennheiser Momentum 2'''
  +
| bluez5, pulseaudio 9.0-1
  +
| GDM で起動できない問題を解決しないと A2DP プロファイルの変更に失敗することがあります。
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
537行目: 725行目:
 
| '''Logitech Wireless Headset'''
 
| '''Logitech Wireless Headset'''
 
| bluez 5.14, pulseaudio-git
 
| bluez 5.14, pulseaudio-git
| part number PN 981-000381, advertised for use with iPad
+
| 製造番号 PN 981-000381。iPad 用と喧伝されているヘッドセット。
  +
| {{Yes}}
  +
|-
  +
| '''Logitech UE9000'''
  +
| bluez 5.37, pulseaudio 7.1, gnome 3.18.2
  +
| [[#接続は成功するが、音が聞こえない|gnome/gdm の修正]]をすることで再生可能。音声プロファイルのデフォルトは HSP/HFP。マイクは HSP/HFP と A2DP プロファイルのどちらでも動作。再生・停止や次へ・前へは Spotify や VLC で機能する。
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
547行目: 740行目:
 
| '''PT-810'''
 
| '''PT-810'''
 
| bluez 5.14, pulseaudio-git
 
| bluez 5.14, pulseaudio-git
| Generic USB-Powered Bluetooth Audio Receiver with 3.5mm headset jack and a2dp profile. Widely available as "USB Bluetooth Receiver." IDs as PT-810.
+
| 汎用の USB 給電 Bluetooth 音声レシーバー。3.5mm ヘッドセットジャックと a2dp プロファイルで機能。"USB Bluetooth Receiver" ID として PT-810 は広く使えます。
| {{Yes}}
 
|-
 
| '''Philips SHB4000WT'''
 
| bluez5
 
| A2DP works, HDP distorted.
 
| {{Yes}}
 
|-
 
| '''Philips AEA2000/12'''
 
| bluez5
 
|
 
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
567行目: 750行目:
 
| '''Creative AirwaveHD'''
 
| '''Creative AirwaveHD'''
 
| bluez 5.23
 
| bluez 5.23
| Bluetooth adapter Atheros Communications usb: 0cf3:0036
+
| Bluetooth アダプタ Atheros Communications usb: 0cf3:0036
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
 
| '''Creative HITZ WP380'''
 
| '''Creative HITZ WP380'''
 
| bluez 5.27, pulseaudio 5.0-1
 
| bluez 5.27, pulseaudio 5.0-1
  +
| A2DP プロファイルのみ。ボタンも動作 (再生, 停止, 次へ, 前へ)。ボリュームボタンはハードウェアのみ。自動接続もできるが bluetooth モジュールを "pulseaudio" に組み込んで自動的に切り替えさせる必要がある。ハイレゾ再生もクリア (デバイスとしては APTx コーデックをサポートしていますが Linux ではまだ対応されていません)。遅延の問題が発生するときは pulseaudio を再起動する必要あり。
| A2DP Profile only. Buttons work (Play, Pause, Prev, Next). Volume buttons are hardware-only. Auto-connect works but you should include the bluetooth module in "pulseaudio" to switch to it automatically. Clear HD Music Audio (This device support APTx codec but it isn't supported in linux yet). You may have some latency problems which needs pulseaudio restart.
 
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
 
| '''deleyCON Bluetooth Headset'''
 
| '''deleyCON Bluetooth Headset'''
 
| bluez 5.23
 
| bluez 5.23
  +
| アダプタ: CSL - USB nano Bluetooth-Adapter V4.0。a2dp プロファイルでテスト。マイクは未テスト。(ペアリングしても) 自動接続は行われないため、手動で接続する必要あり。再生/停止ボタンを押すとヘッドフォンがミュート/アンミュートになるが、再生には影響なし。次に進む/前に戻るボタンは動作せず (''xev'' で変化なし)。
| Adapter: CSL - USB nano Bluetooth-Adapter V4.0. Tested a2dp profile. Untested microphone. Does not auto-connect (even when paired and trusted), must connect manually. Play/pause button mutes/unmutes the headphones, not the playback. Playback fwd/bwd buttons do not work (nothing visible with ''xev'').
 
 
| {{R|Limited}}
 
| {{R|Limited}}
 
|-
 
|-
 
| '''UE BOOM'''
 
| '''UE BOOM'''
 
| bluez 5.27, pulseaudio-git 5.99
 
| bluez 5.27, pulseaudio-git 5.99
  +
| 最新の UE BOOM fw 1.3.58 にアップデート。動画再生における音声の遅延は pavucontrol を設定することで解決できる。UE BOOM x2 で動作。
| Update to latest UE BOOM fw 1.3.58. Sound latency in video solved by configuring pavucontrol. Works with UE BOOM x2.
 
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
 
| '''LG HBS-730'''
 
| '''LG HBS-730'''
| bluez 5.27, pulseaudio 5.0
+
| bluez 5.30, pulseaudio 6.0
  +
| A2DP プロファイルで何も設定しなくても動作。
| Works out of box.
 
  +
| {{Yes}}
  +
|-
  +
| '''LG HBS-750'''
  +
| bluez 5.30, pulseaudio-git 6.0
  +
| A2DP プロファイルで何も設定しなくても動作。
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
 
| '''Beats Studio Wireless'''
 
| '''Beats Studio Wireless'''
 
| bluez 5.28, pulseaudio 6.0
 
| bluez 5.28, pulseaudio 6.0
  +
| 何も設定しなくても動作。マルチメディアボタンは未テスト。
| Works out of box. Not tested multimedia buttons.
 
 
| {{Yes}}
 
| {{Yes}}
 
|-
 
|-
 
| '''AKG Y45BT'''
 
| '''AKG Y45BT'''
| bluez 5.28, pulseaudio 6.0
+
| bluez 5.30, pulseaudio 6.0
  +
| 停止・再生が動作せず。{{ic|/etc/bluetooth/audio.conf}} に {{ic|1=Enable=Socket}} を、{{ic|/etc/pulse/default.pa}} に {{ic|load-module module-bluetooth-discover}} を設定する必要あり。
| Pause and resume does not work. Needs {{ic|1=Enable=Socket}} in {{ic|/etc/bluetooth/audio.conf}}.
 
  +
| {{Yes}}
  +
|-
  +
| '''Bluedio Turbine/Turbine 2+'''
  +
| bluez 5.3, pulseaudio 6.0
  +
| HSP/HFP で動作、A2DP も問題なく動作。
  +
| {{Yes}}
  +
|-
  +
| '''Nokia BH-111'''
  +
| bluez 5.30, pulseaudio 6.0
  +
| HSP/HFP と A2DP どちらでも動作。ボタンは特定のアプリで動作。
  +
| {{Yes}}
  +
|-
  +
| '''Samsung Level Link'''
  +
| bluez 5.33, pulseaudio 6.0
  +
| 何も設定しなくても動作 (HSP/HFP と A2DP)。ボタンは特定のアプリで動作。
  +
| {{Yes}}
  +
|-
  +
| '''Bernafon Soundgate 3'''
  +
| bluez 5.34-2, pulseaudio 7.0-1
  +
| blueman-git 2.0.r53.g2a812a8-1 をインストールすることで動作 (A2DP)。
  +
| {{Yes}}
  +
|-
  +
| '''JBL E40 BT'''
  +
| bluez 5.35, pulseaudio 7.0
  +
| blueberry と blueman をインストールすることで接続可能。{{ic|1=Disable=Socket}} を {{ic|/etc/bluetooth/audio.conf}} に追加することで A2DP が動作。メディアボタンも動作。
  +
| {{Yes}}
  +
|-
  +
| '''JBL Everest 300'''
  +
| bluez 5.37, pulseaudio 8.0
  +
| 全てが問題なく動作。HSP/HFP プロファイルでヘッドフォンを接続すると音質が悪いが、'''pavucontrol''' でプロファイルを A2DP sink に切り替えることで音質はかなり改善する。ペアリングに問題なし。
  +
| {{Yes}}
  +
|-
  +
| '''Kitsound Manhattan'''
  +
| bluez 5.37, pulseaudio 7.13
  +
| 全て問題なし。Pulseaudio をユーザーでなく root で ( --system) 動作させた場合、ペアリングしても接続できなかったり、(アクセス PIN を要求して) システムがフリーズしてしまう可能性あり。注意が必要。
  +
| {{Yes}}
  +
|-
  +
| '''Jawbone Jambox'''
  +
| bluez 5.38, pulseaudio 8.0
  +
|
  +
| {{Yes}}
  +
|-
  +
| '''Plantronics BackBeat FIT'''
  +
| bluez5, pulseaudio 8.0
  +
| ヘッドセットと a2dp プロファイルどちらも完全に動作。停止ボタンでプレイヤーを停止できます ([[mpv]] で確認)。
  +
| {{Yes}}
  +
|-
  +
| '''Plantronics BackBeat Pro'''
  +
| bluez5, pulseaudio 9.0
  +
| ヘッドセットと a2dp プロファイルどちらも完全に動作。停止ボタンを押したりヘッドセットを外すとプレイヤーが停止します。
  +
| {{Yes}}
  +
|-
  +
| '''Aukey EP-B26'''
  +
| bluez 5.39-1, pulseaudio 8.0-3
  +
| ヘッドセット (低品質) と a2dp (高品質) プロファイルどちらも完全に動作。停止ボタンでプレイヤーを停止したり、次・前ボタンで曲を変えられます。マイクは HSP/HFP モードでのみ動作。
  +
| {{Yes}}
  +
|-
  +
| '''Bose AE2 SoundLink'''
  +
| bluez 5.36, pulseaudio 7.1
  +
| 停止・再生ボタンが動作しません。マイクも使えません。
  +
| {{R|Limited}}
  +
|-
  +
| '''Bose QuietComfort 35'''
  +
| bluez 5.41, pulseaudio 9.0
  +
| {{ic|1=ControllerMode=bredr}} を設定することでペアリングできます。
  +
| {{Yes}}
  +
|-
  +
| '''Blue Tiger Dual Elite'''
  +
| bluez-5.42-1, pulseaudio 9.0-1
  +
| {{ic|1=pulseaudio-bluetooth}} パッケージで接続できます。マイクや操作ボタンは未確認。
 
| {{Yes}}
 
| {{Yes}}
 
|}
 
|}
603行目: 861行目:
 
== 参照 ==
 
== 参照 ==
   
  +
Windows と Linux でペアリングを解除しないでデバイスを共有する方法:
Using the same device on Windows and Linux without pairing the device over and over again
 
   
* [http://ubuntuforums.org/showthread.php?p=9363229#post9363229 Dual booting with a Bluetooth keyboard]
+
* [https://ubuntuforums.org/showthread.php?p=9363229#post9363229 Dual booting with a Bluetooth keyboard]

2024年4月6日 (土) 21:51時点における最新版

関連記事

Bluetooth オーディオシステムには次の 3 つがあります:

  • A2DP (高度なオーディオ配信) は、通常は入力 (ソース) なしで、音楽グレードのステレオ出力 (シンク) を提供します。
    • A2DP はさまざまなコーデックを使用できます。標準の SBC には品質とビットレートのトレードオフが劣りますが、はるかに優れた代替手段としてオープンソースの (LDAC、AptX) が普及しています。
    • AVRCP は、再生制御を提供するために A2DP の上で使用されます。
  • HFP/HSP (ハンズフリー/ヘッドセット) は音声グレードのモノラル出力と入力を提供します。HFP は HSP の上に構築されます。
  • LE Audio は 2020 年に発表された低エネルギーオーディオ規格です。標準コーデックは LC3 です。

カーネル、BlueZ5、および PipeWire は、3 つのプロファイルすべてをサポートします。PulseAudio や ALSA などの古いサウンドサーバーは、A2DP と HFP/HSP のみをサポートします。Bluetooth は信頼性が低いことで悪名が高い [1] ですが、多くの実装では大幅な改善が見られ、Intel Bluetooth チップのような確立されたハードウェアでの耐え難いエクスペリエンスが多少軽減されています。

目次

PipeWire 経由のヘッドセット

PipeWirePulseAudio のドロップイン代替品として機能し、Bluetooth ヘッドセットをセットアップする簡単な方法を提供します。これには、SBC/SBC-XQ、AptX、LDAC または AAC コーデック、および HFP/HSP を使用した A2DP シンクプロファイルのすぐに使えるサポートが含まれています。

pipewire-pulse (pulseaudiopulseaudio-bluetoothインストール して置き換えます)

デーモンは user service として自動的に起動されます。設定には、pavucontrol またはデスクトップ環境の設定を使用します。詳細については、PipeWire#Bluetooth デバイス を参照してください。

Bluez5/PulseAudio 経由のヘッドセット

PulseAudio 5.x はデフォルトで A2DP をサポートしています。以下のパッケージをインストールしてください: pulseaudio-alsa, pulseaudio-bluetooth, bluez, bluez-libs, bluez-utils, bluez-firmwareAURpulseaudio-bluetooth がないとペアリングした後に接続することができなくなります。エラーメッセージは表示されません。

Bluetooth システムを起動:

# systemctl start bluetooth

bluetoothctl コマンドラインユーティリティを使うことでペアリングと接続が行えます。bluetoothctl に関する詳細やトラブルシューティングは Bluetooth の記事を見てください。次のコマンドを実行することでコマンドプロンプトを開きます:

# bluetoothctl

そして以下を入力:

# power on
# agent on
# default-agent
# scan on

ヘッドセットをペアリングモードにします。ヘッドセットは簡単に確認できます。例えば:

[NEW] Device 00:1D:43:6D:03:26 Lasmex LBT10

上記の場合、デバイスの名前は "Lasmex LBT10" で MAC アドレスは 00:1D:43:6D:03:26 です。この MAC アドレスを使ってペアリングを開始します:

# pair 00:1D:43:6D:03:26

ペアリングが完了したら、デバイスを明示的に接続する必要があります (every time?):

# connect 00:1D:43:6D:03:26

全てが上手くいけば、PulseAudio にアウトプットデバイスが新しく作られます。

ノート: デバイスはデフォルトではオフになっています。pavucontrol の "Configuration" タブでオーディオプロファイル (OFF, A2DP, HFP) を選択してください。

pavucontrol の "Playback" や "Recording" タブを使うことでデバイスに音声を転送することができます。

スキャンを無効化してプログラムを終了:

# scan off
# exit

CLI による設定

bluetooth.service起動 します。

これで、bluetoothctl コマンド ラインユーティリティを使用してペアリングして接続できるようになりました。bluetoothctl のトラブルシューティングと詳細な説明については、Bluetooth の記事を参照してください。

$ bluetoothctl

内部コマンドプロンプトが表示されます。次に、次のように入力します。

[bluetooth]# power on
[bluetooth]# agent on
[bluetooth]# default-agent
[bluetooth]# scan on

次に、ヘッドセットがペアリングモードになっていることを確認します。それはすぐに発見されるはずです。例えば、

[NEW] Device 00:1D:43:6D:03:26 Lasmex LBT10

は、自身を "Lasmex LBT10" と呼び、MAC アドレス "00:1D:43:6D:03:26" を持つデバイスを示しています。次に、その MAC アドレスを使用してペアリングを開始します。

[bluetooth]# pair 00:1D:43:6D:03:26

ペアリング後、デバイスを明示的に接続する必要もあります (これが機能しない場合は、接続を試行する 前に 以下の trust コマンドを試してください。)

[bluetooth]# connect 00:1D:43:6D:03:26

接続エラー org.bluez.Error.Failed が発生した場合は、まず既存の PulseAudio デーモンを強制終了して再試行してください。

$ pulseaudio -k
[bluetooth]# connect 00:1D:43:6D:03:26

最後に、今後このデバイスに自動的に接続する場合は、次のようにします。

[bluetooth]# trust 00:1D:43:6D:03:26

すべてが正しく動作すれば、PulseAudio に別の出力デバイスが作成されます。

ノート: デバイスはデフォルトでオフになっている可能性があります。pavucontrol の "設定" タブでオーディオプロファイル (OFFA2DPHFP) を選択します。

pavucontrol の "再生" タブと "録音" タブを使用して、そのデバイス経由でオーディオをリダイレクトできるようになりました。

ここで、スキャンを再度無効にしてプログラムを終了できます。

[bluetooth]# scan off
[bluetooth]# exit

自動接続の設定

ヘッドセットを自動接続するには、PulseAudio のスイッチオン接続モジュールを有効にする必要があります。これを行うには、次の行を /etc/pulse/default.pa に追加します。

/etc/pulse/default.pa
### Automatically switch to newly-connected devices
load-module module-switch-on-connect
ノート: Bluetooth オーディオ デバイスが "信頼" されていることを確認してください。そうでない場合、ペアリングを繰り返しても失敗します。詳細については、Bluetooth#ペアリング を参照してください。

GNOME Bluetooth 経由の設定

ノート: 現在進行中のバグのため、pulseaudio 9/10 ではこの方法を使用しても A2DP プロファイルがアクティブ化されず、低品質のモノラルサウンドが発生する可能性があります。考えられる解決策については、PulseAudio で A2DP が動作しない を参照してください。

GNOME Bluetooth グラフィカルフロントエンドを使用して、Bluetooth ヘッドセットを簡単に設定できます。

まず、bluetooth.service systemd ユニットが実行されていることを確認する必要があります。

GNOME Bluetooth を開き、Bluetooth をアクティブにします。デバイスをスキャンした後、デバイスリストでヘッドセットを選択して接続できます。デバイスメニューからサウンド設定パネルに直接アクセスして。デバイスが接続されると、サウンドパネルに新しいシンクが表示されます。

LDAC/aptX

LDAC/aptX コーデックは PulseAudio 15.0 以降でサポートされています。接続に使用しているコーデックは次のように確認できます。

$ pactl list | grep a2dp_codec

トラブルシューティング

ノート: A2DP/Bluetooth ヘッドセットが動作しないという報告は多数存在します。細については、HSV と A2DP の設定の切り替え を参照してください。

異音 / 雑音 / "濁った音"

ヘッドセットの音質が悪い場合は、ヘッドセットが正しいプロファイルに設定されていないことが原因である可能性が高くなります。 問題を解決するには、HSV と A2DP の設定の切り替え を参照してください。

オーディオプロファイルが選択されていますが、ヘッドセットが非アクティブであり、オーディオをリダイレクトできません

一見、このメニューはデバイスが接続される前から利用可能です。面倒なことに効果はありません。受信機がデバイスを認識するとすぐにメニューが作成されるようです。

必ず bluetoothctl を root として実行し、デバイスを手動で接続してください。毎回これを行う必要をなくす設定オプションがあるかもしれませんが、ペアリングも信頼も自動接続を誘発しません。

AuthenticationFailed でペアリングが失敗する

ペアリングが失敗する場合、次のコマンドで SSPMode を無効化 または有効化してみてください:

# btmgmt ssp off

または

# btmgmt ssp on

これらのコマンドを実行する間、Bluetooth 機器の電源を OFF にする必要がある可能性があります。

ペアリングは成功するが、接続が失敗する

bluetoothctl で以下のエラーが表示される場合:

[bluetooth]# connect 00:1D:43:6D:03:26
Attempting to connect to 00:1D:43:6D:03:26
Failed to connect: org.bluez.Error.Failed

以下のようなコマンドを使ってログを確認してみてください:

# systemctl status bluetooth
# journalctl -n 20

以下のようなメッセージが確認できる場合:

bluetoothd[5556]: a2dp-sink profile connect failed for 00:1D:43:6D:03:26: Protocol not available

おそらく pulseaudio-bluetooth パッケージがインストールされていないのが原因です。インストールしたら、pulseaudio を再起動してください。

パッケージが欠けていることが問題ではない場合、PulseAudio が上手く起動していないのが原因です。一般的に PulseAudio を再起動することで問題は解決します。PulseAudio をユーザーで実行している場合に bluetoothctl を root で実行することは全く問題ありません。PulseAudio の再起動後、接続を再試行してください。ペアリングを繰り返す必要はありません。

PulseAudio の再起動で問題が直らないときは、module-bluetooth-discover をロードしてください:

# pactl load-module module-bluetooth-discover

上記の load-module コマンドは /etc/pulse/default.pa に追加することができます。

それでも問題が修正されない場合、あるいは PulseAudio の system-wide モードを使っていない場合、以下の PulseAudio モジュールもロードしてください (以下のモジュールも default.pasystem.pa でロードすることができます):

module-bluetooth-policy
module-bluez5-device
module-bluez5-discover

接続は機能しますが、常に音の不具合が発生します

これは、Bluetooth と WiFi が同じ物理アンテナとおそらく帯域範囲 (2.4GHz) を共有しているため、同じチップを共有している場合に発生する可能性が非常に高くなります。これは Windows ではシームレスに機能しますが、Linux ではそうではありません。

考えられる解決策は、干渉が発生しないように WiFi ネットワークを 5GHz に移行することです。カード/ルーターがこれをサポートしていない場合は、WiFi ドライバー/ファームウェアをアップグレードできます。このアプローチは、Realtek 8723BE および AUR のこのチップ用の最新の rtl ドライバーで機能します。

上記の方法が何も不可能な場合は、フラグメントサイズと PulseAudio 出力ポートの遅延を微調整して干渉を補償することにより、あまり効果的ではありません。これらの設定によりオーディオが同期しなくなる可能性があるため (ビデオの再生時など)、適切な値を選択する必要があります。Bluetooth ヘッドセットのポートの遅延を変更するには (たとえば、次の例では 125000 マイクロ秒に):

$ pactl set-port-latency-offset <bluez_card> headset-output 125000

カードの識別子は次のようになります。

$ pacmd list-sinks | grep -Eo 'bluez_card[^>]*'

フラグメントサイズは /etc/pulse/daemon.conf で設定でき、PulseAudio の再起動後に有効になります (詳細については、PulseAudio/トラブルシューティング#Pulseaudio におけるデフォルトのフラグメント・バッファサイズを設定する を参照してください) おそらく、(適切な Bluetooth アダプターを使用して) options ath9k btcoex_enable=1/etc/modprobe.d/ath9k.conf に追加すると役立つでしょう。

/etc/modprobe.d/ath9k.conf
# possibly fix for sound glitches
options ath9k btcoex_enable=1

その後、再起動します。

接続は成功するが、音が聞こえない

システムログに以下のメッセージが記録されてないか確認してください:

bluetoothd[5556]: Endpoint registered: sender=:1.83 path=/MediaEndpoint/A2DPSource
bluetoothd[5556]: Endpoint registered: sender=:1.83 path=/MediaEndpoint/A2DPSink

上記のようなメッセージがある場合、PulseAudio の設定を確認してください。もしくは、一度戻って接続が成功するかどうか確かめてください。

GDM を使っている場合、PulseAudio のインスタンスが起動して、bluetooth デバイスの接続を奪っている可能性があります。以下のコマンドを実行して GDM ユーザーで pulseaudio ソケットをマスクすることで問題は解決します:

# mkdir -p ~gdm/.config/systemd/user
# ln -s /dev/null ~gdm/.config/systemd/user/pulseaudio.socket

再起動すれば PulseAudio のインスタンスが起動しなくなるはずです。

bluez がヘッドセットを a2dp に対応していると認識してくれない場合もあります。そのようなときは、以下のコマンドで bluetooth デバイスのインデックスを検索してください:

$ pacmd ls

以下のように bluetooth ヘッドセットに関連するセクションが出力されます:

pacmd ls
index: 2
        name: <bluez_card.XX_XX_XX_XX_XX_XX>
        driver: <module-bluez5-device.c>
        owner module: 27
        properties:
                device.description = "SONY MDR-100ABN"
                device.string = "XX:XX:XX:XX:XX:XX"
                device.api = "bluez"
                device.class = "sound"
                ...

プロファイルを手動で設定するには、以下のコマンドを実行 (2pacmd ls で確認したデバイスのインデックスに置き換えてください):

$ pacmd set-card-profile 2 a2dp_sink

接続は機能しますが、デバイスが PulseAudio シンクに表示されません

ヘッドフォンが正常に接続された (bluetoothctl 経由で 確認済み である可能性がある) が、pavucontrol で出力/入力シンクとして表示されない場合は、次のことを試してください。次のポリシーを Bluetooth 構成ファイル /etc/bluetooth/main.conf に追加します。

/etc/bluetooth/main.conf
[General]
Enable=Control,Gateway,Headset,Media,Sink,Socket,Source

これで問題が解決したと報告しているユーザーもいます 報告

接続は機能し、ヘッドフォンがアイドル状態になるまでサウンドは正常に再生されますが、その後途切れます。

ヘッドホンがアイドル状態になるまでサウンドを正しく再生し、再開時に音が途切れる場合 (たとえば、サウンドが一時停止されている、またはしばらくサウンドが再生されないため)、アイドル時の PulseAudio の自動シンク/ソース サスペンションを無効にしてみてください。

Bluetooth 接続でデータが送信されない場合、一部のユーザー が報告 に大幅な遅延が発生したり、音声が聞こえなくなったりすることがあります。これは、アイドル時にシンク/ソースを自動的に一時停止する module-suspend-on-idle モジュールによるものです。これによりヘッドセットに問題が発生する可能性があるため、責任のあるモジュールを無効にすることができます。

module-suspend-on-idle モジュールの読み込みを無効にするには、使用中の設定ファイル (~/.config/pulse/default.pa または /etc/pulse/default.pa):

~/.config/pulse/default.pa
### Automatically suspend sinks/sources that become idle for too long
#load-module module-suspend-on-idle

最後に PulseAudio を再起動して、変更を適用します。

UUIDs has unsupported type

ペアリング中に bluetoothctl で以下のような出力がされることがあります:

[CHG] Device 00:1D:43:6D:03:26 UUIDs has unsupported type

このメッセージは無視してかまいません。

PC からはデバイスがペアリング済みと認識されるがデバイスから PC が認識されていない

デバイスが bluetooth LE のペアリングに対応していない可能性があります。

/etc/bluetooth/main.confControllerMode = bredr を設定してみてください。詳しくは [2] を参照。

デバイスが接続され、しばらくすると切断される

ジャーナル に次のようなメッセージが表示され、デバイスが接続に失敗するか、接続後すぐに切断される場合:

bluetoothd: Unable to get connect data for Headset Voice gateway: getpeername: Transport endpoint is not connected (107)
bluetoothd: connect error: Connection refused (111)

これは、同じ Bluetooth アダプタを使用してデバイスを別のオペレーティングシステムとすでにペアリングしていることが考えられます (デュアルブートなど) 一部のデバイス (Bluetooth アダプターなど) は、同じ MAC アドレスに関連付けられた複数のペアリングを処理できません。この問題は、デバイスを再ペアリングすることで修正できます、まずデバイスを削除します。

$ bluetoothctl
[bluetooth]# devices
Device XX:XX:XX:XX:XX:XX My Device
[bluetooth]# remove XX:XX:XX:XX:XX:XX

次に、bluetooth.service再起動 して Bluetooth アダプターの電源を入れ、デバイスを検出可能にして、デバイスを再スキャンして、デバイスを再ペアリングします。Bluetooth マネージャーによっては、デバイスを再検出するために完全な再起動を実行する必要がある場合があります。

Apple AirPodsの音量が小さい

次の内容で bluetooth.serviceドロップインファイル を作成します。

/etc/systemd/system/bluetooth.service.d/noplugin-avrc.conf
[Service]
ExecStart=
ExecStart=/usr/lib/bluetooth/bluetoothd --noplugin=avrcp

次に、bluetooth.service、を 再起動 して設定を リロード し、ヘッドセットを再接続します。

さらに、AirPods Pro の場合は、iPhone の設定で空間オーディオを無効にし、モノラルを有効にします。

これにより、AVRCP を通じて制御できない一部のデバイスの問題も解決できます。

Apple AirPods Pro は A2DP シンクとして PulseAudio で動作しますが、HSP/HFP では動作しません

AirPods Pro が PulseAudio で動作しているものの、HSP/HFP 構成を使用できない場合 (pavucontrol設定 タブで、通常は使用不可として表示されます) に切り替えてみてください。pipewire-pulse

pipewire-pulse に切り替えると (コンピューターまたは適切なユーザーレベルの systemd サービスを再起動すると)、HSP/HFP が有効になりますが、A2DP が無効になる可能性があることに注意してください。(設定 タブで A2DP シンク を選択すると、オプションは即座に選択解除され、オフ になります。) この問題が発生した場合は、次のように /var/lib/bluetooth フォルダーを削除または名前変更します。

# mv /var/lib/bluetooth /var/lib/bluetooth.bak

その後、AirPods Pro (およびその他のデバイス) を再ペアリングします。これにより、すべての設定 (HSP/HFP および A2DP) が再び利用可能になり、pavucontrol および pacmd から簡単にアクセスできるようになります。

HSP の問題: Bluetooth シンクとソースは作成されましたが、オーディオが送信されません

ファームウェアが不足しているか、SCO (HSP および HFP のオーディオ プロトコル) ルーティングが間違っている可能性があります。[3] を参照してください。BCM20702 のファームウェアは、AUR 経由でインストールできます。bcm20702a1-firmwareAUR または bcm20702b0-firmwareAUR

Error: Failed to start discovery org.bluez.Error.InProgress

ヘッドセットは検出されたものの、"Error: Failed to start discovery org.bluez.Error.InProgress" というエラーが表示されて接続に失敗した場合は、bluez-hciconfigAUR をインストールして実行してください。

$ hciconfig hciX up
$ hciconfig hciX reset

ここで、X はコンピュータの Bluetooth デバイスの識別子 (通常は 0) です。

CLI による設定 の手順に従って接続できるようになります。

ヘッドフォンと PulseAudio 間の同期による大音量

PulseAudio 15 以降、絶対音量 はヘッドフォンのオーディオ音量を PulseAudio と連動させるため、PulseAudio なしで音量を変更することは不可能になります。もう一方。Hoco W25 などの一部のヘッドフォンでは、不快な音量が発生する可能性があります。絶対音量 を無効にするには、/etc/pulse/default.pa を編集して次の行を変更します。

 load-module module-bluetooth-discover

から

 load-module module-bluetooth-discover avrcp_absolute_volume=false

HSV と A2DP の設定の切り替え

これは、次のコマンドで簡単に実現できます。card_number は、pacmd list-cards を実行することで取得できます。

$ pacmd set-card-profile card_number a2dp_sink

ロールが設定されていない録画ストリームが表示されたときに A2DP から HSP へのプロファイルの自動切り替えを有効にするには、auto_switch=2load-module module-bluetooth-policy に追加します。/etc/pulse/default.pa

PulseAudio プロファイルの詳細については、PulseAudio Documentation を参照してください。

PulseAudio で A2DP が動作しない

Socket インターフェイスの問題

bluez 4.1+ と PulseAudio 3.0+ を使っていて、PulseAudio でプロファイルを A2DP に切り替えられない場合、/etc/bluetooth/audio.conf を編集して Enable=Socket という行を削除して Disable=Socket という行を追加することで Socket インターフェイスを無効化できます。

A2DP シンクプロファイルが使用できません

A2DP シンクプロファイルが利用できない場合、PulseAudio フロントエンドを備えた A2DP シンク (出力) に切り替えることはできず、A2DP シンクはリストにも表示されません。これは、pactl で確認できます。

$ pactl list | grep -C2 A2DP
     Profiles:
             headset_head_unit: Headset Head Unit (HSP/HFP) (sinks: 1, sources: 1, priority: 30, available: yes)
             a2dp_sink: High Fidelity Playback (A2DP Sink) (sinks: 1, sources: 0, priority: 40, available: no)
             off: Off (sinks: 0, sources: 0, priority: 0, available: yes)
        Active Profile: headset_head_unit

pacmd を使用してカードプロファイルを手動で設定しようとすると失敗します。

$ pacmd set-card-profile bluez_card.C4_45_67_09_12_00 a2dp_sink
Failed to set card profile to 'a2dp_sink'.

これは、Bluedevil または別の BlueZ フロントエンドを介して Bluetooth ヘッドフォンに接続するときに PulseAudio のバージョン 10.0 から発生することが知られています。関連のバグレポート を参照してください。

この問題は、デフォルトで Handsfree または Headset - HS に設定される可能性がある一部の Bluetooth コントローラ (例: 0a12:0001、Cambridge Silicon Radio) とヘッドフォンを最初にペアリングした後にも発生します。サービスを必要とするため、AudioSink サービスを必要とする A2DP PulseAudio シンクへの切り替えは許可されません。

可能な解決策:

  • 一部のヘッドセットでは、接続中にヘッドセットの音量または再生/一時停止コントロールを使用すると、A2DP プロファイルが使用可能になる可能性があります。
  • bluez-utils から bluetoothctl 経由でヘッドセットに接続すると、A2DP シンクプロファイルが利用可能になる可能性があります。Bluetooth デバイスが接続されるたびに、これが自動化されます: fix-bt-a2dpAUR (詳細な使用法)
[bluetooth]# connect headset_MAC_address
  • Bluetooth の AudioSink サービスに手動で切り替えると、A2DP プロファイルとその A2DP PulseAudio シンクが利用可能になります。これは、blueman に含まれる blueman-manager を使用するか、AudioSink サービスの UUID を bluetoothctl に登録することで実行できます。
$ bluetoothctl
[bluetooth]# menu gatt
[bluetooth]# register-service 0000110b-0000-1000-8000-00805f9b34fb
[bluetooth]# quit
  • ヘッドセットプロファイルを無効にする
/etc/bluetooth/main.conf
[General]
Disable=Headset
  • マルチプロファイルのサポートを有効にします。これは、A2DP およびヘッドセットオーディオをサポートするヘッドセットで役立つ場合があります。
/etc/bluetooth/main.conf
[General]
MultiProfile=multiple
  • 場合によっては、上記の手順がどれも機能しない場合があります。再起動したり、Bluetooth の電源をオフにしたりオンにしたりしてみても効果が無い可能性があります。この場合、bluetooth.service再起動 してみてください。
  • オーディオコントロールパネルを備えた一部のヘッドフォンモデルでは、パネルの 再生/一時停止 ボタンを押して A2DP プロファイルを有効にする必要があります。

GDM を使用した Gnome

この記事あるいはセクションは #Connecting works, but I cannot play sound と合併することが議論されています。
ノート: duplicate instructions (議論: トーク:Bluetooth ヘッドセット#)

以下の手順は Gnome 3.24.2 および PulseAudio 10.0 でテストされましたが、他のバージョンにも適用でき、役立つ可能性があります。

GDM で GNOME を使用しているときにプロファイルを A2DP に変更すると PulseAudio が失敗する場合は、GDM が独自の PulseAudio インスタンスを開始しないようにする必要があります。

  • 以下を追加することで、サーバーが実行されていない場合に PulseAudio クライアントがサーバーを自動的に起動しないようにします。
/var/lib/gdm/.config/pulse/client.conf
autospawn = no
daemon-binary = /bin/true
  • ソケットをアクティブ化しても systemd が PulseAudio を開始しないようにします。
$ sudo -ugdm mkdir -p /var/lib/gdm/.config/systemd/user
$ sudo -ugdm ln -s /dev/null /var/lib/gdm/.config/systemd/user/pulseaudio.socket
  • 再起動し、次のコマンドを使用して、gdm ユーザーの PulseAudio プロセスがないことを確認します。
$ pgrep -u gdm pulseaudio

この問題と代替修正に関する詳細な議論は、[4] および [5] で参照できます。あるいは、fix-bt-a2dpAUR をインストールしてみることもできます。

HFP が PulseAudio で動作しない

ノート: 一部のユーザーは、Bluetooth サポートのために PulseAudio を PipeWire に置き換えることで HFP サポートを有効にすることに成功したと報告しています。[6] インストール手順については、Bluetooth ヘッドセット#PipeWire 経由のヘッドセット を参照してください。

HFP 専用 Bluetooth ヘッドセットは、PulseAudio の標準構成では使用できない場合があります。それぞれのプロファイルが存在しますが、使用できません。

bluetoothctl info
UUID: Audio Sink                (0000110b-0000-1000-8000-00805f9b34fb)
UUID: A/V Remote Control Target (0000110c-0000-1000-8000-00805f9b34fb)
UUID: A/V Remote Control        (0000110e-0000-1000-8000-00805f9b34fb)
UUID: Handsfree                 (0000111e-0000-1000-8000-00805f9b34fb)
pactl list
...
Profiles:
      ...
      headset_head_unit: Headset Head Unit (HSP/HFP) (sinks: 1, sources: 1, priority: 30, available: no)

それぞれの問題を解決するには、PulseAudio と BlueZ を最新バージョンに更新します。次に、ofonoAURphonesimAURインストール ここ [7] の説明に従って偽のモデム​​を作成/アクティブ化します。:

ノート: phonesim.conf の作成後の手順は、ヘッドセットを接続する たびに 実行する必要があります
  • 以下を使用して /etc/ofono/phonesim.conf を作成します。
[phonesim]
Address=127.0.0.1
Driver=phonesim
Port=12345
  • ユーザーとして開始:
$ phonesim -p 12345 /usr/share/phonesim/default.xml &
$ dbus-send --print-reply --system --dest=org.ofono /phonesim org.ofono.Modem.SetProperty string:"Powered" variant:boolean:true
  • モデムをアクティブ化します:
$ dbus-send --print-reply --system --dest=org.ofono /phonesim org.ofono.Modem.SetProperty string:"Online" variant:boolean:true
  • 結果を確認するには、/usr/lib/ofono/test/ にインストールされている ofonoAUR のテストコマンドを使用します。モデムの電源を投入、アクティブ化、テストするには、以下を使用できます。
$ /usr/lib/ofono/test/enable-modem /phonesim
$ /usr/lib/ofono/test/online-modem /phonesim
$ /usr/lib/ofono/test/list-modems

それぞれのモデムセクションの出力は次のようになります。

...
[ /phonesim ]
  Online = 1
  Powered = 1
  Lockdown = 0
  Emergency = 0
  Manufacturer = MeeGo
  ...
  • 最後に、PulseAudio を再起動し、ヘッドセットを再接続します。これで、HFP が利用可能になるはずです。

headset_head_unit: ヘッドセットヘッドユニット (HSP/HFP) (sinks: 1, sources: 1, priority: 30, available: yes)

ノート: HFP サポートは安定していないため、A2DP への切り替え時に問題が発生する可能性があります。必要なモードが利用できない場合は、再接続してみてください

PulseAudio ヘッドセットの HSP/HFP への自動切り替えを無効にする

複数のプロファイルをサポートする Bluetooth ヘッドセットを使用すると、一部のアプリケーションは自動的に HSP/HFP プロファイルに切り替わります。この動作を望まない場合は、auto_switch=false パラメータを Bluetooth ポリシーモジュールに追加することでこれを無効にできます。

/etc/pulse/default.pa
load-module module-bluetooth-policy auto_switch=false

PipeWire HSP/HFP プロファイルを無効にする

PulseAudio とは異なり、PipeWire は入力イベントに応じて A2DP と HSP/HFP を自動的に切り替えません ただし、A2DP が失敗した場合に (低音質の) HSP/HFP プロファイルへの自動的な切り替えを有効にするのではなく、前者を完全に無効にした方がよい場合もあります。これを行うには、/usr/share/wireplumber/bluetooth.lua.d/50-bluez-config.lua のコピーを作成します。以下に示すように、[8]

ノート: 内蔵マイクが動作するには HSP モードが必要です [9]
/etc/wireplumber/bluetooth.lua.d/50-bluez-config.lua (or ~/.config/wireplumber/bluetooth.lua.d/50-bluez-config.lua)
...
bluez_monitor.properties = {
  ...
  ["bluez5.headset-roles"] = "[ ]",
  ...
  ["bluez5.hfphsp-backend"] = "none",
}
...
bluez_monitor.rules = {
  {
    ...
    apply_properties = {
      ...
      ["bluez5.auto-connect"] = "[ a2dp_sink ]",
      ...
       ["bluez5.hw-volume"] = "[ a2dp_sink ]",
    },
    ...
  },
}

ヒントとテクニック

以下は PipeWire と PulseAudio の両方に適用されます。

バッテリーレベルのレポート

ノート: これは実験的な機能です。これを有効にすると、一部の Bluetooth マウスが自動的に接続されなくなる可能性があります (GitHub issue を参照)

upower に報告されているヘッドセットの現在のバッテリー レベルを取得するには、Bluetooth#実験的な機能を有効化する で説明されているように、bluez の D-Bus 実験的機能を有効にする必要があります。

メディアコントロール

メディアコントロールを使用するために、MPRIS に転送して、そこで MPRIS をサポートするメディアプレーヤーが外部コントロールのためにピックアップする必要があります。詳しくは MPRIS#Bluetooth を参照してください。

代替: A2DP 二重チャネル

FastStream、AptX LL、および "Opus 05 Pro" (a pipewire invention) には、マイクの音声を送り返すことができる "二重" チャネルがあります。 HSP/HFP を使用する必要がなく、音質の劣化を許容できます。PipeWire はこの機能をサポートしていますが、PulseAudio はサポートしていません。サポートは機能が検出されると自動的に行われます。既存のプロファイルスイッチャー (WirePlumber) との相互作用は不明です。

これはデバイスの切断と再接続時にリセットされるため、次のような udev ルールを介して自動的に設定することが望ましいと考えられます:

SUBSYSTEM=="input" ATTR{name}=="Soundcore Life P3 (AVRCP)" ATTR{inhibited}="1"

通常のユーザーとしてこの属性を変更できるようにしたい場合は、udev#通常ユーザーにデバイスの使用を許可する を参照してください。

テスト済みのヘッドセット

機種 バージョン コメント 対応状況
Philips SHB3060 bluez 5.40, PulseAudio 9.0 ボタンが機能しません。対応プロファイル: HSP (マイクロフォンも動作) と A2DP。 Yes
Philips SHB4000WT bluez5 A2DP で動作、HDP は問題あり。 Yes
Philips SHB5500BK/00 bluez 5.28, PulseAudio 6.0 停止・再生が機能せず。 Limited
Philips SHB7000 停止・再生がおかしい。 Limited
Philips SHB7100 bluez 5.32, pulseaudio 6.0 次へ・前へボタンも動作。停止・再生は微妙 (VLC では動くこともあるが、Audacious では全く機能しない)。A2DP と Handsfree の音声出力のみで確認。マイクは機能せず。 Limited
Philips SHB7150 bluez 5.32, pulseaudio 6.0 次へ・前へボタンも動作。停止・再生は VLC では動作。A2DP プロファイルでのみ確認。 Yes
Philips SHB9100 停止・再生がおかしい。音質を改善する一時的な方法は [10] を参照。 Limited
Philips SHB9150 bluez5, pulseaudio 9 Yes
Philips AEA2000/12 bluez5 Yes
Parrot Zik マイクは認識されますが機能しません (HSP プロファイルは使えません)。Bluetooth 接続が切れると、音声に遅延が発生します。Bluetooth 接続を初期化することで解決します。 Limited
Parrot Zik 2.0 マイクは認識されますが機能しません (HSP プロファイルは使えません)。Bluetooth 接続が切れると、音声に遅延が発生します。Bluetooth 接続を初期化することで解決します。 Limited
Parrot Zik 3.0 マイクは認識されますが機能しません (HSP プロファイルは使えません)。遅延の問題はありません。 Limited
Sony DR-BT50 bluez{4,5} a2dp で動作。[11] を参照。アダプタ: D-Link DBT-120 USB ドングル。 Yes
Sony SBH20 bluez 5.30, pulseaudio 6.0 A2DP プロファイルで問題なく動作。 Yes
Sony SBH50 bluez5 a2dp で動作。アダプタ: Broadcom Bluetooth 2.1 Device (Vendor=0a5c ProdID=219b Rev=03.43)。btusb モジュールが必要。 Yes
Sony SBH80 bluez 5.36, pulseaudio 7.1 メディアボタンは機能せず。blueman でプロファイルを無効化して A2DP を有効化することで動作。 Yes
Sony MDR-XB950BT pulseaudio a2dp でテスト済み。アダプタ: Grand-X BT40G。自動で接続されない場合、手動で接続する必要があります。他の機能は問題なく動作。 Limited
Sony MDR-ZX330BT bluez 5.31, pulseaudio 6.0 何も設定しなくても動作 (HSP/HFP と A2DP)。ボタンは特定のアプリで動作。 Yes
Sony MUC-M1BT1 bluez5, pulseaudio-gitAUR A2DP & HSP/HFP どちらも問題なく動作。 Yes
Sony WH-1000XM3 bluez5, pulseaudio-gitAUR A2DP & HSP/HFP どちらも動作。マイク、側面のタッチコントロールも使用可能です。 Yes
SoundBot SB220 bluez5, pulseaudio-gitAUR Yes
Auna Air 300 bluez5, pulseaudio-git 何らかの理由で、再起動が必要ですが、それで問題なく起動します。 Limited
Sennheiser MM 400-X bluez5, pulseaudio 4.0-6 Yes
Sennheiser MM 550-X Travel bluez 5.27-1, pulseaudio 5.0-1 次・前ボタンは何も設定しなくても動作しますが、再生・停止ボタンは動作しません。 Yes
Sennheiser URBANITE XL Wireless bluez 5.37-2, pulseaudio 7.1-3 A2DP 高音質再生。再生・停止・次へ・前へも問題なく動作。 Yes
Sennheiser Momentum 2 bluez5, pulseaudio 9.0-1 GDM で起動できない問題を解決しないと A2DP プロファイルの変更に失敗することがあります。 Yes
Audionic BlueBeats (B-777) bluez5, pulseaudio 4.0-6 Yes
Logitech Wireless Headset bluez 5.14, pulseaudio-git 製造番号 PN 981-000381。iPad 用と喧伝されているヘッドセット。 Yes
Logitech UE9000 bluez 5.37, pulseaudio 7.1, gnome 3.18.2 gnome/gdm の修正をすることで再生可能。音声プロファイルのデフォルトは HSP/HFP。マイクは HSP/HFP と A2DP プロファイルのどちらでも動作。再生・停止や次へ・前へは Spotify や VLC で機能する。 Yes
HMDX Jam Classic Bluetooth bluez, pulseaudio-git Yes
PT-810 bluez 5.14, pulseaudio-git 汎用の USB 給電 Bluetooth 音声レシーバー。3.5mm ヘッドセットジャックと a2dp プロファイルで機能。"USB Bluetooth Receiver" ID として PT-810 は広く使えます。 Yes
Nokia BH-104 bluez4 Yes
Creative AirwaveHD bluez 5.23 Bluetooth アダプタ Atheros Communications usb: 0cf3:0036 Yes
Creative HITZ WP380 bluez 5.27, pulseaudio 5.0-1 A2DP プロファイルのみ。ボタンも動作 (再生, 停止, 次へ, 前へ)。ボリュームボタンはハードウェアのみ。自動接続もできるが bluetooth モジュールを "pulseaudio" に組み込んで自動的に切り替えさせる必要がある。ハイレゾ再生もクリア (デバイスとしては APTx コーデックをサポートしていますが Linux ではまだ対応されていません)。遅延の問題が発生するときは pulseaudio を再起動する必要あり。 Yes
deleyCON Bluetooth Headset bluez 5.23 アダプタ: CSL - USB nano Bluetooth-Adapter V4.0。a2dp プロファイルでテスト。マイクは未テスト。(ペアリングしても) 自動接続は行われないため、手動で接続する必要あり。再生/停止ボタンを押すとヘッドフォンがミュート/アンミュートになるが、再生には影響なし。次に進む/前に戻るボタンは動作せず (xev で変化なし)。 Limited
UE BOOM bluez 5.27, pulseaudio-git 5.99 最新の UE BOOM fw 1.3.58 にアップデート。動画再生における音声の遅延は pavucontrol を設定することで解決できる。UE BOOM x2 で動作。 Yes
LG HBS-730 bluez 5.30, pulseaudio 6.0 A2DP プロファイルで何も設定しなくても動作。 Yes
LG HBS-750 bluez 5.30, pulseaudio-git 6.0 A2DP プロファイルで何も設定しなくても動作。 Yes
Beats Studio Wireless bluez 5.28, pulseaudio 6.0 何も設定しなくても動作。マルチメディアボタンは未テスト。 Yes
AKG Y45BT bluez 5.30, pulseaudio 6.0 停止・再生が動作せず。/etc/bluetooth/audio.confEnable=Socket を、/etc/pulse/default.paload-module module-bluetooth-discover を設定する必要あり。 Yes
Bluedio Turbine/Turbine 2+ bluez 5.3, pulseaudio 6.0 HSP/HFP で動作、A2DP も問題なく動作。 Yes
Nokia BH-111 bluez 5.30, pulseaudio 6.0 HSP/HFP と A2DP どちらでも動作。ボタンは特定のアプリで動作。 Yes
Samsung Level Link bluez 5.33, pulseaudio 6.0 何も設定しなくても動作 (HSP/HFP と A2DP)。ボタンは特定のアプリで動作。 Yes
Bernafon Soundgate 3 bluez 5.34-2, pulseaudio 7.0-1 blueman-git 2.0.r53.g2a812a8-1 をインストールすることで動作 (A2DP)。 Yes
JBL E40 BT bluez 5.35, pulseaudio 7.0 blueberry と blueman をインストールすることで接続可能。Disable=Socket/etc/bluetooth/audio.conf に追加することで A2DP が動作。メディアボタンも動作。 Yes
JBL Everest 300 bluez 5.37, pulseaudio 8.0 全てが問題なく動作。HSP/HFP プロファイルでヘッドフォンを接続すると音質が悪いが、pavucontrol でプロファイルを A2DP sink に切り替えることで音質はかなり改善する。ペアリングに問題なし。 Yes
Kitsound Manhattan bluez 5.37, pulseaudio 7.13 全て問題なし。Pulseaudio をユーザーでなく root で ( --system) 動作させた場合、ペアリングしても接続できなかったり、(アクセス PIN を要求して) システムがフリーズしてしまう可能性あり。注意が必要。 Yes
Jawbone Jambox bluez 5.38, pulseaudio 8.0 Yes
Plantronics BackBeat FIT bluez5, pulseaudio 8.0 ヘッドセットと a2dp プロファイルどちらも完全に動作。停止ボタンでプレイヤーを停止できます (mpv で確認)。 Yes
Plantronics BackBeat Pro bluez5, pulseaudio 9.0 ヘッドセットと a2dp プロファイルどちらも完全に動作。停止ボタンを押したりヘッドセットを外すとプレイヤーが停止します。 Yes
Aukey EP-B26 bluez 5.39-1, pulseaudio 8.0-3 ヘッドセット (低品質) と a2dp (高品質) プロファイルどちらも完全に動作。停止ボタンでプレイヤーを停止したり、次・前ボタンで曲を変えられます。マイクは HSP/HFP モードでのみ動作。 Yes
Bose AE2 SoundLink bluez 5.36, pulseaudio 7.1 停止・再生ボタンが動作しません。マイクも使えません。 Limited
Bose QuietComfort 35 bluez 5.41, pulseaudio 9.0 ControllerMode=bredr を設定することでペアリングできます。 Yes
Blue Tiger Dual Elite bluez-5.42-1, pulseaudio 9.0-1 pulseaudio-bluetooth パッケージで接続できます。マイクや操作ボタンは未確認。 Yes

参照

Windows と Linux でペアリングを解除しないでデバイスを共有する方法: