mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	improve debug
This commit is contained in:
		
							parent
							
								
									068be74f73
								
							
						
					
					
						commit
						75a4cff450
					
				
					 1 changed files with 41 additions and 38 deletions
				
			
		| 
						 | 
					@ -39,6 +39,8 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "defs.h"
 | 
					#include "defs.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define NAME "oFono"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct spa_bt_backend {
 | 
					struct spa_bt_backend {
 | 
				
			||||||
	struct spa_bt_monitor *monitor;
 | 
						struct spa_bt_monitor *monitor;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -92,9 +94,9 @@ static void ofono_transport_get_mtu(struct spa_bt_backend *backend, struct spa_b
 | 
				
			||||||
		memset(&sco_opt, 0, len);
 | 
							memset(&sco_opt, 0, len);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (getsockopt(t->fd, SOL_SCO, SCO_OPTIONS, &sco_opt, &len) < 0)
 | 
							if (getsockopt(t->fd, SOL_SCO, SCO_OPTIONS, &sco_opt, &len) < 0)
 | 
				
			||||||
			spa_log_warn(backend->log, "getsockopt(SCO_OPTIONS) failed, loading defaults");
 | 
								spa_log_warn(backend->log, NAME": getsockopt(SCO_OPTIONS) failed, loading defaults");
 | 
				
			||||||
		else {
 | 
							else {
 | 
				
			||||||
			spa_log_debug(backend->log, "autodetected mtu = %u", sco_opt.mtu);
 | 
								spa_log_debug(backend->log, NAME" : autodetected mtu = %u", sco_opt.mtu);
 | 
				
			||||||
			t->read_mtu = sco_opt.mtu;
 | 
								t->read_mtu = sco_opt.mtu;
 | 
				
			||||||
			t->write_mtu = sco_opt.mtu;
 | 
								t->write_mtu = sco_opt.mtu;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
| 
						 | 
					@ -123,14 +125,14 @@ static int ofono_audio_acquire(void *data, bool optional)
 | 
				
			||||||
	m = NULL;
 | 
						m = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (r == NULL) {
 | 
						if (r == NULL) {
 | 
				
			||||||
		spa_log_error(backend->log, "Transport Acquire() failed for transport %s (%s)",
 | 
							spa_log_error(backend->log, NAME": Transport Acquire() failed for transport %s (%s)",
 | 
				
			||||||
				transport->path, err.message);
 | 
									transport->path, err.message);
 | 
				
			||||||
		dbus_error_free(&err);
 | 
							dbus_error_free(&err);
 | 
				
			||||||
		return -EIO;
 | 
							return -EIO;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (dbus_message_get_type(r) == DBUS_MESSAGE_TYPE_ERROR) {
 | 
						if (dbus_message_get_type(r) == DBUS_MESSAGE_TYPE_ERROR) {
 | 
				
			||||||
		spa_log_error(backend->log, "Acquire returned error: %s", dbus_message_get_error_name(r));
 | 
							spa_log_error(backend->log, NAME": Acquire returned error: %s", dbus_message_get_error_name(r));
 | 
				
			||||||
		ret = -EIO;
 | 
							ret = -EIO;
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					@ -139,12 +141,12 @@ static int ofono_audio_acquire(void *data, bool optional)
 | 
				
			||||||
				   DBUS_TYPE_UNIX_FD, &transport->fd,
 | 
									   DBUS_TYPE_UNIX_FD, &transport->fd,
 | 
				
			||||||
				   DBUS_TYPE_BYTE, &transport->codec,
 | 
									   DBUS_TYPE_BYTE, &transport->codec,
 | 
				
			||||||
				   DBUS_TYPE_INVALID)) {
 | 
									   DBUS_TYPE_INVALID)) {
 | 
				
			||||||
		spa_log_error(backend->log, "Failed to parse Acquire() reply: %s", err.message);
 | 
							spa_log_error(backend->log, NAME": Failed to parse Acquire() reply: %s", err.message);
 | 
				
			||||||
		dbus_error_free(&err);
 | 
							dbus_error_free(&err);
 | 
				
			||||||
		ret = -EIO;
 | 
							ret = -EIO;
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	spa_log_debug(backend->log, "transport %p: Acquire %s, fd %d codec %d", transport,
 | 
						spa_log_debug(backend->log, NAME": transport %p: Acquire %s, fd %d codec %d", transport,
 | 
				
			||||||
			transport->path, transport->fd, transport->codec);
 | 
								transport->path, transport->fd, transport->codec);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ofono_transport_get_mtu(backend, transport);
 | 
						ofono_transport_get_mtu(backend, transport);
 | 
				
			||||||
| 
						 | 
					@ -161,11 +163,11 @@ static int ofono_audio_release(void *data)
 | 
				
			||||||
	struct spa_bt_backend *backend = transport->backend;
 | 
						struct spa_bt_backend *backend = transport->backend;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (transport->fd < 0) {
 | 
						if (transport->fd < 0) {
 | 
				
			||||||
		spa_log_info(backend->log, "transport %s already released", transport->path);
 | 
							spa_log_info(backend->log, NAME": transport %s already released", transport->path);
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "transport %p: Release %s",
 | 
						spa_log_debug(backend->log, NAME": transport %p: Release %s",
 | 
				
			||||||
			transport, transport->path);
 | 
								transport, transport->path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* shutdown to make sure connection is dropped immediately */
 | 
						/* shutdown to make sure connection is dropped immediately */
 | 
				
			||||||
| 
						 | 
					@ -183,14 +185,14 @@ static DBusHandlerResult ofono_audio_card_removed(struct spa_bt_backend *backend
 | 
				
			||||||
	spa_assert(backend);
 | 
						spa_assert(backend);
 | 
				
			||||||
	spa_assert(path);
 | 
						spa_assert(path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "oFono card removed: %s", path);
 | 
						spa_log_debug(backend->log, NAME": card removed: %s", path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	transport = spa_bt_transport_find(backend->monitor, path);
 | 
						transport = spa_bt_transport_find(backend->monitor, path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (transport != NULL) {
 | 
						if (transport != NULL) {
 | 
				
			||||||
		struct spa_bt_device *device = transport->device;
 | 
							struct spa_bt_device *device = transport->device;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		spa_log_debug(backend->log, "transport %p: free %s",
 | 
							spa_log_debug(backend->log, NAME" :transport %p: free %s",
 | 
				
			||||||
			transport, transport->path);
 | 
								transport, transport->path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		spa_bt_transport_free(transport);
 | 
							spa_bt_transport_free(transport);
 | 
				
			||||||
| 
						 | 
					@ -219,7 +221,7 @@ static DBusHandlerResult ofono_audio_card_found(struct spa_bt_backend *backend,
 | 
				
			||||||
	spa_assert(path);
 | 
						spa_assert(path);
 | 
				
			||||||
	spa_assert(props_i);
 | 
						spa_assert(props_i);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "oFono new card: %s", path);
 | 
						spa_log_debug(backend->log, NAME": new card: %s", path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	while (dbus_message_iter_get_arg_type(props_i) != DBUS_TYPE_INVALID) {
 | 
						while (dbus_message_iter_get_arg_type(props_i) != DBUS_TYPE_INVALID) {
 | 
				
			||||||
		DBusMessageIter i, value_i;
 | 
							DBusMessageIter i, value_i;
 | 
				
			||||||
| 
						 | 
					@ -233,7 +235,7 @@ static DBusHandlerResult ofono_audio_card_found(struct spa_bt_backend *backend,
 | 
				
			||||||
		dbus_message_iter_recurse(&i, &value_i);
 | 
							dbus_message_iter_recurse(&i, &value_i);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ((c = dbus_message_iter_get_arg_type(&value_i)) != DBUS_TYPE_STRING) {
 | 
							if ((c = dbus_message_iter_get_arg_type(&value_i)) != DBUS_TYPE_STRING) {
 | 
				
			||||||
			spa_log_error(backend->log, "Invalid properties for %s: expected 's', received '%c'", path, c);
 | 
								spa_log_error(backend->log, NAME": Invalid properties for %s: expected 's', received '%c'", path, c);
 | 
				
			||||||
			return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
 | 
								return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -248,21 +250,21 @@ static DBusHandlerResult ofono_audio_card_found(struct spa_bt_backend *backend,
 | 
				
			||||||
				profile = SPA_BT_PROFILE_HFP_HF;
 | 
									profile = SPA_BT_PROFILE_HFP_HF;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		spa_log_debug(backend->log, "%s: %s", key, value);
 | 
							spa_log_debug(backend->log, NAME": %s: %s", key, value);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		dbus_message_iter_next(props_i);
 | 
							dbus_message_iter_next(props_i);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	d = spa_bt_device_find_by_address(backend->monitor, remote_address, local_address);
 | 
						d = spa_bt_device_find_by_address(backend->monitor, remote_address, local_address);
 | 
				
			||||||
	if (!d) {
 | 
						if (!d) {
 | 
				
			||||||
		spa_log_error(backend->log, "Device doesn’t exist for %s", path);
 | 
							spa_log_error(backend->log, NAME": Device doesn’t exist for %s", path);
 | 
				
			||||||
		return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
 | 
							return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	char *t_path = strdup(path);
 | 
						char *t_path = strdup(path);
 | 
				
			||||||
	t = spa_bt_transport_create(backend->monitor, t_path, 0);
 | 
						t = spa_bt_transport_create(backend->monitor, t_path, 0);
 | 
				
			||||||
	if (t == NULL) {
 | 
						if (t == NULL) {
 | 
				
			||||||
		spa_log_warn(backend->log, "can't create transport: %m");
 | 
							spa_log_warn(backend->log, NAME": can't create transport: %m");
 | 
				
			||||||
		free(t_path);
 | 
							free(t_path);
 | 
				
			||||||
		return DBUS_HANDLER_RESULT_NEED_MEMORY;
 | 
							return DBUS_HANDLER_RESULT_NEED_MEMORY;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					@ -275,7 +277,7 @@ static DBusHandlerResult ofono_audio_card_found(struct spa_bt_backend *backend,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_bt_device_connect_profile(t->device, profile);
 | 
						spa_bt_device_connect_profile(t->device, profile);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "Transport %s available for oFono", t->path);
 | 
						spa_log_debug(backend->log, NAME": Transport %s available", t->path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return DBUS_HANDLER_RESULT_HANDLED;
 | 
						return DBUS_HANDLER_RESULT_HANDLED;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -285,7 +287,7 @@ static DBusHandlerResult ofono_release(DBusConnection *conn, DBusMessage *m, voi
 | 
				
			||||||
	struct spa_bt_backend *backend = userdata;
 | 
						struct spa_bt_backend *backend = userdata;
 | 
				
			||||||
	DBusMessage *r;
 | 
						DBusMessage *r;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_warn(backend->log, "oFono release");
 | 
						spa_log_warn(backend->log, NAME": release");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	r = dbus_message_new_error(m, OFONO_HF_AUDIO_AGENT_INTERFACE ".Error.NotImplemented",
 | 
						r = dbus_message_new_error(m, OFONO_HF_AUDIO_AGENT_INTERFACE ".Error.NotImplemented",
 | 
				
			||||||
                                            "Method not implemented");
 | 
					                                            "Method not implemented");
 | 
				
			||||||
| 
						 | 
					@ -319,7 +321,8 @@ static DBusHandlerResult ofono_new_audio_connection(DBusConnection *conn, DBusMe
 | 
				
			||||||
	t = spa_bt_transport_find(backend->monitor, path);
 | 
						t = spa_bt_transport_find(backend->monitor, path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!t || codec != HFP_AUDIO_CODEC_CVSD || t->fd >= 0) {
 | 
						if (!t || codec != HFP_AUDIO_CODEC_CVSD || t->fd >= 0) {
 | 
				
			||||||
			spa_log_warn(backend->log, "New audio connection invalid arguments (path=%s fd=%d, codec=%d)", path, fd, codec);
 | 
								spa_log_warn(backend->log, NAME": New audio connection invalid "
 | 
				
			||||||
 | 
										"arguments (path=%s fd=%d, codec=%d)", path, fd, codec);
 | 
				
			||||||
			r = dbus_message_new_error(m, "org.ofono.Error.InvalidArguments", "Invalid arguments in method call");
 | 
								r = dbus_message_new_error(m, "org.ofono.Error.InvalidArguments", "Invalid arguments in method call");
 | 
				
			||||||
			shutdown(fd, SHUT_RDWR);
 | 
								shutdown(fd, SHUT_RDWR);
 | 
				
			||||||
			close(fd);
 | 
								close(fd);
 | 
				
			||||||
| 
						 | 
					@ -330,7 +333,7 @@ static DBusHandlerResult ofono_new_audio_connection(DBusConnection *conn, DBusMe
 | 
				
			||||||
	t->codec = codec;
 | 
						t->codec = codec;
 | 
				
			||||||
	ofono_transport_get_mtu(backend, t);
 | 
						ofono_transport_get_mtu(backend, t);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "transport %p: NewConnection %s, fd %d codec %d", t, t->path, t->fd, t->codec);
 | 
						spa_log_debug(backend->log, NAME": transport %p: NewConnection %s, fd %d codec %d", t, t->path, t->fd, t->codec);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* TODO: pass fd to SCO nodes */
 | 
						/* TODO: pass fd to SCO nodes */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -354,7 +357,7 @@ static DBusHandlerResult ofono_handler(DBusConnection *c, DBusMessage *m, void *
 | 
				
			||||||
	interface = dbus_message_get_interface(m);
 | 
						interface = dbus_message_get_interface(m);
 | 
				
			||||||
	member = dbus_message_get_member(m);
 | 
						member = dbus_message_get_member(m);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "dbus: path=%s, interface=%s, member=%s", path, interface, member);
 | 
						spa_log_debug(backend->log, NAME": path=%s, interface=%s, member=%s", path, interface, member);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (dbus_message_is_method_call(m, "org.freedesktop.DBus.Introspectable", "Introspect")) {
 | 
						if (dbus_message_is_method_call(m, "org.freedesktop.DBus.Introspectable", "Introspect")) {
 | 
				
			||||||
		const char *xml = OFONO_INTROSPECT_XML;
 | 
							const char *xml = OFONO_INTROSPECT_XML;
 | 
				
			||||||
| 
						 | 
					@ -390,13 +393,13 @@ static void ofono_getcards_reply(DBusPendingCall *pending, void *user_data)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (dbus_message_get_type(r) == DBUS_MESSAGE_TYPE_ERROR) {
 | 
						if (dbus_message_get_type(r) == DBUS_MESSAGE_TYPE_ERROR) {
 | 
				
			||||||
		spa_log_error(backend->log, "Failed to get a list of handsfree audio cards from ofono: %s",
 | 
							spa_log_error(backend->log, NAME": Failed to get a list of handsfree audio cards: %s",
 | 
				
			||||||
				dbus_message_get_error_name(r));
 | 
									dbus_message_get_error_name(r));
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!dbus_message_iter_init(r, &i) || strcmp(dbus_message_get_signature(r), "a(oa{sv})") != 0) {
 | 
						if (!dbus_message_iter_init(r, &i) || strcmp(dbus_message_get_signature(r), "a(oa{sv})") != 0) {
 | 
				
			||||||
		spa_log_error(backend->log, "Invalid arguments in GetCards() reply");
 | 
							spa_log_error(backend->log, NAME": Invalid arguments in GetCards() reply");
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -432,24 +435,24 @@ static void ofono_register_reply(DBusPendingCall *pending, void *user_data)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (dbus_message_is_error(r, OFONO_ERROR_INVALID_ARGUMENTS)) {
 | 
						if (dbus_message_is_error(r, OFONO_ERROR_INVALID_ARGUMENTS)) {
 | 
				
			||||||
		spa_log_warn(backend->log, "oFono invalid arguments");
 | 
							spa_log_warn(backend->log, NAME": invalid arguments");
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if (dbus_message_is_error(r, OFONO_ERROR_IN_USE)) {
 | 
						if (dbus_message_is_error(r, OFONO_ERROR_IN_USE)) {
 | 
				
			||||||
		spa_log_warn(backend->log, "oFono already in use");
 | 
							spa_log_warn(backend->log, NAME": already in use");
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if (dbus_message_is_error(r, DBUS_ERROR_UNKNOWN_METHOD)) {
 | 
						if (dbus_message_is_error(r, DBUS_ERROR_UNKNOWN_METHOD)) {
 | 
				
			||||||
		spa_log_warn(backend->log, "Error registering profile");
 | 
							spa_log_warn(backend->log, NAME": Error registering profile");
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if (dbus_message_get_type(r) == DBUS_MESSAGE_TYPE_ERROR) {
 | 
						if (dbus_message_get_type(r) == DBUS_MESSAGE_TYPE_ERROR) {
 | 
				
			||||||
		spa_log_error(backend->log, "Register() failed: %s",
 | 
							spa_log_error(backend->log, NAME": Register() failed: %s",
 | 
				
			||||||
				dbus_message_get_error_name(r));
 | 
									dbus_message_get_error_name(r));
 | 
				
			||||||
		goto finish;
 | 
							goto finish;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "oFono registered");
 | 
						spa_log_debug(backend->log, NAME": registered");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	m = dbus_message_new_method_call(OFONO_SERVICE, "/",
 | 
						m = dbus_message_new_method_call(OFONO_SERVICE, "/",
 | 
				
			||||||
			OFONO_HF_AUDIO_MANAGER_INTERFACE, "GetCards");
 | 
								OFONO_HF_AUDIO_MANAGER_INTERFACE, "GetCards");
 | 
				
			||||||
| 
						 | 
					@ -474,7 +477,7 @@ static int ofono_register(struct spa_bt_backend *backend)
 | 
				
			||||||
	int ncodecs = 0;
 | 
						int ncodecs = 0;
 | 
				
			||||||
	DBusPendingCall *call;
 | 
						DBusPendingCall *call;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spa_log_debug(backend->log, "Registering oFono");
 | 
						spa_log_debug(backend->log, NAME": Registering");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	m = dbus_message_new_method_call(OFONO_SERVICE, "/",
 | 
						m = dbus_message_new_method_call(OFONO_SERVICE, "/",
 | 
				
			||||||
			OFONO_HF_AUDIO_MANAGER_INTERFACE, "Register");
 | 
								OFONO_HF_AUDIO_MANAGER_INTERFACE, "Register");
 | 
				
			||||||
| 
						 | 
					@ -509,18 +512,18 @@ static DBusHandlerResult ofono_filter_cb(DBusConnection *bus, DBusMessage *m, vo
 | 
				
			||||||
		                           DBUS_TYPE_STRING, &old_owner,
 | 
							                           DBUS_TYPE_STRING, &old_owner,
 | 
				
			||||||
		                           DBUS_TYPE_STRING, &new_owner,
 | 
							                           DBUS_TYPE_STRING, &new_owner,
 | 
				
			||||||
		                           DBUS_TYPE_INVALID)) {
 | 
							                           DBUS_TYPE_INVALID)) {
 | 
				
			||||||
				spa_log_error(backend->log, "Failed to parse org.freedesktop.DBus.NameOwnerChanged: %s", err.message);
 | 
									spa_log_error(backend->log, NAME": Failed to parse org.freedesktop.DBus.NameOwnerChanged: %s", err.message);
 | 
				
			||||||
				goto fail;
 | 
									goto fail;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (strcmp(name, OFONO_SERVICE) == 0) {
 | 
							if (strcmp(name, OFONO_SERVICE) == 0) {
 | 
				
			||||||
				if (old_owner && *old_owner) {
 | 
									if (old_owner && *old_owner) {
 | 
				
			||||||
						spa_log_debug(backend->log, "oFono disappeared");
 | 
											spa_log_debug(backend->log, NAME": disappeared");
 | 
				
			||||||
						//ofono_bus_id_destroy(backend);
 | 
											//ofono_bus_id_destroy(backend);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				if (new_owner && *new_owner) {
 | 
									if (new_owner && *new_owner) {
 | 
				
			||||||
						spa_log_debug(backend->log, "oFono appeared");
 | 
											spa_log_debug(backend->log, NAME": appeared");
 | 
				
			||||||
						ofono_register(backend);
 | 
											ofono_register(backend);
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
| 
						 | 
					@ -531,7 +534,7 @@ static DBusHandlerResult ofono_filter_cb(DBusConnection *bus, DBusMessage *m, vo
 | 
				
			||||||
			DBusMessageIter arg_i, props_i;
 | 
								DBusMessageIter arg_i, props_i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (!dbus_message_iter_init(m, &arg_i) || strcmp(dbus_message_get_signature(m), "oa{sv}") != 0) {
 | 
								if (!dbus_message_iter_init(m, &arg_i) || strcmp(dbus_message_get_signature(m), "oa{sv}") != 0) {
 | 
				
			||||||
					spa_log_error(backend->log, "Failed to parse org.ofono.HandsfreeAudioManager.CardAdded");
 | 
										spa_log_error(backend->log, NAME": Failed to parse org.ofono.HandsfreeAudioManager.CardAdded");
 | 
				
			||||||
					goto fail;
 | 
										goto fail;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -547,7 +550,7 @@ static DBusHandlerResult ofono_filter_cb(DBusConnection *bus, DBusMessage *m, vo
 | 
				
			||||||
			const char *p;
 | 
								const char *p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			if (!dbus_message_get_args(m, &err, DBUS_TYPE_OBJECT_PATH, &p, DBUS_TYPE_INVALID)) {
 | 
								if (!dbus_message_get_args(m, &err, DBUS_TYPE_OBJECT_PATH, &p, DBUS_TYPE_INVALID)) {
 | 
				
			||||||
					spa_log_error(backend->log, "Failed to parse org.ofono.HandsfreeAudioManager.CardRemoved: %s", err.message);
 | 
										spa_log_error(backend->log, NAME": Failed to parse org.ofono.HandsfreeAudioManager.CardRemoved: %s", err.message);
 | 
				
			||||||
					goto fail;
 | 
										goto fail;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -568,7 +571,7 @@ void backend_ofono_add_filters(struct spa_bt_backend *backend)
 | 
				
			||||||
	dbus_error_init(&err);
 | 
						dbus_error_init(&err);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!dbus_connection_add_filter(backend->conn, ofono_filter_cb, backend, NULL)) {
 | 
						if (!dbus_connection_add_filter(backend->conn, ofono_filter_cb, backend, NULL)) {
 | 
				
			||||||
		spa_log_error(backend->log, "failed to add filter function");
 | 
							spa_log_error(backend->log, NAME": failed to add filter function");
 | 
				
			||||||
		goto fail;
 | 
							goto fail;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -601,7 +604,7 @@ void backend_ofono_free(struct spa_bt_backend *backend)
 | 
				
			||||||
struct spa_bt_backend *backend_ofono_new(struct spa_bt_monitor *monitor,
 | 
					struct spa_bt_backend *backend_ofono_new(struct spa_bt_monitor *monitor,
 | 
				
			||||||
		void *dbus_connection,
 | 
							void *dbus_connection,
 | 
				
			||||||
		const struct spa_support *support,
 | 
							const struct spa_support *support,
 | 
				
			||||||
	  uint32_t n_support)
 | 
							uint32_t n_support)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct spa_bt_backend *backend;
 | 
						struct spa_bt_backend *backend;
 | 
				
			||||||
	static const DBusObjectPathVTable vtable_profile = {
 | 
						static const DBusObjectPathVTable vtable_profile = {
 | 
				
			||||||
| 
						 | 
					@ -621,11 +624,11 @@ struct spa_bt_backend *backend_ofono_new(struct spa_bt_monitor *monitor,
 | 
				
			||||||
	if (!dbus_connection_register_object_path(backend->conn,
 | 
						if (!dbus_connection_register_object_path(backend->conn,
 | 
				
			||||||
						  OFONO_AUDIO_CLIENT,
 | 
											  OFONO_AUDIO_CLIENT,
 | 
				
			||||||
						  &vtable_profile, backend)) {
 | 
											  &vtable_profile, backend)) {
 | 
				
			||||||
    free(backend);
 | 
							free(backend);
 | 
				
			||||||
		return NULL;
 | 
							return NULL;
 | 
				
			||||||
  }
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ofono_register(backend);
 | 
						ofono_register(backend);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return backend;
 | 
						return backend;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue