mirror of
				https://github.com/espressif/ESP8266_RTOS_SDK.git
				synced 2025-10-20 22:31:30 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			352 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			352 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * ESPRSSIF MIT License
 | |
|  *
 | |
|  * Copyright (c) 2015 <ESPRESSIF SYSTEMS (SHANGHAI) PTE LTD>
 | |
|  *
 | |
|  * Permission is hereby granted for use on ESPRESSIF SYSTEMS ESP8266 only, in which case,
 | |
|  * it is free of charge, to any person obtaining a copy of this software and associated
 | |
|  * documentation files (the "Software"), to deal in the Software without restriction, including
 | |
|  * without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense,
 | |
|  * and/or sell copies of the Software, and to permit persons to whom the Software is furnished
 | |
|  * to do so, subject to the following conditions:
 | |
|  *
 | |
|  * The above copyright notice and this permission notice shall be included in all copies or
 | |
|  * substantial portions of the Software.
 | |
|  *
 | |
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | |
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
 | |
|  * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
 | |
|  * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
 | |
|  * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 | |
|  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| #ifndef __ESPNOW_H__
 | |
| #define __ESPNOW_H__
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /** \defgroup ESPNow_APIs ESP-NOW APIs
 | |
|   * @brief ESP-NOW APIs
 | |
|   *
 | |
|   * @attention 1. ESP-NOW do not support broadcast and multicast.
 | |
|   * @attention 2. ESP-NOW is targeted to Smart-Light project, so it is suggested
 | |
|   *               that slave role corresponding to soft-AP or soft-AP+station mode,
 | |
|   *               controller role corresponding to station mode.
 | |
|   * @attention 3. When ESP8266 is in soft-AP+station mode, it will communicate through
 | |
|   *               station interface if it is in slave role, and communicate through
 | |
|   *               soft-AP interface if it is in controller role.
 | |
|   * @attention 4. ESP-NOW can not wake ESP8266 up from sleep, so if the target ESP8266
 | |
|   *               station is in sleep, ESP-NOW communication will fail.
 | |
|   * @attention 5. In station mode, ESP8266 supports 10 encrypt ESP-NOW peers at most,
 | |
|   *               with the unencrypted peers, it can be 20 peers in total at most.
 | |
|   * @attention 6. In the soft-AP mode or soft-AP + station mode, the ESP8266 supports
 | |
|   *               6 encrypt ESP-NOW peers at most, with the unencrypted peers, it can
 | |
|   *               be 20 peers in total at most.
 | |
|   *
 | |
|   */
 | |
| 
 | |
| /** @addtogroup ESPNow_APIs
 | |
|   * @{
 | |
|   */
 | |
| 
 | |
| enum esp_now_role {
 | |
|     ESP_NOW_ROLE_IDLE = 0,
 | |
|     ESP_NOW_ROLE_CONTROLLER,
 | |
|     ESP_NOW_ROLE_SLAVE,
 | |
|     ESP_NOW_ROLE_MAX,
 | |
| };
 | |
| 
 | |
| /**
 | |
|   * @brief     ESP-NOW send callback.
 | |
|   *
 | |
|   * @attention The status will be OK, if ESP-NOW send packet successfully. But users
 | |
|   *            need to make sure by themselves that key of communication is correct.
 | |
|   *
 | |
|   * @param     uint8 *mac_addr : MAC address of target device
 | |
|   * @param     uint8 *data     : data received
 | |
|   * @param     uint8 len       : data length
 | |
|   *
 | |
|   * @return null
 | |
|   */
 | |
| typedef void (*esp_now_recv_cb_t)(uint8 *mac_addr, uint8 *data, uint8 len);
 | |
| 
 | |
| /**
 | |
|   * @brief     ESP-NOW send callback.
 | |
|   *
 | |
|   * @attention The status will be OK, if ESP-NOW send packet successfully. But users
 | |
|   *            need to make sure by themselves that key of communication is correct.
 | |
|   *
 | |
|   * @param     uint8 *mac_addr : MAC address of target device
 | |
|   * @param     uint8 status    : status of ESP-NOW sending packet, 0, OK; 1, fail.
 | |
|   *
 | |
|   * @return    null
 | |
|   */
 | |
| typedef void (*esp_now_send_cb_t)(uint8 *mac_addr, uint8 status);
 | |
| 
 | |
