mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 19:32:46 +01:00
228 lines
11 KiB
Plaintext
228 lines
11 KiB
Plaintext
|
# Copyright (c) 2020 Freie Universitaet Berlin
|
||
|
#
|
||
|
# 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.
|
||
|
#
|
||
|
menuconfig KCONFIG_MODULE_GNRC_GOMACH
|
||
|
bool "Configure GNRC GOMACH"
|
||
|
depends on MODULE_GNRC_GOMACH
|
||
|
help
|
||
|
Configure the GNRC GOMACH using Kconfig.
|
||
|
|
||
|
if KCONFIG_MODULE_GNRC_GOMACH
|
||
|
|
||
|
config GNRC_GOMACH_CP_DURATION_US
|
||
|
int "Wake-up period (WP) duration in microseconds"
|
||
|
default 10000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_CP_DURATION_US'. GoMacH adopts the
|
||
|
duty-cycle scheme that, by default, a node only wakes up for a short
|
||
|
period of 'CONFIG_GNRC_GOMACH_CP_DURATION_US' in each cycle. In the
|
||
|
rest of the cycle (except vTDMA), the node turns off the radio to
|
||
|
conserve power. 'CONFIG_GNRC_GOMACH_CP_DURATION_US' should be at least
|
||
|
longer than 'CONFIG_GNRC_GOMACH_MAX_PREAM_INTERVAL_US', thus to
|
||
|
guarantee that the receiver will not miss the preamble packet.
|
||
|
|
||
|
config GNRC_GOMACH_SUPERFRAME_DURATION_US
|
||
|
int "Duration of superframe in microseconds"
|
||
|
default 300000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_SUPERFRAME_DURATION_US' ,superframe
|
||
|
duration, i.e , time between two consecutive wake-ups.
|
||
|
The configurations should not be shorter than 10 times of
|
||
|
'CONFIG_GNRC_GOMACH_CP_DURATION_US' and not shorter than the RTT tickle
|
||
|
interval.This configuration governs power consumption and GoMacH's
|
||
|
reactiveness to traffic loads.In GoMacH, nodes adopt duty-cycle scheme
|
||
|
to conserve power. That is, time is divided into repeated cycles
|
||
|
(superframes), and in each cycle, a node only wakes up for a short
|
||
|
period of time for receiving potential incoming packets for itself.
|
||
|
This configuration defines the wake-up interval, or, in other words,
|
||
|
defines the cycle duration used in GoMacH. For more information refer
|
||
|
file 'gomach.h' in sys/include/net/gnrc.
|
||
|
|
||
|
config GNRC_GOMACH_CP_RANDOM_END_US
|
||
|
int "Duration of random period at the end of WP in microseconds"
|
||
|
default 1000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_CP_RANDOM_END_US', the maximum duration
|
||
|
of the random period at the end of GoMacH's wake-up period (WP).
|
||
|
Currently, GoMacH's WP is composed of
|
||
|
'CONFIG_GNRC_GOMACH_CP_DURATION_US' and (+)
|
||
|
'CONFIG_GNRC_GOMACH_CP_RANDOM_END_US'. This random was introduced
|
||
|
to avoid beacon collision among neighbor nodes. This configuration may
|
||
|
be removed in the future.
|
||
|
|
||
|
config GNRC_GOMACH_CP_MIN_GAP_US
|
||
|
int "Time interval between neighbor nodes' Wake-up phases in microseconds"
|
||
|
default 25000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_CP_MIN_GAP_US', the minimum gap between
|
||
|
neighbor nodes' wake-up phases in GoMacH.To reduce beacon collisions
|
||
|
and transmission collisions, GoMacH intends to avoid neighbor nodes'
|
||
|
phases being too close to each other. This configuration defines the
|
||
|
minimum gap between two nodes's wake-up phases. If the sender finds its
|
||
|
wake-up phase too closed to its receiver's, it will randomly select a
|
||
|
new phase for itself.
|
||
|
|
||
|
config GNRC_GOMACH_WAIT_RX_END_US
|
||
|
int "Timeout for 'NETDEV_EVENT_RX_COMPLETE' in GoMacH in microseconds"
|
||
|
default 6000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_WAIT_RX_END_US', the timeout duration for
|
||
|
waiting 'NETDEV_EVENT_RX_COMPLETE' event in GoMacH. Sometimes in
|
||
|
GoMacH, if a node finds RX ongoing when it is just about to enter the
|
||
|
next MAC state, it will set up a timeout for waiting this packet
|
||
|
reception complete with a timeout of this
|
||
|
'CONFIG_GNRC_GOMACH_WAIT_RX_END_US' duration.
|
||
|
|
||
|
config GNRC_GOMACH_NO_TX_ISR_US
|
||
|
int "Timeout duration for confirming TX-No-ISR event in microseconds"
|
||
|
default 50000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_NO_TX_ISR_US',the timeout duration for
|
||
|
confirming TX-No-ISR event in GoMacH. This configuration is used to
|
||
|
confirm/catch a case that a transmission doesn't have its
|
||
|
'NETDEV_EVENT_TX_COMPLETE' interrupt event, which is considered as a
|
||
|
hardware abnormal event. Upon this timeout expiration, GoMach will
|
||
|
accordingly take actions to maintain its state-machine.
|
||
|
|
||
|
config GNRC_GOMACH_MAX_PREAM_INTERVAL_US
|
||
|
int "Maximum time interval between two preamble packets in microseconds"
|
||
|
default 6000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_MAX_PREAM_INTERVAL_US',the maximum time
|
||
|
interval between two consecutive preamble packets in GoMacH. In GoMacH,
|
||
|
a sender first uses preamble stream to track the receiver's wake-up
|
||
|
phase (WP), if the receiver's WP is unknown. This configuration defines
|
||
|
the maximum time interval between twoconsecutive preamble packets.
|
||
|
|
||
|
config GNRC_GOMACH_PREAMBLE_INTERVAL_US
|
||
|
int "Time interval between two preamble packets in microseconds"
|
||
|
default 2000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_PREAMBLE_INTERVAL_US', the time interval
|
||
|
between two consecutive preamble packets in GoMacH. In GoMacH, after a
|
||
|
preamble is sent, the sender sets a timeout with
|
||
|
'CONFIG_GNRC_GOMACH_PREAMBLE_INTERVAL_US' duration for waiting to send
|
||
|
the next preamble. Notably, this configuration is with a very small
|
||
|
value. In GoMacH, for receiving the preamble-ACK packet, the sender
|
||
|
doesn't wait for the whole reception of the preamble-ACK. Instead, it
|
||
|
only waits for the 'NETDEV_EVENT_RX_STARTED' event which leads to
|
||
|
shorter time interval between two consecutive preamble transmissions.
|
||
|
|
||
|
config GNRC_GOMACH_BCAST_INTERVAL_US
|
||
|
int "Time interval between two broadcast packets in microseconds"
|
||
|
default 1000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_BCAST_INTERVAL_US', the time interval
|
||
|
between two consecutive broadcast packets in GoMacH. In GoMacH, when
|
||
|
sending a broadcast packet, the sender broadcasts the same packet frame
|
||
|
on its two public channels simultaneously, with a total duration of
|
||
|
'CONFIG_GNRC_GOMACH_SUPERFRAME_DURATION_US' to guarantee that all
|
||
|
neighbors will get a copy. This configuration defines the time interval
|
||
|
between ending two consecutive broadcast copies.
|
||
|
|
||
|
config GNRC_GOMACH_VTDMA_SLOT_SIZE_US
|
||
|
int "Transmission slot size in microseconds **Should not be changed**"
|
||
|
default 5000
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_VTDMA_SLOT_SIZE_US', the transmission slot
|
||
|
size in GoMacH. GoMacH adopts dynamic slots allocation scheme to
|
||
|
allocate transmission slots to senders that have pending packets. Each
|
||
|
slot is for one data packet with ACK transmission.
|
||
|
'CONFIG_GNRC_GOMACH_VTDMA_SLOT_SIZE_US' is right sufficient for the
|
||
|
transmission of the longest packet in IEEE 802.15.4 with ACK. Should
|
||
|
not be changed.
|
||
|
|
||
|
config GNRC_GOMACH_TX_BUSY_THRESHOLD
|
||
|
int "Maximum number of CSMA TX attempts under busy-indication in the WP"
|
||
|
default 5
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_TX_BUSY_THRESHOLD', maximum number of
|
||
|
CSMA TX attempts under busy-indication in the WP period of the receiver.
|
||
|
Senders in GoMacH adopt CSMA scheme to send data packets in the WP
|
||
|
period of the receiver. In case of having medium-busy feedback in WP
|
||
|
and the TX failure count (due to busy) is below
|
||
|
'CONFIG_GNRC_GOMACH_TX_BUSY_THRESHOLD', the sender continue to send the
|
||
|
packet with CSMAin the receiver's WP, with the consideration that there
|
||
|
may be multi-senders simultaneously competing in WP and the WP will be
|
||
|
continuously extended (thus the packet can be received).
|
||
|
|
||
|
config GNRC_GOMACH_CP_EXTEND_THRESHOLD
|
||
|
int "Maximum WP period extension number"
|
||
|
default 5
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_CP_EXTEND_THRESHOLD', maximum WP period
|
||
|
extension number in GoMacH. The WP period of a receiver will be
|
||
|
extended upon each successful packet reception (except receiving
|
||
|
broadcast or preamble packet) to receive more potential incoming
|
||
|
packets.
|
||
|
|
||
|
config GNRC_GOMACH_RX_DUPCHK_UNIT_LIFE
|
||
|
int "Life time of check-duplicate-packet in cycle count"
|
||
|
default 30
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_RX_DUPCHK_UNIT_LIFE', GoMacH's
|
||
|
check-duplicate-packet unit life time in cycle count. In GoMacH, to
|
||
|
avoid receiving duplicate-packet, we currently introduce a data type of
|
||
|
'gnrc_gomach_dupchk_unit_t' to record the recent senders' information
|
||
|
(especially MAC TX sequence). This configuration defines the
|
||
|
check-duplicate-packet data unit's life time in cycle count. Once
|
||
|
expired, the related data unit will be reset. This configuration maybe
|
||
|
removed in the future.
|
||
|
|
||
|
config GNRC_GOMACH_MAX_ALLOC_SENDER_NUM
|
||
|
int "Maximum number of senders allowed to be allocated slots in one cycle"
|
||
|
default 11
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_MAX_ALLOC_SENDER_NUM', maximum number of
|
||
|
senders allowed to be allocated slots in one cycle. Exclude the static
|
||
|
GoMacH MAC header payload in the beacon, which is 20 bytes, we have 107
|
||
|
bytes left for constructing the sender-ID list and the related
|
||
|
slots-number list. A combined slots allocation information pair (sender
|
||
|
ID with its corresponded allocate slots number) will cost 9 (8+1)
|
||
|
bytes, thus we can hold a maximum of 11 i.e., ((127 - 20) / 9), sender
|
||
|
IDs in the beacon.
|
||
|
|
||
|
config GNRC_GOMACH_REPHASELOCK_THRESHOLD
|
||
|
int "Maximum number of t2k attempts before t2u"
|
||
|
default 4
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_REPHASELOCK_THRESHOLD', maximum t2k
|
||
|
attempts before going to t2u in GoMacH.After phase-locked with the
|
||
|
receiver, a sender runs a t2k (transmit-to-known) procedure to transmit
|
||
|
packet to the phase-known device. However, due to factors like timer
|
||
|
driftor busy-channel, a transmission attempt may fail in t2k. If the
|
||
|
t2k failure count has reached this
|
||
|
'CONFIG_GNRC_GOMACH_REPHASELOCK_THRESHOLD', the sender regards
|
||
|
phase-locked failed due to timer drift. In this case, it will adopt t2u
|
||
|
(transmit-to-unknown) procedure to get re-phase-locked with the
|
||
|
receiver.
|
||
|
|
||
|
config GNRC_GOMACH_T2U_RETYR_THRESHOLD
|
||
|
int "Maximum number of t2u attempts before dropping data packet"
|
||
|
default 2
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_T2U_RETYR_THRESHOLD', maximum number of
|
||
|
t2u attempts before dropping data packet in GoMacH. In case the
|
||
|
receiver's phase is unknown to the sender, the sender adopts the t2u
|
||
|
(transmit-to-unknown) procedure to get phase-locked with the receiver.
|
||
|
This configuration defines the maximum t2u attempts before dropping the
|
||
|
data packet in GoMacH.
|
||
|
|
||
|
config GNRC_GOMACH_MAX_T2U_RETYR_THRESHOLD
|
||
|
int "Maximum t2u attempts before re-initiating radio"
|
||
|
default 10
|
||
|
help
|
||
|
Configure 'CONFIG_GNRC_GOMACH_MAX_T2U_RETYR_THRESHOLD', maximum number
|
||
|
of t2u attempts before re-initiaing radio in GoMacH. After a long
|
||
|
period of run time, a radio may be in wrong condition which needs to be
|
||
|
re-calibrated. This is indicated by having a series of continuous t2u
|
||
|
failures (no preambleACK) in GoMacH. In case we have
|
||
|
'CONFIG_GNRC_GOMACH_MAX_T2U_RETYR_THRESHOLD' number of t2u failures,
|
||
|
then we re-initiate the radio, trying to re-calibrate the radio for
|
||
|
bringing it back to normal condition.
|
||
|
|
||
|
endif # KCONFIG_MODULE_GNRC_GOMACH
|