mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-16 17:12:45 +01:00
30c79a66d0
Replaced magic undocumented numbers in the code by human readable preprocessor macros.
253 lines
12 KiB
C
253 lines
12 KiB
C
/*
|
|
* Copyright (C) 2008 Freie Universität Berlin
|
|
* Copyright (C) 2013 INRIA
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
* directory for more details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup drivers_cc110x
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Driver internal constants for CC110x chip configuration
|
|
*
|
|
* @author Thomas Hillebrandt <hillebra@inf.fu-berlin.de>
|
|
* @author Heiko Will <hwill@inf.fu-berlin.de>
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
|
*/
|
|
|
|
#ifndef CC110X_DEFINES_H
|
|
#define CC110X_DEFINES_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief Variable packet length PKTCTRL0 bit configuration
|
|
*
|
|
* If variable packet length is configured in PKTCTRL0 the
|
|
* first byte after the synch word determines the packet length.
|
|
*/
|
|
#define VARIABLE_PKTLEN (0x01)
|
|
|
|
/**
|
|
* @brief RSSI calculation offset.
|
|
*
|
|
* The cc1101 has 74 as a RSSI offset. The CC1100E has a
|
|
* slightly larger offset of 75 to 79 (not implemented here).
|
|
* With those devices we thus get a slightly optimistic result.
|
|
*/
|
|
#define CC110X_RSSI_OFFSET (74)
|
|
|
|
/**
|
|
* @name Bitmasks for reading out status register values
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @brief Bitmask (=10000000) for reading CRC_OK.
|
|
*
|
|
* If CRC_OK == 1: CRC for received data OK (or CRC disabled).
|
|
* If CRC_OK == 0: CRC error in received data.
|
|
*/
|
|
#define CRC_OK (0x80)
|
|
/**
|
|
* @brief Bitmask (=01111111) for reading LQI_EST.
|
|
*
|
|
* The Link Quality Indicator estimates how easily a received signal can be demodulated.
|
|
*/
|
|
#define LQI_EST (0x7F)
|
|
#define I_RSSI (0x00) /**< Index 0 contains RSSI information (from optionally appended packet status bytes). */
|
|
#define I_LQI (0x01) /**< Index 1 contains LQI & CRC_OK information (from optionally appended packet status bytes). */
|
|
#define MARC_STATE (0x1F) /**< Bitmask (=00011111) for reading MARC_STATE in MARCSTATE status register. */
|
|
#define PKTSTATUS_CS (0x40) /**< Bitmask (=01000000) for reading CS (Carrier Sense) in PKTSTATUS status register. */
|
|
#define PKTSTATUS_PQT_REACHED (0x20) /**< Bitmask (=00100000) for reading PQT_REACHED (Preamble Quality reached) in PKTSTATUS status register. */
|
|
#define PKTSTATUS_CCA (0x10) /**< Bitmask (=00010000) for reading CCA (clear channel assessment) in PKTSTATUS status register. */
|
|
#define PKTSTATUS_SFD (0x08) /**< Bitmask (=00001000) for reading SFD (Sync word found) in PKTSTATUS status register. */
|
|
#define PKTSTATUS_GDO2 (0x04) /**< Bitmask (=00000100) for reading GDO2 (current value on GDO2 pin) in PKTSTATUS status register. */
|
|
#define PKTSTATUS_GDO1 (0x02) /**< Bitmask (=00000010) for reading GDO1 (current value on GDO1 pin) in PKTSTATUS status register. */
|
|
#define PKTSTATUS_GDO0 (0x01) /**< Bitmask (=00000001) for reading GDO0 (current value on GDO0 pin) in PKTSTATUS status register. */
|
|
#define TXFIFO_UNDERFLOW (0x80) /**< Bitmask (=10000000) for reading TXFIFO_UNDERFLOW in TXBYTES status register. */
|
|
#define BYTES_IN_TXFIFO (0x7F) /**< Bitmask (=01111111) for reading NUM_TXBYTES in TXBYTES status register. */
|
|
#define RXFIFO_OVERFLOW (0x80) /**< Bitmask (=10000000) for reading RXFIFO_OVERFLOW in RXBYTES status register. */
|
|
#define BYTES_IN_RXFIFO (0x7F) /**< Bitmask (=01111111) for reading NUM_RXBYTES in RXBYTES status register. */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Bitmasks for reading out configuration register values
|
|
* @{
|
|
*/
|
|
#define PKT_LENGTH_CONFIG (0x03) /**< Bitmask (=00000011) for reading LENGTH_CONFIG in PKTCTRL0 configuration register. */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Definitions to support burst/single access
|
|
* @{
|
|
*/
|
|
#define CC110X_WRITE_BURST (0x40) /**< Offset for burst write. */
|
|
#define CC110X_READ_SINGLE (0x80) /**< Offset for read single byte. */
|
|
#define CC110X_READ_BURST (0xC0) /**< Offset for read burst. */
|
|
#define CC110X_NOBYTE (0xFF) /**< No command (for reading). */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Configuration Registers (47x)
|
|
* @{
|
|
*/
|
|
#define CC110X_IOCFG2 (0x00) /**< GDO2 output pin configuration */
|
|
#define CC110X_IOCFG1 (0x01) /**< GDO1 output pin configuration */
|
|
#define CC110X_IOCFG0 (0x02) /**< GDO0 output pin configuration */
|
|
#define CC110X_FIFOTHR (0x03) /**< RX FIFO and TX FIFO thresholds */
|
|
#define CC110X_SYNC1 (0x04) /**< Sync word, high byte */
|
|
#define CC110X_SYNC0 (0x05) /**< Sync word, low byte */
|
|
#define CC110X_PKTLEN (0x06) /**< Packet length */
|
|
#define CC110X_PKTCTRL1 (0x07) /**< Packet automation control */
|
|
#define CC110X_PKTCTRL0 (0x08) /**< Packet automation control */
|
|
#define CC110X_ADDR (0x09) /**< Device address */
|
|
#define CC110X_CHANNR (0x0A) /**< Channel number */
|
|
#define CC110X_FSCTRL1 (0x0B) /**< Frequency synthesizer control */
|
|
#define CC110X_FSCTRL0 (0x0C) /**< Frequency synthesizer control */
|
|
#define CC110X_FREQ2 (0x0D) /**< Frequency control word, high byte */
|
|
#define CC110X_FREQ1 (0x0E) /**< Frequency control word, middle byte */
|
|
#define CC110X_FREQ0 (0x0F) /**< Frequency control word, low byte */
|
|
#define CC110X_MDMCFG4 (0x10) /**< Modem configuration */
|
|
#define CC110X_MDMCFG3 (0x11) /**< Modem configuration */
|
|
#define CC110X_MDMCFG2 (0x12) /**< Modem configuration */
|
|
#define CC110X_MDMCFG1 (0x13) /**< Modem configuration */
|
|
#define CC110X_MDMCFG0 (0x14) /**< Modem configuration */
|
|
#define CC110X_DEVIATN (0x15) /**< Modem deviation setting */
|
|
#define CC110X_MCSM2 (0x16) /**< Main Radio Control State Machine configuration */
|
|
#define CC110X_MCSM1 (0x17) /**< Main Radio Control State Machine configuration */
|
|
#define CC110X_MCSM0 (0x18) /**< Main Radio Control State Machine configuration */
|
|
#define CC110X_FOCCFG (0x19) /**< Frequency Offset Compensation configuration */
|
|
#define CC110X_BSCFG (0x1A) /**< Bit Synchronization configuration */
|
|
#define CC110X_AGCCTRL2 (0x1B) /**< AGC control */
|
|
#define CC110X_AGCCTRL1 (0x1C) /**< AGC control */
|
|
#define CC110X_AGCCTRL0 (0x1D) /**< AGC control */
|
|
#define CC110X_WOREVT1 (0x1E) /**< High byte Event 0 timeout */
|
|
#define CC110X_WOREVT0 (0x1F) /**< Low byte Event 0 timeout */
|
|
#define CC110X_WORCTRL (0x20) /**< Wake On Radio control */
|
|
#define CC110X_FREND1 (0x21) /**< Front end RX configuration */
|
|
#define CC110X_FREND0 (0x22) /**< Front end TX configuration */
|
|
#define CC110X_FSCAL3 (0x23) /**< Frequency synthesizer calibration */
|
|
#define CC110X_FSCAL2 (0x24) /**< Frequency synthesizer calibration */
|
|
#define CC110X_FSCAL1 (0x25) /**< Frequency synthesizer calibration */
|
|
#define CC110X_FSCAL0 (0x26) /**< Frequency synthesizer calibration */
|
|
#define CC110X_RCCTRL1 (0x27) /**< RC oscillator configuration */
|
|
#define CC110X_RCCTRL0 (0x28) /**< RC oscillator configuration */
|
|
#define CC110X_FSTEST (0x29) /**< Frequency synthesizer calibration control */
|
|
#define CC110X_PTEST (0x2A) /**< Production test */
|
|
#define CC110X_AGCTEST (0x2B) /**< AGC test */
|
|
#define CC110X_TEST2 (0x2C) /**< Various test settings */
|
|
#define CC110X_TEST1 (0x2D) /**< Various test settings */
|
|
#define CC110X_TEST0 (0x2E) /**< Various test settings */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Strobe commands (14x)
|
|
* @{
|
|
*/
|
|
#define CC110X_SRES (0x30) /**< Reset chip. */
|
|
/**
|
|
* @brief Enable and calibrate frequency synthesizer (if MCSM0.FS_AUTOCAL=1).
|
|
*
|
|
* If in RX/TX: Go to a wait state where only the synthesizer is running (for quick RX / TX turnaround).
|
|
*/
|
|
#define CC110X_SFSTXON (0x31)
|
|
#define CC110X_SXOFF (0x32) /**< Turn off crystal oscillator. */
|
|
#define CC110X_SCAL (0x33) /**< Calibrate frequency synthesizer and turn it off (enables quick start). */
|
|
#define CC110X_SRX (0x34) /**< Enable RX. Perform calibration first if coming from IDLE and MCSM0.FS_AUTOCAL=1. */
|
|
/**
|
|
* In IDLE state: Enable TX. Perform calibration first if MCSM0.FS_AUTOCAL=1.
|
|
* If in RX state and CCA is enabled: Only go to TX if channel is clear.
|
|
*/
|
|
#define CC110X_STX (0x35)
|
|
#define CC110X_SIDLE (0x36) /**< Exit RX / TX, turn off frequency synthesizer and exit WOR mode if applicable. */
|
|
#define CC110X_SAFC (0x37) /**< Perform AFC adjustment of the frequency synthesizer */
|
|
#define CC110X_SWOR (0x38) /**< Start automatic RX polling sequence (Wake-on-Radio) */
|
|
#define CC110X_SPWD (0x39) /**< Enter power down mode when CSn goes high. */
|
|
#define CC110X_SFRX (0x3A) /**< Flush the RX FIFO buffer (CC110X should be in IDLE state). */
|
|
#define CC110X_SFTX (0x3B) /**< Flush the TX FIFO buffer (CC110X should be in IDLE state). */
|
|
#define CC110X_SWORRST (0x3C) /**< Reset real time clock. */
|
|
#define CC110X_SNOP (0x3D) /**< No operation. May be used to pad strobe commands to two bytes for simpler software. */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Status registers (12x)
|
|
* @{
|
|
*/
|
|
#define CC110X_PARTNUM (0x30) /**< Part number of CC110X. */
|
|
#define CC110X_VERSION (0x31) /**< Current version number. */
|
|
#define CC110X_FREQEST (0x32) /**< Frequency Offset Estimate. */
|
|
#define CC110X_LQI (0x33) /**< Demodulator estimate for Link Quality. */
|
|
#define CC110X_RSSI (0x34) /**< Received signal strength indication. */
|
|
#define CC110X_MARCSTATE (0x35) /**< Control state machine state. */
|
|
#define CC110X_WORTIME1 (0x36) /**< High byte of WOR timer. */
|
|
#define CC110X_WORTIME0 (0x37) /**< Low byte of WOR timer. */
|
|
#define CC110X_PKTSTATUS (0x38) /**< Current GDOx status and packet status. */
|
|
#define CC110X_VCO_VC_DAC (0x39) /**< Current setting from PLL calibration module. */
|
|
#define CC110X_TXBYTES (0x3A) /**< Underflow and number of bytes in the TX FIFO. */
|
|
#define CC110X_RXBYTES (0x3B) /**< Overflow and number of bytes in the RX FIFO. */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Multi byte registers
|
|
* @{
|
|
*/
|
|
/**
|
|
* @brief Register for eight user selected output power settings.
|
|
*
|
|
* 3-bit FREND0.PA_POWER value selects the PATABLE entry to use.
|
|
*/
|
|
#define CC110X_PATABLE (0x3E)
|
|
#define CC110X_TXFIFO (0x3F) /**< TX FIFO: Write operations write to the TX FIFO (SB: +0x00; BURST: +0x40) */
|
|
#define CC110X_RXFIFO (0x3F) /**< RX FIFO: Read operations read from the RX FIFO (SB: +0x80; BURST: +0xC0) */
|
|
/** @} */
|
|
|
|
|
|
/**
|
|
* @name GDO configuration values
|
|
*
|
|
* Values that can be written to the GDO0, GDO1 and GDO2 configuration registers
|
|
* @{
|
|
*/
|
|
|
|
/** @brief GDO goes high when RX FIFO is filled at or above threshold */
|
|
#define CC110X_GDO_HIGH_ON_RX_FIFO_ABOVE_THRESHOLD (0x00)
|
|
/**
|
|
* @brief GDO goes high when RX FIFO is filled at or above threshold or when
|
|
* packet is fully received
|
|
*/
|
|
#define CC110X_GDO_HIGH_ON_RX_FIFO_FILLED_OR_PKT_END (0x01)
|
|
/** @brief GDO goes low when TX FIFO is filled less than threshold */
|
|
#define CC110X_GDO_LOW_ON_TX_FIFO_BELOW_THRESHOLD (0x02)
|
|
/** @brief GDO goes low when TX FIFO becomes empty */
|
|
#define CC110X_GDO_LOW_ON_TX_FIFO_EMPTY (0x03)
|
|
/** @brief GDO goes high when RX FIFO overflows */
|
|
#define CC110X_GDO_HIGH_ON_RX_FIFO_OVERFLOW (0x04)
|
|
/** @brief GDO goes high when TX FIFO underflows */
|
|
#define CC110X_GDO_HIGH_ON_TX_FIFO_UNDERFLOW (0x05)
|
|
/**
|
|
* @brief GDO goes high when sync word was just received until the packet is
|
|
* fully received, or when sync word has been send until packet is fully
|
|
* send
|
|
*/
|
|
#define CC110X_GDO_HIGH_ON_SYNC_WORD (0x06)
|
|
/**
|
|
* @brief GDO goes high when a packet is received and CRC is correct.
|
|
* Goes back to low when first byte of RX fifo has been read
|
|
*/
|
|
#define CC110X_GDO_HIGH_ON_PACKET_RECEIVED (0x07)
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* CC110X_DEFINES_H */
|
|
/** @} */
|