| /**
 | |
|   * @brief  ESP-NOW initialization.
 | |
|   *
 | |
|   * @param  null
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_init(void);
 | |
| 
 | |
| /**
 | |
|   * @brief  Deinitialize ESP-NOW.
 | |
|   *
 | |
|   * @param  null
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_deinit(void);
 | |
| 
 | |
| /**
 | |
|   * @brief  Register ESP-NOW send callback.
 | |
|   *
 | |
|   * @param  esp_now_send_cb_t cb : send callback
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_register_send_cb(esp_now_send_cb_t cb);
 | |
| 
 | |
| /**
 | |
|   * @brief  Unregister ESP-NOW send callback.
 | |
|   *
 | |
|   * @param  null
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_unregister_send_cb(void);
 | |
| 
 | |
| /**
 | |
|   * @brief  Register ESP-NOW receive callback.
 | |
|   *
 | |
|   * @param  esp_now_recv_cb_t cb : receive callback
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_register_recv_cb(esp_now_recv_cb_t cb);
 | |
| 
 | |
| /**
 | |
|   * @brief  Unregister ESP-NOW receive callback.
 | |
|   *
 | |
|   * @param  null
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_unregister_recv_cb(void);
 | |
| 
 | |
| /**
 | |
|   * @brief  Send ESP-NOW packet.
 | |
|   *
 | |
|   * @param  uint8 *da   : destination MAC address.
 | |
|   *                       If it's NULL, send packet to all MAC addresses recorded
 | |
|   *                       by ESP-NOW; otherwise, send packet to target MAC address.
 | |
|   * @param  uint8 *data : data need to send
 | |
|   * @param  uint8 len   : data length
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_send(uint8 *da, uint8 *data, uint8 len);
 | |
| 
 | |
| /**
 | |
|   * @brief  Add an ESP-NOW peer, store MAC address of target device into ESP-NOW MAC list.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of device
 | |
|   * @param  uint8 role      : role type of device, enum esp_now_role
 | |
|   * @param  uint8 channel   : channel of device
 | |
|   * @param  uint8 *key      : 16 bytes key which is needed for ESP-NOW communication
 | |
|   * @param  uint8 key_len   : length of key, has to be 16 bytes now
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_add_peer(uint8 *mac_addr, uint8 role, uint8 channel, uint8 *key, uint8 key_len);
 | |
| 
 | |
| /**
 | |
|   * @brief  Delete an ESP-NOW peer, delete MAC address of the device from ESP-NOW MAC list.
 | |
|   *
 | |
|   * @param  u8 *mac_addr : MAC address of device
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_del_peer(uint8 *mac_addr);
 | |
| 
 | |
| /**
 | |
|   * @brief  Set ESP-NOW role of device itself.
 | |
|   *
 | |
|   * @param  uint8 role : role type of device, enum esp_now_role.
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_set_self_role(uint8 role);
 | |
| 
 | |
| /**
 | |
|   * @brief  Get ESP-NOW role of device itself.
 | |
|   *
 | |
|   * @param  uint8 role : role type of device, enum esp_now_role.
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_get_self_role(void);
 | |
| 
 | |
| /**
 | |
|   * @brief  Set ESP-NOW role for a target device. If it is set multiple times,
 | |
|   *         new role will cover the old one.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of device.
 | |
|   * @param  uint8 role      : role type, enum esp_now_role.
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_set_peer_role(uint8 *mac_addr, uint8 role);
 | |
| 
 | |
| /**
 | |
|   * @brief  Get ESP-NOW role of a target device.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of device.
 | |
|   *
 | |
|   * @return  ESP_NOW_ROLE_CONTROLLER, role type : controller
 | |
|   * @return  ESP_NOW_ROLE_SLAVE, role type : slave
 | |
|   * @return  otherwise : fail
 | |
|   */
 | |
| sint32 esp_now_get_peer_role(uint8 *mac_addr);
 | |
| 
 | |
