1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 19:52:45 +01:00
RIOT/sys/net/gnrc/link_layer/gomach/include/gomach_internal.h

918 lines
27 KiB
C

/*
* Copyright (C) 2017 INRIA
*
* 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 net_gnrc_gomach
* @{
*
* @file
* @brief GoMacH's internal functions.
* @internal
* @author Shuguo Zhuo <shuguo.zhuo@inria.fr>
*/
#ifndef GOMACH_INTERNAL_H
#define GOMACH_INTERNAL_H
#include <stdint.h>
#include "periph/rtt.h"
#include "net/gnrc/netif.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Flag to track if the transmission has finished.
*/
#define GNRC_GOMACH_INFO_TX_FINISHED (0x0008U)
/**
* @brief Flag to track if a packet has been successfully received.
*/
#define GNRC_GOMACH_INFO_PKT_RECEIVED (0x0010U)
/**
* @brief Flag to track if need to update GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_ND_UPDATE (0x0001U)
/**
* @brief Flag to track if need to quit the current cycle in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_QUIT_CYCLE (0x0002U)
/**
* @brief Flag to track if CP period has ended in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_CP_END (0x0004U)
/**
* @brief Flag to track if vTDMA has ended in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_VTDMA_END (0x0008U)
/**
* @brief Flag to track if the node has received unintended preamble.
*/
#define GNRC_GOMACH_INTERNAL_INFO_UNINTD_PREAMBLE (0x0010U)
/**
* @brief Flag to track if need to quit the current cycle in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLE (0x0020U)
/**
* @brief Flag to track if node's duty-cycle has started in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_DUTY_CYCLE_START (0x0040U)
/**
* @brief Flag to track if node need to backoff its phase in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_PHASE_BACKOFF (0x0080U)
/**
* @brief Flag to track if beacon transmission fail in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_BEACON_FAIL (0x0200U)
/**
* @brief Flag to track if node's packet buffer is full in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_BUFFER_FULL (0x0400U)
/**
* @brief Flag to track if node has entered a new cycle in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_ENTER_NEW_CYCLE (0x0800U)
/**
* @brief Flag to track if node has got preamble-ACK in GoMacH.
*/
#define GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLEACK (0x1000U)
/**
* @brief Flag to track if node's radio is on public-channel-1.
*/
#define GNRC_GOMACH_INTERNAL_INFO_ON_PUBCHAN_1 (0x2000U)
/**
* @brief Flag to track if node has reached maximum preamble interval.
*/
#define GNRC_GOMACH_INTERNAL_INFO_MAX_PREAM_INTERV (0x4000U)
/**
* @brief Flag to track if node has turned on its radio.
*/
#define GNRC_GOMACH_INTERNAL_INFO_RADIO_IS_ON (0x8000U)
/**
* @brief Set the @ref GNRC_GOMACH_INFO_TX_FINISHED flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] tx_finish value for GoMacH's
* @ref GNRC_GOMACH_INFO_TX_FINISHED flag.
*
*/
static inline void gnrc_gomach_set_tx_finish(gnrc_netif_t *netif, bool tx_finish)
{
if (tx_finish) {
netif->mac.mac_info |= GNRC_GOMACH_INFO_TX_FINISHED;
}
else {
netif->mac.mac_info &= ~GNRC_GOMACH_INFO_TX_FINISHED;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INFO_TX_FINISHED flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if TX has finished.
* @return false if TX hasn't finished yet.
*/
static inline bool gnrc_gomach_get_tx_finish(gnrc_netif_t *netif)
{
return (netif->mac.mac_info & GNRC_GOMACH_INFO_TX_FINISHED);
}
/**
* @brief Set the @ref GNRC_GOMACH_INFO_PKT_RECEIVED flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] received value for GoMacH's
* @ref GNRC_GOMACH_INFO_PKT_RECEIVED flag.
*
*/
static inline void gnrc_gomach_set_pkt_received(gnrc_netif_t *netif, bool received)
{
if (received) {
netif->mac.mac_info |= GNRC_GOMACH_INFO_PKT_RECEIVED;
}
else {
netif->mac.mac_info &= ~GNRC_GOMACH_INFO_PKT_RECEIVED;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INFO_PKT_RECEIVED flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if radio has successfully received a packet.
* @return false if radio hasn't received a packet yet.
*/
static inline bool gnrc_gomach_get_pkt_received(gnrc_netif_t *netif)
{
return (netif->mac.mac_info & GNRC_GOMACH_INFO_PKT_RECEIVED);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_QUIT_CYCLE flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] quit value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_QUIT_CYCLE flag.
*
*/
static inline void gnrc_gomach_set_quit_cycle(gnrc_netif_t *netif, bool quit)
{
if (quit) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_QUIT_CYCLE;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_QUIT_CYCLE;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_QUIT_CYCLE flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if need to quit cycle.
* @return false if no need to quit cycle.
*/
static inline bool gnrc_gomach_get_quit_cycle(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_QUIT_CYCLE);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLE flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] got_preamble value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLE flag.
*
*/
static inline void gnrc_gomach_set_got_preamble(gnrc_netif_t *netif, bool got_preamble)
{
if (got_preamble) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLE;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLE;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLE flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if get preamble packet.
* @return false if not get preamble packet yet.
*/
static inline bool gnrc_gomach_get_got_preamble(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLE);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_CP_END flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] cp_end value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_CP_END flag.
*
*/
static inline void gnrc_gomach_set_cp_end(gnrc_netif_t *netif, bool cp_end)
{
if (cp_end) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_CP_END;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_CP_END;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_CP_END flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if cp has ended.
* @return false if cp hasn't ended yet.
*/
static inline bool gnrc_gomach_get_cp_end(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_CP_END);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_VTDMA_END flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] vtdma_end value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_VTDMA_END flag.
*
*/
static inline void gnrc_gomach_set_vTDMA_end(gnrc_netif_t *netif, bool vtdma_end)
{
if (vtdma_end) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_VTDMA_END;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_VTDMA_END;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_VTDMA_END flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if vTDMA has ended.
* @return false if vTDMA hasn't ended yet.
*/
static inline bool gnrc_gomach_get_vTDMA_end(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_VTDMA_END);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_UNINTD_PREAMBLE flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] uintd_preamble value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_UNINTD_PREAMBLE flag.
*
*/
static inline void gnrc_gomach_set_unintd_preamble(gnrc_netif_t *netif, bool uintd_preamble)
{
if (uintd_preamble) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_UNINTD_PREAMBLE;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_UNINTD_PREAMBLE;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_UNINTD_PREAMBLE flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if has received unintended-preamble.
* @return false if hasn't received unintended-preamble yet.
*/
static inline bool gnrc_gomach_get_unintd_preamble(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_UNINTD_PREAMBLE);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_ND_UPDATE flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] update value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_ND_UPDATE flag.
*
*/
static inline void gnrc_gomach_set_update(gnrc_netif_t *netif, bool update)
{
if (update) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_ND_UPDATE;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_ND_UPDATE;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_ND_UPDATE flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if need update GoMacH.
* @return false if no need to update GoMacH.
*/
static inline bool gnrc_gomach_get_update(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_ND_UPDATE);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_DUTY_CYCLE_START flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] start value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_DUTY_CYCLE_START flag.
*
*/
static inline void gnrc_gomach_set_duty_cycle_start(gnrc_netif_t *netif, bool start)
{
if (start) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_DUTY_CYCLE_START;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_DUTY_CYCLE_START;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_DUTY_CYCLE_START flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if duty-cycle has started.
* @return false if duty-cycle hasn't started yet.
*/
static inline bool gnrc_gomach_get_duty_cycle_start(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_DUTY_CYCLE_START);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_PHASE_BACKOFF flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] backoff value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_PHASE_BACKOFF flag.
*
*/
static inline void gnrc_gomach_set_phase_backoff(gnrc_netif_t *netif, bool backoff)
{
if (backoff) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_PHASE_BACKOFF;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_PHASE_BACKOFF;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_PHASE_BACKOFF flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if need to run phase backoff.
* @return false if no need to run phase backoff.
*/
static inline bool gnrc_gomach_get_phase_backoff(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_PHASE_BACKOFF);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_BEACON_FAIL flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] fail value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_BEACON_FAIL flag.
*
*/
static inline void gnrc_gomach_set_beacon_fail(gnrc_netif_t *netif, bool fail)
{
if (fail) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_BEACON_FAIL;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_BEACON_FAIL;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_BEACON_FAIL flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if send beacon fail.
* @return false upon beacon transmission success.
*/
static inline bool gnrc_gomach_get_beacon_fail(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_BEACON_FAIL);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_BUFFER_FULL flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] full value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_BUFFER_FULL flag.
*
*/
static inline void gnrc_gomach_set_buffer_full(gnrc_netif_t *netif, bool full)
{
if (full) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_BUFFER_FULL;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_BUFFER_FULL;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_BUFFER_FULL flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if node's packet buffer is full.
* @return false if node's packet buffer is not full.
*/
static inline bool gnrc_gomach_get_buffer_full(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_BUFFER_FULL);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_ENTER_NEW_CYCLE flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] enter value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_ENTER_NEW_CYCLE flag.
*
*/
static inline void gnrc_gomach_set_enter_new_cycle(gnrc_netif_t *netif, bool enter)
{
if (enter) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_ENTER_NEW_CYCLE;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_ENTER_NEW_CYCLE;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_ENTER_NEW_CYCLE flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if node has entered a new cycle.
* @return false if node hasn't entered a new cycle yet.
*/
static inline bool gnrc_gomach_get_enter_new_cycle(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_ENTER_NEW_CYCLE);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLEACK flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] got value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLEACK flag.
*
*/
static inline void gnrc_gomach_set_got_preamble_ack(gnrc_netif_t *netif, bool got)
{
if (got) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLEACK;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLEACK;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLEACK flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if node has got preamble-ACK.
* @return false if node hasn't got preamble-ACK yet.
*/
static inline bool gnrc_gomach_get_got_preamble_ack(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_GOT_PREAMBLEACK);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_ON_PUBCHAN_1 flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] on_pubchan_1 value for GoMacH's
* @ref GNRC_GOMACH_INTERNAL_INFO_ON_PUBCHAN_1 flag.
*
*/
static inline void gnrc_gomach_set_on_pubchan_1(gnrc_netif_t *netif, bool on_pubchan_1)
{
if (on_pubchan_1) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_ON_PUBCHAN_1;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_ON_PUBCHAN_1;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_ON_PUBCHAN_1 flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if node is on public channel 1.
* @return false if node is not on public channel 1.
*/
static inline bool gnrc_gomach_get_on_pubchan_1(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_ON_PUBCHAN_1);
}
/**
* @brief Set the @ref GNRC_GOMACH_INTERNAL_INFO_MAX_PREAM_INTERV flag of the device.
*
* @param[in,out] netif the network interface.
* @param[in] max value for GoMacH's @ref
* GNRC_GOMACH_INTERNAL_INFO_MAX_PREAM_INTERV flag.
*
*/
static inline void gnrc_gomach_set_max_pream_interv(gnrc_netif_t *netif, bool max)
{
if (max) {
netif->mac.prot.gomach.gomach_info |= GNRC_GOMACH_INTERNAL_INFO_MAX_PREAM_INTERV;
}
else {
netif->mac.prot.gomach.gomach_info &= ~GNRC_GOMACH_INTERNAL_INFO_MAX_PREAM_INTERV;
}
}
/**
* @brief Get the @ref GNRC_GOMACH_INTERNAL_INFO_MAX_PREAM_INTERV flag of the device.
*
* @param[in] netif the network interface.
*
* @return true if node has reached maximum preamble interval.
* @return false if node hasn't reached maximum preamble interval yet.
*/
static inline bool gnrc_gomach_get_max_pream_interv(gnrc_netif_t *netif)
{
return (netif->mac.prot.gomach.gomach_info & GNRC_GOMACH_INTERNAL_INFO_MAX_PREAM_INTERV);
}
/**
* @brief Get device's current phase.
*
* @param[in] netif the network interface.
*
* @return device's current phase.
*/
uint64_t gnrc_gomach_phase_now(gnrc_netif_t *netif);
/**
* @brief Shortcut to set the state of netdev
*
* @param[in] netif ptr to the network interface
* @param[in] devstate new state for netdev
*/
void gnrc_gomach_set_netdev_state(gnrc_netif_t *netif, netopt_state_t devstate);
/**
* @brief Set the auto-ACK parameter of the device.
*
* @param[in,out] netif the network interface.
* @param[in] autoack value for the auto-ACK parameter.
*
*/
static inline void gnrc_gomach_set_autoack(gnrc_netif_t *netif, netopt_enable_t autoack)
{
assert(netif != NULL);
netif->dev->driver->set(netif->dev,
NETOPT_AUTOACK,
&autoack,
sizeof(autoack));
}
/**
* @brief Set the ACK-require parameter of the device.
*
* @param[in,out] netif the network interface.
* @param[in] ack_req value for the ACK-require parameter.
*
*/
static inline void gnrc_gomach_set_ack_req(gnrc_netif_t *netif, netopt_enable_t ack_req)
{
assert(netif != NULL);
netif->dev->driver->set(netif->dev,
NETOPT_ACK_REQ,
&ack_req,
sizeof(ack_req));
}
/**
* @brief Shortcut to get the state of netdev.
*
* @param[in] netif the network interface.
*
* @return state of netdev upon success.
* @return -ENOSYS, upon failure.
*/
static inline netopt_state_t gnrc_gomach_get_netdev_state(gnrc_netif_t *netif)
{
assert(netif != NULL);
netopt_state_t state;
if (0 < netif->dev->driver->get(netif->dev,
NETOPT_STATE,
&state,
sizeof(state))) {
return state;
}
return -ENOSYS;
}
/**
* @brief Turn the radio to a specific channel.
*
* @param[in,out] netif the network interface.
* @param[in] channel_num targeted channel number to turn to.
*
*/
static inline void gnrc_gomach_turn_channel(gnrc_netif_t *netif, uint16_t channel_num)
{
assert(netif != NULL);
netif->dev->driver->set(netif->dev,
NETOPT_CHANNEL,
&channel_num,
sizeof(channel_num));
}
/**
* @brief send a @ref net_gnrc_pkt "packet" over the network interface in GoMacH
*
* @internal
*
* @pre `netif != NULL && pkt != NULL`
*
* @note The function re-formats the content of @p pkt to a format expected
* by the netdev_driver_t::send() method of gnrc_netif_t::dev and
* releases the packet before returning (so no additional release
* should be required after calling this method).
*
* @param[in] netif The network interface.
* @param[in] pkt A packet to send.
*
* @return The number of bytes actually sent on success
* @return -EBADMSG, if the @ref net_gnrc_netif_hdr in @p pkt is missing
* or is in an unexpected format.
* @return -ENOTSUP, if sending @p pkt in the given format isn't supported
* (e.g. empty payload with Ethernet).
* @return Any negative error code reported by gnrc_netif_t::dev.
*/
int _gnrc_gomach_transmit(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt);
/**
* @brief Check if the received packet is a duplicate packet.
*
* @param[in] netif the network interface.
* @param[in] pa_info ptr to received packet's parsed information.
*
* @return true if the received packet is a duplicate packet.
* @return false if the received packet is not a duplicate packet.
*/
bool gnrc_gomach_check_duplicate(gnrc_netif_t *netif, gnrc_gomach_packet_info_t *pa_info);
/**
* @brief Send a pktsnip in GoMacH.
*
* @param[in] netif the network interface.
* @param[in] pkt ptr to the packet for sending.
* @param[in] csma_enable value of csma-enable parameter.
*
* @return >0 upon sending success.
* @return 0< upon sending failure.
*/
int gnrc_gomach_send(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt, netopt_enable_t csma_enable);
/**
* @brief Reply a preamble-ACK packet in GoMacH.
*
* @param[in] netif the network interface.
* @param[in] info ptr to the info of the preamble packet.
*
* @return >0 upon sending success.
* @return 0< upon sending failure.
*/
int gnrc_gomach_send_preamble_ack(gnrc_netif_t *netif, gnrc_gomach_packet_info_t *info);
/**
* @brief Broadcast a beacon packet in GoMacH.
*
* @param[in] netif the network interface.
*
* @return >0 upon sending success.
* @return 0< upon sending failure.
*/
int gnrc_gomach_send_beacon(gnrc_netif_t *netif);
/**
* @brief Store the received packet to the dispatch buffer.
*
* @param[in,out] buffer RX dispatch packet buffer
* @param[in] pkt received packet
*
* @return 0 if correctly stored
* @return <0 on error
*/
int gnrc_gomach_dispatch_defer(gnrc_pktsnip_t * buffer[], gnrc_pktsnip_t * pkt);
/**
* @brief Update the queue-length indicator of the packet sender.
*
* @param[in,out] netif the network interface.
* @param[in] pkt received packet
* @param[in] pa_info ptr to the info of the received packet.
*
*/
void gnrc_gomach_indicator_update(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt,
gnrc_gomach_packet_info_t *pa_info);
/**
* @brief Process packets received during the CP (wake-up) period of GoMacH.
*
* @param[in,out] netif the network interface.
*
*/
void gnrc_gomach_cp_packet_process(gnrc_netif_t *netif);
/**
* @brief Choose a sub-channel for a device running GoMacH.
*
* @param[in,out] netif the network interface.
*
*/
void gnrc_gomach_init_choose_subchannel(gnrc_netif_t *netif);
/**
* @brief Broadcast the chosen sub-channel sequence to the device's neighbors.
*
* @param[in] netif the network interface.
* @param[in] use_csma value of csma-enable parameter.
*
* @return >0 upon sending success.
* @return 0< upon sending failure.
*/
int gnrc_gomach_bcast_subchann_seq(gnrc_netif_t *netif, netopt_enable_t use_csma);
/**
* @brief Send a preamble packet to the targeted neighbor.
*
* @param[in] netif the network interface.
* @param[in] csma_enable value of csma-enable parameter.
*
* @return >0 upon sending success.
* @return 0< upon sending failure.
*/
int gnrc_gomach_send_preamble(gnrc_netif_t *netif, netopt_enable_t csma_enable);
/**
* @brief Process the received preamble-ACK packet to get phase-locked with the sender.
*
* @param[in,out] netif the network interface.
* @param[in] pkt ptr to the received preamble-ACK.
*
*/
void gnrc_gomach_process_preamble_ack(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt);
/**
* @brief Process the received packets to when waiting for the preamble-ACK packet.
*
* @param[in,out] netif the network interface.
*
*/
void gnrc_gomach_process_pkt_in_wait_preamble_ack(gnrc_netif_t *netif);
/**
* @brief Send a data packet to the targeted neighbor.
*
* @param[in,out] netif the network interface.
* @param[in] csma_enable value of csma-enable parameter.
*
* @return >0 upon sending success.
* @return 0< upon sending failure.
*/
int gnrc_gomach_send_data(gnrc_netif_t *netif, netopt_enable_t csma_enable);
/**
* @brief Find a neighbor that is next to send packet to.
*
* @param[in,out] netif the network interface.
*
* @return true, if found next TX neighbor.
* @return false, if not found next TX neighbor.
*
*/
bool gnrc_gomach_find_next_tx_neighbor(gnrc_netif_t *netif);
/**
* @brief Process the received beacon packet.
*
* @param[in,out] netif the network interface.
* @param[in] pkt ptr to the received beacon.
*
*/
void gnrc_gomach_beacon_process(gnrc_netif_t *netif, gnrc_pktsnip_t *pkt);
/**
* @brief Process the received packets when waiting for the beacon during
* t2k procedure in GoMacH.
*
* @param[in,out] netif the network interface.
*
*/
void gnrc_gomach_packet_process_in_wait_beacon(gnrc_netif_t *netif);
/**
* @brief Process the received packets in the vTDMA period in GoMacH.
*
* @param[in,out] netif the network interface.
*
*/
void gnrc_gomach_packet_process_in_vtdma(gnrc_netif_t *netif);
/**
* @brief Update the TX neighbors' phases in GoMacH.
*
* @param[in,out] netif the network interface.
*
*/
void gnrc_gomach_update_neighbor_phase(gnrc_netif_t *netif);
/**
* @brief Update the TX neighbors' public channel phase in GoMacH.
*
* @param[in,out] netif the network interface.
*
*/
void gnrc_gomach_update_neighbor_pubchan(gnrc_netif_t *netif);
#ifdef __cplusplus
}
#endif
#endif /* GOMACH_INTERNAL_H */
/** @} */