mirror of
https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
synced 2025-10-29 05:40:23 -04:00
bluetooth: Fix assertion failure if BlueZ crashes during GetProperties
If BlueZ crashes exactly while PulseAudio waits for the GetProperties reply, the device has already been removed from the hashmap and therefore an assertion failure is experienced. The solution consists of ignoring the reply in these cases. The problem can be observed in the following traces: D: [pulseaudio] bluetooth-util.c: Bluetooth daemon appeared. D: [pulseaudio] bluetooth-util.c: dbus: interface=org.bluez.Manager, path=/, member=AdapterAdded D: [pulseaudio] bluetooth-util.c: Adapter /org/bluez/497/hci1 created D: [pulseaudio] bluetooth-util.c: Registering /MediaEndpoint/HFPAG on adapter /org/bluez/497/hci1. D: [pulseaudio] bluetooth-util.c: Registering /MediaEndpoint/HFPHS on adapter /org/bluez/497/hci1. D: [pulseaudio] bluetooth-util.c: Registering /MediaEndpoint/A2DPSource on adapter /org/bluez/497/hci1. D: [pulseaudio] bluetooth-util.c: Registering /MediaEndpoint/A2DPSink on adapter /org/bluez/497/hci1. D: [pulseaudio] bluetooth-util.c: dbus: interface=org.bluez.Adapter, path=/org/bluez/497/hci1, member=DeviceCreated D: [pulseaudio] bluetooth-util.c: Device /org/bluez/497/hci1/dev_90_84_0D_B2_C7_04 created D: [pulseaudio] bluetooth-util.c: dbus: interface=org.freedesktop.DBus, path=/org/freedesktop/DBus, member=NameOwnerChanged D: [pulseaudio] bluetooth-util.c: Bluetooth daemon disappeared. E: [pulseaudio] bluetooth-util.c: Assertion 'p->call_data == d' failed at modules/bluetooth/bluetooth-util.c:685, function get_properties_reply(). Aborting.
This commit is contained in:
parent
90ae777500
commit
2f0f07a755
1 changed files with 4 additions and 2 deletions
|
|
@ -679,8 +679,10 @@ static void get_properties_reply(DBusPendingCall *pending, void *userdata) {
|
|||
if (dbus_message_has_interface(p->message, "org.bluez.Manager") ||
|
||||
dbus_message_has_interface(p->message, "org.bluez.Adapter"))
|
||||
d = NULL;
|
||||
else
|
||||
d = pa_hashmap_get(y->devices, dbus_message_get_path(p->message));
|
||||
else if (!(d = pa_hashmap_get(y->devices, dbus_message_get_path(p->message)))) {
|
||||
pa_log_warn("Received GetProperties() reply from unknown device: %s (device removed?)", dbus_message_get_path(p->message));
|
||||
goto finish2;
|
||||
}
|
||||
|
||||
pa_assert(p->call_data == d);
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue