mirror of
				https://github.com/espressif/ESP8266_RTOS_SDK.git
				synced 2025-10-23 01:47:33 +08:00 
			
		
		
		
	 5f2b5eafcf
			
		
	
	5f2b5eafcf
	
	
	
		
			
			It is that maybe less modification working on the components is better, so I just modified the platform code of AES, SHA and so on. ESP8266 has no real hardware AES, SHA or bignum peripheral, but some method can speed up the process of part of upper algorithm, so I also added the platform code of AES, SHA, bignum, ARC, MD5. ESP8266 has no platform of bignum, so users should not enable the bignum hardware at "menuconfig".
		
			
				
	
	
		
			259 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			259 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // Copyright 2018-2019 Espressif Systems (Shanghai) PTE LTD
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| 
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| #ifndef __ESP_SYSTEM_H__
 | |
| #define __ESP_SYSTEM_H__
 | |
| 
 | |
| #include <stdint.h>
 | |
| #include <stdbool.h>
 | |
| #include "esp_err.h"
 | |
| 
 | |
| #include "sdkconfig.h"
 | |
| 
 | |
| #include "esp_idf_version.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| #if CONFIG_CRYSTAL_USED_26MHZ
 | |
| #define CRYSTAL_USED 26
 | |
| #endif
 | |
| 
 | |
| #if CONFIG_CRYSTAL_USED_40MHZ
 | |
| #define CRYSTAL_USED 40
 | |
| #endif
 | |
| 
 | |
| typedef enum {
 | |
|     ESP_MAC_WIFI_STA,
 | |
|     ESP_MAC_WIFI_SOFTAP,
 | |
| } esp_mac_type_t;
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @brief Reset reasons
 | |
|  */
 | |
| typedef enum {
 | |
|     ESP_RST_UNKNOWN = 0,    //!< Reset reason can not be determined
 | |
|     ESP_RST_POWERON,        //!< Reset due to power-on event
 | |
|     ESP_RST_EXT,            //!< Reset by external pin (not applicable for ESP8266)
 | |
|     ESP_RST_SW,             //!< Software reset via esp_restart
 | |
|     ESP_RST_PANIC,          //!< Software reset due to exception/panic
 | |
|     ESP_RST_INT_WDT,        //!< Reset (software or hardware) due to interrupt watchdog
 | |
|     ESP_RST_TASK_WDT,       //!< Reset due to task watchdog
 | |
|     ESP_RST_WDT,            //!< Reset due to other watchdogs
 | |
|     ESP_RST_DEEPSLEEP,      //!< Reset after exiting deep sleep mode
 | |
|     ESP_RST_BROWNOUT,       //!< Brownout reset (software or hardware)
 | |
|     ESP_RST_SDIO,           //!< Reset over SDIO
 | |
| } esp_reset_reason_t;
 | |
| 
 | |
| /**
 | |
|   * @brief  Set base MAC address with the MAC address which is stored in EFUSE or
 | |
|   *         external storage e.g. flash and EEPROM.
 | |
|   *
 | |
|   * Base MAC address is used to generate the MAC addresses used by the networking interfaces.
 | |
|   * If using base MAC address stored in EFUSE or external storage, call this API to set base MAC
 | |
|   * address with the MAC address which is stored in EFUSE or external storage before initializing
 | |
|   * WiFi.
 | |
|   *
 | |
|   * @param  mac  base MAC address, length: 6 bytes.
 | |
|   *
 | |
|   * @return ESP_OK on success
 | |
|   */
 | |
| esp_err_t esp_base_mac_addr_set(uint8_t *mac);
 | |
| 
 | |
| /**
 | |
|   * @brief  Return base MAC address which is set using esp_base_mac_addr_set.
 | |
|   *
 | |
|   * @param  mac  base MAC address, length: 6 bytes.
 | |
|   *
 | |
|   * @return ESP_OK on success
 | |
|   *         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 is factory-programmed by Espressif in EFUSE.
 | |
|   *
 | |
|   * @param  mac  base MAC address, length: 6 bytes.
 | |
|   *
 | |
|   * @return ESP_OK on success
 | |
|   */
 | |
