Hallo,...
k.osmo schrieb
Dann verstehe ich überhaupt nicht, was die ganze Konfig eigentlich soll. [...]
Rückblickend betrachted, ist mein Beitrag von gestern tatsächlich einigermaßen wirr geraten. Vllt. hat die Vorfreude, nach mehr als 1 Jahr Arch-Linux, endlich
einen Grund zu haben ins Forum zu posten, da etwas reingespielt. ;-)
k.osmo schrieb
Also, bei mir füge ich mit diesem Befehl "root" der Gruppe "audio" hinzu. Mir ist nicht klar, welchen Sinn das machen soll. War das deine Absicht, oder wie kommst Du auf diese Idee? [...]
Das war mein plumper Versuch, meinen Anmeldenamen zu maskieren. Das hatte natürlich zur Folge, das die Bedeutung der Zeile nicht mehr stimmt. Das kannst du komplett "stornieren".
Zwischenzeitlich habe ich jetzt auch meine Änderungen wieder rückgängig gemacht, da ich selbst eingesehen habe, dass das alles ziemlicher Blödsinn war, was ich da vorhatte. Ich war der Meinung, ich müsste nur irgendwie die Berechtigungen etwas aufbohren.
Der ursprüngliche Fehler ist jetzt weg, bzw. ich kann ihn nicht mehr in der ursprünglichen Form reproduzieren. Jetzt kommt der Fehler nur noch nach einem "Suspend/Resume" und zusätzlich ein neuer Fehler, wenn ich am Mobiltelefon Bluetooth ausschalte, aka. "Disconnect". Beides DBUS Meldungen:
Nach dem Supend/Resume:
Mai 23 21:08:00 dbus[414]: [system] Rejected send message, 1 matched rules; type="error", sender=":1.87" (uid=1000 pid=1346 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="org.bluez.MediaEndpoint1.Error.NotImplemented" requested_reply="0" destination=":1.6" (uid=0 pid=699 comm="/usr/lib/bluetooth/bluetoothd ")
Wenn ich am Handy Bluetooth ausschalte:
Mai 23 18:27:56 dbus[416]: [system] Rejected send message, 1 matched rules; type="method_return", sender=":1.87" (uid=1000 pid=1337 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="(unset)" requested_reply="0" destination=":1.6" (uid=0 pid=682 comm="/usr/lib/bluetooth/bluetoothd ")
Um diese beiden Meldungen geht es mir.
Aber nun erstmal von Anfang an:
Gegeben ist eine etwa 1 Jahr junge und aktuell gehaltene Installation von Arch Linux (x86_64) auf einem "Lenovo Thinkpad X200".
Als Desktopumgebung kommt "Gnome 3.24.2" und als Anmeldeschirm "GDM" zum Einsatz.
Gewünscht ist das Abspielen von Musik von einem Mobiltelefon aus via Bluetooth an den angeschlossenen Lautsprechern des Thinkpad.
Oder anders ausgedrückt: Ich möchte das Thinkpad nebenher als Bluetooth-Lautsprecher zweckentfremden.
Mein erster Versuch (ohne irgendwelche Änderungen vorzunehmen):
* Bluetooth gepaart -> ok.
* Musik auf dem Handy gestartet -> ok.
* Am Thinkpad -> Stille.
Nach etwas Suchmaschinenbedienung habe ich herausgefunden, dass das erforderliche Bluetooth-Modul als Teil von Pulseaudio bereits vor der Anmeldung des ersten Nutzers von "GDM" belegt wird und damit die spätere Verwendung in der Nutzersitzung verhindert wird.
Also habe ich das Bluetooth-Modul in /etc/pulse/default.pa auskommentiert, damit es nicht mehr geladen wird, wenn der Anmeldeschirm startet:
# cat /etc/pulse/default.pa
#!/usr/bin/pulseaudio -nF
#
# This file is part of PulseAudio.
#
# PulseAudio is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# PulseAudio is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with PulseAudio; if not, see <http://www.gnu.org/licenses/>.
# This startup script is used only if PulseAudio is started per-user
# (i.e. not in system mode)
.fail
### Automatically restore the volume of streams and devices
load-module module-device-restore
load-module module-stream-restore
load-module module-card-restore
### Automatically augment property information from .desktop files
### stored in /usr/share/application
load-module module-augment-properties
### Should be after module-*-restore but before module-*-detect
load-module module-switch-on-port-available
### Load audio drivers statically
### (it's probably better to not load these drivers manually, but instead
### use module-udev-detect -- see below -- for doing this automatically)
#load-module module-alsa-sink
#load-module module-alsa-source device=hw:1,0
#load-module module-oss device="/dev/dsp" sink_name=output source_name=input
#load-module module-oss-mmap device="/dev/dsp" sink_name=output source_name=input
#load-module module-null-sink
#load-module module-pipe-sink
### Automatically load driver modules depending on the hardware available
.ifexists module-udev-detect.so
load-module module-udev-detect
.else
### Use the static hardware detection module (for systems that lack udev support)
load-module module-detect
.endif
### Automatically connect sink and source if JACK server is present
.ifexists module-jackdbus-detect.so
.nofail
load-module module-jackdbus-detect channels=2
.fail
.endif
### Automatically load driver modules for Bluetooth hardware
.ifexists module-bluetooth-policy.so
load-module module-bluetooth-policy
.endif
### Disabled, because it grabs the sink, before the user session can
#.ifexists module-bluetooth-discover.so
#load-module module-bluetooth-discover
#.endif
###
### Load several protocols
.ifexists module-esound-protocol-unix.so
load-module module-esound-protocol-unix
.endif
load-module module-native-protocol-unix
### Network access (may be configured with paprefs, so leave this commented
### here if you plan to use paprefs)
#load-module module-esound-protocol-tcp
#load-module module-native-protocol-tcp
#load-module module-zeroconf-publish
### Load the RTP receiver module (also configured via paprefs, see above)
#load-module module-rtp-recv
### Load the RTP sender module (also configured via paprefs, see above)
#load-module module-null-sink sink_name=rtp format=s16be channels=2 rate=44100 sink_properties="device.description='RTP Multicast Sink'"
#load-module module-rtp-send source=rtp.monitor
### Load additional modules from GConf settings. This can be configured with the paprefs tool.
### Please keep in mind that the modules configured by paprefs might conflict with manually
### loaded modules.
.ifexists module-gconf.so
.nofail
load-module module-gconf
.fail
.endif
### Automatically restore the default sink/source when changed by the user
### during runtime
### NOTE: This should be loaded as early as possible so that subsequent modules
### that look up the default sink/source get the right value
load-module module-default-device-restore
### Automatically move streams to the default sink if the sink they are
### connected to dies, similar for sources
load-module module-rescue-streams
### Make sure we always have a sink around, even if it is a null sink.
load-module module-always-sink
### Honour intended role device property
load-module module-intended-roles
### Automatically suspend sinks/sources that become idle for too long
load-module module-suspend-on-idle
### If autoexit on idle is enabled we want to make sure we only quit
### when no local session needs us anymore.
.ifexists module-console-kit.so
load-module module-console-kit
.endif
.ifexists module-systemd-login.so
load-module module-systemd-login
.endif
### Enable positioned event sounds
load-module module-position-event-sounds
### Cork music/video streams when a phone stream is active
load-module module-role-cork
### Modules to allow autoloading of filters (such as echo cancellation)
### on demand. module-filter-heuristics tries to determine what filters
### make sense, and module-filter-apply does the heavy-lifting of
### loading modules and rerouting streams.
load-module module-filter-heuristics
load-module module-filter-apply
### Make some devices default
#set-default-sink output
#set-default-source input
Dazu habe ich dann noch eine neue Konfigurationsdatei im Nutzerverzeichnis angelegt, die das Bluetooth-Modul in der Sitzung lädt:
# cat ~/.config/pulse/default.pa
.include /etc/pulse/default.pa
### Pulseaudio Bluetooth Discovery Modul ###
.ifexists module-bluetooth-discover.so
.nofail
load-module module-bluetooth-discover
.fail
.endif
###
Das funktioniert einwandfrei. Bei der Benutzung treten allerdings die oben benannten DBUS Fehler auf, die weg haben möchte.
Hier noch die Logs dazu:
Nach Suspend/Resume:
# journalctl _SYSTEMD_UNIT=dbus.service --no-hostname --no-pager -b -f
-- Logs begin at Tue 2017-05-23 19:48:42 CEST. --
Mai 23 19:57:21 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.nm_dispatcher' unit='dbus-org.freedesktop.nm-dispatcher.service'
Mai 23 19:57:21 dbus[414]: [system] Successfully activated service 'org.freedesktop.nm_dispatcher'
Mai 23 20:02:25 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.hostname1' unit='dbus-org.freedesktop.hostname1.service'
Mai 23 20:02:25 dbus[414]: [system] Successfully activated service 'org.freedesktop.hostname1'
Mai 23 20:03:18 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.hostname1' unit='dbus-org.freedesktop.hostname1.service'
Mai 23 20:03:18 dbus[414]: [system] Successfully activated service 'org.freedesktop.hostname1'
Mai 23 20:06:45 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.hostname1' unit='dbus-org.freedesktop.hostname1.service'
Mai 23 20:06:45 dbus[414]: [system] Successfully activated service 'org.freedesktop.hostname1'
Mai 23 20:27:22 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.nm_dispatcher' unit='dbus-org.freedesktop.nm-dispatcher.service'
Mai 23 20:27:22 dbus[414]: [system] Successfully activated service 'org.freedesktop.nm_dispatcher'
Mai 23 20:53:07 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.nm_dispatcher' unit='dbus-org.freedesktop.nm-dispatcher.service'
Mai 23 20:53:08 dbus[414]: [system] Successfully activated service 'org.freedesktop.nm_dispatcher'
Mai 23 20:53:08 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.hostname1' unit='dbus-org.freedesktop.hostname1.service'
Mai 23 20:53:08 dbus[414]: [system] Successfully activated service 'org.freedesktop.hostname1'
Mai 23 21:08:00 dbus[414]: [system] Rejected send message, 1 matched rules; type="error", sender=":1.87" (uid=1000 pid=1346 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="org.bluez.MediaEndpoint1.Error.NotImplemented" requested_reply="0" destination=":1.6" (uid=0 pid=699 comm="/usr/lib/bluetooth/bluetoothd ")
Mai 23 21:08:00 dbus[414]: [system] Rejected send message, 1 matched rules; type="error", sender=":1.87" (uid=1000 pid=1346 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="org.bluez.MediaEndpoint1.Error.NotImplemented" requested_reply="0" destination=":1.6" (uid=0 pid=699 comm="/usr/lib/bluetooth/bluetoothd ")
Mai 23 21:08:00 dbus[414]: [system] Rejected send message, 1 matched rules; type="error", sender=":1.87" (uid=1000 pid=1346 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="org.bluez.MediaEndpoint1.Error.NotImplemented" requested_reply="0" destination=":1.6" (uid=0 pid=699 comm="/usr/lib/bluetooth/bluetoothd ")
Mai 23 21:08:00 dbus[414]: [system] Rejected send message, 1 matched rules; type="error", sender=":1.87" (uid=1000 pid=1346 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="org.bluez.MediaEndpoint1.Error.NotImplemented" requested_reply="0" destination=":1.6" (uid=0 pid=699 comm="/usr/lib/bluetooth/bluetoothd ")
Mai 23 21:08:06 dbus[414]: [system] Activating via systemd: service name='net.reactivated.Fprint' unit='fprintd.service'
Mai 23 21:08:06 dbus[414]: [system] Successfully activated service 'net.reactivated.Fprint'
Mai 23 21:08:09 dbus[414]: [system] Activating via systemd: service name='org.freedesktop.nm_dispatcher' unit='dbus-org.freedesktop.nm-dispatcher.service'
Mai 23 21:08:09 dbus[414]: [system] Successfully activated service 'org.freedesktop.nm_dispatcher'
^C
# journalctl _SYSTEMD_UNIT=bluetooth.service --no-hostname --no-pager -b -f
-- Logs begin at Tue 2017-05-23 19:48:42 CEST. --
Mai 23 19:54:00 bluetoothd[699]: Bluetooth daemon 5.45
Mai 23 19:54:00 bluetoothd[699]: Starting SDP server
Mai 23 19:54:00 bluetoothd[699]: Bluetooth management interface 1.14 initialized
Mai 23 19:54:15 bluetoothd[699]: Endpoint registered: sender=:1.87 path=/MediaEndpoint/A2DPSource
Mai 23 19:54:15 bluetoothd[699]: Endpoint registered: sender=:1.87 path=/MediaEndpoint/A2DPSink
Mai 23 21:08:00 bluetoothd[699]: Endpoint unregistered: sender=:1.87 path=/MediaEndpoint/A2DPSource
Mai 23 21:08:00 bluetoothd[699]: Endpoint unregistered: sender=:1.87 path=/MediaEndpoint/A2DPSink
Mai 23 21:08:01 bluetoothd[699]: Endpoint registered: sender=:1.87 path=/MediaEndpoint/A2DPSource
Mai 23 21:08:01 bluetoothd[699]: Endpoint registered: sender=:1.87 path=/MediaEndpoint/A2DPSink
^C
und wenn am gepaarten Gerät Bluetooth ausgeschaltet wird:
# journalctl _SYSTEMD_UNIT=dbus.service --no-hostname --no-pager -b -f
-- Logs begin at Mon 2017-05-22 18:25:36 CEST. --
Mai 23 18:18:50 dbus[416]: [system] Successfully activated service 'org.freedesktop.PackageKit'
Mai 23 18:18:50 dbus[416]: [system] Successfully activated service 'org.freedesktop.ModemManager1'
Mai 23 18:18:50 dbus[416]: [system] Activating via systemd: service name='org.freedesktop.ColorManager' unit='colord.service'
Mai 23 18:18:50 dbus[416]: [system] Successfully activated service 'org.freedesktop.ColorManager'
Mai 23 18:18:51 dbus[416]: [system] Activating via systemd: service name='net.reactivated.Fprint' unit='fprintd.service'
Mai 23 18:18:51 dbus[416]: [system] Successfully activated service 'net.reactivated.Fprint'
Mai 23 18:19:03 dbus[416]: [system] Activating via systemd: service name='org.freedesktop.UDisks2' unit='udisks2.service'
Mai 23 18:19:03 dbus[416]: [system] Successfully activated service 'org.freedesktop.UDisks2'
Mai 23 18:19:04 dbus[416]: [system] Activating via systemd: service name='org.freedesktop.timedate1' unit='dbus-org.freedesktop.timedate1.service'
Mai 23 18:19:04 dbus[416]: [system] Successfully activated service 'org.freedesktop.timedate1'
Mai 23 18:27:56 dbus[416]: [system] Rejected send message, 1 matched rules; type="method_return", sender=":1.87" (uid=1000 pid=1337 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="(unset)" requested_reply="0" destination=":1.6" (uid=0 pid=682 comm="/usr/lib/bluetooth/bluetoothd ")
Mai 23 18:28:19 dbus[416]: [system] Rejected send message, 1 matched rules; type="method_return", sender=":1.87" (uid=1000 pid=1337 comm="/usr/bin/pulseaudio --daemonize=no ") interface="(unset)" member="(unset)" error name="(unset)" requested_reply="0" destination=":1.6" (uid=0 pid=682 comm="/usr/lib/bluetooth/bluetoothd ")
^C
# journalctl _SYSTEMD_UNIT=bluetooth.service --no-hostname --no-pager -b -f
-- Logs begin at Mon 2017-05-22 18:25:36 CEST. --
Mai 23 18:18:45 bluetoothd[682]: Bluetooth daemon 5.45
Mai 23 18:18:45 bluetoothd[682]: Starting SDP server
Mai 23 18:18:45 bluetoothd[682]: Bluetooth management interface 1.14 initialized
Mai 23 18:19:01 bluetoothd[682]: Endpoint registered: sender=:1.87 path=/MediaEndpoint/A2DPSource
Mai 23 18:19:01 bluetoothd[682]: Endpoint registered: sender=:1.87 path=/MediaEndpoint/A2DPSink
Mai 23 18:25:06 bluetoothd[682]: No cache for 1C:7B:21:9D:D8:28
Mai 23 18:25:25 bluetoothd[682]: /org/bluez/hci0/dev_1C_7B_21_9D_D8_28/fd0: fd(28) ready
Mai 23 18:27:56 bluetoothd[682]: /org/bluez/hci0/dev_1C_7B_21_9D_D8_28/fd1: fd(28) ready
Mai 23 18:28:25 bluetoothd[682]: connect error: Host is down (112)
Mai 23 18:28:33 bluetoothd[682]: connect error: Host is down (112)
Mai 23 18:28:43 bluetoothd[682]: connect error: Host is down (112)
Mai 23 18:28:57 bluetoothd[682]: connect error: Host is down (112)
Mai 23 18:29:19 bluetoothd[682]: connect error: Host is down (112)
Mai 23 18:29:57 bluetoothd[682]: connect error: Host is down (112)
^C
Beste Grüße
Steinwanderer