Morse Micro IoT SDK  2.10.4
mmutils.h
1/*
2 * Copyright 2024 Morse Micro
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
15#pragma once
16
17#include <stdarg.h>
18#include <stdint.h>
19#include <stdlib.h>
20#include <stdbool.h>
21#include <string.h>
22
23#ifdef __cplusplus
24extern "C"
25{
26#endif
27
42#define MM_MIN(_x, _y) (((_x) < (_y)) ? (_x) : (_y))
43
58#define MM_MAX(_x, _y) (((_x) > (_y)) ? (_x) : (_y))
59
65#ifndef MM_FAST_ROUND_UP
66#define MM_FAST_ROUND_UP(x, m) ((((x) - 1) | ((m) - 1)) + 1)
67#endif
68
70#define MM_UNUSED(_x) (void)(_x)
71
73#ifndef MM_PACKED
74#define MM_PACKED __attribute__((packed))
75#endif
76
78#ifndef MM_WEAK
79#define MM_WEAK __attribute__((weak))
80#endif
81
83#ifndef MM_FALLTHROUGH
84#define MM_FALLTHROUGH __attribute__((fallthrough))
85#endif
86
87#ifndef MM_STATIC_ASSERT
99#define MM_STATIC_ASSERT(_expression, _message) _Static_assert((_expression), _message)
100#endif
101
111#define MM_ARRAY_COUNT(_a) (sizeof(_a) / sizeof((_a)[0]))
112
121#define MM_MEMBER_SIZE(_type, _member) (sizeof(((_type *)0)->_member))
122
135static inline char mm_nibble_to_hex_char(uint8_t nibble)
136{
137 nibble &= 0x0f;
138 if (nibble < 0x0a)
139 {
140 return '0' + nibble;
141 }
142 else
143 {
144 return 'A' + nibble - 0x0a;
145 }
146}
147
158{
162 MM_AKM_SUITE_PSK = 0x506f9a02,
164 MM_AKM_SUITE_SAE = 0x000fac08,
166 MM_AKM_SUITE_OWE = 0x000fac12,
169};
170
173{
178};
179
181#ifndef MM_RSN_INFORMATION_MAX_PAIRWISE_CIPHER_SUITES
182#define MM_RSN_INFORMATION_MAX_PAIRWISE_CIPHER_SUITES (2)
183#endif
184
186#ifndef MM_RSN_INFORMATION_MAX_AKM_SUITES
187#define MM_RSN_INFORMATION_MAX_AKM_SUITES (2)
188#endif
189
191#define MM_RSN_INFORMATION_IE_TYPE (48)
193#define MM_VENDOR_SPECIFIC_IE_TYPE (221)
195#define MM_S1G_OPERATION_IE_TYPE (232)
196
200{
201 MM_ENOMEM = 12,
202 MM_EFAULT = 14,
203 MM_ENODEV = 19,
204 MM_EINVAL = 22,
205 MM_ETIMEDOUT = 110,
206};
207
214{
226 uint16_t version;
229};
230
238const char *mm_akm_suite_to_string(uint32_t akm_suite_oui);
239
256int mm_find_ie_from_offset(const uint8_t *ies,
257 uint32_t ies_len,
258 uint32_t search_offset,
259 uint8_t ie_type);
260
273static inline int mm_find_ie(const uint8_t *ies, uint32_t ies_len, uint8_t ie_type)
274{
275 return mm_find_ie_from_offset(ies, ies_len, 0, ie_type);
276}
277
296 uint32_t ies_len,
297 uint32_t search_offset,
298 const uint8_t *id,
299 size_t id_len);
300
314static inline int mm_find_vendor_specific_ie(const uint8_t *ies,
315 uint32_t ies_len,
316 const uint8_t *id,
317 size_t id_len)
318{
319 return mm_find_vendor_specific_ie_from_offset(ies, ies_len, 0, id, id_len);
320}
321
332int mm_parse_rsn_information(const uint8_t *ies,
333 uint32_t ies_len,
334 struct mm_rsn_information *output);
335
340{
351};
352
363int mm_parse_s1g_operation(const uint8_t *ies, uint32_t ies_len, struct mm_s1g_operation *output);
364
372static inline bool mm_mac_addr_is_zero(const uint8_t *mac_addr)
373{
374 return (mac_addr[0] | mac_addr[1] | mac_addr[2] | mac_addr[3] | mac_addr[4] | mac_addr[5]) ==
375 0x00;
376}
377
385static inline bool mm_mac_addr_is_multicast(const uint8_t *mac_addr)
386{
387 return mac_addr[0] & 0x01;
388}
389
397static inline bool mm_mac_addr_is_broadcast(const uint8_t *mac_addr)
398{
399 return (mac_addr[0] & mac_addr[1] & mac_addr[2] & mac_addr[3] & mac_addr[4] & mac_addr[5]) ==
400 0xff;
401}
402
411static inline bool mm_mac_addr_is_equal(const uint8_t *mac_addr1, const uint8_t *mac_addr2)
412{
413 return memcmp(mac_addr1, mac_addr2, 6) == 0;
414}
415
418#ifdef __cplusplus
419}
420#endif
421
#define MM_RSN_INFORMATION_MAX_AKM_SUITES
Maximum number of AKM suites our parser will process.
Definition: mmutils.h:187
static int mm_find_vendor_specific_ie(const uint8_t *ies, uint32_t ies_len, const uint8_t *id, size_t id_len)
Search through the given list of Information Elements (IEs) to find the first Vendor Specific IE that...
Definition: mmutils.h:314
mm_akm_suite_oui
Enumeration of Authentication Key Management (AKM) Suite OUIs as BE32 integers.
Definition: mmutils.h:158
static bool mm_mac_addr_is_zero(const uint8_t *mac_addr)
Determines if a given MAC address is all zeros.
Definition: mmutils.h:372
static int mm_find_ie(const uint8_t *ies, uint32_t ies_len, uint8_t ie_type)
Search a list of Information Elements (IEs) and find the first instance of matching the given type.
Definition: mmutils.h:273
const char * mm_akm_suite_to_string(uint32_t akm_suite_oui)
Get the name of the given AKM Suite as a string.
int mm_parse_s1g_operation(const uint8_t *ies, uint32_t ies_len, struct mm_s1g_operation *output)
Find the S1G Operation information element from within a block of IEs and extract useful information ...
static bool mm_mac_addr_is_multicast(const uint8_t *mac_addr)
Determines if a given MAC address is a multicast/broadcast address.
Definition: mmutils.h:385
static bool mm_mac_addr_is_equal(const uint8_t *mac_addr1, const uint8_t *mac_addr2)
Compares two MAC addresses and determines if they are equal.
Definition: mmutils.h:411
int mm_find_vendor_specific_ie_from_offset(const uint8_t *ies, uint32_t ies_len, uint32_t search_offset, const uint8_t *id, size_t id_len)
Search through the given list of Information Elements (IEs) from the given starting offset to find th...
static bool mm_mac_addr_is_broadcast(const uint8_t *mac_addr)
Determines if a given MAC address is the broadcast address (i.e., ff:ff:ff:ff:ff:ff ).
Definition: mmutils.h:397
mm_errno
Explicitly defined errno values to obviate the need to include errno.h.
Definition: mmutils.h:200
int mm_parse_rsn_information(const uint8_t *ies, uint32_t ies_len, struct mm_rsn_information *output)
Search through the given list of information elements to find the RSN IE then parse it to extract rel...
#define MM_RSN_INFORMATION_MAX_PAIRWISE_CIPHER_SUITES
Maximum number of pairwise cipher suites our parser will process.
Definition: mmutils.h:182
mm_cipher_suite_oui
Enumeration of Cipher Suite OUIs as BE32 integers.
Definition: mmutils.h:173
int mm_find_ie_from_offset(const uint8_t *ies, uint32_t ies_len, uint32_t search_offset, uint8_t ie_type)
Search a list of Information Elements (IEs) from the given starting offset and find the first instanc...
@ MM_AKM_SUITE_SAE
Simultaneous Authentication of Equals (SAE)
Definition: mmutils.h:164
@ MM_AKM_SUITE_NONE
Open (no security)
Definition: mmutils.h:160
@ MM_AKM_SUITE_OWE
OWE.
Definition: mmutils.h:166
@ MM_AKM_SUITE_OTHER
Another suite not in this enum.
Definition: mmutils.h:168
@ MM_AKM_SUITE_PSK
Pre-shared key (WFA OUI)
Definition: mmutils.h:162
@ MM_CIPHER_SUITE_OTHER
Another cipher suite not in this enum.
Definition: mmutils.h:177
@ MM_CIPHER_SUITE_AES_CCM
Open (no security)
Definition: mmutils.h:175
static char mm_nibble_to_hex_char(uint8_t nibble)
Convert the least significant 4 bits of the given argument to a character representing their hexadeci...
Definition: mmutils.h:135
Data structure to represent information extracted from an RSN information element.
Definition: mmutils.h:214
uint16_t num_akm_suites
Number of AKM suites in akm_suites.
Definition: mmutils.h:224
uint32_t group_cipher_suite
The group cipher suite OUI.
Definition: mmutils.h:216
uint16_t version
Version number of the RSN IE.
Definition: mmutils.h:226
uint32_t pairwise_cipher_suites[MM_RSN_INFORMATION_MAX_PAIRWISE_CIPHER_SUITES]
Pairwise cipher suite OUIs.
Definition: mmutils.h:218
uint16_t rsn_capabilities
RSN Capabilities field of the RSN IE (in host order).
Definition: mmutils.h:228
uint16_t num_pairwise_cipher_suites
Number of pairwise cipher suites in pairwise_cipher_suites.
Definition: mmutils.h:222
uint32_t akm_suites[MM_RSN_INFORMATION_MAX_AKM_SUITES]
AKM suite OUIs.
Definition: mmutils.h:220
Data structure to represent information extracted from an S1G Operation information element.
Definition: mmutils.h:340
uint8_t operating_channel_width_mhz
Width of the operating channel in MHz.
Definition: mmutils.h:344
uint8_t operating_channel_number
Channel number of the operating channel.
Definition: mmutils.h:348
uint8_t primary_channel_width_mhz
Width of the primary channel in MHz.
Definition: mmutils.h:346
uint8_t primary_channel_number
Channel number of the primary channel.
Definition: mmutils.h:350
uint8_t operating_class
Operating class.
Definition: mmutils.h:342