Bastien Nocera ebbc29
diff --git a/src/security.c b/src/security.c
Bastien Nocera 1fb2c4
index 905cf61..67fd266 100644
Bastien Nocera ebbc29
--- a/src/security.c
Bastien Nocera ebbc29
+++ b/src/security.c
Bastien Nocera 1fb2c4
@@ -705,8 +705,16 @@ static inline void remote_name_information(int dev, bdaddr_t *sba, void *ptr)
Bastien Nocera 1fb2c4
 		memcpy(name, evt->name, MAX_NAME_LENGTH);
Bastien Nocera ebbc29
 		/* It's ok to cast end between const and non-const since
Bastien Nocera ebbc29
 		 * we know it points to inside of name which is non-const */
Bastien Nocera ebbc29
-		if (!g_utf8_validate(name, -1, (const char **) &end))
Bastien Nocera ebbc29
-			*end = '\0';
Bastien Nocera ebbc29
+		if (!g_utf8_validate(name, -1, (const char **) &end)) {
Bastien Nocera ebbc29
+			char *utf8_name;
Bastien Nocera ebbc29
+
Bastien Nocera ebbc29
+			utf8_name = g_convert(name, -1, "UTF-8", "ISO-8859-1", NULL, NULL, NULL);
Bastien Nocera ebbc29
+			if (utf8_name) {
Bastien Nocera ebbc29
+				memcpy(name, utf8_name, 248);
Bastien Nocera ebbc29
+				g_free(utf8_name);
Bastien Nocera ebbc29
+			} else
Bastien Nocera ebbc29
+				*end = '\0';
Bastien Nocera ebbc29
+		}
Bastien Nocera ebbc29
 		write_device_name(sba, &dba, name);
Bastien Nocera ebbc29
 	}
Bastien Nocera ebbc29