Select one of the symbols to view example projects that use it.
 
Outline
#include "esp_err.h"
#include "sdkconfig.h"
#define MAC2STR
#define MACSTR
esp_mac_type_t
#define ONE_UNIVERSAL_MAC_ADDR
#define TWO_UNIVERSAL_MAC_ADDR
#define FOUR_UNIVERSAL_MAC_ADDR
#define UNIVERSAL_MAC_ADDR_NUM
esp_base_mac_addr_set(const uint8_t *);
esp_base_mac_addr_get(uint8_t *);
esp_efuse_mac_get_custom(uint8_t *);
esp_efuse_mac_get_default(uint8_t *);
esp_read_mac(uint8_t *, esp_mac_type_t);
esp_derive_local_mac(uint8_t *, const uint8_t *);
esp_iface_mac_addr_set(const uint8_t *, esp_mac_type_t);
esp_mac_addr_len_get(esp_mac_type_t);
Files
loading...
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/esp_hw_support/include/esp_mac.h
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* * SPDX-FileCopyrightText: 2021-2022 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 *//* ... */ #pragma once #include "esp_err.h" #include "sdkconfig.h" #ifndef MAC2STR #define MAC2STR(a) (a)[0], (a)[1], (a)[2], (a)[3], (a)[4], (a)[5] #define MACSTR "%02x:%02x:%02x:%02x:%02x:%02x"/* ... */ #endif #ifdef __cplusplus extern "C" { #endif typedef enum { ESP_MAC_WIFI_STA, /**< MAC for WiFi Station (6 bytes) */ ESP_MAC_WIFI_SOFTAP, /**< MAC for WiFi Soft-AP (6 bytes) */ ESP_MAC_BT, /**< MAC for Bluetooth (6 bytes) */ ESP_MAC_ETH, /**< MAC for Ethernet (6 bytes) */ ESP_MAC_IEEE802154, /**< if CONFIG_SOC_IEEE802154_SUPPORTED=y, MAC for IEEE802154 (8 bytes) */ ESP_MAC_BASE, /**< Base MAC for that used for other MAC types (6 bytes) */ ESP_MAC_EFUSE_FACTORY, /**< MAC_FACTORY eFuse which was burned by Espressif in production (6 bytes) */ ESP_MAC_EFUSE_CUSTOM, /**< MAC_CUSTOM eFuse which was can be burned by customer (6 bytes) */ ESP_MAC_EFUSE_EXT, /**< if CONFIG_SOC_IEEE802154_SUPPORTED=y, MAC_EXT eFuse which is used as an extender for IEEE802154 MAC (2 bytes) */ }{ ... } esp_mac_type_t; /** @cond */ #define ONE_UNIVERSAL_MAC_ADDR 1 #define TWO_UNIVERSAL_MAC_ADDR 2 #define FOUR_UNIVERSAL_MAC_ADDR 4 #define UNIVERSAL_MAC_ADDR_NUM CONFIG_ESP_MAC_UNIVERSAL_MAC_ADDRESSES /** @endcond */ /** * @brief Set base MAC address with the MAC address which is stored in BLK3 of EFUSE or * external storage e.g. flash and EEPROM. * * Base MAC address is used to generate the MAC addresses used by network interfaces. * * If using a custom base MAC address, call this API before initializing any network interfaces. * Refer to the ESP-IDF Programming Guide for details about how the Base MAC is used. * * @note Base MAC must be a unicast MAC (least significant bit of first byte must be zero). * * @note If not using a valid OUI, set the "locally administered" bit * (bit value 0x02 in the first byte) to avoid collisions. * * @param mac base MAC address, length: 6 bytes. * length: 6 bytes for MAC-48 * * @return ESP_OK on success * ESP_ERR_INVALID_ARG If mac is NULL or is not a unicast MAC *//* ... */ esp_err_t esp_base_mac_addr_set(const uint8_t *mac); /** * @brief Return base MAC address which is set using esp_base_mac_addr_set. * * @note If no custom Base MAC has been set, this returns the pre-programmed Espressif base MAC address. * * @param mac base MAC address, length: 6 bytes. * length: 6 bytes for MAC-48 * * @return ESP_OK on success * ESP_ERR_INVALID_ARG mac is NULL * ESP_ERR_INVALID_MAC base MAC address has not been set *//* ... */ esp_err_t esp_base_mac_addr_get(uint8_t *mac); /** * @brief Return base MAC address which was previously written to BLK3 of EFUSE. * * Base MAC address is used to generate the MAC addresses used by the networking interfaces. * This API returns the custom base MAC address which was previously written to EFUSE BLK3 in * a specified format. * * Writing this EFUSE allows setting of a different (non-Espressif) base MAC address. It is also * possible to store a custom base MAC address elsewhere, see esp_base_mac_addr_set() for details. * * @note This function is currently only supported on ESP32. * * @param mac base MAC address, length: 6 bytes/8 bytes. * length: 6 bytes for MAC-48 * 8 bytes for EUI-64(used for IEEE 802.15.4, if CONFIG_SOC_IEEE802154_SUPPORTED=y) * * @return ESP_OK on success * ESP_ERR_INVALID_ARG mac is NULL * ESP_ERR_INVALID_MAC CUSTOM_MAC address has not been set, all zeros (for esp32-xx) * ESP_ERR_INVALID_VERSION An invalid MAC version field was read from BLK3 of EFUSE (for esp32) * ESP_ERR_INVALID_CRC An invalid MAC CRC was read from BLK3 of EFUSE (for esp32) *//* ... */ esp_err_t esp_efuse_mac_get_custom(uint8_t *mac); /** * @brief Return base MAC address which is factory-programmed by Espressif in EFUSE. * * @param mac base MAC address, length: 6 bytes/8 bytes. * length: 6 bytes for MAC-48 * 8 bytes for EUI-64(used for IEEE 802.15.4, if CONFIG_SOC_IEEE802154_SUPPORTED=y) * * @return ESP_OK on success * ESP_ERR_INVALID_ARG mac is NULL *//* ... */ esp_err_t esp_efuse_mac_get_default(uint8_t *mac); /** * @brief Read base MAC address and set MAC address of the interface. * * This function first get base MAC address using esp_base_mac_addr_get(). * Then calculates the MAC address of the specific interface requested, * refer to ESP-IDF Programming Guide for the algorithm. * * The MAC address set by the esp_iface_mac_addr_set() function will not depend on the base MAC address. * * @param mac base MAC address, length: 6 bytes/8 bytes. * length: 6 bytes for MAC-48 * 8 bytes for EUI-64(used for IEEE 802.15.4, if CONFIG_SOC_IEEE802154_SUPPORTED=y) * @param type Type of MAC address to return * * @return ESP_OK on success *//* ... */ esp_err_t esp_read_mac(uint8_t *mac, esp_mac_type_t type); /** * @brief Derive local MAC address from universal MAC address. * * This function copies a universal MAC address and then sets the "locally * administered" bit (bit 0x2) in the first octet, creating a locally * administered MAC address. * * If the universal MAC address argument is already a locally administered MAC * address, then the first octet is XORed with 0x4 in order to create a different * locally administered MAC address. * * @param local_mac base MAC address, length: 6 bytes. * length: 6 bytes for MAC-48 * @param universal_mac Source universal MAC address, length: 6 bytes. * * @return ESP_OK on success *//* ... */ esp_err_t esp_derive_local_mac(uint8_t *local_mac, const uint8_t *universal_mac); /** * @brief Set custom MAC address of the interface. This function allows you to overwrite the MAC addresses * of the interfaces set by the base MAC address. * * @param mac MAC address, length: 6 bytes/8 bytes. * length: 6 bytes for MAC-48 * 8 bytes for EUI-64(used for ESP_MAC_IEEE802154 type, if CONFIG_SOC_IEEE802154_SUPPORTED=y) * @param type Type of MAC address * * @return ESP_OK on success *//* ... */ esp_err_t esp_iface_mac_addr_set(const uint8_t *mac, esp_mac_type_t type); /** * @brief Return the size of the MAC type in bytes. * * If CONFIG_SOC_IEEE802154_SUPPORTED is set then for these types: * - ESP_MAC_IEEE802154 is 8 bytes. * - ESP_MAC_BASE, ESP_MAC_EFUSE_FACTORY and ESP_MAC_EFUSE_CUSTOM the MAC size is 6 bytes. * - ESP_MAC_EFUSE_EXT is 2 bytes. * If CONFIG_SOC_IEEE802154_SUPPORTED is not set then for all types it returns 6 bytes. * * @param type Type of MAC address * * @return 0 MAC type not found (not supported) * 6 bytes for MAC-48. * 8 bytes for EUI-64. *//* ... */ size_t esp_mac_addr_len_get(esp_mac_type_t type); #ifdef __cplusplus }{...} #endif
Details