10#ifndef ZEPHYR_INCLUDE_BLUETOOTH_ADDR_H_
11#define ZEPHYR_INCLUDE_BLUETOOTH_ADDR_H_
28#define BT_ADDR_LE_PUBLIC 0x00
29#define BT_ADDR_LE_RANDOM 0x01
30#define BT_ADDR_LE_PUBLIC_ID 0x02
31#define BT_ADDR_LE_RANDOM_ID 0x03
45#define BT_ADDR_ANY ((bt_addr_t[]) { { { 0, 0, 0, 0, 0, 0 } } })
47#define BT_ADDR_NONE ((bt_addr_t[]) { { \
48 { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff } } })
50#define BT_ADDR_LE_ANY ((bt_addr_le_t[]) { { 0, { { 0, 0, 0, 0, 0, 0 } } } })
52#define BT_ADDR_LE_NONE ((bt_addr_le_t[]) { { 0, \
53 { { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff } } } })
64 return memcmp(a, b,
sizeof(*a));
76 return memcmp(a, b,
sizeof(*a));
86 memcpy(dst, src,
sizeof(*dst));
96 memcpy(dst, src,
sizeof(*dst));
100#define BT_ADDR_IS_RPA(a) (((a)->val[5] & 0xc0) == 0x40)
103#define BT_ADDR_IS_NRPA(a) (((a)->val[5] & 0xc0) == 0x00)
105#define BT_ADDR_IS_STATIC(a) (((a)->val[5] & 0xc0) == 0xc0)
108#define BT_ADDR_SET_RPA(a) ((a)->val[5] = (((a)->val[5] & 0x3f) | 0x40))
110#define BT_ADDR_SET_NRPA(a) ((a)->val[5] &= 0x3f)
112#define BT_ADDR_SET_STATIC(a) ((a)->val[5] |= 0xc0)
162#define BT_ADDR_STR_LEN 18
172#define BT_ADDR_LE_STR_LEN 30
186 return snprintk(str, len,
"%02X:%02X:%02X:%02X:%02X:%02X",
187 addr->
val[5], addr->
val[4], addr->
val[3],
188 addr->
val[2], addr->
val[1], addr->
val[0]);
206 switch (addr->
type) {
214 strcpy(type,
"public-id");
217 strcpy(type,
"random-id");
224 return snprintk(str, len,
"%02X:%02X:%02X:%02X:%02X:%02X (%s)",
#define BT_ADDR_IS_STATIC(a)
Definition: addr.h:105
static int bt_addr_to_str(const bt_addr_t *addr, char *str, size_t len)
Converts binary Bluetooth address to string.
Definition: addr.h:184
#define BT_ADDR_LE_PUBLIC
Definition: addr.h:28
#define BT_ADDR_LE_PUBLIC_ID
Definition: addr.h:30
int bt_addr_le_from_str(const char *str, const char *type, bt_addr_le_t *addr)
Convert LE Bluetooth address from string to binary.
#define BT_ADDR_IS_RPA(a)
Definition: addr.h:100
static int bt_addr_cmp(const bt_addr_t *a, const bt_addr_t *b)
Compare Bluetooth device addresses.
Definition: addr.h:62
static bool bt_addr_le_is_rpa(const bt_addr_le_t *addr)
Check if a Bluetooth LE address is a random private resolvable address.
Definition: addr.h:127
static int bt_addr_le_cmp(const bt_addr_le_t *a, const bt_addr_le_t *b)
Compare Bluetooth LE device addresses.
Definition: addr.h:74
static void bt_addr_copy(bt_addr_t *dst, const bt_addr_t *src)
Copy Bluetooth device address.
Definition: addr.h:84
#define BT_ADDR_LE_RANDOM
Definition: addr.h:29
static int bt_addr_le_to_str(const bt_addr_le_t *addr, char *str, size_t len)
Converts binary LE Bluetooth address to string.
Definition: addr.h:201
static bool bt_addr_le_is_identity(const bt_addr_le_t *addr)
Check if a Bluetooth LE address is valid identity address.
Definition: addr.h:145
static void bt_addr_le_copy(bt_addr_le_t *dst, const bt_addr_le_t *src)
Copy Bluetooth LE device address.
Definition: addr.h:94
int bt_addr_le_create_static(bt_addr_le_t *addr)
Create a Bluetooth LE random static address.
int bt_addr_from_str(const char *str, bt_addr_t *addr)
Convert Bluetooth address from string to binary.
int bt_addr_le_create_nrpa(bt_addr_le_t *addr)
Create a Bluetooth LE random non-resolvable private address.
#define BT_ADDR_LE_RANDOM_ID
Definition: addr.h:31
int snprintk(char *str, size_t size, const char *fmt,...)
__UINT8_TYPE__ uint8_t
Definition: stdint.h:58
char * strcpy(char *_MLIBC_RESTRICT d, const char *_MLIBC_RESTRICT s)
void * memcpy(void *_MLIBC_RESTRICT d, const void *_MLIBC_RESTRICT s, size_t n)
int memcmp(const void *m1, const void *m2, size_t n)
uint8_t type
Definition: addr.h:40
bt_addr_t a
Definition: addr.h:41
uint8_t val[6]
Definition: addr.h:35