2017-02-06 12:42:34 +01:00
|
|
|
/* ieee802154_nrf5.h - nRF5 802.15.4 driver */
|
|
|
|
|
|
|
|
/*
|
2023-07-18 12:28:33 +02:00
|
|
|
* Copyright (c) 2017-2023 Nordic Semiconductor ASA
|
2017-02-06 12:42:34 +01:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2018-09-14 19:43:44 +02:00
|
|
|
#ifndef ZEPHYR_DRIVERS_IEEE802154_IEEE802154_NRF5_H_
|
|
|
|
#define ZEPHYR_DRIVERS_IEEE802154_IEEE802154_NRF5_H_
|
2017-02-06 12:42:34 +01:00
|
|
|
|
2022-05-06 10:25:46 +02:00
|
|
|
#include <zephyr/net/ieee802154_radio.h>
|
2021-01-25 16:33:17 +01:00
|
|
|
|
2017-02-06 12:42:34 +01:00
|
|
|
#define NRF5_PHR_LENGTH (1)
|
|
|
|
|
2019-01-17 14:12:27 +01:00
|
|
|
struct nrf5_802154_rx_frame {
|
|
|
|
void *fifo_reserved; /* 1st word reserved for use by fifo. */
|
2020-05-27 18:26:57 +02:00
|
|
|
uint8_t *psdu; /* Pointer to a received frame. */
|
2022-02-23 12:16:19 +01:00
|
|
|
uint64_t time; /* RX timestamp. */
|
2020-05-27 18:26:57 +02:00
|
|
|
uint8_t lqi; /* Last received frame LQI value. */
|
|
|
|
int8_t rssi; /* Last received frame RSSI value. */
|
2020-03-20 11:39:21 +01:00
|
|
|
bool ack_fpb; /* FPB value in ACK sent for the received frame. */
|
2019-01-17 14:12:27 +01:00
|
|
|
};
|
|
|
|
|
2017-02-06 12:42:34 +01:00
|
|
|
struct nrf5_802154_data {
|
|
|
|
/* Pointer to the network interface. */
|
|
|
|
struct net_if *iface;
|
2019-01-17 14:12:27 +01:00
|
|
|
|
2017-02-06 12:42:34 +01:00
|
|
|
/* 802.15.4 HW address. */
|
2020-05-27 18:26:57 +02:00
|
|
|
uint8_t mac[8];
|
2019-01-17 14:12:27 +01:00
|
|
|
|
2017-02-06 12:42:34 +01:00
|
|
|
/* RX thread stack. */
|
2020-07-31 21:29:38 +02:00
|
|
|
K_KERNEL_STACK_MEMBER(rx_stack, CONFIG_IEEE802154_NRF5_RX_STACK_SIZE);
|
2019-01-17 14:12:27 +01:00
|
|
|
|
|
|
|
/* RX thread control block. */
|
2017-05-09 21:15:00 +02:00
|
|
|
struct k_thread rx_thread;
|
2017-02-06 12:42:34 +01:00
|
|
|
|
2019-01-17 14:12:27 +01:00
|
|
|
/* RX fifo queue. */
|
|
|
|
struct k_fifo rx_fifo;
|
|
|
|
|
|
|
|
/* Buffers for passing received frame pointers and data to the
|
|
|
|
* RX thread via rx_fifo object.
|
|
|
|
*/
|
2020-11-13 16:39:45 +01:00
|
|
|
struct nrf5_802154_rx_frame rx_frames[CONFIG_NRF_802154_RX_BUFFERS];
|
2019-01-17 14:12:27 +01:00
|
|
|
|
2020-03-20 11:39:21 +01:00
|
|
|
/* Frame pending bit value in ACK sent for the last received frame. */
|
|
|
|
bool last_frame_ack_fpb;
|
|
|
|
|
2022-02-24 13:00:55 +01:00
|
|
|
/* CCA complete semaphore. Unlocked when CCA is complete. */
|
2017-02-06 12:42:34 +01:00
|
|
|
struct k_sem cca_wait;
|
2019-01-17 14:12:27 +01:00
|
|
|
|
|
|
|
/* CCA result. Holds information whether channel is free or not. */
|
|
|
|
bool channel_free;
|
|
|
|
|
2017-02-06 12:42:34 +01:00
|
|
|
/* TX synchronization semaphore. Unlocked when frame has been
|
2019-01-17 14:12:27 +01:00
|
|
|
* sent or send procedure failed.
|
2017-02-06 12:42:34 +01:00
|
|
|
*/
|
|
|
|
struct k_sem tx_wait;
|
|
|
|
|
2019-01-17 14:12:27 +01:00
|
|
|
/* TX buffer. First byte is PHR (length), remaining bytes are
|
|
|
|
* MPDU data.
|
|
|
|
*/
|
2023-07-19 09:15:08 +02:00
|
|
|
uint8_t tx_psdu[NRF5_PHR_LENGTH + IEEE802154_MAX_PHY_PACKET_SIZE];
|
2017-02-06 12:42:34 +01:00
|
|
|
|
2019-01-17 14:12:27 +01:00
|
|
|
/* TX result, updated in radio transmit callbacks. */
|
2020-05-27 18:26:57 +02:00
|
|
|
uint8_t tx_result;
|
2017-02-06 12:42:34 +01:00
|
|
|
|
2019-04-11 13:29:25 +02:00
|
|
|
/* A buffer for the received ACK frame. psdu pointer be NULL if no
|
|
|
|
* ACK was requested/received.
|
2019-01-17 14:12:27 +01:00
|
|
|
*/
|
2019-04-11 13:29:25 +02:00
|
|
|
struct nrf5_802154_rx_frame ack_frame;
|
2020-02-25 11:17:45 +01:00
|
|
|
|
|
|
|
/* Callback handler of the currently ongoing energy scan.
|
|
|
|
* It shall be NULL if energy scan is not in progress.
|
|
|
|
*/
|
|
|
|
energy_scan_done_cb_t energy_scan_done;
|
2020-02-28 15:48:57 +01:00
|
|
|
|
|
|
|
/* Callback handler to notify of any important radio events.
|
|
|
|
* Can be NULL if event notification is not needed.
|
|
|
|
*/
|
|
|
|
ieee802154_event_cb_t event_handler;
|
2021-01-25 16:33:17 +01:00
|
|
|
|
|
|
|
/* Capabilities of the network interface. */
|
|
|
|
enum ieee802154_hw_caps capabilities;
|
2021-06-23 16:52:35 +02:00
|
|
|
|
2021-07-12 15:00:37 +02:00
|
|
|
/* Indicates if currently processed TX frame is secured. */
|
|
|
|
bool tx_frame_is_secured;
|
|
|
|
|
|
|
|
/* Indicates if currently processed TX frame has dynamic data updated. */
|
|
|
|
bool tx_frame_mac_hdr_rdy;
|
2023-07-18 12:28:33 +02:00
|
|
|
|
|
|
|
#if defined(CONFIG_IEEE802154_NRF5_MULTIPLE_CCA)
|
|
|
|
/* The maximum number of extra CCA attempts to be performed before transmission. */
|
|
|
|
uint8_t max_extra_cca_attempts;
|
|
|
|
#endif
|
2017-02-06 12:42:34 +01:00
|
|
|
};
|
|
|
|
|
2018-09-14 19:43:44 +02:00
|
|
|
#endif /* ZEPHYR_DRIVERS_IEEE802154_IEEE802154_NRF5_H_ */
|