From: baohongde Date: Mon, 26 Feb 2018 07:09:03 +0000 (+0800) Subject: component/bt: Fix bug: string_to_bdaddr() error when opening nano X-Git-Tag: v3.1-beta1~355^2 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=54320d5f7bb4c2855a5a96734e19cf0e50bb2b58;p=esp-idf component/bt: Fix bug: string_to_bdaddr() error when opening nano --- diff --git a/components/bt/bluedroid/btcore/bdaddr.c b/components/bt/bluedroid/btcore/bdaddr.c index e69bb53e1f..e2466fa6bb 100644 --- a/components/bt/bluedroid/btcore/bdaddr.c +++ b/components/bt/bluedroid/btcore/bdaddr.c @@ -102,10 +102,13 @@ bool string_to_bdaddr(const char *string, bt_bdaddr_t *addr) bt_bdaddr_t new_addr; uint8_t *ptr = new_addr.address; - bool ret = sscanf(string, "%02hhx:%02hhx:%02hhx:%02hhx:%02hhx:%02hhx", - &ptr[0], &ptr[1], &ptr[2], &ptr[3], &ptr[4], &ptr[5]) == 6; - + uint32_t ptr_32[6]; + bool ret = sscanf(string, "%02x:%02x:%02x:%02x:%02x:%02x", + &ptr_32[0], &ptr_32[1], &ptr_32[2], &ptr_32[3], &ptr_32[4], &ptr_32[5]) == 6; if (ret) { + for (uint8_t i = 0; i < 6; i++){ + ptr[i] = (uint8_t) ptr_32[i]; + } memcpy(addr, &new_addr, sizeof(bt_bdaddr_t)); }