mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
a301c37c2e
Make the unions anonymous, since this makes referencing their bytes much simpler.
283 lines
15 KiB
C
283 lines
15 KiB
C
/*
|
|
* Copyright (C) 2014 Loci Controls Inc.
|
|
*
|
|
* 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 cpu_cc2538_rfcore CC2538 RF core interface
|
|
* @ingroup cpu_cc2538_regs
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief CC2538 RF core interface
|
|
*
|
|
* @author Ian Martin <ian@locicontrols.com>
|
|
*
|
|
*/
|
|
|
|
#ifndef CC2538_RFCORE_H
|
|
#define CC2538_RFCORE_H
|
|
|
|
#include "cc2538.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief RF Core component registers
|
|
*/
|
|
typedef struct {
|
|
cc2538_reg_t FFSM_SRCRESMASK0; /**< RF Source address matching result */
|
|
cc2538_reg_t FFSM_SRCRESMASK1; /**< RF Source address matching result */
|
|
cc2538_reg_t FFSM_SRCRESMASK2; /**< RF Source address matching result */
|
|
cc2538_reg_t FFSM_SRCRESINDEX; /**< RF Source address matching result */
|
|
cc2538_reg_t FFSM_SRCEXTPENDEN0; /**< RF Source address matching control */
|
|
cc2538_reg_t FFSM_SRCEXTPENDEN1; /**< RF Source address matching control */
|
|
cc2538_reg_t FFSM_SRCEXTPENDEN2; /**< RF Source address matching control */
|
|
cc2538_reg_t FFSM_SRCSHORTPENDEN0; /**< RF Source address matching control */
|
|
cc2538_reg_t FFSM_SRCSHORTPENDEN1; /**< RF Source address matching control */
|
|
cc2538_reg_t FFSM_SRCSHORTPENDEN2; /**< RF Source address matching control */
|
|
cc2538_reg_t FFSM_EXT_ADDR0; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_EXT_ADDR1; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_EXT_ADDR2; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_EXT_ADDR3; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_EXT_ADDR4; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_EXT_ADDR5; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_EXT_ADDR6; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_EXT_ADDR7; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_PAN_ID0; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_PAN_ID1; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_SHORT_ADDR0; /**< RF Local address information */
|
|
cc2538_reg_t FFSM_SHORT_ADDR1; /**< RF Local address information */
|
|
cc2538_reg_t RESERVED1[10]; /**< Reserved bytes */
|
|
|
|
union {
|
|
cc2538_reg_t XREG_FRMFILT0; /**< RF Frame Filter 0 */
|
|
struct {
|
|
cc2538_reg_t FRAME_FILTER_EN : 1;
|
|
cc2538_reg_t PAN_COORDINATOR : 1;
|
|
cc2538_reg_t MAX_FRAME_VERSION: 2;
|
|
cc2538_reg_t RESERVED : 28;
|
|
} XREG_FRMFILT0bits;
|
|
};
|
|
|
|
cc2538_reg_t XREG_FRMFILT1; /**< RF Frame Filter 1 */
|
|
cc2538_reg_t XREG_SRCMATCH; /**< RF Source address matching and pending bits */
|
|
cc2538_reg_t XREG_SRCSHORTEN0; /**< RF Short address matching */
|
|
cc2538_reg_t XREG_SRCSHORTEN1; /**< RF Short address matching */
|
|
cc2538_reg_t XREG_SRCSHORTEN2; /**< RF Short address matching */
|
|
cc2538_reg_t XREG_SRCEXTEN0; /**< RF Extended address matching */
|
|
cc2538_reg_t XREG_SRCEXTEN1; /**< RF Extended address matching */
|
|
cc2538_reg_t XREG_SRCEXTEN2; /**< RF Extended address matching */
|
|
|
|
union {
|
|
cc2538_reg_t XREG_FRMCTRL0; /**< RF Frame handling */
|
|
struct {
|
|
cc2538_reg_t TX_MODE : 2;
|
|
cc2538_reg_t RX_MODE : 2;
|
|
cc2538_reg_t ENERGY_SCAN : 1;
|
|
cc2538_reg_t AUTOACK : 1;
|
|
cc2538_reg_t AUTOCRC : 1;
|
|
cc2538_reg_t APPEND_DATA_MODE : 1;
|
|
cc2538_reg_t RESERVED : 24;
|
|
} XREG_FRMCTRL0bits;
|
|
};
|
|
|
|
cc2538_reg_t XREG_FRMCTRL1; /**< RF Frame handling */
|
|
cc2538_reg_t XREG_RXENABLE; /**< RF RX enabling */
|
|
cc2538_reg_t XREG_RXMASKSET; /**< RF RX enabling */
|
|
cc2538_reg_t XREG_RXMASKCLR; /**< RF RX disabling */
|
|
cc2538_reg_t XREG_FREQTUNE; /**< RF Crystal oscillator frequency tuning */
|
|
cc2538_reg_t XREG_FREQCTRL; /**< RF Controls the RF frequency */
|
|
cc2538_reg_t XREG_TXPOWER; /**< RF Controls the output power */
|
|
cc2538_reg_t XREG_TXCTRL; /**< RF Controls the TX settings */
|
|
|
|
union {
|
|
cc2538_reg_t XREG_FSMSTAT0; /**< RF Radio status register */
|
|
struct {
|
|
cc2538_reg_t FSM_FFCTRL_STATE : 6;
|
|
cc2538_reg_t CAL_RUNNING : 1;
|
|
cc2538_reg_t CAL_DONE : 1;
|
|
cc2538_reg_t RESERVED : 24;
|
|
} XREG_FSMSTAT0bits;
|
|
};
|
|
|
|
union {
|
|
cc2538_reg_t XREG_FSMSTAT1; /**< RF Radio status register */
|
|
struct {
|
|
cc2538_reg_t RX_ACTIVE : 1;
|
|
cc2538_reg_t TX_ACTIVE : 1;
|
|
cc2538_reg_t LOCK_STATUS : 1;
|
|
cc2538_reg_t SAMPLED_CCA : 1;
|
|
cc2538_reg_t CCA : 1;
|
|
cc2538_reg_t SFD : 1;
|
|
cc2538_reg_t FIFOP : 1;
|
|
cc2538_reg_t FIFO : 1;
|
|
cc2538_reg_t RESERVED : 24;
|
|
} XREG_FSMSTAT1bits;
|
|
};
|
|
|
|
cc2538_reg_t XREG_FIFOPCTRL; /**< RF FIFOP threshold */
|
|
cc2538_reg_t XREG_FSMCTRL; /**< RF FSM options */
|
|
cc2538_reg_t XREG_CCACTRL0; /**< RF CCA threshold */
|
|
cc2538_reg_t XREG_CCACTRL1; /**< RF Other CCA Options */
|
|
cc2538_reg_t XREG_RSSI; /**< RF RSSI status register */
|
|
|
|
/**
|
|
* @brief RSSI status register
|
|
*/
|
|
union {
|
|
cc2538_reg_t XREG_RSSISTAT; /**< RF RSSI valid status register */
|
|
struct {
|
|
cc2538_reg_t RSSI_VALID : 1; /**< RSSI value is valid */
|
|
cc2538_reg_t RESERVED : 31; /**< Reserved bits */
|
|
} XREG_RSSISTATbits;
|
|
};
|
|
|
|
cc2538_reg_t XREG_RXFIRST; /**< RF First byte in RX FIFO */
|
|
cc2538_reg_t XREG_RXFIFOCNT; /**< RF Number of bytes in RX FIFO */
|
|
cc2538_reg_t XREG_TXFIFOCNT; /**< RF Number of bytes in TX FIFO */
|
|
cc2538_reg_t XREG_RXFIRST_PTR; /**< RF RX FIFO pointer */
|
|
cc2538_reg_t XREG_RXLAST_PTR; /**< RF RX FIFO pointer */
|
|
cc2538_reg_t XREG_RXP1_PTR; /**< RF RX FIFO pointer */
|
|
cc2538_reg_t RESERVED2; /**< Reserved bytes */
|
|
cc2538_reg_t XREG_TXFIRST_PTR; /**< RF TX FIFO pointer */
|
|
cc2538_reg_t XREG_TXLAST_PTR; /**< RF TX FIFO pointer */
|
|
cc2538_reg_t XREG_RFIRQM0; /**< RF interrupt masks */
|
|
cc2538_reg_t XREG_RFIRQM1; /**< RF interrupt masks */
|
|
cc2538_reg_t XREG_RFERRM; /**< RF error interrupt mask */
|
|
cc2538_reg_t RESERVED3; /**< Reserved bytes */
|
|
|
|
/**
|
|
* @brief RF random data register
|
|
*/
|
|
union {
|
|
cc2538_reg_t XREG_RFRND; /**< RF Random data */
|
|
struct {
|
|
cc2538_reg_t IRND : 1; /**< Random bit from the I channel of the receiver */
|
|
cc2538_reg_t QRND : 1; /**< Random bit from the Q channel of the receiver */
|
|
cc2538_reg_t RESERVED : 30; /**< Reserved bits */
|
|
} XREG_RFRNDbits;
|
|
};
|
|
|
|
cc2538_reg_t XREG_MDMCTRL0; /**< RF Controls modem */
|
|
cc2538_reg_t XREG_MDMCTRL1; /**< RF Controls modem */
|
|
cc2538_reg_t XREG_FREQEST; /**< RF Estimated RF frequency offset */
|
|
cc2538_reg_t XREG_RXCTRL; /**< RF Tune receive section */
|
|
cc2538_reg_t XREG_FSCTRL; /**< RF Tune frequency synthesizer */
|
|
cc2538_reg_t XREG_FSCAL0; /**< RF Tune frequency calibration */
|
|
cc2538_reg_t XREG_FSCAL1; /**< RF Tune frequency calibration */
|
|
cc2538_reg_t XREG_FSCAL2; /**< RF Tune frequency calibration */
|
|
cc2538_reg_t XREG_FSCAL3; /**< RF Tune frequency calibration */
|
|
cc2538_reg_t XREG_AGCCTRL0; /**< RF AGC dynamic range control */
|
|
cc2538_reg_t XREG_AGCCTRL1; /**< RF AGC reference level */
|
|
cc2538_reg_t XREG_AGCCTRL2; /**< RF AGC gain override */
|
|
cc2538_reg_t XREG_AGCCTRL3; /**< RF AGC control */
|
|
cc2538_reg_t XREG_ADCTEST0; /**< RF ADC tuning */
|
|
cc2538_reg_t XREG_ADCTEST1; /**< RF ADC tuning */
|
|
cc2538_reg_t XREG_ADCTEST2; /**< RF ADC tuning */
|
|
cc2538_reg_t XREG_MDMTEST0; /**< RF Test register for modem */
|
|
cc2538_reg_t XREG_MDMTEST1; /**< RF Test Register for Modem */
|
|
cc2538_reg_t XREG_DACTEST0; /**< RF DAC override value */
|
|
cc2538_reg_t XREG_DACTEST1; /**< RF DAC override value */
|
|
cc2538_reg_t XREG_DACTEST2; /**< RF DAC test setting */
|
|
cc2538_reg_t XREG_ATEST; /**< RF Analog test control */
|
|
cc2538_reg_t XREG_PTEST0; /**< RF Override power-down register */
|
|
cc2538_reg_t XREG_PTEST1; /**< RF Override power-down register */
|
|
cc2538_reg_t RESERVED4[32]; /**< Reserved bytes */
|
|
cc2538_reg_t XREG_CSPCTRL; /**< RF CSP control bit */
|
|
cc2538_reg_t XREG_CSPSTAT; /**< RF CSP status register */
|
|
cc2538_reg_t XREG_CSPX; /**< RF CSP X data register */
|
|
cc2538_reg_t XREG_CSPY; /**< RF CSP Y data register */
|
|
cc2538_reg_t XREG_CSPZ; /**< RF CSP Z data register */
|
|
cc2538_reg_t XREG_CSPT; /**< RF CSP T data register */
|
|
cc2538_reg_t RESERVED5[5]; /**< Reserved bytes */
|
|
cc2538_reg_t XREG_RFC_OBS_CTRL0; /**< RF observation mux control */
|
|
cc2538_reg_t XREG_RFC_OBS_CTRL1; /**< RF observation mux control */
|
|
cc2538_reg_t XREG_RFC_OBS_CTRL2; /**< RF observation mux control */
|
|
cc2538_reg_t RESERVED6[12]; /**< Reserved bytes */
|
|
cc2538_reg_t XREG_TXFILTCFG; /**< RF TX filter configuration */
|
|
cc2538_reg_t RESERVED7[5]; /**< Reserved bytes */
|
|
cc2538_reg_t SFR_MTCSPCFG; /**< RF MAC Timer event configuration */
|
|
cc2538_reg_t SFR_MTCTRL; /**< RF MAC Timer control register */
|
|
cc2538_reg_t SFR_MTIRQM; /**< RF MAC Timer interrupt mask */
|
|
cc2538_reg_t SFR_MTIRQF; /**< RF MAC Timer interrupt flags */
|
|
cc2538_reg_t SFR_MTMSEL; /**< RF MAC Timer multiplex select */
|
|
cc2538_reg_t SFR_MTM0; /**< RF MAC Timer multiplexed register 0 */
|
|
cc2538_reg_t SFR_MTM1; /**< RF MAC Timer multiplexed register 1 */
|
|
cc2538_reg_t SFR_MTMOVF2; /**< RF MAC Timer multiplexed overflow register 2 */
|
|
cc2538_reg_t SFR_MTMOVF1; /**< RF MAC Timer multiplexed overflow register 1 */
|
|
cc2538_reg_t SFR_MTMOVF0; /**< RF MAC Timer multiplexed overflow register 0 */
|
|
cc2538_reg_t SFR_RFDATA; /**< RF Tx/Rx FIFO */
|
|
cc2538_reg_t SFR_RFERRF; /**< RF error interrupt flags */
|
|
cc2538_reg_t SFR_RFIRQF1; /**< RF interrupt flags */
|
|
cc2538_reg_t SFR_RFIRQF0; /**< RF interrupt flags */
|
|
cc2538_reg_t SFR_RFST; /**< RF CSMA-CA/strobe processor */
|
|
} cc2538_rfcore_t;
|
|
|
|
#define RFCORE ( (cc2538_rfcore_t*)0x40088580 ) /**< RF Core instance */
|
|
|
|
/** @brief RF Core opcodes */
|
|
enum {
|
|
DECZ = 0xc5, /**< Decrement Z */
|
|
DECY = 0xc4, /**< Decrement Y */
|
|
DECX = 0xc3, /**< Decrement X */
|
|
INCZ = 0xc2, /**< Increment Z */
|
|
INCY = 0xc1, /**< Increment Y */
|
|
INCX = 0xc0, /**< Increment X */
|
|
INCMAXY = 0xc8, /**< Increment Y not greater than M. | M (M = 0-7) */
|
|
RANDXY = 0xbd, /**< Load random value into X. */
|
|
INT = 0xba, /**< Interrupt */
|
|
WAITX = 0xbc, /**< Wait for X MAC timer overflows */
|
|
SETCMP1 = 0xbe, /**< Set the compare value of the MAC timer to the current timer value. */
|
|
WAIT_W = 0x80, /**< Wait for W MAC timer overflows | W (W = 0-31) */
|
|
WEVENT1 = 0xb8, /**< Wait until MAC timer event 1 */
|
|
WEVENT2 = 0xb9, /**< Wait until MAC timer event 2 */
|
|
LABEL = 0xbb, /**< Set loop label */
|
|
RPT_C = 0xa0, /**< Conditional repeat | N | C (N = 0, 8; C = 0-7) */
|
|
SKIP_S_C = 0x00, /**< Conditional skip instruction | S | N | C */
|
|
STOP = 0xd2, /**< Stop program execution */
|
|
SNOP = 0xd0, /**< No operation */
|
|
SRXON = 0xd3, /**< Enable and calibrate frequency synthesizer for RX */
|
|
STXON = 0xd9, /**< Enable TX after calibration */
|
|
STXONCCA = 0xda, /**< Enable calibration and TX if CCA indicates a clear channel */
|
|
SSAMPLECCA = 0xdb, /**< Sample the current CCA value to SAMPLED_CCA */
|
|
SRFOFF = 0xdf, /**< Disable RX or TX and frequency synthesizer. */
|
|
SFLUSHRX = 0xdd, /**< Flush RX FIFO buffer and reset demodulator */
|
|
SFLUSHTX = 0xde, /**< Flush TX FIFO buffer */
|
|
SACK = 0xd6, /**< Send acknowledge frame with pending field cleared */
|
|
SACKPEND = 0xd7, /**< Send acknowledge frame with the pending field set */
|
|
SNACK = 0xd8, /**< Abort sending of acknowledge frame */
|
|
SRXMASKBITSET = 0xd4, /**< Set bit in RXENABLE register */
|
|
SRXMASKBITCLR = 0xd5, /**< Clear bit in RXENABLE register */
|
|
ISSTOP = 0xe2, /**< Stop program execution */
|
|
ISSTART = 0xe1, /**< Start program execution */
|
|
ISRXON = 0xe3, /**< Enable and calibrate frequency synthesizer for RX */
|
|
ISRXMASKBITSET = 0xe4, /**< Set bit in RXENABLE */
|
|
ISRXMASKBITCLR = 0xe5, /**< Clear bit in RXENABLE */
|
|
ISTXON = 0xe9, /**< Enable TX after calibration */
|
|
ISTXONCCA = 0xea, /**< Enable calibration and TX if CCA indicates a clear channel */
|
|
ISSAMPLECCA = 0xeb, /**< Sample the current CCA value to SAMPLED_CCA */
|
|
ISRFOFF = 0xef, /**< Disable RX or TX, and the frequency synthesizer. */
|
|
ISFLUSHRX = 0xed, /**< Flush RX FIFO buffer and reset demodulator */
|
|
ISFLUSHTX = 0xee, /**< Flush TX FIFO buffer */
|
|
ISACK = 0xe6, /**< Send acknowledge frame with the pending field cleared */
|
|
ISACKPEND = 0xe7, /**< Send acknowledge frame with the pending field set */
|
|
ISNACK = 0xe8, /**< Abort sending of acknowledge frame */
|
|
ISCLEAR = 0xff, /**< Clear CSP program memory, reset program counter */
|
|
};
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
|
|
#endif /* CC2538_RFCORE_H */
|
|
|
|
/** @} */
|
|
/** @} */
|
|
/** @} */
|