Diff between f79a9e3b446ba6f529765bea928361f1aec8dc26 and 54addf4e59432b9e6f8f4a08bba46a45693b7fd1

Changed Files

File Additions Deletions Status
profiles/input/hog.c +9 -1 modified

Full Patch

diff --git a/profiles/input/hog.c b/profiles/input/hog.c
index ded6303..b9a14b9 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,9 @@ 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 ?
+					hogdev->name : "bluez-hog-device",
+					sizeof(ev.u.create.name) - 1);
 	ev.u.create.vendor = vendor;
 	ev.u.create.product = product;
 	ev.u.create.version = version;
@@ -722,6 +725,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 +733,9 @@ 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, sizeof(name));
+	if (strlen(name) > 0)
+		hogdev->name = g_strdup(name);
 
 	return hogdev;
 }
@@ -751,6 +758,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);
 }