| 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 or reads base MAC address
 | |
|   * from EFUSE. Then set the MAC address of the interface including wifi station and wifi softap.
 | |
|   *
 | |
|   * @param  mac  MAC address of the interface, length: 6 bytes.
 | |
|   * @param  type  type of MAC address, 0:wifi station, 1:wifi softap.
 | |
|   *
 | |
|   * @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 derives a local MAC address from an universal MAC address.
 | |
|   * A `definition of local vs universal MAC address can be found on Wikipedia
 | |
|   * <https://en.wikipedia.org/wiki/MAC_address#Universal_vs._local>`.
 | |
|   * In ESP8266, universal MAC address is generated from base MAC address in EFUSE or other external storage.
 | |
|   * Local MAC address is derived from the universal MAC address.
 | |
|   *
 | |
|   * @param  local_mac  Derived local MAC address, length: 6 bytes.
 | |
|   * @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 CPU frequency values
 | |
|  */
 | |
| typedef enum {
 | |
|     ESP_CPU_FREQ_80M = 1,       //!< 80 MHz
 | |
|     ESP_CPU_FREQ_160M = 2,      //!< 160 MHz
 | |
| } esp_cpu_freq_t;
 | |
| 
 | |
| /**
 | |
|  * @brief Switch CPU frequency
 | |
|  *
 | |
|  * If a PLL-derived frequency is requested (80, 160), this function
 | |
|  * will enable the PLL. Otherwise, PLL will be disabled.
 | |
|  * Note: this function is not optimized for switching speed. It may take several
 | |
|  * hundred microseconds to perform frequency switch.
 | |
|  *
 | |
|  * @param cpu_freq  new CPU frequency
 | |
|  */
 | |
| void esp_set_cpu_freq(esp_cpu_freq_t cpu_freq);
 | |
| 
 | |
| /**
 | |
|   * @brief  Reset to default settings.
 | |
|   */
 | |
| void system_restore(void)  __attribute__ ((noreturn));
 | |
| 
 | |
| /**
 | |
|   * @brief  Restart CPU.
 | |
|   *
 | |
|   * This function does not return.
 | |
|   */
 | |
| void esp_restart(void) __attribute__ ((noreturn));
 | |
| 
 | |
| /**
 | |
|  * @brief  Get reason of last reset
 | |
|  * @return See description of esp_reset_reason_t for explanation of each value.
 | |
|  */
 | |
| esp_reset_reason_t esp_reset_reason(void);
 | |
| 
 | |
| /**
 | |
|   * @brief  Get the size of available heap.
 | |
|   *
 | |
|   * Note that the returned value may be larger than the maximum contiguous block
 | |
|   * which can be allocated.
 | |
|   *
 | |
|   * @return Available heap size, in bytes.
 | |
|   */
 | |
| uint32_t esp_get_free_heap_size(void);
 | |
| 
 | |
| /**
 | |
|   * @brief Get the minimum heap that has ever been available
 | |
|   *
 | |
|   * @return Minimum free heap ever available
 | |
|   */
 | |
| uint32_t esp_get_minimum_free_heap_size( void );
 | |
| 
 | |
| /**
 | |
|  * @brief  Get one random 32-bit word from hardware RNG
 | |
|  *
 | |
|  * @return Random value between 0 and UINT32_MAX
 | |
|  */
 | |
