From: Mikel Astiz <mikel.astiz@xxxxxxxxxxxx> Expose the same API exposed in D-Bus to disconnect devices. --- profiles/input/device.c | 20 ++++++++++++++++++++ profiles/input/device.h | 2 ++ 2 files changed, 22 insertions(+) diff --git a/profiles/input/device.c b/profiles/input/device.c index 7df92e2..fbc3d6f 100644 --- a/profiles/input/device.c +++ b/profiles/input/device.c @@ -700,6 +700,26 @@ static DBusMessage *local_connect(DBusConnection *conn, DBusMessage *msg, return NULL; } +int input_device_disconnect(struct btd_device *dev, struct btd_profile *profile, + btd_profile_cb cb) +{ + struct input_device *idev; + int err; + + idev = find_device_by_path(devices, device_get_path(dev)); + if (!idev) + return -ENOENT; + + err = connection_disconnect(idev, 0); + if (err < 0) + return err; + + if (cb) + cb(profile, dev, 0); + + return 0; +} + static DBusMessage *local_disconnect(DBusConnection *conn, DBusMessage *msg, void *data) { diff --git a/profiles/input/device.h b/profiles/input/device.h index be1f830..d68798c 100644 --- a/profiles/input/device.h +++ b/profiles/input/device.h @@ -38,3 +38,5 @@ int input_device_close_channels(const bdaddr_t *src, const bdaddr_t *dst); int input_device_connect(struct btd_device *dev, struct btd_profile *profile, btd_profile_cb cb); +int input_device_disconnect(struct btd_device *dev, struct btd_profile *profile, + btd_profile_cb cb); -- 1.7.11.7 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html