diff options
| -rw-r--r-- | hcid/adapter.c | 20 | ||||
| -rw-r--r-- | hcid/device.c | 5 | 
2 files changed, 16 insertions, 9 deletions
| diff --git a/hcid/adapter.c b/hcid/adapter.c index 269476ec..94aceadb 100644 --- a/hcid/adapter.c +++ b/hcid/adapter.c @@ -2298,10 +2298,6 @@ struct device *adapter_get_device(DBusConnection *conn,  	snprintf(path, MAX_PATH_LENGTH, "/hci%d", adapter->dev_id);  	adapter->devices = g_slist_append(adapter->devices, device); -	dbus_connection_emit_signal(conn, path, -				ADAPTER_INTERFACE, "DeviceCreated", -				DBUS_TYPE_OBJECT_PATH, &device->path, -				DBUS_TYPE_INVALID);  	return device;  } @@ -2318,11 +2314,13 @@ void adapter_remove_device(DBusConnection *conn, struct adapter *adapter,  	snprintf(path, MAX_PATH_LENGTH, "/hci%d", adapter->dev_id); -	dbus_connection_emit_signal(conn, path, -			ADAPTER_INTERFACE, -			"DeviceRemoved", -			DBUS_TYPE_OBJECT_PATH, &device->path, -			DBUS_TYPE_INVALID); +	if (!device->temporary) { +		dbus_connection_emit_signal(conn, path, +				ADAPTER_INTERFACE, +				"DeviceRemoved", +				DBUS_TYPE_OBJECT_PATH, &device->path, +				DBUS_TYPE_INVALID); +	}  	device_remove(device, conn);  	adapter->devices = g_slist_remove(adapter->devices, device); @@ -3687,6 +3685,10 @@ static DBusHandlerResult list_devices(DBusConnection *conn,  	for (l = adapter->devices; l; l = l->next) {  		struct device *device = l->data; + +		if (device->temporary) +			continue; +  		dbus_message_iter_append_basic(&array_iter,  				DBUS_TYPE_OBJECT_PATH, &device->path);  	} diff --git a/hcid/device.c b/hcid/device.c index 32567851..1a0840e5 100644 --- a/hcid/device.c +++ b/hcid/device.c @@ -1114,6 +1114,11 @@ static void browse_cb(gpointer user_data, sdp_list_t *recs, int err)  					DBUS_TYPE_ARRAY, &uuids);  	g_free(uuids); +	dbus_connection_emit_signal(req->conn, dbus_message_get_path(req->msg), +				ADAPTER_INTERFACE, "DeviceCreated", +				DBUS_TYPE_OBJECT_PATH, &device->path, +				DBUS_TYPE_INVALID); +  	/* Reply create device request */  	reply = dbus_message_new_method_return(req->msg);  	if (!reply) | 
