mac address: add the number of MAC address generated from efuse for user to choose

1. Add the number of MAC address generated from efuse for user to choose.

2. Add MAC address derive method.
This commit is contained in:
XiaXiaotian 2017-03-02 14:57:45 +08:00
parent 6d061ec903
commit d3eede2110
6 changed files with 115 additions and 58 deletions

View File

@ -3,15 +3,6 @@ menuconfig BT_ENABLED
help help
Select this option to enable Bluetooth stack and show the submenu with Bluetooth configuration choices. Select this option to enable Bluetooth stack and show the submenu with Bluetooth configuration choices.
config ESP_MAC_OFFSET_BT
int "MAC address offset value of WiFi station"
depends on BT_ENABLED
range 0 255
default 2
help
The offset value of bluetooth MAC address from the MAC address which is read from efuse.
This offset value must be different from that of WiFi softap, WiFi station and ethernet.
config BTC_TASK_STACK_SIZE config BTC_TASK_STACK_SIZE
int "Bluetooth event (callback to application) task stack size" int "Bluetooth event (callback to application) task stack size"
depends on BT_ENABLED depends on BT_ENABLED

View File

@ -45,7 +45,6 @@ extern void btdm_controller_deinit(void);
extern int btdm_controller_enable(esp_bt_mode_t mode); extern int btdm_controller_enable(esp_bt_mode_t mode);
extern int btdm_controller_disable(esp_bt_mode_t mode); extern int btdm_controller_disable(esp_bt_mode_t mode);
extern void btdm_rf_bb_init(void); extern void btdm_rf_bb_init(void);
extern int esp_read_mac(uint8_t *mac, int type);
/* VHCI function interface */ /* VHCI function interface */
typedef struct vhci_host_callback { typedef struct vhci_host_callback {

View File

@ -105,6 +105,28 @@ config MEMMAP_SPISRAM
main memory map. Enable this if you have this hardware and want to use it in the same main memory map. Enable this if you have this hardware and want to use it in the same
way as on-chip RAM. way as on-chip RAM.
choice NUMBER_OF_MAC_ADDRESS_GENERATED_FROM_EFUSE
bool "Number of MAC address generated from the hardware MAC address in efuse"
default FOUR_MAC_ADDRESS_FROM_EFUSE
help
Config the number of MAC address which is generated from the hardware MAC address in efuse.
If the number is two, the MAC addresses of WiFi station and bluetooth are generated from
the hardware MAC address in efuse. The MAC addresses of WiFi softap and ethernet are derived
from that of WiFi station and bluetooth respectively.
If the number is four, the MAC addresses of WiFi station, WiFi softap, bluetooth and ethernet
are all generated from the hardware MAC address in efuse.
config TWO_MAC_ADDRESS_FROM_EFUSE
bool "Two"
config FOUR_MAC_ADDRESS_FROM_EFUSE
bool "Four"
endchoice
config NUMBER_OF_MAC_ADDRESS_GENERATED_FROM_EFUSE
int
default 2 if TWO_MAC_ADDRESS_FROM_EFUSE
default 4 if FOUR_MAC_ADDRESS_FROM_EFUSE
config SYSTEM_EVENT_QUEUE_SIZE config SYSTEM_EVENT_QUEUE_SIZE
int "System event queue size" int "System event queue size"
default 32 default 32
@ -481,24 +503,6 @@ menuconfig WIFI_ENABLED
help help
Select this option to enable WiFi stack and show the submenu with WiFi configuration choices. Select this option to enable WiFi stack and show the submenu with WiFi configuration choices.
config ESP_MAC_OFFSET_WIFI_STA
int "MAC address offset value of WiFi station"
depends on WIFI_ENABLED
range 0 255
default 0
help
The offset value of WiFi station MAC address from the MAC address which is read from efuse.
This offset value must be different from that of WiFi softap, bluetooth and ethernet.
config ESP_MAC_OFFSET_WIFI_SOFTAP
int "MAC address offset value of WiFi softap"
depends on WIFI_ENABLED
range 0 255
default 1
help
The offset value of WiFi softap MAC address from the MAC address which is read from efuse.
This offset value must be different from that of WiFi station, bluetooth and ethernet.
config SW_COEXIST_ENABLE config SW_COEXIST_ENABLE
bool "Software controls WiFi/Bluetooth coexistence" bool "Software controls WiFi/Bluetooth coexistence"
depends on WIFI_ENABLED && BT_ENABLED depends on WIFI_ENABLED && BT_ENABLED

View File

@ -24,12 +24,16 @@
extern "C" { extern "C" {
#endif #endif
enum { typedef enum {
ESP_MAC_WIFI_STA, ESP_MAC_WIFI_STA,
ESP_MAC_WIFI_SOFTAP, ESP_MAC_WIFI_SOFTAP,
ESP_MAC_BT, ESP_MAC_BT,
ESP_MAC_ETH, ESP_MAC_ETH,
}; } esp_mac_type_t;
#define TWO_MAC_ADDRESS_FROM_EFUSE 2
#define FOUR_MAC_ADDRESS_FROM_EFUSE 4
#define NUM_MAC_ADDRESS_FROM_EFUSE CONFIG_NUMBER_OF_MAC_ADDRESS_GENERATED_FROM_EFUSE
/** /**
* @attention application don't need to call this function anymore. It do nothing and will * @attention application don't need to call this function anymore. It do nothing and will
@ -126,14 +130,42 @@ esp_err_t system_efuse_read_mac(uint8_t mac[6]) __attribute__ ((deprecated));
* @brief Read hardware MAC address and set MAC address of the interface. * @brief Read hardware MAC address and set MAC address of the interface.
* *
* This function first reads hardware MAC address from efuse. Then set the MAC address of the interface * This function first reads hardware MAC address from efuse. Then set the MAC address of the interface
* including wifi station, wifi softap, bluetooth and ethernet according to the offset value in menuconfig. * including wifi station, wifi softap, bluetooth and ethernet.
* *
* @param mac MAC address of the interface, length: 6 bytes. * @param mac MAC address of the interface, length: 6 bytes.
* @param interface interface, 0:wifi station, 1:wifi softap, 2:bluetooth, 3:ethernet. * @param type type of MAC address, 0:wifi station, 1:wifi softap, 2:bluetooth, 3:ethernet.
* *
* @return ESP_OK on success * @return ESP_OK on success
*/ */
esp_err_t esp_read_mac(uint8_t* mac, int interface); esp_err_t esp_read_mac(uint8_t* mac, esp_mac_type_t type);
/**
* @brief Derive MAC address.
*
* This function derives a local MAC address from an universal MAC address.
* Addresses can either be universally administered addresses or locally administered addresses.
* A universally administered address is uniquely assigned to a device by its manufacturer.
* The first three octets (in transmission order) identify the organization that issued the identifier
* and are known as the Organizationally Unique Identifier (OUI).[4] The remainder of the address
* (three octets for MAC-48 and EUI-48 or five for EUI-64) are assigned by that organization in nearly
* any manner they please, subject to the constraint of uniqueness. A locally administered address is
* assigned to a device by a network administrator, overriding the burned-in address.
* Universally administered and locally administered addresses are distinguished by setting
* the second-least-significant bit of the first octet of the address. This bit is also referred to
* as the U/L bit, short for Universal/Local, which identifies how the address is administered.
* If the bit is 0, the address is universally administered. If it is 1, the address is locally administered.
* In the example address 06-00-00-00-00-00 the first octet is 06 (hex), the binary form of which is 00000110,
* where the second-least-significant bit is 1. Therefore, it is a locally administered address.[7] Consequently,
* this bit is 0 in all OUIs.
* In ESP32, universal MAC address is generated from the hardware MAC address in efuse.
* Local MAC address is derived from the universal MAC address.
*
* @param dst_mac Derived local MAC address, length: 6 bytes.
* @param src_mac Source universal MAC address, length: 6 bytes.
*
* @return ESP_OK on success
*/
esp_err_t esp_derive_mac(uint8_t* dst_mac, const uint8_t* src_mac);
/** /**
* Get SDK version * Get SDK version

View File

@ -74,42 +74,82 @@ esp_err_t esp_efuse_read_mac(uint8_t* mac)
esp_err_t system_efuse_read_mac(uint8_t mac[6]) __attribute__((alias("esp_efuse_read_mac"))); esp_err_t system_efuse_read_mac(uint8_t mac[6]) __attribute__((alias("esp_efuse_read_mac")));
esp_err_t esp_read_mac(uint8_t* mac, int interface) esp_err_t esp_derive_mac(uint8_t* dst_mac, const uint8_t* src_mac)
{
uint8_t idx;
if (dst_mac == NULL || src_mac == NULL) {
ESP_LOGE(TAG, "mac address param is NULL");
return ESP_ERR_INVALID_ARG;
}
memcpy(dst_mac, src_mac, 6);
for (idx = 0; idx < 64; idx++) {
dst_mac[0] = src_mac[0] | 0x02;
dst_mac[0] ^= idx << 2;
if (memcmp(dst_mac, src_mac, 6)) {
break;
}
}
return ESP_OK;
}
esp_err_t esp_read_mac(uint8_t* mac, esp_mac_type_t type)
{ {
uint8_t efuse_mac[6]; uint8_t efuse_mac[6];
if (mac == NULL) { if (mac == NULL) {
ESP_LOGE(TAG, "mac address param is NULL"); ESP_LOGE(TAG, "mac address param is NULL");
abort(); return ESP_ERR_INVALID_ARG;
} }
if (type < ESP_MAC_WIFI_STA || type > ESP_MAC_ETH) {
ESP_LOGE(TAG, "mac type is incorrect");
return ESP_ERR_INVALID_ARG;
}
_Static_assert(NUM_MAC_ADDRESS_FROM_EFUSE == FOUR_MAC_ADDRESS_FROM_EFUSE \
|| NUM_MAC_ADDRESS_FROM_EFUSE == TWO_MAC_ADDRESS_FROM_EFUSE, \
"incorrect NUM_MAC_ADDRESS_FROM_EFUSE value");
esp_efuse_read_mac(efuse_mac); esp_efuse_read_mac(efuse_mac);
switch (interface) { switch (type) {
#if CONFIG_WIFI_ENABLED
case ESP_MAC_WIFI_STA: case ESP_MAC_WIFI_STA:
memcpy(mac, efuse_mac, 6); memcpy(mac, efuse_mac, 6);
mac[5] += CONFIG_ESP_MAC_OFFSET_WIFI_STA;
break; break;
case ESP_MAC_WIFI_SOFTAP: case ESP_MAC_WIFI_SOFTAP:
memcpy(mac, efuse_mac, 6); if (NUM_MAC_ADDRESS_FROM_EFUSE == FOUR_MAC_ADDRESS_FROM_EFUSE) {
mac[5] += CONFIG_ESP_MAC_OFFSET_WIFI_SOFTAP; memcpy(mac, efuse_mac, 6);
mac[5] += 1;
}
else if (NUM_MAC_ADDRESS_FROM_EFUSE == TWO_MAC_ADDRESS_FROM_EFUSE) {
esp_derive_mac(mac, efuse_mac);
}
break; break;
#endif
#if CONFIG_BT_ENABLED
case ESP_MAC_BT: case ESP_MAC_BT:
memcpy(mac, efuse_mac, 6); memcpy(mac, efuse_mac, 6);
mac[5] += CONFIG_ESP_MAC_OFFSET_BT; if (NUM_MAC_ADDRESS_FROM_EFUSE == FOUR_MAC_ADDRESS_FROM_EFUSE) {
mac[5] += 2;
}
else if (NUM_MAC_ADDRESS_FROM_EFUSE == TWO_MAC_ADDRESS_FROM_EFUSE) {
mac[5] += 1;
}
break; break;
#endif
#if CONFIG_ETHERNET
case ESP_MAC_ETH: case ESP_MAC_ETH:
memcpy(mac, efuse_mac, 6); if (NUM_MAC_ADDRESS_FROM_EFUSE == FOUR_MAC_ADDRESS_FROM_EFUSE) {
mac[5] += CONFIG_ESP_MAC_OFFSET_ETH; memcpy(mac, efuse_mac, 6);
mac[5] += 3;
}
else if (NUM_MAC_ADDRESS_FROM_EFUSE == TWO_MAC_ADDRESS_FROM_EFUSE) {
efuse_mac[5] += 1;
esp_derive_mac(mac, efuse_mac);
}
break; break;
#endif
default: default:
ESP_LOGW(TAG, "wrong mac type"); ESP_LOGW(TAG, "incorrect mac type");
break; break;
} }

View File

@ -4,15 +4,6 @@ menuconfig ETHERNET
help help
Select this option to enable ethernet driver and show the submenu with ethernet features. Select this option to enable ethernet driver and show the submenu with ethernet features.
config ESP_MAC_OFFSET_ETH
int "MAC address offset value of ethernet"
depends on ETHERNET
range 0 255
default 3
help
The offset value of ethernet MAC address from the MAC address which is read from efuse.
This offset value must be different from that of WiFi softap, bluetooth and WiFi station.
config DMA_RX_BUF_NUM config DMA_RX_BUF_NUM
int "Number of DMA RX buffers" int "Number of DMA RX buffers"
range 3 20 range 3 20