diff --git a/src/shared/gatt-db.c b/src/shared/gatt-db.c
index 8ef6f3b..efd61f9 100644
--- a/src/shared/gatt-db.c
+++ b/src/shared/gatt-db.c
return (start <= handle) && (handle <= end);
}
-struct gatt_db_attribute *gatt_db_get_attribute(struct gatt_db *db,
+struct gatt_db_attribute *gatt_db_get_service(struct gatt_db *db,
uint16_t handle)
{
struct gatt_db_service *service;
- int i;
if (!db || !handle)
return NULL;
service = queue_find(db->services, find_service_for_handle,
- UINT_TO_PTR(handle));
+ UINT_TO_PTR(handle));
if (!service)
return NULL;
+ return service->attributes[0];
+}
+
+struct gatt_db_attribute *gatt_db_get_attribute(struct gatt_db *db,
+ uint16_t handle)
+{
+ struct gatt_db_attribute *attrib;
+ struct gatt_db_service *service;
+ int i;
+
+ attrib = gatt_db_get_service(db, handle);
+ if (!attrib)
+ return NULL;
+
+ service = attrib->service;
+
for (i = 0; i < service->num_handles; i++) {
if (!service->attributes[i])
continue;
diff --git a/src/shared/gatt-db.h b/src/shared/gatt-db.h
index 134ec63..f8277fd 100644
--- a/src/shared/gatt-db.h
+++ b/src/shared/gatt-db.h
gatt_db_destroy_func_t destroy);
bool gatt_db_unregister(struct gatt_db *db, unsigned int id);
+struct gatt_db_attribute *gatt_db_get_service(struct gatt_db *db,
+ uint16_t handle);
+
struct gatt_db_attribute *gatt_db_get_attribute(struct gatt_db *db,
uint16_t handle);