mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 00:52:43 +01:00
127 lines
2.9 KiB
C
127 lines
2.9 KiB
C
/*
|
|
* Copyright (C) 2018 Gunar Schorcht
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup cpu_esp_common_esp_now
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Netdev interface for the ESP-NOW WiFi P2P protocol
|
|
*
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
* @author Timo Rothenpieler <timo.rothenpieler@uni-bremen.de>
|
|
*/
|
|
|
|
#ifndef ESP_NOW_NETDEV_H
|
|
#define ESP_NOW_NETDEV_H
|
|
|
|
#include "net/netdev.h"
|
|
#include "mutex.h"
|
|
#include "net/ethernet/hdr.h"
|
|
#ifdef MODULE_GNRC
|
|
#include "net/gnrc/nettype.h"
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Maximum raw packet size that can be used with ESP-NOW (including headers)
|
|
*/
|
|
#define ESP_NOW_MAX_SIZE_RAW (250)
|
|
|
|
/**
|
|
* @brief Length of ESP-NOW addresses
|
|
*/
|
|
#define ESP_NOW_ADDR_LEN ETHERNET_ADDR_LEN
|
|
|
|
/**
|
|
* @brief Size of non-data header elements in ESP-NOW packet
|
|
*/
|
|
#define ESP_NOW_HEADER_LENGTH (sizeof(esp_now_pkt_hdr_t))
|
|
|
|
/**
|
|
* @brief Maximum packet size that can be used with ESP-NOW
|
|
*/
|
|
#define ESP_NOW_MAX_SIZE (ESP_NOW_MAX_SIZE_RAW - ESP_NOW_HEADER_LENGTH)
|
|
|
|
/**
|
|
* @brief buffer size used for RX buffering
|
|
*
|
|
* The buffer is use to store a ESP-NOW packet and the source MAC address.
|
|
*/
|
|
#ifndef ESP_NOW_BUFSIZE
|
|
#define ESP_NOW_BUFSIZE (ESP_NOW_MAX_SIZE_RAW + ESP_NOW_ADDR_LEN)
|
|
#endif
|
|
|
|
/**
|
|
* @brief Reference to the netdev device driver struct
|
|
*/
|
|
extern const netdev_driver_t esp_now_driver;
|
|
|
|
/**
|
|
* @brief Header with necessary flags for ESP-NOW packets
|
|
*/
|
|
typedef struct __attribute__((packed))
|
|
{
|
|
uint8_t flags; /**< Flags */
|
|
} esp_now_pkt_hdr_t;
|
|
|
|
/**
|
|
* @brief Packet is carrying 6Lo data
|
|
*/
|
|
#define ESP_NOW_PKT_HDR_FLAG_SIXLO (1)
|
|
|
|
/**
|
|
* @brief Device descriptor for ESP-NOW devices
|
|
*/
|
|
typedef struct
|
|
{
|
|
netdev_t netdev; /**< netdev parent struct */
|
|
|
|
uint8_t addr[ESP_NOW_ADDR_LEN]; /**< device addr (MAC address) */
|
|
|
|
uint8_t rx_len; /**< number of bytes received */
|
|
uint8_t* rx_mac; /**< source mac of received data */
|
|
uint8_t* rx_data; /**< received */
|
|
|
|
uint8_t tx_mem[ESP_NOW_MAX_SIZE_RAW]; /**< memory holding outgoing package */
|
|
|
|
#ifdef MODULE_GNRC
|
|
gnrc_nettype_t proto; /**< protocol for upper layer */
|
|
#endif
|
|
|
|
mutex_t dev_lock; /**< device is already in use */
|
|
|
|
uint8_t scan_event; /**< ESP-NOW peers have to be scanned */
|
|
|
|
} esp_now_netdev_t;
|
|
|
|
/**
|
|
* @brief ESP-NOW netdev initialization function
|
|
*
|
|
* @return NULL on error, pointer to esp_now_netdev on success
|
|
*/
|
|
esp_now_netdev_t *netdev_esp_now_setup(void);
|
|
|
|
/**
|
|
* @brief Set the channel used by ESP-NOW netdev
|
|
*
|
|
* @param channel Channel to be used
|
|
* @return ESP_OK on success, an ESP error code otherwise
|
|
*/
|
|
int esp_now_set_channel(uint8_t channel);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* ESP_NOW_NETDEV_H */
|
|
/** @} */
|