Single-Chip Low Cost Low Power RF

CC1100
Low-Power Sub- 1 GHz RF Transceiver
CC1100
Applications
• Ultra low-power wireless applications
operating in the 315/433/868/915 MHz
ISM/SRD bands
• Wireless alarm and security systems
• Industrial monitoring and control
• Wireless sensor networks
• AMR – Automatic Meter Reading
• Home and building automation
Product Description
The
CC1100 is a low-cost sub- 1 GHz transceiver designed for very low-power wireless applications. The circuit is mainly intended for the ISM (Industrial, Scientific and
Medical) and SRD (Short Range Device) frequency bands at 315, 433, 868, and 915
MHz, but can easily be programmed for operation at other frequencies in the 300-348
MHz, 400-464 MHz and 800-928 MHz bands.
The RF transceiver is integrated with a highly configurable baseband modem. The modem supports various modulation formats and has a configurable data up to 500 kBaud.
CC1100 provides extensive hardware support for packet handling, data buffering, burst transmissions, clear channel assessment, link quality indication, and wake-on-radio.
The main operating parameters and the 64byte transmit/receive FIFOs of
CC1100 can be controlled via an SPI interface. In a typical system, the
CC1100 will be used together with a microcontroller and a few additional passive components.
3
4
5
1
2
CC1100
13
12
11
15
14
This product shall not be used in any of the following products or systems without prior express written permission from Texas Instruments:
(i)
(ii)
(iii) implantable cardiac rhythm management systems, including without limitation pacemakers, defibrillators and cardiac resynchronization devices, external cardiac rhythm management systems that communicate directly with one or more implantable medical devices; or other devices used to monitor or treat cardiac function, including without limitation pressure sensors, biochemical sensors and neurostimulators.
Please contact [email protected] if your application might fall within the category described above.
SWRS038D Page 1 of 92
CC1100
Key Features
RF Performance
• High sensitivity (–111 dBm at 1.2 kBaud,
868 MHz, 1% packet error rate)
•
Low current consumption (14.4 mA in RX,
1.2 kBaud, 868 MHz)
• Programmable output power up to +10 dBm for all supported frequencies
•
Excellent receiver selectivity and blocking performance
• Programmable data rate from 1.2 to 500 kBaud
•
Frequency bands: 300-348 MHz, 400-464
MHz and 800-928 MHz
Analog Features
• 2-FSK, GFSK, and MSK supported as well as OOK and flexible ASK shaping
• Suitable for frequency hopping systems due to a fast settling frequency synthesizer: 90us settling time
• Automatic Frequency Compensation
(AFC) can be used to align the frequency synthesizer to the received centre frequency
•
Integrated analog temperature sensor
Digital Features
• Flexible support for packet oriented systems: On-chip support for sync word detection, address check, flexible packet length, and automatic CRC handling
•
Efficient SPI interface: All registers can be programmed with one “burst” transfer
•
Digital RSSI output
• Programmable channel filter bandwidth
• Programmable Carrier Sense (CS) indicator
• Programmable Preamble Quality Indicator
(PQI) for improved protection against false sync word detection in random noise
• Support for automatic Clear Channel
Assessment (CCA) before transmitting
(for listen-before-talk systems)
• Support for per-package Link Quality
Indication (LQI)
• Optional automatic whitening and dewhitening of data
Low-Power Features
•
400nA SLEEP mode current consumption
•
Fast startup time: 240us from sleep to RX or TX mode (measured on EM reference
• Wake-on-radio functionality for automatic low-power RX polling
• Separate 64-byte RX and TX data FIFOs
(enables burst mode data transmission)
General
• Few external components: Completely onchip frequency synthesizer, no external filters or RF switch needed
• Green package: RoHS compliant and no antimony or bromine
• Small size (QLP 4x4 mm package, 20 pins)
• Suited for systems targeting compliance with EN 300 220 (Europe) and FCC CFR
Part 15 (US).
• Support for asynchronous and synchronous serial receive/transmit mode for backwards compatibility with existing radio communication protocols
SWRS038D Page 2 of 92
Abbreviations
Abbreviations used in this data sheet are described below.
ACP
ADC
AFC
AGC
AMR
ASK
BER
BT
CCA
CFR
CRC
Adjacent Channel Power
Automatic Frequency Compensation
Automatic Gain Control
Automatic Meter Reading
Amplitude Shift Keying
Bit Error Rate
Bandwidth-Time product
Clear Channel Assessment
Code of Federal Regulations
Cyclic Redundancy Check
MSK
NRZ
OOK
PA
PCB
PD
PER
PLL
POR
PQI
CW
DC
DVGA
ESR
FCC
FEC
FIFO
FHSS
Continuous Wave (Unmodulated Carrier)
Direct Current
Digital Variable Gain Amplifier
2-FSK
GFSK
IF
I/Q
Federal Communications Commission
Forward Error Correction
First-In-First-Out
Frequency Hopping Spread Spectrum
Binary Frequency Shift Keying
Gaussian shaped Frequency Shift Keying
Intermediate Frequency
In-Phase/Quadrature
ISM Industrial, Scientific, Medical
LC Inductor-Capacitor
LNA Low Noise Amplifier
LSB
LQI
Least Significant Bit
Link Quality Indicator
PTAT
QLP
QPSK
RF
RSSI
RX
SAW
SMD
SNR
SPI
SRD
TBD
TX
UHF
VCO
WOR
CC1100
Minimum Shift Keying
Non Return to Zero (Coding)
On-Off Keying
Power Amplifier
Printed Circuit Board
Power Down
Packet Error Rate
Phase Locked Loop
Power-On Reset
Preamble Quality Indicator
Proportional To Absolute Temperature
Quad Leadless Package
Quadrature Phase Shift Keying
Radio Frequency
Received Signal Strength Indicator
Receive, Receive Mode
Surface Aqustic Wave
Surface Mount Device
Signal to Noise Ratio
Serial Peripheral Interface
Short Range Devices
To Be Defined
Transmit, Transmit Mode
Ultra High frequency
Voltage Controlled Oscillator
Wake on Radio, Low power polling
SWRS038D Page 3 of 92
CC1100
Table Of Contents
.......................................................................................... 15
11 MICROCONTROLLER INTERFACE AND PIN CONFIGURATION .......................................... 28
14 DEMODULATOR, SYMBOL SYNCHRONIZER, AND DATA DECISION.................................. 30
Page 4 of 92 SWRS038D
CC1100
17 RECEIVED SIGNAL QUALIFIERS AND LINK QUALITY INFORMATION ............................ 37
31 ASYNCHRONOUS AND SYNCHRONOUS SERIAL OPERATION .............................................. 57
............................................................................ 58
....................................................................... 58
EGISTERS WITH PRESERVED VALUES IN
Page 5 of 92 SWRS038D
CC1100
(QLP 20) ........................................................................... 88
SWRS038D Page 6 of 92
CC1100
Under no circumstances must the absolute maximum ratings given in Table 1 be violated. Stress
exceeding one or more of the limiting values may cause permanent damage to the device.
Caution! ESD sensitive device.
Precaution should be used when handling the device in order to prevent permanent damage.
Parameter
Supply voltage
Voltage on any digital pin
Min
–0.3
Max
3.9
Units Condition
V All supply pins must have the same voltage
–0.3 VDD+0.3 max 3.9
V
–0.3 2.0 V Voltage on the pins RF_P, RF_N, and DCOUPL
Voltage ramp-up rate
Input RF level
Storage temperature range
Solder reflow temperature
ESD
–50
120
+10
150
260
<500 kV/µs dBm
°C
°C
V
According to IPC/JEDEC J-STD-020C
According to JEDEC STD 22, method A114,
Human Body Model
Table 1: Absolute Maximum Ratings
The operating conditions for
CC1100 are listed Table 2 in below.
Parameter
Operating temperature
Operating supply voltage
Min
-40
1.8
Max
85
3.6
Unit Condition
°C
V All supply pins must have the same voltage
Table 2: Operating Conditions
Parameter
Frequency range
Min
300
Typ Max
348
Unit
MHz
Condition/Note
Data rate 1.2
1.2
26
250
500 kBaud kBaud
2-FSK
GFSK, OOK, and ASK
(Shaped) MSK (also known as differential offset
QPSK)
Optional Manchester encoding (the data rate in kbps will be half the baud rate)
Table 3: General Characteristics
SWRS038D Page 7 of 92
CC1100
Tc = 25
°C, VDD = 3.0V if nothing else stated. All measurement results are obtained using the CC1100EM reference designs
reduction in sensitivity. See Table 5 for additional details on current consumption and sensitivity.
Parameter
Current consumption in power down modes
Current consumption
Current consumption,
315MHz
Min Typ
400
Max Unit Condition
nA Voltage regulator to digital part off, register values retained
(SLEEP state). All GDO pins programmed to 0x2F (HW to 0)
900 nA Voltage regulator to digital part off, register values retained, lowpower RC oscillator running (SLEEP state with WOR enabled
95 µA Voltage regulator to digital part off, register values retained,
XOSC running (SLEEP state with MCSM0.OSC_FORCE_ON set)
160 µA Voltage regulator to digital part on, all other modules in power down (XOFF state)
9.8 µA Automatic RX polling once each second, using low-power RC oscillator, with 460 kHz filter bandwidth and 250 kBaud data rate,
PLL calibration every 4 th
wakeup. Average current with signal in
channel below carrier sense level (MCSM2.RX_TIME_RSSI=1).
34.2 µA Same as above, but with signal in channel above carrier sense level, 1.95 ms RX timeout, and no preamble/sync word found.
1.5 µA Automatic RX polling every 15 th
second, using low-power RC oscillator, with 460kHz filter bandwidth and 250 kBaud data rate,
PLL calibration every 4 th
wakeup. Average current with signal in
channel below carrier sense level (MCSM2.RX_TIME_RSSI=1).
39.3 µA Same as above, but with signal in channel above carrier sense level, 29.3 ms RX timeout, and no preamble/sync word found.
1.6 mA Only voltage regulator to digital part and crystal oscillator running
(IDLE state)
8.2
15.1 mA Only the frequency synthesizer is running (FSTXON state). This currents consumption is also representative for the other intermediate states when going from IDLE to RX or TX, including the calibration state. mA Receive mode, 1.2 kBaud, reduced current, input at sensitivity limit
13.9
14.9
14.1
15.9
14.5 mA Receive mode, 1.2 kBaud, reduced current, input well above sensitivity limit mA Receive mode, 38.4 kBaud, reduced current, input at sensitivity limit mA Receive mode,38.4 kBaud, reduced current, input well above sensitivity limit mA Receive mode, 250 kBaud, reduced current, input at sensitivity limit mA Receive mode, 250 kBaud, reduced current, input well above sensitivity limit
27.0
14.8
12.3 mA Transmit mode, +10 dBm output power mA Transmit mode, 0 dBm output power mA Transmit mode, –6 dBm output power
SWRS038D Page 8 of 92
CC1100
Parameter
Current consumption,
433MHz
Current consumption,
868/915MHz
Min Typ Max Unit Condition
15.5 mA Receive mode, 1.2 kBaud , reduced current, input at sensitivity limit
14.5 mA Receive mode, 1.2 kBaud , reduced current, input well above sensitivity limit
15.4
14.4
16.5 mA Receive mode, 38.4 kBaud , reduced current, input at sensitivity limit mA Receive mode, 38.4 kBaud , reduced current, input well above sensitivity limit mA Receive mode, 250 kBaud , reduced current, input at sensitivity limit
15.2
28.9
15.5
13.1
15.4
14.4
15.2
14.4
16.4
15.1
31.1
16.9
13.5 mA Receive mode, 250 kBaud , reduced current, input well above sensitivity limit mA Transmit mode, +10 dBm output power mA Transmit mode, 0 dBm output power mA Transmit mode, –6 dBm output power mA Receive mode, 1.2 kBaud , reduced current, input at sensitivity limit mA Receive mode, 1.2 kBaud , reduced current, input well above sensitivity limit mA Receive mode, 38.4 kBaud , reduced current, input at sensitivity limit mA Receive mode,38.4 kBaud , reduced current, input well above sensitivity limit mA Receive mode, 250 kBaud , reduced current, input at sensitivity limit mA Receive mode, 250 kBaud , reduced current, input well above sensitivity limit mA Transmit mode, +10 dBm output power mA Transmit mode, 0 dBm output power mA Transmit mode, –6 dBm output power
Table 4: Electrical Specifications
Tc = 25
°C, VDD = 3.0V if nothing else stated. All measurement results are obtained using the CC1100EM reference designs
Parameter Min Typ Max Unit Condition/Note
Digital channel filter bandwidth
58 812 kHz User programmable. The bandwidth limits are proportional to crystal frequency (given values assume a 26.0 MHz crystal).
315 MHz, 1.2 kBaud data rate, sensitivity optimized,
(2-FSK, 1% packet error rate, 20 bytes packet length, 5.2 kHz deviation, 58 kHz digital channel filter bandwidth)
Receiver sensitivity -111 dBm Sensitivity can be traded for current consumption by setting
consumption is then reduced from 17.1 mA to 15.1 mA at sensitivity limit. The sensitivity is typically reduced to -109 dBm
315 MHz, 500 kBaud data rate, sensitivity optimized,
MDMCFG2.DEM_DCFILT_OFF=0 (MDMCFG2.DEM_DCFILT_OFF=1
cannot be used for data rates > 250 kBaud)
(MSK, 1% packet error rate, 20 bytes packet length, 812 kHz digital channel filter bandwidth)
-88 dBm
SWRS038D Page 9 of 92
CC1100
Parameter Min Typ Max Unit Condition/Note
433 MHz, 1.2 kBaud data rate, sensitivity optimized,
(2-FSK, 1% packet error rate, 20 bytes packet length, 5.2 kHz deviation, 58 kHz digital channel filter bandwidth
Receiver sensitivity –110 dBm Sensitivity can be traded for current consumption by setting
consumption is then reduced from 17.4 mA to 15.5 mA at sensitivity limit. The sensitivity is typically reduced to -108 dBm
433 MHz, 38.4 kBaud data rate, sensitivity optimized,
(2-FSK, 1% packet error rate, 20 bytes packet length, 20 kHz deviation, 100 kHz digital channel filter bandwidth)
Receiver sensitivity –103 dBm
433 MHz, 250 kBaud data rate, sensitivity optimized,
(MSK, 1% packet error rate, 20 bytes packet length, 540 kHz digital channel filter bandwidth)
Receiver sensitivity –94 dBm
433 MHz, 500 kBaud data rate, sensitivity optimized,
MDMCFG2.DEM_DCFILT_OFF=0 (MDMCFG2.DEM_DCFILT_OFF=1
cannot be used for data rates > 250 kBaud)
(MSK, 1% packet error rate, 20 bytes packet length, 812 kHz digital channel filter bandwidth)
Receiver sensitivity –88 dBm
868 MHz, 1.2 kBaud data rate, sensitivity optimized,
(2-FSK, 1% packet error rate, 20 bytes packet length, 5.2 kHz deviation, 58 kHz digital channel filter bandwidth)
Receiver sensitivity
Adjacent channel rejection
Alternate channel rejection
–111 dBm Sensitivity can be traded for current consumption by setting
consumption is then reduced from 17.7 mA to 15.4 mA at sensitivity limit. The sensitivity is typically reduced to -109 dBm
–15 dBm
33 dB Desired channel 3 dB above the sensitivity limit. 100 kHz channel spacing
33 dB Desired channel 3 dB above the sensitivity limit. 100 kHz channel spacing
See Figure 25 for plot of selectivity versus frequency offset
Image channel rejection,
868MHz
30 dB IF frequency 152 kHz
Desired channel 3 dB above the sensitivity limit.
868 MHz, 38.4 kBaud data rate
(2-FSK, 1% packet error rate, 20 bytes packet length, 20 kHz deviation, 100 kHz digital channel filter bandwidth)
Receiver sensitivity
Adjacent channel rejection
Alternate channel rejection
–103 dBm
–16 dBm
20 dB Desired channel 3 dB above the sensitivity limit. 200 kHz channel spacing
28 dB Desired channel 3 dB above the sensitivity limit. 200 kHz channel spacing
See Figure 26 for plot of selectivity versus frequency offset
Image channel rejection,
868MHz
23 dB IF frequency 152 kHz
Desired channel 3 dB above the sensitivity limit.
SWRS038D Page 10 of 92
CC1100
Parameter Min Typ Max Unit Condition/Note
868 MHz, 250 kBaud data rate, sensitivity optimized,
(MSK, 1% packet error rate, 20 bytes packet length, 540 kHz digital channel filter bandwidth)
Receiver sensitivity
–93 dBm Sensitivity can be traded for current consumption by setting
. The typical current consumption
is then reduced from 18.8 mA to 16.4 mA at sensitivity limit. The sensitivity is typically reduced to -91 dBm
Saturation –16
Adjacent channel rejection
24
37 Alternate channel rejection dBm dB dB
Desired channel 3 dB above the sensitivity limit. 750 kHz channel spacing
Desired channel 3 dB above the sensitivity limit. 750 kHz channel spacing
See Figure 27 for plot of selectivity versus frequency offset
Image channel rejection,
868MHz
14 dB IF frequency 254 kHz
Desired channel 3 dB above the sensitivity limit.
868 MHz, 500 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0
cannot be used for data rates > 250 kBaud )
(MSK, 1% packet error rate, 20 bytes packet length, 812 kHz digital channel filter bandwidth)
Receiver sensitivity
868 MHz, 250 kBaud data rate, sensitivity optimized,
(OOK, 1% packet error rate, 20 bytes packet length, 540 kHz digital channel filter bandwidth)
-86 dBm Receiver sensitivity
915 MHz, 1.2 kBaud data rate, sensitivity optimized,
(2-FSK, 5.2kHz deviation, 1% packet error rate, 20 bytes packet length, 58 kHz digital channel filter bandwidth)
Receiver sensitivity
–111 dBm Sensitivity can be traded for current consumption by setting
. The typical current consumption
is then reduced from 17.7 mA to 15.4 mA at sensitivity limit. The sensitivity is typically reduced to -109 dBm
915 MHz, 38.4 kBaud data rate, sensitivity optimized,
(2-FSK, 1% packet error rate, 20 bytes packet length, 20 kHz deviation, 100 kHz digital channel filter bandwidth)
Receiver sensitivity
915 MHz, 250 kBaud data rate, sensitivity optimized,
(MSK, 1% packet error rate, 20 bytes packet length, 540 kHz digital channel filter bandwidth)
Receiver sensitivity
–93 dBm Sensitivity can be traded for current consumption by setting
. The typical current consumption
is then reduced from 18.8 mA to 16.4 mA at sensitivity limit. The sensitivity is typically reduced to -92 dBm
915 MHz, 500 kBaud data rate, sensitivity optimized,
MDMCFG2.DEM_DCFILT_OFF=0 (MDMCFG2.DEM_DCFILT_OFF=1
cannot be used for data rates > 250 kBaud )
(MSK, 1% packet error rate, 20 bytes packet length, 812 kHz digital channel filter bandwidth)
Receiver sensitivity
Page 11 of 92 SWRS038D
CC1100
Parameter
Blocking
Blocking at ±2 MHz offset,
1.2 kBaud, 868 MHz
Blocking at ±2 MHz offset,
500 kBaud, 868 MHz
Blocking at ±10 MHz offset,
1.2 kBaud, 868 MHz
Blocking at ±10 MHz offset,
500 kBaud, 868 MHz
Min Typ Max Unit Condition/Note
-53
-51
-43
-43 dBm Desired channel 3dB above the sensitivity limit. Compliant with ETSI EN 300 220 class 2 receiver requirement. dBm Desired channel 3dB above the sensitivity limit. Compliant with ETSI EN 300 220 class 2 receiver requirement. dBm Desired channel 3dB above the sensitivity limit. Compliant with ETSI EN 300 220 class 2 receiver requirement. dBm Desired channel 3dB above the sensitivity limit. Compliant with ETSI EN 300 220 class 2 receiver requirement.
General
Spurious emissions
RX latency
-68
-66
9
–57
–47 dBm 25 MHz – 1 GHz
(Maximum figure is the ETSI EN 300 220 limit) dBm Above 1 GHz
(Maximum figure is the ETSI EN 300 220 limit) bit Serial operation. Time from start of reception until data is available on the receiver data output pin is equal to 9 bit.
Table 5: RF Receive Section
SWRS038D Page 12 of 92
CC1100
4.3 RF Transmit Section
Tc = 25
°C, VDD = 3.0V, +10dBm if nothing else stated. All measurement results are obtained using the CC1100EM reference designs
Parameter
Differential load impedance
315 MHz
433 MHz
868/915 MHz
Output power, highest setting
Output power, lowest setting
Harmonics, radiated
2 nd
Harm, 433 MHz
3 rd
Harm, 433 MHz
2 nd
Harm, 868 MHz
3 rd
Harm, 868 MHz
Harmonics, conducted
315 MHz
433 MHz
868 MHz
915 MHz
Min Typ
122 + j31
116 + j41
86.5 + j43
Max Unit
Ω
Condition/Note
Differential impedance as seen from the RF-port (RF_P and
RF_N) towards the antenna. Follow the CC1100EM reference
design ([5] and [6]) available from theTI website.
+10 Output power is programmable, and full range is available in all frequency bands
(Output power may be restricted by regulatory limits. See also
Delivered to a 50
Ω single-ended load via CC1100EM reference
RF matching network.
-30 Output power is programmable, and full range is available in all frequency bands.
-50
-40
-34
-45 dBm
Delivered to a 50
Ω single-ended load via CC1100EM reference
design([5] and [6]) RF matching network.
Measured on CC1100EM reference designs([5] and [6])
with
CW, 10 dBm output power
The antennas used during the radiated measurements (SMAFF-
433 from R.W.Badland and Nearson S331 868/915) plays a part in attenuating the harmonics
< -33
< -38
< -51
< -34
< -32
< -30 dBm
Measured with 10 dBm CW, TX frequency at 315.00 MHz,
433.00 MHz, 868.00 MHz, or 915.00 MHz
Frequencies below 960 MHz
Frequencies above 960 MHz
Frequencies below 1 GHz
Frequencies above 1 GHz
SWRS038D Page 13 of 92
CC1100
Spurious emissions, conducted
Harmonics not included
315 MHz
433 MHz
868 MHz
915 MHz
General
TX latency
< -50
< -51
< -53
< -51
< -51
< -58
< -53
< -50
< -54
< -56 dBm
Measured with 10 dBm CW, TX frequency at 315.00 MHz,
433.00 MHz, 868.00 MHz or 915.00 MHz
Frequencies below 960 MHz
Frequencies above 960 MHz
Frequencies below 1 GHz
Frequencies above 1 GHz
Frequencies within 47-74, 87.5-118, 174-230, 470-862 MHz
Frequencies below 1 GHz
Frequencies above 1 GHz
Frequencies within 47-74, 87.5-118, 174-230, 470-862 MHz.
The peak conducted spurious emission is -53dBm @ 699 MHz, which is in an EN300220 restricted band limited to -54dBm. All radiated spurious emissions are within the limits of ETSI.
Frequencies below 960 MHz
Frequencies above 960 MHz
8 bit Serial operation. Time from sampling the data on the transmitter data input DIO pin until it is observed on the RF output ports.
Table 6: RF Transmit Section
Tc = 25
°C @ VDD = 3.0 V if nothing else is stated.
Parameter
Crystal frequency
Tolerance
Min
26
Typ
26
±40
Max
27
Unit
MHz
Condition/Note
ppm This is the total tolerance including a) initial tolerance, b) crystal loading, c) aging, and d) temperature dependence.
The acceptable crystal tolerance depends on RF frequency and channel spacing / bandwidth.
Start-up time 150 µs
Measured on the CC1100EM reference designs ([5] and [6])
using crystal AT-41CD2 from NDK.
This parameter is to a large degree crystal dependent.
Table 7: Crystal Oscillator Parameters
SWRS038D Page 14 of 92
CC1100
4.5 Low Power RC Oscillator
Tc = 25
.
Parameter
Calibrated frequency
Min
34.7
Typ
34.7
Max
36
Unit
kHz
Condition/Note
Calibrated RC Oscillator frequency is XTAL frequency divided by 750
±1 % Frequency accuracy after calibration
Temperature coefficient
Supply voltage coefficient
Initial calibration time
+0.5
+3
2
% /
°C Frequency drift when temperature changes after calibration
% / V Frequency drift when supply voltage changes after calibration ms When the RC Oscillator is enabled, calibration is continuously done in the background as long as the crystal oscillator is running.
Table 8: RC Oscillator Parameters
4.6 Frequency Synthesizer Characteristics
Tc = 25 °C @ VDD = 3.0 V if nothing else is stated. All measurement results are obtained using the CC1100EM reference
. Min figures are given using a 27 MHz crystal. Typ and max are given using a 26 MHz crystal.
Parameter
Programmed frequency resolution
Synthesizer frequency tolerance
RF carrier phase noise
RF carrier phase noise
RF carrier phase noise
RF carrier phase noise
RF carrier phase noise
RF carrier phase noise
RF carrier phase noise
RF carrier phase noise
PLL turn-on / hop time
PLL RX/TX settling time
PLL TX/RX settling time
PLL calibration time
Min Typ
397 F
XOSC
2
16
/
85.1
9.3
20.7
694
±40
–89
–89
–90
–98
–107
–113
–119
–129
88.4
9.6
21.5
721
Max
412
88.4
9.6
21.5
721
Unit Condition/Note
Hz 26-27 MHz crystal.
The resolution (in Hz) is equal for all frequency bands. ppm Given by crystal used. Required accuracy
(including temperature and aging) depends on frequency band and channel bandwidth / spacing. dBc/Hz @ 50 kHz offset from carrier dBc/Hz @ 100 kHz offset from carrier dBc/Hz @ 200 kHz offset from carrier dBc/Hz @ 500 kHz offset from carrier dBc/Hz @ 1 MHz offset from carrier dBc/Hz @ 2 MHz offset from carrier dBc/Hz @ 5 MHz offset from carrier dBc/Hz @ 10 MHz offset from carrier
µs
Time from leaving the IDLE state until arriving in the RX, FSTXON or TX state, when not performing calibration.
Crystal oscillator running.
µs
µs
Settling time for the 1·IF frequency step from RX to TX
Settling time for the 1·IF frequency step from TX to RX
µs Calibration can be initiated manually or automatically before entering or after leaving
RX/TX.
Table 9: Frequency Synthesizer Parameters
Page 15 of 92 SWRS038D
CC1100
4.7 Analog Temperature Sensor
The characteristics of the analog temperature sensor at 3.0 V supply voltage are listed in Table 10
below. Note that it is necessary to write 0xBF to the PTEST register to use the analog temperature
sensor in the IDLE state.
Parameter
Output voltage at –40 °C
Output voltage at 0
°C
Output voltage at +40 °C
Output voltage at +80
°C
Temperature coefficient
Error in calculated temperature, calibrated
Current consumption increase when enabled
Min Typ Max Unit Condition/Note
0.651 V
0.747 V
0.847 V
0.945 V
-2
*
2.45 mV/ °C Fitted from –20 °C to +80 °C
°C From °C to +80 °C when using 2.45 mV / °C, after 1-point calibration at room temperature
*
The indicated minimum and maximum error with 1point calibration is based on simulated values for typical process parameters
0.3 mA
Table 10: Analog Temperature Sensor Parameters
Tc = 25
°C if nothing else stated.
Digital Inputs/Outputs
Logic "0" input voltage
Logic "1" input voltage
Logic "0" output voltage
Logic "1" output voltage
Logic "0" input current
Logic "1" input current
Min
0
VDD-0.7
0
VDD-0.3
N/A
N/A
Max
0.7
VDD
0.5
VDD
–50
50
Unit
V
V
V
V nA nA
Condition
For up to 4 mA output current
For up to 4 mA output current
Input equals 0V
Input equals VDD
Table 11: DC Characteristics
When the power supply complies with the requirements in Table 12 below, proper Power-On-Reset
functionality is guaranteed. Otherwise, the chip should be assumed to have unknown state until
transmitting an SRES strobe over the SPI interface. See Section 19.1 on page 42 for further details.
Parameter
Power-up ramp-up time.
Power off time
Min Typ Max Unit Condition/Note
1
5 ms ms
From 0V until reaching 1.8V
Minimum time between power-on and power-off
Table 12: Power-On Reset Requirements
Page 16 of 92 SWRS038D
CC1100
SCLK 1
SO (GDO1) 2
GDO2 3
DVDD 4
DCOUPL 5
20 19 18 17 16
6 7 8 9 10
15 AVDD
14 AVDD
13 RF_N
12 RF_P
11 AVDD
GND
Exposed die attach pad
7
8
9
10
Figure 1: Pinout Top View
Note: The exposed die attach pad must be connected to a solid ground plane as this is the main ground connection for the chip.
Pin # Pin Name
1
2
SCLK
Pin type
Digital Input
SO (GDO1) Digital Output
3 GDO2 Digital Output
Description
Serial configuration interface, clock input
Serial configuration interface, data output.
Optional general output pin when CSn is high
Digital output pin for general use:
4
5
DVDD
DCOUPL
Power (Digital)
Power (Digital)
6 GDO0
(ATEST)
Digital I/O
• FIFO status signals
• Clear Channel Indicator
• Clock output, down-divided from XOSC
• Serial output RX data
1.8 - 3.6 V digital power supply for digital I/O’s and for the digital core voltage regulator
1.6 - 2.0 V digital power supply output for decoupling.
NOTE: This pin is intended for use with the
CC1100
only. It can not be used to provide supply voltage to other devices.
Digital output pin for general use:
CSn
XOSC_Q1
AVDD
XOSC_Q2
Digital Input
Analog I/O
Power (Analog)
Analog I/O
• FIFO status signals
• Clear Channel Indicator
• Clock output, down-divided from XOSC
• Serial output RX data
• Serial input TX data
Also used as analog test I/O for prototype/production testing
Serial configuration interface, chip select
Crystal oscillator pin 1, or external clock input
1.8 - 3.6 V analog power supply connection
Crystal oscillator pin 2
SWRS038D Page 17 of 92
CC1100
Pin # Pin Name
11 AVDD
12 RF_P
13 RF_N
17
18
19
20
14
15
16
AVDD
AVDD
GND
RBIAS
DGUARD
GND
SI
Pin type
Power (Analog)
RF I/O
RF I/O
Power (Analog)
Power (Analog)
Ground (Analog)
Analog I/O
Power (Digital)
Ground (Digital)
Digital Input
Description
1.8 -3.6 V analog power supply connection
Positive RF input signal to LNA in receive mode
Positive RF output signal from PA in transmit mode
Negative RF input signal to LNA in receive mode
Negative RF output signal from PA in transmit mode
1.8 - 3.6 V analog power supply connection
1.8 - 3.6 V analog power supply connection
Analog ground connection
External bias resistor for reference current
Power supply connection for digital noise isolation
Ground connection for digital noise isolation
Serial configuration interface, data input
Table 13: Pinout Overview
RF_P
RF_N
LNA
RADIO CONTROL
ADC
0
90
ADC
FREQ
SYNTH
SCLK
SO (GDO1)
SI
CSn
GDO0 (ATEST)
GDO2
PA
RC OSC BIAS XOSC
RBIAS XOSC_Q1 XOSC_Q2
Figure 2:
CC1100 Simplified Block Diagram
A simplified block diagram of
CC1100 is shown
CC1100 features a low-IF receiver. The received RF signal is amplified by the lownoise amplifier (LNA) and down-converted in quadrature (I and Q) to the intermediate frequency (IF). At IF, the I/Q signals are digitised by the ADCs. Automatic gain control
(AGC), fine channel filtering and demodulation bit/packet synchronization are performed digitally.
The transmitter part of
CC1100 is based on direct synthesis of the RF frequency. The frequency synthesizer includes a completely on-chip LC VCO and a 90 degree phase shifter for generating the I and Q LO signals to the down-conversion mixers in receive mode.
A crystal is to be connected to XOSC_Q1 and
XOSC_Q2. The crystal oscillator generates the reference frequency for the synthesizer, as well as clocks for the ADC and the digital part.
A 4-wire SPI serial interface is used for configuration and data buffer access.
The digital baseband includes support for channel configuration, packet handling, and data buffering.
SWRS038D Page 18 of 92
CC1100
Only a few external components are required for using the
CC1100. The recommended
application circuits are shown in Figure 3 and
Figure 4. The external components are
described in Table 14, and typical values are
Bias Resistor
The bias resistor R171 is used to set an accurate bias current.
Balun and RF Matching
The components between the RF_N/RF_P pins and the point where the two signals are joined together (C131, C121, L121 and L131
for the 315/433 MHz reference design [5].
L121, L131, C121, L122, C131, C122 and
L132 for the 868/915 MHz reference design
[6]) form a balun that converts the differential
RF signal on
CC1100 to a single-ended RF signal. C124 is needed for DC blocking.
Together with an appropriate LC network, the balun components also transform the impedance to match a 50 Ω antenna (or cable). Suggested values for 315 MHz, 433
MHz, and 868/915 MHz are listed in Table 15.
The balun and LC filter component values and their placement are important to keep the performance optimized. It is highly recommended to follow the CC1100EM
Crystal
The crystal oscillator uses an external crystal with two loading capacitors (C81 and C101).
See Section 27 on page 53 for details.
Additional Filtering
Additional external components (e.g. an RF
SAW filter) may be used in order to improve the performance in specific applications.
Power Supply Decoupling
The power supply must be properly decoupled close to the supply pins. Note that decoupling capacitors are not shown in the application circuit. The placement and the size of the decoupling capacitors are very important to achieve the optimum performance. The
CC1100EM reference design ([5] and [6])
should be followed closely.
Component Description
C51 Decoupling capacitor for on-chip voltage regulator to digital part
C81/C101
C121/C131
C122
Crystal loading capacitors, see Section 27 on page 53 for details
RF balun/matching capacitors
RF LC filter/matching filter capacitor (315 and 433 MHz). RF balun/matching capacitor (868/915 MHz).
C123
C124
C125
L121/L131
L122
RF LC filter/matching capacitor
RF balun DC blocking capacitor
RF LC filter DC blocking capacitor (only needed if there is a DC path in the antenna)
RF balun/matching inductors (inexpensive multi-layer type)
RF LC filter/matching filter inductor (315 and 433 MHz). RF balun/matching inductor
(868/915 MHz). (inexpensive multi-layer type)
RF LC filter/matching filter inductor (inexpensive multi-layer type) L123
L124
L132
R171
XTAL
RF LC filter/matching filter inductor (inexpensive multi-layer type)
RF balun/matching inductor. (inexpensive multi-layer type)
Resistor for internal bias current reference.
26MHz - 27MHz crystal, see Section 27 on page 53 for details.
Table 14: Overview of External Components (excluding supply decoupling capacitors)
SWRS038D Page 19 of 92
CC1100
1.8V-3.6V power supply
R171
SI
SCLK
SO
(GDO1)
GDO2
(optional)
1 SCLK
2 SO
(GDO1)
3 GDO2
CC1100
DIE ATTACH PAD:
4 DVDD
5 DCOUPL
AVDD 15
AVDD 14
RF_N 13
RF_P 12
AVDD 11
C131
L131
C125
L121
C124
C121
L122 L123
C122 C123
Antenna
(50 Ohm)
C51
GDO0
(optional)
CSn
C81
XTAL
C101
Figure 3: Typical Application and Evaluation Circuit 315/433 MHz (excluding supply decoupling capacitors)
1.8V-3.6V power supply
R171
SI
SCLK
SO
(GDO1)
GDO2
(optional)
C51
GDO0
(optional)
CSn
1 SCLK AVDD 15
2 SO (GDO1)
3 GDO2
AVDD 14
RF_N 13
4 DVDD
5 DCOUPL
DIE ATTACH PAD: RF_P 12
AVDD 11
L131
L121
C131
L132
C121
C122
L123
Antenna
(50 Ohm)
L124
C125
C123
L122
C124
C81
XTAL
C101
Figure 4: Typical Application and Evaluation Circuit 868/915 MHz (excluding supply decoupling capacitors)
SWRS038D Page 20 of 92
CC1100
Component
C51
C81
C101
C121
C122
C123
Value at 315MHz Value at 433MHz Value at
868/915MHz
100 nF ± 10%, 0402 X5R
27 pF ± 5%, 0402 NP0
6.8 pF ± 0.5 pF,
0402 NP0
27 pF ± 5%, 0402 NP0
3.9 pF ± 0.25 pF,
0402 NP0
12 pF ± 5%, 0402
NP0
6.8 pF ± 0.5 pF,
0402 NP0
8.2 pF ± 0.5 pF,
0402 NP0
5.6 pF ± 0.5 pF,
0402 NP0
1.0 pF ± 0.25 pF, 0402 NP0
1.5 pF ± 0.25 pF, 0402 NP0
3.3 pF ± 0.25 pF, 0402 NP0
C124
C125
C131
L121
220 pF ± 5%,
0402 NP0
220 pF ± 5%,
0402 NP0
6.8 pF ± 0.5 pF,
0402 NP0
33 nH ± 5%, 0402 monolithic
220 pF ± 5%,
0402 NP0
220 pF ± 5%,
0402 NP0
3.9 pF ± 0.25 pF,
0402 NP0
27 nH ± 5%, 0402 monolithic
100 pF ± 5%,
0402 NP0
100 pF ± 5%,
0402 NP0
1.5 pF ± 0.25 pF, 0402 NP0
12 nH ± 5%,
0402 monolithic
L122
L123
L124
L131
L132
18 nH ± 5%, 0402 monolithic
33 nH ± 5%, 0402 monolithic
33 nH ± 5%, 0402 monolithic
22 nH ± 5%, 0402 monolithic
27 nH ± 5%, 0402 monolithic
27 nH ± 5%, 0402 monolithic
18 nH ± 5%,
0402 monolithic
12 nH ± 5%,
0402 monolithic
12 nH ± 5%,
0402 monolithic
12 nH ± 5%,
0402 monolithic
18 nH ± 5%,
0402 monolithic
Manufacturer
Murata GRM1555C series
Murata GRM1555C series
Murata GRM1555C series
Murata GRM1555C series
Murata GRM1555C series
Murata GRM1555C series
Murata GRM1555C series
Murata GRM1555C series
Murata GRM1555C series
Murata LQG15HS series
Murata LQG15HS series
Murata LQG15HS series
Murata LQG15HS series
Murata LQG15HS series
Murata LQG15HS series
XTAL 26.0 MHz surface mount crystal
Koa RK73 series
NDK, AT-41CD2
Table 15: Bill Of Materials for the Application Circuit
The Gerber files for the CC1100EM reference designs ([5] and [6]) are available from the TI website.
SWRS038D Page 21 of 92
CC1100
CC1100 can be configured to achieve optimum performance for many different applications.
Configuration is done using the SPI interface.
The following key parameters can be programmed:
•
Power-down / power up mode
• Crystal oscillator power-up / power-down
•
Receive / transmit mode
•
RF channel selection
• Data format
•
RX channel filter bandwidth
•
RF output power
• Data buffering with separate 64-byte receive and transmit FIFOs
•
Packet radio hardware support
• Forward Error Correction (FEC) with interleaving
• Data
(WOR)
Details of each configuration register can be
found in Section 33, starting on page 60.
Figure 5 shows a simplified state diagram that
explains the main
CC1100 states, together with typical usage and current consumption. For detailed information on controlling the
CC1100 state machine, and a complete state diagram,
see Section 19, starting on page 42.
SWRS038D Page 22 of 92
CC1100
SIDLE
SPWD or wake-on-radio (WOR)
Default state when the radio is not receiving or transmitting. Typ. current consumption: 1.6 mA.
CSn = 0
IDLE
Used for calibrating frequency synthesizer upfront (entering receive or transmit mode can then be done quicker).
Transitional state. Typ. current consumption: 8.2 mA.
Manual freq. synth. calibration
SCAL
SXOFF
CSn = 0
SRX or STX or SFSTXON or wake-on-radio (WOR)
SFSTXON
Frequency synthesizer is on, ready to start transmitting.
Transmission starts very quickly after receiving the STX command strobe.Typ. current consumption: 8.2 mA.
Frequency synthesizer on
Frequency synthesizer startup, optional calibration, settling
STX
Sleep
Crystal oscillator off
SRX or wake-on-radio (WOR)
Lowest power mode. Most register values are retained.
Current consumption typ
400 nA, or typ 900 nA when wake-on-radio (WOR) is enabled.
All register values are retained. Typ. current consumption; 0.16 mA.
Frequency synthesizer is turned on, can optionally be calibrated, and then settles to the correct frequency.
Transitional state. Typ. current consumption: 8.2 mA.
STX TXOFF_MODE = 01
SFSTXON or RXOFF_MODE = 01
Typ. current consumption:
13.5 mA at -6 dBm output,
16.9 mA at 0 dBm output,
30.7 mA at +10 dBm output.
In FIFO-based modes, transmission is turned off and this state entered if the TX
FIFO becomes empty in the middle of a packet. Typ. current consumption: 1.6 mA.
Transmit mode
STX or RXOFF_MODE=10
SRX or TXOFF_MODE = 11
Receive mode
Typ. current consumption: from 14.4 mA (strong input signal) to 15.4mA
(weak input signal).
TXOFF_MODE = 00 RXOFF_MODE = 00
Optional transitional state. Typ. current consumption: 8.2mA.
TX FIFO underflow
Optional freq. synth. calibration
RX FIFO overflow
In FIFO-based modes, reception is turned off and this state entered if the RX FIFO overflows. Typ. current consumption: 1.6 mA.
SFTX
SFRX
IDLE
Figure 5: Simplified State Diagram, with Typical Current Consumption at 1.2 kBaud
Data Rate
and MDMCFG2.DEM_DCFILT_OFF=1 (current optimized). Freq. Band = 868 MHz
SWRS038D Page 23 of 92
CC1100 can be configured using the SmartRF
®
Studio software [7]. The SmartRF
®
Studio software is highly recommended for obtaining optimum register settings, and for evaluating performance and functionality. A screenshot of the SmartRF
®
Studio user interface for
CC1100
CC1100
After chip reset, all the registers have default
values as shown in the tables in Section 33.
The optimum register setting might differ from the default value. After a reset all registers that shall be different from the default value therefore needs to be programmed through the SPI interface.
Figure 6: SmartRF
®
10 4-wire Serial Configuration and Data Interface
CC1100 is configured via a simple 4-wire SPIcompatible interface (SI, SO, SCLK and CSn) where
CC1100 is the slave. This interface is also used to read and write buffered data. All transfers on the SPI interface are done most significant bit first.
The CSn pin must be kept low during transfers on the SPI bus. If CSn goes high during the transfer of a header byte or during read/write from/to a register, the transfer will be cancelled. The timing for the address and data
transfer on the SPI interface is shown in Figure
All transactions on the SPI interface start with a header byte containing a R/W;¯ bit, a burst access bit (B), and a 6-bit address (A
5
– A
0
).
When CSn is pulled low, the MCU must wait until
CC1100 SO pin goes low before starting to transfer the header byte. This indicates that the crystal is running. Unless the chip was in
SWRS038D Page 24 of 92
the SLEEP or XOFF states, the SO pin will always go low immediately after taking CSn low.
CC1100
Figure 7: Configuration Registers Write and Read Operations
Parameter
f
SCLK
Description
SCLK frequency
100 ns delay inserted between address byte and data byte (single access), or between address and data, and between each data byte (burst access).
SCLK frequency, single access
No delay between address and data byte
Min Max Units
- 10 MHz
- 9
SCLK frequency, burst access
No delay between address and data byte, or between data bytes
- 6.5 t sp,pd t sp t ch t cl t rise t fall t sd
CSn low to positive edge on SCLK, in power-down mode
CSn low to positive edge on SCLK, in active mode
Clock high
Clock low
Clock rise time
Clock fall time
Setup data (negative SCLK edge) to positive edge on SCLK
(t sd
applies between address and data bytes, and between data bytes)
Hold data after positive edge on SCLK
Negative edge on SCLK to CSn high.
Single access
Burst access
150
20
50
50
-
-
55
76
20
20
-
-
-
-
5
5
-
-
µs ns ns ns ns ns ns t hd t ns
-
- ns ns
Table 16: SPI Interface Timing Requirements
Note:
The minimum t sp,pd
figure in Table 16 can be used in cases where the user does not read the
signal. CSn low to positive edge on SCLK when the chip is woken from power-down
start-up time measured on CC1100EM reference designs ([5] and [6]) using crystal AT-41CD2 from
NDK.
SWRS038D Page 25 of 92
CC1100
When the header byte, data byte, or command strobe is sent on the SPI interface, the chip status byte is sent by the
CC1100 on the SO pin. The status byte contains key status signals, useful for the MCU. The first bit, s7, is
the CHIP_RDYn signal; this signal must go low
before the first positive edge of SCLK. The
signal indicates that the crystal is
running.
Bits 6, 5, and 4 comprise the STATE value.
This value reflects the state of the chip. The
XOSC and power to the digital core is on in the IDLE state, but all other modules are in power down. The frequency and channel configuration should only be updated when the chip is in this state. The RX state will be active when the chip is in receive mode. Likewise, TX is active when the chip is transmitting.
The last four bits (3:0) in the status byte con-
tains FIFO_BYTES_AVAILABLE. For read
operations (the R/W;¯ bit in the header byte is
set to 1), the FIFO_BYTES_AVAILABLE field
contains the number of bytes available for
reading from the RX FIFO. For write
operations (the R/W;¯ bit in the header byte is
set to 0), the FIFO_BYTES_AVAILABLE field
contains the number of bytes that can be written to the TX FIFO. When
, 15 or more bytes are available/free.
Table 17 gives a status byte summary.
Bits
7
6:4
Name
CHIP_RDYn
STATE[2:0]
Description
Stays high until power and crystal have stabilized. Should always be low when using the SPI interface.
Indicates the current main state machine mode
Value State
000 IDLE
Description
(Also reported for some transitional states instead of SETTLING or CALIBRATE)
001 RX
010 TX
011 FSTXON
100 CALIBRATE
Fast TX ready
Frequency synthesizer calibration is running
101
110
SETTLING
RXFIFO_OVERFLOW
PLL is settling
RX FIFO has overflowed. Read out any useful data, then flush the FIFO with SFRX
111 TXFIFO_UNDERFLOW TX FIFO has underflowed. Acknowledge with SFTX
3:0 FIFO_BYTES_AVAILABLE[3:0] The number of bytes available in the RX FIFO or free bytes in the TX FIFO
Table 17: Status Byte Summary
The configuration registers on the
CC1100 are located on SPI addresses from 0x00 to 0x2E.
Table 36 on page 61 lists all configuration
registers. It is highly recommended to use
SmartRF
®
Studio [7] to generate optimum
register settings. The detailed description of
each register is found in Section 33.1 and
33.2, starting on page 64. All configuration
registers can be both written to and read. The
R/W;¯ bit controls if the register should be written to or read. When writing to registers,
the status byte is sent on the SO pin each time a header byte or data byte is transmitted on the SI pin. When reading from registers, the status byte is sent on the SO pin each time a header byte is transmitted on the SI pin.
Registers with consecutive addresses can be accessed in an efficient way by setting the burst bit (B) in the header byte. The address bits (A
5
– A
0
) set the start address in an internal address counter. This counter is incremented by one each new byte (every 8 clock pulses). The burst access is either a
SWRS038D Page 26 of 92
read or a write access and must be terminated by setting CSn high.
For register addresses in the range 0x30-
0x3D, the burst bit is used to select between status registers, burst bit is one, and command
strobes, burst bit is zero (see 10.4 below).
Because of this, burst access is not available for status registers and they must be accesses one at a time. The status registers can only be read.
CC1100
When reading register fields over the SPI interface while the register fields are updated
by the radio hardware (e.g. MARCSTATE or
), there is a small, but finite,
probability that a single read from the register is being corrupt. As an example, the
probability of any single read from TXBYTES
being corrupt, assuming the maximum data rate is used, is approximately 80 ppm. Refer to the
CC1100 Errata Notes [1] for more details.
Command Strobes may be viewed as single byte instructions to
CC1100. By addressing a command strobe register, internal sequences will be started. These commands are used to disable the crystal oscillator, enable receive mode, enable wake-on-radio etc. The 13
command strobes are listed in Table 35 on page 60.
The command strobe registers are accessed by transferring a single header byte (no data is being transferred). That is, only the R/W;¯ bit, the burst access bit (set to 0), and the six address bits (in the range 0x30 through 0x3D) are written. The R/W;¯ bit can be either one or zero and will determine how the
byte should be interpreted.
When writing command strobes, the status byte is sent on the SO pin.
A command strobe may be followed by any other SPI access without pulling CSn high.
However, if an SRES strobe is being issued,
one will have to waith for SO to go low again before the next header byte can be issued as
shown in Figure 8. The command strobes are
executed immediately, with the exception of
the SPWD and the SXOFF strobes that are
executed when CSn goes high.
The 64-byte TX FIFO and the 64-byte RX
FIFO are accessed through the 0x3F address.
When the R/W;¯ bit is zero, the TX FIFO is accessed, and the RX FIFO is accessed when the R/W;¯ bit is one.
The TX FIFO is write-only, while the RX FIFO is read-only.
The burst bit is used to determine if the FIFO access is a single byte access or a burst access. The single byte access method expects a header byte with the burst bit set to zero and one data byte. After the data byte a new header byte is expected; hence, CSn can remain low. The burst access method expects one header byte and then consecutive data bytes until terminating the access by setting
CSn high.
The following header bytes access the FIFOs:
• 0x3F: Single byte access to TX FIFO
• 0x7F: Burst access to TX FIFO
• 0xBF: Single byte access to RX FIFO
• 0xFF: Burst access to RX FIFO
When writing to the TX FIFO, the status byte
(see Section 10.1) is output for each new data
byte on SO, as shown in Figure 7. This status
byte can be used to detect TX FIFO underflow while writing data to the TX FIFO. Note that the status byte contains the number of bytes free before writing the byte in progress to the
TX FIFO. When the last byte that fits in the TX
FIFO is transmitted on SI, the status byte received concurrently on SO will indicate that one byte is free in the TX FIFO.
The TX FIFO may be flushed by issuing a
command strobe. Similarly, a SFRX
command strobe will flush the RX FIFO. A
SFTX
or SFRX command strobe can only be
issued in the IDLE, TXFIFO_UNDERLOW, or
RXFIFO_OVERFLOW states. Both FIFOs are flushed when going to the SLEEP state.
Figure 9 gives a brief overview of different
register access types possible.
Page 27 of 92 SWRS038D
CC1100
The 0x3E address is used to access the
, which is used for selecting PA
power control settings. The SPI expects up to eight data bytes after receiving the address.
By programming the PATABLE, controlled PA
power ramp-up and ramp-down can be achieved, as well as ASK modulation shaping for reduced bandwidth. Note that both the ASK modulation shaping and the PA ramping is limited to output powers up to -1 dBm, and the
settings allowed are 0x00 and 0x30 to 0x3F. See SmartRF
®
recommended shaping / PA ramping sequences.
See Section 24 on page 49 for details on
output power programming.
The PATABLE is an 8-byte table that defines
the PA control settings to use for each of the eight PA power values (selected by the 3-bit
value FREND0.PA_POWER). The table is
written and read from the lowest setting (0) to the highest (7), one byte at a time. An index counter is used to control the access to the table. This counter is incremented each time a byte is read or written to the table, and set to the lowest index when CSn is high. When the highest value is reached the counter restarts at zero.
The access to the PATABLE is either single
byte or burst access depending on the burst bit. When using burst access the index counter will count up; when reaching 7 the counter will restart at 0. The R/W;¯ bit controls whether the access is a read or a write access.
If one byte is written to the PATABLE and this
value is to be read out then CSn must be set high before the read access in order to set the index counter back to zero.
Note that the content of the PATABLE is lost
when entering the SLEEP state, except for the first byte (index 0).
Figure 9: Register Access Types
In a typical system,
• Read and write buffered data
• Read back status information via the 4-wire
SPI-bus configuration interface (SI, SO,
SCLK and CSn).
CC1100 will interface to a microcontroller. This microcontroller must be able to:
The microcontroller uses four I/O pins for the
SPI configuration interface (SI, SO, SCLK and
CSn). The SPI is described in Section 10 on page 24.
11.2 General Control and Status Pins
The
CC1100 has two dedicated configurable pins (GDO0 and GDO2) and one shared pin
(GDO1) that can output internal status information useful for control software. These pins can be used to generate interrupts on the
MCU. See Section 30 page 55 for more details
on the signals that can be programmed.
GDO1 is shared with the SO pin in the SPI interface. The default setting for GDO1/SO is
3-state output. By selecting any other of the programming options, the GDO1/SO pin will become a generic pin. When CSn is low, the pin will always function as a normal SO pin.
In the synchronous and asynchronous serial modes, the GDO0 pin is used as a serial TX data input pin while in transmit mode.
The GDO0 pin can also be used for an on-chip analog temperature sensor. By measuring the voltage on the GDO0 pin with an external
ADC, the temperature can be calculated.
Specifications for the temperature sensor are
found in Section 4.7 on page 16.
SWRS038D Page 28 of 92
With default PTEST register setting (0x7F) the
temperature sensor output is only available when the frequency synthesizer is enabled
(e.g. the MANCAL, FSTXON, RX, and TX states). It is necessary to write 0xBF to the
register to use the analog temperature
sensor in the IDLE state. Before leaving the
IDLE state, the PTEST register should be
restored to its default value (0x7F).
CC1100
11.3 Optional Radio Control Feature
The
CC1100 has an optional way of controlling the radio, by reusing SI, SCLK, and CSn from the SPI interface. This feature allows for a simple three-pin control of the major states of the radio: SLEEP, IDLE, RX, and TX.
This optional functionality is enabled with the
State changes are commanded as follows :
When CSn is high the SI and SCLK is set to
the desired state according to Table 18. When
CSn goes low the state of SI and SCLK is
12 Data Rate Programming
The data rate used when transmitting, or the data rate expected in receive is programmed
by the MDMCFG3.DRATE_M and the
The data rate is given by the formula below.
As the formula shows, the programmed data rate depends on the crystal frequency.
R
DATA
=
(
256
+
DRATE
2
28
_
M
)
⋅
2
DRATE
_
E
⋅
f
XOSC
The following approach can be used to find suitable values for a given data rate:
DRATE
_
E
DRATE
_
M
=
=
⎢
⎣
⎢
⎢ log
2
⎛
⎜⎜
R
DATA f
⋅
XOSC
2
20
f
R
DATA
XOSC
⋅
2
⋅
2
28
DRATE
_
E
⎞
⎟⎟
⎥
⎥
−
256 latched and a command strobe is generated internally according to the pin configuration. It is only possible to change state with this functionality. That means that for instance RX will not be restarted if SI and SCLK are set to
RX and CSn toggles. When CSn is low the SI and SCLK has normal SPI functionality.
All pin control command strobes are executed
immediately, except the SPWD strobe, which is
delayed until CSn goes high.
CSn SCLK SI Function
1 X X Chip unaffected by SCLK/
SI
↓
↓
↓
↓
0
SPI mode
SPI mode
SPI mode (wakes up into
IDLE if in SLEEP/XOFF)
Table 18: Optional Pin Control Coding
If DRATE_M is rounded to the nearest integer and becomes 256, increment DRATE_E and use DRATE_M = 0.
The data rate can be set from 1.2 kBaud to
500 kBaud with the minimum step size of:
Min Data
Rate
[kBaud]
0.8
Typical Data
Rate
[kBaud]
1.2 / 2.4
Max Data
Rate
[kBaud]
3.17
Data rate
Step Size
[kBaud]
0.0062
Table 19: Data Rate Step Size
SWRS038D Page 29 of 92
13 Receiver Channel Filter Bandwidth
In order to meet different channel width requirements, the receiver channel filter is
programmable. The MDMCFG4.CHANBW_E and
control the receiver channel filter bandwidth, which scales with the crystal oscillator frequency. The following formula gives the relation between the register settings and the channel filter bandwidth:
BW channel
=
f
XOSC
8
⋅
( 4
+
CHANBW
_
M
)· 2
CHANBW
_
E
The
CC1100 supports the following channel filter bandwidths:
MDMCFG4.
CHANBW_M
00
01
10
11
MDMCFG4.CHANBW_E
00 01 10 11
812 406 203 102
650 325 162 81
541 270 135 68
464 232 116 58
Table 20: Channel Filter Bandwidths [kHz]
(Assuming a 26MHz crystal)
CC1100
For best performance, the channel filter bandwidth should be selected so that the signal bandwidth occupies at most 80% of the channel filter bandwidth. The channel centre tolerance due to crystal accuracy should also be subtracted from the signal bandwidth. The following example illustrates this:
With the channel filter bandwidth set to
500 kHz, the signal should stay within 80% of
500 kHz, which is 400 kHz. Assuming
915 MHz frequency and ±20 ppm frequency uncertainty for both the transmitting device and the receiving device, the total frequency uncertainty is ±40 ppm of 915MHz, which is
±37 kHz. If the whole transmitted signal bandwidth is to be received within 400kHz, the transmitted signal bandwidth should be maximum 400kHz – 2·37 kHz, which is
326 kHz.
14 Demodulator, Symbol Synchronizer, and Data Decision
CC1100 contains an advanced and highly configurable demodulator. Channel filtering and frequency offset compensation is performed digitally. To generate the RSSI level
(see Section 17.3 for more information) the
signal level in the channel is estimated. Data filtering is also included for enhanced performance.
If the FOCCFG.FOC_BS_CS_GATE bit is set,
the offset compensator will freeze until carrier sense asserts. This may be useful when the radio is in RX for long periods with no traffic, since the algorithm may drift to the boundaries when trying to track noise.
14.1 Frequency Offset Compensation
The tracking loop has two gain factors, which affects the settling time and noise sensitivity of
the algorithm. FOCCFG.FOC_PRE_K sets the
gain before the sync word is detected, and
the sync word has been found.
When using 2-FSK, GFSK, or MSK modulation, the demodulator will compensate for the offset between the transmitter and receiver frequency, within certain limits, by estimating the centre of the received data.
This value is available in the FREQEST status register. Writing the value from FREQEST into
the frequency synthesizer is automatically adjusted according to the estimated frequency offset.
The tracking range of the algorithm is selectable as fractions of the channel
bandwidth with the FOCCFG.FOC_LIMIT
configuration register.
Note that frequency offset compensation is not supported for ASK or OOK modulation.
The bit synchronization algorithm extracts the clock from the incoming symbols. The algorithm requires that the expected data rate
is programmed as described in Section 12 on page 29. Re-synchronization is performed
continuously to adjust for error in the incoming symbol rate.
Page 30 of 92 SWRS038D
CC1100
Byte synchronization is achieved by a continuous sync word search. The sync word is a 16 bit configurable field (can be repeated to get a 32 bit) that is automatically inserted at the start of the packet by the modulator in transmit mode. The demodulator uses this field to find the byte boundaries in the stream of bits. The sync word will also function as a system identifier, since only packets with the correct predefined sync word will be received if the sync word detection in RX is enabled in
register MDMCFG2 (see Section 17.1). The
sync word detector correlates against the user-configured 16 or 32 bit sync word. The correlation threshold can be set to 15/16,
16/16, or 30/32 bits match. The sync word can be further qualified using the preamble quality indicator mechanism described below and/or a carrier sense condition. The sync word is
configured through the SYNC1 and SYNC0
registers.
In order to make false detections of sync words less likely, a mechanism called preamble quality indication (PQI) can be used to qualify the sync word. A threshold value for the preamble quality must be exceeded in order for a detected sync word to be accepted.
See Section 17.2 on page 37 for more details.
15 Packet Handling Hardware Support
The
CC1100 has built-in hardware support for packet oriented radio protocols.
In transmit mode, the packet handler can be configured to add the following elements to the packet stored in the TX FIFO:
• A programmable number of preamble bytes
• A two byte synchronization (sync) word.
Can be duplicated to give a 4-byte sync word (recommended). It is not possible to only insert preamble or only insert a sync word.
• A CRC checksum computed over the data field.
•
• The recommended setting is 4-byte preamble and 4-byte sync word, except for 500 kBaud data rate where the recommended preamble length is 8 bytes.
•
• In addition, the following can be implemented on the data field and the optional 2-byte CRC checksum:
•
• Whitening of the data with a PN9 sequence.
• Forward error correction by the use of interleaving and coding of the data
(convolutional coding).
•
In receive mode, the packet handling support will de-construct the data packet by implementing the following (if enabled):
• Preamble
• Sync word detection.
•
CRC computation and CRC check.
•
One byte address check.
•
Packet length check (length byte checked against a programmable maximum length).
• De-whitening
•
De-interleaving and decoding
•
Optionally, two status bytes (see Table 21 and Table 22) with RSSI value, Link
•
Quality Indication, and CRC status can be appended in the RX FIFO.
Bit Field Name Description
7:0 RSSI
Table 21: Received Packet Status Byte 1
(first byte appended after the data)
Bit Field Name
7 CRC_OK
6:0 LQI
Description
1: CRC for received data OK
(or CRC disabled)
0: CRC error in received data
Indicating the link quality
Table 22: Received Packet Status Byte 2
(second byte appended after the data)
•
• Note that register fields that control the packet handling features should only be altered when
CC1100 is in the IDLE state.
From a radio perspective, the ideal over the air data are random and DC free. This results in the smoothest power distribution over the occupied bandwidth. This also gives the regulation loops in the receiver uniform operation conditions (no data dependencies).
SWRS038D Page 31 of 92
CC1100
Real world data often contain long sequences of zeros and ones. Performance can then be improved by whitening the data before transmitting, and de-whitening the data in the receiver. With
CC1100, this can be done automatically by setting
. All data, except
in Figure 10. At the receiver end, the data are
XOR-ed with the same pseudo-random sequence. This way, the whitening is reversed, and the original data appear in the receiver.
The PN9 sequence is initialized to all 1’s. the preamble and the sync word, are then
XOR-ed with a 9-bit pseudo-random (PN9) sequence before being transmitted, as shown
Figure 10: Data Whitening in TX Mode
The format of the data packet can be configured and consists of the following items
• Preamble word
•
Optional length byte
•
•
Optional address byte
• Payload
• Optional 2 byte CRC
Optional data whitening
Optionally FEC encoded/decoded
Optional CRC-16 calculation
Legend:
Inserted automatically in TX, processed and removed in RX.
Preamble bits
(1010...1010)
Data field
Optional user-provided fields processed in TX, processed but not removed in RX.
Unprocessed user data (apart from FEC and/or whitening)
8 x n bits 16/32 bits
8 bits
8 bits
8 x n bits 16 bits
Figure 11: Packet Format
The preamble pattern is an alternating sequence of ones and zeros (10101010…).
The minimum length of the preamble is programmable. When enabling TX, the modulator will start transmitting the preamble.
When the programmed number of preamble bytes has been transmitted, the modulator will send the sync word and then data from the TX
FIFO if data is available. If the TX FIFO is empty, the modulator will continue to send
SWRS038D Page 32 of 92
preamble bytes until the first byte is written to the TX FIFO. The modulator will then send the sync word and then the data bytes. The number of preamble bytes is programmed with
the MDMCFG1.NUM_PREAMBLE value.
The synchronization word is a two-byte value
set in the SYNC1 and SYNC0 registers. The
sync word provides byte synchronization of the incoming packet. A one-byte synch word can
be emulated by setting the SYNC1 value to the
preamble pattern. It is also possible to emulate a 32 bit sync word by using
word will then be repeated twice.
CC1100 supports both constant packet length protocols and variable length protocols.
Variable or fixed packet length mode can be used for packets up to 255 bytes. For longer packets, infinite packet length mode must be used.
Fixed packet length mode is selected by
setting PKTCTRL0.LENGTH_CONFIG=0. The
desired packet length is set by the PKTLEN
register.
In variable packet length mode,
, the packet length is configured by the first byte after the sync word. The packet length is defined as the payload data, excluding the length byte and
the optional CRC. The PKTLEN register is
used to set the maximum packet length allowed in RX. Any packet received with a
length byte with a value greater than PKTLEN
will be discarded.
With PKTCTRL0.LENGTH_CONFIG=2, the
packet length is set to infinite and transmission and reception will continue until turned off manually. As described in the next section, this can be used to support packet formats with different length configuration than natively supported by
CC1100. One should make sure that TX mode is not turned off during the transmission of the first half of any byte. Refer to the
CC1100 Errata Notes [1] for more details.
Note that the minimum packet length supported (excluding the optional length byte and CRC) is one byte of payload data.
15.2.1 Arbitrary Length Field Configuration
The packet length register, PKTLEN, can be
reprogrammed during receive and transmit. In combination with fixed packet length mode
CC1100
(PKTCTRL0.LENGTH_CONFIG=0) this opens
the possibility to have a different length field configuration than supported for variable length packets (in variable packet length mode the length byte is the first byte after the sync word). At the start of reception, the packet length is set to a large value. The MCU reads out enough bytes to interpret the length field in
the packet. Then the PKTLEN value is set
according to this value. The end of packet will occur when the byte counter in the packet
handler is equal to the PKTLEN register. Thus,
the MCU must be able to program the correct length, before the internal counter reaches the packet length.
15.2.2 Packet Length > 255
Also the packet automation control register,
can be reprogrammed during TX and RX. This opens the possibility to transmit and receive packets that are longer than 256 bytes and still be able to use the packet handling hardware support. At the start of the packet, the infinite packet length mode
(PKTCTRL0.LENGTH_CONFIG=2) must be
active. On the TX side, the PKTLEN register is
set to mod(length, 256). On the RX side the
MCU reads out enough bytes to interpret the
length field in the packet and sets the PKTLEN
register to mod(length, 256). When less than
256 bytes remains of the packet the MCU disables infinite packet length mode and activates fixed packet length mode. When the
internal byte counter reaches the PKTLEN
value, the transmission or reception ends (the radio enters the state determined by
TXOFF_MODE or RXOFF_MODE). Automatic
CRC appending/checking can also be used
(by setting PKTCTRL0.CRC_EN=1).
When for example a 600-byte packet is to be transmitted, the MCU should do the following
.
• Pre-program the PKTLEN register to
mod(600, 256) = 88.
• Transmit at least 345 bytes (600 - 255), for example by filling the 64-byte TX FIFO six times (384 bytes transmitted).
.
• The transmission ends when the packet counter reaches 88. A total of 600 bytes are transmitted.
Page 33 of 92 SWRS038D
CC1100
Internal byte counter in packet handler counts from 0 to 255 and then starts at 0 again
0,1,..........,88,....................255,0,........,88,..................,255,0,........,88,..................,255,0,.......................
Infinite packet length enabled Fixed packet length enabled when less than
256 bytes remains of packet
600 bytes transmitted and received
Length field transmitted and received. Rx and Tx PKTLEN value set to mod(600,256) = 88
Figure 12: Packet Length > 255
15.3 Packet Filtering in Receive Mode
CC1100 supports three different types of packet-filtering; address filtering, maximum length filtering, and CRC filtering.
FIFO if the CRC check fails. After auto flushing the RX FIFO, the next state depends on the
Setting PKTCTRL1.ADR_CHK to any other
value than zero enables the packet address filter. The packet handler engine will compare the destination address byte in the packet with
the programmed node address in the ADDR
register and the 0x00 broadcast address when
or both 0x00 and
0xFF broadcast addresses when
. If the received address matches a valid address, the packet is received and written into the RX FIFO. If the address match fails, the packet is discarded and receive mode restarted (regardless of the
When using the auto flush function, the maximum packet length is 63 bytes in variable packet length mode and 64 bytes in fixed packet length mode. Note that the maximum allowed packet length is reduced by two bytes when
enabled, to make room in the RX FIFO for the two status bytes appended at the end of the packet. Since the entire RX FIFO is flushed when the CRC check fails, the previously received packet must be read out of the FIFO before receiving the current packet. The MCU must not read from the current packet until the
CRC has been checked as OK.
15.4 Packet Handling in Transmit Mode
If the received address matches a valid address when using infinite packet length mode and address filtering is enabled, 0xFF will be written into the RX FIFO followed by the address byte and then the payload data.
15.3.2 Maximum Length Filtering
In variable packet length mode,
must be the length byte when variable packet length is enabled. The length byte has a value equal to the payload of the packet (including the optional address byte). If address recognition is enabled on the receiver, the second byte written to the TX FIFO must be the address byte. If fixed packet length is enabled, then the first byte written to the TX
FIFO should be the address (if the receiver used to set the maximum allowed packet length. If the received length byte has a larger value than this, the packet is discarded and receive mode restarted (regardless of the
The payload that is to be transmitted must be written into the TX FIFO. The first byte written uses address recognition).
The modulator will first send the programmed number of preamble bytes. If data is available
in the TX FIFO, the modulator will send the two-byte (optionally 4-byte) sync word and then the payload in the TX FIFO. If CRC is enabled, the checksum is calculated over all
The filtering of a packet when CRC check fails the data pulled from the TX FIFO and the
. The CRC auto flush function will flush the entire RX result is sent as two extra bytes following the payload data. If the TX FIFO runs empty before the complete packet has been
SWRS038D Page 34 of 92
transmitted, the radio will enter
TXFIFO_UNDERFLOW state. The only way to exit this state is by issuing an SFTX strobe.
Writing to the TX FIFO after it has underflowed will not restart TX mode.
If whitening is enabled, everything following the sync words will be whitened. This is done before the optional FEC/Interleaver stage.
Whitening is enabled by setting
.
If FEC/Interleaving is enabled, everything following the sync words will be scrambled by the interleaver and FEC encoded before being modulated. FEC is enabled by setting
15.5 Packet Handling in Receive Mode
In receive mode, the demodulator and packet handler will search for a valid preamble and the sync word. When found, the demodulator has obtained both bit and byte synchronism and will receive the first payload byte.
If FEC/Interleaving is enabled, the FEC decoder will start to decode the first payload byte. The interleaver will de-scramble the bits before any other processing is done to the data.
If whitening is enabled, the data will be dewhitened at this stage.
When variable packet length mode is enabled, the first byte is the length byte. The packet handler stores this value as the packet length and receives the number of bytes indicated by the length byte. If fixed packet length mode is used, the packet handler will accept the programmed number of bytes.
Next, the packet handler optionally checks the address and only continues the reception if the address matches. If automatic CRC check is enabled, the packet handler computes CRC and matches it with the appended CRC checksum.
At the end of the payload, the packet handler will optionally write two extra packet status
bytes (see Table 21 and Table 22) that contain
CRC status, link quality indication, and RSSI value.
15.6 Packet Handling in Firmware
When implementing a packet oriented radio protocol in firmware, the MCU needs to know
CC1100 when a packet has been received/transmitted.
Additionally, for packets longer than 64 bytes the RX FIFO needs to be read while in RX and the TX FIFO needs to be refilled while in TX.
This means that the MCU needs to know the number of bytes that can be read from or written to the RX FIFO and TX FIFO respectively. There are two possible solutions to get the necessary status information: a) Interrupt Driven Solution
In both RX and TX one can use one of the
GDO pins to give an interrupt when a sync word has been received/transmitted and/or when a complete packet has been received/transmitted
(IOCFGx.GDOx_CFG=0x06). In addition, there
are 2 configurations for the
associated with the RX FIFO
) and two that are associated with the TX FIFO
) that can be used as interrupt sources to provide information on how many bytes are in the RX FIFO and TX
FIFO respectively. See Table 34.
b) SPI Polling
The PKTSTATUS register can be polled at a
given rate to get information about the current
GDO2 and GDO0 values respectively. The
polled at a given rate to get information about the number of bytes in the RX FIFO and TX
FIFO respectively. Alternatively, the number of bytes in the RX FIFO and TX FIFO can be read from the chip status byte returned on the
MISO line each time a header byte, data byte, or command strobe is sent on the SPI bus.
It is recommended to employ an interrupt driven solution as high rate SPI polling will reduce the RX sensitivity. Furthermore, as
explained in Section 10.3 and the
CC1100
Errata Notes [1], when using SPI polling there
is a small, but finite, probability that a single
read from registers PKTSTATUS , RXBYTES and TXBYTES is being corrupt. The same is
the case when reading the chip status byte.
Refer to the TI website for SW examples ([8] and [9]).
Page 35 of 92 SWRS038D
CC1100
CC1100 supports amplitude, frequency, and phase shift modulation formats. The desired modulation format is set in the
register.
Optionally, the data stream can be Manchester coded by the modulator and decoded by the demodulator. This option is enabled by setting
. Manchester encoding is not supported at the same time as using the FEC/Interleaver option.
16.2 Minimum Shift Keying
When using MSK
(preamble, sync word, and payload) will be
MSK modulated.
Phase shifts are performed with a constant transition time.
The fraction of a symbol period used to change the phase can be modified with the
equivalent to changing the shaping of the symbol.
The MSK modulation format implemented in
CC1100 inverts the sync word and data compared to e.g. signal generators.
16.1 Frequency Shift Keying
2-FSK can optionally be shaped by a
Gaussian filter with BT = 1, producing a GFSK modulated signal.
The frequency deviation is programmed with
the DEVIATION_M and DEVIATION_E values in the DEVIATN register. The value has an
exponent/mantissa form, and the resultant deviation is given by:
f dev
=
f xosc
2
17
⋅
( 8
+
DEVIATION
_
M
)
⋅
2
DEVIATION
The symbol encoding is shown in Table 23.
_
E
Format Symbol
2-FSK/GFSK ‘0’
Coding
Table 23: Symbol Encoding for 2-FSK/GFSK
Modulation
CC1100 supports two different forms of amplitude modulation: On-Off Keying (OOK) and Amplitude Shift Keying (ASK).
OOK modulation simply turns on or off the PA to modulate 1 and 0 respectively.
The ASK variant supported by the
CC1100 allows programming of the modulation depth
(the difference between 1 and 0), and shaping of the pulse amplitude. Pulse shaping will produce a more bandwidth constrained output spectrum. Note that the pulse shaping feature on the
CC1100 does only support output power up to about -1dBm. The PATABLE settings that can be used for pulse shaping are 0x00 and
0x30 to 0x3F.
1
Identical to offset QPSK with half-sine shaping (data coding may differ)
SWRS038D Page 36 of 92
CC1100
CC1100 has several qualifiers that can be used to increase the likelihood that a valid sync word is detected.
17.1 Sync Word Qualifier
If sync word detection in RX is enabled in
CC1100 will not start filling the RX FIFO and perform the packet
filtering described in Section 15.3 before a
valid sync word has been detected. The sync word qualifier mode is set by
and is summarized in
Table 24. Carrier sense is described in Section
Sync Word Qualifier Mode
001
010
011
100
101
110
111
15/16 sync word bits detected
16/16 sync word bits detected
30/32 sync word bits detected
No preamble/sync, carrier sense above threshold
15/16 + carrier sense above threshold
16/16 + carrier sense above threshold
30/32 + carrier sense above threshold
Table 24: Sync Word Qualifier Mode
17.2 Preamble Quality Threshold (PQT)
The Preamble Quality Threshold (PQT) syncword qualifier adds the requirement that the received sync word must be preceded with a preamble with a quality above the programmed threshold.
Another use of the preamble quality threshold is as a qualifier for the optional RX termination
timer. See Section 19.7 on page 46 for details.
The preamble quality estimator increases an internal counter by one each time a bit is received that is different from the previous bit, and decreases the counter by 8 each time a bit is received that is the same as the last bit.
The threshold is configured with the register
field PKTCTRL1.PQT. A threshold of 4·PQT for
this counter is used to gate sync word detection. By setting the value to zero, the preamble quality qualifier of the synch word is disabled.
A “Preamble Quality Reached” signal can be
observed on one of the GDO pins by setting
. It is also possible to determine if preamble quality is reached by
checking the PQT_REACHED bit in the
register. This signal / bit asserts
when the received signal exceeds the PQT.
17.3 RSSI
The RSSI value is an estimate of the signal power level in the chosen channel. This value is based on the current gain setting in the RX chain and the measured signal level in the channel.
In RX mode, the RSSI value can be read continuously from the RSSI status register until the demodulator detects a sync word (when sync word detection is enabled). At that point the RSSI readout value is frozen until the next time the chip enters the RX state. The RSSI value is in dBm with ½dB resolution. The RSSI update rate, f
RSSI
, depends on the receiver filter bandwidth (BW channel
defined in Section
13) and AGCCTRL0.FILTER_LENGTH.
f
RSSI
=
2
⋅
BW channel
8
⋅
2
FILTER
_
LENGTH
If PKTCTRL1.APPEND_STATUS is enabled the
last RSSI value of the packet is automatically added to the first byte appended after the payload.
The RSSI value read from the RSSI status register is a 2’s complement number. The following procedure can be used to convert the
RSSI reading to an absolute power level
(RSSI_dBm).
1) Read the RSSI status register
2) Convert the reading from a hexadecimal number to a decimal number (RSSI_dec)
3) If RSSI_dec ≥ 128 then RSSI_dBm =
(RSSI_dec - 256)/2 – RSSI_offset
4) Else if RSSI_dec < 128 then RSSI_dBm =
(RSSI_dec)/2 – RSSI_offset
Table 25 gives typical values for the
RSSI_offset.
Figure 13 and Figure 14 shows typical plots of
RSSI reading as a function of input power level for different data rates.
SWRS038D Page 37 of 92
CC1100
Data rate [kBaud]
1.2
RSSI_offset [dB], 433 MHz
75
RSSI_offset [dB], 868 MHz
38.4 75
74
74
250 79
500 79
78
77
Table 25: Typical RSSI_offset Values
0
-10
-20
-30
-40
-50
-60
-70
-80
-90
-100
-110
-120
-120 -110 -100 -90 -80 -70 -60 -50 -40 -30 -20 -10 0
Input Power [dBm]
1.2 kBuad 38.4 kBaud 250 kBaud 500 kBaud
Figure 13: Typical RSSI Value vs. Input Power Level for Different Data Rates at 433 MHz
0
-10
-20
-30
-40
-50
-60
-70
-80
-90
-100
-110
-120
-120 -110 -100 -90 -80 -70 -60 -50
Input Power [dBm]
-40 -30 -20 -10 0
1.2 kBaud
38.4 kBuad
250 kBaud 500 kBaud
Figure 14: Typical RSSI Value vs. Input Power Level for Different Data Rates at 868 MHz
Page 38 of 92 SWRS038D
CC1100
17.4 Carrier Sense (CS)
Carrier Sense (CS) is used as a sync word qualifier and for CCA and can be asserted based on two conditions, which can be individually adjusted:
• CS is asserted when the RSSI is above a programmable absolute threshold, and deasserted when RSSI is below the same threshold (with hysteresis).
• CS is asserted when the RSSI has increased with a programmable number of dB from one RSSI sample to the next, and de-asserted when RSSI has decreased with the same number of dB. This setting is not dependent on the absolute signal level and is thus useful to detect signals in environments with time varying noise floor.
Carrier Sense can be used as a sync word qualifier that requires the signal level to be higher than the threshold for a sync word search to be performed. The signal can also
be observed on one of the GDO pins by setting IOCFGx.GDOx_CFG=14 and in the
status register bit PKTSTATUS.CS.
Studio to generate the correct MAGN_TARGET
setting.
Table 26 and Table 27 show the typical RSSI
readout values at the CS threshold at 2.4 kBaud and 250 kBaud data rate respectively.
The default CARRIER_SENSE_ABS_THR=0 (0
dB) and MAGN_TARGET=3 (33 dB) have been
used.
For other data rates the user must generate similar tables to find the CS absolute threshold.
00
MAX_DVGA_GAIN[1:0]
01 10 11
000 -97.5 -91.5 -85.5 -79.5
001 -94 -88 -82.5 -76
010 -90.5 -84.5 -78.5 -72.5
011 -88 -82.5 -76.5 -70.5
100 -85.5 -80 -73.5 -68
101 -84 -78 -72 -66
110 -82 -76 -70 -64
111 -79 -73.5 -67 -61
Other uses of Carrier Sense include the TX-if-
CCA function (see Section 17.5 on page 40)
and the optional fast RX termination (see
CS can be used to avoid interference from other RF sources in the ISM bands.
Table 26: Typical RSSI Value in dBm at CS
Threshold with Default MAGN_TARGET at 2.4
MAX_DVGA_GAIN[1:0]
00 01 10 11
17.4.1 CS Absolute Threshold
The absolute threshold related to the RSSI value depends on the following register fields:
000 -90.5 -84.5 -78.5 -72.5
001 -88 -82 -76 -70
010 -84.5 -78.5 -72 -66
011 -82.5 -76.5 -70 -64
100 -80.5 -74.5 -68 -62
• AGCCTRL1.CARRIER_SENSE_ABS_THR
101 -78 -72 -66 -60
110 -76.5 -70 -64 -58
• For a given AGCCTRL2.MAX_LNA_GAIN and AGCCTRL2.MAX_DVGA_GAIN setting the
absolute threshold can be adjusted ±7 dB in steps of 1 dB using
The MAGN_TARGET setting is a compromise
between blocker tolerance/selectivity and sensitivity. The value sets the desired signal level in the channel into the demodulator.
Increasing this value reduces the headroom for blockers, and therefore close-in selectivity.
It is strongly recommended to use SmartRF
®
111 -74.5 -68 -62 -56
Table 27: Typical RSSI Value in dBm at CS
Threshold with Default MAGN_TARGET at 250
If the threshold is set high, i.e. only strong signals are wanted, the threshold should be adjusted upwards by first reducing the
power consumption in the receiver front end, since the highest gain settings are avoided.
Page 39 of 92 SWRS038D
CC1100
The relative threshold detects sudden changes in the measured signal level. This setting is not dependent on the absolute signal level and is thus useful to detect signals in environments with a time varying noise floor. The register
field AGCCTRL1.CARRIER_SENSE_REL_THR
is used to enable/disable relative CS, and to select threshold of 6 dB, 10 dB, or 14 dB RSSI change. feature is called TX-if-CCA. Four CCA requirements can be programmed:
• Always (CCA disabled, always goes to TX)
• If RSSI is below threshold
• Unless currently receiving a packet
• Both the above (RSSI below threshold and not currently receiving a packet)
17.5 Clear Channel Assessment (CCA)
The Clear Channel Assessment (CCA) is used to indicate if the current channel is free or busy. The current CCA state is viewable on any of the GDO pins by setting
.
when determining CCA.
When the STX or SFSTXON command strobe is
given while
CC1100 is in the RX state, the TX or
FSTXON state is only entered if the clear channel requirements are fulfilled. The chip will otherwise remain in RX (if the channel becomes available, the radio will not enter TX or FSTXON state before a new strobe command is sent on the SPI interface). This
17.6 Link Quality Indicator (LQI)
The Link Quality Indicator is a metric of the current quality of the received signal. If
value is automatically added to the last byte appended after the payload. The value can
also be read from the LQI status register. The
LQI gives an estimate of how easily a received signal can be demodulated by accumulating the magnitude of the error between ideal constellations and the received signal over the
64 symbols immediately following the sync word. LQI is best used as a relative measurement of the link quality (a high value indicates a better link than what a low value does), since the value is dependent on the modulation format.
18 Forward Error Correction with Interleaving
18.1 Forward Error Correction (FEC)
CC1100 has built in support for Forward Error
Correction (FEC). To enable this option, set
in fixed packet length mode
FEC is employed on the data field and CRC word in order to reduce the gross bit error rate when operating near the sensitivity limit.
Redundancy is added to the transmitted data in such a way that the receiver can restore the original data in the presence of some bit errors.
The use of FEC allows correct reception at a lower SNR, thus extending communication range if the receiver bandwidth remains constant. Alternatively, for a given SNR, using
FEC decreases the bit error rate (BER). As the packet error rate (PER) is related to BER by:
PER
=
1
−
( 1
−
BER
)
packet
_
length
a lower BER can be used to allow longer packets, or a higher percentage of packets of a given length, to be transmitted successfully.
Finally, in realistic ISM radio environments, transient and time-varying phenomena will produce occasional errors even in otherwise good reception conditions. FEC will mask such errors and, combined with interleaving of the coded data, even correct relatively long periods of faulty reception (burst errors).
The FEC scheme adopted for
CC1100 is convolutional coding, in which n bits are generated based on k input bits and the m most recent input bits, forming a code stream able to withstand a certain number of bit errors between each coding state (the m-bit window).
The convolutional coder is a rate 1/2 code with a constraint length of m = 4. The coder codes one input bit and produces two output bits; hence, the effective data rate is halved. I.e. to transmit at the same effective datarate when using FEC, it is necessary to use twice as high over-the-air datarate. This will require a higher receiver bandwidth, and thus reduce sensitivity. In other words the improved
SWRS038D Page 40 of 92
reception by using FEC and the degraded sensitivity from a higher receiver bandwidth will be counteracting factors.
18.2 Interleaving
Data received through radio channels will often experience burst errors due to interference and time-varying signal strengths.
In order to increase the robustness to errors spanning multiple bits, interleaving is used when FEC is enabled. After de-interleaving, a continuous span of errors in the received stream will become single errors spread apart.
CC1100 employs matrix interleaving, which is
illustrated in Figure 15. The on-chip
interleaving and de-interleaving buffers are 4 x
4 matrices. In the transmitter, the data bits from the rate ½ convolutional coder are written into the rows of the matrix, whereas the bit sequence to be transmitted is read from the columns of the matrix. Conversely, in the
Interleaver
Write buffer
Packet
Engine
FEC
Encoder
Interleaver
Read buffer
Modulator
CC1100 receiver, the received symbols are written into the columns of the matrix, whereas the data passed onto the convolutional decoder is read from the rows of the matrix.
When FEC and interleaving is used at least one extra byte is required for trellis termination. In addition, the amount of data transmitted over the air must be a multiple of the size of the interleaver buffer (two bytes).
The packet control hardware therefore automatically inserts one or two extra bytes at the end of the packet, so that the total length of the data to be interleaved is an even number. Note that these extra bytes are invisible to the user, as they are removed before the received packet enters the RX
FIFO.
When FEC and interleaving is used the minimum data payload is 2 bytes.
Interleaver
Write buffer
Interleaver
Read buffer
Demodulator
FEC
Decoder
Figure 15: General Principle of Matrix Interleaving
Packet
Engine
SWRS038D Page 41 of 92
CC1100
MANCAL
3,4,5
CAL_COMPLETE
SCAL
SIDLE
SPWD | SWOR
SLEEP
0
IDLE
1
SRX | STX | SFSTXON | WOR
CSn = 0 | WOR
SXOFF
CSn = 0
XOFF
2
FS_WAKEUP
6,7
FS_AUTOCAL = 00 | 10 | 11
&
SRX | STX | SFSTXON | WOR
FS_AUTOCAL = 01
&
SRX | STX | SFSTXON | WOR
CALIBRATE
8
TXOFF_MODE = 10
SFSTXON
SETTLING
9,10,11
CAL_COMPLETE
FSTXON
18
STX
SRX | WOR
TX
19,20
STX
SRX
TXOFF_MODE=01
SFSTXON | RXOFF_MODE = 01
STX | RXOFF_MODE = 10
RXTX_SETTLING
21
( STX | SFSTXON ) & CCA
|
RXOFF_MODE = 01 | 10
TXFIFO_UNDERFLOW
SRX | TXOFF_MODE = 11
TXRX_SETTLING
16
TXOFF_MODE = 00
&
FS_AUTOCAL = 10 | 11
CALIBRATE
12
TX_UNDERFLOW
22
TXOFF_MODE = 00
&
FS_AUTOCAL = 00 | 01
RXOFF_MODE = 00
&
FS_AUTOCAL = 10 | 11
RXOFF_MODE = 00
&
FS_AUTOCAL = 00 | 01
RX
13,14,15
RXFIFO_OVERFLOW
RX_OVERFLOW
17
RXOFF_MODE = 11
SFTX
SFRX
IDLE
1
Figure 16: Complete Radio Control State Diagram
CC1100 has a built-in state machine that is used to switch between different operational states (modes). The change of state is done either by using command strobes or by internal events such as TX FIFO underflow.
A simplified state diagram, together with typical usage and current consumption, is
shown in Figure 5 on page 23. The complete
radio control state diagram is shown in Figure
16. The numbers refer to the state number
readable in the MARCSTATE status register.
This register is primarily for test purposes.
19.1 Power-On Start-Up Sequence
When the power supply is turned on, the system must be reset. This is achieved by one of the two sequences described below, i.e. automatic power-on reset (POR) or manual reset.
After the automatic power-on reset or manual reset it is also recommended to change the signal that is output on the GDO0 pin. The default setting is to output a clock signal with a frequency of CLK_XOSC/192, but to optimize
SWRS038D Page 42 of 92
performance in TX and RX an alternative GDO setting should be selected from the settings
CC1100
A power-on reset circuit is included in the
CC1100. The minimum requirements stated in
Table 12 must be followed for the power-on
reset to function properly. The internal power-
When the
CC1100 reset is completed the chip will be in the IDLE state and the crystal oscillator will be running. If the chip has had sufficient time for the crystal oscillator to stabilize after the power-on-reset the SO pin will go low immediately after taking CSn low. If
CSn is taken low before reset is completed the
SO pin will first go high, indicating that the crystal oscillator is not stabilized, before going
Figure 17: Power-On Reset
The other global reset possibility on
CC1100
uses the SRES command strobe. By issuing
this strobe, all internal registers and states are set to the default, IDLE state. The manual
power-up sequence is as follows (see Figure
• Set potential problems with pin control mode
(see Section 11.3 on page 29).
• Strobe CSn low / high.
• Hold CSn high for at least 40µs relative to pulling CSn low
• Pull CSn low and wait for SO to go low
• When SO goes low again, reset is complete and the chip is in the IDLE state.
XOSC and voltage regulator switched on
40 us
CSn
SO
XOSC Stable
SI
SRES
Figure 18: Power-On Reset with SRES
Note that the above reset procedure is only required just after the power supply is first turned on. If the user wants to reset the
CC1100 after this, it is only necessary to issue an SRES command strobe.
The crystal oscillator (XOSC) is either automatically controlled or always on, if
MCSM0.XOSC_FORCE_ON
is set.
In the automatic mode, the XOSC will be
turned off if the SXOFF or SPWD command
strobes are issued; the state machine then goes to XOFF or SLEEP respectively. This can only be done from the IDLE state. The
XOSC will be turned off when CSn is released
(goes high). The XOSC will be automatically turned on again when CSn goes low. The state machine will then go to the IDLE state.
The SO pin on the SPI interface must be pulled low before the SPI interface is ready to
be used; as described in Section 10.1 on page
If the XOSC is forced on, the crystal will always stay on even in the SLEEP state.
Crystal oscillator start-up time depends on crystal ESR and load capacitances. The electrical specification for the crystal oscillator
can be found in Section 4.4 on page 14.
19.3 Voltage Regulator Control
The voltage regulator to the digital core is controlled by the radio controller. When the chip enters the SLEEP state, which is the state with the lowest current consumption, the voltage regulator is disabled. This occurs after
CSn is released when a SPWD command
strobe has been sent on the SPI interface. The chip is now in the SLEEP state. Setting CSn
SWRS038D Page 43 of 92
low again will turn on the regulator and crystal oscillator and make the chip enter the IDLE state.
When wake on radio is enabled, the WOR module will control the voltage regulator as
CC1100
CC1100 has two active modes: receive and transmit. These modes are activated directly
by the MCU by using the SRX and STX
command strobes, or automatically by Wake on Radio.
The frequency synthesizer must be calibrated regularly.
CC1100 has one manual calibration
option (using the SCAL strobe), and three
automatic calibration options, controlled by the
• Calibrate when going from IDLE to either
RX or TX (or FSTXON)
• Calibrate when going from either RX or TX to IDLE automatically
• Calibrate every fourth time when going from either RX or TX to IDLE automatically
If the radio goes from TX or RX to IDLE by
issuing an SIDLE strobe, calibration will not be
performed.
The calibration takes a constant
number of XOSC cycles (see Table 28 for
timing details).
When RX is activated, the chip will remain in receive mode until a packet is successfully received or the RX termination timer expires
(see Section 19.7). Note: the probability that a
false sync word is detected can be reduced by using PQT, CS, maximum sync word length, and sync word qualifier mode as described in
Section 17. After a packet is successfully
received the radio controller will then go to the
state indicated by the MCSM1.RXOFF_MODE
setting. The possible destinations are:
• IDLE
• FSTXON: Frequency synthesizer on and ready at the TX frequency. Activate TX
• TX: Start sending preamble
• RX: Start search for a new packet
Similarly, when TX is active the chip will remain in the TX state until the current packet has been successfully transmitted. Then the
state will change as indicated by the
destinations are the same as for RX.
The MCU can manually change the state from
RX to TX and vice versa by using the command strobes. If the radio controller is
currently in transmit and the SRX strobe is
used, the current transmission will be ended and the transition to RX will be done.
If the radio controller is in RX when the STX or
command strobes are used, the TX-
if-CCA function will be used. If the channel is not clear, the chip will remain in RX. The
conditions for clear channel assessment. See
Section 17.5 on page 40 for details.
The SIDLE command strobe can always be
used to force the radio controller to go to the
IDLE state.
19.5 Wake On Radio (WOR)
The optional Wake on Radio (WOR) functionality enables
CC1100 to periodically wake up from SLEEP and listen for incoming packets without MCU interaction.
When the WOR strobe command is sent on the SPI interface, the
CC1100 will go to the
SLEEP state when CSn is released. The RC oscillator must be enabled before the WOR strobe can be used, as it is the clock source for the WOR timer. The on-chip timer will set
CC1100 into IDLE state and then RX state. After a programmable time in RX, the chip will go back to the SLEEP state, unless a packet is
received. See Figure 19 and Section 19.7 for
details on how the timeout works.
Set the
CC1100 into the IDLE state to exit WOR mode.
CC1100 can be set up to signal the MCU that a packet has been received by using the GDO pins. If a packet is received, the
will determine the behaviour at the end of the received packet.
When the MCU has read the packet, it can put
the chip back into SLEEP with the SWOR strobe
from the IDLE state. The FIFO will loose its contents in the SLEEP state.
The WOR timer has two events, Event 0 and
Event 1. In the SLEEP state with WOR activated, reaching Event 0 will turn on the digital regulator and start the crystal oscillator.
Event 1 follows Event 0 after a programmed timeout.
SWRS038D Page 44 of 92
The time between two consecutive Event 0 is programmed with a mantissa value given by
and an exponent value set by
t
Event
0
=
750
f
XOSC
⋅
EVENT
0
⋅
2
5
⋅
WOR
_
RES
The Event 1 timeout is programmed with
timing relationship between Event 0 timeout and Event 1 timeout.
CC1100 oscillator is locked to the main crystal frequency divided by 750.
In applications where the radio wakes up very often, typically several times every second, it is possible to do the RC oscillator calibration once and then turn off calibration
(WORCTRL.RC_CAL=0) to reduce the current
consumption. This requires that RC oscillator calibration values are read from registers
and written back to RCCTRL0 and RCCTRL1
respectively. If the RC oscillator calibration is turned off it will have to be manually turned on again if temperature and supply voltage changes.
Refer to Application Note AN047 [4] for further
details.
Figure 19: Event 0 and Event 1 Relationship
The time from the
CC1100 enters SLEEP state until the next Event0 is programmed to appear
(t
SLEEP
in Figure 19) should be larger than
11.08 ms when using a 26 MHz crystal and t
10.67 ms when a 27 MHz crystal is used. If
SLEEP
is less than 11.08 (10.67) ms there is a chance that the consecutive Event 0 will occur
f
750 ⋅
XOSC
128
seconds
too early. Application Note AN047 [4] explains
in detail the theory of operation and the different registers involved when using WOR, as well as highlighting important aspects when using WOR mode.
19.5.1 RC Oscillator and Timing
The frequency of the low-power RC oscillator used for the WOR functionality varies with temperature and supply voltage. In order to keep the frequency as accurate as possible, the RC oscillator will be calibrated whenever possible, which is when the XOSC is running and the chip is not in the SLEEP state. When the power and XOSC is enabled, the clock used by the WOR timer is a divided XOSC clock. When the chip goes to the sleep state, the RC oscillator will use the last valid calibration result. The frequency of the RC
19.6 Timing
The radio controller controls most of the timing in
CC1100, such as synthesizer calibration, PLL lock time, and RX/TX turnaround times. Timing from IDLE to RX and IDLE to TX is constant, dependent on the auto calibration setting.
RX/TX and TX/RX turnaround times are constant. The calibration time is constant
18739 clock periods. Table 28 shows timing in
crystal clock cycles for key state transitions.
Power on time and XOSC start-up times are
variable, but within the limits stated in Table 7.
Note that in a frequency hopping spread spectrum or a multi-channel protocol the calibration time can be reduced from 721 µs to approximately 150 µs. This is explained in
Description
IDLE to RX, no calibration
IDLE to RX, with calibration
IDLE to TX/FSTXON, no calibration
XOSC
Periods
2298
26 MHz
Crystal
88.4µs
~21037 809µs
2298 88.4µs
IDLE to TX/FSTXON, with calibration
TX to RX switch
RX to TX switch
RX or TX to IDLE, no calibration
~21037 809µs
560
250
2
21.5µs
9.6µs
0.1µs
RX or TX to IDLE, with calibration ~18739 721µs
Manual calibration ~18739 721µs
Table 28: State Transition Timing
Page 45 of 92 SWRS038D
CC1100
19.7 RX Termination Timer
CC1100 has optional functions for automatic termination of RX after a programmable time.
The main use for this functionality is wake-onradio (WOR), but it may be useful for other applications. The termination timer starts when in RX state. The timeout is programmable with
the MCSM2.RX_TIME setting. When the timer
expires, the radio controller will check the condition for staying in RX; if the condition is not met, RX will terminate.
The programmable conditions are:
• MCSM2.RX_TIME_QUAL=0: Continue
receive if sync word has been found
• MCSM2.RX_TIME_QUAL=1: Continue
receive if sync word has been found or preamble quality is above threshold (PQT)
If the system can expect the transmission to have started when enabling the receiver, the
The radio controller will then terminate RX if the first valid carrier sense sample indicates no carrier (RSSI below threshold). See Section
17.4 on page 39 for details on Carrier Sense.
For ASK/OOK modulation, lack of carrier sense is only considered valid after eight symbol periods. Thus, the
in ASK/OOK mode when the distance between
“1” symbols is 8 or less.
If RX terminates due to no carrier sense when
the MCSM2.RX_TIME_RSSI function is used,
or if no sync word was found when using the
will always go back to IDLE if WOR is disabled and back to SLEEP if WOR is enabled.
Otherwise, the MCSM1.RXOFF_MODE setting
determines the state to go to when RX ends.
This means that the chip will not automatically go back to SLEEP once a sync word has been received. It is therefore recommended to always wake up the microcontroller on sync word detection when using WOR mode. This can be done by selecting output signal 6 (see
Table 34 on page 56) on one of the
programmable GDO output pins, and programming the microcontroller to wake up on an edge-triggered interrupt from this GDO pin.
The
CC1100 contains two 64 byte FIFOs, one for received data and one for data to be transmitted. The SPI interface is used to read from the RX FIFO and write to the TX FIFO.
Section 10.5 contains details on the SPI FIFO
access. The FIFO controller will detect overflow in the RX FIFO and underflow in the
TX FIFO.
When writing to the TX FIFO it is the responsibility of the MCU to avoid TX FIFO overflow. A TX FIFO overflow will result in an error in the TX FIFO content.
received data byte is written to the RX FIFO at the exact same time as the last byte in the RX
FIFO is read over the SPI interface, the RX
FIFO pointer is not properly updated and the last read byte is duplicated. To avoid this problem one should never empty the RX FIFO before the last byte of the packet is received.
For packet lengths less than 64 bytes it is recommended to wait until the complete packet has been received before reading it out of the RX FIFO.
Likewise, when reading the RX FIFO the MCU must avoid reading the RX FIFO past its empty value, since an RX FIFO underflow will result in an error in the data read out of the RX FIFO.
If the packet length is larger than 64 bytes the
MCU must determine how many bytes can be read from the RX FIFO
(RXBYTES.NUM_RXBYTES-1) and the following
software routine can be used:
The chip status byte that is available on the
SO pin while transferring the SPI header contains the fill grade of the RX FIFO if the access is a read operation and the fill grade of the TX FIFO if the access is a write operation.
Section 10.1 on page 26 contains more details
1.
Read
repeatedly at a rate guaranteed to be at least twice that of which RF bytes are received until the same value is returned twice; store value in
n. on this.
The number of bytes in the RX FIFO and TX
FIFO can be read from the status registers
2. If
n
< # of bytes remaining in packet, read
-1 bytes from the RX FIFO.
SWRS038D Page 46 of 92
3. Repeat steps 1 and 2 until n = # of bytes remaining in packet.
4. Read the remaining bytes from the RX
FIFO.
The 4-bit FIFOTHR.FIFO_THR setting is used
to program threshold points in the FIFOs.
Table 29 lists the 16 FIFO_THR settings and
the corresponding thresholds for the RX and
TX FIFOs. The threshold value is coded in opposite directions for the RX FIFO and TX
FIFO. This gives equal margin to the overflow and underflow conditions when the threshold is reached.
A signal will assert when the number of bytes in the FIFO is equal to or higher than the programmed threshold. This signal can be
viewed on the GDO pins (see Table 34 on page 56).
Figure 21 shows the number of bytes in both
the RX FIFO and TX FIFO when the threshold
signal toggles, in the case of FIFO_THR=13.
Figure 20 shows the signal as the respective
FIFO is filled above the threshold, and then drained below.
NUM_RXBYTES
53 54 55 56 57 56 55 54 53
GDO
NUM_TXBYTES
6 7 8 9 10 9 8 7 6
GDO
Figure 20: FIFO_THR=13 vs. Number of
Bytes in FIFO (GDOx_CFG=0x00 in RX and
FIFO_THR
Bytes in TX FIFO Bytes in RX FIFO
0 (0000)
1 (0001)
61
57
4
8
2 (0010)
3 (0011)
4 (0100)
5 (0101)
6 (0110)
7 (0111)
8 (1000)
53
49
45
41
37
33
29
12
16
20
24
28
32
36
9 (1001)
10 (1010)
11 (1011)
12 (1100)
13 (1101)
14 (1110)
15 (1111)
25
21
17
13
9
5
1
40
44
48
52
56
60
64
Table 29: FIFO_THR Settings and the
Corresponding FIFO Thresholds
Overflow margin
FIFO_THR=13
56 bytes
CC1100
FIFO_THR=13
Underflow margin
8 bytes
RXFIFO TXFIFO
Figure 21: Example of FIFOs at Threshold
SWRS038D Page 47 of 92
CC1100
The frequency programming in
CC1100 is designed to minimize the programming needed in a channel-oriented system.
To set up a system with channel numbers, the desired channel spacing is programmed with spacing registers are mantissa and exponent respectively.
The base or start frequency is set by the 24 bit
frequency word located in the FREQ2, FREQ1, and FREQ0 registers. This word will typically
be set to the centre of the lowest channel frequency that is to be used. the
The desired channel number is programmed
with the 8-bit channel number register,
channel offset. The resultant carrier frequency is given by:
f carrier
=
f
XOSC
2
16
⋅
(
FREQ
+
CHAN
⋅
(
(
256
+
CHANSPC
_
M
)
⋅
2
CHANSPC
_
E
−
2
) )
With a 26 MHz crystal the maximum channel spacing is 405 kHz. To get e.g. 1 MHz channel spacing one solution is to use 333 kHz channel spacing and select each third channel
The preferred IF frequency is programmed
with the FSCTRL1.FREQ_IF register. The IF
frequency is given by:
f
IF
=
f
XOSC
2
10
⋅
FREQ
_
IF
Note that the SmartRF
®
automatically calculates the optimum
channel spacing and channel filter bandwidth.
If any frequency programming register is altered when the frequency synthesizer is running, the synthesizer may give an undesired response. Hence, the frequency programming should only be updated when the radio is in the IDLE state.
22 VCO
The VCO is completely integrated on-chip.
22.1 VCO and PLL Self-Calibration
The VCO characteristics will vary with temperature and supply voltage changes, as well as the desired operating frequency. In order to ensure reliable operation,
CC1100 includes frequency synthesizer self-calibration circuitry. This calibration should be done regularly, and must be performed after turning on power and before using a new frequency
(or channel). The number of XOSC cycles for completing the PLL calibration is given in
The calibration can be initiated automatically or manually. The synthesizer can be automatically calibrated each time the synthesizer is turned on, or each time the synthesizer is turned off automatically. This is
configured with the MCSM0.FS_AUTOCAL
register setting. In manual mode, the calibration is initiated when the SCAL command strobe is activated in the IDLE mode.
Note that the calibration values are maintained in SLEEP mode, so the calibration is still valid after waking up from SLEEP mode (unless supply voltage or temperature has changed significantly).
To check that the PLL is in lock the user can
program register IOCFGx.GDOx_CFG to 0x0A
and use the lock detector output available on the GDOx pin as an interrupt for the MCU (x =
0,1, or 2). A positive transition on the GDOx pin means that the PLL is in lock. As an alternative the user can read register FSCAL1.
The PLL is in lock if the register content is different from 0x3F. Refer also to the
CC1100
Errata Notes [1]. For more robust operation the
source code could include a check so that the
PLL is re-calibrated until PLL lock is achieved if the PLL does not lock the first time.
Page 48 of 92 SWRS038D
CC1100
CC1100 contains several on-chip linear voltage regulators, which generate the supply voltage needed by low-voltage modules. These voltage regulators are invisible to the user, and can be viewed as integral parts of the various modules. The user must however make sure that the absolute maximum ratings and
required pin voltages in Table 1 and Table 13
are not exceeded. The voltage regulator for the digital core requires one external decoupling capacitor.
Setting the CSn pin low turns on the voltage regulator to the digital core and starts the crystal oscillator. The SO pin on the SPI interface must go low before the first positive
edge of SCLK. (setup time is given in Table
If the chip is programmed to enter power-down
mode, (SPWD strobe issued), the power will be
turned off after CSn goes high. The power and crystal oscillator will be turned on again when
CSn goes low.
The voltage regulator output should only be used for driving the
CC1100.
24 Output Power Programming
The RF output power level from the device has two levels of programmability, as
illustrated in Figure 22. Firstly, the special
register can hold up to eight user selected output power settings. Secondly, the
3-bit FREND0.PA_POWER value selects the
entry to use. This two-level functionality provides flexible PA power ramp up and ramp down at the start and end of transmission, as well as ASK modulation shaping. All the PA power settings in the
from index 0 up to the
The power ramping at the start and at the end of a packet can be turned off by setting
to zero and then program the desired output power to index 0 in
If OOK modulation is used, the logic 0 and logic 1 power levels shall be programmed to index 0 and 1 respectively.
Table 30 contains recommended PATABLE
settings for various output levels and frequency bands. Using PA settings from 0x61 to 0x6F is not recommended. See Section
10.6 on page 28 for PATABLE programming
details.
Table 31 contains output power and current
consumption for default PATABLE setting
(0xC6). PATABLE must be programmed in
burst mode if you want to write to other entries
Note that all content of the PATABLE, except
for the first byte (index 0) is lost when entering the SLEEP state.
Output
Power
[dBm]
Setting
315 MHz
Current
Consumption,
Typ. [mA]
433 MHz
Setting
Current
Consumption,
Typ. [mA]
Setting
868 MHz
Current
Consumption,
Typ. [mA]
Setting
915 MHz
Current
Consumption,
Typ. [mA]
Table 30: Optimum PATABLE Settings for Various Output Power Levels and Frequency Bands
SWRS038D Page 49 of 92
CC1100
Default
Power
Setting
Output
Power
[dBm]
315 MHz
Current
Consumption,
Typ. [mA]
Output
Power
[dBm]
433 MHz
Current
Consumption,
Typ. [mA]
Output
Power
[dBm]
868 MHz
Current
Consumption,
Typ. [mA]
Output
Power
[dBm]
915 MHz
Current
Consumption,
Typ. [mA]
Table 31: Output Power and Current Consumption for Default PATABLE Setting
25 Shaping and PA Ramping
With ASK modulation, up to eight power settings are used for shaping. The modulator contains a counter that counts up when transmitting a one and down when transmitting a zero. The counter counts at a rate equal to 8 times the symbol rate. The counter saturates
at FREND0.PA_POWER and 0 respectively.
This counter value is used as an index for a lookup in the power table. Thus, in order to
utilize the whole table, FREND0.PA_POWER
PATABLE(7)[7:0]
PATABLE(6)[7:0]
PATABLE(5)[7:0]
PATABLE(4)[7:0]
PATABLE(3)[7:0]
PATABLE(2)[7:0]
PATABLE(1)[7:0]
PATABLE(0)[7:0] should be 7 when ASK is active. The shaping of the ASK signal is dependent on the
Note that the ASK shaping feature is only supported for output power levels up to -1 dBm and only values in the range 0x30–0x3F, together with 0x00 can be used. The same is the case when implementing PA ramping for
other modulations formats. Figure 23 shows
some examples of ASK shaping.
The PA uses this setting.
Settings 0 to PA_POWER are used during ramp-up at start of transmission and ramp-down at end of transmission, and for
ASK/OOK modulation.
Index into PATABLE(7:0) e.g 6
PA_POWER[2:0] in FREND0 register
The SmartRF® Studio software should be used to obtain optimum
PATABLE settings for various output powers.
Figure 22: PA_POWER and PATABLE
Output Power
PATABLE[7]
PATABLE[6]
PATABLE[5]
PATABLE[4]
PATABLE[3]
PATABLE[2]
PATABLE[1]
PATABLE[0]
1 0
FREND0.PA_POWER = 3
FREND0.PA_POWER = 7
0 1 0 1 1 0
Time
Bit Sequence
Figure 23: Shaping of ASK Signal
SWRS038D Page 50 of 92
CC1100
Output Power [dBm]
PATABLE Setting 315 MHz 433 MHz
-62.0
868 MHz 915 MHz
-57.1 -56.0
0x30 -41.7 -39.0 -33.6 -33.1
0x31 -21.8 -21.7 -21.2 -21.0
0x32 -16.2 -16.1 -16.0 -15.8
0x33 -12.8 -12.7 -12.7 -12.5
0x34 -10.5 -10.4 -10.5 -10.3
0x35 -8.6 -8.5 -8.7 -8.5
0x36 -7.2 -7.1 -7.4 -7.2
0x37 -5.9 -5.8 -6.2 -6.0
0x38 -4.8 -4.9 -5.3 -5.1
0x39 -3.9 -4.0 -4.5 -4.3
0x3A -3.2 -3.3 -3.8 -3.7
0x3B -2.5 -2.7 -3.3 -3.1
0x3C -2.1 -2.3 -2.8 -2.7
0x3D -1.7 -1.9 -2.5 -2.3
0x3E -1.3 -1.6 -2.1 -2.0
0x3F -1.1 -1.3 -1.9 -1.7
Table 32: PATABLE Settings used together with ASK Shaping and PA Ramping
Assume working in the 433 MHz and using
FSK. The desired output power is -10 dBm.
Figure 24 shows how the PATABLE should
look like in the two cases where no ramping is used (A) and when PA ramping is being implemented (B). In case A, the PATABLE
value is taken from Table 30, while in case B,
the values are taken from Table 32.
PATABLE[7] = 0x00
PATABLE[6] = 0x00
PATABLE[5] = 0x00
PATABLE[4] = 0x00
PATABLE[3] = 0x00
PATABLE[2] = 0x00
PATABLE[1] = 0x00
PATABLE[0] = 0x26
PATABLE[7] = 0x00
PATABLE[6] = 0x00
PATABLE[5] = 0x34
PATABLE[4] = 0x33
PATABLE[3] = 0x32
PATABLE[2] = 0x31
PATABLE[1] = 0x30
PATABLE[0] = 0x00
FREND0.PA_POWER = 0
A: Output Power = -10 dBm,
No PA Ramping
FREND0.PA_POWER = 5
B: Output Power = -10 dBm,
PA Ramping
Figure 24: PA Ramping
SWRS038D Page 51 of 92
CC1100
26 Selectivity
Figure 25 to Figure 27 show the typical selectivity performance (adjacent and alternate rejection).
50.0
40.0
30.0
20.0
10.0
0.0
-0.5
-10.0
-0.4
-0.3
-0.2
-0.1
0.0
0.1
0.2
0.4
0.5
Fre que ncy offse t [MHz]
Figure 25: Typical Selectivity at 1.2 kBaud
Data Rate, 868 MHz, 2-FSK, 5.2 kHz Deviation. IF
Frequency is 152.3 kHz and the Digital Channel Filter Bandwidth is 58 kHz
40.0
30.0
20.0
10.0
0.0
-0.5
-10.0
-0.4
-0.3
-0.2
-0.1
0.0
0.1
0.2
0.4
0.5
-20.0
Fre que ncy offse t [MHz]
Figure 26: Typical Selectivity at 38.4 kBaud
Data Rate, 868 MHz, 2-FSK, 20 kHz Deviation. IF
Frequency is 152.3 kHz and the Digital Channel Filter Bandwidth is 100 kHz
SWRS038D Page 52 of 92
CC1100
50.0
40.0
30.0
20.0
10.0
0.0
-2.3
-10.0
1.5
-1.0
-0.8
0.0
0.8
1.0
1.5
2.3
-20.0
Fre que ncy offse t [MHz]
Figure 27: Typical Selectivity at 250 kBaud
Data Rate, 868 MHz, MSK,
IF Frequency is 254 kHz and the Digital Channel Filter Bandwidth is 540 kHz
A crystal in the frequency range 26-27 MHz must be connected between the XOSC_Q1 and XOSC_Q2 pins. The oscillator is designed for parallel mode operation of the crystal. In addition, loading capacitors (C81 and C101) for the crystal are required. The loading capacitor values depend on the total load capacitance, C
L
, specified for the crystal. The total load capacitance seen between the crystal terminals should equal C
L
for the crystal to oscillate at the specified frequency.
C
L
=
1
C
81
1
+
1
C
101
+
C parasitic
The parasitic capacitance is constituted by pin input capacitance and PCB stray capacitance.
Total parasitic capacitance is typically 2.5 pF.
The crystal oscillator circuit is shown in Figure
28. Typical component values for different
values of C
L
The crystal oscillator is amplitude regulated.
This means that a high current is used to start up the oscillations. When the amplitude builds up, the current is reduced to what is necessary to maintain approximately 0.4 Vpp signal swing. This ensures a fast start-up, and keeps the drive level to a minimum. The ESR of the crystal should be within the specification in order to ensure a reliable start-up (see Section
The initial tolerance, temperature drift, aging and load pulling should be carefully specified in order to meet the required frequency accuracy in a certain application.
XOSC_Q1 XOSC_Q2
XTAL
C81 C101
Figure 28: Crystal Oscillator Circuit
Component
C81
C101
C
L
= 10 pF
15 pF
15 pF
C
L
= 13 pF
22 pF
22 pF
C
L
= 16 pF
27 pF
27 pF
Table 33: Crystal Oscillator Component Values
SWRS038D Page 53 of 92
27.1 Reference Signal
The chip can alternatively be operated with a reference signal from 26 to 27 MHz instead of a crystal. This input clock can either be a fullswing digital signal (0 V to VDD) or a sine wave of maximum 1 V peak-peak amplitude.
The reference signal must be connected to the
28 External RF Match
The balanced RF input and output of
CC1100 share two common pins and are designed for a simple, low-cost matching and balun network on the printed circuit board. The receive- and transmit switching at the
CC1100 front-end is controlled by a dedicated on-chip function, eliminating the need for an external RX/TXswitch.
A few passive external components combined with the internal RX/TX switch/termination circuitry ensures match in both RX and TX mode.
Although
CC1100 has a balanced RF input/output, the chip can be connected to a single-ended antenna with few external low cost capacitors and inductors.
29 PCB Layout Recommendations
The top layer should be used for signal routing, and the open areas should be filled with metallization connected to ground using several vias.
The area under the chip is used for grounding and shall be connected to the bottom ground plane with several vias. In the CC1100EM
reference designs ([5] and [6]) we have placed
5 vias inside the exposed die attached pad.
These vias should be “tented” (covered with solder mask) on the component side of the
PCB to avoid migration of solder through the vias during the solder reflow process.
The solder paste coverage should not be
100%. If it is, out gassing may occur during the reflow process, which may cause defects
(splattering, solder balling). Using “tented” vias reduces the solder paste coverage below
100%.
See Figure 29 for top solder resist and top
paste masks.
Each decoupling capacitor should be placed as close as possible to the supply pin it is supposed to decouple. Each decoupling capacitor should be connected to the power line (or power plane) by separate vias. The
CC1100 best routing is from the power line (or power plane) to the decoupling capacitor and then to the
CC1100 supply pin. Supply power filtering is very important.
Each decoupling capacitor ground pad should be connected to the ground plane using a separate via. Direct connections between neighboring power pins will increase noise coupling and should be avoided unless absolutely necessary.
The external components should ideally be as small as possible (0402 is recommended) and surface mount devices are highly recommended. Please note that components smaller than those specified may have differing characteristics.
Precaution should be used when placing the microcontroller in order to avoid noise interfering with the RF circuitry.
A CC1100/1150DK Development Kit with a fully assembled CC1100EM Evaluation
Module is available. It is strongly advised that this reference layout is followed very closely in order to get the best performance. The schematic, BOM and layout Gerber files are all
available from the TI website ([5] and [6]).
SWRS038D Page 54 of 92
XOSC_Q1 input. The sine wave must be connected to XOSC_Q1 using a serial capacitor. When using a full-swing digital signal this capacitor can be omitted. The
XOSC_Q2 line must be left un-connected. C81 and C101 can be omitted when using a reference signal.
The passive matching/filtering network connected to
CC1100 should have the following differential impedance as seen from the RFport (RF_P and RF_N) towards the antenna:
Z out 315 MHz
= 122 + j31 Ω
Z out 433 MHz
= 116 + j41 Ω
Z out 868/915 MHz
= 86.5 + j43 Ω
To ensure optimal matching of the
CC1100 differential output it is recommended to follow
the CC1100EM reference design ([5] or [6]) as
closely as possible. Gerber files for the reference designs are available for download from the TI website.
CC1100
Figure 29: Left: Top Solder Resist Mask (Negative). Right: Top Paste Mask. Circles are Vias
30 General Purpose / Test Output Control Pins
The three digital output pins GDO0, GDO1, and GDO2 are general control pins configured with
respectively. Table 34 shows the different
signals that can be monitored on the GDO pins. These signals can be used as inputs to the MCU. GDO1 is the same pin as the SO pin on the SPI interface, thus the output programmed on this pin will only be valid when
CSn is high. The default value for GDO1 is 3stated, which is useful when the SPI interface is shared with other devices.
The default value for GDO0 is a 135-141 kHz clock output (XOSC frequency divided by
192). Since the XOSC is turned on at poweron-reset, this can be used to clock the MCU in systems with only one crystal. When the MCU is up and running, it can change the clock
frequency by writing to IOCFG0.GDO0_CFG.
register. The voltage on the GDO0
pin is then proportional to temperature. See
Section 4.7 on page 16 for temperature sensor
specifications.
If the IOCFGx.GDOx_CFG setting is less than
0x20 and IOCFGx_GDOx_INV is 0 (1), the
GDO0 and GDO2 pins will be hardwired to 0
(1) and the GDO1 pin will be hardwired to 1
(0) in the SLEEP state. These signals will be
hardwired until the CHIP_RDYn signal goes
low.
If the IOCFGx.GDOx_CFG setting is 0x20 or
higher the GDO pins will work as programmed also in SLEEP state. As an example, GDO1 is high impedance in all states if
.
An on-chip analog temperature sensor is enabled by writing the value 128 (0x80) to the
SWRS038D Page 55 of 92
CC1100
GDOx
_CFG[5:0] Description
0 (0x00)
1 (0x01)
2 (0x02)
3 (0x03)
Associated to the RX FIFO: Asserts when RX FIFO is filled at or above the RX FIFO threshold. De-asserts when RX FIFO is drained below the same threshold.
Associated to the RX FIFO: Asserts when RX FIFO is filled at or above the RX FIFO threshold or the end of packet is reached. De-asserts when the RX FIFO is empty.
Associated to the TX FIFO: Asserts when the TX FIFO is filled at or above the TX FIFO threshold. De-asserts when the TX
FIFO is below the same threshold.
Associated to the TX FIFO: Asserts when TX FIFO is full. De-asserts when the TX FIFO is drained below theTX FIFO threshold.
4 (0x04) Asserts when the RX FIFO has overflowed. De-asserts when the FIFO has been flushed.
5 (0x05) Asserts when the TX FIFO has underflowed. De-asserts when the FIFO is flushed.
6 (0x06)
Asserts when sync word has been sent / received, and de-asserts at the end of the packet. In RX, the pin will de-assert when the optional address check fails or the RX FIFO overflows. In TX the pin will de-assert if the TX FIFO underflows.
7 (0x07) Asserts when a packet has been received with CRC OK. De-asserts when the first byte is read from the RX FIFO.
8 (0x08) Preamble Quality Reached. Asserts when the PQI is above the programmed PQT value.
9 (0x09) Clear channel assessment. High when RSSI level is below threshold (dependent on the current CCA_MODE setting)
10 (0x0A)
Lock detector output. The PLL is in lock if the lock detector output has a positive transition or is constantly logic high. To
11 (0x0B) check for PLL lock the lock detector output should be used as an interrupt for the MCU.
Serial Clock. Synchronous to the data in synchronous serial mode.
In RX mode, data is set up on the falling edge by
CC1100 when
GDOx_INV=
0
.
In TX mode, data is sampled by
CC1100 on the rising edge of the serial clock when
GDOx_INV=0
.
12 (0x0C) Serial Synchronous Data Output. Used for synchronous serial mode.
13 (0x0D) Serial Data Output. Used for asynchronous serial mode.
14 (0x0E) Carrier sense. High if RSSI level is above threshold.
15 (0x0F) CRC_OK. The last CRC comparison matched. Cleared when entering/restarting RX mode.
16 (0x10) Reserved – used for test.
17 (0x11) Reserved – used for test.
18 (0x12) Reserved – used for test.
19 (0x13) Reserved – used for test.
20 (0x14) Reserved – used for test.
21 (0x15) Reserved – used for test.
22 (0x16) RX_HARD_DATA[1]. Can be used together with RX_SYMBOL_TICK for alternative serial RX output.
23 (0x17) RX_HARD_DATA[0]. Can be used together with RX_SYMBOL_TICK for alternative serial RX output.
24 (0x18) Reserved – used for test.
25 (0x19) Reserved – used for test.
26 (0x1A) Reserved – used for test.
27 (0x1B)
PA_PD. Note: PA_PD will have the same signal level in SLEEP and TX states. To control an external PA or RX/TX switch
in applications where the SLEEP state is used it is recommended to use
28 (0x1C)
LNA_PD. Note: LNA_PD will have the same signal level in SLEEP and RX states. To control an external LNA or RX/TX switch in applications where the SLEEP state is used it is recommended to use
29 (0x1D) RX_SYMBOL_TICK. Can be used together with RX_HARD_DATA for alternative serial RX output.
30 (0x1E) Reserved – used for test.
31 (0x1F) Reserved – used for test.
32 (0x20) Reserved – used for test.
33 (0x21) Reserved – used for test.
34 (0x22) Reserved – used for test.
35 (0x23) Reserved – used for test.
36 (0x24) WOR_EVNT0
37 (0x25) WOR_EVNT1
38 (0x26) Reserved – used for test.
39 (0x27) CLK_32k
40 (0x28) Reserved – used for test.
41 (0x29) CHIP_RDYn
42 (0x2A) Reserved – used for test.
43 (0x2B) XOSC_STABLE
44 (0x2C) Reserved – used for test.
45 (0x2D)
GDO0
_Z_EN_N. When this output is 0, GDO0 is configured as input (for serial TX data).
46 (0x2E) High impedance (3-state)
47 (0x2F)
HW to 0 (HW1 achieved by setting
). Can be used to control an external LNA/PA or RX/TX switch.
48 (0x30) CLK_XOSC/1
49 (0x31) CLK_XOSC/1.5
50 (0x32) CLK_XOSC/2
51 (0x33) CLK_XOSC/3
52 (0x34) CLK_XOSC/4
53 (0x35) CLK_XOSC/6
54 (0x36) CLK_XOSC/8
55 (0x37) CLK_XOSC/12
56 (0x38) CLK_XOSC/16
57 (0x39) CLK_XOSC/24
58 (0x3A) CLK_XOSC/32
59 (0x3B) CLK_XOSC/48
60 (0x3C) CLK_XOSC/64
61 (0x3D) CLK_XOSC/96
62 (0x3E) CLK_XOSC/128
63 (0x3F) CLK_XOSC/192
Note: There are 3 GDO pins, but only one CLK_XOSC/n can be selected as an output at any time. If CLK_XOSC/n is to be monitored on one of the GDO pins, the other two GDO pins must be configured to values less than 0x30. The GDO0 default value is CLK_XOSC/192.
To optimize rf performance, these signal should not be used while the radio is in RX or TX mode.
Table 34: GDOx Signal Selection (x = 0, 1, or 2)
Page 56 of 92 SWRS038D
CC1100
31 Asynchronous and Synchronous Serial Operation
Several features and modes of operation have been included in the
CC1100 to provide backward compatibility with previous Chipcon products and other existing RF communication systems. For new systems, it is recommended to use the built-in packet handling features, as they can give more robust communication, significantly offload the microcontroller, and simplify software development.
For backward compatibility with systems already using the asynchronous data transfer from other Chipcon products, asynchronous transfer is also included in
CC1100. When asynchronous transfer is enabled, several of the support mechanisms for the MCU that are included in
CC1100 will be disabled, such as packet handling hardware, buffering in the
FIFO, and so on. The asynchronous transfer mode does not allow the use of the data whitener, interleaver, and FEC, and it is not possible to use Manchester encoding.
Note that MSK is not supported for asynchronous transfer.
Setting
to 3 enables asynchronous serial mode.
31.2 Synchronous Serial Operation
Setting
to 1 enables synchronous serial mode. In the synchronous serial mode, data is transferred on a two wire serial interface. The
CC1100 provides a clock that is used to set up new data on the data input line or sample data on the data output line. Data input (TX data) is the
GDO0 pin. This pin will automatically be configured as an input when TX is active. The data output pin can be any of the GDO pins;
this is set by the IOCFG0.GDO0_CFG,
fields.
Preamble and sync word insertion/detection may or may not be active, dependent on the
sync mode set by the MDMCFG2.SYNC_MODE.
If preamble and sync word is disabled, all other packet handler features and FEC should also be disabled. The MCU must then handle preamble and sync word insertion and detection in software. If preamble and sync word insertion/detection is left on, all packet handling features and FEC can be used. One exception is that the address filtering feature is unavailable in synchronous serial mode.
In TX, the GDO0 pin is used for data input (TX data). Data output can be on GDO0, GDO1, or
GDO2. This is set by the IOCFG0.GDO0_CFG,
fields.
The
CC1100 modulator samples the level of the asynchronous input 8 times faster than the programmed data rate. The timing requirement for the asynchronous stream is that the error in the bit period must be less than one eighth of the programmed data rate.
When using the packet handling features in synchronous serial mode, the
CC1100 will insert and detect the preamble and sync word and the MCU will only provide/get the data payload. This is equivalent to the recommended FIFO operation mode.
32 System Considerations and Guidelines
International regulations and national laws regulate the use of radio receivers and transmitters. Short Range Devices (SRDs) for license free operation below 1 GHz are usually operated in the 433 MHz, 868 MHz or 915
MHz frequency bands. The
CC1100 is specifically designed for such use with its 300 -
348 MHz, 400 - 464 MHz, and 800 - 928 MHz operating ranges. The most important regulations when using the
CC1100 in the 433
MHz, 868 MHz, or 915 MHz frequency bands are EN 300 220 (Europe) and FCC CFR47 part 15 (USA). A summary of the most important aspects of these regulations can be
found in Application Note AN001 [2].
Please note that compliance with regulations is dependent on complete system performance.
It is the customer’s responsibility to ensure that the system complies with regulations.
SWRS038D Page 57 of 92
Channel Systems
The 433 MHz, 868 MHz, or 915 MHz bands are shared by many systems both in industrial, office, and home environments. It is therefore recommended to use frequency hopping spread spectrum (FHSS) or a multi-channel protocol because the frequency diversity makes the system more robust with respect to interference from other systems operating in the same frequency band. FHSS also combats multipath fading.
CC1100 is highly suited for FHSS or multichannel systems due to its agile frequency synthesizer and effective communication interface. Using the packet handling support and data buffering is also beneficial in such systems as these features will significantly offload the host controller.
Charge pump current, VCO current, and VCO capacitance array calibration data is required for each frequency when implementing frequency hopping for
CC1100. There are 3 ways of obtaining the calibration data from the chip:
1) Frequency hopping with calibration for each hop. The PLL calibration time is approximately
720 µs. The blanking interval between each frequency hop is then approximately 810 us.
2) Fast frequency hopping without calibration for each hop can be done by calibrating each frequency at startup and saving the resulting
, FSCAL2, and FSCAL1 register values
in MCU memory. Between each frequency hop, the calibration process can then be
replaced by writing the FSCAL3, FSCAL2and
register values corresponding to the
next RF frequency. The PLL turn on time is approximately 90 µs. The blanking interval between each frequency hop is then approximately 90 us. The VCO current
calibration result available in FSCAL2 is not
dependent on the RF frequency. Neither is the charge pump current calibration result
available in FSCAL3. The same value can
therefore be used for all frequencies.
3) Run calibration on a single frequency at
startup. Next write 0 to FSCAL3[5:4] to
disable the charge pump calibration. After
writing to FSCAL3[5:4] strobe SRX (or STX)
with MCSM0.FS_AUTOCAL=1 for each new
frequency hop. That is, VCO current and VCO capacitance calibration is done but not charge pump current calibration. When charge pump current calibration is disabled the calibration
CC1100 time is reduced from approximately 720 µs to approximately 150 µs. The blanking interval between each frequency hop is then approximately 240 us.
There is a trade off between blanking time and memory space needed for storing calibration data in non-volatile memory. Solution 2) above gives the shortest blanking interval, but requires more memory space to store calibration values. Solution 3) gives approximately 570 µs smaller blanking interval than solution 1).
Note that the recommended settings for
frequency. This means that one should always use SmartRF
®
settings for a specific frequency before doing a calibration, regardless of which calibration method is being used.
It must be noted that the TESTn registers (n =
0, 1, or 2) content is not retained in SLEEP state, and thus it is necessary to re-write these registers when returning from the SLEEP state.
32.3 Wideband Modulation not Using
Spread Spectrum
Digital modulation systems under FFC part
15.247 includes 2-FSK and GFSK modulation.
A maximum peak output power of 1W (+30 dBm) is allowed if the 6 dB bandwidth of the modulated signal exceeds 500 kHz. In addition, the peak power spectral density conducted to the antenna shall not be greater than +8 dBm in any 3 kHz band.
Operating at high data rates and frequency separation, the
CC1100 is suited for systems targeting compliance with digital modulation system as defined by FFC part 15.247. An external power amplifier is needed to increase the output above +10 dBm.
32.4 Data Burst Transmissions
The high maximum data rate of
CC1100 opens up for burst transmissions. A low average data rate link (e.g. 10 kBaud), can be realized using a higher over-the-air data rate. Buffering the data and transmitting in bursts at high data rate (e.g. 500 kBaud) will reduce the time in active mode, and hence also reduce the average current consumption significantly.
Reducing the time in active mode will reduce the likelihood of collisions with other systems in the same frequency range.
SWRS038D Page 58 of 92
In data streaming applications the
CC1100 opens up for continuous transmissions at 500 kBaud effective data rate. As the modulation is done with a closed loop PLL, there is no limitation in the length of a transmission (open loop modulation used in some transceivers often prevents this kind of continuous data streaming and reduces the effective data rate).
CC1100
The
CC1100 has a very fine frequency
resolution (see Table 9). This feature can be
used to compensate for frequency offset and drift.
The frequency offset between an ‘external’ transmitter and the receiver is measured in the
CC1100 and can be read back from the
status register as described in
Section 14.1. The measured frequency offset
can be used to calibrate the frequency using the ‘external’ transmitter as the reference. That is, the received signal of the device will match the receiver’s channel filter better. In the same way the centre frequency of the transmitted signal will match the ‘external’ transmitter’s signal.
32.7 Spectrum Efficient Modulation
CC1100 also has the possibility to use Gaussian shaped 2-FSK (GFSK). This spectrum-shaping feature improves adjacent channel power
(ACP) and occupied bandwidth. In ‘true’ 2-FSK systems with abrupt frequency shifting, the spectrum is inherently broad. By making the frequency shift ‘softer’, the spectrum can be made significantly narrower. Thus, higher data rates can be transmitted in the same bandwidth using GFSK.
Antenna
As the
CC1100 provides 500 kBaud multichannel performance without any external filters, a very low cost system can be made.
A differential antenna will eliminate the need for a balun, and the DC biasing can be
achieved in the antenna topology, see Figure 3 and Figure 4.
A HC-49 type SMD crystal is used in the
CC1100EM reference designs ([5] and [6]).
Note that the crystal package strongly influences the price. In a size constrained PCB design a smaller, but more expensive, crystal may be used.
32.9 Battery Operated Systems
In low power applications, the SLEEP state with the crystal oscillator core switched off should be used when the
CC1100 is not active.
It is possible to leave the crystal oscillator core running in the SLEEP state if start-up time is critical.
The WOR functionality should be used in low power applications.
32.10 Increasing Output Power
In some applications it may be necessary to extend the link range. Adding an external power amplifier is the most effective way of doing this.
The power amplifier should be inserted between the antenna and the balun, and two
T/R switches are needed to disconnect the PA
Filter P
A
Balun
CC1100
T/R switch
T/R switch
Figure 30: Block Diagram of
CC1100 Usage with External Power Amplifier
SWRS038D Page 59 of 92
CC1100
The configuration of
CC1100 is done by programming 8-bit registers. The optimum configuration data based on selected system parameters are most easily found by using the
SmartRF
®
descriptions of the registers are given in the following tables. After chip reset, all the registers have default values as shown in the tables. The optimum register setting might differ from the default value. After a reset all registers that shall be different from the default value therefore needs to be programmed through the SPI interface.
There are 13 command strobe registers, listed
in Table 35. Accessing these registers will
initiate the change of an internal state or mode. There are 47 normal 8-bit configuration
registers, listed in Table 36. Many of these
registers are for test purposes only, and need not be written for normal operation of
CC1100.
Address Strobe
Name
Description
There are also 12 Status registers, which are
listed in Table 37. These registers, which are
read-only, contain information about the status of
CC1100.
The two FIFOs are accessed through one 8-bit register. Write operations write to the TX FIFO, while read operations read from the RX FIFO.
During the header byte transfer and while writing data to a register or the TX FIFO, a status byte is returned on the SO line. This
status byte is described in Table 17 on page
Table 38 summarizes the SPI address space.
The address to use is given by adding the base address to the left and the burst and read/write bits on the top. Note that the burst bit has different meaning for base addresses above and below 0x2F.
0x31 SFSTXON
Go to a wait state where only the synthesizer is running (for quick RX / TX turnaround).
0x32 SXOFF Turn off crystal oscillator.
0x33 SCAL
can be strobed from IDLE mode without
setting manual calibration mode (
0x34 SRX
0x35 STX
If in RX state and CCA is enabled: Only go to TX if channel is clear.
0x36
0x38
SIDLE
SWOR
Exit RX / TX, turn off frequency synthesizer and exit Wake-On-Radio mode if applicable.
Start automatic RX polling sequence (Wake-on-Radio) as described in Section 19.5 if
.
0x39 SPWD Enter power down mode when CSn goes high.
0x3A SFRX
in IDLE or, RXFIFO_OVERFLOW states.
0x3B SFTX
in IDLE or TXFIFO_UNDERFLOW states.
0x3C
0x3D
SWORRST Reset real time clock to Event1 value.
SNOP No operation. May be used to get access to the chip status byte.
Table 35: Command Strobes
SWRS038D Page 60 of 92
CC1100
0x15
0x16
0x17
0x18
0x1E
0x1F
0x20
0x21
0x22
0x23
0x24
0x25
0x26
0x27
0x28
0x29
Address Register Description
0x03
0x04
0x05
0x07
0x08
0x0B
0x0C
0x0D
0x0E
0x0F
0x2C
0x2D
0x2E
GDO2
output pin configuration
GDO1
output pin configuration
GDO0
output pin configuration
RX FIFO and TX FIFO thresholds
Sync word, high byte
Sync word, low byte
PKTCTRL1 Packet automation control
PKTCTRL0 Packet automation control
Frequency synthesizer control
Frequency synthesizer control
Frequency control word, high byte
Frequency control word, middle byte
Frequency control word, low byte
Modem deviation setting
Main Radio Control State Machine configuration
Main Radio Control State Machine configuration
Main Radio Control State Machine configuration
High byte Event 0 timeout
Low byte Event 0 timeout
Front end RX configuration
Front end TX configuration
Frequency synthesizer calibration
Frequency synthesizer calibration
Frequency synthesizer calibration
Frequency synthesizer calibration
RC oscillator configuration
RC oscillator configuration
Frequency synthesizer calibration control
Various test settings
Various test settings
Various test settings
Preserved in
SLEEP State
Details on
Page Number
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
No
No
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
Yes
No
No
No
No
Table 36: Configuration Registers Overview
SWRS038D Page 61 of 92
CC1100
Address
0x30 (0xF0)
0x31 (0xF1)
0x32 (0xF2)
0x33 (0xF3)
0x34 (0xF4)
0x35 (0xF5)
0x36 (0xF6)
0x37 (0xF7)
0x38 (0xF8)
Register
Description
Part number for
CC1100
Current version number
Frequency Offset Estimate
Demodulator estimate for Link Quality
Received signal strength indication
Control state machine state
High byte of WOR timer
0x39 (0xF9)
Low byte of WOR timer
Current GDOx status and packet status
Current setting from PLL calibration module
0x3A (0xFA)
Underflow and number of bytes in the TX
FIFO
Overflow and number of bytes in the RX
FIFO 0x3B (0xFB)
0x3C (0xFC)
Last RC oscillator calibration result
0x3D (0xFD)
Last RC oscillator calibration result
Table 37: Status Registers Overview
Details on page number
SWRS038D Page 62 of 92
CC1100
0x10
0x11
0x12
0x13
0x14
0x15
0x16
0x17
0x08
0x09
0x0A
0x0B
0x0C
0x0D
0x0E
0x0F
0x18
0x19
0x1A
0x1B
0x1C
Write Read
Single Byte Burst
0x00
0x01
0x02
+0x00 +0x40 +0x80 +0xC0
0x03
0x04
0x05
0x06
0x07
0x25
0x26
0x27
0x28
0x29
0x2A
0x2B
0x2C
0x2D
0x2E
0x1D
0x1E
0x1F
0x20
0x21
0x22
0x23
0x24
0x2F
0x30
0x31
0x32
0x33
0x34
0x35
0x36
0x37
0x38
0x39
0x3A
0x3B
0x3C
SWORRST SWORRST RCCTRL1_STATUS
0x3D
0x3E
0x3F
Table 38: SPI Address Space
Page 63 of 92 SWRS038D
CC1100
33.1 Configuration Register Details – Registers with preserved values in SLEEP state
Bit Field Name
7 Reserved
6
GDO2
_INV
5:0
GDO2
_CFG[5:0]
0x00: IOCFG2 – GDO2 Output Pin Configuration
Reset R/W Description
0
R0
R/W Invert output, i.e. select active low (1) / high (0)
41 (0x29) R/W
Bit
7
6
5:0
Field Name
GDO_DS
GDO1
_INV
GDO1
_CFG[5:0]
0x01: IOCFG1 – GDO1 Output Pin Configuration
Reset
0
0
R/W Description
R/W
R/W
Set high (1) or low (0) output drive strength on the GDO pins.
Invert output, i.e. select active low (1) / high (0)
46 (0x2E) R/W
Default is 3-state (See Table 34 on page 56).
Bit
7
6
5:0
0x02: IOCFG0 – GDO0 Output Pin Configuration
Field Name Reset R/W Description
TEMP_SENSOR_ENABLE
GDO0
GDO0
_INV
_CFG[5:0]
0 R/W Enable analog temperature sensor. Write 0 in all other register bits when using temperature sensor.
R/W Invert output, i.e. select active low (1) / high (0) 0
63 (0x3F) R/W
Default is CLK_XOSC/192 (See Table 34 on page 56).
It is recommended to disable the clock output in initialization, in order to optimize RF performance.
SWRS038D Page 64 of 92
CC1100
Bit
7:4
3:0
Field Name
Reserved
FIFO_THR[3:0]
0x03: FIFOTHR – RX FIFO and TX FIFO Thresholds
Reset
0
7 (0111)
R/W Description
R/W Write 0 for compatibility with possible future extensions
R/W Set the threshold for the TX FIFO and RX FIFO. The threshold is exceeded when the number of bytes in the FIFO is equal to or higher than the threshold value.
Setting Bytes in TX FIFO Bytes in RX FIFO
0 (0000)
1 (0001)
2 (0010)
3 (0011)
4 (0100)
5 (0101)
6 (0110)
7 (0111)
8 (1000)
9 (1001)
10 (1010)
11 (1011)
12 (1100)
13 (1101)
14 (1110)
15 (1111)
45
41
37
33
29
61
57
53
49
13
9
5
1
25
21
17
20
24
28
32
36
4
8
12
16
52
56
60
64
40
44
48
Bit Field Name
7:0 SYNC[15:8]
0x04: SYNC1 – Sync Word, High Byte
Reset R/W Description
211 (0xD3) R/W 8 MSB of 16-bit sync word
Bit Field Name
7:0 SYNC[7:0]
Bit
7:0
0x05: SYNC0 – Sync Word, Low Byte
Reset
145 (0x91)
R/W Description
R/W 8 LSB of 16-bit sync word
0x06: PKTLEN – Packet Length
Field Name Reset R/W Description
PACKET_LENGTH 255 (0xFF) R/W Indicates the packet length when fixed packet length mode is enabled.
If variable packet length mode is used, this value indicates the maximum packet length allowed.
SWRS038D Page 65 of 92
CC1100
Bit
7:5
Field Name
PQT[2:0]
4 Reserved
3
0
CRC_AUTOFLUSH 0
2
1:0
APPEND_STATUS 1
ADR_CHK[1:0]
0x07: PKTCTRL1 – Packet Automation Control
Reset
0 (0x00)
0 (00)
R/W Description
R/W Preamble quality estimator threshold. The preamble quality estimator increases an internal counter by one each time a bit is received that is different from the previous bit, and decreases the counter by 8 each time a bit is received that is the same as the last bit.
A threshold of 4·
PQT
for this counter is used to gate sync word detection.
When
PQT=0 a sync word is always accepted.
R0
R/W Enable automatic flush of RX FIFO when CRC in not OK. This requires that only one packet is in the RXIFIFO and that packet length is limited to the RX FIFO size.
R/W When enabled, two status bytes will be appended to the payload of the packet. The status bytes contain RSSI and LQI values, as well as CRC
OK.
R/W Controls address check configuration of received packages.
Setting Address check configuration
0 (00) No address check
1 (01) Address check, no broadcast
2 (10) Address check and 0 (0x00) broadcast
3 (11) Address check and 0 (0x00) and 255 (0xFF) broadcast
SWRS038D Page 66 of 92
CC1100
Bit Field Name
7 Reserved
6 WHITE_DATA
5:4 PKT_FORMAT[1:0]
0x08: PKTCTRL0 – Packet Automation Control
Reset
1
0 (00)
R/W Description
R0
R/W Turn data whitening on / off
0: Whitening off
1: Whitening on
R/W Format of RX and TX data
0
1
0 (00) Normal mode, use FIFOs for RX and TX
1 (01)
Synchronous serial mode, used for backwards compatibility. Data in on GDO0
2 (10)
3 (11)
R0
Random TX mode; sends random data using PN9 generator. Used for test.
Works as normal mode, setting 0 (00), in RX.
Asynchronous serial mode. Data in on GDO0 and
Data out on either of the GDO0 pins
3 Reserved
2 CRC_EN R/W 1: CRC calculation in TX and CRC check in RX enabled
0: CRC disabled for TX and RX
1:0 LENGTH_CONFIG[1:0] 1 R/W Configure the packet length
Setting Packet length configuration
0 (00) Fixed packet length mode. Length configured in
PKTLEN
register
1 (01) Variable packet length mode. Packet length configured by the first byte after sync word
2 (10) Infinite packet length mode
3 (11) Reserved
Bit Field Name
7:0 DEVICE_ADDR[7:0]
0x09: ADDR – Device Address
Reset R/W Description
0 (0x00) R/W Address used for packet filtration. Optional broadcast addresses are 0
(0x00) and 255 (0xFF).
Bit Field Name
7:0 CHAN[7:0]
0x0A: CHANNR – Channel Number
Reset
0 (0x00)
R/W Description
R/W The 8-bit unsigned channel number, which is multiplied by the channel spacing setting and added to the base frequency.
SWRS038D Page 67 of 92
CC1100
Bit Field Name
7:5 Reserved
4:0 FREQ_IF[4:0]
0x0B: FSCTRL1 – Frequency Synthesizer Control
Reset R/W Description
R0
15 (0x0F) R/W The desired IF frequency to employ in RX. Subtracted from FS base frequency in RX and controls the digital complex mixer in the demodulator.
f
IF
=
f
XOSC
2
10
⋅
FREQ
_
IF
The default value gives an IF frequency of 381kHz, assuming a 26.0 MHz crystal.
0x0C: FSCTRL0 – Frequency Synthesizer Control
Bit Field Name Reset
7:0 FREQOFF[7:0] 0 (0x00)
R/W Description
R/W Frequency offset added to the base frequency before being used by the frequency synthesizer. (2s-complement).
Resolution is F
XTAL
/2
14
(1.59kHz-1.65kHz); range is ±202 kHz to ±210 kHz, dependent of XTAL frequency.
Bit Field Name
7:0 FREQ[15:8]
0x0D: FREQ2 – Frequency Control Word, High Byte
Bit Field Name Reset R/W Description
7:6 FREQ[23:22] 0 R
FREQ[23:22]
is always 0 (the
FREQ2
register is less than 36 with 26-27
MHz crystal)
FREQ[23:22]
is the base frequency for the frequency synthesiser in increments of F
XOSC
/2
16
.
f carrier
=
f
XOSC
2
16
⋅
FREQ
[
23 : 0
]
0x0E: FREQ1 – Frequency Control Word, Middle Byte
Reset R/W Description
(0xC4)
FREQ2
register
Bit Field Name
7:0 FREQ[7:0]
0x0F: FREQ0 – Frequency Control Word, Low Byte
Reset R/W Description
236
FREQ2
register
SWRS038D Page 68 of 92
CC1100
0x10: MDMCFG4 – Modem Configuration
Bit Field Name Reset R/W Description
7:6 CHANBW_E[1:0] 2 R/W
5:4 CHANBW_M[1:0] 0 R/W Sets the decimation ratio for the delta-sigma ADC input stream and thus the channel bandwidth.
3:0 DRATE_E[3:0]
BW channel
=
8
⋅
( 4
+
f
XOSC
CHANBW
_
M
)· 2
CHANBW
_
E
The default values give 203 kHz channel filter bandwidth, assuming a 26.0
MHz crystal.
12 (0x0C) R/W The exponent of the user specified symbol rate
Bit Field Name
7:0 DRATE_M[7:0]
0x11: MDMCFG3 – Modem Configuration
Reset R/W Description
34 (0x22) R/W The mantissa of the user specified symbol rate. The symbol rate is configured using an unsigned, floating-point number with 9-bit mantissa and 4-bit exponent. The 9 th
bit is a hidden ‘1’. The resulting data rate is:
R
DATA
=
(
256
+
DRATE
_
M
)
⋅
2
DRATE
_
E
2
28
⋅
f
XOSC
The default values give a data rate of 115.051 kBaud (closest setting to
115.2 kBaud), assuming a 26.0 MHz crystal.
SWRS038D Page 69 of 92
Bit Field Name
CC1100
0x12: MDMCFG2 – Modem Configuration
Reset R/W Description
0 = Enable (better sensitivity)
1 = Disable (current optimized). Only for data rates
≤ 250 kBaud
The recommended IF frequency changes when the DC blocking is disabled. Please use SmartRF
®
Studio [7] to calculate correct register
setting.
0 (000) 2-FSK
1 (001) GFSK
2 (010) -
3 (011) ASK/OOK
4 (100) -
5 (101) -
6 (110) -
7 (111) MSK
ASK is only supported for output powers up to -1 dBm
MSK is only supported for datarates above 26 kBaud
2:0 SYNC_MODE[2:0]
0 = Disable
1 = Enable
2 (010) R/W Combined sync-word qualifier mode.
The values 0 (000) and 4 (100) disables preamble and sync word transmission in TX and preamble and sync word detection in RX.
The values 1 (001), 2 (010), 5 (101) and 6 (110) enables 16-bit sync word transmission in TX and 16-bits sync word detection in RX. Only 15 of 16 bits need to match in RX when using setting 1 (001) or 5 (101). The values
3 (011) and 7 (111) enables repeated sync word transmission in TX and
32-bits sync word detection in RX (only 30 of 32 bits need to match).
Setting Sync-word qualifier mode
0 (000) No preamble/sync
1 (001) 15/16 sync word bits detected
2 (010) 16/16 sync word bits detected
3 (011) 30/32 sync word bits detected
4 (100) No preamble/sync, carrier-sense above threshold
5 (101) 15/16 + carrier-sense above threshold
6 (110) 16/16 + carrier-sense above threshold
7 (111) 30/32 + carrier-sense above threshold
SWRS038D Page 70 of 92
CC1100
Bit
7
6:4
Field Name
FEC_EN
NUM_PREAMBLE[2:0]
3:2 Reserved
1:0 CHANSPC_E[1:0]
0x13: MDMCFG1– Modem Configuration
Reset
0
2 (010)
R/W Description
R/W Enable Forward Error Correction (FEC) with interleaving for packet payload
0 = Disable
1 = Enable (Only supported for fixed packet length mode, i.e.
)
R/W Sets the minimum number of preamble bytes to be transmitted
Setting
0 (000)
1 (001)
2 (010)
3 (011)
4 (100)
5 (101)
6 (110)
7 (111)
R0
12
16
24
3
4
6
8
Number of preamble bytes
2
Bit
7:0
Field Name
CHANSPC_M[7:0]
0x14: MDMCFG0– Modem Configuration
Reset
248 (0xF8)
R/W Description
R/W 8-bit mantissa of channel spacing. The channel spacing is
multiplied by the channel number
frequency. It is unsigned and has the format:
∆
f
CHANNEL
=
f
XOSC
2
18
⋅
(
256
+
CHANSPC
_
M
)
⋅
2
CHANSPC
_
E
The default values give 199.951 kHz channel spacing (the closest setting to 200 kHz), assuming 26.0 MHz crystal frequency.
SWRS038D Page 71 of 92
CC1100
Bit Field Name
7 Reserved
0x15: DEVIATN – Modem Deviation Setting
Reset R/W Description
R0
3 Reserved R0
2:0 DEVIATION_M[2:0] 7 When MSK modulation is enabled:
Sets fraction of symbol period used for phase change. Refer to the
SmartRF
®
Studio software [7] for correct deviation setting when using
MSK.
When 2-FSK/GFSK modulation is enabled:
Deviation mantissa, interpreted as a 4-bit value with MSB implicit 1. The resulting frequency deviation is given by:
f dev
=
f xosc
2
17
⋅
( 8
+
DEVIATION
_
M
)
⋅
2
DEVIATION
_
E
The default values give ±47.607 kHz deviation, assuming 26.0 MHz crystal frequency.
SWRS038D Page 72 of 92
CC1100
0x16: MCSM2 – Main Radio Control State Machine Configuration
Bit Field Name Reset R/W Description
7:5 Reserved
4 RX_TIME_RSSI 0
3 RX_TIME_QUAL 0
2:0 RX_TIME[2:0] 7 (111)
R0 Reserved
R/W Direct RX termination based on RSSI measurement (carrier sense). For
ASK/OOK modulation, RX times out if there is no carrier sense in the first 8 symbol periods.
R/W
RX_TIME
timer expires, the chip checks if sync word is found when
RX_TIME_QUAL=0
, or either sync word is found or PQI is set when
RX_TIME_QUAL=1.
R/W Timeout for sync word search in RX for both WOR mode and normal RX
operation. The timeout is relative to the programmed
The RX timeout in µs is given by
EVENT0
·C(
RX_TIME
,
) ·26/X, where C is given by the table below and X is
the crystal oscillator frequency in MHz:
Setting WOR_RES = 0 WOR_RES = 1 WOR_RES = 2 WOR_RES = 3
0 (000) 3.6058 18.0288 32.4519 46.8750
1 (001) 1.8029 9.0144 16.2260 23.4375
7 (111) Until end of packet
As an example,
EVENT0=34666
,
and
RX_TIME=6
corresponds to 1.96 ms RX timeout, 1 s polling interval and 0.195% duty cycle. Note that
should be 0 or 1 when using WOR because using
> 1 will give a very low duty cycle. In applications where WOR is not used all settings of
The duty cycle using WOR is approximated by:
Setting
WOR_RES=0 WOR_RES=1
0 (000) 12.50%
1 (001) 6.250%
2 (010) 3.125%
3 (011) 1.563%
4 (100) 0.781%
1.95%
9765ppm
4883ppm
2441ppm
NA
5 (101) 0.391%
6 (110) 0.195%
NA
NA
7 (111) NA
Note that the RC oscillator must be enabled in order to use setting 0-6, because the timeout counts RC oscillator periods. WOR mode does not need to be enabled.
The timeout counter resolution is limited: With
RX_TIME=0
, the timeout count is given by the 13 MSBs of
EVENT0
, decreasing to the 7MSBs of
EVENT0 with
RX_TIME=6
.
SWRS038D Page 73 of 92
CC1100
0x17: MCSM1– Main Radio Control State Machine Configuration
Bit Field Name Reset R/W Description
7:6 Reserved R0
5:4 CCA_MODE[1:0] 3
CCA_MODE
; Reflected in CCA signal
Setting Clear channel indication
0 (00) Always
1 (01) If RSSI below threshold
2 (10) Unless currently receiving a packet
3 (11) If RSSI below threshold unless currently receiving a packet
3:2 RXOFF_MODE[1:0] 0 (00) R/W Select what should happen when a packet has been received
Setting Next state after finishing packet reception
0 (00)
IDLE
1 (01) FSTXON
2 (10) TX
3 (11) Stay in RX
It is not possible to set
RXOFF_MODE
to be TX or FSTXON and at the same time use CCA.
1:0 TXOFF_MODE[1:0] 0 (00) R/W Select what should happen when a packet has been sent (TX)
Setting Next state after finishing packet transmission
0 (00) IDLE
1 (01) FSTXON
2 (10) Stay in TX (start sending preamble)
3 (11) RX
SWRS038D Page 74 of 92
CC1100
Bit Field Name
7:6 Reserved
5:4 FS_AUTOCAL[1:0]
3:2
0x18: MCSM0– Main Radio Control State Machine Configuration
PO_TIMEOUT
Reset R/W Description
R0
0 (00) R/W Automatically calibrate when going to RX or TX, or back to IDLE
Setting When to perform automatic calibration
0 (00) Never (manually calibrate using
SCAL
strobe)
1 (01) When going from IDLE to RX or TX (or FSTXON)
2 (10)
3 (11)
When going from RX or TX back to IDLE automatically
Every 4 th
time when going from RX or TX to IDLE automatically
In some automatic wake-on-radio (WOR) applications, using setting 3 (11) can significantly reduce current consumption.
1 (01) R/W Programs the number of times the six-bit ripple counter must expire after
XOSC has stabilized before
If XOSC is on (stable) during power-down,
PO_TIMEOUT
should be set so that the regulated digital supply voltage has time to stabilize before
PO_TIMEOUT=2
recommended). Typical start-up time for the voltage regulator is 50 us.
If XOSC is off during power-down and the regulated digital supply voltage has sufficient time to stabilize while waiting for the crystal to be stable,
PO_TIMEOUT
can be set to 0. For robust operation it is recommended to use
PO_TIMEOUT=2
.
Setting Expire count Timeout after XOSC start
0 (00) 1 Approx. 2.3 – 2.4 µs
1 (01) 16
2 (10) 64
Approx. 37 – 39 µs
Approx. 149 – 155 µs
3 (11) 256 Approx. 597 – 620 µs
Exact timeout depends on crystal frequency.
0 XOSC_FORCE_ON 0 R/W Force the XOSC to stay on in the SLEEP state.
SWRS038D Page 75 of 92
CC1100
0x19: FOCCFG – Frequency Offset Compensation Configuration
Bit Field Name Reset R/W Description
7:6 Reserved R0
5 FOC_BS_CS_GATE 1
4:3 FOC_PRE_K[1:0]
R/W If set, the demodulator freezes the frequency offset compensation and clock recovery feedback loops until the CS signal goes high.
2 (10) R/W The frequency compensation loop gain to be used before a sync word is detected.
2 FOC_POST_K 1
Setting Freq. compensation loop gain before sync word
0 (00)
K
1 (01) 2
K
2 (10) 3
K
3 (11) 4
K
R/W The frequency compensation loop gain to be used after a sync word is detected.
Setting Freq. compensation loop gain after sync word
1:0 FOC_LIMIT[1:0]
0 Same as FOC_PRE_K
1
K
/2
2 (10) R/W The saturation point for the frequency offset compensation algorithm:
Setting Saturation point (max compensated offset)
0 (00) ±0 (no frequency offset compensation)
1 (01) ±BW
CHAN
/8
2 (10) ±BW
CHAN
/4
3 (11) ±BW
CHAN
/2
Frequency offset compensation is not supported for ASK/OOK; Always use
FOC_LIMIT=0 with these modulation formats.
SWRS038D Page 76 of 92
CC1100
0x1A: BSCFG – Bit Synchronization Configuration
Bit Field Name Reset R/W Description
7:6 BS_PRE_KI[1:0] 1 (01) R/W The clock recovery feedback loop integral gain to be used before a sync word is detected (used to correct offsets in data rate):
Setting Clock recovery loop integral gain before sync word
0 (00)
K
I
1 (01) 2
K
I
2 (10) 3
K
I
3 (11) 4
K
I
5:4 BS_PRE_KP[1:0] 2 (10) R/W The clock recovery feedback loop proportional gain to be used before a sync word is detected.
Setting Clock recovery loop proportional gain before sync word
3 BS_POST_KI 1
0 (00)
K
P
1 (01) 2
K
P
2 (10) 3
K
P
3 (11) 4
K
P
R/W The clock recovery feedback loop integral gain to be used after a sync word is detected.
2 BS_POST_KP
1:0 BS_LIMIT[1:0]
1
Setting Clock recovery loop integral gain after sync word
0 Same as BS_PRE_KI
1
K
I
/2
R/W The clock recovery feedback loop proportional gain to be used after a sync word is detected.
Setting Clock recovery loop proportional gain after sync word
0 Same as BS_PRE_KP
1
K
P
0 (00) R/W The saturation point for the data rate offset compensation algorithm:
Setting Data rate offset saturation (max data rate difference)
0 (00) ±0 (No data rate offset compensation performed)
1 (01) ±3.125% data rate offset
2 (10) ±6.25% data rate offset
3 (11) ±12.5% data rate offset
SWRS038D Page 77 of 92
0x1B: AGCCTRL2 – AGC Control
Reset R/W Description
CC1100
Bit Field Name
5:3 MAX_LNA_GAIN[2:0]
2:0 MAGN_TARGET[2:0]
0 (00)
1 (01)
All gain settings can be used
The highest gain setting can not be used
2 (10) The 2 highest gain settings can not be used
3 (11) The 3 highest gain settings can not be used
0 (000) R/W Sets the maximum allowable LNA + LNA 2 gain relative to the maximum possible gain.
Setting Maximum allowable LNA + LNA 2 gain
0 (000) Maximum possible LNA + LNA 2 gain
1 (001) Approx. 2.6 dB below maximum possible gain
2 (010) Approx. 6.1 dB below maximum possible gain
3 (011) Approx. 7.4 dB below maximum possible gain
4 (100) Approx. 9.2 dB below maximum possible gain
5 (101) Approx. 11.5 dB below maximum possible gain
6 (110) Approx. 14.6 dB below maximum possible gain
7 (111) Approx. 17.1 dB below maximum possible gain
3 (011) R/W These bits set the target value for the averaged amplitude from the digital channel filter (1 LSB = 0 dB).
Setting Target amplitude from channel filter
0 (000)
1 (001)
2 (010)
3 (011)
4 (100)
5 (101)
6 (110)
7 (111)
24 dB
27 dB
30 dB
33 dB
36 dB
38 dB
40 dB
42 dB
SWRS038D Page 78 of 92
CC1100
0x1C: AGCCTRL1 – AGC Control
Bit Field Name Reset R/W Description
7 Reserved
6 AGC_LNA_PRIORITY 1
R0
R/W Selects between two different strategies for LNA and LNA 2 gain adjustment. When 1, the LNA gain is decreased first.
When 0, the LNA 2 gain is decreased to minimum before decreasing LNA gain.
5:4 CARRIER_SENSE_REL_THR[1:0] 0 (00) R/W Sets the relative change threshold for asserting carrier sense
3:0 CARRIER_SENSE_ABS_THR[3:0] 0
(0000)
0 (00)
1 (01)
Relative carrier sense threshold disabled
6 dB increase in RSSI value
2 (10) 10 dB increase in RSSI value
3 (11) 14 dB increase in RSSI value
R/W Sets the absolute RSSI threshold for asserting carrier sense.
The 2-complement signed threshold is programmed in steps of
1 dB and is relative to the MAGN_TARGET setting.
(Equal to channel filter amplitude when AGC has not decreased gain)
-8 (1000) Absolute carrier sense threshold disabled
-7 (1001) 7 dB below
MAGN_TARGET
setting
… …
-1 (1111)
1 dB below
MAGN_TARGET
setting
0 (0000)
At
MAGN_TARGET
setting
1 (0001)
1 dB above
MAGN_TARGET
setting
… …
7 (0111) 7 dB above
MAGN_TARGET
setting
SWRS038D Page 79 of 92
CC1100
Bit Field Name
7:6 HYST_LEVEL[1:0]
5:4 WAIT_TIME[1:0]
Reset
2 (10)
1 (01)
3:2 AGC_FREEZE[1:0] 0
1:0 FILTER_LENGTH[1:0] 1 (01)
0x1D: AGCCTRL0 – AGC Control
R/W Description
R/W Sets the level of hysteresis on the magnitude deviation (internal AGC signal that determine gain changes).
Setting Description
0 (00) No hysteresis, small symmetric dead zone, high gain
1 (01)
2 (10)
Low hysteresis, small asymmetric dead zone, medium gain
Medium hysteresis, medium asymmetric dead zone, medium gain
3 (11)
Large hysteresis, large asymmetric dead zone, low gain
R/W Sets the number of channel filter samples from a gain adjustment has been made until the AGC algorithm starts accumulating new samples.
Setting Channel filter samples
0 (00)
1 (01)
8
16
2 (10) 24
3 (11) 32
R/W Control when the AGC gain should be frozen.
Setting Function
0 (00) Normal operation. Always adjust gain when required.
1 (01)
The gain setting is frozen when a sync word has been found.
2 (10)
Manually freeze the analogue gain setting and continue to adjust the digital gain.
3 (11)
Manually freezes both the analogue and the digital gain setting. Used for manually overriding the gain.
R/W Sets the averaging length for the amplitude from the channel filter.
Sets the OOK/ASK decision boundary for OOK/ASK reception.
OOK decision samples
0 (00)
1 (01)
2 (10)
8
16
32
3 (11) 64
4 dB
8 dB
12 dB
16 dB
Bit Field Name
7:0 EVENT0[15:8]
0x1E: WOREVT1 – High Byte Event0 Timeout
Reset R/W Description
135
EVENT0
timeout register
t
Event
0
=
750
f
XOSC
⋅
EVENT
0
⋅
2
5
⋅
WOR
_
RES
SWRS038D Page 80 of 92
CC1100
0x1F: WOREVT0 –Low Byte Event0 Timeout
Bit Field Name Reset R/W Description
7:0 EVENT0[7:0] 107
EVENT0
timeout register.
The default
EVENT0
value gives 1.0s timeout, assuming a 26.0 MHz crystal.
Bit
7
6:4
Field Name
RC_PD
Reset
1
0x20: WORCTRL – Wake On Radio Control
EVENT1[2:0] 7 (111)
R/W Description
R/W Power down signal to RC oscillator. When written to 0, automatic initial calibration will be performed
R/W Timeout setting from register block. Decoded to Event 1 timeout. RC oscillator clock frequency equals F
XOSC
/750, which is 34.7 – 36 kHz, depending on crystal frequency. The table below lists the number of clock periods after Event 0 before Event 1 times out.
Setting t
Event1
0 (000) 4 (0.111 – 0.115 ms)
1 (001) 6 (0.167 – 0.173 ms)
2 (010) 8 (0.222 – 0.230 ms)
3 (011) 12 (0.333 – 0.346 ms)
4 (100) 16 (0.444 – 0.462 ms)
5 (101) 24 (0.667 – 0.692 ms)
6 (110) 32 (0.889 – 0.923 ms)
7 (111) 48 (1.333 – 1.385 ms)
3 RC_CAL 1
2 Reserved
1:0 WOR_RES 0 (00)
R0
R/W Controls the Event 0 resolution as well as maximum timeout of the WOR module and maximum timeout under normal RX operation::
Setting Resolution (1 LSB) Max timeout
0 (00) 1 period (28µs – 29µs) 1.8 – 1.9 seconds
1 (01) 2
5
periods (0.89ms –0.92 ms) 58 – 61 seconds
2 (10) 2
10
periods (28 – 30 ms)
3 (11) 2
15
periods (0.91 – 0.94 s)
31 – 32 minutes
16.5 – 17.2 hours
Note that
WOR_RES
should be 0 or 1 when using WOR because
WOR_RES
> 1 will give a very low duty cycle.
In normal RX operation all settings of
WOR_RES
can be used.
SWRS038D Page 81 of 92
CC1100
0x21: FREND1 – Front End RX Configuration
Reset R/W Description Bit Field Name
7:6 LNA_CURRENT[1:0]
5:4 LNA2MIX_CURRENT[1:0] 1 Adjusts front-end PTAT outputs
1:0 MIX_CURRENT[1:0] 2 (10) R/W Adjusts current in mixer
Bit Field Name
7:6 Reserved
3 Reserved
2:0 PA_POWER[2:0]
0x22: FREND0 – Front End TX Configuration
Reset R/W Description
R0 current TX LO buffer (input to PA). The value to use in this field is given by the SmartRF
®
Studio software
R0
0 (0x00) R/W Selects PA power setting. This value is an index to the
, which can be programmed with up to 8 different
PA settings. In OOK/ASK mode, this selects the
PATABLE index to use when transmitting a ‘1’.
index zero
is used in OOK/ASK when transmitting a ‘0’. The
settings from index ‘0’ to the
PA_POWER
value are used for
ASK TX shaping, and for power ramp-up/ramp-down at the start/end of transmission in all TX modulation formats.
Bit
7:6
Field Name
FSCAL3[7:6]
0x23: FSCAL3 – Frequency Synthesizer Calibration
Reset R/W Description
2 (0x02) R/W Frequency synthesizer calibration configuration. The value to write in this field before calibration is given by the
SmartRF
®
Studio software.
5:4 CHP_CURR_CAL_EN[1:0]
3:0 FSCAL3[3:0] 9 (1001) R/W Frequency synthesizer calibration result register. Digital bit vector defining the charge pump output current, on an exponential scale: IOUT =
I ·2
FSCAL3[3:0]/4
0
Fast frequency hopping without calibration for each hop can be done by calibrating upfront for each frequency and
values. Between each frequency hop, calibration can be
FSCAL1 register values corresponding to the next RF frequency.
SWRS038D Page 82 of 92
CC1100
0x24: FSCAL2 – Frequency Synthesizer Calibration
Bit Field Name Reset R/W Description
7:6 Reserved R0
5 VCO_CORE_H_EN 0
4:0 FSCAL2[4:0]
R/W Choose high (1) / low (0) VCO
10 (0x0A) R/W Frequency synthesizer calibration result register. VCO current calibration result and override value
Fast frequency hopping without calibration for each hop can be done by
calibrating upfront for each frequency and saving the resulting
register values. Between each frequency hop,
calibration can be replaced by writing the
FSCAL1 register values corresponding to the next RF frequency.
Bit Field Name
7:6 Reserved
5:0 FSCAL1[5:0]
0x25: FSCAL1 – Frequency Synthesizer Calibration
Reset R/W Description
R0
32 (0x20) R/W Frequency synthesizer calibration result register. Capacitor array setting for VCO coarse tuning.
Fast frequency hopping without calibration for each hop can be done by
calibrating upfront for each frequency and saving the resulting
register values. Between each frequency hop,
calibration can be replaced by writing the
FSCAL1 register values corresponding to the next RF frequency.
Bit Field Name
7 Reserved
6:0 FSCAL0[6:0]
0x26: FSCAL0 – Frequency Synthesizer Calibration
Reset R/W Description
R0
13 (0x0D) R/W Frequency synthesizer calibration control. The value to use in this register is given by the SmartRF
®
Bit Field Name
7 Reserved
6:0 RCCTRL1[6:0]
0x27: RCCTRL1 – RC Oscillator Configuration
Reset
0
R/W Description
R0
Bit Field Name
7 Reserved
6:0 RCCTRL0[6:0]
0x28: RCCTRL0 – RC Oscillator Configuration
Reset R/W Description
0 R0
0 R/W RC oscillator configuration.
SWRS038D Page 83 of 92
CC1100
33.2 Configuration Register Details – Registers that Lose Programming in SLEEP State
Bit Field Name
7:0 FSTEST[7:0]
0x29: FSTEST – Frequency Synthesizer Calibration Control
Reset R/W Description
89 (0x59) R/W For test only. Do not write to this register.
Bit Field Name
7:0 PTEST[7:0]
0x2A: PTEST – Production Test
Reset R/W Description
127 (0x7F) R/W Writing 0xBF to this register makes the on-chip temperature sensor available in the IDLE state. The default 0x7F value should then be written back before leaving the IDLE state.
Other use of this register is for test only.
Bit Field Name
7:0 AGCTEST[7:0]
0x2B: AGCTEST – AGC Test
Reset R/W Description
63 (0x3F) R/W For test only. Do not write to this register.
Bit Field Name
7:0 TEST2[7:0]
0x2C: TEST2 – Various Test Settings
Reset R/W Description
(0x88) R/W The value to use in this register is given by the SmartRF
®
Studio
0x2D: TEST1 – Various Test Settings
Reset R/W Description Bit Field Name
7:0 TEST1[7:0]
®
Studio
0x2E: TEST0 – Various Test Settings
Bit Field Name Reset R/W Description
7:2 TEST0[7:2]
1
2 R/W The value to use in this register is given by the SmartRF
®
Studio
VCO_SEL_CAL_EN 1
0 TEST0[0] 1
R/W Enable VCO selection calibration stage when 1
The value to use in this register is given by the SmartRF
®
Studio
SWRS038D Page 84 of 92
33.3 Status Register Details
CC1100
0x30 (0xF0): PARTNUM – Chip ID
Bit Field Name Reset R/W Description
7:0 PARTNUM[7:0] 0 (0x00) R Chip part number
Bit Field Name
7:0 VERSION[7:0]
0x31 (0xF1): VERSION – Chip ID
Reset R/W Description
3 (0x03) R Chip version number.
0x32 (0xF2): FREQEST – Frequency Offset Estimate from Demodulator
Bit Field Name
7:0 FREQOFF_EST
Reset R/W Description
R The estimated frequency offset (2’s complement) of the carrier. Resolution is
F
XTAL
/2
14
(1.59 - 1.65 kHz); range is ±202 kHz to ±210 kHz, dependent of XTAL frequency.
Frequency offset compensation is only supported for 2-FSK, GFSK, and MSK modulation. This register will read 0 when using ASK or OOK modulation.
Bit Field Name
7 CRC OK
0x33 (0xF3): LQI – Demodulator Estimate for Link Quality
Reset
6:0 LQI_EST[6:0]
R/W Description
R The last CRC comparison matched. Cleared when entering/restarting RX mode.
R The Quality Indicator estimates how easily a received signal can be demodulated. Calculated over the 64 symbols following the sync word
Bit Field Name
7:0 RSSI
0x34 (0xF4): RSSI – Received Signal Strength Indication
Reset R/W Description
R Received signal strength indicator
SWRS038D Page 85 of 92
CC1100
0x35 (0xF5): MARCSTATE – Main Radio Control State Machine State
Bit Field Name Reset R/W Description
7:5 Reserved
4:0 MARC_STATE[4:0]
R0
R Main Radio Control FSM State
Value State name State (Figure 16, page 42)
0 (0x00)
1 (0x01)
2 (0x02)
3 (0x03)
SLEEP
IDLE
XOFF
VCOON_MC
4 (0x04)
5 (0x05)
6 (0x06)
7 (0x07)
8 (0x08)
REGON_MC
MANCAL
VCOON
REGON
STARTCAL
9 (0x09) BWBOOST
10 (0x0A) FS_LOCK
SLEEP
IDLE
XOFF
MANCAL
MANCAL
MANCAL
FS_WAKEUP
FS_WAKEUP
CALIBRATE
SETTLING
SETTLING
11 (0x0B) IFADCON
12 (0x0C) ENDCAL
13 (0x0D) RX
14 (0x0E) RX_END
15 (0x0F) RX_RST
SETTLING
CALIBRATE
RX
RX
RX
16 (0x10) TXRX_SWITCH TXRX_SETTLING
17 (0x11) RXFIFO_OVERFLOW RXFIFO_OVERFLOW
18 (0x12) FSTXON FSTXON
19 (0x13) TX
20 (0x14) TX_END
TX
TX
21 (0x15) RXTX_SWITCH RXTX_SETTLING
22 (0x16) TXFIFO_UNDERFLOW TXFIFO_UNDERFLOW
Note: it is not possible to read back the SLEEP or XOFF state numbers because setting CSn low will make the chip enter the IDLE mode from the
SLEEP or XOFF states.
Bit Field Name
7:0 TIME[15:8]
0x36 (0xF6): WORTIME1 – High Byte of WOR Time
Reset R/W Description
Bit
7:0
Field Name
TIME[7:0]
0x37 (0xF7): WORTIME0 – Low Byte of WOR Time
Reset R/W Description
R Low byte of timer value in WOR module
SWRS038D Page 86 of 92
CC1100
6 CS
5 PQT_REACHED
4 CCA
3 SFD
2
GDO2
1 Reserved
0
GDO0
0x38 (0xF8): PKTSTATUS – Current GDOx Status and Packet Status
Bit Field Name
7 CRC_OK
Reset R/W Description
R The last CRC comparison matched. Cleared when entering/restarting RX mode.
R
R
R
R
Preamble Quality reached
Channel is clear
Sync word found
Current GDO2 value. Note: the reading gives the non-inverted value
It is not recommended to check for PLL lock by reading
R0
R Current GDO0 value. Note: the reading gives the non-inverted value
It is not recommended to check for PLL lock by reading
0x39 (0xF9): VCO_VC_DAC – Current Setting from PLL Calibration Module
Bit Field Name
7:0 VCO_VC_DAC[7:0]
Reset R/W Description
R Status register for test only.
0x3A (0xFA): TXBYTES – Underflow and Number of Bytes
Bit Field Name
7 TXFIFO_UNDERFLOW
6:0 NUM_TXBYTES
Reset R/W Description
R
R Number of bytes in TX FIFO
0x3B (0xFB): RXBYTES – Overflow and Number of Bytes
Bit Field Name Reset R/W Description
7 RXFIFO_OVERFLOW
6:0 NUM_RXBYTES
R
R Number of bytes in RX FIFO
0x3C (0xFC): RCCTRL1_STATUS – Last RC Oscillator Calibration Result
Bit Field Name Reset R/W Description
7 Reserved
6:0 RCCTRL1_STATUS[6:0]
R0
R Contains the value from the last run of the RC oscillator calibration routine.
For usage description refer to AN047 [4]
SWRS038D Page 87 of 92
CC1100
0x3D (0xFC): RCCTRL0_STATUS – Last RC Oscillator Calibration Result
Bit Field Name Reset R/W Description
7 Reserved
6:0 RCCTRL0_STATUS[6:0]
R0
R Contains the value from the last run of the RC oscillator calibration routine.
For usage description refer to Aplication Note AN047 [4].
34 Package Description (QLP 20)
34.1 Recommended PCB Layout for Package (QLP 20)
Figure 31: Recommended PCB Layout for QLP 20 Package
symmetrically in the ground pad under the package. See also the CC1100EM reference designs
The recommendations for lead-free reflow in IPC/JEDEC J-STD-020 should be followed.
SWRS038D Page 88 of 92
CC1100
Orderable
Device
Status
(1)
Package
Type
Package
Drawing
Pins
Package
Qty
Eco Plan (2)
CC1100RTKR NRND RTK 3000
Green (RoHS & no Sb/Br)
Lead
Finish
Cu NiPdAu
Green (RoHS & no Sb/Br)
Cu NiPdAu
MSL Peak
Temp (3)
LEVEL3-260C
1 YEAR
LEVEL3-260C
1 YEAR
Table 39: Ordering Information
SWRS038D Page 89 of 92
CC1100
36 References
[1] CC1100 Errata Notes (swrz012.pdf)
[2] AN001 SRD Regulations for Licence Free Transceiver Operation (swra090.pdf)
[3] AN039 Using the CC1100 in the European 433 and 868 MHz ISM Bands (swra054.pdf)
[4] AN047 CC1100/CC2500 – Wake-On-Radio (swra126.pdf)
[5] CC1100EM 315 - 433 MHz Reference Design 1.0 (swrr037.zip)
[6] CC1100EM 868 – 915 MHz Reference Design 2.0 (swrr038.zip)
[7] SmartRF
®
Studio (swrc046.zip)
[8] CC1100 CC2500 Examples Libraries (swrc021.zip)
[9] CC1100/CC1150DK, CC1101DK, and CC2500/CC2550DK Examples and Libraries User
Manual (swru109.pdf)
SWRS038D Page 90 of 92
CC1100
Revision Date Description/Changes
SWRS038D 2009-05-26 Updated packet and ordering information.
Removed Product Status Definition, Address Information and TI World Wide Support section.
Removed Low-Cost from datasheet title.
SWRS038C 2008-05-22 Added product information on front page
SWRS038B 2007-07-09
Changes in the
General Principle of Matrix Interleaving
figure.
Changes in Table:
Bill Of Materials for the Application Circuit
Changes in Figure:
Typical Application and Evaluation Circuit 868/915 MHz
Changed the equation for channel spacing in the MDMCFG0 register. kbps replaced by kBaud throughout the document.
Some of the sections have been re-written to be easier to read without having any new info added.
Absolute maximum supply voltage rating increased from 3.6 V to 3.9 V.
Changed the frequency accuracy after calibration for the low power RC oscillator from ±0.3 to
±1 %.
Updates to sensitivity and current consumption numbers listed under
Key Features
.
FSK changed to 2-FSK throughout the document.
Updates to the
Abbreviation
table.
Updates to the
Electrical Specifications
section.
Added info about RX and TX latency.
Added info in the
Pinout Overview
table regarding GDO0 and GDO2.
Changed current consumption in RX and TX in the simplified state diagram.
Added info about default values after reset vs. optimum register settings in the
Configuration
Software
section
Changes to the
SPI Interface Timing Requirements
.
Info added about t sp,pd
The following figures have been changed:
Configuration Registers Write and Read Operations
,
, and
Register Access Types
.
In the
Register Access
section, the address range is changed.
In the
PATABLE Access
section, info is added regarding limitations on output power programming when using PA ramping.
In the
Packet Format
section, preamble pattern is changed to 10101010 and info about bug related to turning off the transmitter in infinite packet length mode is added.
Added info to the
Frequency Offset Compensation
section.
Added info about the initial value of the PN9 sequence in the
Data Whitening
section.
In the
Packet Handling in Transmit Mode
section, info about TX FIFO underflow state is added.
Added section
Packet Handling in Firmware
.
0x00 is added as a valid PATABLE setting in addition to 0x30-0x3F when using ASK.
In the PQT section a change is made as to how much the counter decreases.
The RSSI value is in dBm and not dB.
The whole
CS Absolute Threshold
section has been re-written and the equation calculating the threshold has been removed.
Added info in the CCA section on what happens if the channel is not clear.
Added info to the LQI section for better understanding.
Removed all references to the voltage regulator in relation with the CHP_RDYn signal, as this signal is only related to the crystal.
Removed references to the voltage regulator in the figures:
Power-On Reset
and
Power-On
Reset with SRES
. Changes to the SI line in the
Power-On Reset with SRES
figure
Added info on the three automatic calibration options.
Removed the autosync feature from the WOR section and added info on how to exit WOR mode .
Also added info about minimum sleep time and references to App. Note 047 together with info about calibration of the RC oscillator.
The figure:
Event 0 and Event 1 Relationship
is changed for better readability.
Info added to the
Timing
section related to reduced calibration time.
The
Output Power Programming
section is divided into 2 new sections;
Output Power
Programming
and
Shaping and PA Ramping
.
Added info on programming of PATABLE when using OOK, and about PATABLE when entering
SLEEP mode.
2 new figures added to the
Shaping and PA Ramping
section:
Shaping of ASK Signa
l and
PA
Ramping
, together with one new table:
PATABLE Settings Used Together with ASK Shaping and PA Ramping
.
Changed made to current consumption in the
Optimum PATABLE Settings for Various Output
Power Levels and Frequency Bands
table.
Added section
Layout Recommendations.
In section
General Purpose / Test Output Control Pins
: Added info on GDO pins in SLEEP
SWRS038D Page 91 of 92
CC1100
Revision Date Description/Changes
state.
Better explanation of some of the signals in the
GDOx Signal Selection
table. Also added some more signals.
Asynchronous transparent mode is called asynchronous serial mode throughout the document.
Removed comments about having to use NRZ coding in synchronous serial mode. Added info that Manschester encoding cannot be used in this mode.
Added a third calibration method plus additional info about the 3 methods in the
Frequency
Hopping and Multi-Channel Systems
section.
Added info about differential antenna in the
Low Cost Systems
section.
Changes number of commands strobes from 14 to 13.
Changed description of SFRX, SFTX, SWORRST, and SNOP in the
Command Strobes
table.
Added two new registers; RCCTRL1_STATUS and RCCTRL0_STATUS
Changed field name and/or description of the following registers:
PKTCTRL1, MCSM2, MCSM0, WORCTRL, FSCAL3, FSCAL2, FSCAL1, and TEST0.
Changed tray width in the
Tray Specification
table.
Added references.
SWRS038A 2006-06-20
Electrical Specifications
due to increased amount of measurement data.
Updated application circuit for 868 MHz. Updated balun component values.
Updated current consumption figures in state diagrams.
Added figures to table on SPI interface timing requirements.
Added information about SPI read.
Added table for channel filter bandwidths.
Added figure showing data whitening.
Updates to text and included new figure in section on arbitrary length configuration.
References to SAFC strobe removed.
Added additional information about support of ASK modulation.
Added information about CRC filtering.
Added information about sync word qualifier.
Added information on RSSI offset, RSSI update rate, RSSI calculation and typical RSSI curves.
Added information on CS and tables with register settings versus CS threshold.
Updates to text and included new figures in section on power-on start-up sequence.
Changes to wake-on-radio current consumption figures under electrical specifications.
Updates to text in section on data FIFO.
Corrected formula for calculation of output frequency in
Frequency Programming
section.
Added information about how to check for PLL lock in section on VCO.
Corrected table with PATABLE setting versus output power.
Added typical selectivity curves for selected datarates.
Added information on how to interface external clock signal.
Added optimal match impedances in RF match section.
Better explanation of some of the signals in table of GDO signal selection. Also added some more signals.
Added information on system considerations.
Added CRC_AUTOFLUSH option in PCTRL1 register.
Added information on timeout for sync word search in RX in register MCSM2.
Changes to wake-on-radio control register WORCTRL. WOR_RES[1:0] settings 10 b and 11b changed to NA.
Added more detailed information on PO_TIMEOUT in register MCSM0.
Added description of programming bits in registers FOCCFG, BSCFG, AGCCTRL2,
AGCCTRL1, AGCCTRL0, FREND1, FSCAL3.
1.0 2005-04-25 First preliminary Data Sheet release
Table 40: Document History
SWRS038D Page 92 of 92
PACKAGE OPTION ADDENDUM
20-Jul-2009 www.ti.com
PACKAGING INFORMATION
Orderable Device
CC1100-RTR1
CC1100-RTY1
CC1100RTK
CC1100RTKG3
CC1100RTKR
CC1100RTKRG3
Status
NRND
NRND
NRND
NRND
NRND
NRND
(1)
Package
Type
QFN
QFN
QFN
QFN
QFN
QFN
Package
Drawing
RTK
RTK
RTK
RTK
RTK
RTK
Eco Plan
(2)
Pins Package
Qty
20 3000 Green (RoHS & no Sb/Br)
Lead/Ball Finish MSL Peak Temp
(3)
CU SN Level-3-260C-168 HR
20 CU SN Level-3-260C-168 HR
20
92 Green (RoHS & no Sb/Br)
92 Green (RoHS & no Sb/Br)
CU SN Level-3-260C-168 HR
20 CU SN Level-3-260C-168 HR
20
20
92 Green (RoHS & no Sb/Br)
3000 Green (RoHS & no Sb/Br)
3000 Green (RoHS & no Sb/Br)
CU SN
CU SN
Level-3-260C-168 HR
Level-3-260C-168 HR
(1)
The marketing status values are defined as follows:
ACTIVE: Product device recommended for new designs.
LIFEBUY: TI has announced that the device will be discontinued, and a lifetime-buy period is in effect.
NRND: Not recommended for new designs. Device is in production to support existing customers, but TI does not recommend using this part in a new design.
PREVIEW: Device has been announced but is not in production. Samples may or may not be available.
OBSOLETE: TI has discontinued the production of the device.
(2)
Eco Plan - The planned eco-friendly classification: Pb-Free (RoHS), Pb-Free (RoHS Exempt), or Green (RoHS & no Sb/Br) - please check http://www.ti.com/productcontent for the latest availability information and additional product content details.
TBD: The Pb-Free/Green conversion plan has not been defined.
Pb-Free (RoHS): TI's terms "Lead-Free" or "Pb-Free" mean semiconductor products that are compatible with the current RoHS requirements for all 6 substances, including the requirement that lead not exceed 0.1% by weight in homogeneous materials. Where designed to be soldered at high temperatures, TI Pb-Free products are suitable for use in specified lead-free processes.
Pb-Free (RoHS Exempt): This component has a RoHS exemption for either 1) lead-based flip-chip solder bumps used between the die and package, or 2) lead-based die adhesive used between the die and leadframe. The component is otherwise considered Pb-Free (RoHS compatible) as defined above.
Green (RoHS & no Sb/Br): TI defines "Green" to mean Pb-Free (RoHS compatible), and free of Bromine (Br) and Antimony (Sb) based flame retardants (Br or Sb do not exceed 0.1% by weight in homogeneous material)
(3)
MSL, Peak Temp. -- The Moisture Sensitivity Level rating according to the JEDEC industry standard classifications, and peak solder temperature.
Important Information and Disclaimer:The information provided on this page represents TI's knowledge and belief as of the date that it is provided. TI bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. TI has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release.
In no event shall TI's liability arising out of such information exceed the total purchase price of the TI part(s) at issue in this document sold by TI to Customer on an annual basis.
Addendum-Page 1
IMPORTANT NOTICE
Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI’s terms and conditions of sale supplied at the time of order acknowledgment.
TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI’s standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.
TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.
TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.
Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.
Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.
TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.
TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.
TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.
Following are URLs where you can obtain information on other Texas Instruments products and application solutions:
Products
Amplifiers
Data Converters
DLP® Products
DSP
Clocks and Timers
Interface
Logic
Power Mgmt
Microcontrollers
RFID amplifier.ti.com
dataconverter.ti.com
www.dlp.com
dsp.ti.com
www.ti.com/clocks interface.ti.com
logic.ti.com
power.ti.com
microcontroller.ti.com
www.ti-rfid.com
RF/IF and ZigBee® Solutions www.ti.com/lprf
Applications
Audio
Automotive
Broadband
Digital Control
Medical
Military
Optical Networking
Security
Telephony
Video & Imaging
Wireless www.ti.com/audio www.ti.com/automotive www.ti.com/broadband www.ti.com/digitalcontrol www.ti.com/medical www.ti.com/military www.ti.com/opticalnetwork www.ti.com/security www.ti.com/telephony www.ti.com/video www.ti.com/wireless
Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265
Copyright © 2009, Texas Instruments Incorporated
* Your assessment is very important for improving the work of artificial intelligence, which forms the content of this project