1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 11:52:44 +01:00
RIOT/cpu/esp_common/esp-now/esp_now_netdev.h

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 */
/** @} */