--- profiles/input/hog.c | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/profiles/input/hog.c b/profiles/input/hog.c index ded6303..7a54aa1 100644 --- a/profiles/input/hog.c +++ b/profiles/input/hog.c @@ -91,6 +91,7 @@ struct hog_device { uint16_t proto_mode_handle; uint16_t ctrlpt_handle; uint8_t flags; + char *name; }; struct report { @@ -392,7 +393,8 @@ static void report_map_read_cb(guint8 status, const guint8 *pdu, guint16 plen, /* create uHID device */ memset(&ev, 0, sizeof(ev)); ev.type = UHID_CREATE; - strcpy((char *) ev.u.create.name, "bluez-hog-device"); + strncpy((char *) ev.u.create.name, hogdev->name, + sizeof(ev.u.create.name) - 1); ev.u.create.vendor = vendor; ev.u.create.product = product; ev.u.create.version = version; @@ -722,6 +724,7 @@ static struct hog_device *hog_new_device(struct btd_device *device, uint16_t id) { struct hog_device *hogdev; + char name[HCI_MAX_NAME_LENGTH + 1]; hogdev = g_try_new0(struct hog_device, 1); if (!hogdev) @@ -729,6 +732,12 @@ static struct hog_device *hog_new_device(struct btd_device *device, hogdev->id = id; hogdev->device = btd_device_ref(device); + device_get_name(device, name, HCI_MAX_NAME_LENGTH); + name[HCI_MAX_NAME_LENGTH] = '\0'; + if (strlen(name) > 0) + hogdev->name = g_strdup(name); + else + hogdev->name = g_strdup("bluez-hog-device"); return hogdev; } @@ -751,6 +760,7 @@ static void hog_free_device(struct hog_device *hogdev) g_slist_free_full(hogdev->reports, report_free); g_attrib_unref(hogdev->attrib); g_free(hogdev->hog_primary); + g_free(hogdev->name); g_free(hogdev); } -- 1.9.0.rc1.175.g0b1dcb5 -- 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