| /**
 | |
|   * @brief  Record channel information of a ESP-NOW device.
 | |
|   *
 | |
|   * When communicate with this device,
 | |
|   *    -  call esp_now_get_peer_channel to get its channel first,
 | |
|   *    -  then call wifi_set_channel to be in the same channel and do communication.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of target device.
 | |
|   * @param  uint8 channel   : channel, usually to be 1 ~ 13, some area may use channel 14.
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_set_peer_channel(uint8 *mac_addr, uint8 channel);
 | |
| 
 | |
| /**
 | |
|   * @brief  Get channel information of a ESP-NOW device.
 | |
|   *
 | |
|   * @attention ESP-NOW communication needs to be at the same channel.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of target device.
 | |
|   *
 | |
|   * @return 1 ~ 13 (some area may get 14) : channel number
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_get_peer_channel(uint8 *mac_addr);
 | |
| 
 | |
| /**
 | |
|   * @brief  Set ESP-NOW key for a target device.
 | |
|   *
 | |
|   * If it is set multiple times, new key will cover the old one.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of target device.
 | |
|   * @param  uint8 *key      : 16 bytes key which is needed for ESP-NOW communication,
 | |
|   *                           if it is NULL, current key will be reset to be none.
 | |
|   * @param  uint8 key_len   : key length, has to be 16 bytes now
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_set_peer_key(uint8 *mac_addr, uint8 *key, uint8 key_len);
 | |
| 
 | |
| /**
 | |
|   * @brief  Get ESP-NOW key of a target device.
 | |
|   *
 | |
|   * If it is set multiple times, new key will cover the old one.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of target device.
 | |
|   * @param  uint8 *key      : pointer of key, buffer size has to be 16 bytes at least
 | |
|   * @param  uint8 key_len   : key length
 | |
|   *
 | |
|   * @return 0   : succeed
 | |
|   * @return > 0 : find target device but can't get key
 | |
|   * @return < 0 : fail
 | |
|   */
 | |
| sint32 esp_now_get_peer_key(uint8 *mac_addr, uint8 *key, uint8 *key_len);
 | |
| 
 | |
| /**
 | |
|   * @brief      Get MAC address of ESP-NOW device.
 | |
|   *
 | |
|   *            Get MAC address of ESP-NOW device which is pointed now, and move
 | |
|   *            the pointer to next one in ESP-NOW MAC list or move the pointer to
 | |
|   *            the first one in ESP-NOW MAC list.
 | |
|   *
 | |
|   * @attention 1. This API can not re-entry
 | |
|   * @attention 2. Parameter has to be true when you call it the first time.
 | |
|   *
 | |
|   * @param  bool restart : true, move pointer to the first one in ESP-NOW MAC list;
 | |
|   *                        false, move pointer to the next one in ESP-NOW MAC list
 | |
|   *
 | |
|   * @return NULL, no ESP-NOW devices exist
 | |
|   * @return Otherwise, MAC address of ESP-NOW device which is pointed now
 | |
|   */
 | |
| uint8 *esp_now_fetch_peer(bool restart);
 | |
| 
 | |
| /**
 | |
|   * @brief  Check if target device exists or not.
 | |
|   *
 | |
|   * @param  uint8 *mac_addr : MAC address of target device.
 | |
|   *
 | |
|   * @return 0   : device does not exist
 | |
|   * @return < 0 : error occur, check fail
 | |
|   * @return > 0 : device exists
 | |
|   */
 | |
| sint32 esp_now_is_peer_exist(uint8 *mac_addr);
 | |
| 
 | |
| /**
 | |
|   * @brief  Get the total number of ESP-NOW devices which are associated, and the
 | |
|   *         number count of encrypted devices.
 | |
|   *
 | |
|   * @param  uint8 *all_cnt    : total number of ESP-NOW devices which are associated.
 | |
|   * @param  uint8 *encryp_cnt : number count of encrypted devices
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_get_cnt_info(uint8 *all_cnt, uint8 *encrypt_cnt);
 | |
| 
 | |
| /**
 | |
|   * @brief  Set the encrypt key of communication key.
 | |
|   *
 | |
|   *         All ESP-NOW devices share the same encrypt key. If users do not set
 | |
|   *         the encrypt key, ESP-NOW communication key will be encrypted by a default key.
 | |
|   *
 | |
|   * @param  uint8 *key : pointer of encrypt key.
 | |
|   * @param  uint8 len  : key length, has to be 16 bytes now.
 | |
|   *
 | |
|   * @return 0     : succeed
 | |
|   * @return Non-0 : fail
 | |
|   */
 | |
| sint32 esp_now_set_kok(uint8 *key, uint8 len);
 | |
| 
 | |
| /**
 | |
|   * @}
 | |
|   */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif
 | 
