From d35511bee709413e6c09da4c3ac9bc6edb55bd0b Mon Sep 17 00:00:00 2001 From: Benjamin Valentin Date: Fri, 13 Dec 2019 17:47:03 +0100 Subject: [PATCH 1/3] drivers/at86rf215: Add basic driver for the AT86RF215 radio This adds a driver for the SPI based AT86RF215 transceiver. The chip supports the IEEE Std 802.15.4-2015 and IEEE Std 802.15.4g-2012 standard. This driver supports two versions of the chip: - AT86RF215: dual sub-GHz & 2.4 GHz radio & baseband - AT86RF215M: sub-GHz radio & baseband only Both radios support the following PHY modes: - MR-FSK - MR-OFDM - MR-O-QPKS - O-QPSK (legacy) The driver currently only implements support for legacy O-QPSK. To use both interfaces, add GNRC_NETIF_NUMOF := 2 to your Makefile. The transceiver is able to send frames of up to 2047 bytes according to IEEE 802.15.4g-2012 when operating in non-legacy mode. Known issues: - [ ] dBm setting values are bogus - [ ] Channel spacing for sub-GHz MR-O-QPSK might be wrong - [ ] TX/RX stress test will lock up the driver on openmote-b --- CODEOWNERS | 1 + drivers/Makefile.dep | 23 +- drivers/Makefile.include | 4 + drivers/at86rf215/Makefile | 1 + drivers/at86rf215/at86rf215.c | 342 ++ drivers/at86rf215/at86rf215_getset.c | 333 ++ drivers/at86rf215/at86rf215_internal.c | 204 + drivers/at86rf215/at86rf215_netdev.c | 936 ++++ drivers/at86rf215/at86rf215_o-qpsk.c | 277 + .../at86rf215/include/at86rf215_internal.h | 401 ++ drivers/at86rf215/include/at86rf215_netdev.h | 39 + drivers/at86rf215/include/at86rf215_params.h | 72 + .../at86rf215/include/at86rf215_registers.h | 618 +++ drivers/at86rf215/include/vendor/at86rf215.h | 4722 +++++++++++++++++ drivers/include/at86rf215.h | 429 ++ makefiles/pseudomodules.inc.mk | 1 + .../netif/init_devs/auto_init_at86rf215.c | 122 + sys/net/gnrc/netif/init_devs/init.c | 5 + 18 files changed, 8529 insertions(+), 1 deletion(-) create mode 100644 drivers/at86rf215/Makefile create mode 100644 drivers/at86rf215/at86rf215.c create mode 100644 drivers/at86rf215/at86rf215_getset.c create mode 100644 drivers/at86rf215/at86rf215_internal.c create mode 100644 drivers/at86rf215/at86rf215_netdev.c create mode 100644 drivers/at86rf215/at86rf215_o-qpsk.c create mode 100644 drivers/at86rf215/include/at86rf215_internal.h create mode 100644 drivers/at86rf215/include/at86rf215_netdev.h create mode 100644 drivers/at86rf215/include/at86rf215_params.h create mode 100644 drivers/at86rf215/include/at86rf215_registers.h create mode 100644 drivers/at86rf215/include/vendor/at86rf215.h create mode 100644 drivers/include/at86rf215.h create mode 100644 sys/net/gnrc/netif/init_devs/auto_init_at86rf215.c diff --git a/CODEOWNERS b/CODEOWNERS index dbb1f6457d..0fca3071f0 100644 --- a/CODEOWNERS +++ b/CODEOWNERS @@ -62,6 +62,7 @@ /drivers/ad7746/ @leandrolanzieri /drivers/at24mac/ @benpicco +/drivers/at86rf215/ @benpicco /drivers/at86rf2xx/ @daniel-k @Hyungsin @jia200x @smlng @miri64 /drivers/bh1900nux/ @wosym /drivers/cc110x/ @maribu diff --git a/drivers/Makefile.dep b/drivers/Makefile.dep index e8d4d2e8c5..0831a132fa 100644 --- a/drivers/Makefile.dep +++ b/drivers/Makefile.dep @@ -51,9 +51,30 @@ ifneq (,$(filter at30tse75x,$(USEMODULE))) FEATURES_REQUIRED += periph_i2c endif -ifneq (,$(filter at86rf%,$(USEMODULE))) +ifneq (,$(filter at86rf215%,$(USEMODULE))) + USEMODULE += at86rf215 + DEFAULT_MODULE += auto_init_at86rf215 + DEFAULT_MODULE += at86rf215_subghz + + ifeq (,$(filter at86rf215m,$(USEMODULE))) + DEFAULT_MODULE += at86rf215_24ghz + endif + + FEATURES_REQUIRED += periph_gpio + FEATURES_REQUIRED += periph_gpio_irq + FEATURES_REQUIRED += periph_spi + + USEMODULE += xtimer + USEMODULE += luid + USEMODULE += netif + USEMODULE += ieee802154 + USEMODULE += netdev_ieee802154 +endif + +ifneq (,$(filter at86rf%, $(filter-out at86rf215%, $(USEMODULE)))) USEMODULE += at86rf2xx DEFAULT_MODULE += auto_init_at86rf2xx + USEMODULE += xtimer USEMODULE += luid USEMODULE += netif diff --git a/drivers/Makefile.include b/drivers/Makefile.include index 576f964adb..b4b806e675 100644 --- a/drivers/Makefile.include +++ b/drivers/Makefile.include @@ -32,6 +32,10 @@ ifneq (,$(filter at86rf2xx,$(USEMODULE))) USEMODULE_INCLUDES += $(RIOTBASE)/drivers/at86rf2xx/include endif +ifneq (,$(filter at86rf215,$(USEMODULE))) + USEMODULE_INCLUDES += $(RIOTBASE)/drivers/at86rf215/include +endif + ifneq (,$(filter ata8520e,$(USEMODULE))) USEMODULE_INCLUDES += $(RIOTBASE)/drivers/ata8520e/include endif diff --git a/drivers/at86rf215/Makefile b/drivers/at86rf215/Makefile new file mode 100644 index 0000000000..48422e909a --- /dev/null +++ b/drivers/at86rf215/Makefile @@ -0,0 +1 @@ +include $(RIOTBASE)/Makefile.base diff --git a/drivers/at86rf215/at86rf215.c b/drivers/at86rf215/at86rf215.c new file mode 100644 index 0000000000..bb604cc770 --- /dev/null +++ b/drivers/at86rf215/at86rf215.c @@ -0,0 +1,342 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Implementation of public functions for AT86RF215 driver + * + * @author Benjamin Valentin + * @} + */ + + +#include "luid.h" +#include "byteorder.h" +#include "net/ieee802154.h" +#include "net/gnrc.h" +#include "unaligned.h" +#include "at86rf215_internal.h" +#include "at86rf215_netdev.h" + +#define ENABLE_DEBUG (0) +#include "debug.h" + +static void _setup_interface(at86rf215_t *dev, const at86rf215_params_t *params) +{ + netdev_t *netdev = (netdev_t *)dev; + + netdev->driver = &at86rf215_driver; + dev->params = *params; + dev->state = AT86RF215_STATE_OFF; +} + +void at86rf215_setup(at86rf215_t *dev_09, at86rf215_t *dev_24, const at86rf215_params_t *params) +{ + /* configure the sub-GHz interface */ + if (dev_09) { + dev_09->RF = &RF09_regs; + dev_09->BBC = &BBC0_regs; + _setup_interface(dev_09, params); + dev_09->sibling = dev_24; + } + + /* configure the 2.4 GHz interface */ + if (dev_24) { + dev_24->RF = &RF24_regs; + dev_24->BBC = &BBC1_regs; + _setup_interface(dev_24, params); + dev_24->sibling = dev_09; + } +} + +void at86rf215_reset_and_cfg(at86rf215_t *dev) +{ + netdev_ieee802154_reset(&dev->netdev); + + /* set device address */ + luid_get_short((network_uint16_t *)&dev->netdev.short_addr); + luid_get_eui64((eui64_t *)&dev->netdev.long_addr); + + if (is_subGHz(dev)) { + dev->netdev.chan = AT86RF215_DEFAULT_SUBGHZ_CHANNEL; + } else { + dev->netdev.chan = AT86RF215_DEFAULT_CHANNEL; + } + + dev->netdev.pan = IEEE802154_DEFAULT_PANID; + + /* set default options */ + dev->retries_max = AT86RF215_RETRIES_MAX_DEFAULT; + dev->csma_retries_max = AT86RF215_CSMA_RETRIES_MAX_DEFAULT; + dev->csma_maxbe = AT86RF215_CSMA_MAX_BE_DEFAULT; + dev->csma_minbe = AT86RF215_CSMA_MIN_BE_DEFAULT; + + dev->flags |= AT86RF215_OPT_AUTOACK + | AT86RF215_OPT_CSMA; + + /* apply the configuration */ + at86rf215_reset(dev); + + /* default to requesting ACKs, just like at86rf2xx */ + const netopt_enable_t enable = NETOPT_ENABLE; + netdev_ieee802154_set(&dev->netdev, NETOPT_ACK_REQ, &enable, sizeof(enable)); +} + +void at86rf215_reset(at86rf215_t *dev) +{ + uint8_t reg; + dev->state = AT86RF215_STATE_OFF; + + /* Reset state machine to ensure a known state */ + at86rf215_rf_cmd(dev, CMD_RF_TRXOFF); + at86rf215_await_state(dev, RF_STATE_TRXOFF); + + if (!dev->sibling) { + /* disable 2.4-GHz IRQs if the interface is not enabled */ + if (is_subGHz(dev)) { + at86rf215_reg_write(dev, RG_BBC1_IRQM, 0); + at86rf215_reg_write(dev, RG_RF24_IRQM, 0); + at86rf215_reg_write(dev, RG_RF24_CMD, CMD_RF_SLEEP); + + /* disable sub-GHz IRQs if the interface is not enabled */ + } else { + at86rf215_reg_write(dev, RG_BBC0_IRQM, 0); + at86rf215_reg_write(dev, RG_RF09_IRQM, 0); + at86rf215_reg_write(dev, RG_RF09_CMD, CMD_RF_SLEEP); + } + } + + /* disable clock output */ +#if AT86RF215_USE_CLOCK_OUTPUT == 0 + at86rf215_reg_write(dev, RG_RF_CLKO, 0); +#endif + + /* allow to configure board-specific trim */ +#ifdef AT86RF215_TRIM_VAL + at86rf215_reg_write(dev, RG_RF_XOC, AT86RF215_TRIM_VAL | XOC_FS_MASK); +#endif + + /* enable TXFE & RXFE IRQ */ + at86rf215_reg_write(dev, dev->BBC->RG_IRQM, BB_IRQ_TXFE | BB_IRQ_RXFE); + + /* enable EDC IRQ */ + at86rf215_reg_write(dev, dev->RF->RG_IRQM, RF_IRQ_EDC | RF_IRQ_TRXRDY); + + /* set energy detect threshold to -84 dBm */ + at86rf215_set_cca_threshold(dev, AT86RF215_EDT_DEFAULT); + + /* enable address filter 0 */ + at86rf215_reg_write(dev, dev->BBC->RG_AFC0, AFC0_AFEN0_MASK ); + at86rf215_reg_write(dev, dev->BBC->RG_AMAACKPD, AMAACKPD_PD0_MASK); + + /* enable auto-ACK with Frame Checksum & Data Rate derived from RX frame */ + reg = AMCS_AACKFA_MASK | AMCS_AACKDR_MASK; + if (dev->flags & AT86RF215_OPT_AUTOACK) { + reg |= AMCS_AACK_MASK; + } + + at86rf215_reg_write(dev, dev->BBC->RG_AMCS, reg); + + /* set compatibility with first-gen 802.15.4 devices */ + at86rf215_configure_legacy_OQPSK(dev, 0); + + /* set default channel */ + at86rf215_set_chan(dev, dev->netdev.chan); + + /* set short and long address */ + uint64_t long_addr; + memcpy(&long_addr, dev->netdev.long_addr, sizeof(long_addr)); + at86rf215_set_addr_long(dev, long_addr); + at86rf215_set_addr_short(dev, 0, unaligned_get_u16(dev->netdev.short_addr)); + + /* set default PAN id */ + at86rf215_set_pan(dev, 0, dev->netdev.pan); + + /* set default TX power */ + at86rf215_set_txpower(dev, AT86RF215_DEFAULT_TXPOWER); + + /* start listening for incoming packets */ + at86rf215_rf_cmd(dev, CMD_RF_RX); + at86rf215_await_state(dev, RF_STATE_RX); + + dev->state = AT86RF215_STATE_IDLE; +} + +ssize_t at86rf215_send(at86rf215_t *dev, const void *data, size_t len) +{ + /* check data length */ + if (len > AT86RF215_MAX_PKT_LENGTH) { + DEBUG("[at86rf215] Error: data to send exceeds max packet size\n"); + return -EOVERFLOW; + } + + if (at86rf215_tx_prepare(dev)) { + return -EBUSY; + } + + at86rf215_tx_load(dev, data, len, 0); + at86rf215_tx_exec(dev); + return len; +} + +void at86rf215_tx_done(at86rf215_t *dev) +{ + uint8_t amcs = at86rf215_reg_read(dev, dev->BBC->RG_AMCS); + + /* re-enable AACK, disable TX2RX */ + amcs &= ~AMCS_TX2RX_MASK; + if (dev->flags & AT86RF215_OPT_AUTOACK) { + amcs |= AMCS_AACK_MASK; + } + + at86rf215_reg_write(dev, dev->BBC->RG_AMCS, amcs); +} + +static bool _tx_ongoing(at86rf215_t *dev) +{ + if (dev->flags & AT86RF215_OPT_TX_PENDING) { + return true; + } + + if (dev->state == AT86RF215_STATE_TX || + dev->state == AT86RF215_STATE_TX_WAIT_ACK) { + return true; + } + + return false; +} + +/* + * As there is no packet queue in RIOT we have to block in send() + * when the device is busy sending a previous frame. + * + * Since both _send() and _isr() are running in the same thread + * we have to service radio events while waiting in order to + * advance the previous transmission. + */ +static void _block_while_busy(at86rf215_t *dev) +{ + gpio_irq_disable(dev->params.int_pin); + + do { + if (gpio_read(dev->params.int_pin) || dev->timeout) { + at86rf215_driver.isr((netdev_t *) dev); + } + /* allow the other interface to process events */ + thread_yield(); + } while (_tx_ongoing(dev)); + + gpio_irq_enable(dev->params.int_pin); +} + +void at86rf215_block_while_busy(at86rf215_t *dev) +{ + if (_tx_ongoing(dev)) { + DEBUG("[at86rf215] Block while TXing\n"); + _block_while_busy(dev); + } +} + +int at86rf215_tx_prepare(at86rf215_t *dev) +{ + if (dev->state == AT86RF215_STATE_SLEEP) { + return -EAGAIN; + } + + at86rf215_block_while_busy(dev); + dev->tx_frame_len = IEEE802154_FCS_LEN; + + return 0; +} + +size_t at86rf215_tx_load(at86rf215_t *dev, const uint8_t *data, + size_t len, size_t offset) +{ + /* set bit if ACK was requested and retransmission is enabled */ + if (offset == 0 && (data[0] & IEEE802154_FCF_ACK_REQ) && dev->retries_max) { + dev->flags |= AT86RF215_OPT_ACK_REQUESTED; + } + + at86rf215_reg_write_bytes(dev, dev->BBC->RG_FBTXS + offset, data, len); + dev->tx_frame_len += (uint16_t) len; + + return offset + len; +} + +int at86rf215_tx_exec(at86rf215_t *dev) +{ + /* write frame length */ + at86rf215_reg_write16(dev, dev->BBC->RG_TXFLL, dev->tx_frame_len); + + dev->retries = dev->retries_max; + dev->csma_retries = dev->csma_retries_max; + + dev->flags |= AT86RF215_OPT_TX_PENDING; + + if ((dev->flags & AT86RF215_OPT_CSMA) && !(dev->flags & AT86RF215_OPT_CCATX)) { + dev->flags |= AT86RF215_OPT_CCA_PENDING; + } + + if (dev->state == AT86RF215_STATE_IDLE) { + at86rf215_rf_cmd(dev, CMD_RF_TXPREP); + } else { + DEBUG("[at86rf215] will TX after %s\n", at86rf215_sw_state2a(dev->state)); + } + + return 0; +} + +void at86rf215_tx_abort(at86rf215_t *dev) +{ + dev->flags &= ~(AT86RF215_OPT_CCA_PENDING | AT86RF215_OPT_TX_PENDING); + + at86rf215_tx_done(dev); + at86rf215_enable_baseband(dev); + at86rf215_rf_cmd(dev, CMD_RF_RX); + + dev->state = AT86RF215_STATE_IDLE; +} + +bool at86rf215_cca(at86rf215_t *dev) +{ + bool clear; + uint8_t old_state; + + if (dev->state != AT86RF215_STATE_IDLE) { + return false; + } + + if (dev->flags & AT86RF215_OPT_TX_PENDING) { + return false; + } + + if (!at86rf215_set_rx_from_idle(dev, &old_state)) { + return false; + } + + /* disable ED IRQ, baseband */ + at86rf215_reg_and(dev, dev->RF->RG_IRQM, ~(RF_IRQ_EDC | RF_IRQ_TRXRDY)); + at86rf215_reg_and(dev, dev->BBC->RG_PC, ~PC_BBEN_MASK); + + /* start energy detect */ + at86rf215_reg_write(dev, dev->RF->RG_EDC, RF_EDSINGLE); + while (!(at86rf215_reg_read(dev, dev->RF->RG_IRQS) & RF_IRQ_EDC)) {} + + clear = !(at86rf215_reg_read(dev, dev->BBC->RG_AMCS) & AMCS_CCAED_MASK); + + /* enable ED IRQ, baseband */ + at86rf215_reg_or(dev, dev->RF->RG_IRQM, RF_IRQ_EDC | RF_IRQ_TRXRDY); + at86rf215_reg_or(dev, dev->BBC->RG_PC, PC_BBEN_MASK); + + at86rf215_set_idle_from_rx(dev, old_state); + + return clear; +} diff --git a/drivers/at86rf215/at86rf215_getset.c b/drivers/at86rf215/at86rf215_getset.c new file mode 100644 index 0000000000..9016340916 --- /dev/null +++ b/drivers/at86rf215/at86rf215_getset.c @@ -0,0 +1,333 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Getter and setter functions for the AT86RF215 driver + * + * @author Benjamin Valentin + * @} + */ + +#include + +#include "at86rf215.h" +#include "at86rf215_internal.h" +#include "periph/spi.h" + +#define ENABLE_DEBUG (0) +#include "debug.h" + +/* we can still go +3 dBm higher by increasing PA current */ +#define PAC_DBM_MIN (-31) /* dBm */ + +uint16_t at86rf215_get_addr_short(const at86rf215_t *dev, uint8_t filter) +{ + if (filter > 3) { + return 0; + } + + /* Each frame filter has a 2 byte short addr + 2 byte PAN ID, so we have to + skip 4 bytes per filter */ + return ntohs(at86rf215_reg_read16(dev, dev->BBC->RG_MACSHA0F0 + (4 * filter))); +} + +void at86rf215_set_addr_short(at86rf215_t *dev, uint8_t filter, uint16_t addr) +{ + /* do not overwrite node address for filters other than 0 */ + if (filter == 0) { + dev->netdev.short_addr[0] = (uint8_t)(addr); + dev->netdev.short_addr[1] = (uint8_t)(addr >> 8); + } + + if (filter > 3) { + return; + } + + at86rf215_reg_write16(dev, dev->BBC->RG_MACSHA0F0 + (4 * filter), htons(addr)); +} + +bool at86rf215_get_framefilter_enabled(at86rf215_t *dev, uint8_t filter) +{ + return (at86rf215_reg_read(dev, dev->BBC->RG_AFC0) >> (AFC0_AFEN0_SHIFT + filter)) & 1; +} + +void at86rf215_enable_framefilter(at86rf215_t *dev, uint8_t filter) +{ + at86rf215_reg_or(dev, dev->BBC->RG_AFC0, 1 << (AFC0_AFEN0_SHIFT + filter)); +} + +void at86rf215_disable_framefilter(at86rf215_t *dev, uint8_t filter) +{ + at86rf215_reg_and(dev, dev->BBC->RG_AFC0, 1 << (AFC0_AFEN0_SHIFT + filter)); +} + +uint64_t at86rf215_get_addr_long(const at86rf215_t *dev) +{ + uint64_t addr; + at86rf215_reg_read_bytes(dev, dev->BBC->RG_MACEA0, &addr, sizeof(addr)); + return addr; +} + +void at86rf215_set_addr_long(at86rf215_t *dev, uint64_t addr) +{ + memcpy(dev->netdev.long_addr, &addr, sizeof(addr)); + addr = ntohll(addr); + at86rf215_reg_write_bytes(dev, dev->BBC->RG_MACEA0, &addr, sizeof(addr)); +} + +uint8_t at86rf215_get_chan(const at86rf215_t *dev) +{ + return at86rf215_reg_read16(dev, dev->RF->RG_CNL); +} + +void at86rf215_set_chan(at86rf215_t *dev, uint16_t channel) +{ + at86rf215_await_state_end(dev, RF_STATE_TX); + + uint8_t old_state = at86rf215_get_rf_state(dev); + + /* frequency has to be updated in TRXOFF or TXPREP (datatsheet: 6.3.2) */ + if (old_state == RF_STATE_RX) { + at86rf215_rf_cmd(dev, CMD_RF_TXPREP); + } + + at86rf215_reg_write16(dev, dev->RF->RG_CNL, channel); + dev->netdev.chan = channel; + + /* enable the radio again */ + if (old_state == RF_STATE_RX) { + at86rf215_rf_cmd(dev, old_state); + } +} + +uint16_t at86rf215_get_channel_spacing(at86rf215_t *dev) { + /* 25 kHz resolution */ + return 25 * at86rf215_reg_read(dev, dev->RF->RG_CS); +} + +uint16_t at86rf215_get_pan(const at86rf215_t *dev, uint8_t filter) +{ + if (filter > 3) { + return 0; + } + + return at86rf215_reg_read16(dev, dev->BBC->RG_MACPID0F0 + (4 * filter)); +} + +void at86rf215_set_pan(at86rf215_t *dev, uint8_t filter, uint16_t pan) +{ + if (filter == 0) { + dev->netdev.pan = pan; + } + + if (filter > 3) { + return; + } + + at86rf215_reg_write16(dev, dev->BBC->RG_MACPID0F0 + (4 * filter), pan); +} + +// TODO: take modulation into account +int16_t at86rf215_get_txpower(const at86rf215_t *dev) +{ + uint8_t pac = at86rf215_reg_read(dev, dev->RF->RG_PAC); + + /* almost linear, each PACUR step adds ~1 dBm */ + return PAC_DBM_MIN + (pac & PAC_TXPWR_MASK) + + ((pac & PAC_PACUR_MASK) >> PAC_PACUR_SHIFT); +} + +// TODO: take modulation into account +void at86rf215_set_txpower(const at86rf215_t *dev, int16_t txpower) +{ + uint8_t pacur = 0; + + txpower -= PAC_DBM_MIN; + + if (txpower < 0) { + txpower = 0; + } + + if (txpower > PAC_TXPWR_MASK) { + switch (txpower - PAC_TXPWR_MASK) { + case 1: + pacur = 1 << PAC_PACUR_SHIFT; + break; + case 2: + pacur = 2 << PAC_PACUR_SHIFT; + break; + default: + pacur = 3 << PAC_PACUR_SHIFT; + break; + } + + txpower = PAC_TXPWR_MASK; + } + + at86rf215_reg_write(dev, dev->RF->RG_PAC, pacur | txpower); +} + +int8_t at86rf215_get_cca_threshold(const at86rf215_t *dev) +{ + return dev->csma_ed; +} + +void at86rf215_set_cca_threshold(at86rf215_t *dev, int8_t value) +{ + dev->csma_ed = value; + at86rf215_reg_write(dev, dev->BBC->RG_AMEDT, value); +} + +int8_t at86rf215_get_ed_level(at86rf215_t *dev) +{ + return at86rf215_reg_read(dev, dev->RF->RG_EDV); +} + +void at86rf215_set_option(at86rf215_t *dev, uint16_t option, bool state) +{ + /* set option field */ + dev->flags = (state) ? (dev->flags | option) + : (dev->flags & ~option); + + switch (option) { + case AT86RF215_OPT_TELL_RX_START: + if (state) { + at86rf215_reg_or(dev, dev->BBC->RG_IRQM, BB_IRQ_RXAM); + } else { + at86rf215_reg_and(dev, dev->BBC->RG_IRQM, ~BB_IRQ_RXAM); + } + + break; + case AT86RF215_OPT_PROMISCUOUS: + if (state) { + at86rf215_reg_or(dev, dev->BBC->RG_AFC0, AFC0_PM_MASK); + } else { + at86rf215_reg_and(dev, dev->BBC->RG_AFC0, ~AFC0_PM_MASK); + } + + break; + case AT86RF215_OPT_AUTOACK: + if (state) { + at86rf215_reg_or(dev, dev->BBC->RG_AMCS, AMCS_AACK_MASK); + } else { + at86rf215_reg_and(dev, dev->BBC->RG_AMCS, ~AMCS_AACK_MASK); + } + + break; + case AT86RF215_OPT_CCATX: + if (state){ + at86rf215_reg_or(dev, dev->BBC->RG_AMCS, AMCS_CCATX_MASK); + } else { + at86rf215_reg_and(dev, dev->BBC->RG_AMCS, ~AMCS_CCATX_MASK); + } + + break; + + default: + /* do nothing */ + break; + } +} + +static void _wake_from_sleep(at86rf215_t *dev) +{ + /* wake the transceiver */ + at86rf215_rf_cmd(dev, CMD_RF_TRXOFF); + at86rf215_await_state(dev, RF_STATE_TRXOFF); + + /* config is lost after SLEEP */ + at86rf215_reset(dev); + + /* if both transceivers were sleeping, the chip entered DEEP_SLEEP. + Waking one device in that mode wakes the other one too. */ + if (dev->sibling && dev->sibling->state == AT86RF215_STATE_SLEEP) { + at86rf215_rf_cmd(dev->sibling, CMD_RF_SLEEP); + } +} + +bool at86rf215_set_rx_from_idle(at86rf215_t *dev, uint8_t *state) +{ + if (dev->state == AT86RF215_STATE_SLEEP) { + _wake_from_sleep(dev); + } + + uint8_t s; + while ((s = at86rf215_get_rf_state(dev)) == RF_STATE_TRANSITION) {} + + if (state) { + *state = s; + } + + if (s == RF_STATE_RESET) { + at86rf215_rf_cmd(dev, CMD_RF_TRXOFF); + at86rf215_await_state(dev, RF_STATE_TRXOFF); + s = RF_STATE_TRXOFF; + } + + if (s == RF_STATE_TRXOFF) { + at86rf215_rf_cmd(dev, CMD_RF_RX); + at86rf215_await_state(dev, RF_STATE_RX); + s = RF_STATE_RX; + } + + if (s == RF_STATE_RX) { + return true; + } + + return false; +} + +bool at86rf215_set_idle_from_rx(at86rf215_t *dev, uint8_t state) +{ + if (state == RF_STATE_TX || state == CMD_RF_TXPREP) { + return false; + } + + if (dev->state == AT86RF215_STATE_SLEEP) { + if (state == CMD_RF_SLEEP) { + return true; + } + + _wake_from_sleep(dev); + } + + uint8_t s; + while ((s = at86rf215_get_rf_state(dev)) == RF_STATE_TRANSITION) {} + + if (s != RF_STATE_RX) { + return false; + } + + if (state == RF_STATE_RX) { + return true; + } + + at86rf215_rf_cmd(dev, CMD_RF_TRXOFF); + at86rf215_await_state(dev, RF_STATE_TRXOFF); + + if (state == RF_STATE_TRXOFF) { + return true; + } + + /* clear IRQ */ + at86rf215_reg_read(dev, dev->BBC->RG_IRQS); + at86rf215_reg_read(dev, dev->RF->RG_IRQS); + at86rf215_rf_cmd(dev, CMD_RF_SLEEP); + + dev->state = AT86RF215_STATE_SLEEP; + + if (state == RF_STATE_RESET) { + return true; + } + + return false; +} diff --git a/drivers/at86rf215/at86rf215_internal.c b/drivers/at86rf215/at86rf215_internal.c new file mode 100644 index 0000000000..f396cdebea --- /dev/null +++ b/drivers/at86rf215/at86rf215_internal.c @@ -0,0 +1,204 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Low-Level functions for the AT86RF215 driver + * + * @author Benjamin Valentin + * @} + */ + +#include "periph/spi.h" +#include "periph/gpio.h" +#include "xtimer.h" +#include "at86rf215_internal.h" + +#include + +#define SPIDEV (dev->params.spi) +#define CSPIN (dev->params.cs_pin) + +static inline void getbus(const at86rf215_t *dev) +{ + spi_acquire(SPIDEV, CSPIN, SPI_MODE_0, dev->params.spi_clk); +} + +/* only to be used by at86rf215_hardware_reset() + can't use normal at86rf215_reg_read() because + we already hold the lock */ +static inline uint8_t _get_reg_with_lock(at86rf215_t *dev, uint16_t r) +{ + uint16_t reg = htons(r | FLAG_READ); + spi_transfer_bytes(SPIDEV, CSPIN, true, ®, NULL, sizeof(reg)); + return spi_transfer_byte(SPIDEV, CSPIN, false, 0); +} + +int at86rf215_hardware_reset(at86rf215_t *dev) +{ + /* prevent access during reset */ + getbus(dev); + + /* trigger hardware reset */ + gpio_clear(dev->params.reset_pin); + xtimer_usleep(AT86RF215_RESET_PULSE_WIDTH_US); + gpio_set(dev->params.reset_pin); + xtimer_usleep(AT86RF215_RESET_DELAY_US); + + uint8_t state = _get_reg_with_lock(dev, dev->RF->RG_STATE) & STATE_STATE_MASK; + if (state != RF_STATE_TRXOFF && state != RF_STATE_RESET) { + spi_release(SPIDEV); + return -ENODEV; + } + + /* While the device is in RESET / DEEP SLEEP, all registers + but STATE will read 0xFF. + WAKEUP IRQ signals that the device is ready. */ + state = 0; + while (state == 0xFF || !(state & IRQS_WAKEUP_MASK)) { + state = _get_reg_with_lock(dev, dev->RF->RG_IRQS); + } + + spi_release(SPIDEV); + + /* clear interrupts */ + at86rf215_reg_read(dev, RG_RF09_IRQS); + at86rf215_reg_read(dev, RG_RF24_IRQS); + at86rf215_reg_read(dev, RG_BBC0_IRQS); + at86rf215_reg_read(dev, RG_BBC1_IRQS); + + return 0; +} + +void at86rf215_reg_write(const at86rf215_t *dev, uint16_t reg, uint8_t value) +{ + reg = htons(reg | FLAG_WRITE); + + getbus(dev); + spi_transfer_bytes(SPIDEV, CSPIN, true, ®, NULL, sizeof(reg)); + spi_transfer_byte(SPIDEV, CSPIN, false, value); + spi_release(SPIDEV); +} + +void at86rf215_reg_write_bytes(const at86rf215_t *dev, uint16_t reg, const void *data, size_t len) +{ + reg = htons(reg | FLAG_WRITE); + + getbus(dev); + spi_transfer_bytes(SPIDEV, CSPIN, true, ®, NULL, sizeof(reg)); + spi_transfer_bytes(SPIDEV, CSPIN, false, data, NULL, len); + spi_release(SPIDEV); +} + +uint8_t at86rf215_reg_read(const at86rf215_t *dev, uint16_t reg) +{ + uint8_t val; + + reg = htons(reg | FLAG_READ); + + getbus(dev); + spi_transfer_bytes(SPIDEV, CSPIN, true, ®, NULL, sizeof(reg)); + val = spi_transfer_byte(SPIDEV, CSPIN, false, 0); + spi_release(SPIDEV); + + return val; +} + +void at86rf215_reg_read_bytes(const at86rf215_t *dev, uint16_t reg, void *data, size_t len) +{ + reg = htons(reg | FLAG_READ); + + getbus(dev); + spi_transfer_bytes(SPIDEV, CSPIN, true, ®, NULL, sizeof(reg)); + spi_transfer_bytes(SPIDEV, CSPIN, false, NULL, data, len); + spi_release(SPIDEV); +} + +void at86rf215_filter_ack(at86rf215_t *dev, bool on) +{ + /* only listen for ACK frames */ + uint8_t val = on ? (1 << IEEE802154_FCF_TYPE_ACK) + : (1 << IEEE802154_FCF_TYPE_BEACON) + | (1 << IEEE802154_FCF_TYPE_DATA) + | (1 << IEEE802154_FCF_TYPE_MACCMD); + + at86rf215_reg_write(dev, dev->BBC->RG_AFFTM, val); +} + +void at86rf215_get_random(at86rf215_t *dev, void *data, size_t len) +{ + /* store previous PHY control state */ + uint8_t state_pc = at86rf215_reg_read(dev, dev->BBC->RG_PC); + + /* disable baseband processor */ + at86rf215_reg_write(dev, dev->BBC->RG_PC, state_pc & ~PC_BBEN_MASK); + + /* store previous RX bandwidth settings */ + uint8_t rxbwc = at86rf215_reg_read(dev, dev->RF->RG_RXBWC); + + /* The analog frontend of the radio must be configured to the + widest filter bandwidth; The bit RXBWC.IFS must be set to 1 */ + at86rf215_reg_write(dev, dev->RF->RG_RXBWC, 0x1B); + + uint8_t *data8 = data; + while (len--) { + *data8++ = at86rf215_reg_read(dev, dev->RF->RG_RNDV); + } + + /* restore RX bandwidth settings */ + at86rf215_reg_write(dev, dev->RF->RG_RXBWC, rxbwc); + + /* restore PHY control settings */ + at86rf215_reg_write(dev, dev->BBC->RG_PC, state_pc); + +} + +uint16_t at86rf215_chan_valid(at86rf215_t *dev, uint16_t chan) +{ + if (is_subGHz(dev)) { + if (chan >= dev->num_chans) { + return dev->num_chans - 1; + } + } else { + if (chan < IEEE802154_CHANNEL_MIN) { + return IEEE802154_CHANNEL_MIN; + } else if (chan >= IEEE802154_CHANNEL_MIN + dev->num_chans) { + return IEEE802154_CHANNEL_MIN + dev->num_chans - 1; + } + } + + return chan; +} + +const char* at86rf215_hw_state2a(uint8_t state) +{ + switch (state) { + case RF_STATE_TRXOFF: return "TRXOFF"; + case RF_STATE_TXPREP: return "TXPREP"; + case RF_STATE_TX: return "TX"; + case RF_STATE_RX: return "RX"; + case RF_STATE_TRANSITION: return "TRANSITION"; + case RF_STATE_RESET: return "RESET"; + default: return "invalid"; + } +} + +const char* at86rf215_sw_state2a(at86rf215_state_t state) { + switch (state) { + case AT86RF215_STATE_OFF: return "OFF"; + case AT86RF215_STATE_IDLE: return "IDLE"; + case AT86RF215_STATE_RX_SEND_ACK: return "RX (sending ACK)"; + case AT86RF215_STATE_TX: return "TX"; + case AT86RF215_STATE_TX_WAIT_ACK: return "TX (wait for ACK)"; + case AT86RF215_STATE_SLEEP: return "SLEEP"; + default: return "invalid"; + } +} diff --git a/drivers/at86rf215/at86rf215_netdev.c b/drivers/at86rf215/at86rf215_netdev.c new file mode 100644 index 0000000000..00e493dd65 --- /dev/null +++ b/drivers/at86rf215/at86rf215_netdev.c @@ -0,0 +1,936 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Netdev adaption for the AT86RF215 driver + * + * @author Benjamin Valentin + * @author Georg von Zengen + * @} + */ + +#include +#include +#include + +#include "iolist.h" + +#include "net/eui64.h" +#include "net/ieee802154.h" +#include "net/netdev.h" +#include "net/netdev/ieee802154.h" +#include "net/gnrc/netif/internal.h" + +#include "at86rf215.h" +#include "at86rf215_netdev.h" +#include "at86rf215_internal.h" + +#include "debug.h" + +static int _send(netdev_t *netdev, const iolist_t *iolist); +static int _recv(netdev_t *netdev, void *buf, size_t len, void *info); +static int _init(netdev_t *netdev); +static void _isr(netdev_t *netdev); +static int _get(netdev_t *netdev, netopt_t opt, void *val, size_t max_len); +static int _set(netdev_t *netdev, netopt_t opt, const void *val, size_t len); + +const netdev_driver_t at86rf215_driver = { + .send = _send, + .recv = _recv, + .init = _init, + .isr = _isr, + .get = _get, + .set = _set, +}; + +/* executed in the GPIO ISR context */ +static void _irq_handler(void *arg) +{ + netdev_t *netdev = (netdev_t *) arg; + + netdev->event_callback(netdev, NETDEV_EVENT_ISR); +} + +/* if only one interface is active, but the other one to sleep */ +static inline void _put_sibling_to_sleep(at86rf215_t *dev) { + if (is_subGHz(dev)) { + at86rf215_reg_write(dev, RG_RF24_CMD, CMD_RF_SLEEP); + } else { + at86rf215_reg_write(dev, RG_RF09_CMD, CMD_RF_SLEEP); + } +} + +static int _init(netdev_t *netdev) +{ + int res; + at86rf215_t *dev = (at86rf215_t *)netdev; + + /* don't call HW init for both radios */ + if (is_subGHz(dev) || dev->sibling == NULL) { + /* initialize GPIOs */ + spi_init_cs(dev->params.spi, dev->params.cs_pin); + gpio_init(dev->params.reset_pin, GPIO_OUT); + gpio_set(dev->params.reset_pin); + + /* reset the entire chip */ + if ((res = at86rf215_hardware_reset(dev))) { + return res; + } + + /* turn off unused interface */ + if (dev->sibling == NULL) { + _put_sibling_to_sleep(dev); + } + + gpio_init_int(dev->params.int_pin, GPIO_IN, GPIO_RISING, _irq_handler, dev); + } + + res = at86rf215_reg_read(dev, RG_RF_PN); + if ((res != AT86RF215_PN) && (res != AT86RF215M_PN)) { + DEBUG("[at86rf215] error: unable to read correct part number: %x\n", res); + return -ENOTSUP;; + } + + /* reset device to default values and put it into RX state */ + at86rf215_reset_and_cfg(dev); + + return 0; +} + +static int _send(netdev_t *netdev, const iolist_t *iolist) +{ + at86rf215_t *dev = (at86rf215_t *)netdev; + size_t len = 0; + + if (at86rf215_tx_prepare(dev)) { + return -EBUSY; + } + + /* load packet data into FIFO */ + for (const iolist_t *iol = iolist; iol; iol = iol->iol_next) { + + /* current packet data + FCS too long */ + if ((len + iol->iol_len + IEEE802154_FCS_LEN) > AT86RF215_MAX_PKT_LENGTH) { + DEBUG("[at86rf215] error: packet too large (%u byte) to be send\n", + (unsigned)len + IEEE802154_FCS_LEN); + at86rf215_tx_abort(dev); + return -EOVERFLOW; + } + + if (iol->iol_len) { + len = at86rf215_tx_load(dev, iol->iol_base, iol->iol_len, len); + } + } + + /* send data out directly if pre-loading id disabled */ + if (!(dev->flags & AT86RF215_OPT_PRELOADING)) { + at86rf215_tx_exec(dev); + } + + /* return the number of bytes that were actually loaded into the frame + * buffer/send out */ + return (int)len; +} + +static int _recv(netdev_t *netdev, void *buf, size_t len, void *info) +{ + at86rf215_t *dev = (at86rf215_t *)netdev; + int16_t pkt_len; + + /* get the size of the received packet */ + at86rf215_reg_read_bytes(dev, dev->BBC->RG_RXFLL, &pkt_len, sizeof(pkt_len)); + + /* subtract length of FCS field */ + pkt_len = (pkt_len & 0x7ff) - IEEE802154_FCS_LEN; + + /* just return length when buf == NULL */ + if (buf == NULL) { + return pkt_len; + } + + /* not enough space in buf */ + if (pkt_len > (int) len) { + return -ENOBUFS; + } + + /* copy payload */ + at86rf215_reg_read_bytes(dev, dev->BBC->RG_FBRXS, buf, pkt_len); + + if (info != NULL) { + netdev_ieee802154_rx_info_t *radio_info = info; + radio_info->rssi = (int8_t) at86rf215_reg_read(dev, dev->RF->RG_EDV); + } + + return pkt_len; +} + +static int _set_state(at86rf215_t *dev, netopt_state_t state) +{ + at86rf215_block_while_busy(dev); + + switch (state) { + case NETOPT_STATE_STANDBY: + at86rf215_set_idle_from_rx(dev, CMD_RF_TRXOFF); + break; + case NETOPT_STATE_SLEEP: + at86rf215_set_idle_from_rx(dev, CMD_RF_SLEEP); + break; + case NETOPT_STATE_RX: + case NETOPT_STATE_IDLE: + at86rf215_set_rx_from_idle(dev, NULL); + break; + case NETOPT_STATE_TX: + if (dev->flags & AT86RF215_OPT_PRELOADING) { + return at86rf215_tx_exec(dev); + } + break; + case NETOPT_STATE_RESET: + at86rf215_reset(dev); + break; + default: + return -ENOTSUP; + } + return sizeof(netopt_state_t); +} + +static netopt_state_t _get_state(at86rf215_t *dev) +{ + switch (dev->state) { + case AT86RF215_STATE_SLEEP: + return NETOPT_STATE_SLEEP; + case AT86RF215_STATE_RX_SEND_ACK: + return NETOPT_STATE_RX; + case AT86RF215_STATE_TX: + case AT86RF215_STATE_TX_WAIT_ACK: + return NETOPT_STATE_TX; + case AT86RF215_STATE_OFF: + return NETOPT_STATE_OFF; + case AT86RF215_STATE_IDLE: + default: + return NETOPT_STATE_IDLE; + } +} + +static int _get(netdev_t *netdev, netopt_t opt, void *val, size_t max_len) +{ + at86rf215_t *dev = (at86rf215_t *) netdev; + + if (netdev == NULL) { + return -ENODEV; + } + + /* getting these options doesn't require the transceiver to be responsive */ + switch (opt) { + case NETOPT_STATE: + assert(max_len >= sizeof(netopt_state_t)); + *((netopt_state_t *)val) = _get_state(dev); + return sizeof(netopt_state_t); + + case NETOPT_PRELOADING: + if (dev->flags & AT86RF215_OPT_PRELOADING) { + *((netopt_enable_t *)val) = NETOPT_ENABLE; + } + else { + *((netopt_enable_t *)val) = NETOPT_DISABLE; + } + return sizeof(netopt_enable_t); + + case NETOPT_PROMISCUOUSMODE: + if (dev->flags & AT86RF215_OPT_PROMISCUOUS) { + *((netopt_enable_t *)val) = NETOPT_ENABLE; + } + else { + *((netopt_enable_t *)val) = NETOPT_DISABLE; + } + return sizeof(netopt_enable_t); + + case NETOPT_RX_START_IRQ: + *((netopt_enable_t *)val) = + !!(dev->flags & AT86RF215_OPT_TELL_RX_START); + return sizeof(netopt_enable_t); + + case NETOPT_RX_END_IRQ: + *((netopt_enable_t *)val) = + !!(dev->flags & AT86RF215_OPT_TELL_RX_END); + return sizeof(netopt_enable_t); + + case NETOPT_TX_START_IRQ: + *((netopt_enable_t *)val) = + !!(dev->flags & AT86RF215_OPT_TELL_TX_START); + return sizeof(netopt_enable_t); + + case NETOPT_TX_END_IRQ: + *((netopt_enable_t *)val) = + !!(dev->flags & AT86RF215_OPT_TELL_TX_END); + return sizeof(netopt_enable_t); + + case NETOPT_CSMA: + *((netopt_enable_t *)val) = + !!(dev->flags & AT86RF215_OPT_CSMA); + return sizeof(netopt_enable_t); + + case NETOPT_CSMA_RETRIES: + assert(max_len >= sizeof(uint8_t)); + *((uint8_t *)val) = dev->csma_retries_max; + return sizeof(uint8_t); + + case NETOPT_CSMA_MAXBE: + assert(max_len >= sizeof(uint8_t)); + *((uint8_t *)val) = dev->csma_maxbe; + return sizeof(uint8_t); + + case NETOPT_CSMA_MINBE: + assert(max_len >= sizeof(uint8_t)); + *((uint8_t *)val) = dev->csma_minbe; + return sizeof(uint8_t); + + case NETOPT_RETRANS: + assert(max_len >= sizeof(uint8_t)); + *((uint8_t *)val) = dev->retries_max; + return sizeof(uint8_t); + + case NETOPT_TX_RETRIES_NEEDED: + assert(max_len >= sizeof(uint8_t)); + *((uint8_t *)val) = dev->retries_max - dev->retries; + return sizeof(uint8_t); + + case NETOPT_AUTOACK: + *((netopt_enable_t *)val) = + !!(dev->flags & AT86RF215_OPT_AUTOACK); + return sizeof(netopt_enable_t); + + case NETOPT_CHANNEL_PAGE: + assert(max_len >= sizeof(uint16_t)); + ((uint8_t *)val)[1] = 0; + ((uint8_t *)val)[0] = is_subGHz(dev) ? 2 : 0; + return sizeof(uint16_t); + + case NETOPT_AUTOCCA: + *((netopt_enable_t *)val) = + !!(dev->flags & AT86RF215_OPT_CCATX); + return sizeof(netopt_enable_t); + + default: + /* Can still be handled in second switch */ + break; + } + + int res; + + if (((res = netdev_ieee802154_get((netdev_ieee802154_t *)netdev, opt, val, + max_len)) >= 0) || (res != -ENOTSUP)) { + return res; + } + + /* properties are not available if the device is sleeping */ + if (dev->state == AT86RF215_STATE_SLEEP) { + return -ENOTSUP; + } + + /* these options require the transceiver to be not sleeping*/ + switch (opt) { + case NETOPT_TX_POWER: + assert(max_len >= sizeof(int16_t)); + *((uint16_t *)val) = at86rf215_get_txpower(dev); + res = sizeof(uint16_t); + break; + + case NETOPT_CCA_THRESHOLD: + assert(max_len >= sizeof(int8_t)); + *((int8_t *)val) = at86rf215_get_cca_threshold(dev); + res = sizeof(int8_t); + break; + + case NETOPT_IS_CHANNEL_CLR: + assert(max_len >= sizeof(netopt_enable_t)); + *((netopt_enable_t *)val) = at86rf215_cca(dev); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_LAST_ED_LEVEL: + assert(max_len >= sizeof(int8_t)); + *((int8_t *)val) = at86rf215_get_ed_level(dev); + res = sizeof(int8_t); + break; + + case NETOPT_RANDOM: + at86rf215_get_random(dev, val, max_len); + res = max_len; + break; + + default: + res = -ENOTSUP; + break; + } + + return res; +} + +static int _set(netdev_t *netdev, netopt_t opt, const void *val, size_t len) +{ + at86rf215_t *dev = (at86rf215_t *) netdev; + int res = -ENOTSUP; + + if (dev == NULL) { + return -ENODEV; + } + + /* no need to wake up the device when it's sleeping - all registers + are reset on wakeup. */ + + switch (opt) { + case NETOPT_ADDRESS: + assert(len <= sizeof(uint16_t)); + at86rf215_set_addr_short(dev, 0, *((const uint16_t *)val)); + /* don't set res to set netdev_ieee802154_t::short_addr */ + break; + case NETOPT_ADDRESS_LONG: + assert(len <= sizeof(uint64_t)); + at86rf215_set_addr_long(dev, *((const uint64_t *)val)); + /* don't set res to set netdev_ieee802154_t::long_addr */ + break; + case NETOPT_NID: + assert(len <= sizeof(uint16_t)); + at86rf215_set_pan(dev, 0, *((const uint16_t *)val)); + /* don't set res to set netdev_ieee802154_t::pan */ + break; + case NETOPT_CHANNEL: + assert(len == sizeof(uint16_t)); + uint16_t chan = *((const uint16_t *)val); + + if (at86rf215_chan_valid(dev, chan) != chan) { + res = -EINVAL; + break; + } + + at86rf215_set_chan(dev, chan); + /* don't set res to set netdev_ieee802154_t::chan */ + break; + + case NETOPT_TX_POWER: + assert(len <= sizeof(int16_t)); + at86rf215_set_txpower(dev, *((const int16_t *)val)); + res = sizeof(uint16_t); + break; + + case NETOPT_STATE: + assert(len <= sizeof(netopt_state_t)); + res = _set_state(dev, *((const netopt_state_t *)val)); + break; + + case NETOPT_AUTOACK: + at86rf215_set_option(dev, AT86RF215_OPT_AUTOACK, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_AUTOCCA: + at86rf215_set_option(dev, AT86RF215_OPT_CCATX, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_RETRANS: + assert(len <= sizeof(uint8_t)); + dev->retries_max = *((const uint8_t *)val); + res = sizeof(uint8_t); + break; + + case NETOPT_PRELOADING: + at86rf215_set_option(dev, AT86RF215_OPT_PRELOADING, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_PROMISCUOUSMODE: + at86rf215_set_option(dev, AT86RF215_OPT_PROMISCUOUS, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_RX_START_IRQ: + at86rf215_set_option(dev, AT86RF215_OPT_TELL_RX_START, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_RX_END_IRQ: + at86rf215_set_option(dev, AT86RF215_OPT_TELL_RX_END, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_TX_START_IRQ: + at86rf215_set_option(dev, AT86RF215_OPT_TELL_TX_START, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_TX_END_IRQ: + at86rf215_set_option(dev, AT86RF215_OPT_TELL_TX_END, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_CSMA: + at86rf215_set_option(dev, AT86RF215_OPT_CSMA, + ((const bool *)val)[0]); + res = sizeof(netopt_enable_t); + break; + + case NETOPT_CSMA_RETRIES: + assert(len <= sizeof(uint8_t)); + dev->csma_retries_max = *((const uint8_t *)val); + res = sizeof(uint8_t); + break; + + case NETOPT_CSMA_MAXBE: + assert(len <= sizeof(uint8_t)); + dev->csma_maxbe = *((const uint8_t *)val); + res = sizeof(uint8_t); + break; + + case NETOPT_CSMA_MINBE: + assert(len <= sizeof(uint8_t)); + dev->csma_minbe = *((const uint8_t *)val); + res = sizeof(uint8_t); + break; + + case NETOPT_CCA_THRESHOLD: + assert(len <= sizeof(int8_t)); + at86rf215_set_cca_threshold(dev, *((const int8_t *)val)); + res = sizeof(int8_t); + break; + + default: + break; + } + + if (res == -ENOTSUP) { + res = netdev_ieee802154_set((netdev_ieee802154_t *)netdev, opt, val, len); + } + + return res; +} + +static void _enable_tx2rx(at86rf215_t *dev) +{ + uint8_t amcs = at86rf215_reg_read(dev, dev->BBC->RG_AMCS); + + /* disable AACK, enable TX2RX */ + amcs |= AMCS_TX2RX_MASK; + amcs &= ~AMCS_AACK_MASK; + + at86rf215_reg_write(dev, dev->BBC->RG_AMCS, amcs); +} + +static void _tx_end(at86rf215_t *dev, netdev_event_t event) +{ + netdev_t *netdev = (netdev_t *)dev; + + /* listen to non-ACK packets again */ + if (dev->flags & AT86RF215_OPT_ACK_REQUESTED) { + dev->flags &= ~AT86RF215_OPT_ACK_REQUESTED; + at86rf215_filter_ack(dev, false); + } + + at86rf215_tx_done(dev); + + if (dev->flags & AT86RF215_OPT_TELL_TX_END) { + netdev->event_callback(netdev, event); + } + + dev->timeout = 0; + dev->state = AT86RF215_STATE_IDLE; +} + +static void _ack_timeout_cb(void* arg) { + at86rf215_t *dev = arg; + dev->timeout = AT86RF215_TIMEOUT_ACK; + msg_send_int(&dev->timer_msg, dev->timer_msg.sender_pid); +} + +static void _backoff_timeout_cb(void* arg) { + at86rf215_t *dev = arg; + dev->timeout = AT86RF215_TIMEOUT_CSMA; + msg_send_int(&dev->timer_msg, dev->timer_msg.sender_pid); +} + +static void _set_idle(at86rf215_t *dev) +{ + dev->state = AT86RF215_STATE_IDLE; + + uint8_t next_state; + + if (dev->flags & AT86RF215_OPT_TX_PENDING) { + next_state = CMD_RF_TXPREP; + } else { + next_state = CMD_RF_RX; + } + + at86rf215_rf_cmd(dev, next_state); +} + +/* wake up the radio thread after ACK timeout */ +static void _start_ack_timer(at86rf215_t *dev) +{ + dev->timer_msg.type = NETDEV_MSG_TYPE_EVENT; + dev->timer_msg.sender_pid = thread_getpid(); + + dev->timer.arg = dev; + dev->timer.callback = _ack_timeout_cb; + + xtimer_set(&dev->timer, dev->ack_timeout_usec); +} + +/* wake up the radio thread after CSMA backoff period */ +static void _start_backoff_timer(at86rf215_t *dev) +{ + uint8_t be; /* backoff exponent */ + uint32_t base; + + /* energy detect interrupt happened -> hardware is still in RX mode */ + at86rf215_get_random(dev, &base, sizeof(base)); + + be = ((dev->csma_retries_max - dev->csma_retries) - 1) + dev->csma_minbe; + + if (be > dev->csma_maxbe) { + be = dev->csma_maxbe; + } + + uint32_t csma_backoff_usec = ((1LU << be) - 1) * dev->csma_backoff_period; + /* limit the 32bit random value to the current backoff */ + csma_backoff_usec = base % csma_backoff_usec; + + DEBUG("Set CSMA backoff to %"PRIu32" (be %u min %u max %u base: %"PRIu32")\n", + csma_backoff_usec, be, dev->csma_minbe, dev->csma_maxbe, base); + + dev->timer_msg.type = NETDEV_MSG_TYPE_EVENT; + dev->timer_msg.sender_pid = thread_getpid(); + + dev->timer.arg = dev; + dev->timer.callback = _backoff_timeout_cb; + + xtimer_set(&dev->timer, csma_backoff_usec); +} + +static inline bool _ack_frame_received(at86rf215_t *dev) +{ + /* check if the sequence numbers (3rd byte) match */ + return at86rf215_reg_read(dev, dev->BBC->RG_FBRXS + 2) + == at86rf215_reg_read(dev, dev->BBC->RG_FBTXS + 2); +} + +static void _handle_ack_timeout(at86rf215_t *dev) +{ + if (dev->retries) { + --dev->retries; + + if (dev->flags & AT86RF215_OPT_CSMA) { + dev->csma_retries = dev->csma_retries_max; + if (!(dev->flags & AT86RF215_OPT_CCATX)){ + dev->flags |= AT86RF215_OPT_CCA_PENDING; + } + } + + dev->flags |= AT86RF215_OPT_TX_PENDING; + at86rf215_rf_cmd(dev, CMD_RF_TXPREP); + } else { + /* no retransmissions left */ + _tx_end(dev, NETDEV_EVENT_TX_NOACK); + } +} + +/* clear the other IRQ if the sibling is not ready yet */ +static inline void _clear_sibling_irq(at86rf215_t *dev) { + if (is_subGHz(dev)) { + at86rf215_reg_read(dev, RG_RF24_IRQS); + at86rf215_reg_read(dev, RG_BBC1_IRQS); + } else { + at86rf215_reg_read(dev, RG_RF09_IRQS); + at86rf215_reg_read(dev, RG_BBC0_IRQS); + } +} + +static void _handle_edc(at86rf215_t *dev) +{ + netdev_t *netdev = (netdev_t *) dev; + + /* In CCATX mode this function is only triggered if busy */ + if (!(dev->flags & AT86RF215_OPT_CCATX)) { + /* channel clear -> TX */ + if ((int8_t)at86rf215_reg_read(dev, dev->RF->RG_EDV) <= at86rf215_get_cca_threshold(dev)) { + dev->flags &= ~AT86RF215_OPT_CCA_PENDING; + at86rf215_enable_baseband(dev); + at86rf215_rf_cmd(dev, CMD_RF_TXPREP); + return; + } + } + + DEBUG("CSMA busy\n"); + if (dev->csma_retries) { + --dev->csma_retries; + _start_backoff_timer(dev); + } else { + /* channel busy and no retries left */ + dev->flags &= ~(AT86RF215_OPT_CCA_PENDING | AT86RF215_OPT_TX_PENDING); + dev->state = AT86RF215_STATE_IDLE; + + at86rf215_enable_baseband(dev); + at86rf215_tx_done(dev); + + netdev->event_callback(netdev, NETDEV_EVENT_TX_MEDIUM_BUSY); + + DEBUG("CSMA give up"); + /* radio is still in RX mode, tx_done sets IDLE state */ + } +} + +/* executed in the radio thread */ +static void _isr(netdev_t *netdev) +{ + at86rf215_t *dev = (at86rf215_t *) netdev; + uint8_t bb_irq_mask, rf_irq_mask; + uint8_t bb_irqs_enabled = BB_IRQ_RXFE | BB_IRQ_TXFE; + + /* not using IRQMM because we want to know about AGCH */ + if (dev->flags & AT86RF215_OPT_TELL_RX_START) { + bb_irqs_enabled |= BB_IRQ_RXAM; + } + + rf_irq_mask = at86rf215_reg_read(dev, dev->RF->RG_IRQS); + bb_irq_mask = at86rf215_reg_read(dev, dev->BBC->RG_IRQS); + + uint8_t timeout = dev->timeout; + if (timeout) { + dev->timeout = 0; + } + + /* mark AGC Hold bit */ + if (bb_irq_mask & BB_IRQ_AGCH) { + dev->flags |= AT86RF215_OPT_AGCH; + } + + /* clear AGC Hold bit */ + if (bb_irq_mask & BB_IRQ_AGCR) { + dev->flags &= ~AT86RF215_OPT_AGCH; + } + + /* we got here because of CMSA timeout */ + if (timeout & AT86RF215_TIMEOUT_CSMA) { + timeout = 0; + + if (!(dev->flags & AT86RF215_OPT_CCATX)) { + at86rf215_reg_write(dev, dev->RF->RG_EDC, 1); + } else { + at86rf215_rf_cmd(dev, CMD_RF_TXPREP); + } + } + + /* If the interrupt pin is still high, there was an IRQ on the other radio */ + if (gpio_read(dev->params.int_pin)) { + if (dev->sibling && dev->sibling->state != AT86RF215_STATE_OFF) { + netdev->event_callback((netdev_t *) dev->sibling, NETDEV_EVENT_ISR); + } else { + _clear_sibling_irq(dev); + } + } + + /* exit early if the interrupt was not for this interface */ + if (!((bb_irq_mask & bb_irqs_enabled) || + (rf_irq_mask & (RF_IRQ_EDC | RF_IRQ_TRXRDY)) || timeout)) { + return; + } + + /* check if the received packet has the ACK request bit set */ + bool rx_ack_req; + if (bb_irq_mask & BB_IRQ_RXFE) { + rx_ack_req = at86rf215_reg_read(dev, dev->BBC->RG_FBRXS) & IEEE802154_FCF_ACK_REQ; + } else { + rx_ack_req = 0; + } + + if (dev->flags & AT86RF215_OPT_CCA_PENDING) { + + /* Start ED or handle result */ + if (rf_irq_mask & RF_IRQ_EDC) { + _handle_edc(dev); + } else if (rf_irq_mask & RF_IRQ_TRXRDY) { + /* disable baseband for energy detection */ + at86rf215_disable_baseband(dev); + /* switch to state RX for energy detection */ + at86rf215_rf_cmd(dev, CMD_RF_RX); + /* start energy measurement */ + at86rf215_reg_write(dev, dev->RF->RG_EDC, 1); + } + + } else if (dev->flags & AT86RF215_OPT_TX_PENDING) { + + /* start transmitting the frame */ + if (rf_irq_mask & RF_IRQ_TRXRDY) { + + /* automatically switch to RX when TX is done */ + _enable_tx2rx(dev); + + /* only listen for ACK frames */ + if (dev->flags & AT86RF215_OPT_ACK_REQUESTED) { + at86rf215_filter_ack(dev, true); + } + + /* switch to state TX */ + dev->state = AT86RF215_STATE_TX; + dev->flags &= ~AT86RF215_OPT_TX_PENDING; + at86rf215_rf_cmd(dev, CMD_RF_TX); + + /* This also tells the upper layer about retransmissions - should it be like that? */ + if (netdev->event_callback && + (dev->flags & AT86RF215_OPT_TELL_TX_START)) { + netdev->event_callback(netdev, NETDEV_EVENT_TX_STARTED); + } + } + } + + /* CCATX signals medium busy */ + if ((dev->flags & AT86RF215_OPT_CCATX) && (rf_irq_mask & RF_IRQ_EDC) && (bb_irq_mask & BB_IRQ_TXFE)) { + bb_irq_mask &= ~BB_IRQ_TXFE; + rf_irq_mask &= ~RF_IRQ_EDC; + _handle_edc(dev); + } + + int iter = 0; + while (timeout || (bb_irq_mask & (BB_IRQ_RXFE | BB_IRQ_TXFE))) { + + /* This should never happen */ + if (++iter > 3) { + puts("AT86RF215: stuck in ISR"); + printf("\tnum_channels: %d\n", dev->num_chans); + printf("\tHW: %s\n", at86rf215_hw_state2a(at86rf215_get_rf_state(dev))); + printf("\tSW: %s\n", at86rf215_sw_state2a(dev->state)); + printf("\trf_irq_mask: %x\n", rf_irq_mask); + printf("\tbb_irq_mask: %x\n", bb_irq_mask); + printf("\ttimeout: %x\n", timeout); + break; + } + + switch (dev->state) { + case AT86RF215_STATE_IDLE: + + if (!(bb_irq_mask & (BB_IRQ_RXFE | BB_IRQ_RXAM))) { + DEBUG("IDLE: only RXFE/RXAM expected (%x)\n", bb_irq_mask); + break; + } + + if ((bb_irq_mask & BB_IRQ_RXAM) && + (dev->flags & AT86RF215_OPT_TELL_RX_END)) { + /* will be executed in the same thread */ + netdev->event_callback(netdev, NETDEV_EVENT_RX_STARTED); + } + + bb_irq_mask &= ~BB_IRQ_RXAM; + + if (!(bb_irq_mask & BB_IRQ_RXFE)) { + break; + } + + bb_irq_mask &= ~BB_IRQ_RXFE; + + if (dev->flags & AT86RF215_OPT_TELL_RX_END) { + /* will be executed in the same thread */ + netdev->event_callback(netdev, NETDEV_EVENT_RX_COMPLETE); + } + + if (rx_ack_req) { + dev->state = AT86RF215_STATE_RX_SEND_ACK; + break; + } + + _set_idle(dev); + + break; + + case AT86RF215_STATE_RX_SEND_ACK: + + if (!(bb_irq_mask & BB_IRQ_TXFE)) { + DEBUG("RX_SEND_ACK: only TXFE expected (%x)\n", bb_irq_mask); + break; + } + + bb_irq_mask &= ~BB_IRQ_TXFE; + + _set_idle(dev); + break; + + case AT86RF215_STATE_TX: + + if (!(bb_irq_mask & BB_IRQ_TXFE)) { + DEBUG("TX: only TXFE expected (%x)\n", bb_irq_mask); + break; + } + + bb_irq_mask &= ~BB_IRQ_TXFE; + + if (dev->flags & AT86RF215_OPT_ACK_REQUESTED) { + dev->state = AT86RF215_STATE_TX_WAIT_ACK; + _start_ack_timer(dev); + } else { + _tx_end(dev, NETDEV_EVENT_TX_COMPLETE); + } + break; + + case AT86RF215_STATE_TX_WAIT_ACK: + + if (!((bb_irq_mask & BB_IRQ_RXFE) || timeout)) { + DEBUG("TX_WAIT_ACK: only RXFE or timeout expected (%x)\n", bb_irq_mask); + break; + } + + /* handle timeout case */ + if (!(bb_irq_mask & BB_IRQ_RXFE)) { + goto timeout; + } + + bb_irq_mask &= ~BB_IRQ_RXFE; + + if (_ack_frame_received(dev)) { + timeout = 0; + xtimer_remove(&dev->timer); + _tx_end(dev, NETDEV_EVENT_TX_COMPLETE); + at86rf215_rf_cmd(dev, CMD_RF_RX); + break; + } + + /* we got a spurious ACK */ + if (!timeout) { + at86rf215_rf_cmd(dev, CMD_RF_RX); + break; + } + +timeout: + /* For a yet unknown reason, the device spends an excessive amount of time + * transmitting the preamble in non-legacy modes. + * This means the calculated ACK timeouts are often too short. + * To mitigate this, postpone the ACK timeout if the device is still RXign + * the ACK frame when the timeout expires. + */ + if (dev->flags & AT86RF215_OPT_AGCH) { + DEBUG("[at86rf215] Ack timeout postponed\n"); + _start_ack_timer(dev); + } else { + DEBUG("[at86rf215] Ack timeout\n"); + _handle_ack_timeout(dev); + } + + timeout = 0; + break; + } + } +} diff --git a/drivers/at86rf215/at86rf215_o-qpsk.c b/drivers/at86rf215/at86rf215_o-qpsk.c new file mode 100644 index 0000000000..c978eaabf3 --- /dev/null +++ b/drivers/at86rf215/at86rf215_o-qpsk.c @@ -0,0 +1,277 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Configuration of the MR-O-QPSK PHY on the AT86RF215 chip + * + * @author Benjamin Valentin + * @} + */ + +#include "at86rf215.h" +#include "at86rf215_internal.h" + +#include "debug.h" + +/* IEEE Std 802.15.4g™-2012 Amendment 3 + * Table 68d—Total number of channels and first channel center frequencies for SUN PHYs + * Table 68e—Center frequencies for the MR-O-QPSK PHY operating in the 868–870 MHz band + */ + +/* currently only EU-868 MHz band is supported */ +#define QPSK_CHANNEL_SPACING_SUBGHZ (650U) /* kHz */ +#define QPSK_CENTER_FREQUENCY_SUBGHZ (868300U) /* Hz */ + +#define QPSK_CHANNEL_SPACING_24GHZ (5000U) /* kHz */ +#define QPSK_CENTER_FREQUENCY_24GHZ (2350000U - CCF0_24G_OFFSET) /* Hz */ + +/* Table 6-103. O-QPSK Transmitter Frontend Configuration */ +static uint8_t _TXCUTC_PARAMP(uint8_t chips) +{ + switch (chips) { + case BB_FCHIP100: + return RF_PARAMP32U; + case BB_FCHIP200: + return RF_PARAMP16U; + case BB_FCHIP1000: + case BB_FCHIP2000: + return RF_PARAMP4U; + } + + return 0; +} + +/* Table 6-103. O-QPSK Transmitter Frontend Configuration */ +static uint8_t _TXCUTC_LPFCUT(uint8_t chips) +{ + switch (chips) { + case BB_FCHIP100: + case BB_FCHIP200: + return RF_FLC400KHZ; + case BB_FCHIP1000: + case BB_FCHIP2000: + return RF_FLC1000KHZ; + } + + return 0; +} + +/* Table 6-103. O-QPSK Transmitter Frontend Configuration */ +static uint8_t _TXDFE_SR(uint8_t chips) +{ + switch (chips) { + case BB_FCHIP100: + return RF_SR_400K; + case BB_FCHIP200: + return RF_SR_800K; + case BB_FCHIP1000: + return RF_SR_4000K; + case BB_FCHIP2000: + return RF_SR_4000K; + } + + return 0; +} + +/* Table 6-103. O-QPSK Transmitter Frontend Configuration */ +static uint8_t _TXDFE_RCUT(uint8_t chips) +{ + return (chips == BB_FCHIP2000 ? RF_RCUT_FS_BY_2 : RF_RCUT_FS_BY_2P6); +} + +/* Table 6-105. O-QPSK Receiver Frontend Configuration (Filter Settings) */ +static uint8_t _RXBWC_BW(uint8_t chips) +{ + switch (chips) { + case BB_FCHIP100: + return RF_BW160KHZ_IF250KHZ; + case BB_FCHIP200: + return RF_BW250KHZ_IF250KHZ; + case BB_FCHIP1000: + return RF_BW1000KHZ_IF1000KHZ; + case BB_FCHIP2000: + return RF_BW2000KHZ_IF2000KHZ; + } + + return 0; +} + +/* Table 6-105. O-QPSK Receiver Frontend Configuration (Filter Settings) */ +static uint8_t _RXDFE_SR(uint8_t chips) +{ + switch (chips) { + case BB_FCHIP100: + return RF_SR_400K; + case BB_FCHIP200: + return RF_SR_800K; + case BB_FCHIP1000: + case BB_FCHIP2000: + return RF_SR_4000K; + } + + return 0; +} + +/* Table 6-105. O-QPSK Receiver Frontend Configuration (Filter Settings) */ +static uint8_t _RXDFE_RCUT(uint8_t chips) +{ + switch (chips) { + case BB_FCHIP100: + case BB_FCHIP200: + return RF_RCUT_FS_BY_5P3; + case BB_FCHIP1000: + return RF_RCUT_FS_BY_8; + case BB_FCHIP2000: + return RF_RCUT_FS_BY_4; + } + + return 0; +} + +/* Table 6-106. O-QPSK Receiver Frontend Configuration (AGC Settings) */ +static inline uint8_t _AGCC(uint8_t chips) +{ + if (chips > BB_FCHIP200) { + /* 32 samples */ + return (2 << AGCC_AVGS_SHIFT) | AGCC_EN_MASK; + } else { + return AGCC_EN_MASK; + } +} + +/* Table 6-100. MR-O-QPSK Modes */ +static uint32_t _get_bitrate(uint8_t chips, uint8_t mode) +{ + switch (chips) { + case BB_FCHIP100: + return 6250 * (1 << mode); + case BB_FCHIP200: + return 12500 * (1 << mode); + case BB_FCHIP1000: + case BB_FCHIP2000: + return mode ? 125000 * (1 << (mode - 1)) : 31250; + } + + return 0; +} + +static void _set_chips(at86rf215_t *dev, uint8_t chips) +{ + /* enable direct modulation if the chip supports it */ + uint8_t direct_modulation; + if (chips < BB_FCHIP1000 && at86rf215_reg_read(dev, RG_RF_VN) >= 3) { + direct_modulation = TXDFE_DM_MASK; + } else { + direct_modulation = 0; + } + + /* Set Receiver Bandwidth */ + at86rf215_reg_write(dev, dev->RF->RG_RXBWC, _RXBWC_BW(chips)); + /* Set fS; fCUT for RX */ + at86rf215_reg_write(dev, dev->RF->RG_RXDFE, _RXDFE_SR(chips) + | _RXDFE_RCUT(chips)); + /* Set Power Amplifier Ramp Time; fLPCUT */ + at86rf215_reg_write(dev, dev->RF->RG_TXCUTC, _TXCUTC_PARAMP(chips) + | _TXCUTC_LPFCUT(chips)); + /* Set fS; fCUT for TX */ + at86rf215_reg_write(dev, dev->RF->RG_TXDFE, _TXDFE_SR(chips) + | _TXDFE_RCUT(chips) + | direct_modulation); + + /* set receiver gain target according to data sheet, p125 */ + at86rf215_reg_write(dev, dev->RF->RG_AGCS, 3 << AGCS_TGT_SHIFT); + at86rf215_reg_write(dev, dev->RF->RG_AGCC, _AGCC(chips)); + + /* use RC-0.8 shaping */ + at86rf215_reg_write(dev, dev->BBC->RG_OQPSKC0, chips | direct_modulation); +} + +static void _set_legacy(at86rf215_t *dev, bool high_rate) +{ + uint8_t chips; + + /* enable/disable legacy high data rate, only use SFD_1 */ + if (high_rate) { + at86rf215_reg_write(dev, dev->BBC->RG_OQPSKC3, OQPSKC3_HRLEG_MASK); + } else { + at86rf215_reg_write(dev, dev->BBC->RG_OQPSKC3, 0); + } + + if (is_subGHz(dev)) { + chips = BB_FCHIP1000; + } else { + chips = BB_FCHIP2000; + } + + _set_chips(dev, chips); + + at86rf215_reg_write(dev, dev->BBC->RG_OQPSKPHRTX, AT86RF215_OQPSK_MODE_LEGACY); + + at86rf215_reg_write(dev, dev->BBC->RG_OQPSKC2, + RXM_LEGACY_OQPSK /* receive mode, legacy O-QPSK */ + | OQPSKC2_FCSTLEG_MASK /* 16 bit frame checksum */ + | OQPSKC2_ENPROP_MASK); /* enable RX of proprietary modes */ +} + +static void _set_ack_timeout(at86rf215_t *dev, uint8_t chips, uint8_t mode) +{ + dev->ack_timeout_usec = AT86RF215_ACK_PERIOD_IN_BITS * US_PER_SEC / _get_bitrate(chips, mode); + DEBUG("[%s] ACK timeout: %"PRIu32" µs\n", "O-QPSK", dev->ack_timeout_usec); +} + +static void _set_csma_backoff_period(at86rf215_t *dev, uint8_t chips, uint8_t mode) +{ + dev->csma_backoff_period = AT86RF215_BACKOFF_PERIOD_IN_BITS * US_PER_SEC / _get_bitrate(chips, mode); + DEBUG("[%s] CSMA BACKOFF: %"PRIu32" µs\n", "O-QPSK", dev->csma_backoff_period); +} + +void _end_configure_OQPSK(at86rf215_t *dev) +{ + /* set channel spacing with 25 kHz resolution */ + if (is_subGHz(dev)) { + at86rf215_reg_write(dev, dev->RF->RG_CS, QPSK_CHANNEL_SPACING_SUBGHZ / 25); + at86rf215_reg_write16(dev, dev->RF->RG_CCF0L, QPSK_CENTER_FREQUENCY_SUBGHZ / 25); + } else { + at86rf215_reg_write(dev, dev->RF->RG_CS, QPSK_CHANNEL_SPACING_24GHZ / 25); + at86rf215_reg_write16(dev, dev->RF->RG_CCF0L, QPSK_CENTER_FREQUENCY_24GHZ / 25); + } + + /* lowest preamble detection sensitivity, enable receiver override */ + at86rf215_reg_write(dev, dev->BBC->RG_OQPSKC1, OQPSKC1_RXO_MASK | OQPSKC1_RXOLEG_MASK); + + /* make sure the channel config is still valid */ + dev->num_chans = is_subGHz(dev) ? 1 : 16; + dev->netdev.chan = at86rf215_chan_valid(dev, dev->netdev.chan); + at86rf215_reg_write16(dev, dev->RF->RG_CNL, dev->netdev.chan); + + at86rf215_enable_radio(dev, BB_MROQPSK); +} + +int at86rf215_configure_legacy_OQPSK(at86rf215_t *dev, bool high_rate) +{ + /* select 'mode' that would result in the approprate MR-O-QPSK data rate */ + uint8_t mode = high_rate ? 3 : 2; + uint8_t chips = is_subGHz(dev) ? BB_FCHIP1000 : BB_FCHIP2000; + + at86rf215_await_state_end(dev, RF_STATE_TX); + + /* disable radio */ + at86rf215_reg_write(dev, dev->BBC->RG_PC, 0); + + _set_legacy(dev, high_rate); + _set_csma_backoff_period(dev, chips, mode); + _set_ack_timeout(dev, chips, mode); + + _end_configure_OQPSK(dev); + + return 0; +} diff --git a/drivers/at86rf215/include/at86rf215_internal.h b/drivers/at86rf215/include/at86rf215_internal.h new file mode 100644 index 0000000000..00982a5225 --- /dev/null +++ b/drivers/at86rf215/include/at86rf215_internal.h @@ -0,0 +1,401 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Low-Level functions for the AT86RF215 driver + * + * @author Benjamin Valentin + * @} + */ + +#ifndef AT86RF215_INTERNAL_H +#define AT86RF215_INTERNAL_H + +#include +#include "at86rf215.h" +#include "at86rf215_registers.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Minimum reset pulse width (tRST) in µs + */ +#define AT86RF215_RESET_PULSE_WIDTH_US (16U) + +/** + * @brief The typical transition time to TRX_OFF after reset (tPOWERON) in µs + */ +#define AT86RF215_RESET_DELAY_US (16U) + +/** Default energy detect threshold for CSMA (reset value) */ +#define AT86RF215_EDT_DEFAULT (-84) /* dBm */ + +/** + * This is used to calculate the csma backoff based on the bitrate. + */ +/** 20 symbols is the std period length */ +#define AT86RF215_BACKOFF_PERIOD_IN_SYMBOLS (20U) +/** in 802.15.4 oqpsk each symble is 4 bits, not about the others */ +#define AT86RF215_BACKOFF_PERIOD_IN_BITS (AT86RF215_BACKOFF_PERIOD_IN_SYMBOLS * 4) + +/** + * Default Parameters for 802.15.4 retransmissions & CSMA + * @{ + */ +#define AT86RF215_RETRIES_MAX_DEFAULT (3) +#define AT86RF215_CSMA_RETRIES_MAX_DEFAULT (4) +#define AT86RF215_CSMA_MIN_BE_DEFAULT (3) +#define AT86RF215_CSMA_MAX_BE_DEFAULT (5) +/** @} */ + +/** For the SUN PHYs, the value is 1 ms expressed in symbol periods, rounded up to the next + integer number of symbol periods using the ceiling() function */ +#define AT86RF215_TURNAROUND_TIME_US (1 * US_PER_MS) + +/** An ACK consists of 5 payload bytes */ +#define AT86RF215_ACK_PSDU_BYTES (5) + +/** + * This is used to calculate the ACK timeout based on the bitrate. + * AT86RF233 uses an ACK timeout of 54 symbol periods, or 864 µs @ 250 kbit/s + * -> 864µs * 250kbit/s = 216 bit */ +#define AT86RF215_ACK_PERIOD_IN_SYMBOLS (54U) +/** in 802.15.4 oqpsk each symble is 4 bits, not about the others */ +#define AT86RF215_ACK_PERIOD_IN_BITS (AT86RF215_ACK_PERIOD_IN_SYMBOLS * 4) + +#define AT86RF215_OQPSK_MODE_LEGACY (0x1) /**< legacy mode, 250 kbit/s */ +#define AT86RF215_OQPSK_MODE_LEGACY_HDR (0x3) /**< legacy mode, high data rate */ +#define AT86RF215_MR_OQPSK_MODE(n) ((n) << OQPSKPHRTX_MOD_SHIFT) /**< MR-QPSK */ + +/** + * @brief Perform a reset of the entire chip. + * + * @param dev device to reset, will also reset sibling device + * @return 0 on success, error if device is not available + */ +int at86rf215_hardware_reset(at86rf215_t *dev); + +/** + * @brief Write to a register at address `addr` from device `dev`. + * + * @param[in] dev device to write to + * @param[in] reg address of the register to write + * @param[in] val value to write to the given register + */ +void at86rf215_reg_write(const at86rf215_t *dev, uint16_t reg, uint8_t val); + +/** + * @brief Write a chunk of data into the memory of the given device + * + * @param[in] dev device to write to + * @param[in] reg address in the device to write to + * @param[in] data data to copy into the device + * @param[in] len number of bytes to write into the device + */ +void at86rf215_reg_write_bytes(const at86rf215_t *dev, uint16_t reg, const void *data, size_t len); + +/** + * @brief Read from a register at address `addr` from device `dev`. + * + * @param[in] dev device to read from + * @param[in] reg address of the register to read + * + * @return the value of the specified register + */ +uint8_t at86rf215_reg_read(const at86rf215_t *dev, uint16_t reg); + +/** + * @brief Read a chunk of data from the memory of the given device + * + * @param[in] dev device to read from + * @param[in] reg starting address to read from + * @param[out] data buffer to read data into + * @param[in] len number of bytes to read + */ +void at86rf215_reg_read_bytes(const at86rf215_t *dev, uint16_t reg, void *data, size_t len); + +/** + * @brief Enable / Disable the ACK filter + * + * @param[in] dev device to configure + * @param[in] on if true, only ACK frames are received + * if false, only non-ACK frames are received + */ +void at86rf215_filter_ack(at86rf215_t *dev, bool on); + +/** + * @brief Read random data from the RNG + * + * @pre The device has to be in state RX with PLL locked. + * + * @param[in] dev device to configure + * @param[out] data buffer to copy the random data to + * @param[in] len number of random bytes to store in data + */ +void at86rf215_get_random(at86rf215_t *dev, void *data, size_t len); + +/** + * @brief Configure the radio to make use of O-QPSK modulation. + * The rate mode may be + * - 0 for compatibility with first-gen 802.15.4 devices (250 kbit/s) + * - 1 for compatibility with the proprietary high-data rate modes of at86rf2xx + * + * @param[in] dev device to configure + * @param[in] high_rate use proprietary high data rate compatible with at86rf2xx + * + * @return 0 on success, error otherwise + */ +int at86rf215_configure_legacy_OQPSK(at86rf215_t *dev, bool high_rate); + +/** + * @brief Check if a channel number is valid. + * The function takes the current frequency band and modulation into + * account to determine if `chan` would be a legal channel number. + * If so, it is returned unmodified. Otherwise the next closest legal + * channel number is returned. + * + * @note This function does not change the configuration. + * + * @param[in] dev device to check against + * @param[in] chan the channel number to check + * + * @return If the channel number is legal, `chan` is returned. + * Otherwise the next closest legal channel number is + * returned. + */ +uint16_t at86rf215_chan_valid(at86rf215_t *dev, uint16_t chan); + +/** + * @brief Converts radio state into human readable string. + * + * @param[in] state radio state + * + * @return fixed string representation of the radio state + */ +const char* at86rf215_hw_state2a(uint8_t state); + +/** + * @brief Converts state machine state into human readable string. + * + * @param[in] state state of the driver's state machine + * + * @return fixed string representation of the state machine state + */ +const char* at86rf215_sw_state2a(at86rf215_state_t state); + +/** + * @brief Reads the contents of `reg`, apply `val` with a bitwise AND + * and then writes the result back to `reg`. + * + * @param[in] dev device to write to + * @param[in] reg register to write to + * @param[in] val value to bitwise AND with the register content + */ +static inline void at86rf215_reg_and(const at86rf215_t *dev, uint16_t reg, uint8_t val) +{ + val &= at86rf215_reg_read(dev, reg); + at86rf215_reg_write(dev, reg, val); +} + +/** + * @brief Reads the contents of `reg`, apply `val` with a bitwise OR + * and then writes the result back to `reg`. + * + * @param[in] dev device to write to + * @param[in] reg register to write to + * @param[in] val value to bitwise OR with the register content + */ +static inline void at86rf215_reg_or(const at86rf215_t *dev, uint16_t reg, uint8_t val) +{ + val |= at86rf215_reg_read(dev, reg); + at86rf215_reg_write(dev, reg, val); +} + +/** + * @brief Write a 16-bit word to a register at address `addr` from device `dev`. + * + * @param[in] dev device to write to + * @param[in] reg address of the register to write + * @param[in] val value to write to the given register + */ +static inline void at86rf215_reg_write16(const at86rf215_t *dev, uint16_t reg, uint16_t val) +{ + at86rf215_reg_write_bytes(dev, reg, &val, sizeof(val)); +} + +/** + * @brief Read a 16-bit word from a register at address `addr` from device `dev`. + * + * @param[in] dev device to read from + * @param[in] reg address of the register to read + * + * @return the value of the specified register + */ +static inline uint16_t at86rf215_reg_read16(const at86rf215_t *dev, uint16_t reg) +{ + uint16_t value; + at86rf215_reg_read_bytes(dev, reg, &value, sizeof(value)); + return value; +} + +/** + * @brief Issue a radio command to the device + * + * @param[in] dev device to configure + * @param[in] rf_cmd command to send + */ +static inline void at86rf215_rf_cmd(const at86rf215_t *dev, uint8_t rf_cmd) +{ + at86rf215_reg_write(dev, dev->RF->RG_CMD, rf_cmd); +} + +/** + * @brief Get the radio state of the device + * + * @param[in] dev device to read from + * + * @return the current radio state + */ +static inline uint8_t at86rf215_get_rf_state(const at86rf215_t *dev) +{ + return at86rf215_reg_read(dev, dev->RF->RG_STATE) & STATE_STATE_MASK; +} + +/** + * @brief Blocks until the device has reached the given state + * + * @param[in] dev device to poll + * @param[in] state the expected state + */ +static inline void at86rf215_await_state(const at86rf215_t *dev, uint8_t state) +{ + while (at86rf215_get_rf_state(dev) != state) {} +} + +/** + * @brief Blocks until the device has reached the given state + * + * @param[in] dev device to poll + * @param[in] state the expected state + */ +static inline void at86rf215_await_state_end(const at86rf215_t *dev, uint8_t state) +{ + while (at86rf215_get_rf_state(dev) == state) {} +} + +/** + * @brief Switch device back to IDLE-RX from non-RX idle + * + * @param[in] dev device to update + * @param[out] old_state pointer to store the previous state, may be NULL + * + * @return true if the operation was possible + */ +bool at86rf215_set_rx_from_idle(at86rf215_t *dev, uint8_t *old_state); + +/** + * @brief Switch device to non-RX idle state from RX + * + * @param[in] dev device to update + * @param[out] state the new state (may be CMD_RF_TRXOFF or CMD_RF_SLEEP) + * + * @return true if the operation was possible + */ +bool at86rf215_set_idle_from_rx(at86rf215_t *dev, uint8_t state); + +/** + * @brief Enable the baseband processor of the device + * + * @param[in] dev device to enable the baseband on + */ +static inline void at86rf215_enable_baseband(const at86rf215_t *dev) +{ + at86rf215_reg_or(dev, dev->BBC->RG_PC, PC_BBEN_MASK); +} + +/** + * @brief Disable the baseband processor of the device + * + * @param[in] dev device to disable the baseband on + */ +static inline void at86rf215_disable_baseband(const at86rf215_t *dev) { + at86rf215_reg_and(dev, dev->BBC->RG_PC, ~PC_BBEN_MASK); +} + +/** + * @brief Enable the radio hardware with a given modulation. + * + * @param[in] dev device to enable + * @param[in] modulation modulation to configure on the radio + */ +static inline void at86rf215_enable_radio(at86rf215_t *dev, uint8_t modulation) +{ + /* 16 bit frame-checksum, baseband enabled, checksum calculated by chip, + frames with invalid cs are dropped */ + at86rf215_reg_write(dev, dev->BBC->RG_PC, modulation | PC_BBEN_MASK + | PC_FCST_MASK | PC_TXAFCS_MASK + | PC_FCSFE_MASK); +} + +/** + * @brief Internal convenience function to disable reduced power + * consumption (RPC) for energy detection. + * + * @param[in] dev device to configure + */ +void at86rf215_disable_rpc(at86rf215_t *dev); + +/** + * @brief Internal convenience function to re-enable reduced power + * consumption (RPC) after energy detection. + * + * @param[in] dev device to configure + */ +void at86rf215_enable_rpc(at86rf215_t *dev); + +/** + * @brief Notify the driver and stack about a change in transmission mode + * which may result in a change of PDU. + * + * @param[in] dev device that changed it's mode + * @param[in] new_mode the new transmission mode + */ +bool at86rf215_switch_mode(at86rf215_t *dev, uint8_t new_mode); + +/** + * @brief Block while the device is busy sending + * + * @param[in] dev device that might be TXing + */ +void at86rf215_block_while_busy(at86rf215_t *dev); + +/** + * @brief Checks whether the device operates in the sub-GHz band. + * + * @param[in] dev device to read from + * + * @return true if the device operates in the sub-GHz band + * false if the device operates in the 2.4-GHz band + */ +static inline bool is_subGHz(const at86rf215_t *dev) +{ + return dev->RF->RG_IRQS == RG_RF09_IRQS; +} + +#ifdef __cplusplus +} +#endif + +#endif /* AT86RF215_INTERNAL_H */ +/** @} */ diff --git a/drivers/at86rf215/include/at86rf215_netdev.h b/drivers/at86rf215/include/at86rf215_netdev.h new file mode 100644 index 0000000000..f683f8ef32 --- /dev/null +++ b/drivers/at86rf215/include/at86rf215_netdev.h @@ -0,0 +1,39 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Netdev interface to AT86RF215 driver + * + * @author Benjamin Valentin + * @} + */ + +#ifndef AT86RF215_NETDEV_H +#define AT86RF215_NETDEV_H + +#include "net/netdev.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Reference to the netdev device driver struct + */ +extern const netdev_driver_t at86rf215_driver; + +#ifdef __cplusplus +} +#endif + +#endif /* AT86RF215_NETDEV_H */ +/** @} */ diff --git a/drivers/at86rf215/include/at86rf215_params.h b/drivers/at86rf215/include/at86rf215_params.h new file mode 100644 index 0000000000..f9adf3bdc7 --- /dev/null +++ b/drivers/at86rf215/include/at86rf215_params.h @@ -0,0 +1,72 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Default configuration for the AT86RF215 driver + * + * @author Benjamin Valentin + * @} + */ + +#ifndef AT86RF215_PARAMS_H +#define AT86RF215_PARAMS_H + +#include "board.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @name Set default configuration parameters for the AT86RF215 driver + * Example config for EXT3 on same54-xpro + * @{ + */ +#ifndef AT86RF215_PARAM_SPI +#define AT86RF215_PARAM_SPI (SPI_DEV(0)) +#endif +#ifndef AT86RF215_PARAM_SPI_CLK +#define AT86RF215_PARAM_SPI_CLK (SPI_CLK_5MHZ) +#endif +#ifndef AT86RF215_PARAM_CS +#define AT86RF215_PARAM_CS (GPIO_PIN(3, 14)) +#endif +#ifndef AT86RF215_PARAM_INT +#define AT86RF215_PARAM_INT (GPIO_PIN(3, 30)) +#endif +#ifndef AT86RF215_PARAM_RESET +#define AT86RF215_PARAM_RESET (GPIO_PIN(4, 10)) +#endif + +#ifndef AT86RF215_PARAMS +#define AT86RF215_PARAMS { .spi = AT86RF215_PARAM_SPI, \ + .spi_clk = AT86RF215_PARAM_SPI_CLK, \ + .cs_pin = AT86RF215_PARAM_CS, \ + .int_pin = AT86RF215_PARAM_INT, \ + .reset_pin = AT86RF215_PARAM_RESET } +#endif +/**@}*/ + +/** + * @brief AT86RF215 configuration + */ +static const at86rf215_params_t at86rf215_params[] = +{ + AT86RF215_PARAMS +}; + +#ifdef __cplusplus +} +#endif + +#endif /* AT86RF215_PARAMS_H */ +/** @} */ diff --git a/drivers/at86rf215/include/at86rf215_registers.h b/drivers/at86rf215/include/at86rf215_registers.h new file mode 100644 index 0000000000..bf08e15cb6 --- /dev/null +++ b/drivers/at86rf215/include/at86rf215_registers.h @@ -0,0 +1,618 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 drivers_at86rf215 + * @{ + * + * @file + * @brief Register Definitions for the AT86RF215 chip + * + * @author Benjamin Valentin + * @} + */ + +#ifndef AT86RF215_REGISTERS_H +#define AT86RF215_REGISTERS_H + +#include +#include "vendor/at86rf215.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Radio Frontend registers + * @{ + */ +struct at86rf215_RF_regs { + uint16_t RG_IRQS; /**< see datasheet */ + uint16_t RG_IRQM; /**< see datasheet */ + uint16_t RG_AUXS; /**< see datasheet */ + uint16_t RG_STATE; /**< see datasheet */ + uint16_t RG_CMD; /**< see datasheet */ + uint16_t RG_CS; /**< see datasheet */ + uint16_t RG_CCF0L; /**< see datasheet */ + uint16_t RG_CCF0H; /**< see datasheet */ + uint16_t RG_CNL; /**< see datasheet */ + uint16_t RG_CNM; /**< see datasheet */ + uint16_t RG_RXBWC; /**< see datasheet */ + uint16_t RG_RXDFE; /**< see datasheet */ + uint16_t RG_AGCC; /**< see datasheet */ + uint16_t RG_AGCS; /**< see datasheet */ + uint16_t RG_RSSI; /**< see datasheet */ + uint16_t RG_EDC; /**< see datasheet */ + uint16_t RG_EDD; /**< see datasheet */ + uint16_t RG_EDV; /**< see datasheet */ + uint16_t RG_RNDV; /**< see datasheet */ + uint16_t RG_TXCUTC; /**< see datasheet */ + uint16_t RG_TXDFE; /**< see datasheet */ + uint16_t RG_PAC; /**< see datasheet */ + uint16_t RG_PADFE; /**< see datasheet */ + uint16_t RG_PLL; /**< see datasheet */ + uint16_t RG_PLLCF; /**< see datasheet */ + uint16_t RG_TXCI; /**< see datasheet */ + uint16_t RG_TXCQ; /**< see datasheet */ + uint16_t RG_TXDACI; /**< see datasheet */ + uint16_t RG_TXDACQ; /**< see datasheet */ +}; +/** @} */ + +/** + * @brief Base Band Controller registers + * @{ + */ +struct at86rf215_BBC_regs { + uint16_t RG_IRQS; /**< see datasheet */ + uint16_t RG_FBRXS; /**< see datasheet */ + uint16_t RG_FBRXE; /**< see datasheet */ + uint16_t RG_FBTXS; /**< see datasheet */ + uint16_t RG_FBTXE; /**< see datasheet */ + uint16_t RG_IRQM; /**< see datasheet */ + uint16_t RG_PC; /**< see datasheet */ + uint16_t RG_PS; /**< see datasheet */ + uint16_t RG_RXFLL; /**< see datasheet */ + uint16_t RG_RXFLH; /**< see datasheet */ + uint16_t RG_TXFLL; /**< see datasheet */ + uint16_t RG_TXFLH; /**< see datasheet */ + uint16_t RG_FBLL; /**< see datasheet */ + uint16_t RG_FBLH; /**< see datasheet */ + uint16_t RG_FBLIL; /**< see datasheet */ + uint16_t RG_FBLIH; /**< see datasheet */ + uint16_t RG_OFDMPHRTX; /**< see datasheet */ + uint16_t RG_OFDMPHRRX; /**< see datasheet */ + uint16_t RG_OFDMC; /**< see datasheet */ + uint16_t RG_OFDMSW; /**< see datasheet */ + uint16_t RG_OQPSKC0; /**< see datasheet */ + uint16_t RG_OQPSKC1; /**< see datasheet */ + uint16_t RG_OQPSKC2; /**< see datasheet */ + uint16_t RG_OQPSKC3; /**< see datasheet */ + uint16_t RG_OQPSKPHRTX; /**< see datasheet */ + uint16_t RG_OQPSKPHRRX; /**< see datasheet */ + uint16_t RG_AFC0; /**< see datasheet */ + uint16_t RG_AFC1; /**< see datasheet */ + uint16_t RG_AFFTM; /**< see datasheet */ + uint16_t RG_AFFVM; /**< see datasheet */ + uint16_t RG_AFS; /**< see datasheet */ + uint16_t RG_MACEA0; /**< see datasheet */ + uint16_t RG_MACEA1; /**< see datasheet */ + uint16_t RG_MACEA2; /**< see datasheet */ + uint16_t RG_MACEA3; /**< see datasheet */ + uint16_t RG_MACEA4; /**< see datasheet */ + uint16_t RG_MACEA5; /**< see datasheet */ + uint16_t RG_MACEA6; /**< see datasheet */ + uint16_t RG_MACEA7; /**< see datasheet */ + uint16_t RG_MACPID0F0; /**< see datasheet */ + uint16_t RG_MACPID1F0; /**< see datasheet */ + uint16_t RG_MACSHA0F0; /**< see datasheet */ + uint16_t RG_MACSHA1F0; /**< see datasheet */ + uint16_t RG_MACPID0F1; /**< see datasheet */ + uint16_t RG_MACPID1F1; /**< see datasheet */ + uint16_t RG_MACSHA0F1; /**< see datasheet */ + uint16_t RG_MACSHA1F1; /**< see datasheet */ + uint16_t RG_MACPID0F2; /**< see datasheet */ + uint16_t RG_MACPID1F2; /**< see datasheet */ + uint16_t RG_MACSHA0F2; /**< see datasheet */ + uint16_t RG_MACSHA1F2; /**< see datasheet */ + uint16_t RG_MACPID0F3; /**< see datasheet */ + uint16_t RG_MACPID1F3; /**< see datasheet */ + uint16_t RG_MACSHA0F3; /**< see datasheet */ + uint16_t RG_MACSHA1F3; /**< see datasheet */ + uint16_t RG_AMCS; /**< see datasheet */ + uint16_t RG_AMEDT; /**< see datasheet */ + uint16_t RG_AMAACKPD; /**< see datasheet */ + uint16_t RG_AMAACKTL; /**< see datasheet */ + uint16_t RG_AMAACKTH; /**< see datasheet */ + uint16_t RG_FSKC0; /**< see datasheet */ + uint16_t RG_FSKC1; /**< see datasheet */ + uint16_t RG_FSKC2; /**< see datasheet */ + uint16_t RG_FSKC3; /**< see datasheet */ + uint16_t RG_FSKC4; /**< see datasheet */ + uint16_t RG_FSKPLL; /**< see datasheet */ + uint16_t RG_FSKSFD0L; /**< see datasheet */ + uint16_t RG_FSKSFD0H; /**< see datasheet */ + uint16_t RG_FSKSFD1L; /**< see datasheet */ + uint16_t RG_FSKSFD1H; /**< see datasheet */ + uint16_t RG_FSKPHRTX; /**< see datasheet */ + uint16_t RG_FSKPHRRX; /**< see datasheet */ + uint16_t RG_FSKRPC; /**< see datasheet */ + uint16_t RG_FSKRPCONT; /**< see datasheet */ + uint16_t RG_FSKRPCOFFT; /**< see datasheet */ + uint16_t RG_FSKRRXFLL; /**< see datasheet */ + uint16_t RG_FSKRRXFLH; /**< see datasheet */ + uint16_t RG_FSKDM; /**< see datasheet */ + uint16_t RG_FSKPE0; /**< see datasheet */ + uint16_t RG_FSKPE1; /**< see datasheet */ + uint16_t RG_FSKPE2; /**< see datasheet */ + uint16_t RG_PMUC; /**< see datasheet */ + uint16_t RG_PMUVAL; /**< see datasheet */ + uint16_t RG_PMUQF; /**< see datasheet */ + uint16_t RG_PMUI; /**< see datasheet */ + uint16_t RG_PMUQ; /**< see datasheet */ + uint16_t RG_CNTC; /**< see datasheet */ + uint16_t RG_CNT0; /**< see datasheet */ + uint16_t RG_CNT1; /**< see datasheet */ + uint16_t RG_CNT2; /**< see datasheet */ + uint16_t RG_CNT3; /**< see datasheet */ +}; +/** @} */ + +/** + * @name sub-GHz Radio Frontend register map + * @{ + */ +static const struct at86rf215_RF_regs RF09_regs = { + .RG_IRQS = 0x00, + .RG_IRQM = 0x100, + .RG_AUXS = 0x101, + .RG_STATE = 0x102, + .RG_CMD = 0x103, + .RG_CS = 0x104, + .RG_CCF0L = 0x105, + .RG_CCF0H = 0x106, + .RG_CNL = 0x107, + .RG_CNM = 0x108, + .RG_RXBWC = 0x109, + .RG_RXDFE = 0x10A, + .RG_AGCC = 0x10B, + .RG_AGCS = 0x10C, + .RG_RSSI = 0x10D, + .RG_EDC = 0x10E, + .RG_EDD = 0x10F, + .RG_EDV = 0x110, + .RG_RNDV = 0x111, + .RG_TXCUTC = 0x112, + .RG_TXDFE = 0x113, + .RG_PAC = 0x114, + .RG_PADFE = 0x116, + .RG_PLL = 0x121, + .RG_PLLCF = 0x122, + .RG_TXCI = 0x125, + .RG_TXCQ = 0x126, + .RG_TXDACI = 0x127, + .RG_TXDACQ = 0x128, +}; +/** @} */ + +/** + * @name 2.4 GHz Radio Frontend register map + * @{ + */ +static const struct at86rf215_RF_regs RF24_regs = { + .RG_IRQS = 0x01, + .RG_IRQM = 0x200, + .RG_AUXS = 0x201, + .RG_STATE = 0x202, + .RG_CMD = 0x203, + .RG_CS = 0x204, + .RG_CCF0L = 0x205, + .RG_CCF0H = 0x206, + .RG_CNL = 0x207, + .RG_CNM = 0x208, + .RG_RXBWC = 0x209, + .RG_RXDFE = 0x20A, + .RG_AGCC = 0x20B, + .RG_AGCS = 0x20C, + .RG_RSSI = 0x20D, + .RG_EDC = 0x20E, + .RG_EDD = 0x20F, + .RG_EDV = 0x210, + .RG_RNDV = 0x211, + .RG_TXCUTC = 0x212, + .RG_TXDFE = 0x213, + .RG_PAC = 0x214, + .RG_PADFE = 0x216, + .RG_PLL = 0x221, + .RG_PLLCF = 0x222, + .RG_TXCI = 0x225, + .RG_TXCQ = 0x226, + .RG_TXDACI = 0x227, + .RG_TXDACQ = 0x228, +}; +/** @} */ + +/** + * @name sub-GHz Radio Frontend register map + * @{ + */ +static const struct at86rf215_BBC_regs BBC0_regs = { + .RG_IRQS = 0x02, + .RG_FBRXS = 0x2000, + .RG_FBRXE = 0x27FE, + .RG_FBTXS = 0x2800, + .RG_FBTXE = 0x2FFE, + .RG_IRQM = 0x300, + .RG_PC = 0x301, + .RG_PS = 0x302, + .RG_RXFLL = 0x304, + .RG_RXFLH = 0x305, + .RG_TXFLL = 0x306, + .RG_TXFLH = 0x307, + .RG_FBLL = 0x308, + .RG_FBLH = 0x309, + .RG_FBLIL = 0x30A, + .RG_FBLIH = 0x30B, + .RG_OFDMPHRTX = 0x30C, + .RG_OFDMPHRRX = 0x30D, + .RG_OFDMC = 0x30E, + .RG_OFDMSW = 0x30F, + .RG_OQPSKC0 = 0x310, + .RG_OQPSKC1 = 0x311, + .RG_OQPSKC2 = 0x312, + .RG_OQPSKC3 = 0x313, + .RG_OQPSKPHRTX = 0x314, + .RG_OQPSKPHRRX = 0x315, + .RG_AFC0 = 0x320, + .RG_AFC1 = 0x321, + .RG_AFFTM = 0x322, + .RG_AFFVM = 0x323, + .RG_AFS = 0x324, + .RG_MACEA0 = 0x325, + .RG_MACEA1 = 0x326, + .RG_MACEA2 = 0x327, + .RG_MACEA3 = 0x328, + .RG_MACEA4 = 0x329, + .RG_MACEA5 = 0x32A, + .RG_MACEA6 = 0x32B, + .RG_MACEA7 = 0x32C, + .RG_MACPID0F0 = 0x32D, + .RG_MACPID1F0 = 0x32E, + .RG_MACSHA0F0 = 0x32F, + .RG_MACSHA1F0 = 0x330, + .RG_MACPID0F1 = 0x331, + .RG_MACPID1F1 = 0x332, + .RG_MACSHA0F1 = 0x333, + .RG_MACSHA1F1 = 0x334, + .RG_MACPID0F2 = 0x335, + .RG_MACPID1F2 = 0x336, + .RG_MACSHA0F2 = 0x337, + .RG_MACSHA1F2 = 0x338, + .RG_MACPID0F3 = 0x339, + .RG_MACPID1F3 = 0x33A, + .RG_MACSHA0F3 = 0x33B, + .RG_MACSHA1F3 = 0x33C, + .RG_AMCS = 0x340, + .RG_AMEDT = 0x341, + .RG_AMAACKPD = 0x342, + .RG_AMAACKTL = 0x343, + .RG_AMAACKTH = 0x344, + .RG_FSKC0 = 0x360, + .RG_FSKC1 = 0x361, + .RG_FSKC2 = 0x362, + .RG_FSKC3 = 0x363, + .RG_FSKC4 = 0x364, + .RG_FSKPLL = 0x365, + .RG_FSKSFD0L = 0x366, + .RG_FSKSFD0H = 0x367, + .RG_FSKSFD1L = 0x368, + .RG_FSKSFD1H = 0x369, + .RG_FSKPHRTX = 0x36A, + .RG_FSKPHRRX = 0x36B, + .RG_FSKRPC = 0x36C, + .RG_FSKRPCONT = 0x36D, + .RG_FSKRPCOFFT = 0x36E, + .RG_FSKRRXFLL = 0x370, + .RG_FSKRRXFLH = 0x371, + .RG_FSKDM = 0x372, + .RG_FSKPE0 = 0x373, + .RG_FSKPE1 = 0x374, + .RG_FSKPE2 = 0x375, + .RG_PMUC = 0x380, + .RG_PMUVAL = 0x381, + .RG_PMUQF = 0x382, + .RG_PMUI = 0x383, + .RG_PMUQ = 0x384, + .RG_CNTC = 0x390, + .RG_CNT0 = 0x391, + .RG_CNT1 = 0x392, + .RG_CNT2 = 0x393, + .RG_CNT3 = 0x394, +}; +/** @} */ + +/** + * @name 2.4 GHz Radio Frontend register map + * @{ + */ +static const struct at86rf215_BBC_regs BBC1_regs = { + .RG_IRQS = 0x03, + .RG_FBRXS = 0x3000, + .RG_FBRXE = 0x37FE, + .RG_FBTXS = 0x3800, + .RG_FBTXE = 0x3FFE, + .RG_IRQM = 0x400, + .RG_PC = 0x401, + .RG_PS = 0x402, + .RG_RXFLL = 0x404, + .RG_RXFLH = 0x405, + .RG_TXFLL = 0x406, + .RG_TXFLH = 0x407, + .RG_FBLL = 0x408, + .RG_FBLH = 0x409, + .RG_FBLIL = 0x40A, + .RG_FBLIH = 0x40B, + .RG_OFDMPHRTX = 0x40C, + .RG_OFDMPHRRX = 0x40D, + .RG_OFDMC = 0x40E, + .RG_OFDMSW = 0x40F, + .RG_OQPSKC0 = 0x410, + .RG_OQPSKC1 = 0x411, + .RG_OQPSKC2 = 0x412, + .RG_OQPSKC3 = 0x413, + .RG_OQPSKPHRTX = 0x414, + .RG_OQPSKPHRRX = 0x415, + .RG_AFC0 = 0x420, + .RG_AFC1 = 0x421, + .RG_AFFTM = 0x422, + .RG_AFFVM = 0x423, + .RG_AFS = 0x424, + .RG_MACEA0 = 0x425, + .RG_MACEA1 = 0x426, + .RG_MACEA2 = 0x427, + .RG_MACEA3 = 0x428, + .RG_MACEA4 = 0x429, + .RG_MACEA5 = 0x42A, + .RG_MACEA6 = 0x42B, + .RG_MACEA7 = 0x42C, + .RG_MACPID0F0 = 0x42D, + .RG_MACPID1F0 = 0x42E, + .RG_MACSHA0F0 = 0x42F, + .RG_MACSHA1F0 = 0x430, + .RG_MACPID0F1 = 0x431, + .RG_MACPID1F1 = 0x432, + .RG_MACSHA0F1 = 0x433, + .RG_MACSHA1F1 = 0x434, + .RG_MACPID0F2 = 0x435, + .RG_MACPID1F2 = 0x436, + .RG_MACSHA0F2 = 0x437, + .RG_MACSHA1F2 = 0x438, + .RG_MACPID0F3 = 0x439, + .RG_MACPID1F3 = 0x43A, + .RG_MACSHA0F3 = 0x43B, + .RG_MACSHA1F3 = 0x43C, + .RG_AMCS = 0x440, + .RG_AMEDT = 0x441, + .RG_AMAACKPD = 0x442, + .RG_AMAACKTL = 0x443, + .RG_AMAACKTH = 0x444, + .RG_FSKC0 = 0x460, + .RG_FSKC1 = 0x461, + .RG_FSKC2 = 0x462, + .RG_FSKC3 = 0x463, + .RG_FSKC4 = 0x464, + .RG_FSKPLL = 0x465, + .RG_FSKSFD0L = 0x466, + .RG_FSKSFD0H = 0x467, + .RG_FSKSFD1L = 0x468, + .RG_FSKSFD1H = 0x469, + .RG_FSKPHRTX = 0x46A, + .RG_FSKPHRRX = 0x46B, + .RG_FSKRPC = 0x46C, + .RG_FSKRPCONT = 0x46D, + .RG_FSKRPCOFFT = 0x46E, + .RG_FSKRRXFLL = 0x470, + .RG_FSKRRXFLH = 0x471, + .RG_FSKDM = 0x472, + .RG_FSKPE0 = 0x473, + .RG_FSKPE1 = 0x474, + .RG_FSKPE2 = 0x475, + .RG_PMUC = 0x480, + .RG_PMUVAL = 0x481, + .RG_PMUQF = 0x482, + .RG_PMUI = 0x483, + .RG_PMUQ = 0x484, + .RG_CNTC = 0x490, + .RG_CNT0 = 0x491, + .RG_CNT1 = 0x492, + .RG_CNT2 = 0x493, + .RG_CNT3 = 0x494, +}; +/** @} */ + +/** + * @name Part Numbers + * @{ + */ +#define AT86RF215_PN (0x34) /* sub-GHz & 2.4 GHz */ +#define AT86RF215IQ_PN (0x35) /* I/Q radio only */ +#define AT86RF215M_PN (0x36) /* sub-GHz only */ +/** @} */ + +/** + * @name SPI command prefixes + * @{ + */ +#define FLAG_WRITE 0x8000 +#define FLAG_READ 0x0000 +/** @} */ + +/** + * @name Radio Commands written to RF->RG_CMD + * @{ + */ +#define CMD_RF_NOP 0x0 +#define CMD_RF_SLEEP 0x1 +#define CMD_RF_TRXOFF 0x2 +#define CMD_RF_TXPREP 0x3 +#define CMD_RF_TX 0x4 +#define CMD_RF_RX 0x5 +#define CMD_RF_RESET 0x7 /* transceiver reset, the transceiver state + will automatically end up in state TRXOFF */ +/** @} */ + +/** + * @name Radio States, read from RF->RG_STATE + * @{ + */ +#define RF_STATE_TRXOFF 0x2 /* Transceiver off, SPI active */ +#define RF_STATE_TXPREP 0x3 /* Transmit preparation */ +#define RF_STATE_TX 0x4 /* Transmit */ +#define RF_STATE_RX 0x5 /* Receive */ +#define RF_STATE_TRANSITION 0x6 /* State transition in progress */ +#define RF_STATE_RESET 0x7 /* Transceiver is in state RESET or SLEEP */ +/** @} */ + +/** offset (in Hz) for CCF0 in 2.4 GHz mode */ +#define CCF0_24G_OFFSET 1500000U + +/** The sub-register configures the sampling frequency of the received signal. + * Undefined values are mapped to default setting fS=4000kHz + * @{ + */ +#define RF_SR_4000K 0x1 +#define RF_SR_2000K 0x2 +#define RF_SR_1333K 0x3 +#define RF_SR_1000K 0x4 +#define RF_SR_800K 0x5 +#define RF_SR_666K 0x6 +#define RF_SR_500K 0x8 +#define RF_SR_400K 0xA +/** @} */ + +/* The sub-register configures the relative cut-off frequency fCUT + where 1.0 refers to half the sample frequency fS. */ +/** Fcut = 0.25 * Fs/2 */ +#define RF_RCUT_FS_BY_8 (0x0 << RXDFE_RCUT_SHIFT) +/** Fcut = 0.375 * Fs/2 */ +#define RF_RCUT_FS_BY_5P3 (0x1 << RXDFE_RCUT_SHIFT) +/** Fcut = 0.5 * Fs/2 */ +#define RF_RCUT_FS_BY_4 (0x2 << RXDFE_RCUT_SHIFT) +/** Fcut = 0.75 * Fs/2 */ +#define RF_RCUT_FS_BY_2P6 (0x3 << RXDFE_RCUT_SHIFT) +/** Fcut = 1.0 * Fs/2 */ +#define RF_RCUT_FS_BY_2 (0x4 << RXDFE_RCUT_SHIFT) + +/** The averaging time is calculated by T[μs]=DF*DTB. + * @{ + */ +#define RF_DTB_2_US 0x0 +#define RF_DTB_8_US 0x1 +#define RF_DTB_32_US 0x2 +#define RF_DTB_128_US 0x3 +/** @} */ + +/** BPSK, rate ½, 4 x frequency repetition */ +#define BB_MCS_BPSK_REP4 0 +/** BPSK, rate ½, 2 x frequency repetition */ +#define BB_MCS_BPSK_REP2 1 +/** QPSK, rate ½, 2 x frequency repetition */ +#define BB_MCS_QPSK_REP2 2 +/** QPSK, rate ½ */ +#define BB_MCS_QPSK_1BY2 3 +/** QPSK, rate ¾ */ +#define BB_MCS_QPSK_3BY4 4 +/** 16-QAM, rate ½ */ +#define BB_MCS_16QAM_1BY2 5 +/** 16-QAM, rate ¾ */ +#define BB_MCS_16QAM_3BY4 6 + +/** receive only MR-O-QPSK */ +#define RXM_MR_OQPSK 0x0 +/** receive only legacy O-QPSK */ +#define RXM_LEGACY_OQPSK 0x1 +/** receive both legacy & MR-O-QPSK */ +#define RXM_BOTH_OQPSK 0x2 +/** receive nothing */ +#define RXM_DISABLE 0x3 + +/** Modulation Order 2-FSK */ +#define FSK_MORD_2SFK (0 << FSKC0_MORD_SHIFT) +/** Modulation Order 4-FSK */ +#define FSK_MORD_4SFK (1 << FSKC0_MORD_SHIFT) + +/** + * FSK modulation index + * @{ + */ +#define FSK_MIDX_3_BY_8 (0 << FSKC0_MIDX_SHIFT) +#define FSK_MIDX_4_BY_8 (1 << FSKC0_MIDX_SHIFT) +#define FSK_MIDX_6_BY_8 (2 << FSKC0_MIDX_SHIFT) +#define FSK_MIDX_8_BY_8 (3 << FSKC0_MIDX_SHIFT) +#define FSK_MIDX_10_BY_8 (4 << FSKC0_MIDX_SHIFT) +#define FSK_MIDX_12_BY_8 (5 << FSKC0_MIDX_SHIFT) +#define FSK_MIDX_14_BY_8 (6 << FSKC0_MIDX_SHIFT) +#define FSK_MIDX_16_BY_8 (7 << FSKC0_MIDX_SHIFT) +/** @} */ + +/** + * FSK modulation index scale + * @{ + */ +#define FSK_MIDXS_SCALE_7_BY_8 (0 << FSKC0_MIDXS_SHIFT) +#define FSK_MIDXS_SCALE_8_BY_8 (1 << FSKC0_MIDXS_SHIFT) +#define FSK_MIDXS_SCALE_9_BY_8 (2 << FSKC0_MIDXS_SHIFT) +#define FSK_MIDXS_SCALE_10_BY_8 (3 << FSKC0_MIDXS_SHIFT) +/** @} */ + +/** + * FSK bandwidth time product + * @{ + */ +#define FSK_BT_05 (0 << FSKC0_BT_SHIFT) +#define FSK_BT_10 (1 << FSKC0_BT_SHIFT) +#define FSK_BT_15 (2 << FSKC0_BT_SHIFT) +#define FSK_BT_20 (3 << FSKC0_BT_SHIFT) +/** @} */ + +/** + * FSK symbol rate (kHz) + * @{ + */ +#define FSK_SRATE_50K 0x0 +#define FSK_SRATE_100K 0x1 +#define FSK_SRATE_150K 0x2 +#define FSK_SRATE_200K 0x3 +#define FSK_SRATE_300K 0x4 +#define FSK_SRATE_400K 0x5 +/** @} */ + +/** + * FSK channel spacing (kHz) + * @{ + */ +#define FSK_CHANNEL_SPACING_200K 0x0 +#define FSK_CHANNEL_SPACING_400K 0x1 +/** @} */ + +/** Lower values increase the SFD detector sensitivity. + Higher values increase the SFD selectivity. + The default value 8 is recommended for simultaneous sensing + of the SFD pairs according to IEEE 802.15.4g. */ +#define FSKC3_SFDT(n) (((n) << FSKC3_SFDT_SHIFT) & FSKC3_SFDT_MASK) + +/** Lower values increase the preamble detector sensitivity. */ +#define FSKC3_PDT(n) (((n) << FSKC3_PDT_SHIFT) & FSKC3_PDT_MASK) + +/** @} */ + +#ifdef __cplusplus +} +#endif + +#endif /* AT86RF215_REGISTERS_H */ diff --git a/drivers/at86rf215/include/vendor/at86rf215.h b/drivers/at86rf215/include/vendor/at86rf215.h new file mode 100644 index 0000000000..85b7cafd13 --- /dev/null +++ b/drivers/at86rf215/include/vendor/at86rf215.h @@ -0,0 +1,4722 @@ +/** + * @file at86rf215.h + * + * @brief File contains register and command defines specific for RF215. + * + * Copyright (c) 2015-2018 Microchip Technology Inc. and its subsidiaries. + * + * \asf_license_start + * + * \page License + * + * Subject to your compliance with these terms, you may use Microchip + * software and any derivatives exclusively with Microchip products. + * It is your responsibility to comply with third party license terms applicable + * to your use of third party software (including open source software) that + * may accompany Microchip software. + * + * THIS SOFTWARE IS SUPPLIED BY MICROCHIP "AS IS". NO WARRANTIES, + * WHETHER EXPRESS, IMPLIED OR STATUTORY, APPLY TO THIS SOFTWARE, + * INCLUDING ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, + * AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT WILL MICROCHIP BE + * LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL OR CONSEQUENTIAL + * LOSS, DAMAGE, COST OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE + * SOFTWARE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE + * POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT + * ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY + * RELATED TO THIS SOFTWARE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, + * THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THIS SOFTWARE. + * + * \asf_license_stop + */ + +/* + * Copyright (c) 2015-2018, Microchip Technology Inc All rights reserved. + * + * Licensed under Atmel's Limited License Agreement --> EULA.txt + */ + +/* Prevent double inclusion */ +#ifndef RF215_H +#define RF215_H + +/* === EXTERNALS =========================================================== */ + +/* === TYPES =============================================================== */ + +/* === MACROS ============================================================== */ + +/** Parameter definitions */ + +/** Typical timing values. */ +/* TRX Parameter: SPI_T2 */ +#define RST_PULSE_WIDTH_NS (5) + +/** Subregister Type Definitions (MASK, SHIFT) */ + +/** Sub-registers of Register @ref IRQS */ +/** Bit Mask for Sub-Register IRQS.WAKEUP */ +#define IRQS_WAKEUP_MASK 0x01 +/** Bit Offset for Sub-Register IRQS.WAKEUP */ +#define IRQS_WAKEUP_SHIFT 0 + +/** Bit Mask for Sub-Register IRQS.TRXRDY */ +#define IRQS_TRXRDY_MASK 0x02 +/** Bit Offset for Sub-Register IRQS.TRXRDY */ +#define IRQS_TRXRDY_SHIFT 1 + +/** Bit Mask for Sub-Register IRQS.EDC */ +#define IRQS_EDC_MASK 0x04 +/** Bit Offset for Sub-Register IRQS.EDC */ +#define IRQS_EDC_SHIFT 2 + +/** Bit Mask for Sub-Register IRQS.BATLOW */ +#define IRQS_BATLOW_MASK 0x08 +/** Bit Offset for Sub-Register IRQS.BATLOW */ +#define IRQS_BATLOW_SHIFT 3 + +/** Bit Mask for Sub-Register IRQS.TRXERR */ +#define IRQS_TRXERR_MASK 0x10 +/** Bit Offset for Sub-Register IRQS.TRXERR */ +#define IRQS_TRXERR_SHIFT 4 + +/** Bit Mask for Sub-Register IRQS.IQIFSF */ +#define IRQS_IQIFSF_MASK 0x20 +/** Bit Offset for Sub-Register IRQS.IQIFSF */ +#define IRQS_IQIFSF_SHIFT 5 + +/** Sub-registers of Register @ref IRQS */ +/** Bit Mask for Sub-Register IRQS.RXFS */ +#define IRQS_RXFS_MASK 0x01 +/** Bit Offset for Sub-Register IRQS.RXFS */ +#define IRQS_RXFS_SHIFT 0 + +/** Bit Mask for Sub-Register IRQS.RXFE */ +#define IRQS_RXFE_MASK 0x02 +/** Bit Offset for Sub-Register IRQS.RXFE */ +#define IRQS_RXFE_SHIFT 1 + +/** Bit Mask for Sub-Register IRQS.RXAM */ +#define IRQS_RXAM_MASK 0x04 +/** Bit Offset for Sub-Register IRQS.RXAM */ +#define IRQS_RXAM_SHIFT 2 + +/** Bit Mask for Sub-Register IRQS.RXEM */ +#define IRQS_RXEM_MASK 0x08 +/** Bit Offset for Sub-Register IRQS.RXEM */ +#define IRQS_RXEM_SHIFT 3 + +/** Bit Mask for Sub-Register IRQS.TXFE */ +#define IRQS_TXFE_MASK 0x10 +/** Bit Offset for Sub-Register IRQS.TXFE */ +#define IRQS_TXFE_SHIFT 4 + +/** Bit Mask for Sub-Register IRQS.AGCH */ +#define IRQS_AGCH_MASK 0x20 +/** Bit Offset for Sub-Register IRQS.AGCH */ +#define IRQS_AGCH_SHIFT 5 + +/** Bit Mask for Sub-Register IRQS.AGCR */ +#define IRQS_AGCR_MASK 0x40 +/** Bit Offset for Sub-Register IRQS.AGCR */ +#define IRQS_AGCR_SHIFT 6 + +/** Bit Mask for Sub-Register IRQS.FBLI */ +#define IRQS_FBLI_MASK 0x80 +/** Bit Offset for Sub-Register IRQS.FBLI */ +#define IRQS_FBLI_SHIFT 7 + +/** Sub-registers of Register @ref RST */ +/** Bit Mask for Sub-Register RST.CMD */ +#define RST_CMD_MASK 0x07 +/** Bit Offset for Sub-Register RST.CMD */ +#define RST_CMD_SHIFT 0 + +/** Sub-registers of Register @ref CFG */ +/** Bit Mask for Sub-Register CFG.DRV */ +#define CFG_DRV_MASK 0x03 +/** Bit Offset for Sub-Register CFG.DRV */ +#define CFG_DRV_SHIFT 0 + +/** Bit Mask for Sub-Register CFG.IRQP */ +#define CFG_IRQP_MASK 0x04 +/** Bit Offset for Sub-Register CFG.IRQP */ +#define CFG_IRQP_SHIFT 2 + +/** Bit Mask for Sub-Register CFG.IRQMM */ +#define CFG_IRQMM_MASK 0x08 +/** Bit Offset for Sub-Register CFG.IRQMM */ +#define CFG_IRQMM_SHIFT 3 + +/** Sub-registers of Register @ref CLKO */ +/** Bit Mask for Sub-Register CLKO.OS */ +#define CLKO_OS_MASK 0x07 +/** Bit Offset for Sub-Register CLKO.OS */ +#define CLKO_OS_SHIFT 0 + +/** Bit Mask for Sub-Register CLKO.DRV */ +#define CLKO_DRV_MASK 0x18 +/** Bit Offset for Sub-Register CLKO.DRV */ +#define CLKO_DRV_SHIFT 3 + +/** Sub-registers of Register @ref BMDVC */ +/** Bit Mask for Sub-Register BMDVC.BMVTH */ +#define BMDVC_BMVTH_MASK 0x0F +/** Bit Offset for Sub-Register BMDVC.BMVTH */ +#define BMDVC_BMVTH_SHIFT 0 + +/** Bit Mask for Sub-Register BMDVC.BMHR */ +#define BMDVC_BMHR_MASK 0x10 +/** Bit Offset for Sub-Register BMDVC.BMHR */ +#define BMDVC_BMHR_SHIFT 4 + +/** Bit Mask for Sub-Register BMDVC.BMS */ +#define BMDVC_BMS_MASK 0x20 +/** Bit Offset for Sub-Register BMDVC.BMS */ +#define BMDVC_BMS_SHIFT 5 + +/** Sub-registers of Register @ref XOC */ +/** Bit Mask for Sub-Register XOC.TRIM */ +#define XOC_TRIM_MASK 0x0F +/** Bit Offset for Sub-Register XOC.TRIM */ +#define XOC_TRIM_SHIFT 0 + +/** Bit Mask for Sub-Register XOC.FS */ +#define XOC_FS_MASK 0x10 +/** Bit Offset for Sub-Register XOC.FS */ +#define XOC_FS_SHIFT 4 + +/** Sub-registers of Register @ref IQIFC0 */ +/** Bit Mask for Sub-Register IQIFC0.EEC */ +#define IQIFC0_EEC_MASK 0x01 +/** Bit Offset for Sub-Register IQIFC0.EEC */ +#define IQIFC0_EEC_SHIFT 0 + +/** Bit Mask for Sub-Register IQIFC0.CMV1V2 */ +#define IQIFC0_CMV1V2_MASK 0x02 +/** Bit Offset for Sub-Register IQIFC0.CMV1V2 */ +#define IQIFC0_CMV1V2_SHIFT 1 + +/** Bit Mask for Sub-Register IQIFC0.CMV */ +#define IQIFC0_CMV_MASK 0x0C +/** Bit Offset for Sub-Register IQIFC0.CMV */ +#define IQIFC0_CMV_SHIFT 2 + +/** Bit Mask for Sub-Register IQIFC0.DRV */ +#define IQIFC0_DRV_MASK 0x30 +/** Bit Offset for Sub-Register IQIFC0.DRV */ +#define IQIFC0_DRV_SHIFT 4 + +/** Bit Mask for Sub-Register IQIFC0.SF */ +#define IQIFC0_SF_MASK 0x40 +/** Bit Offset for Sub-Register IQIFC0.SF */ +#define IQIFC0_SF_SHIFT 6 + +/** Bit Mask for Sub-Register IQIFC0.EXTLB */ +#define IQIFC0_EXTLB_MASK 0x80 +/** Bit Offset for Sub-Register IQIFC0.EXTLB */ +#define IQIFC0_EXTLB_SHIFT 7 + +/** Sub-registers of Register @ref IQIFC1 */ +/** Bit Mask for Sub-Register IQIFC1.SKEWDRV */ +#define IQIFC1_SKEWDRV_MASK 0x03 +/** Bit Offset for Sub-Register IQIFC1.SKEWDRV */ +#define IQIFC1_SKEWDRV_SHIFT 0 + +/** Bit Mask for Sub-Register IQIFC1.CHPM */ +#define IQIFC1_CHPM_MASK 0x70 +/** Bit Offset for Sub-Register IQIFC1.CHPM */ +#define IQIFC1_CHPM_SHIFT 4 + +/** Bit Mask for Sub-Register IQIFC1.FAILSF */ +#define IQIFC1_FAILSF_MASK 0x80 +/** Bit Offset for Sub-Register IQIFC1.FAILSF */ +#define IQIFC1_FAILSF_SHIFT 7 + +/** Sub-registers of Register @ref IQIFC2 */ +/** Bit Mask for Sub-Register IQIFC2.SYNC */ +#define IQIFC2_SYNC_MASK 0x80 +/** Bit Offset for Sub-Register IQIFC2.SYNC */ +#define IQIFC2_SYNC_SHIFT 7 + +/** Sub-registers of Register @ref PN */ +/** Bit Mask for Sub-Register PN.PN */ +#define PN_PN_MASK 0xFF +/** Bit Offset for Sub-Register PN.PN */ +#define PN_PN_SHIFT 0 + +/** Sub-registers of Register @ref VN */ +/** Bit Mask for Sub-Register VN.VN */ +#define VN_VN_MASK 0xFF +/** Bit Offset for Sub-Register VN.VN */ +#define VN_VN_SHIFT 0 + +/** Sub-registers of Register @ref IRQM */ +/** Bit Mask for Sub-Register IRQM.WAKEUP */ +#define IRQM_WAKEUP_MASK 0x01 +/** Bit Offset for Sub-Register IRQM.WAKEUP */ +#define IRQM_WAKEUP_SHIFT 0 + +/** Bit Mask for Sub-Register IRQM.TRXRDY */ +#define IRQM_TRXRDY_MASK 0x02 +/** Bit Offset for Sub-Register IRQM.TRXRDY */ +#define IRQM_TRXRDY_SHIFT 1 + +/** Bit Mask for Sub-Register IRQM.EDC */ +#define IRQM_EDC_MASK 0x04 +/** Bit Offset for Sub-Register IRQM.EDC */ +#define IRQM_EDC_SHIFT 2 + +/** Bit Mask for Sub-Register IRQM.BATLOW */ +#define IRQM_BATLOW_MASK 0x08 +/** Bit Offset for Sub-Register IRQM.BATLOW */ +#define IRQM_BATLOW_SHIFT 3 + +/** Bit Mask for Sub-Register IRQM.TRXERR */ +#define IRQM_TRXERR_MASK 0x10 +/** Bit Offset for Sub-Register IRQM.TRXERR */ +#define IRQM_TRXERR_SHIFT 4 + +/** Bit Mask for Sub-Register IRQM.IQIFSF */ +#define IRQM_IQIFSF_MASK 0x20 +/** Bit Offset for Sub-Register IRQM.IQIFSF */ +#define IRQM_IQIFSF_SHIFT 5 + +/** Sub-registers of Register @ref AUXS */ +/** Bit Mask for Sub-Register AUXS.PAVC */ +#define AUXS_PAVC_MASK 0x03 +/** Bit Offset for Sub-Register AUXS.PAVC */ +#define AUXS_PAVC_SHIFT 0 + +/** Bit Mask for Sub-Register AUXS.AVS */ +#define AUXS_AVS_MASK 0x04 +/** Bit Offset for Sub-Register AUXS.AVS */ +#define AUXS_AVS_SHIFT 2 + +/** Bit Mask for Sub-Register AUXS.AVEN */ +#define AUXS_AVEN_MASK 0x08 +/** Bit Offset for Sub-Register AUXS.AVEN */ +#define AUXS_AVEN_SHIFT 3 + +/** Bit Mask for Sub-Register AUXS.AVEXT */ +#define AUXS_AVEXT_MASK 0x10 +/** Bit Offset for Sub-Register AUXS.AVEXT */ +#define AUXS_AVEXT_SHIFT 4 + +/** Bit Mask for Sub-Register AUXS.AGCMAP */ +#define AUXS_AGCMAP_MASK 0x60 +/** Bit Offset for Sub-Register AUXS.AGCMAP */ +#define AUXS_AGCMAP_SHIFT 5 + +/** Bit Mask for Sub-Register AUXS.EXTLNABYP */ +#define AUXS_EXTLNABYP_MASK 0x80 +/** Bit Offset for Sub-Register AUXS.EXTLNABYP */ +#define AUXS_EXTLNABYP_SHIFT 7 + +/** Sub-registers of Register @ref STATE */ +/** Bit Mask for Sub-Register STATE.STATE */ +#define STATE_STATE_MASK 0x07 +/** Bit Offset for Sub-Register STATE.STATE */ +#define STATE_STATE_SHIFT 0 + +/** Sub-registers of Register @ref CMD */ +/** Bit Mask for Sub-Register CMD.CMD */ +#define CMD_CMD_MASK 0x07 +/** Bit Offset for Sub-Register CMD.CMD */ +#define CMD_CMD_SHIFT 0 + +/** Sub-registers of Register @ref CS */ +/** Bit Mask for Sub-Register CS.CS */ +#define CS_CS_MASK 0xFF +/** Bit Offset for Sub-Register CS.CS */ +#define CS_CS_SHIFT 0 + +/** Sub-registers of Register @ref CCF0L */ +/** Bit Mask for Sub-Register CCF0L.CCF0L */ +#define CCF0L_CCF0L_MASK 0xFF +/** Bit Offset for Sub-Register CCF0L.CCF0L */ +#define CCF0L_CCF0L_SHIFT 0 + +/** Sub-registers of Register @ref CCF0H */ +/** Bit Mask for Sub-Register CCF0H.CCF0H */ +#define CCF0H_CCF0H_MASK 0xFF +/** Bit Offset for Sub-Register CCF0H.CCF0H */ +#define CCF0H_CCF0H_SHIFT 0 + +/** Sub-registers of Register @ref CNL */ +/** Bit Mask for Sub-Register CNL.CNL */ +#define CNL_CNL_MASK 0xFF +/** Bit Offset for Sub-Register CNL.CNL */ +#define CNL_CNL_SHIFT 0 + +/** Sub-registers of Register @ref CNM */ +/** Bit Mask for Sub-Register CNM.CNH */ +#define CNM_CNH_MASK 0x01 +/** Bit Offset for Sub-Register CNM.CNH */ +#define CNM_CNH_SHIFT 0 + +/** Bit Mask for Sub-Register CNM.CM */ +#define CNM_CM_MASK 0xC0 +/** Bit Offset for Sub-Register CNM.CM */ +#define CNM_CM_SHIFT 6 + +/** Sub-registers of Register @ref RXBWC */ +/** Bit Mask for Sub-Register RXBWC.BW */ +#define RXBWC_BW_MASK 0x0F +/** Bit Offset for Sub-Register RXBWC.BW */ +#define RXBWC_BW_SHIFT 0 + +/** Bit Mask for Sub-Register RXBWC.IFS */ +#define RXBWC_IFS_MASK 0x10 +/** Bit Offset for Sub-Register RXBWC.IFS */ +#define RXBWC_IFS_SHIFT 4 + +/** Bit Mask for Sub-Register RXBWC.IFI */ +#define RXBWC_IFI_MASK 0x20 +/** Bit Offset for Sub-Register RXBWC.IFI */ +#define RXBWC_IFI_SHIFT 5 + +/** Sub-registers of Register @ref RXDFE */ +/** Bit Mask for Sub-Register RXDFE.SR */ +#define RXDFE_SR_MASK 0x0F +/** Bit Offset for Sub-Register RXDFE.SR */ +#define RXDFE_SR_SHIFT 0 + +/** Bit Mask for Sub-Register RXDFE.RCUT */ +#define RXDFE_RCUT_MASK 0xE0 +/** Bit Offset for Sub-Register RXDFE.RCUT */ +#define RXDFE_RCUT_SHIFT 5 + +/** Sub-registers of Register @ref AGCC */ +/** Bit Mask for Sub-Register AGCC.EN */ +#define AGCC_EN_MASK 0x01 +/** Bit Offset for Sub-Register AGCC.EN */ +#define AGCC_EN_SHIFT 0 + +/** Bit Mask for Sub-Register AGCC.FRZC */ +#define AGCC_FRZC_MASK 0x02 +/** Bit Offset for Sub-Register AGCC.FRZC */ +#define AGCC_FRZC_SHIFT 1 + +/** Bit Mask for Sub-Register AGCC.FRZS */ +#define AGCC_FRZS_MASK 0x04 +/** Bit Offset for Sub-Register AGCC.FRZS */ +#define AGCC_FRZS_SHIFT 2 + +/** Bit Mask for Sub-Register AGCC.RST */ +#define AGCC_RST_MASK 0x08 +/** Bit Offset for Sub-Register AGCC.RST */ +#define AGCC_RST_SHIFT 3 + +/** Bit Mask for Sub-Register AGCC.AVGS */ +#define AGCC_AVGS_MASK 0x30 +/** Bit Offset for Sub-Register AGCC.AVGS */ +#define AGCC_AVGS_SHIFT 4 + +/** Bit Mask for Sub-Register AGCC.AGCI */ +#define AGCC_AGCI_MASK 0x40 +/** Bit Offset for Sub-Register AGCC.AGCI */ +#define AGCC_AGCI_SHIFT 6 + +/** Sub-registers of Register @ref AGCS */ +/** Bit Mask for Sub-Register AGCS.GCW */ +#define AGCS_GCW_MASK 0x1F +/** Bit Offset for Sub-Register AGCS.GCW */ +#define AGCS_GCW_SHIFT 0 + +/** Bit Mask for Sub-Register AGCS.TGT */ +#define AGCS_TGT_MASK 0xE0 +/** Bit Offset for Sub-Register AGCS.TGT */ +#define AGCS_TGT_SHIFT 5 + +/** Sub-registers of Register @ref RSSI */ +/** Bit Mask for Sub-Register RSSI.RSSI */ +#define RSSI_RSSI_MASK 0xFF +/** Bit Offset for Sub-Register RSSI.RSSI */ +#define RSSI_RSSI_SHIFT 0 + +/** Sub-registers of Register @ref EDC */ +/** Bit Mask for Sub-Register EDC.EDM */ +#define EDC_EDM_MASK 0x03 +/** Bit Offset for Sub-Register EDC.EDM */ +#define EDC_EDM_SHIFT 0 + +/** Sub-registers of Register @ref EDD */ +/** Bit Mask for Sub-Register EDD.DTB */ +#define EDD_DTB_MASK 0x03 +/** Bit Offset for Sub-Register EDD.DTB */ +#define EDD_DTB_SHIFT 0 + +/** Bit Mask for Sub-Register EDD.DF */ +#define EDD_DF_MASK 0xFC +/** Bit Offset for Sub-Register EDD.DF */ +#define EDD_DF_SHIFT 2 + +/** Sub-registers of Register @ref EDV */ +/** Bit Mask for Sub-Register EDV.EDV */ +#define EDV_EDV_MASK 0xFF +/** Bit Offset for Sub-Register EDV.EDV */ +#define EDV_EDV_SHIFT 0 + +/** Sub-registers of Register @ref RNDV */ +/** Bit Mask for Sub-Register RNDV.RNDV */ +#define RNDV_RNDV_MASK 0xFF +/** Bit Offset for Sub-Register RNDV.RNDV */ +#define RNDV_RNDV_SHIFT 0 + +/** Sub-registers of Register @ref TXCUTC */ +/** Bit Mask for Sub-Register TXCUTC.LPFCUT */ +#define TXCUTC_LPFCUT_MASK 0x0F +/** Bit Offset for Sub-Register TXCUTC.LPFCUT */ +#define TXCUTC_LPFCUT_SHIFT 0 + +/** Bit Mask for Sub-Register TXCUTC.PARAMP */ +#define TXCUTC_PARAMP_MASK 0xC0 +/** Bit Offset for Sub-Register TXCUTC.PARAMP */ +#define TXCUTC_PARAMP_SHIFT 6 + +/** Sub-registers of Register @ref TXDFE */ +/** Bit Mask for Sub-Register TXDFE.SR */ +#define TXDFE_SR_MASK 0x0F +/** Bit Offset for Sub-Register TXDFE.SR */ +#define TXDFE_SR_SHIFT 0 + +/** Bit Mask for Sub-Register TXDFE.DM */ +#define TXDFE_DM_MASK 0x10 +/** Bit Offset for Sub-Register TXDFE.DM */ +#define TXDFE_DM_SHIFT 4 + +/** Bit Mask for Sub-Register TXDFE.RCUT */ +#define TXDFE_RCUT_MASK 0xE0 +/** Bit Offset for Sub-Register TXDFE.RCUT */ +#define TXDFE_RCUT_SHIFT 5 + +/** Sub-registers of Register @ref PAC */ +/** Bit Mask for Sub-Register PAC.TXPWR */ +#define PAC_TXPWR_MASK 0x1F +/** Bit Offset for Sub-Register PAC.TXPWR */ +#define PAC_TXPWR_SHIFT 0 + +/** Bit Mask for Sub-Register PAC.PACUR */ +#define PAC_PACUR_MASK 0x60 +/** Bit Offset for Sub-Register PAC.PACUR */ +#define PAC_PACUR_SHIFT 5 + +/** Sub-registers of Register @ref PADFE */ +/** Bit Mask for Sub-Register PADFE.PADFE */ +#define PADFE_PADFE_MASK 0xC0 +/** Bit Offset for Sub-Register PADFE.PADFE */ +#define PADFE_PADFE_SHIFT 6 + +/** Sub-registers of Register @ref PLL */ +/** Bit Mask for Sub-Register PLL.LS */ +#define PLL_LS_MASK 0x02 +/** Bit Offset for Sub-Register PLL.LS */ +#define PLL_LS_SHIFT 1 + +/** Bit Mask for Sub-Register PLL.LBW */ +#define PLL_LBW_MASK 0x30 +/** Bit Offset for Sub-Register PLL.LBW */ +#define PLL_LBW_SHIFT 4 + +/** Sub-registers of Register @ref PLLCF */ +/** Bit Mask for Sub-Register PLLCF.CF */ +#define PLLCF_CF_MASK 0x3F +/** Bit Offset for Sub-Register PLLCF.CF */ +#define PLLCF_CF_SHIFT 0 + +/** Sub-registers of Register @ref TXCI */ +/** Bit Mask for Sub-Register TXCI.DCOI */ +#define TXCI_DCOI_MASK 0x3F +/** Bit Offset for Sub-Register TXCI.DCOI */ +#define TXCI_DCOI_SHIFT 0 + +/** Sub-registers of Register @ref TXCQ */ +/** Bit Mask for Sub-Register TXCQ.DCOQ */ +#define TXCQ_DCOQ_MASK 0x3F +/** Bit Offset for Sub-Register TXCQ.DCOQ */ +#define TXCQ_DCOQ_SHIFT 0 + +/** Sub-registers of Register @ref TXDACI */ +/** Bit Mask for Sub-Register TXDACI.TXDACID */ +#define TXDACI_TXDACID_MASK 0x7F +/** Bit Offset for Sub-Register TXDACI.TXDACID */ +#define TXDACI_TXDACID_SHIFT 0 + +/** Bit Mask for Sub-Register TXDACI.ENTXDACID */ +#define TXDACI_ENTXDACID_MASK 0x80 +/** Bit Offset for Sub-Register TXDACI.ENTXDACID */ +#define TXDACI_ENTXDACID_SHIFT 7 + +/** Sub-registers of Register @ref TXDACQ */ +/** Bit Mask for Sub-Register TXDACQ.TXDACQD */ +#define TXDACQ_TXDACQD_MASK 0x7F +/** Bit Offset for Sub-Register TXDACQ.TXDACQD */ +#define TXDACQ_TXDACQD_SHIFT 0 + +/** Bit Mask for Sub-Register TXDACQ.ENTXDACQD */ +#define TXDACQ_ENTXDACQD_MASK 0x80 +/** Bit Offset for Sub-Register TXDACQ.ENTXDACQD */ +#define TXDACQ_ENTXDACQD_SHIFT 7 + +/** Sub-registers of Register @ref IRQM */ +/** Bit Mask for Sub-Register IRQM.RXFS */ +#define IRQM_RXFS_MASK 0x01 +/** Bit Offset for Sub-Register IRQM.RXFS */ +#define IRQM_RXFS_SHIFT 0 + +/** Bit Mask for Sub-Register IRQM.RXFE */ +#define IRQM_RXFE_MASK 0x02 +/** Bit Offset for Sub-Register IRQM.RXFE */ +#define IRQM_RXFE_SHIFT 1 + +/** Bit Mask for Sub-Register IRQM.RXAM */ +#define IRQM_RXAM_MASK 0x04 +/** Bit Offset for Sub-Register IRQM.RXAM */ +#define IRQM_RXAM_SHIFT 2 + +/** Bit Mask for Sub-Register IRQM.RXEM */ +#define IRQM_RXEM_MASK 0x08 +/** Bit Offset for Sub-Register IRQM.RXEM */ +#define IRQM_RXEM_SHIFT 3 + +/** Bit Mask for Sub-Register IRQM.TXFE */ +#define IRQM_TXFE_MASK 0x10 +/** Bit Offset for Sub-Register IRQM.TXFE */ +#define IRQM_TXFE_SHIFT 4 + +/** Bit Mask for Sub-Register IRQM.AGCH */ +#define IRQM_AGCH_MASK 0x20 +/** Bit Offset for Sub-Register IRQM.AGCH */ +#define IRQM_AGCH_SHIFT 5 + +/** Bit Mask for Sub-Register IRQM.AGCR */ +#define IRQM_AGCR_MASK 0x40 +/** Bit Offset for Sub-Register IRQM.AGCR */ +#define IRQM_AGCR_SHIFT 6 + +/** Bit Mask for Sub-Register IRQM.FBLI */ +#define IRQM_FBLI_MASK 0x80 +/** Bit Offset for Sub-Register IRQM.FBLI */ +#define IRQM_FBLI_SHIFT 7 + +/** Sub-registers of Register @ref PC */ +/** Bit Mask for Sub-Register PC.PT */ +#define PC_PT_MASK 0x03 +/** Bit Offset for Sub-Register PC.PT */ +#define PC_PT_SHIFT 0 + +/** Bit Mask for Sub-Register PC.BBEN */ +#define PC_BBEN_MASK 0x04 +/** Bit Offset for Sub-Register PC.BBEN */ +#define PC_BBEN_SHIFT 2 + +/** Bit Mask for Sub-Register PC.FCST */ +#define PC_FCST_MASK 0x08 +/** Bit Offset for Sub-Register PC.FCST */ +#define PC_FCST_SHIFT 3 + +/** Bit Mask for Sub-Register PC.TXAFCS */ +#define PC_TXAFCS_MASK 0x10 +/** Bit Offset for Sub-Register PC.TXAFCS */ +#define PC_TXAFCS_SHIFT 4 + +/** Bit Mask for Sub-Register PC.FCSOK */ +#define PC_FCSOK_MASK 0x20 +/** Bit Offset for Sub-Register PC.FCSOK */ +#define PC_FCSOK_SHIFT 5 + +/** Bit Mask for Sub-Register PC.FCSFE */ +#define PC_FCSFE_MASK 0x40 +/** Bit Offset for Sub-Register PC.FCSFE */ +#define PC_FCSFE_SHIFT 6 + +/** Bit Mask for Sub-Register PC.CTX */ +#define PC_CTX_MASK 0x80 +/** Bit Offset for Sub-Register PC.CTX */ +#define PC_CTX_SHIFT 7 + +/** Sub-registers of Register @ref PS */ +/** Bit Mask for Sub-Register PS.TXUR */ +#define PS_TXUR_MASK 0x01 +/** Bit Offset for Sub-Register PS.TXUR */ +#define PS_TXUR_SHIFT 0 + +/** Sub-registers of Register @ref RXFLL */ +/** Bit Mask for Sub-Register RXFLL.RXFLL */ +#define RXFLL_RXFLL_MASK 0xFF +/** Bit Offset for Sub-Register RXFLL.RXFLL */ +#define RXFLL_RXFLL_SHIFT 0 + +/** Sub-registers of Register @ref RXFLH */ +/** Bit Mask for Sub-Register RXFLH.RXFLH */ +#define RXFLH_RXFLH_MASK 0x07 +/** Bit Offset for Sub-Register RXFLH.RXFLH */ +#define RXFLH_RXFLH_SHIFT 0 + +/** Sub-registers of Register @ref TXFLL */ +/** Bit Mask for Sub-Register TXFLL.TXFLL */ +#define TXFLL_TXFLL_MASK 0xFF +/** Bit Offset for Sub-Register TXFLL.TXFLL */ +#define TXFLL_TXFLL_SHIFT 0 + +/** Sub-registers of Register @ref TXFLH */ +/** Bit Mask for Sub-Register TXFLH.TXFLH */ +#define TXFLH_TXFLH_MASK 0x07 +/** Bit Offset for Sub-Register TXFLH.TXFLH */ +#define TXFLH_TXFLH_SHIFT 0 + +/** Sub-registers of Register @ref FBLL */ +/** Bit Mask for Sub-Register FBLL.FBLL */ +#define FBLL_FBLL_MASK 0xFF +/** Bit Offset for Sub-Register FBLL.FBLL */ +#define FBLL_FBLL_SHIFT 0 + +/** Sub-registers of Register @ref FBLH */ +/** Bit Mask for Sub-Register FBLH.FBLH */ +#define FBLH_FBLH_MASK 0x07 +/** Bit Offset for Sub-Register FBLH.FBLH */ +#define FBLH_FBLH_SHIFT 0 + +/** Sub-registers of Register @ref FBLIL */ +/** Bit Mask for Sub-Register FBLIL.FBLIL */ +#define FBLIL_FBLIL_MASK 0xFF +/** Bit Offset for Sub-Register FBLIL.FBLIL */ +#define FBLIL_FBLIL_SHIFT 0 + +/** Sub-registers of Register @ref FBLIH */ +/** Bit Mask for Sub-Register FBLIH.FBLIH */ +#define FBLIH_FBLIH_MASK 0x07 +/** Bit Offset for Sub-Register FBLIH.FBLIH */ +#define FBLIH_FBLIH_SHIFT 0 + +/** Sub-registers of Register @ref OFDMPHRTX */ +/** Bit Mask for Sub-Register OFDMPHRTX.MCS */ +#define OFDMPHRTX_MCS_MASK 0x07 +/** Bit Offset for Sub-Register OFDMPHRTX.MCS */ +#define OFDMPHRTX_MCS_SHIFT 0 + +/** Bit Mask for Sub-Register OFDMPHRTX.RB5 */ +#define OFDMPHRTX_RB5_MASK 0x10 +/** Bit Offset for Sub-Register OFDMPHRTX.RB5 */ +#define OFDMPHRTX_RB5_SHIFT 4 + +/** Bit Mask for Sub-Register OFDMPHRTX.RB17 */ +#define OFDMPHRTX_RB17_MASK 0x20 +/** Bit Offset for Sub-Register OFDMPHRTX.RB17 */ +#define OFDMPHRTX_RB17_SHIFT 5 + +/** Bit Mask for Sub-Register OFDMPHRTX.RB18 */ +#define OFDMPHRTX_RB18_MASK 0x40 +/** Bit Offset for Sub-Register OFDMPHRTX.RB18 */ +#define OFDMPHRTX_RB18_SHIFT 6 + +/** Bit Mask for Sub-Register OFDMPHRTX.RB21 */ +#define OFDMPHRTX_RB21_MASK 0x80 +/** Bit Offset for Sub-Register OFDMPHRTX.RB21 */ +#define OFDMPHRTX_RB21_SHIFT 7 + +/** Sub-registers of Register @ref OFDMPHRRX */ +/** Bit Mask for Sub-Register OFDMPHRRX.MCS */ +#define OFDMPHRRX_MCS_MASK 0x07 +/** Bit Offset for Sub-Register OFDMPHRRX.MCS */ +#define OFDMPHRRX_MCS_SHIFT 0 + +/** Bit Mask for Sub-Register OFDMPHRRX.SPC */ +#define OFDMPHRRX_SPC_MASK 0x08 +/** Bit Offset for Sub-Register OFDMPHRRX.SPC */ +#define OFDMPHRRX_SPC_SHIFT 3 + +/** Bit Mask for Sub-Register OFDMPHRRX.RB5 */ +#define OFDMPHRRX_RB5_MASK 0x10 +/** Bit Offset for Sub-Register OFDMPHRRX.RB5 */ +#define OFDMPHRRX_RB5_SHIFT 4 + +/** Bit Mask for Sub-Register OFDMPHRRX.RB17 */ +#define OFDMPHRRX_RB17_MASK 0x20 +/** Bit Offset for Sub-Register OFDMPHRRX.RB17 */ +#define OFDMPHRRX_RB17_SHIFT 5 + +/** Bit Mask for Sub-Register OFDMPHRRX.RB18 */ +#define OFDMPHRRX_RB18_MASK 0x40 +/** Bit Offset for Sub-Register OFDMPHRRX.RB18 */ +#define OFDMPHRRX_RB18_SHIFT 6 + +/** Bit Mask for Sub-Register OFDMPHRRX.RB21 */ +#define OFDMPHRRX_RB21_MASK 0x80 +/** Bit Offset for Sub-Register OFDMPHRRX.RB21 */ +#define OFDMPHRRX_RB21_SHIFT 7 + +/** Sub-registers of Register @ref OFDMC */ +/** Bit Mask for Sub-Register OFDMC.OPT */ +#define OFDMC_OPT_MASK 0x03 +/** Bit Offset for Sub-Register OFDMC.OPT */ +#define OFDMC_OPT_SHIFT 0 + +/** Bit Mask for Sub-Register OFDMC.POI */ +#define OFDMC_POI_MASK 0x04 +/** Bit Offset for Sub-Register OFDMC.POI */ +#define OFDMC_POI_SHIFT 2 + +/** Bit Mask for Sub-Register OFDMC.LFO */ +#define OFDMC_LFO_MASK 0x08 +/** Bit Offset for Sub-Register OFDMC.LFO */ +#define OFDMC_LFO_SHIFT 3 + +/** Bit Mask for Sub-Register OFDMC.SSTX */ +#define OFDMC_SSTX_MASK 0x30 +/** Bit Offset for Sub-Register OFDMC.SSTX */ +#define OFDMC_SSTX_SHIFT 4 + +/** Bit Mask for Sub-Register OFDMC.SSRX */ +#define OFDMC_SSRX_MASK 0xC0 +/** Bit Offset for Sub-Register OFDMC.SSRX */ +#define OFDMC_SSRX_SHIFT 6 + +/** Sub-registers of Register @ref OFDMSW */ +/** Bit Mask for Sub-Register OFDMSW.RXO */ +#define OFDMSW_RXO_MASK 0x10 +/** Bit Offset for Sub-Register OFDMSW.RXO */ +#define OFDMSW_RXO_SHIFT 4 + +/** Bit Mask for Sub-Register OFDMSW.PDT */ +#define OFDMSW_PDT_MASK 0xE0 +/** Bit Offset for Sub-Register OFDMSW.PDT */ +#define OFDMSW_PDT_SHIFT 5 + +/** Sub-registers of Register @ref OQPSKC0 */ +/** Bit Mask for Sub-Register OQPSKC0.FCHIP */ +#define OQPSKC0_FCHIP_MASK 0x03 +/** Bit Offset for Sub-Register OQPSKC0.FCHIP */ +#define OQPSKC0_FCHIP_SHIFT 0 + +/** Bit Mask for Sub-Register OQPSKC0.MOD */ +#define OQPSKC0_MOD_MASK 0x08 +/** Bit Offset for Sub-Register OQPSKC0.MOD */ +#define OQPSKC0_MOD_SHIFT 3 + +/** Bit Mask for Sub-Register OQPSKC0.DM */ +#define OQPSKC0_DM_MASK 0x10 +/** Bit Offset for Sub-Register OQPSKC0.DM */ +#define OQPSKC0_DM_SHIFT 4 + +/** Sub-registers of Register @ref OQPSKC1 */ +/** Bit Mask for Sub-Register OQPSKC1.PDT0 */ +#define OQPSKC1_PDT0_MASK 0x07 +/** Bit Offset for Sub-Register OQPSKC1.PDT0 */ +#define OQPSKC1_PDT0_SHIFT 0 + +/** Bit Mask for Sub-Register OQPSKC1.PDT1 */ +#define OQPSKC1_PDT1_MASK 0x38 +/** Bit Offset for Sub-Register OQPSKC1.PDT1 */ +#define OQPSKC1_PDT1_SHIFT 3 + +/** Bit Mask for Sub-Register OQPSKC1.RXOLEG */ +#define OQPSKC1_RXOLEG_MASK 0x40 +/** Bit Offset for Sub-Register OQPSKC1.RXOLEG */ +#define OQPSKC1_RXOLEG_SHIFT 6 + +/** Bit Mask for Sub-Register OQPSKC1.RXO */ +#define OQPSKC1_RXO_MASK 0x80 +/** Bit Offset for Sub-Register OQPSKC1.RXO */ +#define OQPSKC1_RXO_SHIFT 7 + +/** Sub-registers of Register @ref OQPSKC2 */ +/** Bit Mask for Sub-Register OQPSKC2.RXM */ +#define OQPSKC2_RXM_MASK 0x03 +/** Bit Offset for Sub-Register OQPSKC2.RXM */ +#define OQPSKC2_RXM_SHIFT 0 + +/** Bit Mask for Sub-Register OQPSKC2.FCSTLEG */ +#define OQPSKC2_FCSTLEG_MASK 0x04 +/** Bit Offset for Sub-Register OQPSKC2.FCSTLEG */ +#define OQPSKC2_FCSTLEG_SHIFT 2 + +/** Bit Mask for Sub-Register OQPSKC2.ENPROP */ +#define OQPSKC2_ENPROP_MASK 0x08 +/** Bit Offset for Sub-Register OQPSKC2.ENPROP */ +#define OQPSKC2_ENPROP_SHIFT 3 + +/** Bit Mask for Sub-Register OQPSKC2.RPC */ +#define OQPSKC2_RPC_MASK 0x10 +/** Bit Offset for Sub-Register OQPSKC2.RPC */ +#define OQPSKC2_RPC_SHIFT 4 + +/** Bit Mask for Sub-Register OQPSKC2.SPC */ +#define OQPSKC2_SPC_MASK 0x20 +/** Bit Offset for Sub-Register OQPSKC2.SPC */ +#define OQPSKC2_SPC_SHIFT 5 + +/** Sub-registers of Register @ref OQPSKC3 */ +/** Bit Mask for Sub-Register OQPSKC3.NSFD */ +#define OQPSKC3_NSFD_MASK 0x0C +/** Bit Offset for Sub-Register OQPSKC3.NSFD */ +#define OQPSKC3_NSFD_SHIFT 2 + +/** Bit Mask for Sub-Register OQPSKC3.HRLEG */ +#define OQPSKC3_HRLEG_MASK 0x20 +/** Bit Offset for Sub-Register OQPSKC3.HRLEG */ +#define OQPSKC3_HRLEG_SHIFT 5 + +/** Sub-registers of Register @ref OQPSKPHRTX */ +/** Bit Mask for Sub-Register OQPSKPHRTX.LEG */ +#define OQPSKPHRTX_LEG_MASK 0x01 +/** Bit Offset for Sub-Register OQPSKPHRTX.LEG */ +#define OQPSKPHRTX_LEG_SHIFT 0 + +/** Bit Mask for Sub-Register OQPSKPHRTX.MOD */ +#define OQPSKPHRTX_MOD_MASK 0x0E +/** Bit Offset for Sub-Register OQPSKPHRTX.MOD */ +#define OQPSKPHRTX_MOD_SHIFT 1 + +/** Bit Mask for Sub-Register OQPSKPHRTX.RB0 */ +#define OQPSKPHRTX_RB0_MASK 0x10 +/** Bit Offset for Sub-Register OQPSKPHRTX.RB0 */ +#define OQPSKPHRTX_RB0_SHIFT 4 + +/** Bit Mask for Sub-Register OQPSKPHRTX.PPDUT */ +#define OQPSKPHRTX_PPDUT_MASK 0x20 +/** Bit Offset for Sub-Register OQPSKPHRTX.PPDUT */ +#define OQPSKPHRTX_PPDUT_SHIFT 5 + +/** Sub-registers of Register @ref OQPSKPHRRX */ +/** Bit Mask for Sub-Register OQPSKPHRRX.LEG */ +#define OQPSKPHRRX_LEG_MASK 0x01 +/** Bit Offset for Sub-Register OQPSKPHRRX.LEG */ +#define OQPSKPHRRX_LEG_SHIFT 0 + +/** Bit Mask for Sub-Register OQPSKPHRRX.MOD */ +#define OQPSKPHRRX_MOD_MASK 0x0E +/** Bit Offset for Sub-Register OQPSKPHRRX.MOD */ +#define OQPSKPHRRX_MOD_SHIFT 1 + +/** Bit Mask for Sub-Register OQPSKPHRRX.RB0 */ +#define OQPSKPHRRX_RB0_MASK 0x10 +/** Bit Offset for Sub-Register OQPSKPHRRX.RB0 */ +#define OQPSKPHRRX_RB0_SHIFT 4 + +/** Bit Mask for Sub-Register OQPSKPHRRX.PPDUT */ +#define OQPSKPHRRX_PPDUT_MASK 0x20 +/** Bit Offset for Sub-Register OQPSKPHRRX.PPDUT */ +#define OQPSKPHRRX_PPDUT_SHIFT 5 + +/** Sub-registers of Register @ref AFC0 */ +/** Bit Mask for Sub-Register AFC0.AFEN0 */ +#define AFC0_AFEN0_MASK 0x01 +/** Bit Offset for Sub-Register AFC0.AFEN0 */ +#define AFC0_AFEN0_SHIFT 0 + +/** Bit Mask for Sub-Register AFC0.AFEN1 */ +#define AFC0_AFEN1_MASK 0x02 +/** Bit Offset for Sub-Register AFC0.AFEN1 */ +#define AFC0_AFEN1_SHIFT 1 + +/** Bit Mask for Sub-Register AFC0.AFEN2 */ +#define AFC0_AFEN2_MASK 0x04 +/** Bit Offset for Sub-Register AFC0.AFEN2 */ +#define AFC0_AFEN2_SHIFT 2 + +/** Bit Mask for Sub-Register AFC0.AFEN3 */ +#define AFC0_AFEN3_MASK 0x08 +/** Bit Offset for Sub-Register AFC0.AFEN3 */ +#define AFC0_AFEN3_SHIFT 3 + +/** Bit Mask for Sub-Register AFC0.PM */ +#define AFC0_PM_MASK 0x10 +/** Bit Offset for Sub-Register AFC0.PM */ +#define AFC0_PM_SHIFT 4 + +/** Sub-registers of Register @ref AFC1 */ +/** Bit Mask for Sub-Register AFC1.PANC0 */ +#define AFC1_PANC0_MASK 0x01 +/** Bit Offset for Sub-Register AFC1.PANC0 */ +#define AFC1_PANC0_SHIFT 0 + +/** Bit Mask for Sub-Register AFC1.PANC1 */ +#define AFC1_PANC1_MASK 0x02 +/** Bit Offset for Sub-Register AFC1.PANC1 */ +#define AFC1_PANC1_SHIFT 1 + +/** Bit Mask for Sub-Register AFC1.PANC2 */ +#define AFC1_PANC2_MASK 0x04 +/** Bit Offset for Sub-Register AFC1.PANC2 */ +#define AFC1_PANC2_SHIFT 2 + +/** Bit Mask for Sub-Register AFC1.PANC3 */ +#define AFC1_PANC3_MASK 0x08 +/** Bit Offset for Sub-Register AFC1.PANC3 */ +#define AFC1_PANC3_SHIFT 3 + +/** Bit Mask for Sub-Register AFC1.MRFT0 */ +#define AFC1_MRFT0_MASK 0x10 +/** Bit Offset for Sub-Register AFC1.MRFT0 */ +#define AFC1_MRFT0_SHIFT 4 + +/** Bit Mask for Sub-Register AFC1.MRFT1 */ +#define AFC1_MRFT1_MASK 0x20 +/** Bit Offset for Sub-Register AFC1.MRFT1 */ +#define AFC1_MRFT1_SHIFT 5 + +/** Bit Mask for Sub-Register AFC1.MRFT2 */ +#define AFC1_MRFT2_MASK 0x40 +/** Bit Offset for Sub-Register AFC1.MRFT2 */ +#define AFC1_MRFT2_SHIFT 6 + +/** Bit Mask for Sub-Register AFC1.MRFT3 */ +#define AFC1_MRFT3_MASK 0x80 +/** Bit Offset for Sub-Register AFC1.MRFT3 */ +#define AFC1_MRFT3_SHIFT 7 + +/** Sub-registers of Register @ref AFFTM */ +/** Bit Mask for Sub-Register AFFTM.AFFTM */ +#define AFFTM_AFFTM_MASK 0xFF +/** Bit Offset for Sub-Register AFFTM.AFFTM */ +#define AFFTM_AFFTM_SHIFT 0 + +/** Sub-registers of Register @ref AFFVM */ +/** Bit Mask for Sub-Register AFFVM.AFFVM */ +#define AFFVM_AFFVM_MASK 0x0F +/** Bit Offset for Sub-Register AFFVM.AFFVM */ +#define AFFVM_AFFVM_SHIFT 0 + +/** Sub-registers of Register @ref AFS */ +/** Bit Mask for Sub-Register AFS.AM0 */ +#define AFS_AM0_MASK 0x01 +/** Bit Offset for Sub-Register AFS.AM0 */ +#define AFS_AM0_SHIFT 0 + +/** Bit Mask for Sub-Register AFS.AM1 */ +#define AFS_AM1_MASK 0x02 +/** Bit Offset for Sub-Register AFS.AM1 */ +#define AFS_AM1_SHIFT 1 + +/** Bit Mask for Sub-Register AFS.AM2 */ +#define AFS_AM2_MASK 0x04 +/** Bit Offset for Sub-Register AFS.AM2 */ +#define AFS_AM2_SHIFT 2 + +/** Bit Mask for Sub-Register AFS.AM3 */ +#define AFS_AM3_MASK 0x08 +/** Bit Offset for Sub-Register AFS.AM3 */ +#define AFS_AM3_SHIFT 3 + +/** Bit Mask for Sub-Register AFS.EM */ +#define AFS_EM_MASK 0x10 +/** Bit Offset for Sub-Register AFS.EM */ +#define AFS_EM_SHIFT 4 + +/** Sub-registers of Register @ref MACEA0 */ +/** Bit Mask for Sub-Register MACEA0.MACEA0 */ +#define MACEA0_MACEA0_MASK 0xFF +/** Bit Offset for Sub-Register MACEA0.MACEA0 */ +#define MACEA0_MACEA0_SHIFT 0 + +/** Sub-registers of Register @ref MACEA1 */ +/** Bit Mask for Sub-Register MACEA1.MACEA1 */ +#define MACEA1_MACEA1_MASK 0xFF +/** Bit Offset for Sub-Register MACEA1.MACEA1 */ +#define MACEA1_MACEA1_SHIFT 0 + +/** Sub-registers of Register @ref MACEA2 */ +/** Bit Mask for Sub-Register MACEA2.MACEA2 */ +#define MACEA2_MACEA2_MASK 0xFF +/** Bit Offset for Sub-Register MACEA2.MACEA2 */ +#define MACEA2_MACEA2_SHIFT 0 + +/** Sub-registers of Register @ref MACEA3 */ +/** Bit Mask for Sub-Register MACEA3.MACEA3 */ +#define MACEA3_MACEA3_MASK 0xFF +/** Bit Offset for Sub-Register MACEA3.MACEA3 */ +#define MACEA3_MACEA3_SHIFT 0 + +/** Sub-registers of Register @ref MACEA4 */ +/** Bit Mask for Sub-Register MACEA4.MACEA4 */ +#define MACEA4_MACEA4_MASK 0xFF +/** Bit Offset for Sub-Register MACEA4.MACEA4 */ +#define MACEA4_MACEA4_SHIFT 0 + +/** Sub-registers of Register @ref MACEA5 */ +/** Bit Mask for Sub-Register MACEA5.MACEA5 */ +#define MACEA5_MACEA5_MASK 0xFF +/** Bit Offset for Sub-Register MACEA5.MACEA5 */ +#define MACEA5_MACEA5_SHIFT 0 + +/** Sub-registers of Register @ref MACEA6 */ +/** Bit Mask for Sub-Register MACEA6.MACEA6 */ +#define MACEA6_MACEA6_MASK 0xFF +/** Bit Offset for Sub-Register MACEA6.MACEA6 */ +#define MACEA6_MACEA6_SHIFT 0 + +/** Sub-registers of Register @ref MACEA7 */ +/** Bit Mask for Sub-Register MACEA7.MACEA7 */ +#define MACEA7_MACEA7_MASK 0xFF +/** Bit Offset for Sub-Register MACEA7.MACEA7 */ +#define MACEA7_MACEA7_SHIFT 0 + +/** Sub-registers of Register @ref MACPID0F0 */ +/** Bit Mask for Sub-Register MACPID0F0.MACPID0F0 */ +#define MACPID0F0_MACPID0F0_MASK 0xFF +/** Bit Offset for Sub-Register MACPID0F0.MACPID0F0 */ +#define MACPID0F0_MACPID0F0_SHIFT 0 + +/** Sub-registers of Register @ref MACPID1F0 */ +/** Bit Mask for Sub-Register MACPID1F0.MACPID1F0 */ +#define MACPID1F0_MACPID1F0_MASK 0xFF +/** Bit Offset for Sub-Register MACPID1F0.MACPID1F0 */ +#define MACPID1F0_MACPID1F0_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA0F0 */ +/** Bit Mask for Sub-Register MACSHA0F0.MACSHA0F0 */ +#define MACSHA0F0_MACSHA0F0_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA0F0.MACSHA0F0 */ +#define MACSHA0F0_MACSHA0F0_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA1F0 */ +/** Bit Mask for Sub-Register MACSHA1F0.MACSHA1F0 */ +#define MACSHA1F0_MACSHA1F0_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA1F0.MACSHA1F0 */ +#define MACSHA1F0_MACSHA1F0_SHIFT 0 + +/** Sub-registers of Register @ref MACPID0F1 */ +/** Bit Mask for Sub-Register MACPID0F1.MACPID0F1 */ +#define MACPID0F1_MACPID0F1_MASK 0xFF +/** Bit Offset for Sub-Register MACPID0F1.MACPID0F1 */ +#define MACPID0F1_MACPID0F1_SHIFT 0 + +/** Sub-registers of Register @ref MACPID1F1 */ +/** Bit Mask for Sub-Register MACPID1F1.MACPID1F1 */ +#define MACPID1F1_MACPID1F1_MASK 0xFF +/** Bit Offset for Sub-Register MACPID1F1.MACPID1F1 */ +#define MACPID1F1_MACPID1F1_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA0F1 */ +/** Bit Mask for Sub-Register MACSHA0F1.MACSHA0F1 */ +#define MACSHA0F1_MACSHA0F1_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA0F1.MACSHA0F1 */ +#define MACSHA0F1_MACSHA0F1_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA1F1 */ +/** Bit Mask for Sub-Register MACSHA1F1.MACSHA1F1 */ +#define MACSHA1F1_MACSHA1F1_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA1F1.MACSHA1F1 */ +#define MACSHA1F1_MACSHA1F1_SHIFT 0 + +/** Sub-registers of Register @ref MACPID0F2 */ +/** Bit Mask for Sub-Register MACPID0F2.MACPID0F2 */ +#define MACPID0F2_MACPID0F2_MASK 0xFF +/** Bit Offset for Sub-Register MACPID0F2.MACPID0F2 */ +#define MACPID0F2_MACPID0F2_SHIFT 0 + +/** Sub-registers of Register @ref MACPID1F2 */ +/** Bit Mask for Sub-Register MACPID1F2.MACPID1F2 */ +#define MACPID1F2_MACPID1F2_MASK 0xFF +/** Bit Offset for Sub-Register MACPID1F2.MACPID1F2 */ +#define MACPID1F2_MACPID1F2_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA0F2 */ +/** Bit Mask for Sub-Register MACSHA0F2.MACSHA0F2 */ +#define MACSHA0F2_MACSHA0F2_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA0F2.MACSHA0F2 */ +#define MACSHA0F2_MACSHA0F2_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA1F2 */ +/** Bit Mask for Sub-Register MACSHA1F2.MACSHA1F2 */ +#define MACSHA1F2_MACSHA1F2_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA1F2.MACSHA1F2 */ +#define MACSHA1F2_MACSHA1F2_SHIFT 0 + +/** Sub-registers of Register @ref MACPID0F3 */ +/** Bit Mask for Sub-Register MACPID0F3.MACPID0F3 */ +#define MACPID0F3_MACPID0F3_MASK 0xFF +/** Bit Offset for Sub-Register MACPID0F3.MACPID0F3 */ +#define MACPID0F3_MACPID0F3_SHIFT 0 + +/** Sub-registers of Register @ref MACPID1F3 */ +/** Bit Mask for Sub-Register MACPID1F3.MACPID1F3 */ +#define MACPID1F3_MACPID1F3_MASK 0xFF +/** Bit Offset for Sub-Register MACPID1F3.MACPID1F3 */ +#define MACPID1F3_MACPID1F3_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA0F3 */ +/** Bit Mask for Sub-Register MACSHA0F3.MACSHA0F3 */ +#define MACSHA0F3_MACSHA0F3_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA0F3.MACSHA0F3 */ +#define MACSHA0F3_MACSHA0F3_SHIFT 0 + +/** Sub-registers of Register @ref MACSHA1F3 */ +/** Bit Mask for Sub-Register MACSHA1F3.MACSHA1F3 */ +#define MACSHA1F3_MACSHA1F3_MASK 0xFF +/** Bit Offset for Sub-Register MACSHA1F3.MACSHA1F3 */ +#define MACSHA1F3_MACSHA1F3_SHIFT 0 + +/** Sub-registers of Register @ref AMCS */ +/** Bit Mask for Sub-Register AMCS.TX2RX */ +#define AMCS_TX2RX_MASK 0x01 +/** Bit Offset for Sub-Register AMCS.TX2RX */ +#define AMCS_TX2RX_SHIFT 0 + +/** Bit Mask for Sub-Register AMCS.CCATX */ +#define AMCS_CCATX_MASK 0x02 +/** Bit Offset for Sub-Register AMCS.CCATX */ +#define AMCS_CCATX_SHIFT 1 + +/** Bit Mask for Sub-Register AMCS.CCAED */ +#define AMCS_CCAED_MASK 0x04 +/** Bit Offset for Sub-Register AMCS.CCAED */ +#define AMCS_CCAED_SHIFT 2 + +/** Bit Mask for Sub-Register AMCS.AACK */ +#define AMCS_AACK_MASK 0x08 +/** Bit Offset for Sub-Register AMCS.AACK */ +#define AMCS_AACK_SHIFT 3 + +/** Bit Mask for Sub-Register AMCS.AACKS */ +#define AMCS_AACKS_MASK 0x10 +/** Bit Offset for Sub-Register AMCS.AACKS */ +#define AMCS_AACKS_SHIFT 4 + +/** Bit Mask for Sub-Register AMCS.AACKDR */ +#define AMCS_AACKDR_MASK 0x20 +/** Bit Offset for Sub-Register AMCS.AACKDR */ +#define AMCS_AACKDR_SHIFT 5 + +/** Bit Mask for Sub-Register AMCS.AACKFA */ +#define AMCS_AACKFA_MASK 0x40 +/** Bit Offset for Sub-Register AMCS.AACKFA */ +#define AMCS_AACKFA_SHIFT 6 + +/** Bit Mask for Sub-Register AMCS.AACKFT */ +#define AMCS_AACKFT_MASK 0x80 +/** Bit Offset for Sub-Register AMCS.AACKFT */ +#define AMCS_AACKFT_SHIFT 7 + +/** Sub-registers of Register @ref AMEDT */ +/** Bit Mask for Sub-Register AMEDT.AMEDT */ +#define AMEDT_AMEDT_MASK 0xFF +/** Bit Offset for Sub-Register AMEDT.AMEDT */ +#define AMEDT_AMEDT_SHIFT 0 + +/** Sub-registers of Register @ref AMAACKPD */ +/** Bit Mask for Sub-Register AMAACKPD.PD0 */ +#define AMAACKPD_PD0_MASK 0x01 +/** Bit Offset for Sub-Register AMAACKPD.PD0 */ +#define AMAACKPD_PD0_SHIFT 0 + +/** Bit Mask for Sub-Register AMAACKPD.PD1 */ +#define AMAACKPD_PD1_MASK 0x02 +/** Bit Offset for Sub-Register AMAACKPD.PD1 */ +#define AMAACKPD_PD1_SHIFT 1 + +/** Bit Mask for Sub-Register AMAACKPD.PD2 */ +#define AMAACKPD_PD2_MASK 0x04 +/** Bit Offset for Sub-Register AMAACKPD.PD2 */ +#define AMAACKPD_PD2_SHIFT 2 + +/** Bit Mask for Sub-Register AMAACKPD.PD3 */ +#define AMAACKPD_PD3_MASK 0x08 +/** Bit Offset for Sub-Register AMAACKPD.PD3 */ +#define AMAACKPD_PD3_SHIFT 3 + +/** Sub-registers of Register @ref AMAACKTL */ +/** Bit Mask for Sub-Register AMAACKTL.AMAACKTL */ +#define AMAACKTL_AMAACKTL_MASK 0xFF +/** Bit Offset for Sub-Register AMAACKTL.AMAACKTL */ +#define AMAACKTL_AMAACKTL_SHIFT 0 + +/** Sub-registers of Register @ref AMAACKTH */ +/** Bit Mask for Sub-Register AMAACKTH.AMAACKTH */ +#define AMAACKTH_AMAACKTH_MASK 0x07 +/** Bit Offset for Sub-Register AMAACKTH.AMAACKTH */ +#define AMAACKTH_AMAACKTH_SHIFT 0 + +/** Sub-registers of Register @ref FSKC0 */ +/** Bit Mask for Sub-Register FSKC0.MORD */ +#define FSKC0_MORD_MASK 0x01 +/** Bit Offset for Sub-Register FSKC0.MORD */ +#define FSKC0_MORD_SHIFT 0 + +/** Bit Mask for Sub-Register FSKC0.MIDX */ +#define FSKC0_MIDX_MASK 0x0E +/** Bit Offset for Sub-Register FSKC0.MIDX */ +#define FSKC0_MIDX_SHIFT 1 + +/** Bit Mask for Sub-Register FSKC0.MIDXS */ +#define FSKC0_MIDXS_MASK 0x30 +/** Bit Offset for Sub-Register FSKC0.MIDXS */ +#define FSKC0_MIDXS_SHIFT 4 + +/** Bit Mask for Sub-Register FSKC0.BT */ +#define FSKC0_BT_MASK 0xC0 +/** Bit Offset for Sub-Register FSKC0.BT */ +#define FSKC0_BT_SHIFT 6 + +/** Sub-registers of Register @ref FSKC1 */ +/** Bit Mask for Sub-Register FSKC1.SRATE */ +#define FSKC1_SRATE_MASK 0x0F +/** Bit Offset for Sub-Register FSKC1.SRATE */ +#define FSKC1_SRATE_SHIFT 0 + +/** Bit Mask for Sub-Register FSKC1.FI */ +#define FSKC1_FI_MASK 0x20 +/** Bit Offset for Sub-Register FSKC1.FI */ +#define FSKC1_FI_SHIFT 5 + +/** Bit Mask for Sub-Register FSKC1.FSKPLH */ +#define FSKC1_FSKPLH_MASK 0xC0 +/** Bit Offset for Sub-Register FSKC1.FSKPLH */ +#define FSKC1_FSKPLH_SHIFT 6 + +/** Sub-registers of Register @ref FSKC2 */ +/** Bit Mask for Sub-Register FSKC2.FECIE */ +#define FSKC2_FECIE_MASK 0x01 +/** Bit Offset for Sub-Register FSKC2.FECIE */ +#define FSKC2_FECIE_SHIFT 0 + +/** Bit Mask for Sub-Register FSKC2.FECS */ +#define FSKC2_FECS_MASK 0x02 +/** Bit Offset for Sub-Register FSKC2.FECS */ +#define FSKC2_FECS_SHIFT 1 + +/** Bit Mask for Sub-Register FSKC2.PRI */ +#define FSKC2_PRI_MASK 0x04 +/** Bit Offset for Sub-Register FSKC2.PRI */ +#define FSKC2_PRI_SHIFT 2 + +/** Bit Mask for Sub-Register FSKC2.MSE */ +#define FSKC2_MSE_MASK 0x08 +/** Bit Offset for Sub-Register FSKC2.MSE */ +#define FSKC2_MSE_SHIFT 3 + +/** Bit Mask for Sub-Register FSKC2.RXPTO */ +#define FSKC2_RXPTO_MASK 0x10 +/** Bit Offset for Sub-Register FSKC2.RXPTO */ +#define FSKC2_RXPTO_SHIFT 4 + +/** Bit Mask for Sub-Register FSKC2.RXO */ +#define FSKC2_RXO_MASK 0x60 +/** Bit Offset for Sub-Register FSKC2.RXO */ +#define FSKC2_RXO_SHIFT 5 + +/** Bit Mask for Sub-Register FSKC2.PDTM */ +#define FSKC2_PDTM_MASK 0x80 +/** Bit Offset for Sub-Register FSKC2.PDTM */ +#define FSKC2_PDTM_SHIFT 7 + +/** Sub-registers of Register @ref FSKC3 */ +/** Bit Mask for Sub-Register FSKC3.PDT */ +#define FSKC3_PDT_MASK 0x0F +/** Bit Offset for Sub-Register FSKC3.PDT */ +#define FSKC3_PDT_SHIFT 0 + +/** Bit Mask for Sub-Register FSKC3.SFDT */ +#define FSKC3_SFDT_MASK 0xF0 +/** Bit Offset for Sub-Register FSKC3.SFDT */ +#define FSKC3_SFDT_SHIFT 4 + +/** Sub-registers of Register @ref FSKC4 */ +/** Bit Mask for Sub-Register FSKC4.CSFD0 */ +#define FSKC4_CSFD0_MASK 0x03 +/** Bit Offset for Sub-Register FSKC4.CSFD0 */ +#define FSKC4_CSFD0_SHIFT 0 + +/** Bit Mask for Sub-Register FSKC4.CSFD1 */ +#define FSKC4_CSFD1_MASK 0x0C +/** Bit Offset for Sub-Register FSKC4.CSFD1 */ +#define FSKC4_CSFD1_SHIFT 2 + +/** Bit Mask for Sub-Register FSKC4.RAWRBIT */ +#define FSKC4_RAWRBIT_MASK 0x10 +/** Bit Offset for Sub-Register FSKC4.RAWRBIT */ +#define FSKC4_RAWRBIT_SHIFT 4 + +/** Bit Mask for Sub-Register FSKC4.SFD32 */ +#define FSKC4_SFD32_MASK 0x20 +/** Bit Offset for Sub-Register FSKC4.SFD32 */ +#define FSKC4_SFD32_SHIFT 5 + +/** Bit Mask for Sub-Register FSKC4.SFDQ */ +#define FSKC4_SFDQ_MASK 0x40 +/** Bit Offset for Sub-Register FSKC4.SFDQ */ +#define FSKC4_SFDQ_SHIFT 6 + +/** Sub-registers of Register @ref FSKPLL */ +/** Bit Mask for Sub-Register FSKPLL.FSKPLL */ +#define FSKPLL_FSKPLL_MASK 0xFF +/** Bit Offset for Sub-Register FSKPLL.FSKPLL */ +#define FSKPLL_FSKPLL_SHIFT 0 + +/** Sub-registers of Register @ref FSKSFD0L */ +/** Bit Mask for Sub-Register FSKSFD0L.FSKSFD0L */ +#define FSKSFD0L_FSKSFD0L_MASK 0xFF +/** Bit Offset for Sub-Register FSKSFD0L.FSKSFD0L */ +#define FSKSFD0L_FSKSFD0L_SHIFT 0 + +/** Sub-registers of Register @ref FSKSFD0H */ +/** Bit Mask for Sub-Register FSKSFD0H.FSKSFD0H */ +#define FSKSFD0H_FSKSFD0H_MASK 0xFF +/** Bit Offset for Sub-Register FSKSFD0H.FSKSFD0H */ +#define FSKSFD0H_FSKSFD0H_SHIFT 0 + +/** Sub-registers of Register @ref FSKSFD1L */ +/** Bit Mask for Sub-Register FSKSFD1L.FSKSFD1L */ +#define FSKSFD1L_FSKSFD1L_MASK 0xFF +/** Bit Offset for Sub-Register FSKSFD1L.FSKSFD1L */ +#define FSKSFD1L_FSKSFD1L_SHIFT 0 + +/** Sub-registers of Register @ref FSKSFD1H */ +/** Bit Mask for Sub-Register FSKSFD1H.FSKSFD1H */ +#define FSKSFD1H_FSKSFD1H_MASK 0xFF +/** Bit Offset for Sub-Register FSKSFD1H.FSKSFD1H */ +#define FSKSFD1H_FSKSFD1H_SHIFT 0 + +/** Sub-registers of Register @ref FSKPHRTX */ +/** Bit Mask for Sub-Register FSKPHRTX.RB1 */ +#define FSKPHRTX_RB1_MASK 0x01 +/** Bit Offset for Sub-Register FSKPHRTX.RB1 */ +#define FSKPHRTX_RB1_SHIFT 0 + +/** Bit Mask for Sub-Register FSKPHRTX.RB2 */ +#define FSKPHRTX_RB2_MASK 0x02 +/** Bit Offset for Sub-Register FSKPHRTX.RB2 */ +#define FSKPHRTX_RB2_SHIFT 1 + +/** Bit Mask for Sub-Register FSKPHRTX.DW */ +#define FSKPHRTX_DW_MASK 0x04 +/** Bit Offset for Sub-Register FSKPHRTX.DW */ +#define FSKPHRTX_DW_SHIFT 2 + +/** Bit Mask for Sub-Register FSKPHRTX.SFD */ +#define FSKPHRTX_SFD_MASK 0x08 +/** Bit Offset for Sub-Register FSKPHRTX.SFD */ +#define FSKPHRTX_SFD_SHIFT 3 + +/** Sub-registers of Register @ref FSKPHRRX */ +/** Bit Mask for Sub-Register FSKPHRRX.RB1 */ +#define FSKPHRRX_RB1_MASK 0x01 +/** Bit Offset for Sub-Register FSKPHRRX.RB1 */ +#define FSKPHRRX_RB1_SHIFT 0 + +/** Bit Mask for Sub-Register FSKPHRRX.RB2 */ +#define FSKPHRRX_RB2_MASK 0x02 +/** Bit Offset for Sub-Register FSKPHRRX.RB2 */ +#define FSKPHRRX_RB2_SHIFT 1 + +/** Bit Mask for Sub-Register FSKPHRRX.DW */ +#define FSKPHRRX_DW_MASK 0x04 +/** Bit Offset for Sub-Register FSKPHRRX.DW */ +#define FSKPHRRX_DW_SHIFT 2 + +/** Bit Mask for Sub-Register FSKPHRRX.SFD */ +#define FSKPHRRX_SFD_MASK 0x08 +/** Bit Offset for Sub-Register FSKPHRRX.SFD */ +#define FSKPHRRX_SFD_SHIFT 3 + +/** Bit Mask for Sub-Register FSKPHRRX.MS */ +#define FSKPHRRX_MS_MASK 0x40 +/** Bit Offset for Sub-Register FSKPHRRX.MS */ +#define FSKPHRRX_MS_SHIFT 6 + +/** Bit Mask for Sub-Register FSKPHRRX.FCST */ +#define FSKPHRRX_FCST_MASK 0x80 +/** Bit Offset for Sub-Register FSKPHRRX.FCST */ +#define FSKPHRRX_FCST_SHIFT 7 + +/** Sub-registers of Register @ref FSKRPC */ +/** Bit Mask for Sub-Register FSKRPC.BASET */ +#define FSKRPC_BASET_MASK 0x07 +/** Bit Offset for Sub-Register FSKRPC.BASET */ +#define FSKRPC_BASET_SHIFT 0 + +/** Bit Mask for Sub-Register FSKRPC.EN */ +#define FSKRPC_EN_MASK 0x08 +/** Bit Offset for Sub-Register FSKRPC.EN */ +#define FSKRPC_EN_SHIFT 3 + +/** Sub-registers of Register @ref FSKRPCONT */ +/** Bit Mask for Sub-Register FSKRPCONT.FSKRPCONT */ +#define FSKRPCONT_FSKRPCONT_MASK 0xFF +/** Bit Offset for Sub-Register FSKRPCONT.FSKRPCONT */ +#define FSKRPCONT_FSKRPCONT_SHIFT 0 + +/** Sub-registers of Register @ref FSKRPCOFFT */ +/** Bit Mask for Sub-Register FSKRPCOFFT.FSKRPCOFFT */ +#define FSKRPCOFFT_FSKRPCOFFT_MASK 0xFF +/** Bit Offset for Sub-Register FSKRPCOFFT.FSKRPCOFFT */ +#define FSKRPCOFFT_FSKRPCOFFT_SHIFT 0 + +/** Sub-registers of Register @ref FSKRRXFLL */ +/** Bit Mask for Sub-Register FSKRRXFLL.FSKRRXFLL */ +#define FSKRRXFLL_FSKRRXFLL_MASK 0xFF +/** Bit Offset for Sub-Register FSKRRXFLL.FSKRRXFLL */ +#define FSKRRXFLL_FSKRRXFLL_SHIFT 0 + +/** Sub-registers of Register @ref FSKRRXFLH */ +/** Bit Mask for Sub-Register FSKRRXFLH.FSKRRXFLH */ +#define FSKRRXFLH_FSKRRXFLH_MASK 0x07 +/** Bit Offset for Sub-Register FSKRRXFLH.FSKRRXFLH */ +#define FSKRRXFLH_FSKRRXFLH_SHIFT 0 + +/** Sub-registers of Register @ref FSKDM */ +/** Bit Mask for Sub-Register FSKDM.EN */ +#define FSKDM_EN_MASK 0x01 +/** Bit Offset for Sub-Register FSKDM.EN */ +#define FSKDM_EN_SHIFT 0 + +/** Bit Mask for Sub-Register FSKDM.PE */ +#define FSKDM_PE_MASK 0x02 +/** Bit Offset for Sub-Register FSKDM.PE */ +#define FSKDM_PE_SHIFT 1 + +/** Sub-registers of Register @ref FSKPE0 */ +/** Bit Mask for Sub-Register FSKPE0.FSKPE0 */ +#define FSKPE0_FSKPE0_MASK 0xFF +/** Bit Offset for Sub-Register FSKPE0.FSKPE0 */ +#define FSKPE0_FSKPE0_SHIFT 0 + +/** Sub-registers of Register @ref FSKPE1 */ +/** Bit Mask for Sub-Register FSKPE1.FSKPE1 */ +#define FSKPE1_FSKPE1_MASK 0xFF +/** Bit Offset for Sub-Register FSKPE1.FSKPE1 */ +#define FSKPE1_FSKPE1_SHIFT 0 + +/** Sub-registers of Register @ref FSKPE2 */ +/** Bit Mask for Sub-Register FSKPE2.FSKPE2 */ +#define FSKPE2_FSKPE2_MASK 0xFF +/** Bit Offset for Sub-Register FSKPE2.FSKPE2 */ +#define FSKPE2_FSKPE2_SHIFT 0 + +/** Sub-registers of Register @ref PMUC */ +/** Bit Mask for Sub-Register PMUC.EN */ +#define PMUC_EN_MASK 0x01 +/** Bit Offset for Sub-Register PMUC.EN */ +#define PMUC_EN_SHIFT 0 + +/** Bit Mask for Sub-Register PMUC.AVG */ +#define PMUC_AVG_MASK 0x02 +/** Bit Offset for Sub-Register PMUC.AVG */ +#define PMUC_AVG_SHIFT 1 + +/** Bit Mask for Sub-Register PMUC.SYNC */ +#define PMUC_SYNC_MASK 0x1C +/** Bit Offset for Sub-Register PMUC.SYNC */ +#define PMUC_SYNC_SHIFT 2 + +/** Bit Mask for Sub-Register PMUC.FED */ +#define PMUC_FED_MASK 0x20 +/** Bit Offset for Sub-Register PMUC.FED */ +#define PMUC_FED_SHIFT 5 + +/** Bit Mask for Sub-Register PMUC.IQSEL */ +#define PMUC_IQSEL_MASK 0x40 +/** Bit Offset for Sub-Register PMUC.IQSEL */ +#define PMUC_IQSEL_SHIFT 6 + +/** Bit Mask for Sub-Register PMUC.CCFTS */ +#define PMUC_CCFTS_MASK 0x80 +/** Bit Offset for Sub-Register PMUC.CCFTS */ +#define PMUC_CCFTS_SHIFT 7 + +/** Sub-registers of Register @ref PMUVAL */ +/** Bit Mask for Sub-Register PMUVAL.PMUVAL */ +#define PMUVAL_PMUVAL_MASK 0xFF +/** Bit Offset for Sub-Register PMUVAL.PMUVAL */ +#define PMUVAL_PMUVAL_SHIFT 0 + +/** Sub-registers of Register @ref PMUQF */ +/** Bit Mask for Sub-Register PMUQF.PMUQF */ +#define PMUQF_PMUQF_MASK 0xFF +/** Bit Offset for Sub-Register PMUQF.PMUQF */ +#define PMUQF_PMUQF_SHIFT 0 + +/** Sub-registers of Register @ref PMUI */ +/** Bit Mask for Sub-Register PMUI.PMUI */ +#define PMUI_PMUI_MASK 0xFF +/** Bit Offset for Sub-Register PMUI.PMUI */ +#define PMUI_PMUI_SHIFT 0 + +/** Sub-registers of Register @ref PMUQ */ +/** Bit Mask for Sub-Register PMUQ.PMUQ */ +#define PMUQ_PMUQ_MASK 0xFF +/** Bit Offset for Sub-Register PMUQ.PMUQ */ +#define PMUQ_PMUQ_SHIFT 0 + +/** Sub-registers of Register @ref CNTC */ +/** Bit Mask for Sub-Register CNTC.EN */ +#define CNTC_EN_MASK 0x01 +/** Bit Offset for Sub-Register CNTC.EN */ +#define CNTC_EN_SHIFT 0 + +/** Bit Mask for Sub-Register CNTC.RSTRXS */ +#define CNTC_RSTRXS_MASK 0x02 +/** Bit Offset for Sub-Register CNTC.RSTRXS */ +#define CNTC_RSTRXS_SHIFT 1 + +/** Bit Mask for Sub-Register CNTC.RSTTXS */ +#define CNTC_RSTTXS_MASK 0x04 +/** Bit Offset for Sub-Register CNTC.RSTTXS */ +#define CNTC_RSTTXS_SHIFT 2 + +/** Bit Mask for Sub-Register CNTC.CAPRXS */ +#define CNTC_CAPRXS_MASK 0x08 +/** Bit Offset for Sub-Register CNTC.CAPRXS */ +#define CNTC_CAPRXS_SHIFT 3 + +/** Bit Mask for Sub-Register CNTC.CAPTXS */ +#define CNTC_CAPTXS_MASK 0x10 +/** Bit Offset for Sub-Register CNTC.CAPTXS */ +#define CNTC_CAPTXS_SHIFT 4 + +/** Sub-registers of Register @ref CNT0 */ +/** Bit Mask for Sub-Register CNT0.CNT0 */ +#define CNT0_CNT0_MASK 0xFF +/** Bit Offset for Sub-Register CNT0.CNT0 */ +#define CNT0_CNT0_SHIFT 0 + +/** Sub-registers of Register @ref CNT1 */ +/** Bit Mask for Sub-Register CNT1.CNT1 */ +#define CNT1_CNT1_MASK 0xFF +/** Bit Offset for Sub-Register CNT1.CNT1 */ +#define CNT1_CNT1_SHIFT 0 + +/** Sub-registers of Register @ref CNT2 */ +/** Bit Mask for Sub-Register CNT2.CNT2 */ +#define CNT2_CNT2_MASK 0xFF +/** Bit Offset for Sub-Register CNT2.CNT2 */ +#define CNT2_CNT2_SHIFT 0 + +/** Sub-registers of Register @ref CNT3 */ +/** Bit Mask for Sub-Register CNT3.CNT3 */ +#define CNT3_CNT3_MASK 0xFF +/** Bit Offset for Sub-Register CNT3.CNT3 */ +#define CNT3_CNT3_SHIFT 0 + +/** Sub-registers of Register @ref FBRXS */ +/** Bit Mask for Sub-Register FBRXS.FBRXS */ +#define FBRXS_FBRXS_MASK 0xFF +/** Bit Offset for Sub-Register FBRXS.FBRXS */ +#define FBRXS_FBRXS_SHIFT 0 + +/** Sub-registers of Register @ref FBRXE */ +/** Bit Mask for Sub-Register FBRXE.FBRXE */ +#define FBRXE_FBRXE_MASK 0xFF +/** Bit Offset for Sub-Register FBRXE.FBRXE */ +#define FBRXE_FBRXE_SHIFT 0 + +/** Sub-registers of Register @ref FBTXS */ +/** Bit Mask for Sub-Register FBTXS.FBTXS */ +#define FBTXS_FBTXS_MASK 0xFF +/** Bit Offset for Sub-Register FBTXS.FBTXS */ +#define FBTXS_FBTXS_SHIFT 0 + +/** Sub-registers of Register @ref FBTXE */ +/** Bit Mask for Sub-Register FBTXE.FBTXE */ +#define FBTXE_FBTXE_MASK 0xFF +/** Bit Offset for Sub-Register FBTXE.FBTXE */ +#define FBTXE_FBTXE_SHIFT 0 + +/** Register group base addresses */ + +/** Base address for RF09_RFIRQS09 register set */ +#define BASE_ADDR_RF09_RFIRQS09 (0x0000) +/** Base address for RF24_RFIRQS24 register set */ +#define BASE_ADDR_RF24_RFIRQS24 (0x0001) +/** Base address for BBC0_CORE0_IRQS register set */ +#define BASE_ADDR_BBC0_CORE0_IRQS (0x0002) +/** Base address for BBC1_CORE1_IRQS register set */ +#define BASE_ADDR_BBC1_CORE1_IRQS (0x0003) +/** Base address for RF_RFCOMMON register set */ +#define BASE_ADDR_RF_RFCOMMON (0x0005) +/** Base address for RFT_RFTESTCOMMON register set */ +#define BASE_ADDR_RFT_RFTESTCOMMON (0x0005) +/** Base address for RF09_RF09 register set */ +#define BASE_ADDR_RF09_RF09 (0x0100) +/** Base address for RFT09_RFT09 register set */ +#define BASE_ADDR_RFT09_RFT09 (0x0100) +/** Base address for RF24_RF24 register set */ +#define BASE_ADDR_RF24_RF24 (0x0200) +/** Base address for RFT24_RFT24 register set */ +#define BASE_ADDR_RFT24_RFT24 (0x0200) +/** Base address for BBC0_CORE0 register set */ +#define BASE_ADDR_BBC0_CORE0 (0x0300) +/** Base address for BBC1_CORE1 register set */ +#define BASE_ADDR_BBC1_CORE1 (0x0400) +/** Base address for BBC0_FB0 register set */ +#define BASE_ADDR_BBC0_FB0 (0x2000) +/** Base address for BBC1_FB1 register set */ +#define BASE_ADDR_BBC1_FB1 (0x3000) + +/** Register addresses */ + +/** Address for register RF09_IRQS */ +#define RG_RF09_IRQS (0x00) +/** Sub-registers of Register @ref RG_RF09_IRQS */ +/** Access parameters for sub-register WAKEUP in register @ref RG_RF09_IRQS */ +#define SR_RF09_IRQS_WAKEUP RG_RF09_IRQS, IRQS_WAKEUP_MASK, \ + IRQS_WAKEUP_SHIFT +/** Access parameters for sub-register TRXRDY in register @ref RG_RF09_IRQS */ +#define SR_RF09_IRQS_TRXRDY RG_RF09_IRQS, IRQS_TRXRDY_MASK, \ + IRQS_TRXRDY_SHIFT +/** Access parameters for sub-register EDC in register @ref RG_RF09_IRQS */ +#define SR_RF09_IRQS_EDC RG_RF09_IRQS, IRQS_EDC_MASK, \ + IRQS_EDC_SHIFT +/** Access parameters for sub-register BATLOW in register @ref RG_RF09_IRQS */ +#define SR_RF09_IRQS_BATLOW RG_RF09_IRQS, IRQS_BATLOW_MASK, \ + IRQS_BATLOW_SHIFT +/** Access parameters for sub-register TRXERR in register @ref RG_RF09_IRQS */ +#define SR_RF09_IRQS_TRXERR RG_RF09_IRQS, IRQS_TRXERR_MASK, \ + IRQS_TRXERR_SHIFT +/** Access parameters for sub-register IQIFSF in register @ref RG_RF09_IRQS */ +#define SR_RF09_IRQS_IQIFSF RG_RF09_IRQS, IRQS_IQIFSF_MASK, \ + IRQS_IQIFSF_SHIFT + +/** Address for register RF24_IRQS */ +#define RG_RF24_IRQS (0x01) +/** Sub-registers of Register @ref RG_RF24_IRQS */ +/** Access parameters for sub-register WAKEUP in register @ref RG_RF24_IRQS */ +#define SR_RF24_IRQS_WAKEUP RG_RF24_IRQS, IRQS_WAKEUP_MASK, \ + IRQS_WAKEUP_SHIFT +/** Access parameters for sub-register TRXRDY in register @ref RG_RF24_IRQS */ +#define SR_RF24_IRQS_TRXRDY RG_RF24_IRQS, IRQS_TRXRDY_MASK, \ + IRQS_TRXRDY_SHIFT +/** Access parameters for sub-register EDC in register @ref RG_RF24_IRQS */ +#define SR_RF24_IRQS_EDC RG_RF24_IRQS, IRQS_EDC_MASK, \ + IRQS_EDC_SHIFT +/** Access parameters for sub-register BATLOW in register @ref RG_RF24_IRQS */ +#define SR_RF24_IRQS_BATLOW RG_RF24_IRQS, IRQS_BATLOW_MASK, \ + IRQS_BATLOW_SHIFT +/** Access parameters for sub-register TRXERR in register @ref RG_RF24_IRQS */ +#define SR_RF24_IRQS_TRXERR RG_RF24_IRQS, IRQS_TRXERR_MASK, \ + IRQS_TRXERR_SHIFT +/** Access parameters for sub-register IQIFSF in register @ref RG_RF24_IRQS */ +#define SR_RF24_IRQS_IQIFSF RG_RF24_IRQS, IRQS_IQIFSF_MASK, \ + IRQS_IQIFSF_SHIFT + +/** Address for register BBC0_IRQS */ +#define RG_BBC0_IRQS (0x02) +/** Sub-registers of Register @ref RG_BBC0_IRQS */ +/** Access parameters for sub-register RXFS in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_RXFS RG_BBC0_IRQS, IRQS_RXFS_MASK, \ + IRQS_RXFS_SHIFT +/** Access parameters for sub-register RXFE in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_RXFE RG_BBC0_IRQS, IRQS_RXFE_MASK, \ + IRQS_RXFE_SHIFT +/** Access parameters for sub-register RXAM in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_RXAM RG_BBC0_IRQS, IRQS_RXAM_MASK, \ + IRQS_RXAM_SHIFT +/** Access parameters for sub-register RXEM in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_RXEM RG_BBC0_IRQS, IRQS_RXEM_MASK, \ + IRQS_RXEM_SHIFT +/** Access parameters for sub-register TXFE in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_TXFE RG_BBC0_IRQS, IRQS_TXFE_MASK, \ + IRQS_TXFE_SHIFT +/** Access parameters for sub-register AGCH in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_AGCH RG_BBC0_IRQS, IRQS_AGCH_MASK, \ + IRQS_AGCH_SHIFT +/** Access parameters for sub-register AGCR in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_AGCR RG_BBC0_IRQS, IRQS_AGCR_MASK, \ + IRQS_AGCR_SHIFT +/** Access parameters for sub-register FBLI in register @ref RG_BBC0_IRQS */ +#define SR_BBC0_IRQS_FBLI RG_BBC0_IRQS, IRQS_FBLI_MASK, \ + IRQS_FBLI_SHIFT + +/** Address for register BBC1_IRQS */ +#define RG_BBC1_IRQS (0x03) +/** Sub-registers of Register @ref RG_BBC1_IRQS */ +/** Access parameters for sub-register RXFS in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_RXFS RG_BBC1_IRQS, IRQS_RXFS_MASK, \ + IRQS_RXFS_SHIFT +/** Access parameters for sub-register RXFE in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_RXFE RG_BBC1_IRQS, IRQS_RXFE_MASK, \ + IRQS_RXFE_SHIFT +/** Access parameters for sub-register RXAM in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_RXAM RG_BBC1_IRQS, IRQS_RXAM_MASK, \ + IRQS_RXAM_SHIFT +/** Access parameters for sub-register RXEM in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_RXEM RG_BBC1_IRQS, IRQS_RXEM_MASK, \ + IRQS_RXEM_SHIFT +/** Access parameters for sub-register TXFE in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_TXFE RG_BBC1_IRQS, IRQS_TXFE_MASK, \ + IRQS_TXFE_SHIFT +/** Access parameters for sub-register AGCH in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_AGCH RG_BBC1_IRQS, IRQS_AGCH_MASK, \ + IRQS_AGCH_SHIFT +/** Access parameters for sub-register AGCR in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_AGCR RG_BBC1_IRQS, IRQS_AGCR_MASK, \ + IRQS_AGCR_SHIFT +/** Access parameters for sub-register FBLI in register @ref RG_BBC1_IRQS */ +#define SR_BBC1_IRQS_FBLI RG_BBC1_IRQS, IRQS_FBLI_MASK, \ + IRQS_FBLI_SHIFT + +/** Address for register RF_RST */ +#define RG_RF_RST (0x05) +/** Sub-registers of Register @ref RG_RF_RST */ +/** Access parameters for sub-register CMD in register @ref RG_RF_RST */ +#define SR_RF_RST_CMD RG_RF_RST, RST_CMD_MASK, RST_CMD_SHIFT + +/** Address for register RF_CFG */ +#define RG_RF_CFG (0x06) +/** Sub-registers of Register @ref RG_RF_CFG */ +/** Access parameters for sub-register DRV in register @ref RG_RF_CFG */ +#define SR_RF_CFG_DRV RG_RF_CFG, CFG_DRV_MASK, CFG_DRV_SHIFT +/** Constant DRV2 for sub-register @ref SR_DRV in register RF_CFG */ +#define RF_DRV2 (0x0) +/** Constant DRV4 for sub-register @ref SR_DRV in register RF_CFG */ +#define RF_DRV4 (0x1) +/** Constant DRV6 for sub-register @ref SR_DRV in register RF_CFG */ +#define RF_DRV6 (0x2) +/** Constant DRV8 for sub-register @ref SR_DRV in register RF_CFG */ +#define RF_DRV8 (0x3) +/** Access parameters for sub-register IRQP in register @ref RG_RF_CFG */ +#define SR_RF_CFG_IRQP RG_RF_CFG, CFG_IRQP_MASK, CFG_IRQP_SHIFT +/** Access parameters for sub-register IRQMM in register @ref RG_RF_CFG */ +#define SR_RF_CFG_IRQMM RG_RF_CFG, CFG_IRQMM_MASK, \ + CFG_IRQMM_SHIFT + +/** Address for register RF_CLKO */ +#define RG_RF_CLKO (0x07) +/** Sub-registers of Register @ref RG_RF_CLKO */ +/** Access parameters for sub-register OS in register @ref RG_RF_CLKO */ +#define SR_RF_CLKO_OS RG_RF_CLKO, CLKO_OS_MASK, CLKO_OS_SHIFT +/** Access parameters for sub-register DRV in register @ref RG_RF_CLKO */ +#define SR_RF_CLKO_DRV RG_RF_CLKO, CLKO_DRV_MASK, \ + CLKO_DRV_SHIFT +/** Constant DRVCLKO2 for sub-register @ref SR_DRV in register RF_CLKO */ +#define RF_DRVCLKO2 (0x0) +/** Constant DRVCLKO4 for sub-register @ref SR_DRV in register RF_CLKO */ +#define RF_DRVCLKO4 (0x1) +/** Constant DRVCLKO6 for sub-register @ref SR_DRV in register RF_CLKO */ +#define RF_DRVCLKO6 (0x2) +/** Constant DRVCLKO8 for sub-register @ref SR_DRV in register RF_CLKO */ +#define RF_DRVCLKO8 (0x3) + +/** Address for register RF_BMDVC */ +#define RG_RF_BMDVC (0x08) +/** Sub-registers of Register @ref RG_RF_BMDVC */ +/** Access parameters for sub-register BMVTH in register @ref RG_RF_BMDVC */ +#define SR_RF_BMDVC_BMVTH RG_RF_BMDVC, BMDVC_BMVTH_MASK, \ + BMDVC_BMVTH_SHIFT +/** Access parameters for sub-register BMHR in register @ref RG_RF_BMDVC */ +#define SR_RF_BMDVC_BMHR RG_RF_BMDVC, BMDVC_BMHR_MASK, \ + BMDVC_BMHR_SHIFT +/** Access parameters for sub-register BMS in register @ref RG_RF_BMDVC */ +#define SR_RF_BMDVC_BMS RG_RF_BMDVC, BMDVC_BMS_MASK, \ + BMDVC_BMS_SHIFT + +/** Address for register RF_XOC */ +#define RG_RF_XOC (0x09) +/** Sub-registers of Register @ref RG_RF_XOC */ +/** Access parameters for sub-register TRIM in register @ref RG_RF_XOC */ +#define SR_RF_XOC_TRIM RG_RF_XOC, XOC_TRIM_MASK, XOC_TRIM_SHIFT +/** Access parameters for sub-register FS in register @ref RG_RF_XOC */ +#define SR_RF_XOC_FS RG_RF_XOC, XOC_FS_MASK, XOC_FS_SHIFT + +/** Address for register RF_IQIFC0 */ +#define RG_RF_IQIFC0 (0x0A) +/** Sub-registers of Register @ref RG_RF_IQIFC0 */ +/** Access parameters for sub-register EEC in register @ref RG_RF_IQIFC0 */ +#define SR_RF_IQIFC0_EEC RG_RF_IQIFC0, IQIFC0_EEC_MASK, \ + IQIFC0_EEC_SHIFT +/** Access parameters for sub-register CMV1V2 in register @ref RG_RF_IQIFC0 */ +#define SR_RF_IQIFC0_CMV1V2 RG_RF_IQIFC0, IQIFC0_CMV1V2_MASK, \ + IQIFC0_CMV1V2_SHIFT +/** Access parameters for sub-register CMV in register @ref RG_RF_IQIFC0 */ +#define SR_RF_IQIFC0_CMV RG_RF_IQIFC0, IQIFC0_CMV_MASK, \ + IQIFC0_CMV_SHIFT +/** Access parameters for sub-register DRV in register @ref RG_RF_IQIFC0 */ +#define SR_RF_IQIFC0_DRV RG_RF_IQIFC0, IQIFC0_DRV_MASK, \ + IQIFC0_DRV_SHIFT +/** Access parameters for sub-register SF in register @ref RG_RF_IQIFC0 */ +#define SR_RF_IQIFC0_SF RG_RF_IQIFC0, IQIFC0_SF_MASK, \ + IQIFC0_SF_SHIFT +/** Access parameters for sub-register EXTLB in register @ref RG_RF_IQIFC0 */ +#define SR_RF_IQIFC0_EXTLB RG_RF_IQIFC0, IQIFC0_EXTLB_MASK, \ + IQIFC0_EXTLB_SHIFT + +/** Address for register RF_IQIFC1 */ +#define RG_RF_IQIFC1 (0x0B) +/** Sub-registers of Register @ref RG_RF_IQIFC1 */ +/** Access parameters for sub-register SKEWDRV in register @ref RG_RF_IQIFC1 */ +#define SR_RF_IQIFC1_SKEWDRV RG_RF_IQIFC1, IQIFC1_SKEWDRV_MASK, \ + IQIFC1_SKEWDRV_SHIFT +/** Access parameters for sub-register CHPM in register @ref RG_RF_IQIFC1 */ +#define SR_RF_IQIFC1_CHPM RG_RF_IQIFC1, IQIFC1_CHPM_MASK, \ + IQIFC1_CHPM_SHIFT +/** Constant MODE_BBRF for sub-register @ref SR_CHPM in register RF_IQIFC1 */ +#define RF_MODE_BBRF (0x0) +/** Constant MODE_BBRF09 for sub-register @ref SR_CHPM in register RF_IQIFC1 */ +#define RF_MODE_BBRF09 (0x4) +/** Constant MODE_BBRF24 for sub-register @ref SR_CHPM in register RF_IQIFC1 */ +#define RF_MODE_BBRF24 (0x5) +/** Constant MODE_RF for sub-register @ref SR_CHPM in register RF_IQIFC1 */ +#define RF_MODE_RF (0x1) +/** Access parameters for sub-register FAILSF in register @ref RG_RF_IQIFC1 */ +#define SR_RF_IQIFC1_FAILSF RG_RF_IQIFC1, IQIFC1_FAILSF_MASK, \ + IQIFC1_FAILSF_SHIFT + +/** Address for register RF_IQIFC2 */ +#define RG_RF_IQIFC2 (0x0C) +/** Sub-registers of Register @ref RG_RF_IQIFC2 */ +/** Access parameters for sub-register SYNC in register @ref RG_RF_IQIFC2 */ +#define SR_RF_IQIFC2_SYNC RG_RF_IQIFC2, IQIFC2_SYNC_MASK, \ + IQIFC2_SYNC_SHIFT + +/** Address for register RF_PN */ +#define RG_RF_PN (0x0D) +/** Sub-registers of Register @ref RG_RF_PN */ +/** Access parameters for sub-register PN in register @ref RG_RF_PN */ +#define SR_RF_PN_PN RG_RF_PN, PN_PN_MASK, PN_PN_SHIFT + +/** Address for register RF_VN */ +#define RG_RF_VN (0x0E) +/** Sub-registers of Register @ref RG_RF_VN */ +/** Access parameters for sub-register VN in register @ref RG_RF_VN */ +#define SR_RF_VN_VN RG_RF_VN, VN_VN_MASK, VN_VN_SHIFT + +/** Address for register RF09_IRQM */ +#define RG_RF09_IRQM (0x100) +/** Sub-registers of Register @ref RG_RF09_IRQM */ +/** Access parameters for sub-register WAKEUP in register @ref RG_RF09_IRQM */ +#define SR_RF09_IRQM_WAKEUP RG_RF09_IRQM, IRQM_WAKEUP_MASK, \ + IRQM_WAKEUP_SHIFT +/** Access parameters for sub-register TRXRDY in register @ref RG_RF09_IRQM */ +#define SR_RF09_IRQM_TRXRDY RG_RF09_IRQM, IRQM_TRXRDY_MASK, \ + IRQM_TRXRDY_SHIFT +/** Access parameters for sub-register EDC in register @ref RG_RF09_IRQM */ +#define SR_RF09_IRQM_EDC RG_RF09_IRQM, IRQM_EDC_MASK, \ + IRQM_EDC_SHIFT +/** Access parameters for sub-register BATLOW in register @ref RG_RF09_IRQM */ +#define SR_RF09_IRQM_BATLOW RG_RF09_IRQM, IRQM_BATLOW_MASK, \ + IRQM_BATLOW_SHIFT +/** Access parameters for sub-register TRXERR in register @ref RG_RF09_IRQM */ +#define SR_RF09_IRQM_TRXERR RG_RF09_IRQM, IRQM_TRXERR_MASK, \ + IRQM_TRXERR_SHIFT +/** Access parameters for sub-register IQIFSF in register @ref RG_RF09_IRQM */ +#define SR_RF09_IRQM_IQIFSF RG_RF09_IRQM, IRQM_IQIFSF_MASK, \ + IRQM_IQIFSF_SHIFT + +/** Address for register RF09_AUXS */ +#define RG_RF09_AUXS (0x101) +/** Sub-registers of Register @ref RG_RF09_AUXS */ +/** Access parameters for sub-register PAVC in register @ref RG_RF09_AUXS */ +#define SR_RF09_AUXS_PAVC RG_RF09_AUXS, AUXS_PAVC_MASK, \ + AUXS_PAVC_SHIFT +/** Access parameters for sub-register AVS in register @ref RG_RF09_AUXS */ +#define SR_RF09_AUXS_AVS RG_RF09_AUXS, AUXS_AVS_MASK, \ + AUXS_AVS_SHIFT +/** Access parameters for sub-register AVEN in register @ref RG_RF09_AUXS */ +#define SR_RF09_AUXS_AVEN RG_RF09_AUXS, AUXS_AVEN_MASK, \ + AUXS_AVEN_SHIFT +/** Access parameters for sub-register AVEXT in register @ref RG_RF09_AUXS */ +#define SR_RF09_AUXS_AVEXT RG_RF09_AUXS, AUXS_AVEXT_MASK, \ + AUXS_AVEXT_SHIFT +/** Access parameters for sub-register AGCMAP in register @ref RG_RF09_AUXS */ +#define SR_RF09_AUXS_AGCMAP RG_RF09_AUXS, AUXS_AGCMAP_MASK, \ + AUXS_AGCMAP_SHIFT + +/** Access parameters for sub-register EXTLNABYP in register @ref RG_RF09_AUXS +**/ +#define SR_RF09_AUXS_EXTLNABYP RG_RF09_AUXS, AUXS_EXTLNABYP_MASK, \ + AUXS_EXTLNABYP_SHIFT + +/** Address for register RF09_STATE */ +#define RG_RF09_STATE (0x102) +/** Sub-registers of Register @ref RG_RF09_STATE */ +/** Access parameters for sub-register STATE in register @ref RG_RF09_STATE */ +#define SR_RF09_STATE_STATE RG_RF09_STATE, STATE_STATE_MASK, \ + STATE_STATE_SHIFT +/** Constant TRANSITION for sub-register @ref SR_STATE in register RF09_STATE */ +#define RF_TRANSITION (0x6) + +/** Address for register RF09_CMD */ +#define RG_RF09_CMD (0x103) +/** Sub-registers of Register @ref RG_RF09_CMD */ +/** Access parameters for sub-register CMD in register @ref RG_RF09_CMD */ +#define SR_RF09_CMD_CMD RG_RF09_CMD, CMD_CMD_MASK, CMD_CMD_SHIFT + +/** Address for register RF09_CS */ +#define RG_RF09_CS (0x104) +/** Sub-registers of Register @ref RG_RF09_CS */ +/** Access parameters for sub-register CS in register @ref RG_RF09_CS */ +#define SR_RF09_CS_CS RG_RF09_CS, CS_CS_MASK, CS_CS_SHIFT + +/** Address for register RF09_CCF0L */ +#define RG_RF09_CCF0L (0x105) +/** Sub-registers of Register @ref RG_RF09_CCF0L */ +/** Access parameters for sub-register CCF0L in register @ref RG_RF09_CCF0L */ +#define SR_RF09_CCF0L_CCF0L RG_RF09_CCF0L, CCF0L_CCF0L_MASK, \ + CCF0L_CCF0L_SHIFT + +/** Address for register RF09_CCF0H */ +#define RG_RF09_CCF0H (0x106) +/** Sub-registers of Register @ref RG_RF09_CCF0H */ +/** Access parameters for sub-register CCF0H in register @ref RG_RF09_CCF0H */ +#define SR_RF09_CCF0H_CCF0H RG_RF09_CCF0H, CCF0H_CCF0H_MASK, \ + CCF0H_CCF0H_SHIFT + +/** Address for register RF09_CNL */ +#define RG_RF09_CNL (0x107) +/** Sub-registers of Register @ref RG_RF09_CNL */ +/** Access parameters for sub-register CNL in register @ref RG_RF09_CNL */ +#define SR_RF09_CNL_CNL RG_RF09_CNL, CNL_CNL_MASK, CNL_CNL_SHIFT + +/** Address for register RF09_CNM */ +#define RG_RF09_CNM (0x108) +/** Sub-registers of Register @ref RG_RF09_CNM */ +/** Access parameters for sub-register CNH in register @ref RG_RF09_CNM */ +#define SR_RF09_CNM_CNH RG_RF09_CNM, CNM_CNH_MASK, CNM_CNH_SHIFT +/** Access parameters for sub-register CM in register @ref RG_RF09_CNM */ +#define SR_RF09_CNM_CM RG_RF09_CNM, CNM_CM_MASK, CNM_CM_SHIFT + +/** Address for register RF09_RXBWC */ +#define RG_RF09_RXBWC (0x109) +/** Sub-registers of Register @ref RG_RF09_RXBWC */ +/** Access parameters for sub-register BW in register @ref RG_RF09_RXBWC */ +#define SR_RF09_RXBWC_BW RG_RF09_RXBWC, RXBWC_BW_MASK, \ + RXBWC_BW_SHIFT + +/** Constant BW1000KHZ_IF1000KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW1000KHZ_IF1000KHZ (0x8) + +/** Constant BW1250KHZ_IF2000KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW1250KHZ_IF2000KHZ (0x9) + +/** Constant BW1600KHZ_IF2000KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW1600KHZ_IF2000KHZ (0xA) + +/** Constant BW160KHZ_IF250KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW160KHZ_IF250KHZ (0x0) + +/** Constant BW2000KHZ_IF2000KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW2000KHZ_IF2000KHZ (0xB) + +/** Constant BW200KHZ_IF250KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW200KHZ_IF250KHZ (0x1) + +/** Constant BW250KHZ_IF250KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW250KHZ_IF250KHZ (0x2) + +/** Constant BW320KHZ_IF500KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW320KHZ_IF500KHZ (0x3) + +/** Constant BW400KHZ_IF500KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW400KHZ_IF500KHZ (0x4) + +/** Constant BW500KHZ_IF500KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW500KHZ_IF500KHZ (0x5) + +/** Constant BW630KHZ_IF1000KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW630KHZ_IF1000KHZ (0x6) + +/** Constant BW800KHZ_IF1000KHZ for sub-register @ref SR_BW in register + * RF09_RXBWC */ +#define RF_BW800KHZ_IF1000KHZ (0x7) +/** Access parameters for sub-register IFS in register @ref RG_RF09_RXBWC */ +#define SR_RF09_RXBWC_IFS RG_RF09_RXBWC, RXBWC_IFS_MASK, \ + RXBWC_IFS_SHIFT +/** Access parameters for sub-register IFI in register @ref RG_RF09_RXBWC */ +#define SR_RF09_RXBWC_IFI RG_RF09_RXBWC, RXBWC_IFI_MASK, \ + RXBWC_IFI_SHIFT + +/** Address for register RF09_RXDFE */ +#define RG_RF09_RXDFE (0x10A) +/** Sub-registers of Register @ref RG_RF09_RXDFE */ +/** Access parameters for sub-register SR in register @ref RG_RF09_RXDFE */ +#define SR_RF09_RXDFE_SR RG_RF09_RXDFE, RXDFE_SR_MASK, \ + RXDFE_SR_SHIFT +/** Access parameters for sub-register RCUT in register @ref RG_RF09_RXDFE */ +#define SR_RF09_RXDFE_RCUT RG_RF09_RXDFE, RXDFE_RCUT_MASK, \ + RXDFE_RCUT_SHIFT + +/** Address for register RF09_AGCC */ +#define RG_RF09_AGCC (0x10B) +/** Sub-registers of Register @ref RG_RF09_AGCC */ +/** Access parameters for sub-register EN in register @ref RG_RF09_AGCC */ +#define SR_RF09_AGCC_EN RG_RF09_AGCC, AGCC_EN_MASK, \ + AGCC_EN_SHIFT +/** Access parameters for sub-register FRZC in register @ref RG_RF09_AGCC */ +#define SR_RF09_AGCC_FRZC RG_RF09_AGCC, AGCC_FRZC_MASK, \ + AGCC_FRZC_SHIFT +/** Access parameters for sub-register FRZS in register @ref RG_RF09_AGCC */ +#define SR_RF09_AGCC_FRZS RG_RF09_AGCC, AGCC_FRZS_MASK, \ + AGCC_FRZS_SHIFT +/** Access parameters for sub-register RST in register @ref RG_RF09_AGCC */ +#define SR_RF09_AGCC_RST RG_RF09_AGCC, AGCC_RST_MASK, \ + AGCC_RST_SHIFT +/** Access parameters for sub-register AVGS in register @ref RG_RF09_AGCC */ +#define SR_RF09_AGCC_AVGS RG_RF09_AGCC, AGCC_AVGS_MASK, \ + AGCC_AVGS_SHIFT +/** Access parameters for sub-register AGCI in register @ref RG_RF09_AGCC */ +#define SR_RF09_AGCC_AGCI RG_RF09_AGCC, AGCC_AGCI_MASK, \ + AGCC_AGCI_SHIFT + +/** Address for register RF09_AGCS */ +#define RG_RF09_AGCS (0x10C) +/** Sub-registers of Register @ref RG_RF09_AGCS */ +/** Access parameters for sub-register GCW in register @ref RG_RF09_AGCS */ +#define SR_RF09_AGCS_GCW RG_RF09_AGCS, AGCS_GCW_MASK, \ + AGCS_GCW_SHIFT +/** Access parameters for sub-register TGT in register @ref RG_RF09_AGCS */ +#define SR_RF09_AGCS_TGT RG_RF09_AGCS, AGCS_TGT_MASK, \ + AGCS_TGT_SHIFT + +/** Address for register RF09_RSSI */ +#define RG_RF09_RSSI (0x10D) +/** Sub-registers of Register @ref RG_RF09_RSSI */ +/** Access parameters for sub-register RSSI in register @ref RG_RF09_RSSI */ +#define SR_RF09_RSSI_RSSI RG_RF09_RSSI, RSSI_RSSI_MASK, \ + RSSI_RSSI_SHIFT + +/** Address for register RF09_EDC */ +#define RG_RF09_EDC (0x10E) +/** Sub-registers of Register @ref RG_RF09_EDC */ +/** Access parameters for sub-register EDM in register @ref RG_RF09_EDC */ +#define SR_RF09_EDC_EDM RG_RF09_EDC, EDC_EDM_MASK, EDC_EDM_SHIFT +/** Constant EDAUTO for sub-register @ref SR_EDM in register RF09_EDC */ +#define RF_EDAUTO (0x0) +/** Constant EDCONT for sub-register @ref SR_EDM in register RF09_EDC */ +#define RF_EDCONT (0x2) +/** Constant EDOFF for sub-register @ref SR_EDM in register RF09_EDC */ +#define RF_EDOFF (0x3) +/** Constant EDSINGLE for sub-register @ref SR_EDM in register RF09_EDC */ +#define RF_EDSINGLE (0x1) + +/** Address for register RF09_EDD */ +#define RG_RF09_EDD (0x10F) +/** Sub-registers of Register @ref RG_RF09_EDD */ +/** Access parameters for sub-register DTB in register @ref RG_RF09_EDD */ +#define SR_RF09_EDD_DTB RG_RF09_EDD, EDD_DTB_MASK, EDD_DTB_SHIFT +/** Access parameters for sub-register DF in register @ref RG_RF09_EDD */ +#define SR_RF09_EDD_DF RG_RF09_EDD, EDD_DF_MASK, EDD_DF_SHIFT + +/** Address for register RF09_EDV */ +#define RG_RF09_EDV (0x110) +/** Sub-registers of Register @ref RG_RF09_EDV */ +/** Access parameters for sub-register EDV in register @ref RG_RF09_EDV */ +#define SR_RF09_EDV_EDV RG_RF09_EDV, EDV_EDV_MASK, EDV_EDV_SHIFT + +/** Address for register RF09_RNDV */ +#define RG_RF09_RNDV (0x111) +/** Sub-registers of Register @ref RG_RF09_RNDV */ +/** Access parameters for sub-register RNDV in register @ref RG_RF09_RNDV */ +#define SR_RF09_RNDV_RNDV RG_RF09_RNDV, RNDV_RNDV_MASK, \ + RNDV_RNDV_SHIFT + +/** Address for register RF09_TXCUTC */ +#define RG_RF09_TXCUTC (0x112) +/** Sub-registers of Register @ref RG_RF09_TXCUTC */ +/** Access parameters for sub-register LPFCUT in register @ref RG_RF09_TXCUTC */ +#define SR_RF09_TXCUTC_LPFCUT RG_RF09_TXCUTC, TXCUTC_LPFCUT_MASK, \ + TXCUTC_LPFCUT_SHIFT + +/** Constant FLC1000KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC1000KHZ (0xB) + +/** Constant FLC100KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC100KHZ (0x1) + +/** Constant FLC125KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC125KHZ (0x2) + +/** Constant FLC160KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC160KHZ (0x3) + +/** Constant FLC200KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC200KHZ (0x4) + +/** Constant FLC250KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC250KHZ (0x5) + +/** Constant FLC315KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC315KHZ (0x6) + +/** Constant FLC400KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC400KHZ (0x7) + +/** Constant FLC500KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC500KHZ (0x8) + +/** Constant FLC625KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC625KHZ (0x9) + +/** Constant FLC800KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC +**/ +#define RF_FLC800KHZ (0xA) +/** Constant FLC80KHZ for sub-register @ref SR_LPFCUT in register RF09_TXCUTC */ +#define RF_FLC80KHZ (0x0) +/** Access parameters for sub-register PARAMP in register @ref RG_RF09_TXCUTC */ +#define SR_RF09_TXCUTC_PARAMP RG_RF09_TXCUTC, TXCUTC_PARAMP_MASK, \ + TXCUTC_PARAMP_SHIFT + +/** Constant PARAMP16U for sub-register @ref SR_PARAMP in register RF09_TXCUTC +**/ +#define RF_PARAMP16U (0x2) + +/** Constant PARAMP32U for sub-register @ref SR_PARAMP in register RF09_TXCUTC +**/ +#define RF_PARAMP32U (0x3) +/** Constant PARAMP4U for sub-register @ref SR_PARAMP in register RF09_TXCUTC */ +#define RF_PARAMP4U (0x0) +/** Constant PARAMP8U for sub-register @ref SR_PARAMP in register RF09_TXCUTC */ +#define RF_PARAMP8U (0x1) + +/** Address for register RF09_TXDFE */ +#define RG_RF09_TXDFE (0x113) +/** Sub-registers of Register @ref RG_RF09_TXDFE */ +/** Access parameters for sub-register SR in register @ref RG_RF09_TXDFE */ +#define SR_RF09_TXDFE_SR RG_RF09_TXDFE, TXDFE_SR_MASK, \ + TXDFE_SR_SHIFT +/** Access parameters for sub-register DM in register @ref RG_RF09_TXDFE */ +#define SR_RF09_TXDFE_DM RG_RF09_TXDFE, TXDFE_DM_MASK, \ + TXDFE_DM_SHIFT +/** Access parameters for sub-register RCUT in register @ref RG_RF09_TXDFE */ +#define SR_RF09_TXDFE_RCUT RG_RF09_TXDFE, TXDFE_RCUT_MASK, \ + TXDFE_RCUT_SHIFT + +/** Address for register RF09_PAC */ +#define RG_RF09_PAC (0x114) +/** Sub-registers of Register @ref RG_RF09_PAC */ +/** Access parameters for sub-register TXPWR in register @ref RG_RF09_PAC */ +#define SR_RF09_PAC_TXPWR RG_RF09_PAC, PAC_TXPWR_MASK, \ + PAC_TXPWR_SHIFT +/** Access parameters for sub-register PACUR in register @ref RG_RF09_PAC */ +#define SR_RF09_PAC_PACUR RG_RF09_PAC, PAC_PACUR_MASK, \ + PAC_PACUR_SHIFT + +/** Address for register RF09_PADFE */ +#define RG_RF09_PADFE (0x116) +/** Sub-registers of Register @ref RG_RF09_PADFE */ +/** Access parameters for sub-register PADFE in register @ref RG_RF09_PADFE */ +#define SR_RF09_PADFE_PADFE RG_RF09_PADFE, PADFE_PADFE_MASK, \ + PADFE_PADFE_SHIFT +/** Constant FEMODE0 for sub-register @ref SR_PADFE in register RF09_PADFE */ +#define RF_FEMODE0 (0x0) +/** Constant FEMODE1 for sub-register @ref SR_PADFE in register RF09_PADFE */ +#define RF_FEMODE1 (0x1) +/** Constant FEMODE2 for sub-register @ref SR_PADFE in register RF09_PADFE */ +#define RF_FEMODE2 (0x2) +/** Constant FEMODE3 for sub-register @ref SR_PADFE in register RF09_PADFE */ +#define RF_FEMODE3 (0x3) + +/** Address for register RF09_PLL */ +#define RG_RF09_PLL (0x121) +/** Sub-registers of Register @ref RG_RF09_PLL */ +/** Access parameters for sub-register LS in register @ref RG_RF09_PLL */ +#define SR_RF09_PLL_LS RG_RF09_PLL, PLL_LS_MASK, PLL_LS_SHIFT +/** Access parameters for sub-register LBW in register @ref RG_RF09_PLL */ +#define SR_RF09_PLL_LBW RG_RF09_PLL, PLL_LBW_MASK, PLL_LBW_SHIFT + +/** Address for register RF09_PLLCF */ +#define RG_RF09_PLLCF (0x122) +/** Sub-registers of Register @ref RG_RF09_PLLCF */ +/** Access parameters for sub-register CF in register @ref RG_RF09_PLLCF */ +#define SR_RF09_PLLCF_CF RG_RF09_PLLCF, PLLCF_CF_MASK, \ + PLLCF_CF_SHIFT + +/** Address for register RF09_TXCI */ +#define RG_RF09_TXCI (0x125) +/** Sub-registers of Register @ref RG_RF09_TXCI */ +/** Access parameters for sub-register DCOI in register @ref RG_RF09_TXCI */ +#define SR_RF09_TXCI_DCOI RG_RF09_TXCI, TXCI_DCOI_MASK, \ + TXCI_DCOI_SHIFT + +/** Address for register RF09_TXCQ */ +#define RG_RF09_TXCQ (0x126) +/** Sub-registers of Register @ref RG_RF09_TXCQ */ +/** Access parameters for sub-register DCOQ in register @ref RG_RF09_TXCQ */ +#define SR_RF09_TXCQ_DCOQ RG_RF09_TXCQ, TXCQ_DCOQ_MASK, \ + TXCQ_DCOQ_SHIFT + +/** Address for register RF09_TXDACI */ +#define RG_RF09_TXDACI (0x127) +/** Sub-registers of Register @ref RG_RF09_TXDACI */ + +/** Access parameters for sub-register TXDACID in register @ref RG_RF09_TXDACI +**/ +#define SR_RF09_TXDACI_TXDACID RG_RF09_TXDACI, TXDACI_TXDACID_MASK, \ + TXDACI_TXDACID_SHIFT + +/** Access parameters for sub-register ENTXDACID in register @ref RG_RF09_TXDACI +**/ +#define SR_RF09_TXDACI_ENTXDACID RG_RF09_TXDACI, TXDACI_ENTXDACID_MASK, \ + TXDACI_ENTXDACID_SHIFT + +/** Address for register RF09_TXDACQ */ +#define RG_RF09_TXDACQ (0x128) +/** Sub-registers of Register @ref RG_RF09_TXDACQ */ + +/** Access parameters for sub-register TXDACQD in register @ref RG_RF09_TXDACQ +**/ +#define SR_RF09_TXDACQ_TXDACQD RG_RF09_TXDACQ, TXDACQ_TXDACQD_MASK, \ + TXDACQ_TXDACQD_SHIFT + +/** Access parameters for sub-register ENTXDACQD in register @ref RG_RF09_TXDACQ +**/ +#define SR_RF09_TXDACQ_ENTXDACQD RG_RF09_TXDACQ, TXDACQ_ENTXDACQD_MASK, \ + TXDACQ_ENTXDACQD_SHIFT + +/** Address for register RF24_IRQM */ +#define RG_RF24_IRQM (0x200) +/** Sub-registers of Register @ref RG_RF24_IRQM */ +/** Access parameters for sub-register WAKEUP in register @ref RG_RF24_IRQM */ +#define SR_RF24_IRQM_WAKEUP RG_RF24_IRQM, IRQM_WAKEUP_MASK, \ + IRQM_WAKEUP_SHIFT +/** Access parameters for sub-register TRXRDY in register @ref RG_RF24_IRQM */ +#define SR_RF24_IRQM_TRXRDY RG_RF24_IRQM, IRQM_TRXRDY_MASK, \ + IRQM_TRXRDY_SHIFT +/** Access parameters for sub-register EDC in register @ref RG_RF24_IRQM */ +#define SR_RF24_IRQM_EDC RG_RF24_IRQM, IRQM_EDC_MASK, \ + IRQM_EDC_SHIFT +/** Access parameters for sub-register BATLOW in register @ref RG_RF24_IRQM */ +#define SR_RF24_IRQM_BATLOW RG_RF24_IRQM, IRQM_BATLOW_MASK, \ + IRQM_BATLOW_SHIFT +/** Access parameters for sub-register TRXERR in register @ref RG_RF24_IRQM */ +#define SR_RF24_IRQM_TRXERR RG_RF24_IRQM, IRQM_TRXERR_MASK, \ + IRQM_TRXERR_SHIFT +/** Access parameters for sub-register IQIFSF in register @ref RG_RF24_IRQM */ +#define SR_RF24_IRQM_IQIFSF RG_RF24_IRQM, IRQM_IQIFSF_MASK, \ + IRQM_IQIFSF_SHIFT + +/** Address for register BBC0_FBRXS */ +#define RG_BBC0_FBRXS (0x2000) +/** Sub-registers of Register @ref RG_BBC0_FBRXS */ +/** Access parameters for sub-register FBRXS in register @ref RG_BBC0_FBRXS */ +#define SR_BBC0_FBRXS_FBRXS RG_BBC0_FBRXS, FBRXS_FBRXS_MASK, \ + FBRXS_FBRXS_SHIFT + +/** Address for register RF24_AUXS */ +#define RG_RF24_AUXS (0x201) +/** Sub-registers of Register @ref RG_RF24_AUXS */ +/** Access parameters for sub-register PAVC in register @ref RG_RF24_AUXS */ +#define SR_RF24_AUXS_PAVC RG_RF24_AUXS, AUXS_PAVC_MASK, \ + AUXS_PAVC_SHIFT +/** Access parameters for sub-register AVS in register @ref RG_RF24_AUXS */ +#define SR_RF24_AUXS_AVS RG_RF24_AUXS, AUXS_AVS_MASK, \ + AUXS_AVS_SHIFT +/** Access parameters for sub-register AVEN in register @ref RG_RF24_AUXS */ +#define SR_RF24_AUXS_AVEN RG_RF24_AUXS, AUXS_AVEN_MASK, \ + AUXS_AVEN_SHIFT +/** Access parameters for sub-register AVEXT in register @ref RG_RF24_AUXS */ +#define SR_RF24_AUXS_AVEXT RG_RF24_AUXS, AUXS_AVEXT_MASK, \ + AUXS_AVEXT_SHIFT +/** Access parameters for sub-register AGCMAP in register @ref RG_RF24_AUXS */ +#define SR_RF24_AUXS_AGCMAP RG_RF24_AUXS, AUXS_AGCMAP_MASK, \ + AUXS_AGCMAP_SHIFT + +/** Access parameters for sub-register EXTLNABYP in register @ref RG_RF24_AUXS +**/ +#define SR_RF24_AUXS_EXTLNABYP RG_RF24_AUXS, AUXS_EXTLNABYP_MASK, \ + AUXS_EXTLNABYP_SHIFT + +/** Address for register RF24_STATE */ +#define RG_RF24_STATE (0x202) +/** Sub-registers of Register @ref RG_RF24_STATE */ +/** Access parameters for sub-register STATE in register @ref RG_RF24_STATE */ +#define SR_RF24_STATE_STATE RG_RF24_STATE, STATE_STATE_MASK, \ + STATE_STATE_SHIFT + +/** Address for register RF24_CMD */ +#define RG_RF24_CMD (0x203) +/** Sub-registers of Register @ref RG_RF24_CMD */ +/** Access parameters for sub-register CMD in register @ref RG_RF24_CMD */ +#define SR_RF24_CMD_CMD RG_RF24_CMD, CMD_CMD_MASK, CMD_CMD_SHIFT + +/** Address for register RF24_CS */ +#define RG_RF24_CS (0x204) +/** Sub-registers of Register @ref RG_RF24_CS */ +/** Access parameters for sub-register CS in register @ref RG_RF24_CS */ +#define SR_RF24_CS_CS RG_RF24_CS, CS_CS_MASK, CS_CS_SHIFT + +/** Address for register RF24_CCF0L */ +#define RG_RF24_CCF0L (0x205) +/** Sub-registers of Register @ref RG_RF24_CCF0L */ +/** Access parameters for sub-register CCF0L in register @ref RG_RF24_CCF0L */ +#define SR_RF24_CCF0L_CCF0L RG_RF24_CCF0L, CCF0L_CCF0L_MASK, \ + CCF0L_CCF0L_SHIFT + +/** Address for register RF24_CCF0H */ +#define RG_RF24_CCF0H (0x206) +/** Sub-registers of Register @ref RG_RF24_CCF0H */ +/** Access parameters for sub-register CCF0H in register @ref RG_RF24_CCF0H */ +#define SR_RF24_CCF0H_CCF0H RG_RF24_CCF0H, CCF0H_CCF0H_MASK, \ + CCF0H_CCF0H_SHIFT + +/** Address for register RF24_CNL */ +#define RG_RF24_CNL (0x207) +/** Sub-registers of Register @ref RG_RF24_CNL */ +/** Access parameters for sub-register CNL in register @ref RG_RF24_CNL */ +#define SR_RF24_CNL_CNL RG_RF24_CNL, CNL_CNL_MASK, CNL_CNL_SHIFT + +/** Address for register RF24_CNM */ +#define RG_RF24_CNM (0x208) +/** Sub-registers of Register @ref RG_RF24_CNM */ +/** Access parameters for sub-register CNH in register @ref RG_RF24_CNM */ +#define SR_RF24_CNM_CNH RG_RF24_CNM, CNM_CNH_MASK, CNM_CNH_SHIFT +/** Access parameters for sub-register CM in register @ref RG_RF24_CNM */ +#define SR_RF24_CNM_CM RG_RF24_CNM, CNM_CM_MASK, CNM_CM_SHIFT + +/** Address for register RF24_RXBWC */ +#define RG_RF24_RXBWC (0x209) +/** Sub-registers of Register @ref RG_RF24_RXBWC */ +/** Access parameters for sub-register BW in register @ref RG_RF24_RXBWC */ +#define SR_RF24_RXBWC_BW RG_RF24_RXBWC, RXBWC_BW_MASK, \ + RXBWC_BW_SHIFT +/** Access parameters for sub-register IFS in register @ref RG_RF24_RXBWC */ +#define SR_RF24_RXBWC_IFS RG_RF24_RXBWC, RXBWC_IFS_MASK, \ + RXBWC_IFS_SHIFT +/** Access parameters for sub-register IFI in register @ref RG_RF24_RXBWC */ +#define SR_RF24_RXBWC_IFI RG_RF24_RXBWC, RXBWC_IFI_MASK, \ + RXBWC_IFI_SHIFT + +/** Address for register RF24_RXDFE */ +#define RG_RF24_RXDFE (0x20A) +/** Sub-registers of Register @ref RG_RF24_RXDFE */ +/** Access parameters for sub-register SR in register @ref RG_RF24_RXDFE */ +#define SR_RF24_RXDFE_SR RG_RF24_RXDFE, RXDFE_SR_MASK, \ + RXDFE_SR_SHIFT +/** Access parameters for sub-register RCUT in register @ref RG_RF24_RXDFE */ +#define SR_RF24_RXDFE_RCUT RG_RF24_RXDFE, RXDFE_RCUT_MASK, \ + RXDFE_RCUT_SHIFT + +/** Address for register RF24_AGCC */ +#define RG_RF24_AGCC (0x20B) +/** Sub-registers of Register @ref RG_RF24_AGCC */ +/** Access parameters for sub-register EN in register @ref RG_RF24_AGCC */ +#define SR_RF24_AGCC_EN RG_RF24_AGCC, AGCC_EN_MASK, \ + AGCC_EN_SHIFT +/** Access parameters for sub-register FRZC in register @ref RG_RF24_AGCC */ +#define SR_RF24_AGCC_FRZC RG_RF24_AGCC, AGCC_FRZC_MASK, \ + AGCC_FRZC_SHIFT +/** Access parameters for sub-register FRZS in register @ref RG_RF24_AGCC */ +#define SR_RF24_AGCC_FRZS RG_RF24_AGCC, AGCC_FRZS_MASK, \ + AGCC_FRZS_SHIFT +/** Access parameters for sub-register RST in register @ref RG_RF24_AGCC */ +#define SR_RF24_AGCC_RST RG_RF24_AGCC, AGCC_RST_MASK, \ + AGCC_RST_SHIFT +/** Access parameters for sub-register AVGS in register @ref RG_RF24_AGCC */ +#define SR_RF24_AGCC_AVGS RG_RF24_AGCC, AGCC_AVGS_MASK, \ + AGCC_AVGS_SHIFT +/** Access parameters for sub-register AGCI in register @ref RG_RF24_AGCC */ +#define SR_RF24_AGCC_AGCI RG_RF24_AGCC, AGCC_AGCI_MASK, \ + AGCC_AGCI_SHIFT + +/** Address for register RF24_AGCS */ +#define RG_RF24_AGCS (0x20C) +/** Sub-registers of Register @ref RG_RF24_AGCS */ +/** Access parameters for sub-register GCW in register @ref RG_RF24_AGCS */ +#define SR_RF24_AGCS_GCW RG_RF24_AGCS, AGCS_GCW_MASK, \ + AGCS_GCW_SHIFT +/** Access parameters for sub-register TGT in register @ref RG_RF24_AGCS */ +#define SR_RF24_AGCS_TGT RG_RF24_AGCS, AGCS_TGT_MASK, \ + AGCS_TGT_SHIFT + +/** Address for register RF24_RSSI */ +#define RG_RF24_RSSI (0x20D) +/** Sub-registers of Register @ref RG_RF24_RSSI */ +/** Access parameters for sub-register RSSI in register @ref RG_RF24_RSSI */ +#define SR_RF24_RSSI_RSSI RG_RF24_RSSI, RSSI_RSSI_MASK, \ + RSSI_RSSI_SHIFT + +/** Address for register RF24_EDC */ +#define RG_RF24_EDC (0x20E) +/** Sub-registers of Register @ref RG_RF24_EDC */ +/** Access parameters for sub-register EDM in register @ref RG_RF24_EDC */ +#define SR_RF24_EDC_EDM RG_RF24_EDC, EDC_EDM_MASK, EDC_EDM_SHIFT + +/** Address for register RF24_EDD */ +#define RG_RF24_EDD (0x20F) +/** Sub-registers of Register @ref RG_RF24_EDD */ +/** Access parameters for sub-register DTB in register @ref RG_RF24_EDD */ +#define SR_RF24_EDD_DTB RG_RF24_EDD, EDD_DTB_MASK, EDD_DTB_SHIFT +/** Access parameters for sub-register DF in register @ref RG_RF24_EDD */ +#define SR_RF24_EDD_DF RG_RF24_EDD, EDD_DF_MASK, EDD_DF_SHIFT + +/** Address for register RF24_EDV */ +#define RG_RF24_EDV (0x210) +/** Sub-registers of Register @ref RG_RF24_EDV */ +/** Access parameters for sub-register EDV in register @ref RG_RF24_EDV */ +#define SR_RF24_EDV_EDV RG_RF24_EDV, EDV_EDV_MASK, EDV_EDV_SHIFT + +/** Address for register RF24_RNDV */ +#define RG_RF24_RNDV (0x211) +/** Sub-registers of Register @ref RG_RF24_RNDV */ +/** Access parameters for sub-register RNDV in register @ref RG_RF24_RNDV */ +#define SR_RF24_RNDV_RNDV RG_RF24_RNDV, RNDV_RNDV_MASK, \ + RNDV_RNDV_SHIFT + +/** Address for register RF24_TXCUTC */ +#define RG_RF24_TXCUTC (0x212) +/** Sub-registers of Register @ref RG_RF24_TXCUTC */ +/** Access parameters for sub-register LPFCUT in register @ref RG_RF24_TXCUTC */ +#define SR_RF24_TXCUTC_LPFCUT RG_RF24_TXCUTC, TXCUTC_LPFCUT_MASK, \ + TXCUTC_LPFCUT_SHIFT +/** Access parameters for sub-register PARAMP in register @ref RG_RF24_TXCUTC */ +#define SR_RF24_TXCUTC_PARAMP RG_RF24_TXCUTC, TXCUTC_PARAMP_MASK, \ + TXCUTC_PARAMP_SHIFT + +/** Address for register RF24_TXDFE */ +#define RG_RF24_TXDFE (0x213) +/** Sub-registers of Register @ref RG_RF24_TXDFE */ +/** Access parameters for sub-register SR in register @ref RG_RF24_TXDFE */ +#define SR_RF24_TXDFE_SR RG_RF24_TXDFE, TXDFE_SR_MASK, \ + TXDFE_SR_SHIFT +/** Access parameters for sub-register DM in register @ref RG_RF24_TXDFE */ +#define SR_RF24_TXDFE_DM RG_RF24_TXDFE, TXDFE_DM_MASK, \ + TXDFE_DM_SHIFT +/** Access parameters for sub-register RCUT in register @ref RG_RF24_TXDFE */ +#define SR_RF24_TXDFE_RCUT RG_RF24_TXDFE, TXDFE_RCUT_MASK, \ + TXDFE_RCUT_SHIFT + +/** Address for register RF24_PAC */ +#define RG_RF24_PAC (0x214) +/** Sub-registers of Register @ref RG_RF24_PAC */ +/** Access parameters for sub-register TXPWR in register @ref RG_RF24_PAC */ +#define SR_RF24_PAC_TXPWR RG_RF24_PAC, PAC_TXPWR_MASK, \ + PAC_TXPWR_SHIFT +/** Access parameters for sub-register PACUR in register @ref RG_RF24_PAC */ +#define SR_RF24_PAC_PACUR RG_RF24_PAC, PAC_PACUR_MASK, \ + PAC_PACUR_SHIFT + +/** Address for register RF24_PADFE */ +#define RG_RF24_PADFE (0x216) +/** Sub-registers of Register @ref RG_RF24_PADFE */ +/** Access parameters for sub-register PADFE in register @ref RG_RF24_PADFE */ +#define SR_RF24_PADFE_PADFE RG_RF24_PADFE, PADFE_PADFE_MASK, \ + PADFE_PADFE_SHIFT + +/** Address for register RF24_PLL */ +#define RG_RF24_PLL (0x221) +/** Sub-registers of Register @ref RG_RF24_PLL */ +/** Access parameters for sub-register LS in register @ref RG_RF24_PLL */ +#define SR_RF24_PLL_LS RG_RF24_PLL, PLL_LS_MASK, PLL_LS_SHIFT +/** Access parameters for sub-register LBW in register @ref RG_RF24_PLL */ +#define SR_RF24_PLL_LBW RG_RF24_PLL, PLL_LBW_MASK, PLL_LBW_SHIFT + +/** Address for register RF24_PLLCF */ +#define RG_RF24_PLLCF (0x222) +/** Sub-registers of Register @ref RG_RF24_PLLCF */ +/** Access parameters for sub-register CF in register @ref RG_RF24_PLLCF */ +#define SR_RF24_PLLCF_CF RG_RF24_PLLCF, PLLCF_CF_MASK, \ + PLLCF_CF_SHIFT + +/** Address for register RF24_TXCI */ +#define RG_RF24_TXCI (0x225) +/** Sub-registers of Register @ref RG_RF24_TXCI */ +/** Access parameters for sub-register DCOI in register @ref RG_RF24_TXCI */ +#define SR_RF24_TXCI_DCOI RG_RF24_TXCI, TXCI_DCOI_MASK, \ + TXCI_DCOI_SHIFT + +/** Address for register RF24_TXCQ */ +#define RG_RF24_TXCQ (0x226) +/** Sub-registers of Register @ref RG_RF24_TXCQ */ +/** Access parameters for sub-register DCOQ in register @ref RG_RF24_TXCQ */ +#define SR_RF24_TXCQ_DCOQ RG_RF24_TXCQ, TXCQ_DCOQ_MASK, \ + TXCQ_DCOQ_SHIFT + +/** Address for register RF24_TXDACI */ +#define RG_RF24_TXDACI (0x227) +/** Sub-registers of Register @ref RG_RF24_TXDACI */ + +/** Access parameters for sub-register TXDACID in register @ref RG_RF24_TXDACI +**/ +#define SR_RF24_TXDACI_TXDACID RG_RF24_TXDACI, TXDACI_TXDACID_MASK, \ + TXDACI_TXDACID_SHIFT + +/** Access parameters for sub-register ENTXDACID in register @ref RG_RF24_TXDACI +**/ +#define SR_RF24_TXDACI_ENTXDACID RG_RF24_TXDACI, TXDACI_ENTXDACID_MASK, \ + TXDACI_ENTXDACID_SHIFT + +/** Address for register RF24_TXDACQ */ +#define RG_RF24_TXDACQ (0x228) +/** Sub-registers of Register @ref RG_RF24_TXDACQ */ + +/** Access parameters for sub-register TXDACQD in register @ref RG_RF24_TXDACQ +**/ +#define SR_RF24_TXDACQ_TXDACQD RG_RF24_TXDACQ, TXDACQ_TXDACQD_MASK, \ + TXDACQ_TXDACQD_SHIFT + +/** Access parameters for sub-register ENTXDACQD in register @ref RG_RF24_TXDACQ +**/ +#define SR_RF24_TXDACQ_ENTXDACQD RG_RF24_TXDACQ, TXDACQ_ENTXDACQD_MASK, \ + TXDACQ_ENTXDACQD_SHIFT + +/** Address for register BBC0_FBRXE */ +#define RG_BBC0_FBRXE (0x27FE) +/** Sub-registers of Register @ref RG_BBC0_FBRXE */ +/** Access parameters for sub-register FBRXE in register @ref RG_BBC0_FBRXE */ +#define SR_BBC0_FBRXE_FBRXE RG_BBC0_FBRXE, FBRXE_FBRXE_MASK, \ + FBRXE_FBRXE_SHIFT + +/** Address for register BBC0_FBTXS */ +#define RG_BBC0_FBTXS (0x2800) +/** Sub-registers of Register @ref RG_BBC0_FBTXS */ +/** Access parameters for sub-register FBTXS in register @ref RG_BBC0_FBTXS */ +#define SR_BBC0_FBTXS_FBTXS RG_BBC0_FBTXS, FBTXS_FBTXS_MASK, \ + FBTXS_FBTXS_SHIFT + +/** Address for register BBC0_FBTXE */ +#define RG_BBC0_FBTXE (0x2FFE) +/** Sub-registers of Register @ref RG_BBC0_FBTXE */ +/** Access parameters for sub-register FBTXE in register @ref RG_BBC0_FBTXE */ +#define SR_BBC0_FBTXE_FBTXE RG_BBC0_FBTXE, FBTXE_FBTXE_MASK, \ + FBTXE_FBTXE_SHIFT + +/** Address for register BBC0_IRQM */ +#define RG_BBC0_IRQM (0x300) +/** Sub-registers of Register @ref RG_BBC0_IRQM */ +/** Access parameters for sub-register RXFS in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_RXFS RG_BBC0_IRQM, IRQM_RXFS_MASK, \ + IRQM_RXFS_SHIFT +/** Access parameters for sub-register RXFE in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_RXFE RG_BBC0_IRQM, IRQM_RXFE_MASK, \ + IRQM_RXFE_SHIFT +/** Access parameters for sub-register RXAM in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_RXAM RG_BBC0_IRQM, IRQM_RXAM_MASK, \ + IRQM_RXAM_SHIFT +/** Access parameters for sub-register RXEM in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_RXEM RG_BBC0_IRQM, IRQM_RXEM_MASK, \ + IRQM_RXEM_SHIFT +/** Access parameters for sub-register TXFE in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_TXFE RG_BBC0_IRQM, IRQM_TXFE_MASK, \ + IRQM_TXFE_SHIFT +/** Access parameters for sub-register AGCH in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_AGCH RG_BBC0_IRQM, IRQM_AGCH_MASK, \ + IRQM_AGCH_SHIFT +/** Access parameters for sub-register AGCR in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_AGCR RG_BBC0_IRQM, IRQM_AGCR_MASK, \ + IRQM_AGCR_SHIFT +/** Access parameters for sub-register FBLI in register @ref RG_BBC0_IRQM */ +#define SR_BBC0_IRQM_FBLI RG_BBC0_IRQM, IRQM_FBLI_MASK, \ + IRQM_FBLI_SHIFT + +/** Address for register BBC1_FBRXS */ +#define RG_BBC1_FBRXS (0x3000) +/** Sub-registers of Register @ref RG_BBC1_FBRXS */ +/** Access parameters for sub-register FBRXS in register @ref RG_BBC1_FBRXS */ +#define SR_BBC1_FBRXS_FBRXS RG_BBC1_FBRXS, FBRXS_FBRXS_MASK, \ + FBRXS_FBRXS_SHIFT + +/** Address for register BBC0_PC */ +#define RG_BBC0_PC (0x301) +/** Sub-registers of Register @ref RG_BBC0_PC */ +/** Access parameters for sub-register PT in register @ref RG_BBC0_PC */ +#define SR_BBC0_PC_PT RG_BBC0_PC, PC_PT_MASK, PC_PT_SHIFT +/** Constant MRFSK for sub-register @ref SR_PT in register BBC0_PC */ +#define BB_MRFSK (0x1) +/** Constant MROFDM for sub-register @ref SR_PT in register BBC0_PC */ +#define BB_MROFDM (0x2) +/** Constant MROQPSK for sub-register @ref SR_PT in register BBC0_PC */ +#define BB_MROQPSK (0x3) +/** Constant PHYOFF for sub-register @ref SR_PT in register BBC0_PC */ +#define BB_PHYOFF (0x0) +/** Access parameters for sub-register BBEN in register @ref RG_BBC0_PC */ +#define SR_BBC0_PC_BBEN RG_BBC0_PC, PC_BBEN_MASK, PC_BBEN_SHIFT +/** Access parameters for sub-register FCST in register @ref RG_BBC0_PC */ +#define SR_BBC0_PC_FCST RG_BBC0_PC, PC_FCST_MASK, PC_FCST_SHIFT +/** Access parameters for sub-register TXAFCS in register @ref RG_BBC0_PC */ +#define SR_BBC0_PC_TXAFCS RG_BBC0_PC, PC_TXAFCS_MASK, \ + PC_TXAFCS_SHIFT +/** Access parameters for sub-register FCSOK in register @ref RG_BBC0_PC */ +#define SR_BBC0_PC_FCSOK RG_BBC0_PC, PC_FCSOK_MASK, \ + PC_FCSOK_SHIFT +/** Access parameters for sub-register FCSFE in register @ref RG_BBC0_PC */ +#define SR_BBC0_PC_FCSFE RG_BBC0_PC, PC_FCSFE_MASK, \ + PC_FCSFE_SHIFT +/** Access parameters for sub-register CTX in register @ref RG_BBC0_PC */ +#define SR_BBC0_PC_CTX RG_BBC0_PC, PC_CTX_MASK, PC_CTX_SHIFT + +/** Address for register BBC0_PS */ +#define RG_BBC0_PS (0x302) +/** Sub-registers of Register @ref RG_BBC0_PS */ +/** Access parameters for sub-register TXUR in register @ref RG_BBC0_PS */ +#define SR_BBC0_PS_TXUR RG_BBC0_PS, PS_TXUR_MASK, PS_TXUR_SHIFT + +/** Address for register BBC0_RXFLL */ +#define RG_BBC0_RXFLL (0x304) +/** Sub-registers of Register @ref RG_BBC0_RXFLL */ +/** Access parameters for sub-register RXFLL in register @ref RG_BBC0_RXFLL */ +#define SR_BBC0_RXFLL_RXFLL RG_BBC0_RXFLL, RXFLL_RXFLL_MASK, \ + RXFLL_RXFLL_SHIFT + +/** Address for register BBC0_RXFLH */ +#define RG_BBC0_RXFLH (0x305) +/** Sub-registers of Register @ref RG_BBC0_RXFLH */ +/** Access parameters for sub-register RXFLH in register @ref RG_BBC0_RXFLH */ +#define SR_BBC0_RXFLH_RXFLH RG_BBC0_RXFLH, RXFLH_RXFLH_MASK, \ + RXFLH_RXFLH_SHIFT + +/** Address for register BBC0_TXFLL */ +#define RG_BBC0_TXFLL (0x306) +/** Sub-registers of Register @ref RG_BBC0_TXFLL */ +/** Access parameters for sub-register TXFLL in register @ref RG_BBC0_TXFLL */ +#define SR_BBC0_TXFLL_TXFLL RG_BBC0_TXFLL, TXFLL_TXFLL_MASK, \ + TXFLL_TXFLL_SHIFT + +/** Address for register BBC0_TXFLH */ +#define RG_BBC0_TXFLH (0x307) +/** Sub-registers of Register @ref RG_BBC0_TXFLH */ +/** Access parameters for sub-register TXFLH in register @ref RG_BBC0_TXFLH */ +#define SR_BBC0_TXFLH_TXFLH RG_BBC0_TXFLH, TXFLH_TXFLH_MASK, \ + TXFLH_TXFLH_SHIFT + +/** Address for register BBC0_FBLL */ +#define RG_BBC0_FBLL (0x308) +/** Sub-registers of Register @ref RG_BBC0_FBLL */ +/** Access parameters for sub-register FBLL in register @ref RG_BBC0_FBLL */ +#define SR_BBC0_FBLL_FBLL RG_BBC0_FBLL, FBLL_FBLL_MASK, \ + FBLL_FBLL_SHIFT + +/** Address for register BBC0_FBLH */ +#define RG_BBC0_FBLH (0x309) +/** Sub-registers of Register @ref RG_BBC0_FBLH */ +/** Access parameters for sub-register FBLH in register @ref RG_BBC0_FBLH */ +#define SR_BBC0_FBLH_FBLH RG_BBC0_FBLH, FBLH_FBLH_MASK, \ + FBLH_FBLH_SHIFT + +/** Address for register BBC0_FBLIL */ +#define RG_BBC0_FBLIL (0x30A) +/** Sub-registers of Register @ref RG_BBC0_FBLIL */ +/** Access parameters for sub-register FBLIL in register @ref RG_BBC0_FBLIL */ +#define SR_BBC0_FBLIL_FBLIL RG_BBC0_FBLIL, FBLIL_FBLIL_MASK, \ + FBLIL_FBLIL_SHIFT + +/** Address for register BBC0_FBLIH */ +#define RG_BBC0_FBLIH (0x30B) +/** Sub-registers of Register @ref RG_BBC0_FBLIH */ +/** Access parameters for sub-register FBLIH in register @ref RG_BBC0_FBLIH */ +#define SR_BBC0_FBLIH_FBLIH RG_BBC0_FBLIH, FBLIH_FBLIH_MASK, \ + FBLIH_FBLIH_SHIFT + +/** Address for register BBC0_OFDMPHRTX */ +#define RG_BBC0_OFDMPHRTX (0x30C) +/** Sub-registers of Register @ref RG_BBC0_OFDMPHRTX */ +/** Access parameters for sub-register MCS in register @ref RG_BBC0_OFDMPHRTX */ +#define SR_BBC0_OFDMPHRTX_MCS RG_BBC0_OFDMPHRTX, OFDMPHRTX_MCS_MASK, \ + OFDMPHRTX_MCS_SHIFT +/** Access parameters for sub-register RB5 in register @ref RG_BBC0_OFDMPHRTX */ +#define SR_BBC0_OFDMPHRTX_RB5 RG_BBC0_OFDMPHRTX, OFDMPHRTX_RB5_MASK, \ + OFDMPHRTX_RB5_SHIFT + +/** Access parameters for sub-register RB17 in register @ref RG_BBC0_OFDMPHRTX +**/ +#define SR_BBC0_OFDMPHRTX_RB17 RG_BBC0_OFDMPHRTX, OFDMPHRTX_RB17_MASK, \ + OFDMPHRTX_RB17_SHIFT + +/** Access parameters for sub-register RB18 in register @ref RG_BBC0_OFDMPHRTX +**/ +#define SR_BBC0_OFDMPHRTX_RB18 RG_BBC0_OFDMPHRTX, OFDMPHRTX_RB18_MASK, \ + OFDMPHRTX_RB18_SHIFT + +/** Access parameters for sub-register RB21 in register @ref RG_BBC0_OFDMPHRTX +**/ +#define SR_BBC0_OFDMPHRTX_RB21 RG_BBC0_OFDMPHRTX, OFDMPHRTX_RB21_MASK, \ + OFDMPHRTX_RB21_SHIFT + +/** Address for register BBC0_OFDMPHRRX */ +#define RG_BBC0_OFDMPHRRX (0x30D) +/** Sub-registers of Register @ref RG_BBC0_OFDMPHRRX */ +/** Access parameters for sub-register MCS in register @ref RG_BBC0_OFDMPHRRX */ +#define SR_BBC0_OFDMPHRRX_MCS RG_BBC0_OFDMPHRRX, OFDMPHRRX_MCS_MASK, \ + OFDMPHRRX_MCS_SHIFT +/** Access parameters for sub-register SPC in register @ref RG_BBC0_OFDMPHRRX */ +#define SR_BBC0_OFDMPHRRX_SPC RG_BBC0_OFDMPHRRX, OFDMPHRRX_SPC_MASK, \ + OFDMPHRRX_SPC_SHIFT +/** Access parameters for sub-register RB5 in register @ref RG_BBC0_OFDMPHRRX */ +#define SR_BBC0_OFDMPHRRX_RB5 RG_BBC0_OFDMPHRRX, OFDMPHRRX_RB5_MASK, \ + OFDMPHRRX_RB5_SHIFT + +/** Access parameters for sub-register RB17 in register @ref RG_BBC0_OFDMPHRRX +**/ +#define SR_BBC0_OFDMPHRRX_RB17 RG_BBC0_OFDMPHRRX, OFDMPHRRX_RB17_MASK, \ + OFDMPHRRX_RB17_SHIFT + +/** Access parameters for sub-register RB18 in register @ref RG_BBC0_OFDMPHRRX +**/ +#define SR_BBC0_OFDMPHRRX_RB18 RG_BBC0_OFDMPHRRX, OFDMPHRRX_RB18_MASK, \ + OFDMPHRRX_RB18_SHIFT + +/** Access parameters for sub-register RB21 in register @ref RG_BBC0_OFDMPHRRX +**/ +#define SR_BBC0_OFDMPHRRX_RB21 RG_BBC0_OFDMPHRRX, OFDMPHRRX_RB21_MASK, \ + OFDMPHRRX_RB21_SHIFT + +/** Address for register BBC0_OFDMC */ +#define RG_BBC0_OFDMC (0x30E) +/** Sub-registers of Register @ref RG_BBC0_OFDMC */ +/** Access parameters for sub-register OPT in register @ref RG_BBC0_OFDMC */ +#define SR_BBC0_OFDMC_OPT RG_BBC0_OFDMC, OFDMC_OPT_MASK, \ + OFDMC_OPT_SHIFT +/** Access parameters for sub-register POI in register @ref RG_BBC0_OFDMC */ +#define SR_BBC0_OFDMC_POI RG_BBC0_OFDMC, OFDMC_POI_MASK, \ + OFDMC_POI_SHIFT +/** Access parameters for sub-register LFO in register @ref RG_BBC0_OFDMC */ +#define SR_BBC0_OFDMC_LFO RG_BBC0_OFDMC, OFDMC_LFO_MASK, \ + OFDMC_LFO_SHIFT +/** Access parameters for sub-register SSTX in register @ref RG_BBC0_OFDMC */ +#define SR_BBC0_OFDMC_SSTX RG_BBC0_OFDMC, OFDMC_SSTX_MASK, \ + OFDMC_SSTX_SHIFT +/** Access parameters for sub-register SSRX in register @ref RG_BBC0_OFDMC */ +#define SR_BBC0_OFDMC_SSRX RG_BBC0_OFDMC, OFDMC_SSRX_MASK, \ + OFDMC_SSRX_SHIFT + +/** Address for register BBC0_OFDMSW */ +#define RG_BBC0_OFDMSW (0x30F) +/** Sub-registers of Register @ref RG_BBC0_OFDMSW */ +/** Access parameters for sub-register RXO in register @ref RG_BBC0_OFDMSW */ +#define SR_BBC0_OFDMSW_RXO RG_BBC0_OFDMSW, OFDMSW_RXO_MASK, \ + OFDMSW_RXO_SHIFT +/** Access parameters for sub-register PDT in register @ref RG_BBC0_OFDMSW */ +#define SR_BBC0_OFDMSW_PDT RG_BBC0_OFDMSW, OFDMSW_PDT_MASK, \ + OFDMSW_PDT_SHIFT + +/** Address for register BBC0_OQPSKC0 */ +#define RG_BBC0_OQPSKC0 (0x310) +/** Sub-registers of Register @ref RG_BBC0_OQPSKC0 */ +/** Access parameters for sub-register FCHIP in register @ref RG_BBC0_OQPSKC0 */ +#define SR_BBC0_OQPSKC0_FCHIP RG_BBC0_OQPSKC0, OQPSKC0_FCHIP_MASK, \ + OQPSKC0_FCHIP_SHIFT +/** Constant FCHIP100 for sub-register @ref SR_FCHIP in register BBC0_OQPSKC0 */ +#define BB_FCHIP100 (0x0) + +/** Constant FCHIP1000 for sub-register @ref SR_FCHIP in register BBC0_OQPSKC0 +**/ +#define BB_FCHIP1000 (0x2) +/** Constant FCHIP200 for sub-register @ref SR_FCHIP in register BBC0_OQPSKC0 */ +#define BB_FCHIP200 (0x1) + +/** Constant FCHIP2000 for sub-register @ref SR_FCHIP in register BBC0_OQPSKC0 +**/ +#define BB_FCHIP2000 (0x3) +/** Access parameters for sub-register MOD in register @ref RG_BBC0_OQPSKC0 */ +#define SR_BBC0_OQPSKC0_MOD RG_BBC0_OQPSKC0, OQPSKC0_MOD_MASK, \ + OQPSKC0_MOD_SHIFT +/** Constant RC08 for sub-register @ref SR_MOD in register BBC0_OQPSKC0 */ +#define BB_RC08 (0x0) +/** Constant RRC08 for sub-register @ref SR_MOD in register BBC0_OQPSKC0 */ +#define BB_RRC08 (0x1) +/** Access parameters for sub-register DM in register @ref RG_BBC0_OQPSKC0 */ +#define SR_BBC0_OQPSKC0_DM RG_BBC0_OQPSKC0, OQPSKC0_DM_MASK, \ + OQPSKC0_DM_SHIFT + +/** Address for register BBC0_OQPSKC1 */ +#define RG_BBC0_OQPSKC1 (0x311) +/** Sub-registers of Register @ref RG_BBC0_OQPSKC1 */ +/** Access parameters for sub-register PDT0 in register @ref RG_BBC0_OQPSKC1 */ +#define SR_BBC0_OQPSKC1_PDT0 RG_BBC0_OQPSKC1, OQPSKC1_PDT0_MASK, \ + OQPSKC1_PDT0_SHIFT +/** Access parameters for sub-register PDT1 in register @ref RG_BBC0_OQPSKC1 */ +#define SR_BBC0_OQPSKC1_PDT1 RG_BBC0_OQPSKC1, OQPSKC1_PDT1_MASK, \ + OQPSKC1_PDT1_SHIFT + +/** Access parameters for sub-register RXOLEG in register @ref RG_BBC0_OQPSKC1 +**/ +#define SR_BBC0_OQPSKC1_RXOLEG RG_BBC0_OQPSKC1, OQPSKC1_RXOLEG_MASK, \ + OQPSKC1_RXOLEG_SHIFT +/** Access parameters for sub-register RXO in register @ref RG_BBC0_OQPSKC1 */ +#define SR_BBC0_OQPSKC1_RXO RG_BBC0_OQPSKC1, OQPSKC1_RXO_MASK, \ + OQPSKC1_RXO_SHIFT + +/** Address for register BBC0_OQPSKC2 */ +#define RG_BBC0_OQPSKC2 (0x312) +/** Sub-registers of Register @ref RG_BBC0_OQPSKC2 */ +/** Access parameters for sub-register RXM in register @ref RG_BBC0_OQPSKC2 */ +#define SR_BBC0_OQPSKC2_RXM RG_BBC0_OQPSKC2, OQPSKC2_RXM_MASK, \ + OQPSKC2_RXM_SHIFT + +/** Access parameters for sub-register FCSTLEG in register @ref RG_BBC0_OQPSKC2 +**/ +#define SR_BBC0_OQPSKC2_FCSTLEG RG_BBC0_OQPSKC2, OQPSKC2_FCSTLEG_MASK, \ + OQPSKC2_FCSTLEG_SHIFT + +/** Access parameters for sub-register ENPROP in register @ref RG_BBC0_OQPSKC2 +**/ +#define SR_BBC0_OQPSKC2_ENPROP RG_BBC0_OQPSKC2, OQPSKC2_ENPROP_MASK, \ + OQPSKC2_ENPROP_SHIFT +/** Access parameters for sub-register RPC in register @ref RG_BBC0_OQPSKC2 */ +#define SR_BBC0_OQPSKC2_RPC RG_BBC0_OQPSKC2, OQPSKC2_RPC_MASK, \ + OQPSKC2_RPC_SHIFT +/** Access parameters for sub-register SPC in register @ref RG_BBC0_OQPSKC2 */ +#define SR_BBC0_OQPSKC2_SPC RG_BBC0_OQPSKC2, OQPSKC2_SPC_MASK, \ + OQPSKC2_SPC_SHIFT + +/** Address for register BBC0_OQPSKC3 */ +#define RG_BBC0_OQPSKC3 (0x313) +/** Sub-registers of Register @ref RG_BBC0_OQPSKC3 */ +/** Access parameters for sub-register NSFD in register @ref RG_BBC0_OQPSKC3 */ +#define SR_BBC0_OQPSKC3_NSFD RG_BBC0_OQPSKC3, OQPSKC3_NSFD_MASK, \ + OQPSKC3_NSFD_SHIFT +/** Access parameters for sub-register HRLEG in register @ref RG_BBC0_OQPSKC3 */ +#define SR_BBC0_OQPSKC3_HRLEG RG_BBC0_OQPSKC3, OQPSKC3_HRLEG_MASK, \ + OQPSKC3_HRLEG_SHIFT + +/** Address for register BBC0_OQPSKPHRTX */ +#define RG_BBC0_OQPSKPHRTX (0x314) +/** Sub-registers of Register @ref RG_BBC0_OQPSKPHRTX */ + +/** Access parameters for sub-register LEG in register @ref RG_BBC0_OQPSKPHRTX +**/ +#define SR_BBC0_OQPSKPHRTX_LEG RG_BBC0_OQPSKPHRTX, OQPSKPHRTX_LEG_MASK, \ + OQPSKPHRTX_LEG_SHIFT + +/** Access parameters for sub-register MOD in register @ref RG_BBC0_OQPSKPHRTX +**/ +#define SR_BBC0_OQPSKPHRTX_MOD RG_BBC0_OQPSKPHRTX, OQPSKPHRTX_MOD_MASK, \ + OQPSKPHRTX_MOD_SHIFT + +/** Access parameters for sub-register RB0 in register @ref RG_BBC0_OQPSKPHRTX +**/ +#define SR_BBC0_OQPSKPHRTX_RB0 RG_BBC0_OQPSKPHRTX, OQPSKPHRTX_RB0_MASK, \ + OQPSKPHRTX_RB0_SHIFT + +/** Access parameters for sub-register PPDUT in register @ref RG_BBC0_OQPSKPHRTX +**/ +#define SR_BBC0_OQPSKPHRTX_PPDUT RG_BBC0_OQPSKPHRTX, \ + OQPSKPHRTX_PPDUT_MASK, OQPSKPHRTX_PPDUT_SHIFT + +/** Address for register BBC0_OQPSKPHRRX */ +#define RG_BBC0_OQPSKPHRRX (0x315) +/** Sub-registers of Register @ref RG_BBC0_OQPSKPHRRX */ + +/** Access parameters for sub-register LEG in register @ref RG_BBC0_OQPSKPHRRX +**/ +#define SR_BBC0_OQPSKPHRRX_LEG RG_BBC0_OQPSKPHRRX, OQPSKPHRRX_LEG_MASK, \ + OQPSKPHRRX_LEG_SHIFT + +/** Access parameters for sub-register MOD in register @ref RG_BBC0_OQPSKPHRRX +**/ +#define SR_BBC0_OQPSKPHRRX_MOD RG_BBC0_OQPSKPHRRX, OQPSKPHRRX_MOD_MASK, \ + OQPSKPHRRX_MOD_SHIFT + +/** Access parameters for sub-register RB0 in register @ref RG_BBC0_OQPSKPHRRX +**/ +#define SR_BBC0_OQPSKPHRRX_RB0 RG_BBC0_OQPSKPHRRX, OQPSKPHRRX_RB0_MASK, \ + OQPSKPHRRX_RB0_SHIFT + +/** Access parameters for sub-register PPDUT in register @ref RG_BBC0_OQPSKPHRRX +**/ +#define SR_BBC0_OQPSKPHRRX_PPDUT RG_BBC0_OQPSKPHRRX, \ + OQPSKPHRRX_PPDUT_MASK, OQPSKPHRRX_PPDUT_SHIFT + +/** Address for register BBC0_AFC0 */ +#define RG_BBC0_AFC0 (0x320) +/** Sub-registers of Register @ref RG_BBC0_AFC0 */ +/** Access parameters for sub-register AFEN0 in register @ref RG_BBC0_AFC0 */ +#define SR_BBC0_AFC0_AFEN0 RG_BBC0_AFC0, AFC0_AFEN0_MASK, \ + AFC0_AFEN0_SHIFT +/** Access parameters for sub-register AFEN1 in register @ref RG_BBC0_AFC0 */ +#define SR_BBC0_AFC0_AFEN1 RG_BBC0_AFC0, AFC0_AFEN1_MASK, \ + AFC0_AFEN1_SHIFT +/** Access parameters for sub-register AFEN2 in register @ref RG_BBC0_AFC0 */ +#define SR_BBC0_AFC0_AFEN2 RG_BBC0_AFC0, AFC0_AFEN2_MASK, \ + AFC0_AFEN2_SHIFT +/** Access parameters for sub-register AFEN3 in register @ref RG_BBC0_AFC0 */ +#define SR_BBC0_AFC0_AFEN3 RG_BBC0_AFC0, AFC0_AFEN3_MASK, \ + AFC0_AFEN3_SHIFT +/** Access parameters for sub-register PM in register @ref RG_BBC0_AFC0 */ +#define SR_BBC0_AFC0_PM RG_BBC0_AFC0, AFC0_PM_MASK, \ + AFC0_PM_SHIFT + +/** Address for register BBC0_AFC1 */ +#define RG_BBC0_AFC1 (0x321) +/** Sub-registers of Register @ref RG_BBC0_AFC1 */ +/** Access parameters for sub-register PANC0 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_PANC0 RG_BBC0_AFC1, AFC1_PANC0_MASK, \ + AFC1_PANC0_SHIFT +/** Access parameters for sub-register PANC1 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_PANC1 RG_BBC0_AFC1, AFC1_PANC1_MASK, \ + AFC1_PANC1_SHIFT +/** Access parameters for sub-register PANC2 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_PANC2 RG_BBC0_AFC1, AFC1_PANC2_MASK, \ + AFC1_PANC2_SHIFT +/** Access parameters for sub-register PANC3 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_PANC3 RG_BBC0_AFC1, AFC1_PANC3_MASK, \ + AFC1_PANC3_SHIFT +/** Access parameters for sub-register MRFT0 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_MRFT0 RG_BBC0_AFC1, AFC1_MRFT0_MASK, \ + AFC1_MRFT0_SHIFT +/** Access parameters for sub-register MRFT1 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_MRFT1 RG_BBC0_AFC1, AFC1_MRFT1_MASK, \ + AFC1_MRFT1_SHIFT +/** Access parameters for sub-register MRFT2 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_MRFT2 RG_BBC0_AFC1, AFC1_MRFT2_MASK, \ + AFC1_MRFT2_SHIFT +/** Access parameters for sub-register MRFT3 in register @ref RG_BBC0_AFC1 */ +#define SR_BBC0_AFC1_MRFT3 RG_BBC0_AFC1, AFC1_MRFT3_MASK, \ + AFC1_MRFT3_SHIFT + +/** Address for register BBC0_AFFTM */ +#define RG_BBC0_AFFTM (0x322) +/** Sub-registers of Register @ref RG_BBC0_AFFTM */ +/** Access parameters for sub-register AFFTM in register @ref RG_BBC0_AFFTM */ +#define SR_BBC0_AFFTM_AFFTM RG_BBC0_AFFTM, AFFTM_AFFTM_MASK, \ + AFFTM_AFFTM_SHIFT + +/** Address for register BBC0_AFFVM */ +#define RG_BBC0_AFFVM (0x323) +/** Sub-registers of Register @ref RG_BBC0_AFFVM */ +/** Access parameters for sub-register AFFVM in register @ref RG_BBC0_AFFVM */ +#define SR_BBC0_AFFVM_AFFVM RG_BBC0_AFFVM, AFFVM_AFFVM_MASK, \ + AFFVM_AFFVM_SHIFT + +/** Address for register BBC0_AFS */ +#define RG_BBC0_AFS (0x324) +/** Sub-registers of Register @ref RG_BBC0_AFS */ +/** Access parameters for sub-register AM0 in register @ref RG_BBC0_AFS */ +#define SR_BBC0_AFS_AM0 RG_BBC0_AFS, AFS_AM0_MASK, AFS_AM0_SHIFT +/** Access parameters for sub-register AM1 in register @ref RG_BBC0_AFS */ +#define SR_BBC0_AFS_AM1 RG_BBC0_AFS, AFS_AM1_MASK, AFS_AM1_SHIFT +/** Access parameters for sub-register AM2 in register @ref RG_BBC0_AFS */ +#define SR_BBC0_AFS_AM2 RG_BBC0_AFS, AFS_AM2_MASK, AFS_AM2_SHIFT +/** Access parameters for sub-register AM3 in register @ref RG_BBC0_AFS */ +#define SR_BBC0_AFS_AM3 RG_BBC0_AFS, AFS_AM3_MASK, AFS_AM3_SHIFT +/** Access parameters for sub-register EM in register @ref RG_BBC0_AFS */ +#define SR_BBC0_AFS_EM RG_BBC0_AFS, AFS_EM_MASK, AFS_EM_SHIFT + +/** Address for register BBC0_MACEA0 */ +#define RG_BBC0_MACEA0 (0x325) +/** Sub-registers of Register @ref RG_BBC0_MACEA0 */ +/** Access parameters for sub-register MACEA0 in register @ref RG_BBC0_MACEA0 */ +#define SR_BBC0_MACEA0_MACEA0 RG_BBC0_MACEA0, MACEA0_MACEA0_MASK, \ + MACEA0_MACEA0_SHIFT + +/** Address for register BBC0_MACEA1 */ +#define RG_BBC0_MACEA1 (0x326) +/** Sub-registers of Register @ref RG_BBC0_MACEA1 */ +/** Access parameters for sub-register MACEA1 in register @ref RG_BBC0_MACEA1 */ +#define SR_BBC0_MACEA1_MACEA1 RG_BBC0_MACEA1, MACEA1_MACEA1_MASK, \ + MACEA1_MACEA1_SHIFT + +/** Address for register BBC0_MACEA2 */ +#define RG_BBC0_MACEA2 (0x327) +/** Sub-registers of Register @ref RG_BBC0_MACEA2 */ +/** Access parameters for sub-register MACEA2 in register @ref RG_BBC0_MACEA2 */ +#define SR_BBC0_MACEA2_MACEA2 RG_BBC0_MACEA2, MACEA2_MACEA2_MASK, \ + MACEA2_MACEA2_SHIFT + +/** Address for register BBC0_MACEA3 */ +#define RG_BBC0_MACEA3 (0x328) +/** Sub-registers of Register @ref RG_BBC0_MACEA3 */ +/** Access parameters for sub-register MACEA3 in register @ref RG_BBC0_MACEA3 */ +#define SR_BBC0_MACEA3_MACEA3 RG_BBC0_MACEA3, MACEA3_MACEA3_MASK, \ + MACEA3_MACEA3_SHIFT + +/** Address for register BBC0_MACEA4 */ +#define RG_BBC0_MACEA4 (0x329) +/** Sub-registers of Register @ref RG_BBC0_MACEA4 */ +/** Access parameters for sub-register MACEA4 in register @ref RG_BBC0_MACEA4 */ +#define SR_BBC0_MACEA4_MACEA4 RG_BBC0_MACEA4, MACEA4_MACEA4_MASK, \ + MACEA4_MACEA4_SHIFT + +/** Address for register BBC0_MACEA5 */ +#define RG_BBC0_MACEA5 (0x32A) +/** Sub-registers of Register @ref RG_BBC0_MACEA5 */ +/** Access parameters for sub-register MACEA5 in register @ref RG_BBC0_MACEA5 */ +#define SR_BBC0_MACEA5_MACEA5 RG_BBC0_MACEA5, MACEA5_MACEA5_MASK, \ + MACEA5_MACEA5_SHIFT + +/** Address for register BBC0_MACEA6 */ +#define RG_BBC0_MACEA6 (0x32B) +/** Sub-registers of Register @ref RG_BBC0_MACEA6 */ +/** Access parameters for sub-register MACEA6 in register @ref RG_BBC0_MACEA6 */ +#define SR_BBC0_MACEA6_MACEA6 RG_BBC0_MACEA6, MACEA6_MACEA6_MASK, \ + MACEA6_MACEA6_SHIFT + +/** Address for register BBC0_MACEA7 */ +#define RG_BBC0_MACEA7 (0x32C) +/** Sub-registers of Register @ref RG_BBC0_MACEA7 */ +/** Access parameters for sub-register MACEA7 in register @ref RG_BBC0_MACEA7 */ +#define SR_BBC0_MACEA7_MACEA7 RG_BBC0_MACEA7, MACEA7_MACEA7_MASK, \ + MACEA7_MACEA7_SHIFT + +/** Address for register BBC0_MACPID0F0 */ +#define RG_BBC0_MACPID0F0 (0x32D) +/** Sub-registers of Register @ref RG_BBC0_MACPID0F0 */ + +/** Access parameters for sub-register MACPID0F0 in register @ref + * RG_BBC0_MACPID0F0 */ +#define SR_BBC0_MACPID0F0_MACPID0F0 RG_BBC0_MACPID0F0, \ + MACPID0F0_MACPID0F0_MASK, MACPID0F0_MACPID0F0_SHIFT + +/** Address for register BBC0_MACPID1F0 */ +#define RG_BBC0_MACPID1F0 (0x32E) +/** Sub-registers of Register @ref RG_BBC0_MACPID1F0 */ + +/** Access parameters for sub-register MACPID1F0 in register @ref + * RG_BBC0_MACPID1F0 */ +#define SR_BBC0_MACPID1F0_MACPID1F0 RG_BBC0_MACPID1F0, \ + MACPID1F0_MACPID1F0_MASK, MACPID1F0_MACPID1F0_SHIFT + +/** Address for register BBC0_MACSHA0F0 */ +#define RG_BBC0_MACSHA0F0 (0x32F) +/** Sub-registers of Register @ref RG_BBC0_MACSHA0F0 */ + +/** Access parameters for sub-register MACSHA0F0 in register @ref + * RG_BBC0_MACSHA0F0 */ +#define SR_BBC0_MACSHA0F0_MACSHA0F0 RG_BBC0_MACSHA0F0, \ + MACSHA0F0_MACSHA0F0_MASK, MACSHA0F0_MACSHA0F0_SHIFT + +/** Address for register BBC0_MACSHA1F0 */ +#define RG_BBC0_MACSHA1F0 (0x330) +/** Sub-registers of Register @ref RG_BBC0_MACSHA1F0 */ + +/** Access parameters for sub-register MACSHA1F0 in register @ref + * RG_BBC0_MACSHA1F0 */ +#define SR_BBC0_MACSHA1F0_MACSHA1F0 RG_BBC0_MACSHA1F0, \ + MACSHA1F0_MACSHA1F0_MASK, MACSHA1F0_MACSHA1F0_SHIFT + +/** Address for register BBC0_MACPID0F1 */ +#define RG_BBC0_MACPID0F1 (0x331) +/** Sub-registers of Register @ref RG_BBC0_MACPID0F1 */ + +/** Access parameters for sub-register MACPID0F1 in register @ref + * RG_BBC0_MACPID0F1 */ +#define SR_BBC0_MACPID0F1_MACPID0F1 RG_BBC0_MACPID0F1, \ + MACPID0F1_MACPID0F1_MASK, MACPID0F1_MACPID0F1_SHIFT + +/** Address for register BBC0_MACPID1F1 */ +#define RG_BBC0_MACPID1F1 (0x332) +/** Sub-registers of Register @ref RG_BBC0_MACPID1F1 */ + +/** Access parameters for sub-register MACPID1F1 in register @ref + * RG_BBC0_MACPID1F1 */ +#define SR_BBC0_MACPID1F1_MACPID1F1 RG_BBC0_MACPID1F1, \ + MACPID1F1_MACPID1F1_MASK, MACPID1F1_MACPID1F1_SHIFT + +/** Address for register BBC0_MACSHA0F1 */ +#define RG_BBC0_MACSHA0F1 (0x333) +/** Sub-registers of Register @ref RG_BBC0_MACSHA0F1 */ + +/** Access parameters for sub-register MACSHA0F1 in register @ref + * RG_BBC0_MACSHA0F1 */ +#define SR_BBC0_MACSHA0F1_MACSHA0F1 RG_BBC0_MACSHA0F1, \ + MACSHA0F1_MACSHA0F1_MASK, MACSHA0F1_MACSHA0F1_SHIFT + +/** Address for register BBC0_MACSHA1F1 */ +#define RG_BBC0_MACSHA1F1 (0x334) +/** Sub-registers of Register @ref RG_BBC0_MACSHA1F1 */ + +/** Access parameters for sub-register MACSHA1F1 in register @ref + * RG_BBC0_MACSHA1F1 */ +#define SR_BBC0_MACSHA1F1_MACSHA1F1 RG_BBC0_MACSHA1F1, \ + MACSHA1F1_MACSHA1F1_MASK, MACSHA1F1_MACSHA1F1_SHIFT + +/** Address for register BBC0_MACPID0F2 */ +#define RG_BBC0_MACPID0F2 (0x335) +/** Sub-registers of Register @ref RG_BBC0_MACPID0F2 */ + +/** Access parameters for sub-register MACPID0F2 in register @ref + * RG_BBC0_MACPID0F2 */ +#define SR_BBC0_MACPID0F2_MACPID0F2 RG_BBC0_MACPID0F2, \ + MACPID0F2_MACPID0F2_MASK, MACPID0F2_MACPID0F2_SHIFT + +/** Address for register BBC0_MACPID1F2 */ +#define RG_BBC0_MACPID1F2 (0x336) +/** Sub-registers of Register @ref RG_BBC0_MACPID1F2 */ + +/** Access parameters for sub-register MACPID1F2 in register @ref + * RG_BBC0_MACPID1F2 */ +#define SR_BBC0_MACPID1F2_MACPID1F2 RG_BBC0_MACPID1F2, \ + MACPID1F2_MACPID1F2_MASK, MACPID1F2_MACPID1F2_SHIFT + +/** Address for register BBC0_MACSHA0F2 */ +#define RG_BBC0_MACSHA0F2 (0x337) +/** Sub-registers of Register @ref RG_BBC0_MACSHA0F2 */ + +/** Access parameters for sub-register MACSHA0F2 in register @ref + * RG_BBC0_MACSHA0F2 */ +#define SR_BBC0_MACSHA0F2_MACSHA0F2 RG_BBC0_MACSHA0F2, \ + MACSHA0F2_MACSHA0F2_MASK, MACSHA0F2_MACSHA0F2_SHIFT + +/** Address for register BBC0_MACSHA1F2 */ +#define RG_BBC0_MACSHA1F2 (0x338) +/** Sub-registers of Register @ref RG_BBC0_MACSHA1F2 */ + +/** Access parameters for sub-register MACSHA1F2 in register @ref + * RG_BBC0_MACSHA1F2 */ +#define SR_BBC0_MACSHA1F2_MACSHA1F2 RG_BBC0_MACSHA1F2, \ + MACSHA1F2_MACSHA1F2_MASK, MACSHA1F2_MACSHA1F2_SHIFT + +/** Address for register BBC0_MACPID0F3 */ +#define RG_BBC0_MACPID0F3 (0x339) +/** Sub-registers of Register @ref RG_BBC0_MACPID0F3 */ + +/** Access parameters for sub-register MACPID0F3 in register @ref + * RG_BBC0_MACPID0F3 */ +#define SR_BBC0_MACPID0F3_MACPID0F3 RG_BBC0_MACPID0F3, \ + MACPID0F3_MACPID0F3_MASK, MACPID0F3_MACPID0F3_SHIFT + +/** Address for register BBC0_MACPID1F3 */ +#define RG_BBC0_MACPID1F3 (0x33A) +/** Sub-registers of Register @ref RG_BBC0_MACPID1F3 */ + +/** Access parameters for sub-register MACPID1F3 in register @ref + * RG_BBC0_MACPID1F3 */ +#define SR_BBC0_MACPID1F3_MACPID1F3 RG_BBC0_MACPID1F3, \ + MACPID1F3_MACPID1F3_MASK, MACPID1F3_MACPID1F3_SHIFT + +/** Address for register BBC0_MACSHA0F3 */ +#define RG_BBC0_MACSHA0F3 (0x33B) +/** Sub-registers of Register @ref RG_BBC0_MACSHA0F3 */ + +/** Access parameters for sub-register MACSHA0F3 in register @ref + * RG_BBC0_MACSHA0F3 */ +#define SR_BBC0_MACSHA0F3_MACSHA0F3 RG_BBC0_MACSHA0F3, \ + MACSHA0F3_MACSHA0F3_MASK, MACSHA0F3_MACSHA0F3_SHIFT + +/** Address for register BBC0_MACSHA1F3 */ +#define RG_BBC0_MACSHA1F3 (0x33C) +/** Sub-registers of Register @ref RG_BBC0_MACSHA1F3 */ + +/** Access parameters for sub-register MACSHA1F3 in register @ref + * RG_BBC0_MACSHA1F3 */ +#define SR_BBC0_MACSHA1F3_MACSHA1F3 RG_BBC0_MACSHA1F3, \ + MACSHA1F3_MACSHA1F3_MASK, MACSHA1F3_MACSHA1F3_SHIFT + +/** Address for register BBC0_AMCS */ +#define RG_BBC0_AMCS (0x340) +/** Sub-registers of Register @ref RG_BBC0_AMCS */ +/** Access parameters for sub-register TX2RX in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_TX2RX RG_BBC0_AMCS, AMCS_TX2RX_MASK, \ + AMCS_TX2RX_SHIFT +/** Access parameters for sub-register CCATX in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_CCATX RG_BBC0_AMCS, AMCS_CCATX_MASK, \ + AMCS_CCATX_SHIFT +/** Access parameters for sub-register CCAED in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_CCAED RG_BBC0_AMCS, AMCS_CCAED_MASK, \ + AMCS_CCAED_SHIFT +/** Constant CH_BUSY for sub-register @ref SR_CCAED in register BBC0_AMCS */ +#define BB_CH_BUSY (0x1) +/** Constant CH_CLEAR for sub-register @ref SR_CCAED in register BBC0_AMCS */ +#define BB_CH_CLEAR (0x0) +/** Access parameters for sub-register AACK in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_AACK RG_BBC0_AMCS, AMCS_AACK_MASK, \ + AMCS_AACK_SHIFT +/** Access parameters for sub-register AACKS in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_AACKS RG_BBC0_AMCS, AMCS_AACKS_MASK, \ + AMCS_AACKS_SHIFT +/** Access parameters for sub-register AACKDR in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_AACKDR RG_BBC0_AMCS, AMCS_AACKDR_MASK, \ + AMCS_AACKDR_SHIFT +/** Access parameters for sub-register AACKFA in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_AACKFA RG_BBC0_AMCS, AMCS_AACKFA_MASK, \ + AMCS_AACKFA_SHIFT +/** Access parameters for sub-register AACKFT in register @ref RG_BBC0_AMCS */ +#define SR_BBC0_AMCS_AACKFT RG_BBC0_AMCS, AMCS_AACKFT_MASK, \ + AMCS_AACKFT_SHIFT + +/** Address for register BBC0_AMEDT */ +#define RG_BBC0_AMEDT (0x341) +/** Sub-registers of Register @ref RG_BBC0_AMEDT */ +/** Access parameters for sub-register AMEDT in register @ref RG_BBC0_AMEDT */ +#define SR_BBC0_AMEDT_AMEDT RG_BBC0_AMEDT, AMEDT_AMEDT_MASK, \ + AMEDT_AMEDT_SHIFT + +/** Address for register BBC0_AMAACKPD */ +#define RG_BBC0_AMAACKPD (0x342) +/** Sub-registers of Register @ref RG_BBC0_AMAACKPD */ +/** Access parameters for sub-register PD0 in register @ref RG_BBC0_AMAACKPD */ +#define SR_BBC0_AMAACKPD_PD0 RG_BBC0_AMAACKPD, AMAACKPD_PD0_MASK, \ + AMAACKPD_PD0_SHIFT +/** Access parameters for sub-register PD1 in register @ref RG_BBC0_AMAACKPD */ +#define SR_BBC0_AMAACKPD_PD1 RG_BBC0_AMAACKPD, AMAACKPD_PD1_MASK, \ + AMAACKPD_PD1_SHIFT +/** Access parameters for sub-register PD2 in register @ref RG_BBC0_AMAACKPD */ +#define SR_BBC0_AMAACKPD_PD2 RG_BBC0_AMAACKPD, AMAACKPD_PD2_MASK, \ + AMAACKPD_PD2_SHIFT +/** Access parameters for sub-register PD3 in register @ref RG_BBC0_AMAACKPD */ +#define SR_BBC0_AMAACKPD_PD3 RG_BBC0_AMAACKPD, AMAACKPD_PD3_MASK, \ + AMAACKPD_PD3_SHIFT + +/** Address for register BBC0_AMAACKTL */ +#define RG_BBC0_AMAACKTL (0x343) +/** Sub-registers of Register @ref RG_BBC0_AMAACKTL */ + +/** Access parameters for sub-register AMAACKTL in register @ref + * RG_BBC0_AMAACKTL */ +#define SR_BBC0_AMAACKTL_AMAACKTL RG_BBC0_AMAACKTL, \ + AMAACKTL_AMAACKTL_MASK, AMAACKTL_AMAACKTL_SHIFT + +/** Address for register BBC0_AMAACKTH */ +#define RG_BBC0_AMAACKTH (0x344) +/** Sub-registers of Register @ref RG_BBC0_AMAACKTH */ + +/** Access parameters for sub-register AMAACKTH in register @ref + * RG_BBC0_AMAACKTH */ +#define SR_BBC0_AMAACKTH_AMAACKTH RG_BBC0_AMAACKTH, \ + AMAACKTH_AMAACKTH_MASK, AMAACKTH_AMAACKTH_SHIFT + +/** Address for register BBC0_FSKC0 */ +#define RG_BBC0_FSKC0 (0x360) +/** Sub-registers of Register @ref RG_BBC0_FSKC0 */ +/** Access parameters for sub-register MORD in register @ref RG_BBC0_FSKC0 */ +#define SR_BBC0_FSKC0_MORD RG_BBC0_FSKC0, FSKC0_MORD_MASK, \ + FSKC0_MORD_SHIFT +/** Access parameters for sub-register MIDX in register @ref RG_BBC0_FSKC0 */ +#define SR_BBC0_FSKC0_MIDX RG_BBC0_FSKC0, FSKC0_MIDX_MASK, \ + FSKC0_MIDX_SHIFT +/** Access parameters for sub-register MIDXS in register @ref RG_BBC0_FSKC0 */ +#define SR_BBC0_FSKC0_MIDXS RG_BBC0_FSKC0, FSKC0_MIDXS_MASK, \ + FSKC0_MIDXS_SHIFT +/** Access parameters for sub-register BT in register @ref RG_BBC0_FSKC0 */ +#define SR_BBC0_FSKC0_BT RG_BBC0_FSKC0, FSKC0_BT_MASK, \ + FSKC0_BT_SHIFT + +/** Address for register BBC0_FSKC1 */ +#define RG_BBC0_FSKC1 (0x361) +/** Sub-registers of Register @ref RG_BBC0_FSKC1 */ +/** Access parameters for sub-register SRATE in register @ref RG_BBC0_FSKC1 */ +#define SR_BBC0_FSKC1_SRATE RG_BBC0_FSKC1, FSKC1_SRATE_MASK, \ + FSKC1_SRATE_SHIFT +/** Access parameters for sub-register FI in register @ref RG_BBC0_FSKC1 */ +#define SR_BBC0_FSKC1_FI RG_BBC0_FSKC1, FSKC1_FI_MASK, \ + FSKC1_FI_SHIFT +/** Access parameters for sub-register FSKPLH in register @ref RG_BBC0_FSKC1 */ +#define SR_BBC0_FSKC1_FSKPLH RG_BBC0_FSKC1, FSKC1_FSKPLH_MASK, \ + FSKC1_FSKPLH_SHIFT + +/** Address for register BBC0_FSKC2 */ +#define RG_BBC0_FSKC2 (0x362) +/** Sub-registers of Register @ref RG_BBC0_FSKC2 */ +/** Access parameters for sub-register FECIE in register @ref RG_BBC0_FSKC2 */ +#define SR_BBC0_FSKC2_FECIE RG_BBC0_FSKC2, FSKC2_FECIE_MASK, \ + FSKC2_FECIE_SHIFT +/** Access parameters for sub-register FECS in register @ref RG_BBC0_FSKC2 */ +#define SR_BBC0_FSKC2_FECS RG_BBC0_FSKC2, FSKC2_FECS_MASK, \ + FSKC2_FECS_SHIFT +/** Access parameters for sub-register PRI in register @ref RG_BBC0_FSKC2 */ +#define SR_BBC0_FSKC2_PRI RG_BBC0_FSKC2, FSKC2_PRI_MASK, \ + FSKC2_PRI_SHIFT +/** Access parameters for sub-register MSE in register @ref RG_BBC0_FSKC2 */ +#define SR_BBC0_FSKC2_MSE RG_BBC0_FSKC2, FSKC2_MSE_MASK, \ + FSKC2_MSE_SHIFT +/** Access parameters for sub-register RXPTO in register @ref RG_BBC0_FSKC2 */ +#define SR_BBC0_FSKC2_RXPTO RG_BBC0_FSKC2, FSKC2_RXPTO_MASK, \ + FSKC2_RXPTO_SHIFT +/** Access parameters for sub-register RXO in register @ref RG_BBC0_FSKC2 */ +#define SR_BBC0_FSKC2_RXO RG_BBC0_FSKC2, FSKC2_RXO_MASK, \ + FSKC2_RXO_SHIFT +/** Access parameters for sub-register PDTM in register @ref RG_BBC0_FSKC2 */ +#define SR_BBC0_FSKC2_PDTM RG_BBC0_FSKC2, FSKC2_PDTM_MASK, \ + FSKC2_PDTM_SHIFT + +/** Address for register BBC0_FSKC3 */ +#define RG_BBC0_FSKC3 (0x363) +/** Sub-registers of Register @ref RG_BBC0_FSKC3 */ +/** Access parameters for sub-register PDT in register @ref RG_BBC0_FSKC3 */ +#define SR_BBC0_FSKC3_PDT RG_BBC0_FSKC3, FSKC3_PDT_MASK, \ + FSKC3_PDT_SHIFT +/** Access parameters for sub-register SFDT in register @ref RG_BBC0_FSKC3 */ +#define SR_BBC0_FSKC3_SFDT RG_BBC0_FSKC3, FSKC3_SFDT_MASK, \ + FSKC3_SFDT_SHIFT + +/** Address for register BBC0_FSKC4 */ +#define RG_BBC0_FSKC4 (0x364) +/** Sub-registers of Register @ref RG_BBC0_FSKC4 */ +/** Access parameters for sub-register CSFD0 in register @ref RG_BBC0_FSKC4 */ +#define SR_BBC0_FSKC4_CSFD0 RG_BBC0_FSKC4, FSKC4_CSFD0_MASK, \ + FSKC4_CSFD0_SHIFT +/** Access parameters for sub-register CSFD1 in register @ref RG_BBC0_FSKC4 */ +#define SR_BBC0_FSKC4_CSFD1 RG_BBC0_FSKC4, FSKC4_CSFD1_MASK, \ + FSKC4_CSFD1_SHIFT +/** Access parameters for sub-register RAWRBIT in register @ref RG_BBC0_FSKC4 */ +#define SR_BBC0_FSKC4_RAWRBIT RG_BBC0_FSKC4, FSKC4_RAWRBIT_MASK, \ + FSKC4_RAWRBIT_SHIFT +/** Access parameters for sub-register SFD32 in register @ref RG_BBC0_FSKC4 */ +#define SR_BBC0_FSKC4_SFD32 RG_BBC0_FSKC4, FSKC4_SFD32_MASK, \ + FSKC4_SFD32_SHIFT +/** Access parameters for sub-register SFDQ in register @ref RG_BBC0_FSKC4 */ +#define SR_BBC0_FSKC4_SFDQ RG_BBC0_FSKC4, FSKC4_SFDQ_MASK, \ + FSKC4_SFDQ_SHIFT + +/** Address for register BBC0_FSKPLL */ +#define RG_BBC0_FSKPLL (0x365) +/** Sub-registers of Register @ref RG_BBC0_FSKPLL */ +/** Access parameters for sub-register FSKPLL in register @ref RG_BBC0_FSKPLL */ +#define SR_BBC0_FSKPLL_FSKPLL RG_BBC0_FSKPLL, FSKPLL_FSKPLL_MASK, \ + FSKPLL_FSKPLL_SHIFT + +/** Address for register BBC0_FSKSFD0L */ +#define RG_BBC0_FSKSFD0L (0x366) +/** Sub-registers of Register @ref RG_BBC0_FSKSFD0L */ + +/** Access parameters for sub-register FSKSFD0L in register @ref + * RG_BBC0_FSKSFD0L */ +#define SR_BBC0_FSKSFD0L_FSKSFD0L RG_BBC0_FSKSFD0L, \ + FSKSFD0L_FSKSFD0L_MASK, FSKSFD0L_FSKSFD0L_SHIFT + +/** Address for register BBC0_FSKSFD0H */ +#define RG_BBC0_FSKSFD0H (0x367) +/** Sub-registers of Register @ref RG_BBC0_FSKSFD0H */ + +/** Access parameters for sub-register FSKSFD0H in register @ref + * RG_BBC0_FSKSFD0H */ +#define SR_BBC0_FSKSFD0H_FSKSFD0H RG_BBC0_FSKSFD0H, \ + FSKSFD0H_FSKSFD0H_MASK, FSKSFD0H_FSKSFD0H_SHIFT + +/** Address for register BBC0_FSKSFD1L */ +#define RG_BBC0_FSKSFD1L (0x368) +/** Sub-registers of Register @ref RG_BBC0_FSKSFD1L */ + +/** Access parameters for sub-register FSKSFD1L in register @ref + * RG_BBC0_FSKSFD1L */ +#define SR_BBC0_FSKSFD1L_FSKSFD1L RG_BBC0_FSKSFD1L, \ + FSKSFD1L_FSKSFD1L_MASK, FSKSFD1L_FSKSFD1L_SHIFT + +/** Address for register BBC0_FSKSFD1H */ +#define RG_BBC0_FSKSFD1H (0x369) +/** Sub-registers of Register @ref RG_BBC0_FSKSFD1H */ + +/** Access parameters for sub-register FSKSFD1H in register @ref + * RG_BBC0_FSKSFD1H */ +#define SR_BBC0_FSKSFD1H_FSKSFD1H RG_BBC0_FSKSFD1H, \ + FSKSFD1H_FSKSFD1H_MASK, FSKSFD1H_FSKSFD1H_SHIFT + +/** Address for register BBC0_FSKPHRTX */ +#define RG_BBC0_FSKPHRTX (0x36A) +/** Sub-registers of Register @ref RG_BBC0_FSKPHRTX */ +/** Access parameters for sub-register RB1 in register @ref RG_BBC0_FSKPHRTX */ +#define SR_BBC0_FSKPHRTX_RB1 RG_BBC0_FSKPHRTX, FSKPHRTX_RB1_MASK, \ + FSKPHRTX_RB1_SHIFT +/** Access parameters for sub-register RB2 in register @ref RG_BBC0_FSKPHRTX */ +#define SR_BBC0_FSKPHRTX_RB2 RG_BBC0_FSKPHRTX, FSKPHRTX_RB2_MASK, \ + FSKPHRTX_RB2_SHIFT +/** Access parameters for sub-register DW in register @ref RG_BBC0_FSKPHRTX */ +#define SR_BBC0_FSKPHRTX_DW RG_BBC0_FSKPHRTX, FSKPHRTX_DW_MASK, \ + FSKPHRTX_DW_SHIFT +/** Access parameters for sub-register SFD in register @ref RG_BBC0_FSKPHRTX */ +#define SR_BBC0_FSKPHRTX_SFD RG_BBC0_FSKPHRTX, FSKPHRTX_SFD_MASK, \ + FSKPHRTX_SFD_SHIFT + +/** Address for register BBC0_FSKPHRRX */ +#define RG_BBC0_FSKPHRRX (0x36B) +/** Sub-registers of Register @ref RG_BBC0_FSKPHRRX */ +/** Access parameters for sub-register RB1 in register @ref RG_BBC0_FSKPHRRX */ +#define SR_BBC0_FSKPHRRX_RB1 RG_BBC0_FSKPHRRX, FSKPHRRX_RB1_MASK, \ + FSKPHRRX_RB1_SHIFT +/** Access parameters for sub-register RB2 in register @ref RG_BBC0_FSKPHRRX */ +#define SR_BBC0_FSKPHRRX_RB2 RG_BBC0_FSKPHRRX, FSKPHRRX_RB2_MASK, \ + FSKPHRRX_RB2_SHIFT +/** Access parameters for sub-register DW in register @ref RG_BBC0_FSKPHRRX */ +#define SR_BBC0_FSKPHRRX_DW RG_BBC0_FSKPHRRX, FSKPHRRX_DW_MASK, \ + FSKPHRRX_DW_SHIFT +/** Access parameters for sub-register SFD in register @ref RG_BBC0_FSKPHRRX */ +#define SR_BBC0_FSKPHRRX_SFD RG_BBC0_FSKPHRRX, FSKPHRRX_SFD_MASK, \ + FSKPHRRX_SFD_SHIFT +/** Access parameters for sub-register MS in register @ref RG_BBC0_FSKPHRRX */ +#define SR_BBC0_FSKPHRRX_MS RG_BBC0_FSKPHRRX, FSKPHRRX_MS_MASK, \ + FSKPHRRX_MS_SHIFT +/** Access parameters for sub-register FCST in register @ref RG_BBC0_FSKPHRRX */ +#define SR_BBC0_FSKPHRRX_FCST RG_BBC0_FSKPHRRX, FSKPHRRX_FCST_MASK, \ + FSKPHRRX_FCST_SHIFT + +/** Address for register BBC0_FSKRPC */ +#define RG_BBC0_FSKRPC (0x36C) +/** Sub-registers of Register @ref RG_BBC0_FSKRPC */ +/** Access parameters for sub-register BASET in register @ref RG_BBC0_FSKRPC */ +#define SR_BBC0_FSKRPC_BASET RG_BBC0_FSKRPC, FSKRPC_BASET_MASK, \ + FSKRPC_BASET_SHIFT +/** Access parameters for sub-register EN in register @ref RG_BBC0_FSKRPC */ +#define SR_BBC0_FSKRPC_EN RG_BBC0_FSKRPC, FSKRPC_EN_MASK, \ + FSKRPC_EN_SHIFT + +/** Address for register BBC0_FSKRPCONT */ +#define RG_BBC0_FSKRPCONT (0x36D) +/** Sub-registers of Register @ref RG_BBC0_FSKRPCONT */ + +/** Access parameters for sub-register FSKRPCONT in register @ref + * RG_BBC0_FSKRPCONT */ +#define SR_BBC0_FSKRPCONT_FSKRPCONT RG_BBC0_FSKRPCONT, \ + FSKRPCONT_FSKRPCONT_MASK, FSKRPCONT_FSKRPCONT_SHIFT + +/** Address for register BBC0_FSKRPCOFFT */ +#define RG_BBC0_FSKRPCOFFT (0x36E) +/** Sub-registers of Register @ref RG_BBC0_FSKRPCOFFT */ + +/** Access parameters for sub-register FSKRPCOFFT in register @ref + * RG_BBC0_FSKRPCOFFT */ +#define SR_BBC0_FSKRPCOFFT_FSKRPCOFFT RG_BBC0_FSKRPCOFFT, \ + FSKRPCOFFT_FSKRPCOFFT_MASK, FSKRPCOFFT_FSKRPCOFFT_SHIFT + +/** Address for register BBC0_FSKRRXFLL */ +#define RG_BBC0_FSKRRXFLL (0x370) +/** Sub-registers of Register @ref RG_BBC0_FSKRRXFLL */ + +/** Access parameters for sub-register FSKRRXFLL in register @ref + * RG_BBC0_FSKRRXFLL */ +#define SR_BBC0_FSKRRXFLL_FSKRRXFLL RG_BBC0_FSKRRXFLL, \ + FSKRRXFLL_FSKRRXFLL_MASK, FSKRRXFLL_FSKRRXFLL_SHIFT + +/** Address for register BBC0_FSKRRXFLH */ +#define RG_BBC0_FSKRRXFLH (0x371) +/** Sub-registers of Register @ref RG_BBC0_FSKRRXFLH */ +/** Access parameters for sub-register FSKRRXFLH in register @ref + *RG_BBC0_FSKRRXFLH */ +#define SR_BBC0_FSKRRXFLH_FSKRRXFLH RG_BBC0_FSKRRXFLH, \ + FSKRRXFLH_FSKRRXFLH_MASK, FSKRRXFLH_FSKRRXFLH_SHIFT + +/** Address for register BBC0_FSKDM */ +#define RG_BBC0_FSKDM (0x372) +/** Sub-registers of Register @ref RG_BBC0_FSKDM */ +/** Access parameters for sub-register EN in register @ref RG_BBC0_FSKDM */ +#define SR_BBC0_FSKDM_EN RG_BBC0_FSKDM, FSKDM_EN_MASK, \ + FSKDM_EN_SHIFT +/** Access parameters for sub-register PE in register @ref RG_BBC0_FSKDM */ +#define SR_BBC0_FSKDM_PE RG_BBC0_FSKDM, FSKDM_PE_MASK, \ + FSKDM_PE_SHIFT + +/** Address for register BBC0_FSKPE0 */ +#define RG_BBC0_FSKPE0 (0x373) +/** Sub-registers of Register @ref RG_BBC0_FSKPE0 */ +/** Access parameters for sub-register FSKPE0 in register @ref RG_BBC0_FSKPE0 */ +#define SR_BBC0_FSKPE0_FSKPE0 RG_BBC0_FSKPE0, FSKPE0_FSKPE0_MASK, \ + FSKPE0_FSKPE0_SHIFT + +/** Address for register BBC0_FSKPE1 */ +#define RG_BBC0_FSKPE1 (0x374) +/** Sub-registers of Register @ref RG_BBC0_FSKPE1 */ +/** Access parameters for sub-register FSKPE1 in register @ref RG_BBC0_FSKPE1 */ +#define SR_BBC0_FSKPE1_FSKPE1 RG_BBC0_FSKPE1, FSKPE1_FSKPE1_MASK, \ + FSKPE1_FSKPE1_SHIFT + +/** Address for register BBC0_FSKPE2 */ +#define RG_BBC0_FSKPE2 (0x375) +/** Sub-registers of Register @ref RG_BBC0_FSKPE2 */ +/** Access parameters for sub-register FSKPE2 in register @ref RG_BBC0_FSKPE2 */ +#define SR_BBC0_FSKPE2_FSKPE2 RG_BBC0_FSKPE2, FSKPE2_FSKPE2_MASK, \ + FSKPE2_FSKPE2_SHIFT + +/** Address for register BBC1_FBRXE */ +#define RG_BBC1_FBRXE (0x37FE) +/** Sub-registers of Register @ref RG_BBC1_FBRXE */ +/** Access parameters for sub-register FBRXE in register @ref RG_BBC1_FBRXE */ +#define SR_BBC1_FBRXE_FBRXE RG_BBC1_FBRXE, FBRXE_FBRXE_MASK, \ + FBRXE_FBRXE_SHIFT + +/** Address for register BBC0_PMUC */ +#define RG_BBC0_PMUC (0x380) +/** Sub-registers of Register @ref RG_BBC0_PMUC */ +/** Access parameters for sub-register EN in register @ref RG_BBC0_PMUC */ +#define SR_BBC0_PMUC_EN RG_BBC0_PMUC, PMUC_EN_MASK, \ + PMUC_EN_SHIFT +/** Access parameters for sub-register AVG in register @ref RG_BBC0_PMUC */ +#define SR_BBC0_PMUC_AVG RG_BBC0_PMUC, PMUC_AVG_MASK, \ + PMUC_AVG_SHIFT +/** Access parameters for sub-register SYNC in register @ref RG_BBC0_PMUC */ +#define SR_BBC0_PMUC_SYNC RG_BBC0_PMUC, PMUC_SYNC_MASK, \ + PMUC_SYNC_SHIFT +/** Access parameters for sub-register FED in register @ref RG_BBC0_PMUC */ +#define SR_BBC0_PMUC_FED RG_BBC0_PMUC, PMUC_FED_MASK, \ + PMUC_FED_SHIFT +/** Access parameters for sub-register IQSEL in register @ref RG_BBC0_PMUC */ +#define SR_BBC0_PMUC_IQSEL RG_BBC0_PMUC, PMUC_IQSEL_MASK, \ + PMUC_IQSEL_SHIFT +/** Access parameters for sub-register CCFTS in register @ref RG_BBC0_PMUC */ +#define SR_BBC0_PMUC_CCFTS RG_BBC0_PMUC, PMUC_CCFTS_MASK, \ + PMUC_CCFTS_SHIFT + +/** Address for register BBC1_FBTXS */ +#define RG_BBC1_FBTXS (0x3800) +/** Sub-registers of Register @ref RG_BBC1_FBTXS */ +/** Access parameters for sub-register FBTXS in register @ref RG_BBC1_FBTXS */ +#define SR_BBC1_FBTXS_FBTXS RG_BBC1_FBTXS, FBTXS_FBTXS_MASK, \ + FBTXS_FBTXS_SHIFT + +/** Address for register BBC0_PMUVAL */ +#define RG_BBC0_PMUVAL (0x381) +/** Sub-registers of Register @ref RG_BBC0_PMUVAL */ +/** Access parameters for sub-register PMUVAL in register @ref RG_BBC0_PMUVAL */ +#define SR_BBC0_PMUVAL_PMUVAL RG_BBC0_PMUVAL, PMUVAL_PMUVAL_MASK, \ + PMUVAL_PMUVAL_SHIFT + +/** Address for register BBC0_PMUQF */ +#define RG_BBC0_PMUQF (0x382) +/** Sub-registers of Register @ref RG_BBC0_PMUQF */ +/** Access parameters for sub-register PMUQF in register @ref RG_BBC0_PMUQF */ +#define SR_BBC0_PMUQF_PMUQF RG_BBC0_PMUQF, PMUQF_PMUQF_MASK, \ + PMUQF_PMUQF_SHIFT + +/** Address for register BBC0_PMUI */ +#define RG_BBC0_PMUI (0x383) +/** Sub-registers of Register @ref RG_BBC0_PMUI */ +/** Access parameters for sub-register PMUI in register @ref RG_BBC0_PMUI */ +#define SR_BBC0_PMUI_PMUI RG_BBC0_PMUI, PMUI_PMUI_MASK, \ + PMUI_PMUI_SHIFT + +/** Address for register BBC0_PMUQ */ +#define RG_BBC0_PMUQ (0x384) +/** Sub-registers of Register @ref RG_BBC0_PMUQ */ +/** Access parameters for sub-register PMUQ in register @ref RG_BBC0_PMUQ */ +#define SR_BBC0_PMUQ_PMUQ RG_BBC0_PMUQ, PMUQ_PMUQ_MASK, \ + PMUQ_PMUQ_SHIFT + +/** Address for register BBC0_CNTC */ +#define RG_BBC0_CNTC (0x390) +/** Sub-registers of Register @ref RG_BBC0_CNTC */ +/** Access parameters for sub-register EN in register @ref RG_BBC0_CNTC */ +#define SR_BBC0_CNTC_EN RG_BBC0_CNTC, CNTC_EN_MASK, \ + CNTC_EN_SHIFT +/** Access parameters for sub-register RSTRXS in register @ref RG_BBC0_CNTC */ +#define SR_BBC0_CNTC_RSTRXS RG_BBC0_CNTC, CNTC_RSTRXS_MASK, \ + CNTC_RSTRXS_SHIFT +/** Access parameters for sub-register RSTTXS in register @ref RG_BBC0_CNTC */ +#define SR_BBC0_CNTC_RSTTXS RG_BBC0_CNTC, CNTC_RSTTXS_MASK, \ + CNTC_RSTTXS_SHIFT +/** Access parameters for sub-register CAPRXS in register @ref RG_BBC0_CNTC */ +#define SR_BBC0_CNTC_CAPRXS RG_BBC0_CNTC, CNTC_CAPRXS_MASK, \ + CNTC_CAPRXS_SHIFT +/** Access parameters for sub-register CAPTXS in register @ref RG_BBC0_CNTC */ +#define SR_BBC0_CNTC_CAPTXS RG_BBC0_CNTC, CNTC_CAPTXS_MASK, \ + CNTC_CAPTXS_SHIFT + +/** Address for register BBC0_CNT0 */ +#define RG_BBC0_CNT0 (0x391) +/** Sub-registers of Register @ref RG_BBC0_CNT0 */ +/** Access parameters for sub-register CNT0 in register @ref RG_BBC0_CNT0 */ +#define SR_BBC0_CNT0_CNT0 RG_BBC0_CNT0, CNT0_CNT0_MASK, \ + CNT0_CNT0_SHIFT + +/** Address for register BBC0_CNT1 */ +#define RG_BBC0_CNT1 (0x392) +/** Sub-registers of Register @ref RG_BBC0_CNT1 */ +/** Access parameters for sub-register CNT1 in register @ref RG_BBC0_CNT1 */ +#define SR_BBC0_CNT1_CNT1 RG_BBC0_CNT1, CNT1_CNT1_MASK, \ + CNT1_CNT1_SHIFT + +/** Address for register BBC0_CNT2 */ +#define RG_BBC0_CNT2 (0x393) +/** Sub-registers of Register @ref RG_BBC0_CNT2 */ +/** Access parameters for sub-register CNT2 in register @ref RG_BBC0_CNT2 */ +#define SR_BBC0_CNT2_CNT2 RG_BBC0_CNT2, CNT2_CNT2_MASK, \ + CNT2_CNT2_SHIFT + +/** Address for register BBC0_CNT3 */ +#define RG_BBC0_CNT3 (0x394) +/** Sub-registers of Register @ref RG_BBC0_CNT3 */ +/** Access parameters for sub-register CNT3 in register @ref RG_BBC0_CNT3 */ +#define SR_BBC0_CNT3_CNT3 RG_BBC0_CNT3, CNT3_CNT3_MASK, \ + CNT3_CNT3_SHIFT + +/** Address for register BBC1_FBTXE */ +#define RG_BBC1_FBTXE (0x3FFE) +/** Sub-registers of Register @ref RG_BBC1_FBTXE */ +/** Access parameters for sub-register FBTXE in register @ref RG_BBC1_FBTXE */ +#define SR_BBC1_FBTXE_FBTXE RG_BBC1_FBTXE, FBTXE_FBTXE_MASK, \ + FBTXE_FBTXE_SHIFT + +/** Address for register BBC1_IRQM */ +#define RG_BBC1_IRQM (0x400) +/** Sub-registers of Register @ref RG_BBC1_IRQM */ +/** Access parameters for sub-register RXFS in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_RXFS RG_BBC1_IRQM, IRQM_RXFS_MASK, \ + IRQM_RXFS_SHIFT +/** Access parameters for sub-register RXFE in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_RXFE RG_BBC1_IRQM, IRQM_RXFE_MASK, \ + IRQM_RXFE_SHIFT +/** Access parameters for sub-register RXAM in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_RXAM RG_BBC1_IRQM, IRQM_RXAM_MASK, \ + IRQM_RXAM_SHIFT +/** Access parameters for sub-register RXEM in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_RXEM RG_BBC1_IRQM, IRQM_RXEM_MASK, \ + IRQM_RXEM_SHIFT +/** Access parameters for sub-register TXFE in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_TXFE RG_BBC1_IRQM, IRQM_TXFE_MASK, \ + IRQM_TXFE_SHIFT +/** Access parameters for sub-register AGCH in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_AGCH RG_BBC1_IRQM, IRQM_AGCH_MASK, \ + IRQM_AGCH_SHIFT +/** Access parameters for sub-register AGCR in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_AGCR RG_BBC1_IRQM, IRQM_AGCR_MASK, \ + IRQM_AGCR_SHIFT +/** Access parameters for sub-register FBLI in register @ref RG_BBC1_IRQM */ +#define SR_BBC1_IRQM_FBLI RG_BBC1_IRQM, IRQM_FBLI_MASK, \ + IRQM_FBLI_SHIFT + +/** Address for register BBC1_PC */ +#define RG_BBC1_PC (0x401) +/** Sub-registers of Register @ref RG_BBC1_PC */ +/** Access parameters for sub-register PT in register @ref RG_BBC1_PC */ +#define SR_BBC1_PC_PT RG_BBC1_PC, PC_PT_MASK, PC_PT_SHIFT +/** Access parameters for sub-register BBEN in register @ref RG_BBC1_PC */ +#define SR_BBC1_PC_BBEN RG_BBC1_PC, PC_BBEN_MASK, PC_BBEN_SHIFT +/** Access parameters for sub-register FCST in register @ref RG_BBC1_PC */ +#define SR_BBC1_PC_FCST RG_BBC1_PC, PC_FCST_MASK, PC_FCST_SHIFT +/** Access parameters for sub-register TXAFCS in register @ref RG_BBC1_PC */ +#define SR_BBC1_PC_TXAFCS RG_BBC1_PC, PC_TXAFCS_MASK, \ + PC_TXAFCS_SHIFT +/** Access parameters for sub-register FCSOK in register @ref RG_BBC1_PC */ +#define SR_BBC1_PC_FCSOK RG_BBC1_PC, PC_FCSOK_MASK, \ + PC_FCSOK_SHIFT +/** Access parameters for sub-register FCSFE in register @ref RG_BBC1_PC */ +#define SR_BBC1_PC_FCSFE RG_BBC1_PC, PC_FCSFE_MASK, \ + PC_FCSFE_SHIFT +/** Access parameters for sub-register CTX in register @ref RG_BBC1_PC */ +#define SR_BBC1_PC_CTX RG_BBC1_PC, PC_CTX_MASK, PC_CTX_SHIFT + +/** Address for register BBC1_PS */ +#define RG_BBC1_PS (0x402) +/** Sub-registers of Register @ref RG_BBC1_PS */ +/** Access parameters for sub-register TXUR in register @ref RG_BBC1_PS */ +#define SR_BBC1_PS_TXUR RG_BBC1_PS, PS_TXUR_MASK, PS_TXUR_SHIFT + +/** Address for register BBC1_RXFLL */ +#define RG_BBC1_RXFLL (0x404) +/** Sub-registers of Register @ref RG_BBC1_RXFLL */ +/** Access parameters for sub-register RXFLL in register @ref RG_BBC1_RXFLL */ +#define SR_BBC1_RXFLL_RXFLL RG_BBC1_RXFLL, RXFLL_RXFLL_MASK, \ + RXFLL_RXFLL_SHIFT + +/** Address for register BBC1_RXFLH */ +#define RG_BBC1_RXFLH (0x405) +/** Sub-registers of Register @ref RG_BBC1_RXFLH */ +/** Access parameters for sub-register RXFLH in register @ref RG_BBC1_RXFLH */ +#define SR_BBC1_RXFLH_RXFLH RG_BBC1_RXFLH, RXFLH_RXFLH_MASK, \ + RXFLH_RXFLH_SHIFT + +/** Address for register BBC1_TXFLL */ +#define RG_BBC1_TXFLL (0x406) +/** Sub-registers of Register @ref RG_BBC1_TXFLL */ +/** Access parameters for sub-register TXFLL in register @ref RG_BBC1_TXFLL */ +#define SR_BBC1_TXFLL_TXFLL RG_BBC1_TXFLL, TXFLL_TXFLL_MASK, \ + TXFLL_TXFLL_SHIFT + +/** Address for register BBC1_TXFLH */ +#define RG_BBC1_TXFLH (0x407) +/** Sub-registers of Register @ref RG_BBC1_TXFLH */ +/** Access parameters for sub-register TXFLH in register @ref RG_BBC1_TXFLH */ +#define SR_BBC1_TXFLH_TXFLH RG_BBC1_TXFLH, TXFLH_TXFLH_MASK, \ + TXFLH_TXFLH_SHIFT + +/** Address for register BBC1_FBLL */ +#define RG_BBC1_FBLL (0x408) +/** Sub-registers of Register @ref RG_BBC1_FBLL */ +/** Access parameters for sub-register FBLL in register @ref RG_BBC1_FBLL */ +#define SR_BBC1_FBLL_FBLL RG_BBC1_FBLL, FBLL_FBLL_MASK, \ + FBLL_FBLL_SHIFT + +/** Address for register BBC1_FBLH */ +#define RG_BBC1_FBLH (0x409) +/** Sub-registers of Register @ref RG_BBC1_FBLH */ +/** Access parameters for sub-register FBLH in register @ref RG_BBC1_FBLH */ +#define SR_BBC1_FBLH_FBLH RG_BBC1_FBLH, FBLH_FBLH_MASK, \ + FBLH_FBLH_SHIFT + +/** Address for register BBC1_FBLIL */ +#define RG_BBC1_FBLIL (0x40A) +/** Sub-registers of Register @ref RG_BBC1_FBLIL */ +/** Access parameters for sub-register FBLIL in register @ref RG_BBC1_FBLIL */ +#define SR_BBC1_FBLIL_FBLIL RG_BBC1_FBLIL, FBLIL_FBLIL_MASK, \ + FBLIL_FBLIL_SHIFT + +/** Address for register BBC1_FBLIH */ +#define RG_BBC1_FBLIH (0x40B) +/** Sub-registers of Register @ref RG_BBC1_FBLIH */ +/** Access parameters for sub-register FBLIH in register @ref RG_BBC1_FBLIH */ +#define SR_BBC1_FBLIH_FBLIH RG_BBC1_FBLIH, FBLIH_FBLIH_MASK, \ + FBLIH_FBLIH_SHIFT + +/** Address for register BBC1_OFDMPHRTX */ +#define RG_BBC1_OFDMPHRTX (0x40C) +/** Sub-registers of Register @ref RG_BBC1_OFDMPHRTX */ +/** Access parameters for sub-register MCS in register @ref RG_BBC1_OFDMPHRTX */ +#define SR_BBC1_OFDMPHRTX_MCS RG_BBC1_OFDMPHRTX, OFDMPHRTX_MCS_MASK, \ + OFDMPHRTX_MCS_SHIFT +/** Access parameters for sub-register RB5 in register @ref RG_BBC1_OFDMPHRTX */ +#define SR_BBC1_OFDMPHRTX_RB5 RG_BBC1_OFDMPHRTX, OFDMPHRTX_RB5_MASK, \ + OFDMPHRTX_RB5_SHIFT + +/** Access parameters for sub-register RB17 in register @ref RG_BBC1_OFDMPHRTX +**/ +#define SR_BBC1_OFDMPHRTX_RB17 RG_BBC1_OFDMPHRTX, OFDMPHRTX_RB17_MASK, \ + OFDMPHRTX_RB17_SHIFT + +/** Access parameters for sub-register RB18 in register @ref RG_BBC1_OFDMPHRTX +**/ +#define SR_BBC1_OFDMPHRTX_RB18 RG_BBC1_OFDMPHRTX, OFDMPHRTX_RB18_MASK, \ + OFDMPHRTX_RB18_SHIFT + +/** Access parameters for sub-register RB21 in register @ref RG_BBC1_OFDMPHRTX +**/ +#define SR_BBC1_OFDMPHRTX_RB21 RG_BBC1_OFDMPHRTX, OFDMPHRTX_RB21_MASK, \ + OFDMPHRTX_RB21_SHIFT + +/** Address for register BBC1_OFDMPHRRX */ +#define RG_BBC1_OFDMPHRRX (0x40D) +/** Sub-registers of Register @ref RG_BBC1_OFDMPHRRX */ +/** Access parameters for sub-register MCS in register @ref RG_BBC1_OFDMPHRRX */ +#define SR_BBC1_OFDMPHRRX_MCS RG_BBC1_OFDMPHRRX, OFDMPHRRX_MCS_MASK, \ + OFDMPHRRX_MCS_SHIFT +/** Access parameters for sub-register SPC in register @ref RG_BBC1_OFDMPHRRX */ +#define SR_BBC1_OFDMPHRRX_SPC RG_BBC1_OFDMPHRRX, OFDMPHRRX_SPC_MASK, \ + OFDMPHRRX_SPC_SHIFT +/** Access parameters for sub-register RB5 in register @ref RG_BBC1_OFDMPHRRX */ +#define SR_BBC1_OFDMPHRRX_RB5 RG_BBC1_OFDMPHRRX, OFDMPHRRX_RB5_MASK, \ + OFDMPHRRX_RB5_SHIFT + +/** Access parameters for sub-register RB17 in register @ref RG_BBC1_OFDMPHRRX +**/ +#define SR_BBC1_OFDMPHRRX_RB17 RG_BBC1_OFDMPHRRX, OFDMPHRRX_RB17_MASK, \ + OFDMPHRRX_RB17_SHIFT + +/** Access parameters for sub-register RB18 in register @ref RG_BBC1_OFDMPHRRX +**/ +#define SR_BBC1_OFDMPHRRX_RB18 RG_BBC1_OFDMPHRRX, OFDMPHRRX_RB18_MASK, \ + OFDMPHRRX_RB18_SHIFT + +/** Access parameters for sub-register RB21 in register @ref RG_BBC1_OFDMPHRRX +**/ +#define SR_BBC1_OFDMPHRRX_RB21 RG_BBC1_OFDMPHRRX, OFDMPHRRX_RB21_MASK, \ + OFDMPHRRX_RB21_SHIFT + +/** Address for register BBC1_OFDMC */ +#define RG_BBC1_OFDMC (0x40E) +/** Sub-registers of Register @ref RG_BBC1_OFDMC */ +/** Access parameters for sub-register OPT in register @ref RG_BBC1_OFDMC */ +#define SR_BBC1_OFDMC_OPT RG_BBC1_OFDMC, OFDMC_OPT_MASK, \ + OFDMC_OPT_SHIFT +/** Access parameters for sub-register POI in register @ref RG_BBC1_OFDMC */ +#define SR_BBC1_OFDMC_POI RG_BBC1_OFDMC, OFDMC_POI_MASK, \ + OFDMC_POI_SHIFT +/** Access parameters for sub-register LFO in register @ref RG_BBC1_OFDMC */ +#define SR_BBC1_OFDMC_LFO RG_BBC1_OFDMC, OFDMC_LFO_MASK, \ + OFDMC_LFO_SHIFT +/** Access parameters for sub-register SSTX in register @ref RG_BBC1_OFDMC */ +#define SR_BBC1_OFDMC_SSTX RG_BBC1_OFDMC, OFDMC_SSTX_MASK, \ + OFDMC_SSTX_SHIFT +/** Access parameters for sub-register SSRX in register @ref RG_BBC1_OFDMC */ +#define SR_BBC1_OFDMC_SSRX RG_BBC1_OFDMC, OFDMC_SSRX_MASK, \ + OFDMC_SSRX_SHIFT + +/** Address for register BBC1_OFDMSW */ +#define RG_BBC1_OFDMSW (0x40F) +/** Sub-registers of Register @ref RG_BBC1_OFDMSW */ +/** Access parameters for sub-register RXO in register @ref RG_BBC1_OFDMSW */ +#define SR_BBC1_OFDMSW_RXO RG_BBC1_OFDMSW, OFDMSW_RXO_MASK, \ + OFDMSW_RXO_SHIFT +/** Access parameters for sub-register PDT in register @ref RG_BBC1_OFDMSW */ +#define SR_BBC1_OFDMSW_PDT RG_BBC1_OFDMSW, OFDMSW_PDT_MASK, \ + OFDMSW_PDT_SHIFT + +/** Address for register BBC1_OQPSKC0 */ +#define RG_BBC1_OQPSKC0 (0x410) +/** Sub-registers of Register @ref RG_BBC1_OQPSKC0 */ +/** Access parameters for sub-register FCHIP in register @ref RG_BBC1_OQPSKC0 */ +#define SR_BBC1_OQPSKC0_FCHIP RG_BBC1_OQPSKC0, OQPSKC0_FCHIP_MASK, \ + OQPSKC0_FCHIP_SHIFT +/** Access parameters for sub-register MOD in register @ref RG_BBC1_OQPSKC0 */ +#define SR_BBC1_OQPSKC0_MOD RG_BBC1_OQPSKC0, OQPSKC0_MOD_MASK, \ + OQPSKC0_MOD_SHIFT +/** Access parameters for sub-register DM in register @ref RG_BBC1_OQPSKC0 */ +#define SR_BBC1_OQPSKC0_DM RG_BBC1_OQPSKC0, OQPSKC0_DM_MASK, \ + OQPSKC0_DM_SHIFT + +/** Address for register BBC1_OQPSKC1 */ +#define RG_BBC1_OQPSKC1 (0x411) +/** Sub-registers of Register @ref RG_BBC1_OQPSKC1 */ +/** Access parameters for sub-register PDT0 in register @ref RG_BBC1_OQPSKC1 */ +#define SR_BBC1_OQPSKC1_PDT0 RG_BBC1_OQPSKC1, OQPSKC1_PDT0_MASK, \ + OQPSKC1_PDT0_SHIFT +/** Access parameters for sub-register PDT1 in register @ref RG_BBC1_OQPSKC1 */ +#define SR_BBC1_OQPSKC1_PDT1 RG_BBC1_OQPSKC1, OQPSKC1_PDT1_MASK, \ + OQPSKC1_PDT1_SHIFT + +/** Access parameters for sub-register RXOLEG in register @ref RG_BBC1_OQPSKC1 +**/ +#define SR_BBC1_OQPSKC1_RXOLEG RG_BBC1_OQPSKC1, OQPSKC1_RXOLEG_MASK, \ + OQPSKC1_RXOLEG_SHIFT +/** Access parameters for sub-register RXO in register @ref RG_BBC1_OQPSKC1 */ +#define SR_BBC1_OQPSKC1_RXO RG_BBC1_OQPSKC1, OQPSKC1_RXO_MASK, \ + OQPSKC1_RXO_SHIFT + +/** Address for register BBC1_OQPSKC2 */ +#define RG_BBC1_OQPSKC2 (0x412) +/** Sub-registers of Register @ref RG_BBC1_OQPSKC2 */ +/** Access parameters for sub-register RXM in register @ref RG_BBC1_OQPSKC2 */ +#define SR_BBC1_OQPSKC2_RXM RG_BBC1_OQPSKC2, OQPSKC2_RXM_MASK, \ + OQPSKC2_RXM_SHIFT + +/** Access parameters for sub-register FCSTLEG in register @ref RG_BBC1_OQPSKC2 +**/ +#define SR_BBC1_OQPSKC2_FCSTLEG RG_BBC1_OQPSKC2, OQPSKC2_FCSTLEG_MASK, \ + OQPSKC2_FCSTLEG_SHIFT + +/** Access parameters for sub-register ENPROP in register @ref RG_BBC1_OQPSKC2 +**/ +#define SR_BBC1_OQPSKC2_ENPROP RG_BBC1_OQPSKC2, OQPSKC2_ENPROP_MASK, \ + OQPSKC2_ENPROP_SHIFT +/** Access parameters for sub-register RPC in register @ref RG_BBC1_OQPSKC2 */ +#define SR_BBC1_OQPSKC2_RPC RG_BBC1_OQPSKC2, OQPSKC2_RPC_MASK, \ + OQPSKC2_RPC_SHIFT +/** Access parameters for sub-register SPC in register @ref RG_BBC1_OQPSKC2 */ +#define SR_BBC1_OQPSKC2_SPC RG_BBC1_OQPSKC2, OQPSKC2_SPC_MASK, \ + OQPSKC2_SPC_SHIFT + +/** Address for register BBC1_OQPSKC3 */ +#define RG_BBC1_OQPSKC3 (0x413) +/** Sub-registers of Register @ref RG_BBC1_OQPSKC3 */ +/** Access parameters for sub-register NSFD in register @ref RG_BBC1_OQPSKC3 */ +#define SR_BBC1_OQPSKC3_NSFD RG_BBC1_OQPSKC3, OQPSKC3_NSFD_MASK, \ + OQPSKC3_NSFD_SHIFT +/** Access parameters for sub-register HRLEG in register @ref RG_BBC1_OQPSKC3 */ +#define SR_BBC1_OQPSKC3_HRLEG RG_BBC1_OQPSKC3, OQPSKC3_HRLEG_MASK, \ + OQPSKC3_HRLEG_SHIFT + +/** Address for register BBC1_OQPSKPHRTX */ +#define RG_BBC1_OQPSKPHRTX (0x414) +/** Sub-registers of Register @ref RG_BBC1_OQPSKPHRTX */ + +/** Access parameters for sub-register LEG in register @ref RG_BBC1_OQPSKPHRTX +**/ +#define SR_BBC1_OQPSKPHRTX_LEG RG_BBC1_OQPSKPHRTX, OQPSKPHRTX_LEG_MASK, \ + OQPSKPHRTX_LEG_SHIFT + +/** Access parameters for sub-register MOD in register @ref RG_BBC1_OQPSKPHRTX +**/ +#define SR_BBC1_OQPSKPHRTX_MOD RG_BBC1_OQPSKPHRTX, OQPSKPHRTX_MOD_MASK, \ + OQPSKPHRTX_MOD_SHIFT + +/** Access parameters for sub-register RB0 in register @ref RG_BBC1_OQPSKPHRTX +**/ +#define SR_BBC1_OQPSKPHRTX_RB0 RG_BBC1_OQPSKPHRTX, OQPSKPHRTX_RB0_MASK, \ + OQPSKPHRTX_RB0_SHIFT + +/** Access parameters for sub-register PPDUT in register @ref RG_BBC1_OQPSKPHRTX +**/ +#define SR_BBC1_OQPSKPHRTX_PPDUT RG_BBC1_OQPSKPHRTX, \ + OQPSKPHRTX_PPDUT_MASK, OQPSKPHRTX_PPDUT_SHIFT + +/** Address for register BBC1_OQPSKPHRRX */ +#define RG_BBC1_OQPSKPHRRX (0x415) +/** Sub-registers of Register @ref RG_BBC1_OQPSKPHRRX */ + +/** Access parameters for sub-register LEG in register @ref RG_BBC1_OQPSKPHRRX +**/ +#define SR_BBC1_OQPSKPHRRX_LEG RG_BBC1_OQPSKPHRRX, OQPSKPHRRX_LEG_MASK, \ + OQPSKPHRRX_LEG_SHIFT + +/** Access parameters for sub-register MOD in register @ref RG_BBC1_OQPSKPHRRX +**/ +#define SR_BBC1_OQPSKPHRRX_MOD RG_BBC1_OQPSKPHRRX, OQPSKPHRRX_MOD_MASK, \ + OQPSKPHRRX_MOD_SHIFT + +/** Access parameters for sub-register RB0 in register @ref RG_BBC1_OQPSKPHRRX +**/ +#define SR_BBC1_OQPSKPHRRX_RB0 RG_BBC1_OQPSKPHRRX, OQPSKPHRRX_RB0_MASK, \ + OQPSKPHRRX_RB0_SHIFT + +/** Access parameters for sub-register PPDUT in register @ref RG_BBC1_OQPSKPHRRX +**/ +#define SR_BBC1_OQPSKPHRRX_PPDUT RG_BBC1_OQPSKPHRRX, \ + OQPSKPHRRX_PPDUT_MASK, OQPSKPHRRX_PPDUT_SHIFT + +/** Address for register BBC1_AFC0 */ +#define RG_BBC1_AFC0 (0x420) +/** Sub-registers of Register @ref RG_BBC1_AFC0 */ +/** Access parameters for sub-register AFEN0 in register @ref RG_BBC1_AFC0 */ +#define SR_BBC1_AFC0_AFEN0 RG_BBC1_AFC0, AFC0_AFEN0_MASK, \ + AFC0_AFEN0_SHIFT +/** Access parameters for sub-register AFEN1 in register @ref RG_BBC1_AFC0 */ +#define SR_BBC1_AFC0_AFEN1 RG_BBC1_AFC0, AFC0_AFEN1_MASK, \ + AFC0_AFEN1_SHIFT +/** Access parameters for sub-register AFEN2 in register @ref RG_BBC1_AFC0 */ +#define SR_BBC1_AFC0_AFEN2 RG_BBC1_AFC0, AFC0_AFEN2_MASK, \ + AFC0_AFEN2_SHIFT +/** Access parameters for sub-register AFEN3 in register @ref RG_BBC1_AFC0 */ +#define SR_BBC1_AFC0_AFEN3 RG_BBC1_AFC0, AFC0_AFEN3_MASK, \ + AFC0_AFEN3_SHIFT +/** Access parameters for sub-register PM in register @ref RG_BBC1_AFC0 */ +#define SR_BBC1_AFC0_PM RG_BBC1_AFC0, AFC0_PM_MASK, \ + AFC0_PM_SHIFT + +/** Address for register BBC1_AFC1 */ +#define RG_BBC1_AFC1 (0x421) +/** Sub-registers of Register @ref RG_BBC1_AFC1 */ +/** Access parameters for sub-register PANC0 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_PANC0 RG_BBC1_AFC1, AFC1_PANC0_MASK, \ + AFC1_PANC0_SHIFT +/** Access parameters for sub-register PANC1 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_PANC1 RG_BBC1_AFC1, AFC1_PANC1_MASK, \ + AFC1_PANC1_SHIFT +/** Access parameters for sub-register PANC2 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_PANC2 RG_BBC1_AFC1, AFC1_PANC2_MASK, \ + AFC1_PANC2_SHIFT +/** Access parameters for sub-register PANC3 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_PANC3 RG_BBC1_AFC1, AFC1_PANC3_MASK, \ + AFC1_PANC3_SHIFT +/** Access parameters for sub-register MRFT0 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_MRFT0 RG_BBC1_AFC1, AFC1_MRFT0_MASK, \ + AFC1_MRFT0_SHIFT +/** Access parameters for sub-register MRFT1 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_MRFT1 RG_BBC1_AFC1, AFC1_MRFT1_MASK, \ + AFC1_MRFT1_SHIFT +/** Access parameters for sub-register MRFT2 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_MRFT2 RG_BBC1_AFC1, AFC1_MRFT2_MASK, \ + AFC1_MRFT2_SHIFT +/** Access parameters for sub-register MRFT3 in register @ref RG_BBC1_AFC1 */ +#define SR_BBC1_AFC1_MRFT3 RG_BBC1_AFC1, AFC1_MRFT3_MASK, \ + AFC1_MRFT3_SHIFT + +/** Address for register BBC1_AFFTM */ +#define RG_BBC1_AFFTM (0x422) +/** Sub-registers of Register @ref RG_BBC1_AFFTM */ +/** Access parameters for sub-register AFFTM in register @ref RG_BBC1_AFFTM */ +#define SR_BBC1_AFFTM_AFFTM RG_BBC1_AFFTM, AFFTM_AFFTM_MASK, \ + AFFTM_AFFTM_SHIFT + +/** Address for register BBC1_AFFVM */ +#define RG_BBC1_AFFVM (0x423) +/** Sub-registers of Register @ref RG_BBC1_AFFVM */ +/** Access parameters for sub-register AFFVM in register @ref RG_BBC1_AFFVM */ +#define SR_BBC1_AFFVM_AFFVM RG_BBC1_AFFVM, AFFVM_AFFVM_MASK, \ + AFFVM_AFFVM_SHIFT + +/** Address for register BBC1_AFS */ +#define RG_BBC1_AFS (0x424) +/** Sub-registers of Register @ref RG_BBC1_AFS */ +/** Access parameters for sub-register AM0 in register @ref RG_BBC1_AFS */ +#define SR_BBC1_AFS_AM0 RG_BBC1_AFS, AFS_AM0_MASK, AFS_AM0_SHIFT +/** Access parameters for sub-register AM1 in register @ref RG_BBC1_AFS */ +#define SR_BBC1_AFS_AM1 RG_BBC1_AFS, AFS_AM1_MASK, AFS_AM1_SHIFT +/** Access parameters for sub-register AM2 in register @ref RG_BBC1_AFS */ +#define SR_BBC1_AFS_AM2 RG_BBC1_AFS, AFS_AM2_MASK, AFS_AM2_SHIFT +/** Access parameters for sub-register AM3 in register @ref RG_BBC1_AFS */ +#define SR_BBC1_AFS_AM3 RG_BBC1_AFS, AFS_AM3_MASK, AFS_AM3_SHIFT +/** Access parameters for sub-register EM in register @ref RG_BBC1_AFS */ +#define SR_BBC1_AFS_EM RG_BBC1_AFS, AFS_EM_MASK, AFS_EM_SHIFT + +/** Address for register BBC1_MACEA0 */ +#define RG_BBC1_MACEA0 (0x425) +/** Sub-registers of Register @ref RG_BBC1_MACEA0 */ +/** Access parameters for sub-register MACEA0 in register @ref RG_BBC1_MACEA0 */ +#define SR_BBC1_MACEA0_MACEA0 RG_BBC1_MACEA0, MACEA0_MACEA0_MASK, \ + MACEA0_MACEA0_SHIFT + +/** Address for register BBC1_MACEA1 */ +#define RG_BBC1_MACEA1 (0x426) +/** Sub-registers of Register @ref RG_BBC1_MACEA1 */ +/** Access parameters for sub-register MACEA1 in register @ref RG_BBC1_MACEA1 */ +#define SR_BBC1_MACEA1_MACEA1 RG_BBC1_MACEA1, MACEA1_MACEA1_MASK, \ + MACEA1_MACEA1_SHIFT + +/** Address for register BBC1_MACEA2 */ +#define RG_BBC1_MACEA2 (0x427) +/** Sub-registers of Register @ref RG_BBC1_MACEA2 */ +/** Access parameters for sub-register MACEA2 in register @ref RG_BBC1_MACEA2 */ +#define SR_BBC1_MACEA2_MACEA2 RG_BBC1_MACEA2, MACEA2_MACEA2_MASK, \ + MACEA2_MACEA2_SHIFT + +/** Address for register BBC1_MACEA3 */ +#define RG_BBC1_MACEA3 (0x428) +/** Sub-registers of Register @ref RG_BBC1_MACEA3 */ +/** Access parameters for sub-register MACEA3 in register @ref RG_BBC1_MACEA3 */ +#define SR_BBC1_MACEA3_MACEA3 RG_BBC1_MACEA3, MACEA3_MACEA3_MASK, \ + MACEA3_MACEA3_SHIFT + +/** Address for register BBC1_MACEA4 */ +#define RG_BBC1_MACEA4 (0x429) +/** Sub-registers of Register @ref RG_BBC1_MACEA4 */ +/** Access parameters for sub-register MACEA4 in register @ref RG_BBC1_MACEA4 */ +#define SR_BBC1_MACEA4_MACEA4 RG_BBC1_MACEA4, MACEA4_MACEA4_MASK, \ + MACEA4_MACEA4_SHIFT + +/** Address for register BBC1_MACEA5 */ +#define RG_BBC1_MACEA5 (0x42A) +/** Sub-registers of Register @ref RG_BBC1_MACEA5 */ +/** Access parameters for sub-register MACEA5 in register @ref RG_BBC1_MACEA5 */ +#define SR_BBC1_MACEA5_MACEA5 RG_BBC1_MACEA5, MACEA5_MACEA5_MASK, \ + MACEA5_MACEA5_SHIFT + +/** Address for register BBC1_MACEA6 */ +#define RG_BBC1_MACEA6 (0x42B) +/** Sub-registers of Register @ref RG_BBC1_MACEA6 */ +/** Access parameters for sub-register MACEA6 in register @ref RG_BBC1_MACEA6 */ +#define SR_BBC1_MACEA6_MACEA6 RG_BBC1_MACEA6, MACEA6_MACEA6_MASK, \ + MACEA6_MACEA6_SHIFT + +/** Address for register BBC1_MACEA7 */ +#define RG_BBC1_MACEA7 (0x42C) +/** Sub-registers of Register @ref RG_BBC1_MACEA7 */ +/** Access parameters for sub-register MACEA7 in register @ref RG_BBC1_MACEA7 */ +#define SR_BBC1_MACEA7_MACEA7 RG_BBC1_MACEA7, MACEA7_MACEA7_MASK, \ + MACEA7_MACEA7_SHIFT + +/** Address for register BBC1_MACPID0F0 */ +#define RG_BBC1_MACPID0F0 (0x42D) +/** Sub-registers of Register @ref RG_BBC1_MACPID0F0 */ + +/** Access parameters for sub-register MACPID0F0 in register @ref + * RG_BBC1_MACPID0F0 */ +#define SR_BBC1_MACPID0F0_MACPID0F0 RG_BBC1_MACPID0F0, \ + MACPID0F0_MACPID0F0_MASK, MACPID0F0_MACPID0F0_SHIFT + +/** Address for register BBC1_MACPID1F0 */ +#define RG_BBC1_MACPID1F0 (0x42E) +/** Sub-registers of Register @ref RG_BBC1_MACPID1F0 */ + +/** Access parameters for sub-register MACPID1F0 in register @ref + * RG_BBC1_MACPID1F0 */ +#define SR_BBC1_MACPID1F0_MACPID1F0 RG_BBC1_MACPID1F0, \ + MACPID1F0_MACPID1F0_MASK, MACPID1F0_MACPID1F0_SHIFT + +/** Address for register BBC1_MACSHA0F0 */ +#define RG_BBC1_MACSHA0F0 (0x42F) +/** Sub-registers of Register @ref RG_BBC1_MACSHA0F0 */ + +/** Access parameters for sub-register MACSHA0F0 in register @ref + * RG_BBC1_MACSHA0F0 */ +#define SR_BBC1_MACSHA0F0_MACSHA0F0 RG_BBC1_MACSHA0F0, \ + MACSHA0F0_MACSHA0F0_MASK, MACSHA0F0_MACSHA0F0_SHIFT + +/** Address for register BBC1_MACSHA1F0 */ +#define RG_BBC1_MACSHA1F0 (0x430) +/** Sub-registers of Register @ref RG_BBC1_MACSHA1F0 */ + +/** Access parameters for sub-register MACSHA1F0 in register @ref + * RG_BBC1_MACSHA1F0 */ +#define SR_BBC1_MACSHA1F0_MACSHA1F0 RG_BBC1_MACSHA1F0, \ + MACSHA1F0_MACSHA1F0_MASK, MACSHA1F0_MACSHA1F0_SHIFT + +/** Address for register BBC1_MACPID0F1 */ +#define RG_BBC1_MACPID0F1 (0x431) +/** Sub-registers of Register @ref RG_BBC1_MACPID0F1 */ + +/** Access parameters for sub-register MACPID0F1 in register @ref + * RG_BBC1_MACPID0F1 */ +#define SR_BBC1_MACPID0F1_MACPID0F1 RG_BBC1_MACPID0F1, \ + MACPID0F1_MACPID0F1_MASK, MACPID0F1_MACPID0F1_SHIFT + +/** Address for register BBC1_MACPID1F1 */ +#define RG_BBC1_MACPID1F1 (0x432) +/** Sub-registers of Register @ref RG_BBC1_MACPID1F1 */ + +/** Access parameters for sub-register MACPID1F1 in register @ref + * RG_BBC1_MACPID1F1 */ +#define SR_BBC1_MACPID1F1_MACPID1F1 RG_BBC1_MACPID1F1, \ + MACPID1F1_MACPID1F1_MASK, MACPID1F1_MACPID1F1_SHIFT + +/** Address for register BBC1_MACSHA0F1 */ +#define RG_BBC1_MACSHA0F1 (0x433) +/** Sub-registers of Register @ref RG_BBC1_MACSHA0F1 */ + +/** Access parameters for sub-register MACSHA0F1 in register @ref + * RG_BBC1_MACSHA0F1 */ +#define SR_BBC1_MACSHA0F1_MACSHA0F1 RG_BBC1_MACSHA0F1, \ + MACSHA0F1_MACSHA0F1_MASK, MACSHA0F1_MACSHA0F1_SHIFT + +/** Address for register BBC1_MACSHA1F1 */ +#define RG_BBC1_MACSHA1F1 (0x434) +/** Sub-registers of Register @ref RG_BBC1_MACSHA1F1 */ + +/** Access parameters for sub-register MACSHA1F1 in register @ref + * RG_BBC1_MACSHA1F1 */ +#define SR_BBC1_MACSHA1F1_MACSHA1F1 RG_BBC1_MACSHA1F1, \ + MACSHA1F1_MACSHA1F1_MASK, MACSHA1F1_MACSHA1F1_SHIFT + +/** Address for register BBC1_MACPID0F2 */ +#define RG_BBC1_MACPID0F2 (0x435) +/** Sub-registers of Register @ref RG_BBC1_MACPID0F2 */ + +/** Access parameters for sub-register MACPID0F2 in register @ref + * RG_BBC1_MACPID0F2 */ +#define SR_BBC1_MACPID0F2_MACPID0F2 RG_BBC1_MACPID0F2, \ + MACPID0F2_MACPID0F2_MASK, MACPID0F2_MACPID0F2_SHIFT + +/** Address for register BBC1_MACPID1F2 */ +#define RG_BBC1_MACPID1F2 (0x436) +/** Sub-registers of Register @ref RG_BBC1_MACPID1F2 */ + +/** Access parameters for sub-register MACPID1F2 in register @ref + * RG_BBC1_MACPID1F2 */ +#define SR_BBC1_MACPID1F2_MACPID1F2 RG_BBC1_MACPID1F2, \ + MACPID1F2_MACPID1F2_MASK, MACPID1F2_MACPID1F2_SHIFT + +/** Address for register BBC1_MACSHA0F2 */ +#define RG_BBC1_MACSHA0F2 (0x437) +/** Sub-registers of Register @ref RG_BBC1_MACSHA0F2 */ + +/** Access parameters for sub-register MACSHA0F2 in register @ref + * RG_BBC1_MACSHA0F2 */ +#define SR_BBC1_MACSHA0F2_MACSHA0F2 RG_BBC1_MACSHA0F2, \ + MACSHA0F2_MACSHA0F2_MASK, MACSHA0F2_MACSHA0F2_SHIFT + +/** Address for register BBC1_MACSHA1F2 */ +#define RG_BBC1_MACSHA1F2 (0x438) +/** Sub-registers of Register @ref RG_BBC1_MACSHA1F2 */ + +/** Access parameters for sub-register MACSHA1F2 in register @ref + * RG_BBC1_MACSHA1F2 */ +#define SR_BBC1_MACSHA1F2_MACSHA1F2 RG_BBC1_MACSHA1F2, \ + MACSHA1F2_MACSHA1F2_MASK, MACSHA1F2_MACSHA1F2_SHIFT + +/** Address for register BBC1_MACPID0F3 */ +#define RG_BBC1_MACPID0F3 (0x439) +/** Sub-registers of Register @ref RG_BBC1_MACPID0F3 */ + +/** Access parameters for sub-register MACPID0F3 in register @ref + * RG_BBC1_MACPID0F3 */ +#define SR_BBC1_MACPID0F3_MACPID0F3 RG_BBC1_MACPID0F3, \ + MACPID0F3_MACPID0F3_MASK, MACPID0F3_MACPID0F3_SHIFT + +/** Address for register BBC1_MACPID1F3 */ +#define RG_BBC1_MACPID1F3 (0x43A) +/** Sub-registers of Register @ref RG_BBC1_MACPID1F3 */ + +/** Access parameters for sub-register MACPID1F3 in register @ref + * RG_BBC1_MACPID1F3 */ +#define SR_BBC1_MACPID1F3_MACPID1F3 RG_BBC1_MACPID1F3, \ + MACPID1F3_MACPID1F3_MASK, MACPID1F3_MACPID1F3_SHIFT + +/** Address for register BBC1_MACSHA0F3 */ +#define RG_BBC1_MACSHA0F3 (0x43B) +/** Sub-registers of Register @ref RG_BBC1_MACSHA0F3 */ + +/** Access parameters for sub-register MACSHA0F3 in register @ref + * RG_BBC1_MACSHA0F3 */ +#define SR_BBC1_MACSHA0F3_MACSHA0F3 RG_BBC1_MACSHA0F3, \ + MACSHA0F3_MACSHA0F3_MASK, MACSHA0F3_MACSHA0F3_SHIFT + +/** Address for register BBC1_MACSHA1F3 */ +#define RG_BBC1_MACSHA1F3 (0x43C) +/** Sub-registers of Register @ref RG_BBC1_MACSHA1F3 */ + +/** Access parameters for sub-register MACSHA1F3 in register @ref + * RG_BBC1_MACSHA1F3 */ +#define SR_BBC1_MACSHA1F3_MACSHA1F3 RG_BBC1_MACSHA1F3, \ + MACSHA1F3_MACSHA1F3_MASK, MACSHA1F3_MACSHA1F3_SHIFT + +/** Address for register BBC1_AMCS */ +#define RG_BBC1_AMCS (0x440) +/** Sub-registers of Register @ref RG_BBC1_AMCS */ +/** Access parameters for sub-register TX2RX in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_TX2RX RG_BBC1_AMCS, AMCS_TX2RX_MASK, \ + AMCS_TX2RX_SHIFT +/** Access parameters for sub-register CCATX in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_CCATX RG_BBC1_AMCS, AMCS_CCATX_MASK, \ + AMCS_CCATX_SHIFT +/** Access parameters for sub-register CCAED in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_CCAED RG_BBC1_AMCS, AMCS_CCAED_MASK, \ + AMCS_CCAED_SHIFT +/** Access parameters for sub-register AACK in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_AACK RG_BBC1_AMCS, AMCS_AACK_MASK, \ + AMCS_AACK_SHIFT +/** Access parameters for sub-register AACKS in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_AACKS RG_BBC1_AMCS, AMCS_AACKS_MASK, \ + AMCS_AACKS_SHIFT +/** Access parameters for sub-register AACKDR in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_AACKDR RG_BBC1_AMCS, AMCS_AACKDR_MASK, \ + AMCS_AACKDR_SHIFT +/** Access parameters for sub-register AACKFA in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_AACKFA RG_BBC1_AMCS, AMCS_AACKFA_MASK, \ + AMCS_AACKFA_SHIFT +/** Access parameters for sub-register AACKFT in register @ref RG_BBC1_AMCS */ +#define SR_BBC1_AMCS_AACKFT RG_BBC1_AMCS, AMCS_AACKFT_MASK, \ + AMCS_AACKFT_SHIFT + +/** Address for register BBC1_AMEDT */ +#define RG_BBC1_AMEDT (0x441) +/** Sub-registers of Register @ref RG_BBC1_AMEDT */ +/** Access parameters for sub-register AMEDT in register @ref RG_BBC1_AMEDT */ +#define SR_BBC1_AMEDT_AMEDT RG_BBC1_AMEDT, AMEDT_AMEDT_MASK, \ + AMEDT_AMEDT_SHIFT + +/** Address for register BBC1_AMAACKPD */ +#define RG_BBC1_AMAACKPD (0x442) +/** Sub-registers of Register @ref RG_BBC1_AMAACKPD */ +/** Access parameters for sub-register PD0 in register @ref RG_BBC1_AMAACKPD */ +#define SR_BBC1_AMAACKPD_PD0 RG_BBC1_AMAACKPD, AMAACKPD_PD0_MASK, \ + AMAACKPD_PD0_SHIFT +/** Access parameters for sub-register PD1 in register @ref RG_BBC1_AMAACKPD */ +#define SR_BBC1_AMAACKPD_PD1 RG_BBC1_AMAACKPD, AMAACKPD_PD1_MASK, \ + AMAACKPD_PD1_SHIFT +/** Access parameters for sub-register PD2 in register @ref RG_BBC1_AMAACKPD */ +#define SR_BBC1_AMAACKPD_PD2 RG_BBC1_AMAACKPD, AMAACKPD_PD2_MASK, \ + AMAACKPD_PD2_SHIFT +/** Access parameters for sub-register PD3 in register @ref RG_BBC1_AMAACKPD */ +#define SR_BBC1_AMAACKPD_PD3 RG_BBC1_AMAACKPD, AMAACKPD_PD3_MASK, \ + AMAACKPD_PD3_SHIFT + +/** Address for register BBC1_AMAACKTL */ +#define RG_BBC1_AMAACKTL (0x443) +/** Sub-registers of Register @ref RG_BBC1_AMAACKTL */ + +/** Access parameters for sub-register AMAACKTL in register @ref + * RG_BBC1_AMAACKTL */ +#define SR_BBC1_AMAACKTL_AMAACKTL RG_BBC1_AMAACKTL, \ + AMAACKTL_AMAACKTL_MASK, AMAACKTL_AMAACKTL_SHIFT + +/** Address for register BBC1_AMAACKTH */ +#define RG_BBC1_AMAACKTH (0x444) +/** Sub-registers of Register @ref RG_BBC1_AMAACKTH */ + +/** Access parameters for sub-register AMAACKTH in register @ref + * RG_BBC1_AMAACKTH */ +#define SR_BBC1_AMAACKTH_AMAACKTH RG_BBC1_AMAACKTH, \ + AMAACKTH_AMAACKTH_MASK, AMAACKTH_AMAACKTH_SHIFT + +/** Address for register BBC1_FSKC0 */ +#define RG_BBC1_FSKC0 (0x460) +/** Sub-registers of Register @ref RG_BBC1_FSKC0 */ +/** Access parameters for sub-register MORD in register @ref RG_BBC1_FSKC0 */ +#define SR_BBC1_FSKC0_MORD RG_BBC1_FSKC0, FSKC0_MORD_MASK, \ + FSKC0_MORD_SHIFT +/** Access parameters for sub-register MIDX in register @ref RG_BBC1_FSKC0 */ +#define SR_BBC1_FSKC0_MIDX RG_BBC1_FSKC0, FSKC0_MIDX_MASK, \ + FSKC0_MIDX_SHIFT +/** Access parameters for sub-register MIDXS in register @ref RG_BBC1_FSKC0 */ +#define SR_BBC1_FSKC0_MIDXS RG_BBC1_FSKC0, FSKC0_MIDXS_MASK, \ + FSKC0_MIDXS_SHIFT +/** Access parameters for sub-register BT in register @ref RG_BBC1_FSKC0 */ +#define SR_BBC1_FSKC0_BT RG_BBC1_FSKC0, FSKC0_BT_MASK, \ + FSKC0_BT_SHIFT + +/** Address for register BBC1_FSKC1 */ +#define RG_BBC1_FSKC1 (0x461) +/** Sub-registers of Register @ref RG_BBC1_FSKC1 */ +/** Access parameters for sub-register SRATE in register @ref RG_BBC1_FSKC1 */ +#define SR_BBC1_FSKC1_SRATE RG_BBC1_FSKC1, FSKC1_SRATE_MASK, \ + FSKC1_SRATE_SHIFT +/** Access parameters for sub-register FI in register @ref RG_BBC1_FSKC1 */ +#define SR_BBC1_FSKC1_FI RG_BBC1_FSKC1, FSKC1_FI_MASK, \ + FSKC1_FI_SHIFT +/** Access parameters for sub-register FSKPLH in register @ref RG_BBC1_FSKC1 */ +#define SR_BBC1_FSKC1_FSKPLH RG_BBC1_FSKC1, FSKC1_FSKPLH_MASK, \ + FSKC1_FSKPLH_SHIFT + +/** Address for register BBC1_FSKC2 */ +#define RG_BBC1_FSKC2 (0x462) +/** Sub-registers of Register @ref RG_BBC1_FSKC2 */ +/** Access parameters for sub-register FECIE in register @ref RG_BBC1_FSKC2 */ +#define SR_BBC1_FSKC2_FECIE RG_BBC1_FSKC2, FSKC2_FECIE_MASK, \ + FSKC2_FECIE_SHIFT +/** Access parameters for sub-register FECS in register @ref RG_BBC1_FSKC2 */ +#define SR_BBC1_FSKC2_FECS RG_BBC1_FSKC2, FSKC2_FECS_MASK, \ + FSKC2_FECS_SHIFT +/** Access parameters for sub-register PRI in register @ref RG_BBC1_FSKC2 */ +#define SR_BBC1_FSKC2_PRI RG_BBC1_FSKC2, FSKC2_PRI_MASK, \ + FSKC2_PRI_SHIFT +/** Access parameters for sub-register MSE in register @ref RG_BBC1_FSKC2 */ +#define SR_BBC1_FSKC2_MSE RG_BBC1_FSKC2, FSKC2_MSE_MASK, \ + FSKC2_MSE_SHIFT +/** Access parameters for sub-register RXPTO in register @ref RG_BBC1_FSKC2 */ +#define SR_BBC1_FSKC2_RXPTO RG_BBC1_FSKC2, FSKC2_RXPTO_MASK, \ + FSKC2_RXPTO_SHIFT +/** Access parameters for sub-register RXO in register @ref RG_BBC1_FSKC2 */ +#define SR_BBC1_FSKC2_RXO RG_BBC1_FSKC2, FSKC2_RXO_MASK, \ + FSKC2_RXO_SHIFT +/** Access parameters for sub-register PDTM in register @ref RG_BBC1_FSKC2 */ +#define SR_BBC1_FSKC2_PDTM RG_BBC1_FSKC2, FSKC2_PDTM_MASK, \ + FSKC2_PDTM_SHIFT + +/** Address for register BBC1_FSKC3 */ +#define RG_BBC1_FSKC3 (0x463) +/** Sub-registers of Register @ref RG_BBC1_FSKC3 */ +/** Access parameters for sub-register PDT in register @ref RG_BBC1_FSKC3 */ +#define SR_BBC1_FSKC3_PDT RG_BBC1_FSKC3, FSKC3_PDT_MASK, \ + FSKC3_PDT_SHIFT +/** Access parameters for sub-register SFDT in register @ref RG_BBC1_FSKC3 */ +#define SR_BBC1_FSKC3_SFDT RG_BBC1_FSKC3, FSKC3_SFDT_MASK, \ + FSKC3_SFDT_SHIFT + +/** Address for register BBC1_FSKC4 */ +#define RG_BBC1_FSKC4 (0x464) +/** Sub-registers of Register @ref RG_BBC1_FSKC4 */ +/** Access parameters for sub-register CSFD0 in register @ref RG_BBC1_FSKC4 */ +#define SR_BBC1_FSKC4_CSFD0 RG_BBC1_FSKC4, FSKC4_CSFD0_MASK, \ + FSKC4_CSFD0_SHIFT +/** Access parameters for sub-register CSFD1 in register @ref RG_BBC1_FSKC4 */ +#define SR_BBC1_FSKC4_CSFD1 RG_BBC1_FSKC4, FSKC4_CSFD1_MASK, \ + FSKC4_CSFD1_SHIFT +/** Access parameters for sub-register RAWRBIT in register @ref RG_BBC1_FSKC4 */ +#define SR_BBC1_FSKC4_RAWRBIT RG_BBC1_FSKC4, FSKC4_RAWRBIT_MASK, \ + FSKC4_RAWRBIT_SHIFT +/** Access parameters for sub-register SFD32 in register @ref RG_BBC1_FSKC4 */ +#define SR_BBC1_FSKC4_SFD32 RG_BBC1_FSKC4, FSKC4_SFD32_MASK, \ + FSKC4_SFD32_SHIFT +/** Access parameters for sub-register SFDQ in register @ref RG_BBC1_FSKC4 */ +#define SR_BBC1_FSKC4_SFDQ RG_BBC1_FSKC4, FSKC4_SFDQ_MASK, \ + FSKC4_SFDQ_SHIFT + +/** Address for register BBC1_FSKPLL */ +#define RG_BBC1_FSKPLL (0x465) +/** Sub-registers of Register @ref RG_BBC1_FSKPLL */ +/** Access parameters for sub-register FSKPLL in register @ref RG_BBC1_FSKPLL */ +#define SR_BBC1_FSKPLL_FSKPLL RG_BBC1_FSKPLL, FSKPLL_FSKPLL_MASK, \ + FSKPLL_FSKPLL_SHIFT + +/** Address for register BBC1_FSKSFD0L */ +#define RG_BBC1_FSKSFD0L (0x466) +/** Sub-registers of Register @ref RG_BBC1_FSKSFD0L */ + +/** Access parameters for sub-register FSKSFD0L in register @ref + * RG_BBC1_FSKSFD0L */ +#define SR_BBC1_FSKSFD0L_FSKSFD0L RG_BBC1_FSKSFD0L, \ + FSKSFD0L_FSKSFD0L_MASK, FSKSFD0L_FSKSFD0L_SHIFT + +/** Address for register BBC1_FSKSFD0H */ +#define RG_BBC1_FSKSFD0H (0x467) +/** Sub-registers of Register @ref RG_BBC1_FSKSFD0H */ + +/** Access parameters for sub-register FSKSFD0H in register @ref + * RG_BBC1_FSKSFD0H */ +#define SR_BBC1_FSKSFD0H_FSKSFD0H RG_BBC1_FSKSFD0H, \ + FSKSFD0H_FSKSFD0H_MASK, FSKSFD0H_FSKSFD0H_SHIFT + +/** Address for register BBC1_FSKSFD1L */ +#define RG_BBC1_FSKSFD1L (0x468) +/** Sub-registers of Register @ref RG_BBC1_FSKSFD1L */ + +/** Access parameters for sub-register FSKSFD1L in register @ref + * RG_BBC1_FSKSFD1L */ +#define SR_BBC1_FSKSFD1L_FSKSFD1L RG_BBC1_FSKSFD1L, \ + FSKSFD1L_FSKSFD1L_MASK, FSKSFD1L_FSKSFD1L_SHIFT + +/** Address for register BBC1_FSKSFD1H */ +#define RG_BBC1_FSKSFD1H (0x469) +/** Sub-registers of Register @ref RG_BBC1_FSKSFD1H */ + +/** Access parameters for sub-register FSKSFD1H in register @ref + * RG_BBC1_FSKSFD1H */ +#define SR_BBC1_FSKSFD1H_FSKSFD1H RG_BBC1_FSKSFD1H, \ + FSKSFD1H_FSKSFD1H_MASK, FSKSFD1H_FSKSFD1H_SHIFT + +/** Address for register BBC1_FSKPHRTX */ +#define RG_BBC1_FSKPHRTX (0x46A) +/** Sub-registers of Register @ref RG_BBC1_FSKPHRTX */ +/** Access parameters for sub-register RB1 in register @ref RG_BBC1_FSKPHRTX */ +#define SR_BBC1_FSKPHRTX_RB1 RG_BBC1_FSKPHRTX, FSKPHRTX_RB1_MASK, \ + FSKPHRTX_RB1_SHIFT +/** Access parameters for sub-register RB2 in register @ref RG_BBC1_FSKPHRTX */ +#define SR_BBC1_FSKPHRTX_RB2 RG_BBC1_FSKPHRTX, FSKPHRTX_RB2_MASK, \ + FSKPHRTX_RB2_SHIFT +/** Access parameters for sub-register DW in register @ref RG_BBC1_FSKPHRTX */ +#define SR_BBC1_FSKPHRTX_DW RG_BBC1_FSKPHRTX, FSKPHRTX_DW_MASK, \ + FSKPHRTX_DW_SHIFT +/** Access parameters for sub-register SFD in register @ref RG_BBC1_FSKPHRTX */ +#define SR_BBC1_FSKPHRTX_SFD RG_BBC1_FSKPHRTX, FSKPHRTX_SFD_MASK, \ + FSKPHRTX_SFD_SHIFT + +/** Address for register BBC1_FSKPHRRX */ +#define RG_BBC1_FSKPHRRX (0x46B) +/** Sub-registers of Register @ref RG_BBC1_FSKPHRRX */ +/** Access parameters for sub-register RB1 in register @ref RG_BBC1_FSKPHRRX */ +#define SR_BBC1_FSKPHRRX_RB1 RG_BBC1_FSKPHRRX, FSKPHRRX_RB1_MASK, \ + FSKPHRRX_RB1_SHIFT +/** Access parameters for sub-register RB2 in register @ref RG_BBC1_FSKPHRRX */ +#define SR_BBC1_FSKPHRRX_RB2 RG_BBC1_FSKPHRRX, FSKPHRRX_RB2_MASK, \ + FSKPHRRX_RB2_SHIFT +/** Access parameters for sub-register DW in register @ref RG_BBC1_FSKPHRRX */ +#define SR_BBC1_FSKPHRRX_DW RG_BBC1_FSKPHRRX, FSKPHRRX_DW_MASK, \ + FSKPHRRX_DW_SHIFT +/** Access parameters for sub-register SFD in register @ref RG_BBC1_FSKPHRRX */ +#define SR_BBC1_FSKPHRRX_SFD RG_BBC1_FSKPHRRX, FSKPHRRX_SFD_MASK, \ + FSKPHRRX_SFD_SHIFT +/** Access parameters for sub-register MS in register @ref RG_BBC1_FSKPHRRX */ +#define SR_BBC1_FSKPHRRX_MS RG_BBC1_FSKPHRRX, FSKPHRRX_MS_MASK, \ + FSKPHRRX_MS_SHIFT +/** Access parameters for sub-register FCST in register @ref RG_BBC1_FSKPHRRX */ +#define SR_BBC1_FSKPHRRX_FCST RG_BBC1_FSKPHRRX, FSKPHRRX_FCST_MASK, \ + FSKPHRRX_FCST_SHIFT + +/** Address for register BBC1_FSKRPC */ +#define RG_BBC1_FSKRPC (0x46C) +/** Sub-registers of Register @ref RG_BBC1_FSKRPC */ +/** Access parameters for sub-register BASET in register @ref RG_BBC1_FSKRPC */ +#define SR_BBC1_FSKRPC_BASET RG_BBC1_FSKRPC, FSKRPC_BASET_MASK, \ + FSKRPC_BASET_SHIFT +/** Access parameters for sub-register EN in register @ref RG_BBC1_FSKRPC */ +#define SR_BBC1_FSKRPC_EN RG_BBC1_FSKRPC, FSKRPC_EN_MASK, \ + FSKRPC_EN_SHIFT + +/** Address for register BBC1_FSKRPCONT */ +#define RG_BBC1_FSKRPCONT (0x46D) +/** Sub-registers of Register @ref RG_BBC1_FSKRPCONT */ + +/** Access parameters for sub-register FSKRPCONT in register @ref + * RG_BBC1_FSKRPCONT */ +#define SR_BBC1_FSKRPCONT_FSKRPCONT RG_BBC1_FSKRPCONT, \ + FSKRPCONT_FSKRPCONT_MASK, FSKRPCONT_FSKRPCONT_SHIFT + +/** Address for register BBC1_FSKRPCOFFT */ +#define RG_BBC1_FSKRPCOFFT (0x46E) +/** Sub-registers of Register @ref RG_BBC1_FSKRPCOFFT */ + +/** Access parameters for sub-register FSKRPCOFFT in register @ref + * RG_BBC1_FSKRPCOFFT */ +#define SR_BBC1_FSKRPCOFFT_FSKRPCOFFT RG_BBC1_FSKRPCOFFT, \ + FSKRPCOFFT_FSKRPCOFFT_MASK, FSKRPCOFFT_FSKRPCOFFT_SHIFT + +/** Address for register BBC1_FSKRRXFLL */ +#define RG_BBC1_FSKRRXFLL (0x470) +/** Sub-registers of Register @ref RG_BBC1_FSKRRXFLL */ + +/** Access parameters for sub-register FSKRRXFLL in register @ref + * RG_BBC1_FSKRRXFLL */ +#define SR_BBC1_FSKRRXFLL_FSKRRXFLL RG_BBC1_FSKRRXFLL, \ + FSKRRXFLL_FSKRRXFLL_MASK, FSKRRXFLL_FSKRRXFLL_SHIFT + +/** Address for register BBC1_FSKRRXFLH */ +#define RG_BBC1_FSKRRXFLH (0x471) +/** Sub-registers of Register @ref RG_BBC1_FSKRRXFLH */ +/** Access parameters for sub-register FSKRRXFLH in register @ref + *RG_BBC1_FSKRRXFLH */ +#define SR_BBC1_FSKRRXFLH_FSKRRXFLH RG_BBC1_FSKRRXFLH, \ + FSKRRXFLH_FSKRRXFLH_MASK, FSKRRXFLH_FSKRRXFLH_SHIFT + +/** Address for register BBC1_FSKDM */ +#define RG_BBC1_FSKDM (0x472) +/** Sub-registers of Register @ref RG_BBC1_FSKDM */ +/** Access parameters for sub-register EN in register @ref RG_BBC1_FSKDM */ +#define SR_BBC1_FSKDM_EN RG_BBC1_FSKDM, FSKDM_EN_MASK, \ + FSKDM_EN_SHIFT +/** Access parameters for sub-register PE in register @ref RG_BBC1_FSKDM */ +#define SR_BBC1_FSKDM_PE RG_BBC1_FSKDM, FSKDM_PE_MASK, \ + FSKDM_PE_SHIFT + +/** Address for register BBC1_FSKPE0 */ +#define RG_BBC1_FSKPE0 (0x473) +/** Sub-registers of Register @ref RG_BBC1_FSKPE0 */ +/** Access parameters for sub-register FSKPE0 in register @ref RG_BBC1_FSKPE0 */ +#define SR_BBC1_FSKPE0_FSKPE0 RG_BBC1_FSKPE0, FSKPE0_FSKPE0_MASK, \ + FSKPE0_FSKPE0_SHIFT + +/** Address for register BBC1_FSKPE1 */ +#define RG_BBC1_FSKPE1 (0x474) +/** Sub-registers of Register @ref RG_BBC1_FSKPE1 */ +/** Access parameters for sub-register FSKPE1 in register @ref RG_BBC1_FSKPE1 */ +#define SR_BBC1_FSKPE1_FSKPE1 RG_BBC1_FSKPE1, FSKPE1_FSKPE1_MASK, \ + FSKPE1_FSKPE1_SHIFT + +/** Address for register BBC1_FSKPE2 */ +#define RG_BBC1_FSKPE2 (0x475) +/** Sub-registers of Register @ref RG_BBC1_FSKPE2 */ +/** Access parameters for sub-register FSKPE2 in register @ref RG_BBC1_FSKPE2 */ +#define SR_BBC1_FSKPE2_FSKPE2 RG_BBC1_FSKPE2, FSKPE2_FSKPE2_MASK, \ + FSKPE2_FSKPE2_SHIFT + +/** Address for register BBC1_PMUC */ +#define RG_BBC1_PMUC (0x480) +/** Sub-registers of Register @ref RG_BBC1_PMUC */ +/** Access parameters for sub-register EN in register @ref RG_BBC1_PMUC */ +#define SR_BBC1_PMUC_EN RG_BBC1_PMUC, PMUC_EN_MASK, \ + PMUC_EN_SHIFT +/** Access parameters for sub-register AVG in register @ref RG_BBC1_PMUC */ +#define SR_BBC1_PMUC_AVG RG_BBC1_PMUC, PMUC_AVG_MASK, \ + PMUC_AVG_SHIFT +/** Access parameters for sub-register SYNC in register @ref RG_BBC1_PMUC */ +#define SR_BBC1_PMUC_SYNC RG_BBC1_PMUC, PMUC_SYNC_MASK, \ + PMUC_SYNC_SHIFT +/** Access parameters for sub-register FED in register @ref RG_BBC1_PMUC */ +#define SR_BBC1_PMUC_FED RG_BBC1_PMUC, PMUC_FED_MASK, \ + PMUC_FED_SHIFT +/** Access parameters for sub-register IQSEL in register @ref RG_BBC1_PMUC */ +#define SR_BBC1_PMUC_IQSEL RG_BBC1_PMUC, PMUC_IQSEL_MASK, \ + PMUC_IQSEL_SHIFT +/** Access parameters for sub-register CCFTS in register @ref RG_BBC1_PMUC */ +#define SR_BBC1_PMUC_CCFTS RG_BBC1_PMUC, PMUC_CCFTS_MASK, \ + PMUC_CCFTS_SHIFT + +/** Address for register BBC1_PMUVAL */ +#define RG_BBC1_PMUVAL (0x481) +/** Sub-registers of Register @ref RG_BBC1_PMUVAL */ +/** Access parameters for sub-register PMUVAL in register @ref RG_BBC1_PMUVAL */ +#define SR_BBC1_PMUVAL_PMUVAL RG_BBC1_PMUVAL, PMUVAL_PMUVAL_MASK, \ + PMUVAL_PMUVAL_SHIFT + +/** Address for register BBC1_PMUQF */ +#define RG_BBC1_PMUQF (0x482) +/** Sub-registers of Register @ref RG_BBC1_PMUQF */ +/** Access parameters for sub-register PMUQF in register @ref RG_BBC1_PMUQF */ +#define SR_BBC1_PMUQF_PMUQF RG_BBC1_PMUQF, PMUQF_PMUQF_MASK, \ + PMUQF_PMUQF_SHIFT + +/** Address for register BBC1_PMUI */ +#define RG_BBC1_PMUI (0x483) +/** Sub-registers of Register @ref RG_BBC1_PMUI */ +/** Access parameters for sub-register PMUI in register @ref RG_BBC1_PMUI */ +#define SR_BBC1_PMUI_PMUI RG_BBC1_PMUI, PMUI_PMUI_MASK, \ + PMUI_PMUI_SHIFT + +/** Address for register BBC1_PMUQ */ +#define RG_BBC1_PMUQ (0x484) +/** Sub-registers of Register @ref RG_BBC1_PMUQ */ +/** Access parameters for sub-register PMUQ in register @ref RG_BBC1_PMUQ */ +#define SR_BBC1_PMUQ_PMUQ RG_BBC1_PMUQ, PMUQ_PMUQ_MASK, \ + PMUQ_PMUQ_SHIFT + +/** Address for register BBC1_CNTC */ +#define RG_BBC1_CNTC (0x490) +/** Sub-registers of Register @ref RG_BBC1_CNTC */ +/** Access parameters for sub-register EN in register @ref RG_BBC1_CNTC */ +#define SR_BBC1_CNTC_EN RG_BBC1_CNTC, CNTC_EN_MASK, \ + CNTC_EN_SHIFT +/** Access parameters for sub-register RSTRXS in register @ref RG_BBC1_CNTC */ +#define SR_BBC1_CNTC_RSTRXS RG_BBC1_CNTC, CNTC_RSTRXS_MASK, \ + CNTC_RSTRXS_SHIFT +/** Access parameters for sub-register RSTTXS in register @ref RG_BBC1_CNTC */ +#define SR_BBC1_CNTC_RSTTXS RG_BBC1_CNTC, CNTC_RSTTXS_MASK, \ + CNTC_RSTTXS_SHIFT +/** Access parameters for sub-register CAPRXS in register @ref RG_BBC1_CNTC */ +#define SR_BBC1_CNTC_CAPRXS RG_BBC1_CNTC, CNTC_CAPRXS_MASK, \ + CNTC_CAPRXS_SHIFT +/** Access parameters for sub-register CAPTXS in register @ref RG_BBC1_CNTC */ +#define SR_BBC1_CNTC_CAPTXS RG_BBC1_CNTC, CNTC_CAPTXS_MASK, \ + CNTC_CAPTXS_SHIFT + +/** Address for register BBC1_CNT0 */ +#define RG_BBC1_CNT0 (0x491) +/** Sub-registers of Register @ref RG_BBC1_CNT0 */ +/** Access parameters for sub-register CNT0 in register @ref RG_BBC1_CNT0 */ +#define SR_BBC1_CNT0_CNT0 RG_BBC1_CNT0, CNT0_CNT0_MASK, \ + CNT0_CNT0_SHIFT + +/** Address for register BBC1_CNT1 */ +#define RG_BBC1_CNT1 (0x492) +/** Sub-registers of Register @ref RG_BBC1_CNT1 */ +/** Access parameters for sub-register CNT1 in register @ref RG_BBC1_CNT1 */ +#define SR_BBC1_CNT1_CNT1 RG_BBC1_CNT1, CNT1_CNT1_MASK, \ + CNT1_CNT1_SHIFT + +/** Address for register BBC1_CNT2 */ +#define RG_BBC1_CNT2 (0x493) +/** Sub-registers of Register @ref RG_BBC1_CNT2 */ +/** Access parameters for sub-register CNT2 in register @ref RG_BBC1_CNT2 */ +#define SR_BBC1_CNT2_CNT2 RG_BBC1_CNT2, CNT2_CNT2_MASK, \ + CNT2_CNT2_SHIFT + +/** Address for register BBC1_CNT3 */ +#define RG_BBC1_CNT3 (0x494) +/** Sub-registers of Register @ref RG_BBC1_CNT3 */ +/** Access parameters for sub-register CNT3 in register @ref RG_BBC1_CNT3 */ +#define SR_BBC1_CNT3_CNT3 RG_BBC1_CNT3, CNT3_CNT3_MASK, \ + CNT3_CNT3_SHIFT + +/** Enumerations */ + +/** Enumeration for RF commands and states used for trx command and state + * registers */ +typedef enum rf_cmd_state_tag { + /** Constant RF_NOP for sub-register @ref SR_CMD */ + RF_NOP = (0x0), + + /** Constant RF_SLEEP for sub-register @ref SR_CMD */ + RF_SLEEP = (0x1), + + /** Constant RF_TRXOFF for sub-register @ref SR_CMD */ + RF_TRXOFF = (0x2), + + /** Constant RF_TXPREP for sub-register @ref SR_CMD */ + RF_TXPREP = (0x3), + + /** Constant RF_TX for sub-register @ref SR_CMD */ + RF_TX = (0x4), + + /** Constant RF_RX for sub-register @ref SR_CMD */ + RF_RX = (0x5), + + /** Constant RF_RESET for sub-register @ref SR_CMD */ + RF_RESET = (0x7) +} rf_cmd_state_t; + +/** Enumeration for RF commands and states used for trx command and state + * registers */ +typedef enum rf_cmd_status_tag { + /** Constant RF_TRXOFF for sub-register @ref SR_CMD */ + STATUS_RF_TRXOFF = (0x2), + + /** Constant RF_TXPREP for sub-register @ref SR_CMD */ + STATUS_RF_TXPREP = (0x3), + + /** Constant RF_TX for sub-register @ref SR_CMD */ + STATUS_RF_TX = (0x4), + + /** Constant RF_RX for sub-register @ref SR_CMD */ + STATUS_RF_RX = (0x5), + + /** Constant RF_RX for sub-register @ref SR_CMD */ + STATUS_RF_TRANSITION = (0x6), + + /** Constant RF_RESET for sub-register @ref SR_CMD */ + STATUS_RF_RESET = (0x7) +} rf_cmd_status_t; + +/** Enumeration for RF IRQs used for IRQS and IRQM registers */ +typedef enum rf_irq_tag { + /** Constant RF_IRQ_IQIFSF for sub-register @ref SR_IQIFSF */ + RF_IRQ_IQIFSF = (0x20), + + /** Constant RF_IRQ_TRXERR for sub-register @ref SR_TRXERR */ + RF_IRQ_TRXERR = (0x10), + + /** Constant RF_IRQ_BATLOW for sub-register @ref SR_BATLOW */ + RF_IRQ_BATLOW = (0x08), + + /** Constant RF_IRQ_EDC for sub-register @ref SR_EDC */ + RF_IRQ_EDC = (0x04), + + /** Constant RF_IRQ_TRXRDY for sub-register @ref SR_TRXRDY */ + RF_IRQ_TRXRDY = (0x02), + + /** Constant RF_IRQ_WAKEUP for sub-register @ref SR_WAKEUP */ + RF_IRQ_WAKEUP = (0x01), + + /** No interrupt is indicated by IRQ_STATUS register */ + RF_IRQ_NO_IRQ = (0x00), + + /** All interrupts are indicated by IRQ_STATUS register */ + RF_IRQ_ALL_IRQ = (0x3F) +} rf_irq_t; + +/** Enumeration for BB IRQs */ +typedef enum bb_irq_tag { + /** Constant BB_IRQ_FBLI for sub-register @ref SR_FBLI */ + BB_IRQ_FBLI = (0x80), + + /** Constant BB_IRQ_AGCR for sub-register @ref SR_AGCR */ + BB_IRQ_AGCR = (0x40), + + /** Constant BB_IRQ_AGCH for sub-register @ref SR_AGCH */ + BB_IRQ_AGCH = (0x20), + + /** Constant BB_IRQ_TXFE for sub-register @ref SR_TXFE */ + BB_IRQ_TXFE = (0x10), + + /** Constant BB_IRQ_RXEM for sub-register @ref SR_RXEM */ + BB_IRQ_RXEM = (0x08), + + /** Constant BB_IRQ_RXAM for sub-register @ref SR_RXAM */ + BB_IRQ_RXAM = (0x04), + + /** Constant BB_IRQ_RXFE for sub-register @ref SR_RXFE */ + BB_IRQ_RXFE = (0x02), + + /** Constant BB_IRQ_RXFS for sub-register @ref SR_RXFS */ + BB_IRQ_RXFS = (0x01), + + /** No interrupt is indicated by IRQ_STATUS register */ + BB_IRQ_NO_IRQ = (0x00), + + /** All interrupts are indicated by IRQ_STATUS register */ + BB_IRQ_ALL_IRQ = (0xFF) +} bb_irq_t; + +#endif /* RF215_H */ diff --git a/drivers/include/at86rf215.h b/drivers/include/at86rf215.h new file mode 100644 index 0000000000..bba974e43c --- /dev/null +++ b/drivers/include/at86rf215.h @@ -0,0 +1,429 @@ +/* + * Copyright (C) 2019 2019 ML!PA Consulting GmbH + * + * 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. + */ + +/** + * @defgroup drivers_at86rf215 AT86RF215 based drivers + * @ingroup drivers_netdev + * + * This module contains a driver for the Atmel AT86RF215 radio. + * + * @{ + * + * @file + * @brief Interface definition for AT86RF215 based drivers + * + * @author Benjamin Valentin + */ + +#ifndef AT86RF215_H +#define AT86RF215_H + +#include +#include + +#include "board.h" +#include "periph/spi.h" +#include "periph/gpio.h" +#include "net/netdev.h" +#include "net/netdev/ieee802154.h" +#include "net/gnrc/nettype.h" +#include "xtimer.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Registers for the Radio Frontend + */ +typedef struct at86rf215_RF_regs at86rf215_RF_regs_t; + +/** + * @brief Registers for the BaseBand Controller + */ +typedef struct at86rf215_BBC_regs at86rf215_BBC_regs_t; + +/** + * @brief Signature for the Battery monitor callback. + * + * @param[in] arg optional argument which is passed to the + * callback + */ +typedef void (*at86rf215_batmon_cb_t)(void *arg); + +/** + * @brief Maximum possible packet size in byte + */ +#define AT86RF215_MAX_PKT_LENGTH (2047) + +/** + * @brief Set to 1 if the clock output of the AT86RF215 is used + * as a clock source on the board. + * Otherwise it is turned off to save energy. + */ +#ifndef AT86RF215_USE_CLOCK_OUTPUT +#define AT86RF215_USE_CLOCK_OUTPUT (0) +#endif + +/** + * @name Channel configuration + * @{ + */ +#define AT86RF215_DEFAULT_CHANNEL (IEEE802154_DEFAULT_CHANNEL) +#define AT86RF215_DEFAULT_SUBGHZ_CHANNEL (IEEE802154_DEFAULT_SUBGHZ_CHANNEL) +/** @} */ + +/** + * @brief Default TX power (0dBm) + */ +#define AT86RF215_DEFAULT_TXPOWER (IEEE802154_DEFAULT_TXPOWER) + +/** + * @name Flags for device internal states (see datasheet) + * @{ + */ +typedef enum { + AT86RF215_STATE_OFF, /**< radio not configured */ + AT86RF215_STATE_IDLE, /**< idle state, listening */ + AT86RF215_STATE_RX_SEND_ACK,/**< receiving frame, sending ACK */ + AT86RF215_STATE_TX, /**< sending frame */ + AT86RF215_STATE_TX_WAIT_ACK,/**< sending frame, wait for ACK */ + AT86RF215_STATE_SLEEP /**< sleep mode, not listening */ +} at86rf215_state_t; +/** @} */ + +/** + * @name Internal device option flags + * @{ + */ +#define AT86RF215_OPT_TELL_TX_START (0x0001) /**< notify MAC layer on TX start */ +#define AT86RF215_OPT_TELL_TX_END (0x0002) /**< notify MAC layer on TX finished */ +#define AT86RF215_OPT_TELL_RX_START (0x0004) /**< notify MAC layer on RX start */ +#define AT86RF215_OPT_TELL_RX_END (0x0008) /**< notify MAC layer on RX finished */ +#define AT86RF215_OPT_CSMA (0x0010) /**< CSMA active */ +#define AT86RF215_OPT_PROMISCUOUS (0x0020) /**< promiscuous mode active */ +#define AT86RF215_OPT_PRELOADING (0x0040) /**< preloading enabled */ +#define AT86RF215_OPT_AUTOACK (0x0080) /**< Auto ACK active */ +#define AT86RF215_OPT_ACK_REQUESTED (0x0100) /**< ACK requested for current frame */ +#define AT86RF215_OPT_AGCH (0x0200) /**< AGC Hold active */ +#define AT86RF215_OPT_TX_PENDING (0x0400) /**< Frame is loaded into TX buffer */ +#define AT86RF215_OPT_CCA_PENDING (0x0800) /**< CCA needs to be done for the current frame */ +#define AT86RF215_OPT_RPC (0x1000) /**< Enable Reduced Power Consumption */ +#define AT86RF215_OPT_CCATX (0x2000) /**< TX after CCA performd automatically */ +/** @} */ + +/** + * @name Internal timeout flags + * @{ + */ +#define AT86RF215_TIMEOUT_ACK (0x0001) /**< ACK timeout */ +#define AT86RF215_TIMEOUT_CSMA (0x0002) /**< CMSA timeout */ +/** @} */ + +/** + * @brief struct holding all params needed for device initialization + */ +typedef struct at86rf215_params { + spi_t spi; /**< SPI bus the device is connected to */ + spi_clk_t spi_clk; /**< SPI clock speed to use */ + spi_cs_t cs_pin; /**< GPIO pin connected to chip select */ + gpio_t int_pin; /**< GPIO pin connected to the interrupt pin */ + gpio_t reset_pin; /**< GPIO pin connected to the reset pin */ +} at86rf215_params_t; + +/** + * @brief Device descriptor for AT86RF215 radio devices + * + * @extends netdev_ieee802154_t + */ +typedef struct at86rf215 { + netdev_ieee802154_t netdev; /**< netdev parent struct */ + /* device specific fields */ + at86rf215_params_t params; /**< parameters for initialization */ + struct at86rf215 *sibling; /**< The other radio */ + const at86rf215_RF_regs_t *RF; /**< Radio Frontend Registers */ + const at86rf215_BBC_regs_t *BBC; /**< Baseband Registers */ + xtimer_t timer; /**< timer for ACK & CSMA timeout */ + msg_t timer_msg; /**< message for timeout timer */ + uint32_t ack_timeout_usec; /**< time to wait before retransmission in µs */ + uint32_t csma_backoff_period; /**< CSMA Backoff period */ + uint16_t flags; /**< Device specific flags */ + uint16_t num_chans; /**< Number of legal channel at current modulation */ + uint16_t tx_frame_len; /**< length of the current TX frame */ + uint8_t timeout; /**< indicates which timeout was reached */ + uint8_t state; /**< current state of the radio */ + uint8_t retries_max; /**< number of retries until ACK is received */ + uint8_t retries; /**< retries left */ + uint8_t csma_retries_max; /**< number of retries until channel is clear */ + uint8_t csma_retries; /**< CSMA retries left */ + uint8_t csma_minbe; /**< CSMA minimum backoff exponent */ + uint8_t csma_maxbe; /**< CSMA maximum backoff exponent */ + int8_t csma_ed; /**< CSMA energy detect threshold */ +} at86rf215_t; + +/** + * @brief Setup an AT86RF215 based device state + * + * @param[out] dev_09 sub-GHz device descriptor + * @param[out] dev_24 2.4 GHz device descriptor + * @param[in] params parameters for device initialization + */ +void at86rf215_setup(at86rf215_t *dev_09, at86rf215_t *dev_24, const at86rf215_params_t *params); + +/** + * @brief Trigger a hardware reset and configure radio with default values. + * + * @param[in,out] dev device to configure + */ +void at86rf215_reset_and_cfg(at86rf215_t *dev); + +/** + * @brief Trigger a hardware reset, configuration is retained. + * + * @param[in,out] dev device to reset + */ +void at86rf215_reset(at86rf215_t *dev); + +/** + * @brief Get the short address of the given device form multi address filter + * + * @param[in] dev device to read from + * @param[in] filter address filter to read + * + * @return the currently set (2-byte) short address + */ +uint16_t at86rf215_get_addr_short(const at86rf215_t *dev, uint8_t filter); + +/** + * @brief Set the short address of the given device to multi address filter + * + * @param[in,out] dev device to write to + * @param[in] filter (1-byte) address filter to set + * @param[in] addr (2-byte) short address to set + */ +void at86rf215_set_addr_short(at86rf215_t *dev, uint8_t filter, uint16_t addr); + +/** + * @brief Get whether a frame filter is enabled or not + * + * @param[in] dev device to read from + * @param[in] filter (1-byte) filter to get + * + * @return (bool) the current state of the filter + */ +bool at86rf215_get_framefilter_enabled(at86rf215_t *dev, uint8_t filter); + +/** + * @brief Enables a frame filter + * + * @param[in] dev device to read from + * @param[in] filter (1-byte) filter to get + * + */ + void at86rf215_disable_framefilter(at86rf215_t *dev, uint8_t filter); + +/** + * @brief Disables a frame filter + * + * @param[in] dev device to read from + * @param[in] filter (1-byte) filter to get + * + */ +void at86rf215_enable_framefilter(at86rf215_t *dev, uint8_t filter); + +/** + * @brief Get the configured long address of the given device + * + * @param[in] dev device to read from + * + * @return the currently set (8-byte) long address + */ +uint64_t at86rf215_get_addr_long(const at86rf215_t *dev); + +/** + * @brief Set the long address of the given device + * + * @param[in,out] dev device to write to + * @param[in] addr (8-byte) long address to set + */ +void at86rf215_set_addr_long(at86rf215_t *dev, uint64_t addr); + +/** + * @brief Get the configured channel number of the given device + * + * @param[in] dev device to read from + * + * @return the currently set channel number + */ +uint8_t at86rf215_get_chan(const at86rf215_t *dev); + +/** + * @brief Set the channel number of the given device + * + * @param[in,out] dev device to write to + * @param[in] chan channel number to set + */ +void at86rf215_set_chan(at86rf215_t *dev, uint16_t chan); + +/** + * @brief Get the configured PAN ID of the given device from multi address filter + * + * @param[in] dev device to read from + * @param[in] filter address filter to read from + * + * @return the currently set PAN ID + */ +uint16_t at86rf215_get_pan(const at86rf215_t *dev, uint8_t filter); + +/** + * @brief Set the PAN ID of the given address filter + * + * @param[in,out] dev device to write to + * @param[in] filter address filter to set + * @param[in] pan PAN ID to set + */ +void at86rf215_set_pan(at86rf215_t *dev, uint8_t filter, uint16_t pan); + +/** + * @brief Get the configured transmission power of the given device [in dBm] + * + * @param[in] dev device to read from + * + * @return configured transmission power in dBm + */ +int16_t at86rf215_get_txpower(const at86rf215_t *dev); + +/** + * @brief Set the transmission power of the given device [in dBm] + * + * If the device does not support the exact dBm value given, it will set a value + * as close as possible to the given value. If the given value is larger or + * lower then the maximal or minimal possible value, the min or max value is + * set, respectively. + * + * @param[in] dev device to write to + * @param[in] txpower transmission power in dBm + */ +void at86rf215_set_txpower(const at86rf215_t *dev, int16_t txpower); + +/** + * @brief Get the CCA threshold value + * + * @param[in] dev device to read value from + * + * @return the current CCA threshold value + */ +int8_t at86rf215_get_cca_threshold(const at86rf215_t *dev); + +/** + * @brief Set the CCA threshold value + * + * @param[in] dev device to write to + * @param[in] value the new CCA threshold value + */ +void at86rf215_set_cca_threshold(at86rf215_t *dev, int8_t value); + +/** + * @brief Get the latest ED level measurement + * + * @param[in] dev device to read value from + * + * @return the last ED level + */ +int8_t at86rf215_get_ed_level(at86rf215_t *dev); + +/** + * @brief Enable or disable driver specific options + * + * @param[in,out] dev device to set/clear option flag for + * @param[in] option option to enable/disable + * @param[in] state true for enable, false for disable + */ +void at86rf215_set_option(at86rf215_t *dev, uint16_t option, bool state); + +/** + * @brief Convenience function for simply sending data + * + * @note This function ignores the PRELOADING option + * + * @param[in,out] dev device to use for sending + * @param[in] data data to send (must include IEEE802.15.4 header) + * @param[in] len length of @p data + * + * @return number of bytes that were actually send + * @return or negative error code + */ +ssize_t at86rf215_send(at86rf215_t *dev, const void *data, size_t len); + +/** + * @brief Prepare for sending of data + * + * This function puts the given device into the TX state, so no receiving of + * data is possible after it was called. + * + * @param[in,out] dev device to prepare for sending + * + * @return 0 on success, error otherwise + */ +int at86rf215_tx_prepare(at86rf215_t *dev); + +/** + * @brief Load chunks of data into the transmit buffer of the given device + * + * @param[in,out] dev device to write data to + * @param[in] data buffer containing the data to load + * @param[in] len number of bytes in @p buffer + * @param[in] offset offset used when writing data to internal buffer + * + * @return offset + number of bytes written + */ +size_t at86rf215_tx_load(at86rf215_t *dev, const uint8_t *data, + size_t len, size_t offset); + +/** + * @brief Trigger sending of data previously loaded into transmit buffer + * + * @param[in] dev device to trigger + * + * @return 0 on success, error otherwise + */ +int at86rf215_tx_exec(at86rf215_t *dev); + +/** + * @brief Abort sending of data previously loaded into transmit buffer + * + * @param[in] dev device to abort TX on + */ +void at86rf215_tx_abort(at86rf215_t *dev); + +/** + * @brief Signal that the transfer of the frame (and optional ACK reception) + * has finished. Sets the radio in RX mode. + * + * @param[in] dev device to use + */ +void at86rf215_tx_done(at86rf215_t *dev); + +/** + * @brief Perform one manual channel clear assessment (CCA) + * + * The CCA mode and threshold level depends on the current transceiver settings. + * + * @param[in] dev device to use + * + * @return true if channel is determined clear + * @return false if channel is determined busy + */ +bool at86rf215_cca(at86rf215_t *dev); + +#ifdef __cplusplus +} +#endif + +#endif /* AT86RF215_H */ +/** @} */ diff --git a/makefiles/pseudomodules.inc.mk b/makefiles/pseudomodules.inc.mk index 2964ac030a..8579ec42c8 100644 --- a/makefiles/pseudomodules.inc.mk +++ b/makefiles/pseudomodules.inc.mk @@ -115,6 +115,7 @@ PSEUDOMODULES += at86rf23% PSEUDOMODULES += at86rf21% PSEUDOMODULES += at86rfa1 PSEUDOMODULES += at86rfr2 +NO_PSEUDOMODULES += at86rf215 # include variants of the BMX280 drivers as pseudo modules PSEUDOMODULES += bmp280_i2c diff --git a/sys/net/gnrc/netif/init_devs/auto_init_at86rf215.c b/sys/net/gnrc/netif/init_devs/auto_init_at86rf215.c new file mode 100644 index 0000000000..17b733b517 --- /dev/null +++ b/sys/net/gnrc/netif/init_devs/auto_init_at86rf215.c @@ -0,0 +1,122 @@ +/* + * Copyright (C) 2019 ML!PA Consulting GmbH + * + * 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 sys_auto_init_gnrc_netif + * @{ + * + * @file + * @brief Auto initialization for at86rf215 network interfaces + * + * @author Benjamin Valentin + */ + +#ifdef MODULE_AT86RF215 + +#define USED_BANDS (IS_USED(MODULE_AT86RF215_SUBGHZ) + IS_USED(MODULE_AT86RF215_24GHZ)) + +#include "log.h" +#include "board.h" +#include "net/gnrc/netif/ieee802154.h" +#ifdef MODULE_GNRC_LWMAC +#include "net/gnrc/lwmac/lwmac.h" +#endif +#ifdef MODULE_GNRC_GOMACH +#include "net/gnrc/gomach/gomach.h" +#endif +#include "net/gnrc.h" + +#include "at86rf215.h" +#include "at86rf215_params.h" + +/* If we don't have enough NETIFs configured, disable the sub-GHz band */ +#if (GNRC_NETIF_NUMOF == 1) && IS_USED(MODULE_AT86RF215_SUBGHZ) && IS_USED(MODULE_AT86RF215_24GHZ) +#undef MODULE_AT86RF215_SUBGHZ +#undef USED_BANDS +#define USED_BANDS 1 +#endif + +/** + * @brief Define stack parameters for the MAC layer thread + * @{ + */ +#define AT86RF215_MAC_STACKSIZE (THREAD_STACKSIZE_DEFAULT) +#ifndef AT86RF215_MAC_PRIO +#define AT86RF215_MAC_PRIO (GNRC_NETIF_PRIO) +#endif +#ifndef AT86RF215_MAC_PRIO_SUBGHZ +#define AT86RF215_MAC_PRIO_SUBGHZ (AT86RF215_MAC_PRIO) +#endif + +#define AT86RF215_NUM ARRAY_SIZE(at86rf215_params) + +static at86rf215_t at86rf215_devs[AT86RF215_NUM * USED_BANDS]; +static char _at86rf215_stacks[AT86RF215_NUM * USED_BANDS][AT86RF215_MAC_STACKSIZE]; + +static inline void _setup_netif(void* netdev, void* stack, int prio) { + if (netdev == NULL) { + return; + } + +#if defined(MODULE_GNRC_GOMACH) + gnrc_netif_gomach_create(stack, + AT86RF215_MAC_STACKSIZE, + prio, "at86rf215-gomach", + netdev); +#elif defined(MODULE_GNRC_LWMAC) + gnrc_netif_lwmac_create(stack, + AT86RF215_MAC_STACKSIZE, + prio, "at86rf215-lwmac", + netdev); +#else + gnrc_netif_ieee802154_create(stack, + AT86RF215_MAC_STACKSIZE, + prio, "at86rf215", + netdev); +#endif +} + +void auto_init_at86rf215(void) +{ + unsigned i = 0; + unsigned j = 0; + while (j < AT86RF215_NUM) { + + at86rf215_t *dev_09 = NULL; + at86rf215_t *dev_24 = NULL; + void *stack_09 = NULL; + void *stack_24 = NULL; + + if (IS_USED(MODULE_AT86RF215_SUBGHZ)) { + dev_09 = &at86rf215_devs[i]; + stack_09 = &_at86rf215_stacks[i]; + ++i; + } + + if (IS_USED(MODULE_AT86RF215_24GHZ)) { + dev_24 = &at86rf215_devs[i]; + stack_24 = &_at86rf215_stacks[i]; + ++i; + } + + at86rf215_setup(dev_09, dev_24, &at86rf215_params[j++]); + + /* setup sub-GHz interface */ + _setup_netif(dev_09, stack_09, AT86RF215_MAC_PRIO_SUBGHZ); + + /* setup 2.4-GHz interface */ + _setup_netif(dev_24, stack_24, AT86RF215_MAC_PRIO); + } +} + +#else +typedef int dont_be_pedantic; +#endif /* MODULE_AT86RF215 */ + +/** @} */ diff --git a/sys/net/gnrc/netif/init_devs/init.c b/sys/net/gnrc/netif/init_devs/init.c index 7ca10c5697..1762ce1308 100644 --- a/sys/net/gnrc/netif/init_devs/init.c +++ b/sys/net/gnrc/netif/init_devs/init.c @@ -32,6 +32,11 @@ void gnrc_netif_init_devs(void) auto_init_stm32_eth(); } + if (IS_USED(MODULE_AUTO_INIT_AT86RF215)) { + extern void auto_init_at86rf215(void); + auto_init_at86rf215(); + } + if (IS_USED(MODULE_AUTO_INIT_AT86RF2XX)) { extern void auto_init_at86rf2xx(void); auto_init_at86rf2xx(); From 8ac5bdc6c1598dbe0989eeead21fcd42dd2de77d Mon Sep 17 00:00:00 2001 From: Benjamin Valentin Date: Wed, 18 Mar 2020 00:52:14 +0100 Subject: [PATCH 2/3] tests: added test app for the at86rf215 driver --- tests/driver_at86rf215/Makefile | 28 +++++++++++++++++++++ tests/driver_at86rf215/Makefile.ci | 18 ++++++++++++++ tests/driver_at86rf215/main.c | 39 ++++++++++++++++++++++++++++++ 3 files changed, 85 insertions(+) create mode 100644 tests/driver_at86rf215/Makefile create mode 100644 tests/driver_at86rf215/Makefile.ci create mode 100644 tests/driver_at86rf215/main.c diff --git a/tests/driver_at86rf215/Makefile b/tests/driver_at86rf215/Makefile new file mode 100644 index 0000000000..9fd605967f --- /dev/null +++ b/tests/driver_at86rf215/Makefile @@ -0,0 +1,28 @@ +BOARD ?= openmote-b +include ../Makefile.tests_common + +# Modules to include: +USEMODULE += shell +USEMODULE += shell_commands +USEMODULE += ps + +# the radio driver to test +USEMODULE += at86rf215 +GNRC_NETIF_NUMOF ?= 2 + +# gnrc is a meta module including all required, basic gnrc networking modules +USEMODULE += gnrc + +# automatically initialize the network interface +USEMODULE += auto_init_gnrc_netif + +# shell command to send L2 packets with a simple string +USEMODULE += gnrc_txtsnd + +# the application dumps received packets to stdout +USEMODULE += gnrc_pktdump + +include $(RIOTBASE)/Makefile.include + +# Set a custom channel if needed +include $(RIOTMAKE)/default-radio-settings.inc.mk diff --git a/tests/driver_at86rf215/Makefile.ci b/tests/driver_at86rf215/Makefile.ci new file mode 100644 index 0000000000..a8c5610bdd --- /dev/null +++ b/tests/driver_at86rf215/Makefile.ci @@ -0,0 +1,18 @@ +BOARD_INSUFFICIENT_MEMORY := \ + arduino-duemilanove \ + arduino-leonardo \ + arduino-mega2560 \ + arduino-uno \ + atmega328p \ + i-nucleo-lrwan1 \ + nucleo-f031k6 \ + nucleo-f042k6 \ + nucleo-f303k8 \ + nucleo-f334r8 \ + nucleo-l031k6 \ + nucleo-l053r8 \ + stm32f030f4-demo \ + stm32f0discovery \ + stm32l0538-disco \ + waspmote-pro \ + # diff --git a/tests/driver_at86rf215/main.c b/tests/driver_at86rf215/main.c new file mode 100644 index 0000000000..66cc2bd986 --- /dev/null +++ b/tests/driver_at86rf215/main.c @@ -0,0 +1,39 @@ +/* + * Copyright (C) 2020 ML!PA Consulting GmbH + * + * 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 tests + * @{ + * + * @file + * @brief Test application for network device drivers + * + * @author Benjamin Valentin + * @} + */ + +#include "thread.h" +#include "shell.h" +#include "shell_commands.h" + +#include "net/gnrc/pktdump.h" +#include "net/gnrc.h" + +int main(void) +{ + /* enable pktdump output */ + gnrc_netreg_entry_t dump = GNRC_NETREG_ENTRY_INIT_PID(GNRC_NETREG_DEMUX_CTX_ALL, + gnrc_pktdump_pid); + gnrc_netreg_register(GNRC_NETTYPE_UNDEF, &dump); + + /* start the shell */ + char line_buf[SHELL_DEFAULT_BUFSIZE]; + shell_run(NULL, line_buf, SHELL_DEFAULT_BUFSIZE); + + return 0; +} From f905108d8e2bfef5d0a5c6afdfdaf3f806e1e113 Mon Sep 17 00:00:00 2001 From: Benjamin Valentin Date: Wed, 28 Aug 2019 22:10:23 +0200 Subject: [PATCH 3/3] boards/openmote-b: hook up at86rf215 Openmote-B includes an AT86RF215 radio. This adds support for it. --- boards/openmote-b/Makefile.dep | 10 +++++++++- boards/openmote-b/board.c | 10 ++++++++-- boards/openmote-b/include/board.h | 10 ++++++++++ 3 files changed, 27 insertions(+), 3 deletions(-) diff --git a/boards/openmote-b/Makefile.dep b/boards/openmote-b/Makefile.dep index df94179725..b96e814846 100644 --- a/boards/openmote-b/Makefile.dep +++ b/boards/openmote-b/Makefile.dep @@ -1,5 +1,13 @@ ifneq (,$(filter gnrc_netdev_default netdev_default,$(USEMODULE))) - USEMODULE += cc2538_rf + ifeq (,$(filter cc2538_rf,$(USEMODULE))) + USEMODULE += at86rf215 + endif +endif + +# at86rf215 is hard-wired to sub-GHz, but 2.4 GHz can be switched between +# at86rf215 and cc2538_rf. Use 2.4 GHz for cc2538_rf if both are used. +ifeq (at86rf215 cc2538_rf, $(filter at86rf215 cc2538_rf,$(USEMODULE))) + DISABLE_MODULE += at86rf215_24ghz endif ifneq (,$(filter saul_default,$(USEMODULE))) diff --git a/boards/openmote-b/board.c b/boards/openmote-b/board.c index ceaaecec02..da825bba54 100644 --- a/boards/openmote-b/board.c +++ b/boards/openmote-b/board.c @@ -36,9 +36,15 @@ void board_init(void) gpio_init(RF24_SWITCH_CC2538_PIN, GPIO_OUT); gpio_init(RF24_SWITCH_AT86RF215_PIN, GPIO_OUT); - /* start with cc2538 2.4ghz radio*/ - RF24_SWITCH_CC2538_ON; +#ifdef MODULE_CC2538_RF + /* use cc2538 2.4ghz radio*/ RF24_SWITCH_AT86RF215_OFF; + RF24_SWITCH_CC2538_ON; +#else + /* use at86rf215 2.4ghz radio*/ + RF24_SWITCH_CC2538_OFF; + RF24_SWITCH_AT86RF215_ON; +#endif /* initialize the CPU */ cpu_init(); diff --git a/boards/openmote-b/include/board.h b/boards/openmote-b/include/board.h index 0e49505b90..e2ecedd77f 100644 --- a/boards/openmote-b/include/board.h +++ b/boards/openmote-b/include/board.h @@ -76,6 +76,16 @@ #define RF24_SWITCH_AT86RF215_TOGGLE (RF_SWITCH_PORT->DATA ^= RF24_SWITCH_AT86RF215_MASK) /** @} */ +/** + * @name AT86RF215 configuration + * @{ + */ +#define AT86RF215_PARAM_SPI SPI_DEV(0) +#define AT86RF215_PARAM_CS GPIO_PIN(0, 3) /* A3 */ +#define AT86RF215_PARAM_INT GPIO_PIN(3, 0) /* D0 */ +#define AT86RF215_PARAM_RESET GPIO_PIN(3, 1) /* D1 */ +/** @} */ + /** * @name xtimer configuration * @{