From de66f77b07f0151b5dafadddaf13b66d40a43497 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fr=C3=A9d=C3=A9ric=20Danis?= Date: Fri, 30 Nov 2012 15:47:01 +0100 Subject: [PATCH] adapter: Convert storage linkkeys file --- src/adapter.c | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/src/adapter.c b/src/adapter.c index f3b1c5d5a..bf20580ba 100644 --- a/src/adapter.c +++ b/src/adapter.c @@ -2639,6 +2639,34 @@ static void convert_did_entry(GKeyFile *key_file, void *value) g_key_file_set_integer(key_file, "DeviceID", "Version", val); } +static void convert_linkkey_entry(GKeyFile *key_file, void *value) +{ + char *type_str, *length_str, *str; + gint val; + + type_str = strchr(value, ' '); + if (!type_str) + return; + + *(type_str++) = 0; + + length_str = strchr(type_str, ' '); + if (!length_str) + return; + + *(length_str++) = 0; + + str = g_strconcat("0x", value, NULL); + g_key_file_set_string(key_file, "LinkKey", "Key", str); + g_free(str); + + val = strtol(type_str, NULL, 16); + g_key_file_set_integer(key_file, "LinkKey", "Type", val); + + val = strtol(length_str, NULL, 16); + g_key_file_set_integer(key_file, "LinkKey", "PINLength", val); +} + static void convert_entry(char *key, char *value, void *user_data) { struct device_converter *converter = user_data; @@ -2747,6 +2775,9 @@ static void convert_device_storage(struct btd_adapter *adapter) /* Convert blocked */ convert_file("blocked", address, convert_blocked_entry, TRUE); + /* Convert linkkeys */ + convert_file("linkkeys", address, convert_linkkey_entry, TRUE); + /* Convert classes */ convert_file("classes", address, convert_classes_entry, FALSE); -- 2.47.3