| uint32_t esp_random(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Fill a buffer with random bytes from hardware RNG
 | |
|  *
 | |
|  * @note This function has the same restrictions regarding available entropy as esp_random()
 | |
|  *
 | |
|  * @param buf Pointer to buffer to fill with random numbers.
 | |
|  * @param len Length of buffer in bytes
 | |
|  */
 | |
| void esp_fill_random(void *buf, size_t len);
 | |
| 
 | |
| typedef enum {
 | |
|     FLASH_SIZE_4M_MAP_256_256 = 0,  /**<  Flash size : 4Mbits. Map : 256KBytes + 256KBytes */
 | |
|     FLASH_SIZE_2M,                  /**<  Flash size : 2Mbits. Map : 256KBytes */
 | |
|     FLASH_SIZE_8M_MAP_512_512,      /**<  Flash size : 8Mbits. Map : 512KBytes + 512KBytes */
 | |
|     FLASH_SIZE_16M_MAP_512_512,     /**<  Flash size : 16Mbits. Map : 512KBytes + 512KBytes */
 | |
|     FLASH_SIZE_32M_MAP_512_512,     /**<  Flash size : 32Mbits. Map : 512KBytes + 512KBytes */
 | |
|     FLASH_SIZE_16M_MAP_1024_1024,   /**<  Flash size : 16Mbits. Map : 1024KBytes + 1024KBytes */
 | |
|     FLASH_SIZE_32M_MAP_1024_1024,    /**<  Flash size : 32Mbits. Map : 1024KBytes + 1024KBytes */
 | |
|     FLASH_SIZE_32M_MAP_2048_2048,    /**<  attention: don't support now ,just compatible for nodemcu;
 | |
|                                            Flash size : 32Mbits. Map : 2048KBytes + 2048KBytes */
 | |
|     FLASH_SIZE_64M_MAP_1024_1024,     /**<  Flash size : 64Mbits. Map : 1024KBytes + 1024KBytes */
 | |
|     FLASH_SIZE_128M_MAP_1024_1024,    /**<  Flash size : 128Mbits. Map : 1024KBytes + 1024KBytes */
 | |
| 
 | |
|     FALSH_SIZE_MAP_MAX
 | |
| } flash_size_map;
 | |
| 
 | |
| /**
 | |
|  * @brief Chip models
 | |
|  */
 | |
| typedef enum {
 | |
|     CHIP_ESP8266 = 0, //!< ESP8266
 | |
|     CHIP_ESP32 = 1, //!< ESP32
 | |
| } esp_chip_model_t;
 | |
| 
 | |
| /**
 | |
|  * Chip feature flags, used in esp_chip_info_t
 | |
|  */
 | |
| #define CHIP_FEATURE_EMB_FLASH      BIT(0)      //!< Chip has embedded flash memory
 | |
| #define CHIP_FEATURE_WIFI_BGN       BIT(1)      //!< Chip has 2.4GHz WiFi
 | |
| #define CHIP_FEATURE_BLE            BIT(4)      //!< Chip has Bluetooth LE
 | |
| #define CHIP_FEATURE_BT             BIT(5)      //!< Chip has Bluetooth Classic
 | |
| 
 | |
| /**
 | |
|  * @brief The structure represents information about the chip
 | |
|  */
 | |
| typedef struct {
 | |
|     esp_chip_model_t model;  //!< chip model, one of esp_chip_model_t
 | |
|     uint32_t features;       //!< bit mask of CHIP_FEATURE_x feature flags
 | |
|     uint8_t cores;           //!< number of CPU cores
 | |
|     uint8_t revision;        //!< chip revision number
 | |
| } esp_chip_info_t;
 | |
| 
 | |
| /**
 | |
|  * @brief Fill an esp_chip_info_t structure with information about the chip
 | |
|  * @param[out] out_info structure to be filled
 | |
|  */
 | |
| void esp_chip_info(esp_chip_info_t* out_info);
 | |
| 
 | |
| /**
 | |
|   * @brief  Get the current Flash size and Flash map.
 | |
|   *
 | |
|   *         Flash map depends on the selection when compiling, more details in document
 | |
|   *         "2A-ESP8266__IOT_SDK_User_Manual"
 | |
|   *
 | |
|   * @return enum flash_size_map
 | |
|   */
 | |
| flash_size_map system_get_flash_size_map(void);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* __ESP_SYSTEM_H__ */
 |