Diff between b338b804fa5f00c463cf6cff2fa3e2325e013994 and d010757dd10079f4172a5082d32dd43f454a85c7

Changed Files

File Additions Deletions Status
src/service.c +12 -0 modified
src/service.h +2 -0 modified

Full Patch

diff --git a/src/service.c b/src/service.c
index a10138d..e03a412 100644
--- a/src/service.c
+++ b/src/service.c
@@ -50,6 +50,7 @@ struct btd_service {
 	gint			ref;
 	struct btd_device	*device;
 	struct btd_profile	*profile;
+	void			*user_data;
 	btd_service_state_t	state;
 };
 
@@ -239,6 +240,17 @@ struct btd_profile *btd_service_get_profile(const struct btd_service *service)
 	return service->profile;
 }
 
+void btd_service_set_user_data(struct btd_service *service, void *user_data)
+{
+	assert(service->state == BTD_SERVICE_STATE_UNAVAILABLE);
+	service->user_data = user_data;
+}
+
+void *btd_service_get_user_data(const struct btd_service *service)
+{
+	return service->user_data;
+}
+
 btd_service_state_t btd_service_get_state(const struct btd_service *service)
 {
 	return service->state;
diff --git a/src/service.h b/src/service.h
index 8fb1ed5..a89b524 100644
--- a/src/service.h
+++ b/src/service.h
@@ -55,3 +55,5 @@ btd_service_state_t btd_service_get_state(const struct btd_service *service);
 /* Functions used by profile implementation */
 void btd_service_connecting_complete(struct btd_service *service, int err);
 void btd_service_disconnecting_complete(struct btd_service *service, int err);
+void btd_service_set_user_data(struct btd_service *service, void *user_data);
+void *btd_service_get_user_data(const struct btd_service *service);