Low-Power Sub-1 GHZ RF Transceiver: Applications

Download as pdf or txt
Download as pdf or txt
You are on page 1of 105

CC1101

Low-Power Sub-1 GHz RF Transceiver


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
Wireless MBUS

Product Description

16

17

The CC1190 850-950 MHz range extender [21]


can be used with CC1101
in long range
applications for improved sensitivity and higher
output power.

18

The RF transceiver is integrated with a highly


configurable baseband modem. The modem
supports various modulation formats and has
a configurable data rate up to 600 kbps.

microcontroller and a few additional passive


components.

19

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, 387-464 MHz
and 779-928 MHz bands.

20

CC1101 is a low-cost sub-1 GHz transceiver

1
2

15

CC1101

14
13

10

11

12

for packet handling, data buffering, burst


transmissions, clear channel assessment, link
quality indication, and wake-on-radio.

CC1101 provides extensive hardware support

The main operating parameters and the 64byte transmit/receive FIFOs of CC1101 can be
controlled via an SPI interface. In a typical
system, the CC1101 will be used together with a

SWRS061I

Page 1 of 98

CC1101
Key Features
RF Performance

Low-Power Features

High sensitivity
o -116 dBm at 0.6 kBaud, 433 MHz,
1% packet error rate
o -112 dBm at 1.2 kBaud, 868 MHz,
1% packet error rate
Low current consumption (14.7 mA in RX,
1.2 kBaud, 868 MHz)
Programmable output power up to +12
dBm for all supported frequencies
Excellent receiver selectivity and blocking
performance
Programmable data rate from 0.6 to 600
kbps
Frequency bands: 300-348 MHz, 387-464
MHz and 779-928 MHz

2-FSK, 4-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; 75 s settling time
Automatic
Frequency
Compensation
(AFC) can be used to align the frequency
synthesizer to the received signal centre
frequency
Integrated analog temperature sensor

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)
Suited for systems targeting compliance
with the Wireless MBUS standard
EN 13757-4:2005
Support
for
asynchronous
and
synchronous serial receive/transmit mode
for backwards compatibility with existing
radio communication protocols

Improved Range using CC1190

Digital Features

Analog Features

200 nA sleep mode current consumption


Fast startup time; 240 s from sleep to RX
or TX mode (measured on EM reference
design [1] and [2])
Wake-on-radio functionality for automatic
low-power RX polling
Separate 64-byte RX and TX data FIFOs
(enables burst mode data transmission)

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

SWRS061I

The CC1190 [21] is a range extender for


850-950 MHz and is an ideal fit for CC1101
to enhance RF performance
High sensitivity
o -118 dBm at 1.2 kBaud, 868 MHz,
1% packet error rate
o -120 dBm at 1.2 kBaud, 915 MHz,
1% packet error rate
+20 dBm output power at 868 MHz
+27 dBm output power at 915 MHz
Refer to AN094 [22] and AN096 [23] for
more performance figures of the CC1101 +
CC1190 combination

Page 2 of 98

CC1101
Reduced Battery Current using
TPS62730

The TPS62730 [26] is a step down


converter with bypass mode for ultra low
power wireless applications.
In RX, the current drawn from a 3.6 V
battery is typically less than 11 mA when
TPS62730 output voltage is 2.1 V. When
connecting CC1101 directly to a 3.6 V
battery the current drawn is typically 17
mA (see Figure 1)
In TX, at maximum output power (+12
dBm), the current drawn from a 3.6 V

battery is typically 22 mA when TPS62730


output voltage is 2.1 V. When connecting
CC1101 directly to a 3.6 V battery the
current drawn is typically 34 mA (see
Figure 2).
When CC1101 enters SLEEP mode, the
TPS62730 can be put in bypass mode for
very low power down current
The typical TPS62730 current consumption
is 30 nA in bypass mode.
The CC1101 is connected to the battery via
an integrated 2.1 (typical) switch in
bypass mode

Figure 1: Typical RX Battery Current vs Battery Voltage

Figure 2: Typical TX Battery Current vs Battery Voltage at Maximum CC1101 Output Power (+12
dBm)

SWRS061I

Page 3 of 98

CC1101
Abbreviations
Abbreviations used in this data sheet are described below.
2-FSK
4-FSK
ACP
ADC
AFC
AGC
AMR
ASK
BER
BT
CCA
CFR
CRC
CS
CW
DC
DVGA
ESR
FCC
FEC
FIFO
FHSS
FS
GFSK
IF
I/Q
ISM
LC
LNA
LO
LSB
LQI
MCU

Binary Frequency Shift Keying


Quaternary Frequency Shift Keying
Adjacent Channel Power
Analog to Digital Converter
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
Carrier Sense
Continuous Wave (Unmodulated Carrier)
Direct Current
Digital Variable Gain Amplifier
Equivalent Series Resistance
Federal Communications Commission
Forward Error Correction
First-In-First-Out
Frequency Hopping Spread Spectrum
Frequency Synthesizer
Gaussian shaped Frequency Shift Keying
Intermediate Frequency
In-Phase/Quadrature
Industrial, Scientific, Medical
Inductor-Capacitor
Low Noise Amplifier
Local Oscillator
Least Significant Bit
Link Quality Indicator
Microcontroller Unit

SWRS061I

MSB
MSK
N/A
NRZ
OOK
PA
PCB
PD
PER
PLL
POR
PQI
PQT
PTAT
QLP
QPSK
RC
RF
RSSI
RX
SAW
SMD
SNR
SPI
SRD
TBD
T/R
TX
UHF
VCO
WOR
XOSC
XTAL

Most Significant Bit


Minimum Shift Keying
Not Applicable
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
Preamble Quality Threshold
Proportional To Absolute Temperature
Quad Leadless Package
Quadrature Phase Shift Keying
Resistor-Capacitor
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/Receive
Transmit, Transmit Mode
Ultra High frequency
Voltage Controlled Oscillator
Wake on Radio, Low power polling
Crystal Oscillator
Crystal

Page 4 of 98

CC1101
Table Of Contents
APPLICATIONS .................................................................................................................................................. 1
PRODUCT DESCRIPTION ................................................................................................................................ 1
KEY FEATURES ................................................................................................................................................. 2
RF PERFORMANCE .......................................................................................................................................... 2
ANALOG FEATURES ........................................................................................................................................ 2
DIGITAL FEATURES......................................................................................................................................... 2
LOW-POWER FEATURES ................................................................................................................................ 2
GENERAL ............................................................................................................................................................ 2
IMPROVED RANGE USING CC1190 .............................................................................................................. 2
REDUCED BATTERY CURRENT USING TPS62730 .................................................................................... 3
ABBREVIATIONS ............................................................................................................................................... 4
TABLE OF CONTENTS ..................................................................................................................................... 5
1
ABSOLUTE MAXIMUM RATINGS ..................................................................................................... 8
2
OPERATING CONDITIONS ................................................................................................................. 8
3
GENERAL CHARACTERISTICS ......................................................................................................... 8
4
ELECTRICAL SPECIFICATIONS ....................................................................................................... 9
4.1
CURRENT CONSUMPTION ............................................................................................................................ 9
4.2
RF RECEIVE SECTION ................................................................................................................................ 12
4.3
RF TRANSMIT SECTION ............................................................................................................................. 16
4.4
CRYSTAL OSCILLATOR .............................................................................................................................. 18
4.5
LOW POWER RC OSCILLATOR ................................................................................................................... 18
4.6
FREQUENCY SYNTHESIZER CHARACTERISTICS .......................................................................................... 19
4.7
ANALOG TEMPERATURE SENSOR .............................................................................................................. 19
4.8
DC CHARACTERISTICS .............................................................................................................................. 20
4.9
POWER-ON RESET ..................................................................................................................................... 20
5
PIN CONFIGURATION ........................................................................................................................ 20
6
CIRCUIT DESCRIPTION .................................................................................................................... 22
7
APPLICATION CIRCUIT .................................................................................................................... 22
7.1
BIAS RESISTOR .......................................................................................................................................... 22
7.2
BALUN AND RF MATCHING ....................................................................................................................... 23
7.3
CRYSTAL ................................................................................................................................................... 23
7.4
REFERENCE SIGNAL .................................................................................................................................. 23
7.5
ADDITIONAL FILTERING ............................................................................................................................ 24
7.6
POWER SUPPLY DECOUPLING .................................................................................................................... 24
7.7
ANTENNA CONSIDERATIONS ..................................................................................................................... 24
7.8
PCB LAYOUT RECOMMENDATIONS ........................................................................................................... 26
8
CONFIGURATION OVERVIEW ........................................................................................................ 27
9
CONFIGURATION SOFTWARE ........................................................................................................ 29
10
4-WIRE SERIAL CONFIGURATION AND DATA INTERFACE .................................................. 29
10.1 CHIP STATUS BYTE ................................................................................................................................... 31
10.2 REGISTER ACCESS ..................................................................................................................................... 31
10.3 SPI READ .................................................................................................................................................. 32
10.4 COMMAND STROBES ................................................................................................................................. 32
10.5 FIFO ACCESS ............................................................................................................................................ 32
10.6 PATABLE ACCESS ................................................................................................................................... 33
11
MICROCONTROLLER INTERFACE AND PIN CONFIGURATION .......................................... 34
11.1 CONFIGURATION INTERFACE ..................................................................................................................... 34
11.2 GENERAL CONTROL AND STATUS PINS ..................................................................................................... 34
11.3 OPTIONAL RADIO CONTROL FEATURE ...................................................................................................... 34
12
DATA RATE PROGRAMMING.......................................................................................................... 35

SWRS061I

Page 5 of 98

CC1101
13
14
14.1
14.2
14.3
15
15.1
15.2
15.3
15.4
15.5
15.6
16
16.1
16.2
16.3
17
17.1
17.2
17.3
17.4
17.5
17.6
18
18.1
18.2
19
19.1
19.2
19.3
19.4
19.5
19.6
19.7
20
21
22
22.1
23
24
25
26
27
27.1
27.2
28
28.1
28.2
28.3
28.4
28.5
28.6
28.7
28.8

RECEIVER CHANNEL FILTER BANDWIDTH .............................................................................. 35


DEMODULATOR, SYMBOL SYNCHRONIZER, AND DATA DECISION .................................. 36
FREQUENCY OFFSET COMPENSATION........................................................................................................ 36
BIT SYNCHRONIZATION ............................................................................................................................. 36
BYTE SYNCHRONIZATION .......................................................................................................................... 36
PACKET HANDLING HARDWARE SUPPORT .............................................................................. 37
DATA WHITENING ..................................................................................................................................... 37
PACKET FORMAT ....................................................................................................................................... 38
PACKET FILTERING IN RECEIVE MODE ...................................................................................................... 40
PACKET HANDLING IN TRANSMIT MODE ................................................................................................... 40
PACKET HANDLING IN RECEIVE MODE ..................................................................................................... 41
PACKET HANDLING IN FIRMWARE ............................................................................................................. 41
MODULATION FORMATS ................................................................................................................. 42
FREQUENCY SHIFT KEYING ....................................................................................................................... 42
MINIMUM SHIFT KEYING........................................................................................................................... 43
AMPLITUDE MODULATION ........................................................................................................................ 43
RECEIVED SIGNAL QUALIFIERS AND LINK QUALITY INFORMATION ............................ 43
SYNC WORD QUALIFIER ............................................................................................................................ 43
PREAMBLE QUALITY THRESHOLD (PQT) .................................................................................................. 44
RSSI .......................................................................................................................................................... 44
CARRIER SENSE (CS)................................................................................................................................. 46
CLEAR CHANNEL ASSESSMENT (CCA) ..................................................................................................... 48
LINK QUALITY INDICATOR (LQI) .............................................................................................................. 48
FORWARD ERROR CORRECTION WITH INTERLEAVING ..................................................... 48
FORWARD ERROR CORRECTION (FEC)...................................................................................................... 48
INTERLEAVING .......................................................................................................................................... 49
RADIO CONTROL ................................................................................................................................ 50
POWER-ON START-UP SEQUENCE ............................................................................................................. 50
CRYSTAL CONTROL ................................................................................................................................... 51
VOLTAGE REGULATOR CONTROL.............................................................................................................. 52
ACTIVE MODES (RX AND TX)................................................................................................................... 52
WAKE ON RADIO (WOR) .......................................................................................................................... 53
TIMING ...................................................................................................................................................... 54
RX TERMINATION TIMER .......................................................................................................................... 55
DATA FIFO ............................................................................................................................................ 56
FREQUENCY PROGRAMMING ........................................................................................................ 57
VCO ......................................................................................................................................................... 58
VCO AND PLL SELF-CALIBRATION .......................................................................................................... 58
VOLTAGE REGULATORS ................................................................................................................. 58
OUTPUT POWER PROGRAMMING ................................................................................................ 59
SHAPING AND PA RAMPING ............................................................................................................ 60
GENERAL PURPOSE / TEST OUTPUT CONTROL PINS ............................................................. 61
ASYNCHRONOUS AND SYNCHRONOUS SERIAL OPERATION .............................................. 63
ASYNCHRONOUS SERIAL OPERATION ........................................................................................................ 63
SYNCHRONOUS SERIAL OPERATION .......................................................................................................... 63
SYSTEM CONSIDERATIONS AND GUIDELINES ......................................................................... 64
SRD REGULATIONS ................................................................................................................................... 64
FREQUENCY HOPPING AND MULTI-CHANNEL SYSTEMS ............................................................................ 64
WIDEBAND MODULATION WHEN NOT USING SPREAD SPECTRUM ............................................................. 65
WIRELESS MBUS ...................................................................................................................................... 65
DATA BURST TRANSMISSIONS................................................................................................................... 65
CONTINUOUS TRANSMISSIONS .................................................................................................................. 65
BATTERY OPERATED SYSTEMS ................................................................................................................. 66
INCREASING RANGE .................................................................................................................................. 66

SWRS061I

Page 6 of 98

CC1101
29
29.1
29.2
29.3
30
31
32
33
33.1

CONFIGURATION REGISTERS ........................................................................................................ 66


CONFIGURATION REGISTER DETAILS REGISTERS WITH PRESERVED VALUES IN SLEEP STATE ............... 71
CONFIGURATION REGISTER DETAILS REGISTERS THAT LOOSE PROGRAMMING IN SLEEP STATE ......... 91
STATUS REGISTER DETAILS....................................................................................................................... 92
SOLDERING INFORMATION ............................................................................................................ 95
DEVELOPMENT KIT ORDERING INFORMATION ..................................................................... 95
REFERENCES ....................................................................................................................................... 96
GENERAL INFORMATION ................................................................................................................ 97
DOCUMENT HISTORY ................................................................................................................................ 97

SWRS061I

Page 7 of 98

CC1101
1

Absolute Maximum Ratings

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.
Parameter

Min

Max

Units

Supply voltage

0.3

3.9

Voltage on any digital pin

0.3

VDD + 0.3,
max 3.9

Voltage on the pins RF_P, RF_N,


DCOUPL, RBIAS

0.3

2.0

Voltage ramp-up rate

120

kV/s

Input RF level

+10

dBm

150

Solder reflow temperature

260

According to IPC/JEDEC J-STD-020

ESD

750

According to JEDEC STD 22, method A114,


Human Body Model (HBM)

ESD

400

According to JEDEC STD 22, C101C,


Charged Device Model (CDM)

50

Storage temperature range

Condition
All supply pins must have the same voltage

Table 1: Absolute Maximum Ratings


Caution!
ESD
sensitive
device.
Precaution should be used when handling
the device in order to prevent permanent
damage.

Operating Conditions

The operating conditions for CC1101 are listed Table 2 in below.


Parameter

Min

Max

Unit

Operating temperature

-40

85

Operating supply voltage

1.8

3.6

Condition

All supply pins must have the same voltage

Table 2: Operating Conditions

General Characteristics
Parameter

Min

Frequency
range

Data rate

Typ

Max

Unit

Condition/Note

300

348

MHz

387

464

MHz

779

928

MHz

0.6

500

kBaud

2-FSK

0.6

250

kBaud

GFSK, OOK, and ASK

0.6

300

kBaud

4-FSK (the data rate in kbps will be twice the baud rate)

26

500

kBaud

(Shaped) MSK (also known as differential offset QPSK).

If using a 27 MHz crystal, the lower frequency limit for


this band is 392 MHz

Optional Manchester encoding (the data rate in kbps will


be half the baud rate)

Table 3: General Characteristics

SWRS061I

Page 8 of 98

CC1101
4

Electrical Specifications

4.1

Current Consumption

TA = 25C, VDD = 3.0 V if nothing else stated. All measurement results are obtained using the CC1101EM reference designs
([1] and [2]). Reduced current settings (MDMCFG2.DEM_DCFILT_OFF=1) gives a slightly lower current consumption at the cost
of a reduction in sensitivity. See Table 7 for additional details on current consumption and sensitivity.
Parameter
Current consumption in power
down modes

Current consumption

Current consumption,
315 MHz

Min

Typ

Max

0.2

Unit Condition
A

Voltage regulator to digital part off, register values retained


(SLEEP state). All GDO pins programmed to 0x2F (HW to 0)

0.5

Voltage regulator to digital part off, register values retained, lowpower RC oscillator running (SLEEP state with WOR enabled)

100

Voltage regulator to digital part off, register values retained,


XOSC running (SLEEP state with MCSM0.OSC_FORCE_ON set)

165

Voltage regulator to digital part on, all other modules in power


down (XOFF state)

8.8

Automatic RX polling once each second, using low-power RC


oscillator, with 542 kHz filter bandwidth and 250 kBaud data rate,
PLL calibration every 4th wakeup. Average current with signal in
channel below carrier sense level (MCSM2.RX_TIME_RSSI=1)

35.3

Same as above, but with signal in channel above carrier sense


level, 1.96 ms RX timeout, and no preamble/sync word found

1.4

Automatic RX polling every 15th second, using low-power RC


oscillator, with 542 kHz filter bandwidth and 250 kBaud data rate,
PLL calibration every 4th wakeup. Average current with signal in
channel below carrier sense level (MCSM2.RX_TIME_RSSI=1)

39.3

Same as above, but with signal in channel above carrier sense


level, 36.6 ms RX timeout, and no preamble/sync word found

1.7

mA

Only voltage regulator to digital part and crystal oscillator running


(IDLE state)

8.4

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

15.4

mA

Receive mode, 1.2 kBaud, reduced current, input at sensitivity


limit

14.4

mA

Receive mode, 1.2 kBaud, register settings optimized for


reduced current, input well above sensitivity limit

15.2

mA

Receive mode, 38.4 kBaud, register settings optimized for


reduced current, input at sensitivity limit

14.3

mA

Receive mode, 38.4 kBaud, register settings optimized for


reduced current, input well above sensitivity limit

16.5

mA

Receive mode, 250 kBaud, register settings optimized for


reduced current, input at sensitivity limit

15.1

mA

Receive mode, 250 kBaud, register settings optimized for


reduced current, input well above sensitivity limit

27.4

mA

Transmit mode, +10 dBm output power

15.0

mA

Transmit mode, 0 dBm output power

12.3

mA

Transmit mode, 6 dBm output power

SWRS061I

Page 9 of 98

CC1101
Parameter
Current consumption,
433 MHz

Current consumption,
868/915 MHz

Min

Typ

Max

Unit Condition

16.0

mA

Receive mode, 1.2 kBaud, register settings optimized for reduced


current, input at sensitivity limit

15.0

mA

Receive mode, 1.2 kBaud, register settings optimized for reduced


current, input well above sensitivity limit

15.7

mA

Receive mode, 38.4 kBaud, register settings optimized for


reduced current, input at sensitivity limit

15.0

mA

Receive mode, 38.4 kBaud, register settings optimized for


reduced current, input well above sensitivity limit

17.1

mA

Receive mode, 250 kBaud, register settings optimized for


reduced current, input at sensitivity limit

15.7

mA

Receive mode, 250 kBaud, register settings optimized for


reduced current, input well above sensitivity limit

29.2

mA

Transmit mode, +10 dBm output power

16.0

mA

Transmit mode, 0 dBm output power

13.1

mA

Transmit mode, 6 dBm output power

15.7

mA

Receive mode, 1.2 kBaud, register settings optimized for


reduced current, input at sensitivity limit.
See Figure 3 for current consumption with register settings
optimized for sensitivity.

14.7

mA

Receive mode, 1.2 kBaud, register settings optimized for


reduced current, input well above sensitivity limit.
See Figure 3 for current consumption with register settings
optimized for sensitivity.

15.6

mA

Receive mode, 38.4 kBaud, register settings optimized for


reduced current, input at sensitivity limit.
See Figure 3 for current consumption with register settings
optimized for sensitivity.

14.6

mA

Receive mode, 38.4 kBaud, register settings optimized for


reduced current, input well above sensitivity limit.
See Figure 3 for current consumption with register settings
optimized for sensitivity.

16.9

mA

Receive mode, 250 kBaud, register settings optimized for


reduced current, input at sensitivity limit.
See Figure 3 for current consumption with register settings
optimized for sensitivity.

15.6

mA

Receive mode, 250 kBaud, register settings optimized for


reduced current, input well above sensitivity limit.
See Figure 3 for current consumption with register settings
optimized for sensitivity.

34.2

mA

Transmit mode, +12 dBm output power, 868 MHz

30.0

mA

Transmit mode, +10 dBm output power, 868 MHz

16.8

mA

Transmit mode, 0 dBm output power, 868 MHz

16.4

mA

Transmit mode, 6 dBm output power, 868 MHz.

33.4

mA

Transmit mode, +11 dBm output power, 915 MHz

30.7

mA

Transmit mode, +10 dBm output power, 915 MHz

17.2

mA

Transmit mode, 0 dBm output power, 915 MHz

17.0

mA

Transmit mode, 6 dBm output power, 915 MHz

Table 4: Current Consumption

SWRS061I

Page 10 of 98

CC1101

Temperature [C]
Current [mA], PATABLE=0xC0,
+12 dBm
Current [mA], PATABLE=0xC5,
+10 dBm
Current [mA], PATABLE=0x50,
0 dBm

Supply Voltage
VDD = 1.8 V
-40
25
85

Supply Voltage
VDD = 3.0 V
-40
25
85

Supply Voltage
VDD = 3.6 V
-40
25
85

32.7

31.5

30.5

35.3

34.2

33.3

35.5

34.4

33.5

30.1

29.2

28.3

30.9

30.0

29.4

31.1

30.3

29.6

16.4

16.0

15.6

17.3

16.8

16.4

17.6

17.1

16.7

Table 5: Typical TX Current Consumption over Temperature and Supply Voltage, 868 MHz

Temperature [C]
Current [mA], PATABLE=0xC0,
+11 dBm
Current [mA], PATABLE=0xC3,
+10 dBm
Current [mA], PATABLE=0x8E,
0 dBm

Supply Voltage
VDD = 1.8 V
-40
25
85

Supply Voltage
VDD = 3.0 V
-40
25
85

Supply Voltage
VDD = 3.6 V
-40
25
85

31.9

30.7

29.8

34.6

33.4

32.5

34.8

33.6

32.7

30.9

29.8

28.9

31.7

30.7

30.0

31.9

31.0

30.2

17.2

16.8

16.4

17.6

17.2

16.9

17.8

17.4

17.1

Table 6: Typical TX Current Consumption over Temperature and Supply Voltage, 915 MHz

17,8

19,5
19

17,4
17,2
17

-40C

16,8

+85C

+25C

16,6

Current [mA]

Current [mA]

17,6

18,5

-40C

18

+25C

17,5

+85C

17

16,4
16,2
-110

-90

-70

-50

-30

16,5
-100

-10

-80

-60

Input Power Level [dBm]

Input Power Level [dBm]

1.2 kBaud GFSK

250 kBaud GFSK

17,8

-40

-20

19,5
19,0

17,4
17,2
17,0

-40C

16,8

+85C

+25C

16,6

Current [mA]

Current [mA]

17,6

-40C

18,5

+25C
18,0

+85C

17,5

16,4
16,2
-100

17,0
-80

-60

-40

-20

-90

-70

-50

Input Power Level [dBm]

Input Power Level [dBm]

38.4 kBaud GFSK

500 kBaud MSK

-30

-10

Figure 3: Typical RX Current Consumption over Temperature and Input Power Level,
868/915 MHz, Sensitivity Optimized Setting

SWRS061I

Page 11 of 98

CC1101
4.2

RF Receive Section

TA = 25C, VDD = 3.0 V if nothing else stated. All measurement results are obtained using the CC1101EM reference designs
([1] and [2]).
Parameter

Min

Digital channel filter


bandwidth

58

Spurious emissions

Typ

Max

Unit

Condition/Note

812

kHz

User programmable. The bandwidth limits are proportional to


crystal frequency (given values assume a 26.0 MHz crystal)

-68

57

dBm

25 MHz 1 GHz
(Maximum figure is the ETSI EN 300 220 limit)

-66

47

dBm

Above 1 GHz
(Maximum figure is the ETSI EN 300 220 limit)
Typical radiated spurious emission is -49 dBm measured at the
VCO frequency

RX latency

bit

Serial operation. Time from start of reception until data is


available on the receiver data output pin is equal to 9 bit

315 MHz
1.2 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0
(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


MDMCFG2.DEM_DCFILT_OFF=1. The typical current
consumption is then reduced from 17.2 mA to 15.4 mA at the
sensitivity limit. The sensitivity is typically reduced to -109 dBm

500 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0


(MSK, 1% packet error rate, 20 bytes packet length, 812 kHz digital channel filter bandwidth)
Receiver sensitivity

-88

dBm

MDMCFG2.DEM_DCFILT_OFF=1 cannot be used for data rates >


250 kBaud

433 MHz
0.6 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0
(GFSK, 1% packet error rate, 20 bytes packet length, 14.3 kHz deviation, 58 kHz digital channel filter bandwidth)
Receiver sensitivity

-116

dBm

1.2 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0


(GFSK, 1% packet error rate, 20 bytes packet length, 5.2 kHz deviation, 58 kHz digital channel filter bandwidth)
Receiver sensitivity

-112

dBm

Sensitivity can be traded for current consumption by setting


MDMCFG2.DEM_DCFILT_OFF=1. The typical current
consumption is then reduced from 18.0 mA to 16.0 mA at the
sensitivity limit. The sensitivity is typically reduced to -110 dBm

38.4 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0


(GFSK, 1% packet error rate, 20 bytes packet length, 20 kHz deviation, 100 kHz digital channel filter bandwidth)
Receiver sensitivity

104

dBm

250 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0


(GFSK, 1% packet error rate, 20 bytes packet length, 127 kHz deviation, 540 kHz digital channel filter bandwidth)
Receiver sensitivity

-95

dBm

868/915 MHz
1.2 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0
(GFSK, 1% packet error rate, 20 bytes packet length, 5.2 kHz deviation, 58 kHz digital channel filter bandwidth)
Receiver sensitivity

112

dBm

Sensitivity can be traded for current consumption by setting


MDMCFG2.DEM_DCFILT_OFF=1. The typical current
consumption is then reduced from 17.7 mA to 15.7 mA at
sensitivity limit. The sensitivity is typically reduced to -109 dBm

Saturation

14

dBm

FIFOTHR.CLOSE_IN_RX=0. See more in DN010 [8]

Adjacent channel
rejection
100 kHz offset
Image channel
rejection

37

dB

31

dB

Desired channel 3 dB above the sensitivity limit.


100 kHz channel spacing
See Figure 4 for selectivity performance at other offset
frequencies
IF frequency 152 kHz
Desired channel 3 dB above the sensitivity limit

SWRS061I

Page 12 of 98

CC1101
Parameter
Blocking
2 MHz offset
10 MHz offset

Min

Typ
-50
-40

Max

Unit

Condition/Note

dBm
dBm

Desired channel 3 dB above the sensitivity limit


See Figure 4 for blocking performance at other offset
frequencies

38.4 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0


(GFSK, 1% packet error rate, 20 bytes packet length, 20 kHz deviation, 100 kHz digital channel filter bandwidth)
Receiver sensitivity

104

dBm

Sensitivity can be traded for current consumption by setting


MDMCFG2.DEM_DCFILT_OFF=1. The typical current
consumption is then reduced from 17.7 mA to 15.6 mA at the
sensitivity limit. The sensitivity is typically reduced to -102
dBm

Saturation

16

dBm

FIFOTHR.CLOSE_IN_RX=0. See more in DN010 [8]

Adjacent channel rejection


-200 kHz offset
+200 kHz offset

12
25

dB
dB

Desired channel 3 dB above the sensitivity limit.


200 kHz channel spacing
See Figure 5 for blocking performance at other offset
frequencies

Image channel rejection

23

dB

Blocking
2 MHz offset
10 MHz offset

-50
-40

dBm
dBm

IF frequency 152 kHz


Desired channel 3 dB above the sensitivity limit
Desired channel 3 dB above the sensitivity limit
See Figure 5 for blocking performance at other offset
frequencies

250 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0


(GFSK, 1% packet error rate, 20 bytes packet length, 127 kHz deviation, 540 kHz digital channel filter bandwidth)
Receiver sensitivity

95

dBm

Sensitivity can be traded for current consumption by setting


MDMCFG2.DEM_DCFILT_OFF=1. The typical current
consumption is then reduced from 18.9 mA to 16.9 mA at the
sensitivity limit. The sensitivity is typically reduced to -91 dBm

Saturation

17

dBm

FIFOTHR.CLOSE_IN_RX=0. See more in DN010 [8]

Adjacent channel rejection

25

dB

Desired channel 3 dB above the sensitivity limit.


750 kHz channel spacing
See Figure 6 for blocking performance at other offset
frequencies

Image channel rejection

14

dB

IF frequency 304 kHz


Desired channel 3 dB above the sensitivity limit

Blocking
2 MHz offset
10 MHz offset

-50
-40

dBm
dBm

Desired channel 3 dB above the sensitivity limit


See Figure 6 for blocking performance at other offset
frequencies

500 kBaud data rate, sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0


(MSK, 1% packet error rate, 20 bytes packet length, 812 kHz digital channel filter bandwidth)
Receiver sensitivity
Image channel rejection
Blocking
2 MHz offset
10 MHz offset

90

dBm

dB

-50
-40

dBm
dBm

MDMCFG2.DEM_DCFILT_OFF=1 cannot be used for data


rates > 250 kBaud
IF frequency 355 kHz
Desired channel 3 dB above the sensitivity limit
Desired channel 3 dB above the sensitivity limit
See Figure 7 for blocking performance at other offset
frequencies

4-FSK, 125 kBaud data rate (250 kbps), sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0
(1% packet error rate, 20 bytes packet length, 127 kHz deviation, 406 kHz digital channel filter bandwidth)
Receiver sensitivity

-96

dBm

4-FSK, 250 kBaud data rate (500 kbps), sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0
(1% packet error rate, 20 bytes packet length, 254 kHz deviation, 812 kHz digital channel filter bandwidth)
Receiver sensitivity

-91

dBm

4-FSK, 300 kBaud data rate (600 kbps), sensitivity optimized, MDMCFG2.DEM_DCFILT_OFF=0
(1% packet error rate, 20 bytes packet length, 228 kHz deviation, 812 kHz digital channel filter bandwidth)
Receiver sensitivity

-89

dBm

Table 7: RF Receive Section

SWRS061I

Page 13 of 98

CC1101

Temperature [C]
Sensitivity [dBm]
1.2 kBaud
Sensitivity [dBm]
38.4 kBaud
Sensitivity [dBm]
250 kBaud
Sensitivity [dBm]
500 kBaud

Supply Voltage
VDD = 1.8 V
-40
25
85

Supply Voltage
VDD = 3.0 V
-40
25
85

Supply Voltage
VDD = 3.6 V
-40
25
85

-113

-112

-110

-113

-112

-110

-113

-112

-110

-105

-104

-102

-105

-104

-102

-105

-104

-102

-97

-96

-92

-97

-95

-92

-97

-94

-92

-91

-90

-86

-91

-90

-86

-91

-90

-86

Table 8: Typical Sensitivity over Temperature and Supply Voltage, 868 MHz, Sensitivity Optimized
Setting

Temperature [C]
Sensitivity [dBm]
1.2 kBaud
Sensitivity [dBm]
38.4 kBaud
Sensitivity [dBm]
250 kBaud
Sensitivity [dBm]
500 kBaud

Supply Voltage
VDD = 1.8 V
-40
25
85

Supply Voltage
VDD = 3.0 V
-40
25
85

Supply Voltage
VDD = 3.6 V
-40
25
85

-113

-112

-110

-113

-112

-110

-113

-112

-110

-105

-104

-102

-104

-104

-102

-105

-104

-102

-97

-94

-92

-97

-95

-92

-97

-95

-92

-91

-89

-86

-91

-90

-86

-91

-89

-86

Table 9: Typical Sensitivity over Temperature and Supply Voltage, 915 MHz, Sensitivity Optimized
Setting

80

60

70
50
60
40

50

Selectivity [dB]

Blocking [dB]

40
30
20
10

30

20

10

0
-40

-30

-20

-10

10

20

30

40

-10

-1

-20

-0,9 -0,8 -0,7 -0,6 -0,5 -0,4 -0,3 -0,2 -0,1

0,1

0,2

0,3

0,4

0,5

0,6

0,7

0,8

0,9

-10

Offset [MHz]

Offset [MHz]

Figure 4: Typical Selectivity at 1.2 kBaud Data Rate, 868.3 MHz, GFSK, 5.2 kHz Deviation. IF
Frequency is 152.3 kHz and the Digital Channel Filter Bandwidth is 58 kHz

SWRS061I

Page 14 of 98

CC1101

70

50

60
40
50
30

Selectivity [dB]

Blocking [dB]

40

30

20

20

10

10
0
-1

0
-40

-30

-20

-10

10

20

30

-0,9 -0,8 -0,7 -0,6 -0,5 -0,4 -0,3 -0,2 -0,1

0,1

0,2

0,3

0,4

0,5

0,6

0,7

0,8

0,9

40
-10

-10

-20

-20
Offset [MHz]

Offset [MHz]

Figure 5: Typical Selectivity at 38.4 kBaud Data Rate, 868 MHz, GFSK, 20 kHz Deviation. IF
Frequency is 152.3 kHz and the Digital Channel Filter Bandwidth is 100 kHz

60

50

50

40

40

30

Selectivity [dB]

Blocking [dB]

30

20

20

10

10

0
0

-2
-40

-30

-20

-10

10

20

30

-1,5

-1

-0,5

0,5

1,5

40

-10

-10

-20

-20
Offset [MHz]

Offset [MHz]

Figure 6: Typical Selectivity at 250 kBaud Data Rate, 868 MHz, GFSK, IF Frequency is 304 kHz and
the Digital Channel Filter Bandwidth is 540 kHz

60

40

50

30
40

20
Selectivity [dB]

Blocking [dB]

30

20

10

10

0
-40

-30

-20

-10

10

20

30

40

-2

-1,5

-1

-0,5

0,5

1,5

-10

-10
-20

-30

-20
Offset [MHz]

Offset [MHz]

Figure 7: Typical Selectivity at 500 kBaud Data Rate, 868 MHz, GFSK, IF Frequency is 355 kHz and
the Digital Channel Filter Bandwidth is 812 kHz

SWRS061I

Page 15 of 98

CC1101
4.3

RF Transmit Section

TA = 25C, VDD = 3.0 V, +10 dBm if nothing else stated. All measurement results are obtained using the CC1101EM reference
designs ([1] and [2]).
Parameter

Min

Typ

Max

Unit

Differential load
impedance
122 + j31

433 MHz

116 + j41

868/915 MHz

86.5 + j43

315 MHz

Output power,
highest setting
315 MHz

+10

dBm

433 MHz

+10

dBm

868 MHz

+12

dBm

915 MHz

+11

dBm

Output power, lowest


setting

-30

dBm

Condition/Note
Differential impedance as seen from the RF-port (RF_P and
RF_N) towards the antenna. Follow the CC1101EM reference
designs ([1] and [2]) available from the TI website

Output power is programmable, and full range is available in all


frequency bands. Output power may be restricted by
regulatory limits.
See Design Note DN013 [15] for output power and harmonics
figures when using multi-layer inductors. The output power is
then typically +10 dBm when operating at 868/915 MHz.
Delivered to a 50 single-ended load via CC1101EM
reference designs ([1] and [2]) RF matching network
Output power is programmable, and full range is available in all
frequency bands
Delivered to a 50 single-ended load via CC1101EM
reference designs ([1] and [2]) RF matching network

Harmonics, radiated

Measured on CC1101EM reference designs ([1] and [2]) with


CW, maximum output power

2nd Harm, 433 MHz


3rd Harm, 433 MHz

-49
-40

dBm
dBm

2nd Harm, 868 MHz


3rd Harm, 868 MHz

-47
-55

dBm
dBm

2nd Harm, 915 MHz


3rd Harm, 915 MHz

-50
-54

dBm
dBm

Note: All harmonics are below -41.2 dBm when operating in


the 902 928 MHz band

315 MHz

< -35
< -53

dBm
dBm

Measured with +10 dBm CW at 315 MHz and 433 MHz


Frequencies below 960 MHz
Frequencies above 960 MHz

433 MHz

-43
< -45

dBm
dBm

Frequencies below 1 GHz


Frequencies above 1 GHz

-36
< -46

dBm
dBm

Measured with +12 dBm CW at 868 MHz

-34

dBm

Measured with +11 dBm CW at 915 MHz (requirement is -20


dBc under FCC 15.247)

< -50

dBm

The antennas used during the radiated measurements


(SMAFF-433 from R.W. Badland and Nearson S331 868/915)
play a part in attenuating the harmonics

Harmonics, conducted

868 MHz
2nd Harm
other harmonics
915 MHz
2nd Harm
other harmonics

SWRS061I

Page 16 of 98

CC1101
Parameter

Min

Typ

Max

Unit

Condition/Note

Spurious emissions
conducted, harmonics
not included
315 MHz

< -58
< -53

dBm
dBm

Measured with +10 dBm CW at 315 MHz and 433 MHz


Frequencies below 960 MHz
Frequencies above 960 MHz

433 MHz

< -50
< -54
< -56

dBm
dBm
dBm

Frequencies below 1 GHz


Frequencies above 1 GHz
Frequencies within 47-74, 87.5-118, 174-230, 470-862 MHz

868 MHz

< -50
< -52
< -53

dBm
dBm
dBm

Measured with +12 dBm CW at 868 MHz


Frequencies below 1 GHz
Frequencies above 1 GHz
Frequencies within 47-74, 87.5-118, 174-230, 470-862 MHz
All radiated spurious emissions are within the limits of ETSI.
The peak conducted spurious emission is -53 dBm at 699 MHz
(868 MHz 169 MHz), which is in a frequency band limited to
-54 dBm by EN 300 220. An alternative filter can be used to
reduce the emission at 699 MHz below -54 dBm, for conducted
measurements, and is shown in Figure 11. See more
information in DN017 [9].
For compliance with modulation bandwidth requirements under
EN 300 220 in the 863 to 870 MHz frequency range it is
recommended to use a 26 MHz crystal for frequencies below
869 MHz and a 27 MHz crystal for frequencies above 869
MHz.

915 MHz
TX latency

< -51
< -54

dBm
dBm

bit

Measured with +11 dBm CW at 915 MHz


Frequencies below 960 MHz
Frequencies above 960 MHz
Serial operation. Time from sampling the data on the
transmitter data input pin until it is observed on the RF output
ports

Table 10: RF Transmit Section

Temperature [C]
Output Power [dBm],
PATABLE=0xC0, +12 dBm
Output Power [dBm],
PATABLE=0xC5, +10 dBm
Output Power [dBm],
PATABLE=0x50, 0 dBm

Supply Voltage
VDD = 1.8 V
-40
25
85

Supply Voltage
VDD = 3.0 V
-40
25
85

Supply Voltage
VDD = 3.6 V
-40
25
85

12

11

10

12

12

11

12

12

11

11

10

11

10

10

11

10

10

-1

Table 11: Typical Variation in Output Power over Temperature and Supply Voltage, 868 MHz

Temperature [C]
Output Power [dBm],
PATABLE=0xC0, +11 dBm
Output Power [dBm],
PATABLE=0x8E, +0 dBm

Supply Voltage
VDD = 1.8 V
-40
25
85

Supply Voltage
VDD = 3.0 V
-40
25
85

Supply Voltage
VDD = 3.6 V
-40
25
85

11

10

10

12

11

11

12

11

11

Table 12: Typical Variation in Output Power over Temperature and Supply Voltage, 915 MHz

SWRS061I

Page 17 of 98

CC1101
4.4

Crystal Oscillator

TA = 25C, VDD = 3.0 V if nothing else is stated. All measurement results obtained using the CC1101EM reference designs ([1]
and [2]).
Parameter
Crystal frequency

Min

Typ

Max

Unit

Condition/Note

26

26

27

MHz

For compliance with modulation bandwidth requirements under


EN 300 220 in the 863 to 870 MHz frequency range it is
recommended to use a 26 MHz crystal for frequencies below
869 MHz and a 27 MHz crystal for frequencies above 869 MHz.

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.

Tolerance

Load capacitance

40

10

13

ESR
Start-up time

20

pF

100

150

Simulated over operating conditions

This parameter is to a large degree crystal dependent. Measured


on the CC1101EM reference designs ([1] and [2]) using crystal
AT-41CD2 from NDK

Table 13: Crystal Oscillator Parameters


4.5

Low Power RC Oscillator

TA = 25C, VDD = 3.0 V if nothing else is stated. All measurement results obtained using the CC1101EM reference designs ([1]
and [2]).
Parameter

Min

Typ

Max

Calibrated frequency

34.7

34.7

36

kHz

Frequency accuracy after


calibration

Unit

Condition/Note
Calibrated RC Oscillator frequency is XTAL
frequency divided by 750

+0.5

% / C

Frequency drift when temperature changes after


calibration

Supply voltage coefficient

+3

%/V

Frequency drift when supply voltage changes after


calibration

Initial calibration time

ms

Temperature coefficient

When the RC Oscillator is enabled, calibration is


continuously done in the background as long as
the crystal oscillator is running

Table 14: RC Oscillator Parameters

SWRS061I

Page 18 of 98

CC1101
4.6

Frequency Synthesizer Characteristics

TA = 25C, VDD = 3.0 V if nothing else is stated. All measurement results are obtained using the CC1101EM reference designs
([1] and [2]). Min figures are given using a 27 MHz crystal. Typ and max figures are given using a 26 MHz crystal.
Parameter
Programmed frequency
resolution

Min

Typ

397

Max

FXOSC/
216

Unit

412

Condition/Note

Hz

26-27 MHz crystal. The resolution (in Hz) is equal


for all frequency bands
Given by crystal used. Required accuracy
(including temperature and aging) depends on
frequency band and channel bandwidth / spacing

Synthesizer frequency
tolerance

40

ppm

RF carrier phase noise

92

dBc/Hz

@ 50 kHz offset from carrier

RF carrier phase noise

92

dBc/Hz

@ 100 kHz offset from carrier

RF carrier phase noise

92

dBc/Hz

@ 200 kHz offset from carrier

RF carrier phase noise

98

dBc/Hz

@ 500 kHz offset from carrier

RF carrier phase noise

107

dBc/Hz

@ 1 MHz offset from carrier

RF carrier phase noise

113

dBc/Hz

@ 2 MHz offset from carrier

RF carrier phase noise

119

dBc/Hz

@ 5 MHz offset from carrier

RF carrier phase noise

129

dBc/Hz

@ 10 MHz offset from carrier

PLL turn-on / hop time


( See Table 34)

72

75

75

Time from leaving the IDLE state until arriving in


the RX, FSTXON or TX state, when not
performing calibration. Crystal oscillator running.

PLL RX/TX settling time


( See Table 34)

29

30

30

Settling time for the 1IF frequency step from RX


to TX

PLL TX/RX settling time


( See Table 34)

30

31

31

Settling time for the 1IF frequency step from TX


to RX. 250 kbps data rate.

PLL calibration time


(See Table 35)

685

712

724

Calibration can be initiated manually or


automatically before entering or after leaving
RX/TX

Table 15: Frequency Synthesizer Parameters


4.7

Analog Temperature Sensor

TA = 25C, VDD = 3.0 V if nothing else is stated. All measurement results obtained using the CC1101EM reference designs ([1]
and [2]). Note that it is necessary to write 0xBF to the PTEST register to use the analog temperature sensor in the IDLE state.
Parameter

Min

Typ

Max

Unit

Output voltage at 40C

0.651

Output voltage at 0C

0.747

Output voltage at +40C

0.847

Output voltage at +80C

0.945

Temperature coefficient
Error in calculated
temperature, calibrated

2.47
-2

mV/C
2

Condition/Note

Fitted from 20 C to +80 C


From 20 C to +80 C when using 2.47 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
Current consumption
increase when enabled

0.3

mA

Table 16: Analog Temperature Sensor Parameters

SWRS061I

Page 19 of 98

CC1101
4.8

DC Characteristics

TA = 25C if nothing else stated.


Digital Inputs/Outputs

Min

Max

Unit

Logic "0" input voltage

0.7

Logic "1" input voltage

Condition

VDD-0.7

VDD

Logic "0" output voltage

0.5

For up to 4 mA output current

Logic "1" output voltage

VDD-0.3

VDD

For up to 4 mA output current

Logic "0" input current

N/A

50

nA

Input equals 0V

Logic "1" input current

N/A

50

nA

Input equals VDD

Table 17: DC Characteristics


4.9

Power-On Reset

For proper Power-On-Reset functionality the power supply should comply with the requirements in
Table 18 below. 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 50 for further details.
Parameter

Min

Typ

Power-up ramp-up time


Power off time

Max

Unit

ms

From 0V until reaching 1.8V

ms

Minimum time between power-on and power-off

Condition/Note

Table 18: Power-On Reset Requirements

Pin Configuration

GND

RBIAS

DGUARD

GND

SI

The CC1101 pin-out is shown in Figure 8 and Table 19. See Section 26 for details on the I/O
configuration.

20 19 18 17 16
SCLK 1

15 AVDD

SO (GDO1) 2

14 AVDD

GDO2 3

13 RF_N

DVDD 4

12 RF_P

DCOUPL 5

11 AVDD
7

9 10

GDO0 (ATEST)

CSn

XOSC_Q1

AVDD

XOSC_Q2

GND
Exposed die
attach pad

Figure 8: 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

SWRS061I

Page 20 of 98

CC1101
Pin #

Pin Name

Pin type

Description

SCLK

Digital Input

Serial configuration interface, clock input

SO (GDO1)

Digital Output

Serial configuration interface, data output


Optional general output pin when CSn is high

GDO2

Digital Output

Digital output pin for general use:


Test signals
FIFO status signals
Clear channel indicator
Clock output, down-divided from XOSC
Serial output RX data

DVDD

Power (Digital)

1.8 - 3.6 V digital power supply for digital I/Os and for the digital core
voltage regulator

DCOUPL

Power (Digital)

1.6 - 2.0 V digital power supply output for decoupling


NOTE: This pin is intended for use with the CC1101 only. It can not be used
to provide supply voltage to other devices

GDO0

Digital I/O

Digital output pin for general use:


Test signals

(ATEST)

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
7

CSn

Digital Input

Serial configuration interface, chip select

XOSC_Q1

Analog I/O

Crystal oscillator pin 1, or external clock input

AVDD

Power (Analog)

1.8 - 3.6 V analog power supply connection

10

XOSC_Q2

Analog I/O

Crystal oscillator pin 2

11

AVDD

Power (Analog)

1.8 - 3.6 V analog power supply connection

12

RF_P

RF I/O

Positive RF input signal to LNA in receive mode


Positive RF output signal from PA in transmit mode

13

RF_N

RF I/O

Negative RF input signal to LNA in receive mode


Negative RF output signal from PA in transmit mode

14

AVDD

Power (Analog)

1.8 - 3.6 V analog power supply connection

15

AVDD

Power (Analog)

1.8 - 3.6 V analog power supply connection

16

GND

Ground (Analog)

Analog ground connection

17

RBIAS

Analog I/O

External bias resistor for reference current

18

DGUARD

Power (Digital)

Power supply connection for digital noise isolation

19

GND

Ground (Digital)

Ground connection for digital noise isolation

20

SI

Digital Input

Serial configuration interface, data input

Table 19: Pinout Overview

SWRS061I

Page 21 of 98

CC1101
6

Circuit Description

90

PA

RC OSC

BIAS

RBIAS

XOSC

XOSC_Q1

RXFIFO

DIGITAL INTERFACE TO MCU

FREQ
SYNTH

RF_N

MODULATOR

RF_P

TXFIFO

ADC

PACKET HANDLER

LNA

FEC / INTERLEAVER

ADC

DEMODULATOR

RADIO CONTROL

SCLK
SO (GDO1)
SI
CSn
GDO0 (ATEST)
GDO2

XOSC_Q2

Figure 9: CC1101 Simplified Block Diagram


A simplified block diagram of CC1101 is shown
in Figure 9.

CC1101 features a low-IF receiver. The received


RF signal is amplified by the low-noise
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, demodulation,
and bit/packet synchronization are performed
digitally.
The transmitter part of CC1101 is based on
direct synthesis of the RF frequency. The

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.

Application Circuit

Only a few external components are required


for using the CC1101. The recommended
application circuits for CC1101 are shown in
Figure 10 and
Figure 11. The external components are
described in Table 20, and typical values are
given in Table 21.
The 315 MHz and 433 MHz CC1101EM
reference design [1] use inexpensive multilayer inductors. The 868 MHz and 915 MHz
CC1101EM reference design [2] use wire7.1

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.

wound inductors as this give better output


power, sensitivity, and attenuation of
harmonics compared to using multi-layer
inductors. Refer to design note DN032 [24] for
information about performance when using
wire-wound inductors from different vendors.
See also Design Note DN013 [15], which gives
the output power and harmonics when using
multi-layer inductors. The output power is then
typically +10 dBm when operating at 868/915
MHz.

Bias Resistor

The bias resistor R171 is used to set an

accurate bias current.

SWRS061I

Page 22 of 98

CC1101
7.2

Balun and RF Matching

The balanced RF input and output of CC1101


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 CC1101 front-end is
controlled by a dedicated on-chip function,
eliminating the need for an external RX/TXswitch.

DC blocking. Together with an appropriate LC


network, the balun components also transform
the impedance to match a 50 load. C125
provides DC blocking and is only needed if
there is a DC path in the antenna. For the
868/915
MHz
reference
design,
this
component may also be used for additional
filtering, see Section 7.5 below.

A few external passive components combined


with the internal RX/TX switch/termination
circuitry ensures match in both RX and TX
mode. 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 [1], and L121, L131, C121, L122,
C131, C122 and L132 for the 868/915 MHz
reference design [2]) form a balun that
converts the differential RF signal on CC1101 to
a single-ended RF signal. C124 is needed for

Suggested values for 315 MHz, 433 MHz, and


868/915 MHz are listed in Table 21.

7.3

Crystal

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, CL, specified for the crystal. The
total load capacitance seen between the
crystal terminals should equal CL for the
crystal to oscillate at the specified frequency.

CL

1
C parasitic
1
1

C81 C101

The parasitic capacitance is constituted by pin


input capacitance and PCB stray capacitance.
Total parasitic capacitance is typically 2.5 pF.
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
7.4

The balun and LC filter component values and


their placement are important to keep the
performance
optimized.
It
is
highly
recommended to follow the CC1101EM
reference design ([1] and [2]). Gerber files and
schematics for the reference designs are
available for download from the TI website.

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
4.4).
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.
Avoid routing digital signals with sharp edges
close to XOSC_Q1 PCB track or underneath
the crystal Q1 pad as this may shift the crystal
dc operating point and result in duty cycle
variation.
For compliance with modulation bandwidth
requirements under EN 300 220 in the 863 to
870 MHz frequency range it is recommended
to use a 26 MHz crystal for frequencies below
869 MHz and a 27 MHz crystal for frequencies
above 869 MHz.

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

SWRS061I

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

Page 23 of 98

CC1101
and C101 can be omitted when using a
7.5

Additional Filtering

In the 868/915 MHz reference design, C126


and L125 together with C125 build an optional
filter to reduce emission at carrier frequency
169 MHz. This filter is necessary for
applications with an external antenna
connector that seek compliance with ETSI EN
300-220. For more information, see DN017 [9].
7.6

If this filtering is not necessary, C125 will work


as a DC block (only necessary if there is a DC
path in the antenna). C126 and L125 should in
that case be left unmounted.
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
7.7

reference signal.

decoupling capacitors are very important to


achieve the optimum performance. The
CC1101EM reference designs ([1] and [2])
should be followed closely.

Antenna Considerations

The reference design ([1] and [2]) contains a


SMA connector and is matched for a 50
load. The SMA connector makes it easy to
connect evaluation modules and prototypes to
different test equipment for example a
Component
C51

spectrum analyzer. The SMA connector can


also be replaced by an antenna suitable for
the desired application. Please refer to the
antenna selection guide [13] for further details
regarding antenna solutions provided by TI.

Description
Decoupling capacitor for on-chip voltage regulator to digital part

C81/C101

Crystal loading capacitors

C121/C131

RF balun/matching capacitors

C122

RF LC filter/matching filter capacitor (315/433 MHz). RF balun/matching capacitor (868/915 MHz).

C123

RF LC filter/matching capacitor

C124

RF balun DC blocking capacitor

C125

RF LC filter DC blocking capacitor and part of optional RF LC filter (868/915 MHz)

C126

Part of optional RF LC filter and DC-block (868/915 MHz)

L121/L131

RF balun/matching inductors (inexpensive multi-layer type)

L122

RF LC filter/matching filter inductor (315 and 433 MHz). RF balun/matching inductor (868/915 MHz).
(inexpensive multi-layer type)

L123

RF LC filter/matching filter inductor (inexpensive multi-layer type)

L124

RF LC filter/matching filter inductor (inexpensive multi-layer type)

L125

Optional RF LC filter/matching filter inductor (inexpensive multi-layer type) (868/915 MHz)

L132

RF balun/matching inductor. (inexpensive multi-layer type)

R171

Resistor for internal bias current reference

XTAL

26 27 MHz crystal

Table 20: Overview of External Components (excluding supply decoupling capacitors)

SWRS061I

Page 24 of 98

CC1101
1.8V-3.6V power supply

R171

2 SO
(GDO1)
3 GDO2

GND 16

RBIAS 17

DGUARD 18

SI 20

1 SCLK

SO
(GDO1)
GDO2
(optional)

CC1101

AVDD 14

C131
L131

C125

RF_N 13

DIE ATTACH PAD:

9 AVDD

8 XOSC_Q1

7 CSn

6 GDO0

10 XOSC_Q2

RF_P 12

5 DCOUPL

C51

Antenna
(50 Ohm)
AVDD 15

4 DVDD

AVDD 11

C121

L122

L121

L123
C122

C123

C124

GDO0
(optional)
CSn

XTAL
C81

C101

Figure 10: Typical Application and Evaluation Circuit 315/433 MHz (excluding supply
decoupling capacitors)

1.8V-3.6V power supply

R171

3 GDO2
4 DVDD

CC1101
7 CSn

6 GDO0

C51

GND 16

AVDD 14

L131

L132
C125

RF_N 13

L123

AVDD 11

L121

C123
L122

GDO0
(optional)
CSn

C124

XTAL
C81

L124

C121 C122

DIE ATTACH PAD: RF_P 12

5 DCOUPL

Antenna
(50 Ohm)

C131

AVDD 15

10 XOSC_Q2

2 SO
(GDO1)

RBIAS 17

GND 19

1 SCLK

9 AVDD

SO
(GDO1)
GDO2
(optional)

8 XOSC_Q1

SCLK

DGUARD 18

SI 20

SI

Digital Interface

Digital Inteface

SCLK

GND 19

SI

C126 L125
C126 and L125
may be added to
build an optional
filter to reduce
emission at 699
MHz

C101

Figure 11: Typical Application and Evaluation Circuit 868/915 MHz (excluding supply
decoupling capacitors)

SWRS061I

Page 25 of 98

CC1101
Component

Value at 315MHz

Value at 433MHz

Value at
868/915MHz

Manufacturer

C51

100 nF 10%, 0402 X5R

Murata GRM1555C series

C81

27 pF 5%, 0402 NP0

Murata GRM1555C series

C101

27 pF 5%, 0402 NP0

Murata GRM1555C series

C121

6.8 pF 0.5 pF,


0402 NP0

3.9 pF 0.25 pF,


0402 NP0

1.0 pF 0.25 pF,


0402 NP0

Murata GRM1555C series

C122

12 pF 5%, 0402
NP0

8.2 pF 0.5 pF,


0402 NP0

1.5 pF 0.25 pF,


0402 NP0

Murata GRM1555C series

C123

6.8 pF 0.5 pF,


0402 NP0

5.6 pF 0.5 pF,


0402 NP0

3.3 pF 0.25 pF,


0402 NP0

Murata GRM1555C series

C124

220 pF 5%,
0402 NP0

220 pF 5%, 0402


NP0

100 pF 5%, 0402


NP0

Murata GRM1555C series

C125

220 pF 5%,
0402 NP0

220 pF 5%, 0402


NP0

12 pF 5%, 0402
NP0

Murata GRM1555C series

47 pF 5%, 0402
NP0

Murata GRM1555C series

C126
C131

6.8 pF 0.5 pF,


0402 NP0

3.9 pF 0.25 pF,


0402 NP0

1.5 pF 0.25 pF,


0402 NP0

Murata GRM1555C series

L121

33 nH 5%, 0402
monolithic

27 nH 5%, 0402
monolithic

12 nH 5%, 0402
monolithic

Murata LQG15HS series (315/433 MHz)


Murata LQW15xx series (868/915 MHz)

L122

18 nH 5%, 0402
monolithic

22 nH 5%, 0402
monolithic

18 nH 5%, 0402
monolithic

Murata LQG15HS series (315/433 MHz)


Murata LQW15xx series (868/915 MHz)

L123

33 nH 5%, 0402
monolithic

27 nH 5%, 0402
monolithic

12 nH 5%, 0402
monolithic

Murata LQG15HS series (315/433 MHz)


Murata LQW15xx series (868/915 MHz)

L124

12 nH 5%, 0402
monolithic

Murata LQG15HS series (315/433 MHz)


Murata LQW15xx series (868/915 MHz)

L125

3.3 nH 5%, 0402


monolithic

Murata LQG15HS series (315/433 MHz)


Murata LQW15xx series (868/915 MHz)

12 nH 5%, 0402
monolithic

Murata LQG15HS series (315/433 MHz)


Murata LQW15xx series (868/915 MHz)

18 nH 5%, 0402
monolithic

Murata LQG15HS series (315/433 MHz)


Murata LQW15xx series (868/915 MHz)

L131

33 nH 5%, 0402
monolithic

27 nH 5%, 0402
monolithic

L132
R171
XTAL

56 k 1%, 0402

Koa RK73 series

26.0 MHz surface mount crystal

NDK, NX3225GA or AT-41CD2


1

Table 21: Bill Of Materials for the Application Circuit


1

Refer to design note DN032 [24] for information about performance when using inductors from
other vendors than Murata.
7.8

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 for good thermal
performance and sufficiently low inductance to
ground.

SWRS061I

In the CC1101EM reference designs ([1] and


[2]), 5 vias are placed 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

Page 26 of 98

CC1101
reflow process, which may cause defects
(splattering, solder balling). Using tented vias
reduces the solder paste coverage below
100%. See Figure 12 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
best routing is from the power line (or power
plane) to the decoupling capacitor and then to
the CC1101 supply pin. Supply power filtering is
very important.
Each decoupling capacitor ground pad should
be connected to the ground plane by separate
vias. Direct connections between neighboring
power pins will increase noise coupling and
should be avoided unless absolutely
necessary. Routing in the ground plane
underneath the chip or the balun/RF matching
circuit, or between the chips ground vias and
the decoupling capacitors ground vias should
be avoided. This improves the grounding and

ensures the shortest possible current return


path.
Avoid routing digital signals with sharp edges
close to XOSC_Q1 PCB track or underneath
the crystal Q1 pad as this may shift the crystal
dc operating point and result in duty cycle
variation.
The external components should ideally be as
small as possible (0402 is recommended) and
surface
mount
devices
are
highly
recommended. Please note that components
with different sizes 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 CC1101DK Development Kit with a fully
assembled CC1101EM 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 ([1] and [2]).

Figure 12: Left: Top Solder Resist Mask (Negative). Right: Top Paste Mask. Circles are Vias

Configuration Overview

CC1101 can be configured to achieve optimum


performance for many different applications.
Configuration is done using the SPI interface.
See Section 10 below for more description of
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 rate
Modulation format
RX channel filter bandwidth
RF output power

SWRS061I

Data buffering with separate 64-byte


receive and transmit FIFOs
Packet radio hardware support
Forward Error Correction (FEC) with
interleaving
Data whitening
Wake-On-Radio (WOR)

Details of each configuration register can be


found in Section 29, starting on page 66.
Figure 13 shows a simplified state diagram
that explains the main CC1101 states together
with typical usage and current consumption.
For detailed information on controlling the

Page 27 of 98

CC1101
CC1101 state machine, and a complete state

diagram, see Section 19, starting on page 50.

Sleep
SPWD or wake-on-radio (WOR)

SIDLE

Default state when the radio is not


receiving or transmitting. Typ.
current consumption: 1.7 mA.

CSn = 0

Lowest power mode. Most


register values are retained.
Current consumption typ
200 nA, or typ 500 nA when
wake-on-radio (WOR) is
enabled.

IDLE
SXOFF

Used for calibrating frequency


synthesizer upfront (entering
receive or transmit mode can
Manual freq.
then be done quicker).
synth. calibration
Transitional state. Typ. current
consumption: 8.4 mA.

SCAL
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.4 mA.

Frequency
synthesizer startup,
optional calibration,
settling

Crystal
oscillator off

All register values are


retained. Typ. current
consumption; 165 A.

Frequency synthesizer is turned on, can optionally be


calibrated, and then settles to the correct frequency.
Transitional state. Typ. current consumption: 8.4 mA.

Frequency
synthesizer on
STX
SRX or wake-on-radio (WOR)
STX

TXOFF_MODE = 01
SFSTXON or RXOFF_MODE = 01

Typ. current consumption:


16.8 mA at 0 dBm output,
30.0 mA at +10 dBm output,
34.2 mA at +12 dBm output.

STX or RXOFF_MODE=10

Transmit mode

SRX or TXOFF_MODE = 11

TXOFF_MODE = 00

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.7 mA.

Receive mode

RXOFF_MODE = 00

Optional transitional state. Typ.


current consumption: 8.4 mA.
TX FIFO
underflow

Typ. current
consumption:
from 14.7 mA (strong
input signal) to 15.7 mA
(weak input signal).

Optional freq.
synth. calibration

SFTX

RX FIFO
overflow

In FIFO-based modes,
reception is turned off and this
state entered if the RX FIFO
overflows. Typ. current
consumption: 1.7 mA.

SFRX

IDLE

Figure 13: Simplified State Diagram, with Typical Current Consumption at 1.2 kBaud Data
Rate and MDMCFG2.DEM_DCFILT_OFF=1 (current optimized). Frequency Band = 868 MHz

SWRS061I

Page 28 of 98

CC1101
9

Configuration Software

CC1101 can be configured using the SmartRFTM

After chip reset, all the registers have default


values as shown in the tables in Section 29.
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.

Studio software [5]. 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 CC1101 is
shown in Figure 14.

TM

Figure 14: SmartRF

Studio [5] User Interface

10 4-wire Serial Configuration and Data Interface


CC1101 is configured via a simple 4-wire SPIcompatible interface (SI, SO, SCLK and CSn)
where CC1101 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.
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 (A5 A0).
The CSn pin must be kept low during transfers
on the SPI bus. If CSn goes high during the

SWRS061I

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
15 with reference to Table 22.
When CSn is pulled low, the MCU must wait
until CC1101 SO pin goes low before starting to
transfer the header byte. This indicates that
the crystal is running. Unless the chip was in
the SLEEP or XOFF states, the SO pin will
always go low immediately after taking CSn
low.

Page 29 of 98

CC1101
tsp

tch

tcl

tsd

thd

tns

SCLK:
CSn:
Write to register:
SI

A5

SO

Hi-Z

S7

S5

SI

A4

A3

A2

A1

A0

S4

S3

S2

S1

S0

DW7

DW6
S6

S7

DW5
S5

DW4

DW3

DW2

DW1

DW0

S3

S2

S1

S0

DR2

DR1

S4

X
Hi-Z

Read from register:

SO Hi-Z

A5

A4

A3

A2

A1

A0

S7

S5

S4

S3

S2

S1

S0

X
DR7

DR6

DR5

DR4

DR3

DR0

Hi-Z

Figure 15: Configuration Registers Write and Read Operations

Parameter

Description

Min

Max

Units

fSCLK

SCLK frequency

10

MHz

6.5

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

SCLK frequency, burst access


No delay between address and data byte, or between data bytes

tsp,pd

CSn low to positive edge on SCLK, in power-down mode

150

tsp

CSn low to positive edge on SCLK, in active mode

20

ns

tch

Clock high

50

ns

tcl

Clock low

50

ns

trise

Clock rise time

40

ns

tfall

Clock fall time

40

ns

tsd

Setup data (negative SCLK edge) to


positive edge on SCLK

Single access

55

ns

Burst access

76

(tsd applies between address and data bytes, and between


data bytes)

thd

Hold data after positive edge on SCLK

20

ns

tns

Negative edge on SCLK to CSn high.

20

ns

Table 22: SPI Interface Timing Requirements


Note: The minimum tsp,pd figure in Table 22 can be used in cases where the user does not read
the CHIP_RDYn signal. CSn low to positive edge on SCLK when the chip is woken from powerdown depends on the start-up time of the crystal being used. The 150 s in Table 22 is the
crystal oscillator start-up time measured on CC1101EM reference designs ([1] and [2]) using
crystal AT-41CD2 from NDK.

SWRS061I

Page 30 of 98

CC1101
10.1 Chip Status Byte
When the header byte, data byte, or command
strobe is sent on the SPI interface, the chip
status byte is sent by the CC1101 on the SO pin.
The status byte contains key status signals,
useful for the MCU. The first bit, s7, is the
CHIP_RDYn signal and this signal must go low
before the first positive edge of SCLK. The
CHIP_RDYn 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 are 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
Bits

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
contains 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
FIFO_BYTES_AVAILABLE=15, 15 or more
bytes are available/free.
Table 23 gives a status byte summary.

Name

Description

CHIP_RDYn

Stays high until power and crystal have stabilized. Should always be low when using
the SPI interface.

6:4

STATE[2:0]

Indicates the current main state machine mode


Value

State

Description

000

IDLE

IDLE state
(Also reported for some transitional states instead
of SETTLING or CALIBRATE)

3:0

FIFO_BYTES_AVAILABLE[3:0]

001

RX

Receive mode

010

TX

Transmit mode

011

FSTXON

Fast TX ready

100

CALIBRATE

Frequency synthesizer calibration is running

101

SETTLING

PLL is settling

110

RXFIFO_OVERFLOW

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

The number of bytes available in the RX FIFO or free bytes in the TX FIFO

Table 23: Status Byte Summary


10.2 Register Access
The configuration registers on the CC1101 are
located on SPI addresses from 0x00 to 0x2E.
Table 43 on page 68 lists all configuration
registers. It is highly recommended to use
SmartRF Studio [5] to generate optimum
register settings. The detailed description of
each register is found in Section 29.1 and
29.2, starting on page 71. 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,

SWRS061I

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 (A5 A0) set the start address in an
internal address counter. This counter is
incremented by one each new byte (every 8

Page 31 of 98

CC1101
clock pulses). The burst access is either a
read or a write access and must be terminated
by setting CSn high.
For register addresses in the range 0x300x3D, the burst bit is used to select between
status registers when burst bit is one, and
between command strobes when burst bit is

zero. See more in Section 10.3 below.


Because of this, burst access is not available
for status registers and they must be accessed
one at a time. The status registers can only be
read.

10.3 SPI Read


When reading register fields over the SPI
interface while the register fields are updated
by the radio hardware (e.g. MARCSTATE or
TXBYTES), 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 CC1101 Errata Notes [3] for more details.

10.4 Command Strobes


Command Strobes may be viewed as single
byte instructions to CC1101. 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 42 on
page 67.
Note: An SIDLE strobe will clear all
pending command strobes until IDLE
state is reached. This means that if for
example an SIDLE strobe is issued
while the radio is in RX state, any other
command strobes issued before the
radio reaches IDLE state will be
ignored.

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
FIFO_BYTES_AVAILABLE field in the status
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 wait for SO to go low again
before the next header byte can be issued as
shown in Figure 16. The command strobes are
executed immediately, with the exception of
the SPWD, SWOR, and the SXOFF strobes,
which are executed when CSn goes high.

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
CSn

SO

SI

HeaderSRES

HeaderAddr

Data

Figure 16: SRES Command Strobe


10.5 FIFO Access
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.

SWRS061I

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

Page 32 of 98

CC1101
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.

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 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

The TX FIFO may be flushed by issuing a


SFTX 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_UNDERFLOW, or
RXFIFO_OVERFLOW states. Both FIFOs are
flushed when going to the SLEEP state.

When writing to the TX FIFO, the status byte


(see Section 10.1) is output on SO for each
new data byte as shown in Figure 15. This
status byte can be used to detect TX FIFO

Figure 17 gives a brief overview of different


register access types possible.

10.6 PATABLE Access


The 0x3E address is used to access the
PATABLE, 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. See SmartRF Studio
[5] for recommended shaping / PA ramping
sequences. See also Section 24 for details on
output power programming.

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, CSn must be set high
before the read access in order to set the
index counter back to zero.

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

Note that the content of the PATABLE is lost


when entering the SLEEP state, except for the
first byte (index 0).
For more information, see Design Note DN501
[18].

CSn:
Command strobe(s):
Read or write register(s):

HeaderStrobe

HeaderStrobe

HeaderStrobe

HeaderReg

Data

HeaderReg

Data

Read or write consecutive


registers (burst):

HeaderReg n

Datan

Datan + 1

Datan + 2

Read or write n + 1 bytes


from/to the RX/TX FIFO:

HeaderFIFO

DataByte 0

DataByte 1

DataByte 2

HeaderReg

Data

HeaderStrobe

HeaderReg

Combinations:

HeaderReg

Data

Data

DataByte n - 1

DataByte n

HeaderStrobe

HeaderFIFO

DataByte 0

DataByte 1

Figure 17: Register Access Types

SWRS061I

Page 33 of 98

CC1101
11 Microcontroller Interface and Pin Configuration
In a typical system, CC1101 will interface to a
microcontroller. This microcontroller must be
able to:
Program CC1101 into different modes

Read and write buffered data


Read back status information via the 4-wire
SPI-bus configuration interface (SI, SO,
SCLK and CSn)

11.1 Configuration Interface


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 29.

11.2 General Control and Status Pins


The CC1101 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 26 on page 61 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.

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. With default PTEST
register setting (0x7F), the temperature sensor
output is only available if the frequency
synthesizer is enabled (e.g. the MANCAL,
FSTXON, RX, and TX states). It is necessary
to write 0xBF to the PTEST 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).

In the synchronous and asynchronous serial


modes, the GDO0 pin is used as a serial TX
data input pin while in transmit mode.
11.3 Optional Radio Control Feature
The CC1101 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
MCSM0.PIN_CTRL_EN configuration bit.

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. The
SPWD strobe is delayed until CSn goes high.

State changes are commanded as follows:

CSn

SCLK

SI

Function

If CSn is high, the SI and SCLK are set to


the desired state according to Table 24.

Chip unaffected by SCLK/SI

Generates SPWD strobe

If CSn goes low, the state of SI and SCLK


is latched and a command strobe is
generated internally according to the pin
configuration.

Generates STX strobe

Generates SIDLE strobe

Generates SRX strobe

It is only possible to change state with the


latter functionality. That means that for
instance RX will not be restarted if SI and

SPI
mode

SPI
mode

SPI mode (wakes up into


IDLE if in SLEEP/XOFF)

SWRS061I

Table 24: Optional Pin Control Coding

Page 34 of 98

CC1101
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
MDMCFG4.DRATE_E configuration registers.
The data rate is given by the formula below.
As the formula shows, the programmed data
rate depends on the crystal frequency.

RDATA

256 DRATE _ M 2DRATE _ E f

228

XOSC

The following approach can be used to find


suitable values for a given data rate:

R
2
DRATE _ E log 2 DATA

f XOSC
R DATA 2 28
DRATE _ M
f XOSC 2 DRATE _ E

20

256

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 0.6 kBaud to


500 kBaud with the minimum step size
according to Table 25 below. See Table 3 for
the minimum and maximum data rates for the
different modulation formats.
Min Data
Rate
[kBaud]

Typical Data
Rate
[kBaud]

Max Data
Rate
[kBaud]

Data rate
Step Size
[kBaud]

0.6

1.0

0.79

0.0015

0.79

1.2

1.58

0.0031

1.59

2.4

3.17

0.0062

3.17

4.8

6.33

0.0124

6.35

9.6

12.7

0.0248

12.7

19.6

25.3

0.0496

25.4

38.4

50.7

0.0992

50.8

76.8

101.4

0.1984

101.6

153.6

202.8

0.3967

203.1

250

405.5

0.7935

406.3

500

500

1.5869

Table 25: Data Rate Step Size (assuming a


26 MHz crystal)

13 Receiver Channel Filter Bandwidth


In order to meet different channel width
requirements, the receiver channel filter is
programmable. The MDMCFG4.CHANBW_E and
MDMCFG4.CHANBW_M configuration registers
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:

MDMCFG4.CHANBW_E

MDMCFG4.
CHANBW_M

00

01

10

11

00

812

406

203

102

01

650

325

162

81

10

541

270

135

68

11

464

232

116

58

Table 26: Channel Filter Bandwidths [kHz]


(assuming a 26 MHz crystal)

f XOSC
BWchannel
8 (4 CHANBW _ M )2CHANBW _ E
Table 26 lists the channel filter bandwidths
supported by the CC1101.

SWRS061I

By compensating for a frequency offset


between the transmitter and the receiver, the
filter bandwidth can be reduced and the
sensitivity improved, see more in DN005 [17]
and in Section 14.1.

Page 35 of 98

CC1101
14 Demodulator, Symbol Synchronizer, and Data Decision
CC1101 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.

14.1 Frequency Offset Compensation


The CC1101 has a very fine frequency
resolution (see Table 15). This feature can be
used to compensate for frequency offset and
drift.
When using 2-FSK, GFSK, 4-FSK, 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. The
frequency offset compensation configuration is
controlled from the FOCCFG register. By
compensating for a large frequency offset
between the transmitter and the receiver, the
sensitivity can be improved, see DN005 [17].
The tracking range of the algorithm is
selectable as fractions of the channel
bandwidth with the FOCCFG.FOC_LIMIT
configuration register.
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.
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
FOCCFG.FOC_POST_K selects the gain after
the sync word has been found.
Note: Frequency offset compensation is
not supported for ASK or OOK modulation.
The estimated frequency offset value is
available in the FREQEST status register. This
can be used for permanent frequency offset
compensation. By writing the value from
FREQEST into
FSCTRL0.FREQOFF, the
frequency synthesizer will automatically be
adjusted according to the estimated frequency
offset. More details regarding this permanent
frequency compensation algorithm can be
found in DN015 [10].

14.2 Bit Synchronization


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.


Re-synchronization is performed continuously
to adjust for error in the incoming symbol rate.

14.3 Byte Synchronization


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 MSB in the sync word is
sent first. 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

SWRS061I

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 for more details.

Page 36 of 98

CC1101
15 Packet Handling Hardware Support
The CC1101 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 (FEC) 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 detection
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 27 and


Table 28) with RSSI value, Link Quality
Indication, and CRC status can be appended
in the RX FIFO.
Bit

Field Name

Description

7:0

RSSI

RSSI value

Table 27: Received Packet Status Byte 1


(first byte appended after the data)
Bit

Field Name

Description

CRC_OK

1: CRC for received data OK


(or CRC disabled)
0: CRC error in received data

6:0

LQI

Indicating the link quality

Table 28: Received Packet Status Byte 2


(second byte appended after the data)
Note: Register fields that control the
packet handling features should only be
altered when CC1101 is in the IDLE state.

15.1 Data Whitening


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).
Real data often contain long sequences of
zeros and ones. In these cases, performance
can be improved by whitening the data before
transmitting, and de-whitening the data in the
receiver.

SWRS061I

With CC1101, this can be done automatically.


By setting PKTCTRL0.WHITE_DATA=1, all
data, except the preamble and the sync word
will be XOR-ed with a 9-bit pseudo-random
(PN9) sequence before being transmitted. This
is shown in Figure 18. At the receiver end, the
data are XOR-ed with the same pseudorandom sequence. In this way, the whitening is
reversed, and the original data appear in the
receiver. The PN9 sequence is initialized to all
1s.

Page 37 of 98

CC1101

TX_DATA

The first TX_DATA byte is shifted in before doing the XOR-operation providing the first TX_OUT[7:0] byte. The
second TX_DATA byte is then shifted in before doing the XOR-operation providing the second TX_OUT[7:0] byte.
TX_OUT[7:0]

Figure 18: Data Whitening in TX Mode


15.2 Packet Format
The format of the data packet can be
configured and consists of the following items
(see Figure 19):

Preamble
Synchronization word

Optional length byte


Optional address byte
Payload
Optional 2 byte CRC

Data field

16/32 bits

8
bits

8
bits

8 x n bits

Legend:
Inserted automatically in TX,
processed and removed in RX.

CRC-16

Address field

8 x n bits

Length field

Preamble bits
(1010...1010)

Sync word

Optional data whitening


Optionally FEC encoded/decoded
Optional CRC-16 calculation

Optional user-provided fields processed in TX,


processed but not removed in RX.
Unprocessed user data (apart from FEC
and/or whitening)

16 bits

Figure 19: Packet Format


The preamble pattern is an alternating
sequence of ones and zeros (10101010).
The minimum length of the preamble is
programmable
through
the
value
of
MDMCFG1.NUM_PREAMBLE. 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 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.

SWRS061I

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 sync 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
setting
MDMCFG2.SYNC_MODE to 3 or 7. The sync
word will then be repeated twice.

CC1101 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

Page 38 of 98

CC1101
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. This value must be different from 0.
In
variable
packet
length
mode,
PKTCTRL0.LENGTH_CONFIG=1, 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. The PKTLEN value must be
different from 0.The first byte written to the
TXFIFO must be different from 0.
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 CC1101. One should make sure
that TX mode is not turned off during the
transmission of the first half of any byte. Refer
to the CC1101 Errata Notes [3] for more details.
Note: 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
(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

SWRS061I

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
The packet automation control register,
PKTCTRL0, 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
(see also Figure 20)

Set PKTCTRL0.LENGTH_CONFIG=2.

Pre-program the PKTLEN


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).

Set PKTCTRL0.LENGTH_CONFIG=0.

The transmission ends when the packet


counter reaches 88. A total of 600 bytes
are transmitted.

register to

Page 39 of 98

CC1101
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 20: Packet Length > 255


15.3 Packet Filtering in Receive Mode

CC1101 supports three different types of


packet-filtering; address filtering, maximum
length filtering, and CRC filtering.
15.3.1 Address Filtering
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
PKTCTRL1.ADR_CHK=10 or both the 0x00
and 0xFF broadcast addresses when
PKTCTRL1.ADR_CHK=11. 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
MCSM1.RXOFF_MODE setting).
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,
PKTCTRL0.LENGTH_CONFIG=1,
the
PKTLEN.PACKET_LENGTH register value is

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
MCSM1.RXOFF_MODE setting).
15.3.3 CRC Filtering
The filtering of a packet when CRC check fails
is
enabled
by
setting
PKTCTRL1.CRC_AUTOFLUSH=1. The CRC
auto flush function will flush the entire RX
FIFO if the CRC check fails. After auto flushing
the RX FIFO, the next state depends on the
MCSM1.RXOFF_MODE setting.
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 when
PKTCTRL1.APPEND_STATUS is enabled, the
maximum allowed packet length is reduced by
two bytes in order 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


The payload that is to be transmitted must be
written into the TX FIFO. The first byte written
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

SWRS061I

second byte written to the TX FIFO must be


the address byte.
If fixed packet length is enabled, the first byte
written to the TX FIFO should be the address
(assuming the receiver uses address
recognition).

Page 40 of 98

CC1101
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 followed
by the payload in the TX FIFO. If CRC is
enabled, the checksum is calculated over all
the data pulled from the TX FIFO, and the
result is sent as two extra bytes following the
payload data. If the TX FIFO runs empty
before the complete packet has been
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
PKTCTRL0.WHITE_DATA=1.
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
MDMCFG1.FEC_EN=1.

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 synchronization
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 27 and Table 28) 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
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:

on how many bytes that are in the RX FIFO


and
TX
FIFO
respectively.
The
IOCFGx.GDOx_CFG=0x00
and
the
IOCFGx.GDOx_CFG=0x01 configurations are
associated with the RX FIFO while the
IOCFGx.GDOx_CFG=0x02
and
the
IOCFGx.GDOx_CFG=0x03
configurations
are associated with the TX FIFO. See Table
41 for more information.

a) Interrupt Driven Solution

The PKTSTATUS register can be polled at a


given rate to get information about the current
GDO2 and GDO0 values respectively. The
RXBYTES and TXBYTES registers can be
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

The GDO pins can be used in both RX and TX


to give an interrupt when a sync word has
been received/transmitted or when a complete
packet has been received/transmitted by
setting IOCFGx.GDOx_CFG=0x06. In addition,
there are two configurations for the
IOCFGx.GDOx_CFG register that can be used
as an interrupt source to provide information

SWRS061I

b) SPI Polling

Page 41 of 98

CC1101
MISO line each time a header byte, data byte,
or command strobe is sent on the SPI bus.

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.

It is recommended to employ an interrupt


driven solution since high rate SPI polling
reduces the RX sensitivity. Furthermore, as
explained in Section 10.3 and the CC1101
Errata Notes [3], when using SPI polling, there

Refer to the TI website for SW examples ([6]


and [7]).

16 Modulation Formats
CC1101 supports amplitude, frequency, and

MDMCFG2.MANCHESTER_EN=1.

phase shift modulation formats. The desired


modulation
format
is
set
in
the
MDMCFG2.MOD_FORMAT register.

Note: Manchester encoding is not


supported at the same time as using the
FEC/Interleaver option or when using MSK
and 4-FSK modulation.

Optionally, the data stream can be Manchester


coded by the modulator and decoded by the
demodulator. This option is enabled by setting
16.1 Frequency Shift Keying

CC1101 supports both 2-FSK and 4-FSK

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:

modulation. 2-FSK can optionally be shaped


by a Gaussian filter with BT = 0.5, producing a
GFSK modulated signal. This spectrumshaping feature improves adjacent channel
power (ACP) and occupied bandwidth. When
selecting 4-FSK, the preamble and sync word
is sent using 2-FSK (see Figure 21).
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.

The symbol encoding is shown in Table 29.


Format

Symbol

Coding

Deviation

+ Deviation

01

Deviation

00

1/3 Deviation

10

+1/3 Deviation

11

+ Deviation

2-FSK/GFSK

When 2-FSK/GFSK/4-FSK modulation is used,


the DEVIATN register specifies the expected
frequency deviation of incoming signals in RX
and should be the same as the TX deviation
for demodulation to be performed reliably and
robustly.

1/Baud Rate

f xosc
(8 DEVIATION _ M ) 2 DEVIATION _ E
217

f dev

4-FSK

Table 29: Symbol Encoding for 2-FSK/GFSK


and 4-FSK Modulation

1/Baud Rate

1/Baud Rate

+1
+1/3
-1/3
-1

Preamble
0xAA

Sync
0xD3

00 01 01 11 10 00 11 01
Data
0x17 0x8D

Figure 21: Data Sent Over the Air (MDMCFG2.MOD_FORMAT=100)

SWRS061I

Page 42 of 98

CC1101
16.2 Minimum Shift Keying
2

When using MSK , the complete transmission


(preamble, sync word, and payload) will be
MSK modulated.

This is equivalent to changing the shaping of


the symbol. The DEVIATN register setting has
no effect in RX when using MSK.

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 DEVIATN.DEVIATION_M setting.

When
using
MSK,
Manchester
encoding/decoding should be disabled by
setting MDMCFG2.MANCHESTER_EN=0.

Identical to offset QPSK with half-sine


shaping (data coding may differ).

The MSK modulation format implemented in


CC1101 inverts the sync word and data
compared to e.g. signal generators.

16.3 Amplitude Modulation

CC1101

supports two different forms of


amplitude modulation: On-Off Keying (OOK)
and Amplitude Shift Keying (ASK).
OOK modulation simply turns the PA on or off
to modulate ones and zeros respectively.
The ASK variant supported by the CC1101
allows programming of the modulation depth
(the difference between 1 and 0), and shaping
of the pulse amplitude. Pulse shaping

produces a more
output spectrum.

bandwidth

constrained

When using OOK/ASK, the AGC settings from


the SmartRF Studio [5] preferred FSK/MSK
settings are not optimum. DN022 [16] give
guidelines on how to find optimum OOK/ASK
settings from the preferred settings in
SmartRF Studio [5]. The DEVIATN register
setting has no effect in either TX or RX when
using OOK/ASK.

17 Received Signal Qualifiers and Link Quality Information


CC1101 has several qualifiers that can be used

RSSI

to increase the likelihood that a valid sync


word is detected:

Carrier Sense

Sync Word Qualifier

Clear Channel Assessment

Preamble Quality Threshold

Link Quality Indicator

17.1

Sync Word Qualifier

If sync word detection in RX is enabled in the


MDMCFG2 register, the CC1101 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

SWRS061I

word
qualifier
mode
is
set
by
MDMCFG2.SYNC_MODE and is summarized in
Table 30. Carrier sense in Table 30 is
described in Section 17.4.

Page 43 of 98

CC1101
MDMCFG2.SYNC_MODE

Sync Word Qualifier Mode

000

No preamble/sync

001

15/16 sync word bits detected

010

16/16 sync word bits detected

011

30/32 sync word bits detected

100

No preamble/sync + carrier sense


above threshold

101

15/16 + carrier sense above threshold

110

16/16 + carrier sense above threshold

111

30/32 + carrier sense above threshold

Table 30: Sync Word Qualifier Mode


17.2 Preamble Quality Threshold (PQT)
The Preamble Quality Threshold (PQT) sync
word 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 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 eight 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 4PQT for
this counter is used to gate sync word
detection. By setting the value to zero, the
preamble quality qualifier of the sync word is
disabled.
A Preamble Quality Reached signal can be
observed on one of the GDO pins by setting
IOCFGx.GDOx_CFG=8. It is also possible to
determine if preamble quality is reached by
checking the PQT_REACHED bit in the
PKTSTATUS 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.

(BW channel is defined in Section 13) and


AGCCTRL0.FILTER_LENGTH.

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.

If PKTCTRL1.APPEND_STATUS is enabled,
the last RSSI value of the packet is
automatically added to the first byte appended
after the payload.

Note: It takes some time from the radio


enters RX mode until a valid RSSI value is
present in the RSSI register. Please see
DN505 [12] for details on how the RSSI
response time can be estimated.

The RSSI value is given in dBm with a dB


resolution. The RSSI update rate, fRSSI,
depends on the receiver filter bandwidth

SWRS061I

f RSSI

2 BWchannel
8 2FILTER _ LENGTH

The RSSI value read from the RSSI status


register is a 2s 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

Page 44 of 98

CC1101
4) Else if RSSI_dec < 128 then RSSI_dBm =
(RSSI_dec)/2 RSSI_offset

typical plots of RSSI readings as a function of


input power level for different data rates.

Table 31 gives typical values for the


RSSI_offset. Figure 22 and Figure 23 show
Data rate [kBaud]

RSSI_offset [dB], 433 MHz

RSSI_offset [dB], 868 MHz

1.2

74

74

38.4

74

74

250

74

74

500

74

74

Table 31: Typical RSSI_offset Values


0
-10
-20

RSSI Readout [dBm]

-30
-40
-50
-60
-70
-80
-90
-100
-110
-120
-120

-110

-100

-90

-80

-70

-60

-50

-40

-30

-20

-10

Input Power [dBm]


1.2 kBaud

38.4 kBaud

250 kBaud

500 kBaud

Figure 22: Typical RSSI Value vs. Input Power Level for Different Data Rates at 433 MHz

SWRS061I

Page 45 of 98

CC1101
0
-10
-20

RSSI Readout [dBm]

-30
-40
-50
-60
-70
-80
-90
-100
-110
-120
-120

-110

-100

-90

-80

-70

-60

-50

-40

-30

-20

-10

Input Power [dBm]

1.2 kBaud

250 kBaud

38.4 kBaud

500 kBaud

Figure 23: Typical RSSI Value vs. Input Power Level for Different Data Rates at 868 MHz
17.4 Carrier Sense (CS)
Carrier sense (CS) is used as a sync word
qualifier and for Clear Channel Assessment
(see Section 17.5). CS can be asserted based
on two conditions which can be individually
adjusted:

optional fast RX termination (see Section


19.7).

CS is asserted when the RSSI is above a


programmable absolute threshold, and deasserted when RSSI is below the same
threshold (with hysteresis). See more in
Section 17.4.1.

17.4.1 CS Absolute Threshold

AGCCTRL2.MAX_LNA_GAIN

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.
See more in Section 17.4.2.

AGCCTRL2.MAX_DVGA_GAIN

AGCCTRL1.CARRIER_SENSE_ABS_THR

AGCCTRL2.MAGN_TARGET

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 and is set by setting
MDMCFG2 The carrier sense signal can be
observed on one of the GDO pins by setting
IOCFGx.GDOx_CFG=14 and in the status
register bit PKTSTATUS.CS.
Other uses of Carrier sense include the TX-ifCCA function (see Section 17.5) and the

SWRS061I

CS can be used to avoid interference from


other RF sources in the ISM bands.

The absolute threshold related to the RSSI


value depends on the following register fields:

For given AGCCTRL2.MAX_LNA_GAIN and


AGCCTRL2.MAX_DVGA_GAIN settings, the
absolute threshold can be adjusted 7 dB in
steps
of
1
dB
using
CARRIER_SENSE_ABS_THR.
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
Studio
[5]
to
generate
the
correct
MAGN_TARGET setting. Table 32 and Table

Page 46 of 98

CC1101

If the threshold is set high, i.e. only strong


signals are wanted, the threshold should be
adjusted upwards by first reducing the
MAX_LNA_GAIN
value
and
then
the
MAX_DVGA_GAIN value. This will reduce
power consumption in the receiver front end,
since the highest gain settings are avoided.

MAX_DVGA_GAIN[1:0]

MAX_LNA_GAIN[2:0]

33 show the typical RSSI readout values at the


CS threshold at 2.4 kBaud and 250 kBaud
data rate respectively. The default reset value
for CARRIER_SENSE_ABS_THR = 0 (0 dB) has
been used. MAGN_TARGET = 3 (33 dB) and 7
(42 dB) have been used for 2.4 kBaud and
250 kBaud data rate respectively. For other
data rates, the user must generate similar
tables to find the CS absolute threshold.

00

01

10

11

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

101

-78

-72

-66

-60

110

-76.5

-70

-64

-58

111

-74.5

-68

-62

-56

Table 33: Typical RSSI Value in dBm at CS


Threshold with MAGN_TARGET = 7 (42 dB) at
250 kBaud, 868 MHz

MAX_LNA_GAIN[2:0]

MAX_DVGA_GAIN[1:0]
00

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

17.4.2 CS Relative Threshold


The relative threshold detects sudden changes
in the measured signal level. This setting does
not depend 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.

Table 32: Typical RSSI Value in dBm at CS


Threshold with MAGN_TARGET = 3 (33 dB) at
2.4 kBaud, 868 MHz

SWRS061I

Page 47 of 98

CC1101
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
IOCFGx.GDOx_CFG=0x09.

becomes available, the radio will not enter TX


or FSTXON state before a new strobe
command is sent on the SPI interface. This
feature is called TX-if-CCA. Four CCA
requirements can be programmed:

MCSM1.CCA_MODE selects the mode to use


when determining CCA.

Always (CCA disabled, always goes to TX)

If RSSI is below threshold

When the STX or SFSTXON command strobe is


given while CC1101 is in the RX state, the TX or
FSTXON state is only entered if the clear
channel requirements are fulfilled. Otherwise,
the chip will remain in RX. If the channel then

Unless currently receiving a packet

Both the above (RSSI below threshold and


not currently receiving a packet)

17.6 Link Quality Indicator (LQI)


The Link Quality Indicator is a metric of the
current quality of the received signal. If
PKTCTRL1.APPEND_STATUS is enabled, the
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 low value
indicates a better link than what a high value
does), since the value is dependent on the
modulation format.

18 Forward Error Correction with Interleaving


18.1 Forward Error Correction (FEC)

CC1101 has built in support for Forward Error


Correction (FEC). To enable this option, set
MDMCFG1.FEC_EN to 1. FEC is only supported
in fixed packet length mode, i.e. when
PKTCTRL0.LENGTH_CONFIG=0.
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 Signal-to-Noise Ratio (SNR), thus
extending communication range if the receiver
bandwidth remains constant. Alternatively, for
a given SNR, using FEC decreases the bit
error rate (BER). The packet error rate (PER)
is related to BER by

PER 1 (1 BER ) packet _ length


A lower BER can therefore 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

SWRS061I

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 CC1101 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 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. This
means that in order to transmit at the same
effective data rate when using FEC, it is
necessary to use twice as high over-the-air
data rate. This will require a higher receiver
bandwidth, and thus reduce sensitivity. In
other words the improved reception by using
FEC and the degraded sensitivity from a
higher
receiver
bandwidth
will
be
counteracting factors. See Design Note
DN504 for more details [19].

Page 48 of 98

CC1101
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.

passed onto the convolutional decoder is read


from the columns of the matrix.

CC1101 employs a 4x4 matrix interleaver with 2


bits (one encoder output symbol) per cell and
the amount of data transmitted over the air will
thus always be a multiple of four bytes (see
DN507 [20] for more details). When FEC and
interleaving is used, at least one extra byte is
required for trellis termination and the packet
control hardware therefore automatically
inserts one or two extra bytes at the end of the
packet. These bytes will be invisible to the
user, as they are removed before the received
packet enters the RXFIFO.

CC1101 employs matrix interleaving, which is


illustrated in Figure 24. 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
receiver, the received symbols are written into
the rows of the matrix, whereas the data

When FEC and interleaving is used the


minimum data payload is 2 bytes.

Interleaver
Write buffer

Packet
Engine

Interleaver
Read buffer

FEC
Encoder

Modulator

Interleaver
Write buffer

Interleaver
Read buffer

FEC
Decoder

Demodulator

Packet
Engine

Figure 24: General Principle of Matrix Interleaving

SWRS061I

Page 49 of 98

CC1101
19 Radio Control
SIDLE
SPWD | SWOR

SLEEP
0

CAL_COMPLETE
MANCAL
3,4,5

IDLE
1

CSn = 0 | WOR
SXOFF

SCAL
CSn = 0
XOFF
2

SRX | STX | SFSTXON | WOR

FS_WAKEUP
6,7

FS_AUTOCAL = 01
&
SRX | STX | SFSTXON | WOR

FS_AUTOCAL = 00 | 10 | 11
&
SRX | STX | SFSTXON | WOR

SETTLING
9,10,11

SFSTXON

CALIBRATE
8

CAL_COMPLETE

FSTXON
18
STX

SRX

STX

TXOFF_MODE=01

SFSTXON | RXOFF_MODE = 01

STX | RXOFF_MODE = 10
TXOFF_MODE = 10

SRX | WOR

RXTX_SETTLING
21

TX
19,20

SRX | TXOFF_MODE = 11

TXOFF_MODE = 00
&
FS_AUTOCAL = 00 | 01

RX
13,14,15

RXOFF_MODE = 11

TXRX_SETTLING
16
RXOFF_MODE = 00
&
FS_AUTOCAL = 10 | 11

TXOFF_MODE = 00
&
FS_AUTOCAL = 10 | 11

TXFIFO_UNDERFLOW

( STX | SFSTXON ) & CCA


|
RXOFF_MODE = 01 | 10

CALIBRATE
12

TX_UNDERFLOW
22

SFTX

RXOFF_MODE = 00
&
FS_AUTOCAL = 00 | 01

RXFIFO_OVERFLOW

RX_OVERFLOW
17

SFRX
IDLE
1

Figure 25: Complete Radio Control State Diagram

CC1101 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.

shown in Figure 13 on page 28. The complete


radio control state diagram is shown in Figure
25. The numbers refer to the state number
readable in the MARCSTATE status register.
This register is primarily for test purposes.

A simplified state diagram, together with


typical usage and current consumption, is
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.

SWRS061I

automatic power-on reset (POR) or manual


reset. After the automatic power-on reset or
manual reset, it is also recommended to

Page 50 of 98

CC1101
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.
However, to optimize performance in TX and
RX, an alternative GDO setting from the
settings found in Table 41 on page 62 should
be selected.

this strobe, all internal registers and states are


set to the default, IDLE state. The manual
power-up sequence is as follows (see Figure
27):

Set SCLK = 1 and SI = 0, to avoid


potential problems with pin control mode
(see Section 11.3).

19.1.1 Automatic POR

Strobe CSn low / high.

A power-on reset circuit is included in the


CC1101. The minimum requirements stated in
Table 18 must be followed for the power-on
reset to function properly. The internal powerup sequence is completed when CHIP_RDYn
goes low. CHIP_RDYn is observed on the SO
pin after CSn is pulled low. See Section 10.1
for more details on CHIP_RDYn.

Hold CSn low and then high for at least 40


s relative to pulling CSn low

Pull CSn low and wait for SO to go low


(CHIP_RDYn).

Issue the SRES strobe on the SI line.

When SO goes low again, reset is


complete and the chip is in the IDLE state.

When the CC1101 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
low as shown in Figure 26.

XOSC and voltage regulator switched on


40 us
CSn
SO
XOSC Stable

CSn
SI

SO

SRES

Figure 27: Power-On Reset with SRES


XOSC Stable

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 CC1101 after this, it is only necessary to
issue an SRES command strobe.

Figure 26: Power-On Reset


19.1.2 Manual Reset
The other global reset possibility on CC1101
uses the SRES command strobe. By issuing
19.2 Crystal Control
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

SWRS061I

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.
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.

Page 51 of 98

CC1101
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 then in the SLEEP state. Setting CSn


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
described in Section19.5.

19.4 Active Modes (RX and TX)

CC1101 has two active modes: receive and

IDLE

transmit. These modes are activated directly


by the MCU by using the SRX and STX
command strobes, or automatically by Wake
on Radio.

FSTXON: Frequency synthesizer on and


ready at the TX frequency. Activate TX
with STX

TX: Start sending preamble

RX: Start search for a new packet

The frequency synthesizer must be calibrated


regularly. CC1101 has one manual calibration
option (using the SCAL strobe), and three
automatic calibration options that are
controlled by the MCSM0.FS_AUTOCAL setting:

Calibrate when going from IDLE to either


RX or TX (or FSTXON)

Calibrate when going from either RX or TX


3
to IDLE automatically

Calibrate every fourth time when going


from either RX or TX to IDLE
3
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 34 for
timing details regarding calibration.
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). 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 goes to the state
indicated by the MCSM1.RXOFF_MODE setting.
The possible destinations are:
3

Not forced in IDLE by issuing an SIDLE


strobe

SWRS061I

Note: When MCSM1.RXOFF_MODE=11


and a packet has been received, it will
take some time before a valid RSSI value
is present in the RSSI register again even
if the radio has never exited RX mode.
This time is the same as the RSSI
response time discussed in DN505 [12].
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
MCSM1.TXOFF_MODE setting. The possible
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
SFSTXON command strobes are used, the TXif-CCA function will be used. If the channel is
not clear, the chip will remain in RX. The
MCSM1.CCA_MODE
setting
controls
the
conditions for clear channel assessment. See
Section 17.5 for details.
The SIDLE command strobe can always be
used to force the radio controller to go to the
IDLE state.

Page 52 of 98

CC1101
19.5 Wake On Radio (WOR)
The optional Wake on Radio (WOR)
functionality enables CC1101 to periodically
wake up from SLEEP and listen for incoming
packets without MCU interaction.
When the SWOR strobe command is sent on
the SPI interface, the CC1101 will go to the
SLEEP state when CSn is released. The RC
oscillator must be enabled before the SWOR
strobe can be used, as it is the clock source
for the WOR timer. The on-chip timer will set
CC1101 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 28 and Section 19.7 for
details on how the timeout works.
To exit WOR mode, set the CC1101 into the
IDLE state

CC1101 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
MCSM1.RXOFF_MODE
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.
Note: The FIFO looses its content in the
SLEEP state.

Rx timeout
State:

SLEEP

IDLE

Event0

RX

Event1

SLEEP

IDLE

Event0

RX

Event1
t

tEvent0
tEvent0
tEvent1

tEvent1
tSLEEP

Figure 28: Event 0 and Event 1 Relationship


The time from the CC1101 enters SLEEP state
until the next Event0 is programmed to
appear, tSLEEP in Figure 28, should be larger
than 11.08 ms when using a 26 MHz crystal
and 10.67 ms when a 27 MHz crystal is used.
If tSLEEP is less than 11.08 (10.67) ms, there is
a chance that the consecutive Event 0 will
occur

750
128 seconds
f XOSC
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 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.
The time between two consecutive Event 0 is
programmed with a mantissa value given by
WOREVT1.EVENT0 and WOREVT0.EVENT0,
and
an
exponent
value
set
by
WORCTRL.WOR_RES. The equation is:

t Event 0

750
EVENT 0 2 5WOR _ RES
f XOSC

The Event 1 timeout is programmed with


WORCTRL.EVENT1. Figure 28 shows the
timing relationship between Event 0 timeout
and Event 1 timeout.

SWRS061I

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 are 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
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 to reduce the
current consumption. This is done by setting
WORCTRL.RC_CAL=0 and requires that RC
oscillator calibration values are read from
registers
RCCTRL0_STATUS
and
RCCTRL1_STATUS and written back to

Page 53 of 98

CC1101
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.

19.6 Timing
19.6.1 Overall State Transition Times
The main radio controller needs to wait in
certain states in order to make sure that the
internal analog/digital parts have settled down
and are ready to operate in the new states. A
number of factors are important for the state
transition times:

The crystal oscillator frequency, fxosc

PA ramping enabled or not

The data rate in cases where PA ramping


is enabled

The value of the TEST0, TEST1, and


FSCAL3 registers

Table 34 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
13.
Note that TX to IDLE and TX to RX transition
times are functions of data rate (fbaudrate). When
PA
ramping
is
enabled
(i.e.
FREND0.PA_POWER000b), TX to IDLE and
TX
to
RX
will
require
(FREND0.PA_POWER)/8fbaudrate longer times
than the times stated in Table 34.

Description

Transition Time
(no PA ramping)

Transition Time [s]

IDLE to RX, no calibration

1953/fxosc

75.1

IDLE to RX, with calibration

1953/fxosc + FS calibration Time

799

IDLE to TX/FSTXON, no calibration

1954/fxosc

75.2

IDLE to TX/FSTXON, with calibration

1953/fxosc + FS calibration Time

799

TX to RX switch

782/fxosc + 0.25/fbaudrate

31.1

RX to TX switch

782/fxosc

30.1

TX to IDLE, no calibration

~0.25/fbaudrate

TX to IDLE, with calibration

~0.25/fbaudrate + FS calibration Time

725

RX to IDLE, no calibration

2/fxosc

~0.1

RX to IDLE, with calibration

2/fxosc + FS calibration Time

724

Manual calibration

283/fxosc + FS calibration Time

735

~1

Table 34: Overall State Transition Times (Example for 26 MHz crystal oscillator, 250 kBaud data
rate, and TEST0 = 0x0B (maximum calibration time)).

19.6.2 Frequency
Time

Synthesizer

Calibration

Table
35
summarizes
the
frequency
synthesizer (FS) calibration times for possible
settings
of
TEST0
and
FSCAL3.CHP_CURR_CAL_EN.
Setting
FSCAL3.CHP_CURR_CAL_EN to 00b disables
the charge pump calibration stage. TEST0 is
set to the values recommended by SmartRF
Studio software [5]. The possible values for

SWRS061I

TEST0 when operating with different frequency


bands are 0x09 and 0x0B. SmartRF Studio
software
[5]
always
sets
FSCAL3.CHP_CURR_CAL_EN to 10b.
Note that in a frequency hopping spread
spectrum or a multi-channel protocol the
calibration time can be reduced from 712/724
s to 145/157 s. This is explained in Section
28.2.

Page 54 of 98

CC1101
TEST0

FSCAL3.CHP_CURR_CAL_EN

0x09

00b

3764/fxosc = 145 us

3764/fxosc = 139 us

0x09

10b

18506/fxosc = 712 us

18506/fxosc = 685 us

0x0B

00b

4073/fxosc = 157 us

4073/fxosc = 151 us

0x0B

10b

18815/fxosc = 724 us

18815/fxosc = 697 us

FS Calibration Time
fxosc = 26 MHz

FS Calibration Time
fxosc = 27 MHz

Table 35: Frequency Synthesizer Calibration Times (26/27 MHz crystal)


19.7 RX Termination Timer

CC1101 has optional functions for automatic


termination of RX after a programmable time.
The main use for this functionality is Wake on
Radio, but it may also 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 if
the preamble quality is above threshold
(PQT)

If the system expects the transmission to have


started when enabling the receiver, the
MCSM2.RX_TIME_RSSI function can be used.
The radio controller will then terminate RX if
the first valid carrier sense sample indicates
no carrier (RSSI below threshold). See Section
17.4 for details on Carrier Sense.

SWRS061I

For ASK/OOK modulation, lack of carrier


sense is only considered valid after eight
symbol
periods.
Thus,
the
MCSM2.RX_TIME_RSSI function can be used
in ASK/OOK mode when the distance between
1 symbols is eight 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
MCSM2.RX_TIME timeout function, the chip
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 41 on page 62) on one of the
programmable GDO output pins, and
programming the microcontroller to wake up
on an edge-triggered interrupt from this GDO
pin.

Page 55 of 98

CC1101
20 Data FIFO
The CC1101 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.
Likewise, when reading the RX FIFO the MCU
must avoid reading the RX FIFO past its empty
value since a RX FIFO underflow will result in
an error in the data read out of the RX FIFO.

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 36 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.
FIFO_THR

Bytes in TX FIFO

Bytes in RX FIFO

0 (0000)

61

The chip status byte that is available on the


SO pin while transferring the SPI header and
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 contains more details on this.

1 (0001)

57

2 (0010)

53

12

3 (0011)

49

16

4 (0100)

45

20

5 (0101)

41

24

6 (0110)

37

28

The number of bytes in the RX FIFO and TX


FIFO can be read from the status registers
RXBYTES.NUM_RXBYTES
and
TXBYTES.NUM_TXBYTES respectively. If a
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 will be duplicated. To avoid this
problem, the RX FIFO should never be
emptied before the last byte of the packet is
received.

7 (0111)

33

32

8 (1000)

29

36

9 (1001)

25

40

10 (1010)

21

44

11 (1011)

17

48

12 (1100)

13

52

13 (1101)

56

14 (1110)

60

15 (1111)

64

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.
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). The following
software routine can be used:
RXBYTES.NUM_RXBYTES
repeatedly at a rate specified to be at least
twice that of which RF bytes are received
until the same value is returned twice;
store value in n.

1. Read

Table 36: FIFO_THR Settings and the


Corresponding FIFO Thresholds
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 41 on
page 62).
Figure 29 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 30 shows the signal on the GDO pin as
the respective FIFO is filled above the
threshold, and then drained below in the case
of FIFO_THR=13.

2. If n < # of bytes remaining in packet, read


n-1 bytes from the RX FIFO.

SWRS061I

Page 56 of 98

CC1101
NUM_RXBYTES

Overflow
margin

53 54 55 56 57 56 55 54 53

GDO
FIFO_THR=13

NUM_TXBYTES

9 10 9

GDO

Figure 30: Number of Bytes in FIFO vs. the


GDO Signal (GDOx_CFG=0x00 in RX and
GDOx_CFG=0x02 in TX, FIFO_THR=13)

56 bytes

FIFO_THR=13

Underflow
margin

8 bytes

RXFIFO

TXFIFO

Figure 29: Example of FIFOs at Threshold

21 Frequency Programming
The frequency programming in CC1101 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
the
MDMCFG0.CHANSPC_M
and
MDMCFG1.CHANSPC_E registers. The channel
spacing registers are mantissa and exponent
respectively. The base or start frequency is set

f carrier

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 desired channel number is programmed
with the 8-bit channel number register,
CHANNR.CHAN, which is multiplied by the
channel offset. The resultant carrier frequency
is given by:

f XOSC
FREQ CHAN 256 CHANSPC _ M 2CHANSPC _ E 2
216

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
in CHANNR.CHAN.
The preferred IF frequency is programmed
with the FSCTRL1.FREQ_IF register. The IF
frequency is given by:

SWRS061I

f IF

f XOSC
FREQ _ IF
210

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.

Page 57 of 98

CC1101
22 VCO
The VCO is completely integrated on-chip.
22.1 VCO and PLL Self-Calibration
The VCO characteristics vary with temperature
and supply voltage changes as well as the
desired operating frequency. In order to
ensure reliable operation, CC1101 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 Table 34 on
page 54.
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:
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.

If calibration is performed each time before


entering active mode (RX or TX) the user can
program register IOCFGx.GDOx_CFG to 0x0A
to check that the PLL is in lock. The lock
detector output available on the GDOx pin
should then be 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 CC1101
Errata Notes [3]. The PLL must be recalibrated until PLL lock is achieved if the PLL
does not lock the first time.
If the calibration is not performed each time
before entering active mode (RX or TX) the
user
should
program
register
IOCFGx.GDOx_CFG to 0x0A to check that the
PLL is in lock before receiving/transmitting
data. The lock detector output available on the
GDOx pin should then be an interrupt for the
MCU (x = 0,1, or 2). A positive transition on
the GDOx pin means that the PLL is in lock.
Since the current calibration values are only
valid for a finite temperature range (typically
40C) the PLL must be re-calibrated if the lock
indicator does not indicate PLL lock.

23 Voltage Regulators
CC1101 contains several on-chip linear voltage
regulators that generate the supply voltages
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 19
are not exceeded.
By setting the CSn pin low, the voltage
regulator to the digital core turns on and the
crystal oscillator starts. The SO pin on the SPI
interface must go low before the first positive

SWRS061I

edge of SCLK (setup time is given in Table


22).
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 for the digital core
requires one external decoupling capacitor.
The voltage regulator output should only be
used for driving the CC1101.

Page 58 of 98

CC1101
24 Output Power Programming
The RF output power level from the device has
two levels of programmability as illustrated in
Figure 31. The special PATABLE register can
hold up to eight user selected output power
settings. The 3-bit FREND0.PA_POWER value
selects the PATABLE entry to use. This twolevel functionality provides flexible PA power
ramp up and ramp down at the start and end
of transmission when using 2-FSK, GFSK,
4-FSK, and MSK modulation as well as ASK
modulation shaping. All the PA power settings
in the PATABLE from index 0 up to the
FREND0.PA_POWER value are used.
The power ramping at the start and at the end
of a packet can be turned off by setting
FREND0.PA_POWER=0 and then program the
desired output power to index 0 in the
PATABLE.

If OOK modulation is used, the logic 0 and


logic 1 power levels shall be programmed to
index 0 and 1 respectively.
Table 39 contains recommended PATABLE
settings for various output levels and
frequency bands. DN013 [15] gives the
complete tables for the different frequency
bands using multi-layer inductors. Using PA
settings from 0x61 to 0x6F is not allowed.
Table 40 contains output power and current
consumption for default PATABLE setting
(0xC6).
See Section 10.6 for PATABLE programming
details. PATABLE must be programmed in
burst mode if you want to write to other entries
than PATABLE[0].
Note: All content of the PATABLE except
for the first byte (index 0) is lost when
entering the SLEEP state.

868 MHz

915 MHz

Output
Power
[dBm]

Setting

Current
Consumption,
Typ. [mA]

Setting

Current
Consumption,
Typ. [mA]

-30

0x03

12.0

0x03

11.9

-20

0x17

12.6

0x0E

12.5

-15

0x1D

13.3

0x1E

13.3

-10

0x26

14.5

0x27

14.8

-6

0x37

16.4

0x38

17.0

0x50

16.8

0x8E

17.2

0x86

19.9

0x84

20.2

0xCD

25.8

0xCC

25.7

10

0xC5

30.0

0xC3

30.7

12/11

0xC0

34.2

0xC0

33.4

Table 37: Optimum PATABLE Settings for Various Output Power Levels and Frequency Bands
Using Wire-Wound Inductors in 868/915 MHz Frequency Bands

SWRS061I

Page 59 of 98

CC1101
868 MHz

915 MHz

Default
Power
Setting

Output
Power
[dBm]

Current
Consumption,
Typ. [mA]

Output
Power
[dBm]

0xC6

9.6

29.4

8.9

Current
Consumption,
Typ. [mA]
28.7

Table 38: Output Power and Current Consumption for Default PATABLE Setting Using WireWound Inductors in 868/915 MHz Frequency Bands

315 MHz
Output
Power
[dBm]

Setting

Current
Consumption,
Typ. [mA]

-30

0x12

-20

433 MHz
Setting

Current
Consumption,
Typ. [mA]

10.9

0x12

0x0D

11.4

-15

0x1C

-10

868 MHz

915 MHz

Setting

Current
Consumption,
Typ. [mA]

Setting

Current
Consumption,
Typ. [mA]

11.9

0x03

12.1

0x03

12.0

0x0E

12.4

0x0F

12.7

0x0E

12.6

12.0

0x1D

13.1

0x1E

13.4

0x1E

13.4

0x34

13.5

0x34

14.4

0x27

15.0

0x27

14.9

0x51

15.0

0x60

15.9

0x50

16.9

0x8E

16.7

0x85

18.3

0x84

19.4

0x81

21.0

0xCD

24.3

0xCB

22.1

0xC8

24.2

0xCB

26.8

0xC7

26.9

10

0xC2

26.9

0xC0

29.1

0xC2

32.4

0xC0

31.8

Table 39: Optimum PATABLE Settings for Various Output Power Levels and Frequency Bands
Using Multi-layer Inductors

315 MHz

433 MHz

868 MHz

915 MHz

Default
Power
Setting

Output
Power
[dBm]

Current
Consumption,
Typ. [mA]

Output
Power
[dBm]

Current
Consumption,
Typ. [mA]

Output
Power
[dBm]

Current
Consumption,
Typ. [mA]

Output
Power
[dBm]

0xC6

8.5

24.4

7.8

25.2

8.5

29.5

7.2

Current
Consumption,
Typ. [mA]
27.4

Table 40: Output Power and Current Consumption for Default PATABLE Setting Using Multi-layer
Inductors

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.

SWRS061I

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
should be 7 when ASK is active. The shaping
of the ASK signal is dependent on the
configuration of the PATABLE. Figure 32
shows some examples of ASK shaping.

Page 60 of 98

CC1101
PATABLE(7)[7:0]
The PA uses this
setting.

PATABLE(6)[7:0]
PATABLE(5)[7:0]
PATABLE(4)[7:0]

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.

PATABLE(3)[7:0]
PATABLE(2)[7:0]
PATABLE(1)[7:0]
PATABLE(0)[7:0]
Index into PATABLE(7:0)

The SmartRF Studio software


should be used to obtain optimum
PATABLE settings for various
output powers.

e.g 6
PA_POWER[2:0]
in FREND0 register

Figure 31: PA_POWER and PATABLE


Output Power
PATABLE[7]
PATABLE[6]
PATABLE[5]
PATABLE[4]
PATABLE[3]
PATABLE[2]
PATABLE[1]
PATABLE[0]

Time
Bit Sequence

FREND0.PA_POWER = 3
FREND0.PA_POWER = 7

Figure 32: Shaping of ASK Signal

26 General Purpose / Test Output Control Pins


The three digital output pins GDO0, GDO1,
and GDO2 are general control pins configured
with
IOCFG0.GDO0_CFG,
IOCFG1.GDO1_CFG, and IOCFG2.GDO2_CFG
respectively. Table 41 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 3-stated 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.

SWRS061I

An on-chip analog temperature sensor is


enabled by writing the value 128 (0x80) to the
IOCFG0 register. The voltage on the GDO0
pin is then proportional to temperature. See
Section
4.7
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
IOCFG1.GDO1_CFG=0x2E.

Page 61 of 98

CC1101
GDOx_CFG[5:0]
Description
Associated
to the RX FIFO: Asserts when RX FIFO is filled at or above the RX FIFO threshold. De-asserts when RX FIFO
0 (0x00)
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
1 (0x01)
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
2 (0x02)
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 the TX FIFO
3 (0x03)
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.
Asserts when sync word has been sent / received, and de-asserts at the end of the packet. In RX, the pin will also de6 (0x06)
assert when a packet is discarded due to address or maximum length filtering or when the radio enters
RXFIFO_OVERFLOW state. 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.
Preamble Quality Reached. Asserts when the PQI is above the programmed PQT value. De-asserted when the chip re8 (0x08)
enters RX state (MARCSTATE=0x0D) or the PQI gets below the programmed PQT value.
9 (0x09)
Clear channel assessment. High when RSSI level is below threshold (dependent on the current CCA_MODE setting).
Lock detector output. The PLL is in lock if the lock detector output has a positive transition or is constantly logic high. To
10 (0x0A)
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.
11 (0x0B)
In RX mode, data is set up on the falling edge by CC1101 when GDOx_INV=0.
In TX mode, data is sampled by CC1101 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. Cleared when entering IDLE mode.
15 (0x0F)
CRC_OK. The last CRC comparison matched. Cleared when entering/restarting RX mode.
16 (0x10)
to
Reserved used for test
21 (0x15)
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)
to
Reserved used for test
26 (0x1A)
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
27 (0x1B)
in applications where the SLEEP state is used it is recommended to use GDOx_CFGx=0x2F instead.
LNA_PD. Note: LNA_PD will have the same signal level in SLEEP and RX states. To control an external LNA or RX/TX
28 (0x1C)
switch in applications where the SLEEP state is used it is recommended to use GDOx_CFGx=0x2F instead.
29 (0x1D)
RX_SYMBOL_TICK. Can be used together with RX_HARD_DATA for alternative serial RX output.
30 (0x1E)
Reserved used for test
to
35 (0x23)
36 (0x24)
WOR_EVNT0
37 (0x25)
WOR_EVNT1
38 (0x26)
CLK_256
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)
Reserved used for test
46 (0x2E)
High impedance (3-state)
47 (0x2F)
HW to 0 (HW1 achieved by setting GDOx_INV=1). 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
Note: There are 3 GDO pins, but only one CLK_XOSC/n can be selected as an output at any
53 (0x35)
CLK_XOSC/6
time. If CLK_XOSC/n is to be monitored on one of the GDO pins, the other two GDO pins must
54 (0x36)
CLK_XOSC/8
be configured to values less than 0x30. The GDO0 default value is CLK_XOSC/192.
55 (0x37)
CLK_XOSC/12
56 (0x38)
CLK_XOSC/16
To optimize RF performance, these signals should not be used while the radio is in RX or TX
57 (0x39)
CLK_XOSC/24
mode.
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

Table 41: GDOx Signal Selection (x = 0, 1, or 2)

SWRS061I

Page 62 of 98

CC1101
27 Asynchronous and Synchronous Serial Operation
Several features and modes of operation have
been included in the CC1101 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.

27.1 Asynchronous Serial Operation


Asynchronous transfer is included in the
CC1101 for backward compatibility with systems
that are already using the asynchronous data
transfer.
When asynchronous transfer is enabled,
several of the support mechanisms for the
MCU that are included in CC1101 will be
disabled, such as packet handling hardware,
buffering in the FIFO, and so on. The
asynchronous transfer mode does not allow
for the use of the data whitener, interleaver,
and FEC, and it is not possible to use
Manchester encoding. MSK is not supported
for asynchronous transfer.
Setting
PKTCTRL0.PKT_FORMAT
to
3
enables asynchronous 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,
IOCFG1.GDO1_CFG
and IOCFG2.GDO2_CFG fields.
The CC1101 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.
In asynchronous serial mode no data decision
is done on-chip and the raw data is put on the
data output line in RX. When using
asynchronous serial mode make sure the
interfacing MCU does proper oversampling
and that it can handle the jitter on the data
output line. The MCU should tolerate a jitter of
1/8 of a bit period as the data stream is timediscrete using 8 samples per bit.
In asynchronous serial mode there will be
glitches of 37 - 38.5 ns duration (1/XOSC)
occurring infrequently and with random
periods. A simple RC filter can be added to the
data output line between CC1101 and the MCU
to get rid of the 37 - 38.5 ns ns glitches if
considered a problem. The filter 3 dB cut-off
frequency needs to be high enough so that the
data is not filtered and at the same time low
enough to remove the glitch. As an example,
for 2.4 kBaud data rate a 1 kohm resistor and
2.7 nF capacitor can be used. This gives a 3
dB cut-off frequency of 59 kHz.

27.2 Synchronous Serial Operation


Setting
PKTCTRL0.PKT_FORMAT
to
1
enables synchronous serial mode. In the
synchronous serial mode, data is transferred
on a two-wire serial interface. The CC1101
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 on
the GDO0 pin. This pin will automatically be
configured as an input when TX is active. The
TX latency is 8 bits. The data output pin can
be any of the GDO pins. This is set by the
IOCFG0.GDO0_CFG,
IOCFG1.GDO1_CFG,
and IOCFG2.GDO2_CFG fields. Time from
start of reception until data is available on the
receiver data output pin is equal to 9 bit.
Preamble and sync word insertion/detection
may or may not be active, dependent on the
sync mode set by the MDMCFG2.SYNC_MODE.

SWRS061I

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
are 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.
When using the packet handling features in
synchronous serial mode, the CC1101 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.
An alternative serial RX output option is to
configure any of the GD0 pins for

Page 63 of 98

CC1101
RX_SYMBOL_TICK and RX_HARD_DATA, see
Table 41. RX_HARD_DATA[1:0] is the hard
decision
symbol.
RX_HARD_DATA[1:0]
contain data for 4-ary modulation formats
while RX_HARD_DATA[1] contain data for 2ary
modulation
formats.
The

RX_SYMBOL_TICK signal is the symbol clock


and is high for one half symbol period
whenever a new symbol is presented on the
hard and soft data outputs. This option may be
used for both synchronous and asynchronous
interfaces.

28 System Considerations and Guidelines


28.1 SRD Regulations
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 315 MHz, 433 MHz, 868 MHz
or 915 MHz frequency bands. The CC1101 is
specifically designed for such use with its 300
- 348 MHz, 387 - 464 MHz, and 779 - 928
MHz operating ranges. The most important
regulations when using the CC1101 in the 315
MHz, 433 MHz, 868 MHz, or 915 MHz
frequency bands are EN 300 220 (Europe)
and FCC CFR47 Part 15 (USA).

For compliance with modulation bandwidth


requirements under EN 300 220 in the 863 to
870 MHz frequency range it is recommended
to use a 26 MHz crystal for frequencies below
869 MHz and a 27 MHz crystal for frequencies
above 869 MHz.
Please note that compliance with regulations
is dependent on the complete system
performance. It is the customers responsibility
to ensure that the system complies with
regulations.

28.2 Frequency Hopping and Multi-Channel Systems


The 315 MHz, 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 multichannel 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.

CC1101 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 CC1101. 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 712/724 s
(26 MHz crystal and TEST0 = 0x09/0B, see
Table 35). The blanking interval between each
frequency hop is then 787/799 s.

SWRS061I

2) Fast frequency hopping without calibration


for each hop can be done by performing the
necessary calibrating at startup and saving the
resulting FSCAL3, FSCAL2, and FSCAL1
register values in MCU memory. The VCO
capacitance calibration FSCAL1 register value
must be found for each RF frequency to be
used. The VCO current calibration value and
the charge pump current calibration value
available in FSCAL2 and FSCAL3 respectively
are not dependent on the RF frequency, so the
same value can therefore be used for all RF
frequencies for these two registers. Between
each frequency hop, the calibration process
can then be replaced by writing the FSCAL3,
FSCAL2 and FSCAL1 register values that
corresponds to the next RF frequency. The
PLL turn on time is approximately 75 s (Table
34). The blanking interval between each
frequency hop is then approximately 75 s.
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

Page 64 of 98

CC1101
time is reduced from 712/724 s to 145/157 s
(26 MHz crystal and TEST0 = 0x09/0B, see
Table 35). The blanking interval between each
frequency hop is then 220/232 s.
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. This solution also requires
that the supply voltage and temperature do not
vary much in order to have a robust solution.
Solution 3) gives 567 s smaller blanking
interval than solution 1).

The
recommended
settings
for
TEST0.VCO_SEL_CAL_EN
change
with
frequency. This means that one should always
use SmartRF Studio [5] to get the correct
settings for a specific frequency before doing a
calibration, regardless of which calibration
method is being used.
Note: The content in the TEST0 register is
not retained in SLEEP state, thus it is
necessary to re-write this register when
returning from the SLEEP state.

28.3 Wideband Modulation when not Using Spread Spectrum


Digital modulation systems under FCC Section
15.247 include 2-FSK, GFSK, and 4-FSK
modulation. A maximum peak output power of
1 W (+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 CC1101 is suited for systems

targeting compliance with digital modulation


system as defined by FCC Section 15.247. An
external power amplifier such as CC1190 [21] is
needed to increase the output above +11
dBm. Please refer to DN006 [11] for further
details concerning wideband modulation using
CC1101 and DN036 for wideband modulation at
600 kbps data rate, +19 dBm output power
when using CC1101 +CC1101 [25].

28.4 Wireless MBUS


The wireless MBUS standard is a
communication standard for meters and
wireless readout of meters, and specifies the
physical and the data link layer. Power
consumption is a critical parameter for the
meter side, since the communication link shall
be operative for the full lifetime of the meter,
without changing the battery. CC1101 combined
with MSP430 is an excellent choice for the
Wireless MBUS standard, CC1101 is a truly low

cost, low power and flexible transceiver, and


MSP430 a high performance and low power
MCU. For more informati on regarding using
CC1101 for Wireless MBUS applications, see
AN067 [14].
Since the Wireless MBUS standard operates
in the 868-870 ISM band, the radio
requirements must also comply with the ETSI
EN 300 220 and CEPT/ERC/REC 70-03 E
standards.

28.5 Data Burst Transmissions


The high maximum data rate of CC1101 opens
up for burst transmissions. A low average data
rate link (e.g. 10 kBaud) can be realized by
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.
Note: The sensitivity and thus transmission
range is reduced for high data rate bursts
compared to lower data rates.

28.6 Continuous Transmissions


In data streaming applications, the CC1101
opens up for continuous transmissions at 500
kBaud effective data rate. As the modulation is

SWRS061I

done with a closed loop PLL, there is no


limitation in the length of a transmission (open
loop modulation used in some transceivers

Page 65 of 98

CC1101
often prevents this kind of continuous data

streaming and reduces the effective data rate).

28.7 Battery Operated Systems


In low power applications, the SLEEP state
with the crystal oscillator core switched off
should be used when the CC1101 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.

28.8 Increasing Range


In some applications it may be necessary to
extend the range. The CC1190 [21] is a range
extender for 850-950 MHz RF transceivers,
transmitters, and System-on-Chip devices
from Texas Instruments. It increases the link
budget by providing a power amplifier (PA) for
increased output power, and a low-noise
amplifier (LNA) with low noise figure for

improved receiver sensitivity in addition to


switches and RF matching for simple design of
high performance wireless systems. Refer to
AN094 [22] and AN096 [23] for performance
figures of the CC1101 + CC1190 combination.
Figure 33 shows a simplified application
circuit.

VDD
VDD

PA_OUT

1
A
P
_
D
D
V

2
A
P
_
D
D
V

A
N
L
_
PA_IN
D
D
V LNA_OUT

RF_P

SAW

RF_N

CC1101

CC1190
TR_SW
GDOx

PA_EN
LNA_EN

LNA_IN
S
A
IB

HGM

Connected to MCU
Connected to
VDD/GND/MCU

Figure 33: Simplified CC1101-CC1190 Application Circuit

29 Configuration Registers
The configuration of CC1101 is done by
programming 8-bit registers. The optimum
configuration data based on selected system
parameters are most easily found by using the
SmartRF Studio software [5]. Complete
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 42. Accessing these registers will
initiate the change of an internal state or
mode. There are 47 normal 8-bit configuration

SWRS061I

registers listed in Table 43. Many of these


registers are for test purposes only, and need
not be written for normal operation of CC1101.
There are also 12 status registers that are
listed in Table 44. These registers, which are
read-only, contain information about the status
of CC1101.
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 23 on page
31.

Page 66 of 98

CC1101
Table 45 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.

Address

Strobe
Name

Description

0x30

SRES

Reset chip.

0x31

SFSTXON

0x32

SXOFF

0x33

SCAL

Calibrate frequency synthesizer and turn it off. SCAL can be strobed from IDLE mode without
setting manual calibration mode (MCSM0.FS_AUTOCAL=0)

0x34

SRX

Enable RX. Perform calibration first if coming from IDLE and MCSM0.FS_AUTOCAL=1.

0x35

STX

In IDLE state: Enable TX. Perform calibration first if MCSM0.FS_AUTOCAL=1.


If in RX state and CCA is enabled: Only go to TX if channel is clear.

0x36

SIDLE

Exit RX / TX, turn off frequency synthesizer and exit Wake-On-Radio mode if applicable.

0x38

SWOR

Start automatic RX polling sequence (Wake-on-Radio) as described in Section 19.5 if


WORCTRL.RC_PD=0.

0x39

SPWD

Enter power down mode when CSn goes high.

0x3A

SFRX

Flush the RX FIFO buffer. Only issue SFRX in IDLE or RXFIFO_OVERFLOW states.

0x3B

SFTX

Flush the TX FIFO buffer. Only issue SFTX in IDLE or TXFIFO_UNDERFLOW states.

0x3C

SWORRST

0x3D

SNOP

Enable and calibrate frequency synthesizer (if MCSM0.FS_AUTOCAL=1). If in RX (with CCA):


Go to a wait state where only the synthesizer is running (for quick RX / TX turnaround).
Turn off crystal oscillator.

Reset real time clock to Event1 value.


No operation. May be used to get access to the chip status byte.

Table 42: Command Strobes

SWRS061I

Page 67 of 98

CC1101
Preserved in
SLEEP State

Details on
Page Number

Yes

71

Yes

71

IOCFG0

GDO2 output pin configuration


GDO1 output pin configuration
GDO0 output pin configuration

Yes

71

0x03

FIFOTHR

RX FIFO and TX FIFO thresholds

Yes

72

0x04

SYNC1

Sync word, high byte

Yes

73

0x05

SYNC0

Sync word, low byte

Yes

73

0x06

PKTLEN

Packet length

Yes

73

0x07

PKTCTRL1

Packet automation control

Yes

73

0x08

PKTCTRL0

Packet automation control

Yes

74

Address

Register

Description

0x00

IOCFG2

0x01

IOCFG1

0x02

0x09

ADDR

Device address

Yes

74

0x0A

CHANNR

Channel number

Yes

74

0x0B

FSCTRL1

Frequency synthesizer control

Yes

75

0x0C

FSCTRL0

Frequency synthesizer control

Yes

75

0x0D

FREQ2

Frequency control word, high byte

Yes

75

0x0E

FREQ1

Frequency control word, middle byte

Yes

75

0x0F

FREQ0

Frequency control word, low byte

Yes

75

0x10

MDMCFG4

Modem configuration

Yes

76

0x11

MDMCFG3

Modem configuration

Yes

76

0x12

MDMCFG2

Modem configuration

Yes

77

0x13

MDMCFG1

Modem configuration

Yes

78

0x14

MDMCFG0

Modem configuration

Yes

78

0x15

DEVIATN

Modem deviation setting

Yes

79

0x16

MCSM2

Main Radio Control State Machine configuration

Yes

80

0x17

MCSM1

Main Radio Control State Machine configuration

Yes

81

0x18

MCSM0

Main Radio Control State Machine configuration

Yes

82

0x19

FOCCFG

Frequency Offset Compensation configuration

Yes

83

0x1A

BSCFG

Bit Synchronization configuration

Yes

84

0x1B

AGCTRL2

AGC control

Yes

85

0x1C

AGCTRL1

AGC control

Yes

86

0x1D

AGCTRL0

AGC control

Yes

87

0x1E

WOREVT1

High byte Event 0 timeout

Yes

87

0x1F

WOREVT0

Low byte Event 0 timeout

Yes

88

0x20

WORCTRL

Wake On Radio control

Yes

88

0x21

FREND1

Front end RX configuration

Yes

89

0x22

FREND0

Front end TX configuration

Yes

89

0x23

FSCAL3

Frequency synthesizer calibration

Yes

89

0x24

FSCAL2

Frequency synthesizer calibration

Yes

90

0x25

FSCAL1

Frequency synthesizer calibration

Yes

90

0x26

FSCAL0

Frequency synthesizer calibration

Yes

90

0x27

RCCTRL1

RC oscillator configuration

Yes

90

0x28

RCCTRL0

RC oscillator configuration

Yes

90

0x29

FSTEST

Frequency synthesizer calibration control

No

91

0x2A

PTEST

Production test

No

91

0x2B

AGCTEST

AGC test

No

91

0x2C

TEST2

Various test settings

No

91

0x2D

TEST1

Various test settings

No

91

0x2E

TEST0

Various test settings

No

92

Table 43: Configuration Registers Overview

SWRS061I

Page 68 of 98

CC1101
Address

Register

Description

Details on page number

0x30 (0xF0)

PARTNUM

Part number for CC1101

92

0x31 (0xF1)

VERSION

Current version number

92

0x32 (0xF2)

FREQEST

Frequency Offset Estimate

92

0x33 (0xF3)

LQI

Demodulator estimate for Link Quality

92

0x34 (0xF4)

RSSI

Received signal strength indication

92

0x35 (0xF5)

MARCSTATE

Control state machine state

93

0x36 (0xF6)

WORTIME1

High byte of WOR timer

93

0x37 (0xF7)

WORTIME0

Low byte of WOR timer

93

0x38 (0xF8)

PKTSTATUS

Current GDOx status and packet status

94

VCO_VC_DAC

Current setting from PLL calibration


module

94

0x39 (0xF9)

TXBYTES

Underflow and number of bytes in the TX


FIFO

94

0x3A (0xFA)

RXBYTES

Overflow and number of bytes in the RX


FIFO

94

0x3B (0xFB)
0x3C (0xFC)

RCCTRL1_STATUS

Last RC oscillator calibration result

94

0x3D (0xFD)

RCCTRL0_STATUS

Last RC oscillator calibration result

95

Table 44: Status Registers Overview

Table 45: SPI Address Space (see next page)

SWRS061I

Page 69 of 98

CC1101

SRES
SFSTXON
SXOFF
SCAL
SRX
STX
SIDLE

SRES
SFSTXON
SXOFF
SCAL
SRX
STX
SIDLE

SWOR
SPWD
SFRX
SFTX
SWORRST
SNOP
PATABLE
TX FIFO

SWOR
SPWD
SFRX
SFTX
SWORRST
SNOP
PATABLE
RX FIFO

PATABLE
TX FIFO

SWRS061I

Burst
+0xC0

R/W configuration registers, burst access possible

0x00
0x01
0x02
0x03
0x04
0x05
0x06
0x07
0x08
0x09
0x0A
0x0B
0x0C
0x0D
0x0E
0x0F
0x10
0x11
0x12
0x13
0x14
0x15
0x16
0x17
0x18
0x19
0x1A
0x1B
0x1C
0x1D
0x1E
0x1F
0x20
0x21
0x22
0x23
0x24
0x25
0x26
0x27
0x28
0x29
0x2A
0x2B
0x2C
0x2D
0x2E
0x2F
0x30
0x31
0x32
0x33
0x34
0x35
0x36
0x37
0x38
0x39
0x3A
0x3B
0x3C
0x3D
0x3E
0x3F

Read
Single Byte
+0x80
IOCFG2
IOCFG1
IOCFG0
FIFOTHR
SYNC1
SYNC0
PKTLEN
PKTCTRL1
PKTCTRL0
ADDR
CHANNR
FSCTRL1
FSCTRL0
FREQ2
FREQ1
FREQ0
MDMCFG4
MDMCFG3
MDMCFG2
MDMCFG1
MDMCFG0
DEVIATN
MCSM2
MCSM1
MCSM0
FOCCFG
BSCFG
AGCCTRL2
AGCCTRL1
AGCCTRL0
WOREVT1
WOREVT0
WORCTRL
FREND1
FREND0
FSCAL3
FSCAL2
FSCAL1
FSCAL0
RCCTRL1
RCCTRL0
FSTEST
PTEST
AGCTEST
TEST2
TEST1
TEST0

PARTNUM
VERSION
FREQEST
LQI
RSSI
MARCSTATE
WORTIME1
WORTIME0
PKTSTATUS
VCO_VC_DAC
TXBYTES
RXBYTES
RCCTRL1_STATUS
RCCTRL0_STATUS
PATABLE
RX FIFO

Command Strobes, Status registers


(read only) and multi byte registers

Write
Single Byte
Burst
+0x00
+0x40

Page 70 of 98

CC1101
29.1 Configuration Register Details Registers with preserved values in SLEEP state
0x00: IOCFG2 GDO2 Output Pin Configuration
Bit

Field Name

Reset

R/W

Description

R0

Not used

GDO2_INV

R/W

Invert output, i.e. select active low (1) / high (0)

5:0

GDO2_CFG[5:0]

41 (0x29)

R/W

Default is CHP_RDYn (See Table 41 on page 62).

0x01: IOCFG1 GDO1 Output Pin Configuration


Bit

Field Name

Reset

R/W

Description

GDO_DS

R/W

Set high (1) or low (0) output drive strength on the GDO pins.

GDO1_INV

R/W

Invert output, i.e. select active low (1) / high (0)

5:0

GDO1_CFG[5:0]

46 (0x2E)

R/W

Default is 3-state (See Table 41 on page 62).

0x02: IOCFG0 GDO0 Output Pin Configuration


Bit

Field Name

Reset

R/W

Description

TEMP_SENSOR_ENABLE

R/W

Enable analog temperature sensor. Write 0 in all other register


bits when using temperature sensor.

GDO0_INV

R/W

Invert output, i.e. select active low (1) / high (0)

5:0

GDO0_CFG[5:0]

63 (0x3F)

R/W

Default is CLK_XOSC/192 (See Table 41 on page 62).


It is recommended to disable the clock output in initialization, in
order to optimize RF performance.

SWRS061I

Page 71 of 98

CC1101
0x03: FIFOTHR RX FIFO and TX FIFO Thresholds
Bit

Field Name

7
6

ADC_RETENTION

Reset

R/W

Description

R/W

Reserved , write 0 for compatibility with possible future extensions

R/W

0: TEST1 = 0x31 and TEST2= 0x88 when waking up from SLEEP


1: TEST1 = 0x35 and TEST2 = 0x81 when waking up from SLEEP
Note that the changes in the TEST registers due to the
ADC_RETENTION bit setting are only seen INTERNALLY in the analog
part. The values read from the TEST registers when waking up from
SLEEP mode will always be the reset value.
The ADC_RETENTION bit should be set to 1before going into SLEEP
mode if settings with an RX filter bandwidth below 325 kHz are wanted at
time of wake-up.

5:4

3:0

CLOSE_IN_RX [1:0]

FIFO_THR[3:0]

0 (00)

7 (0111)

R/W

R/W

For more details, please see DN010 [8]


Setting

RX Attenuation, Typical Values

0 (00)

0 dB

1 (01)

6 dB

2 (10)

12 dB

3 (11)

18 dB

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)

61

1 (0001)

57

2 (0010)

53

12

3 (0011)

49

16

4 (0100)

45

20

5 (0101)

41

24

6 (0110)

37

28

7 (0111)

33

32

8 (1000)

29

36

9 (1001)

25

40

10 (1010)

21

44

11 (1011)

17

48

12 (1100)

13

52

13 (1101)

56

14 (1110)

60

15 (1111)

64

SWRS061I

Page 72 of 98

CC1101
0x04: SYNC1 Sync Word, High Byte
Bit

Field Name

Reset

R/W

Description

7:0

SYNC[15:8]

211 (0xD3)

R/W

8 MSB of 16-bit sync word

0x05: SYNC0 Sync Word, Low Byte


Bit

Field Name

Reset

R/W

Description

7:0

SYNC[7:0]

145 (0x91)

R/W

8 LSB of 16-bit sync word

0x06: PKTLEN Packet Length


Bit

Field Name

Reset

R/W

Description

7:0

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. This value must be different from 0.

0x07: PKTCTRL1 Packet Automation Control


Bit

Field Name

Reset

R/W

Description

7:5

PQT[2:0]

0 (0x00)

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 4PQT for this counter is used to gate sync word detection.
When PQT=0 a sync word is always accepted.

R0

Not Used.

CRC_AUTOFLUSH

R/W

Enable automatic flush of RX FIFO when CRC is not OK. This requires that
only one packet is in the RXIFIFO and that packet length is limited to the
RX FIFO size.

APPEND_STATUS

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.

1:0

ADR_CHK[1:0]

0 (00)

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

SWRS061I

Page 73 of 98

CC1101
0x08: PKTCTRL0 Packet Automation Control
Bit

Field Name

Reset

7
6

WHITE_DATA

R/W

Description

R0

Not used

R/W

Turn data whitening on / off


0: Whitening off
1: Whitening on

5:4

PKT_FORMAT[1:0]

0 (00)

R/W

Format of RX and TX data


Setting

Packet format

0 (00)

Normal mode, use FIFOs for RX and TX

1 (01)

Synchronous serial mode, Data in on GDO0 and


data out on either of the GDOx pins

2 (10)

Random TX mode; sends random data using PN9


generator. Used for test.
Works as normal mode, setting 0 (00), in RX

3 (11)

Asynchronous serial mode, Data in on GDO0 and


data out on either of the GDOx pins

R0

Not used
1: CRC calculation in TX and CRC check in RX enabled

CRC_EN

R/W

1:0

LENGTH_CONFIG[1:0]

1 (01)

R/W

0: CRC disabled for TX and RX


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

0x09: ADDR Device Address


Bit

Field Name

Reset

R/W

Description

7:0

DEVICE_ADDR[7:0]

0 (0x00)

R/W

Address used for packet filtration. Optional broadcast addresses are 0


(0x00) and 255 (0xFF).

0x0A: CHANNR Channel Number


Bit

Field Name

Reset

R/W

Description

7:0

CHAN[7:0]

0 (0x00)

R/W

The 8-bit unsigned channel number, which is multiplied by the channel


spacing setting and added to the base frequency.

SWRS061I

Page 74 of 98

CC1101
0x0B: FSCTRL1 Frequency Synthesizer Control
Bit

Field Name

Reset

R/W

Description

R0

Not used

R/W

Reserved

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.

7:6
5
4:0

FREQ_IF[4:0]

f IF

f XOSC
FREQ _ IF
210

The default value gives an IF frequency of 381kHz, assuming a 26.0 MHz


crystal.

0x0C: FSCTRL0 Frequency Synthesizer Control


Bit

Field Name

Reset

R/W

Description

7:0

FREQOFF[7:0]

0 (0x00)

R/W

Frequency offset added to the base frequency before being used by the
frequency synthesizer. (2s-complement).
Resolution is FXTAL/214 (1.59kHz-1.65kHz); range is 202 kHz to 210 kHz,
dependent of XTAL frequency.

0x0D: FREQ2 Frequency Control Word, High Byte


Bit

Field Name

Reset

R/W

Description

7:6

FREQ[23:22]

0 (00)

FREQ[23:22] is always 0 (the FREQ2 register is less than 36 with 26-27 MHz
crystal)

5:0

FREQ[21:16]

30 (0x1E)

R/W

FREQ[23:0] is the base frequency for the frequency synthesiser in


increments of fXOSC/216.

f carrier

f XOSC
FREQ 23 : 0
216

0x0E: FREQ1 Frequency Control Word, Middle Byte


Bit

Field Name

Reset

R/W

Description

7:0

FREQ[15:8]

196 (0xC4)

R/W

Ref. FREQ2 register

0x0F: FREQ0 Frequency Control Word, Low Byte


Bit

Field Name

Reset

R/W

Description

7:0

FREQ[7:0]

236 (0xEC)

R/W

Ref. FREQ2 register

SWRS061I

Page 75 of 98

CC1101
0x10: MDMCFG4 Modem Configuration
Bit

Field Name

Reset

R/W

7:6

CHANBW_E[1:0]

2 (0x02)

R/W

5:4

CHANBW_M[1:0]

0 (0x00)

R/W

Description

Sets the decimation ratio for the delta-sigma ADC input stream and thus the
channel bandwidth.

BWchannel

f XOSC
8 (4 CHANBW _ M )2CHANBW _ E

The default values give 203 kHz channel filter bandwidth, assuming a 26.0
MHz crystal.
3:0

DRATE_E[3:0]

12 (0x0C)

R/W

The exponent of the user specified symbol rate

0x11: MDMCFG3 Modem Configuration


Bit

Field Name

Reset

R/W

Description

7:0

DRATE_M[7:0]

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 9th bit is a hidden 1. The resulting data rate is:

RDATA

256 DRATE _ M 2 DRATE _ E f


228

XOSC

The default values give a data rate of 115.051 kBaud (closest setting to 115.2
kBaud), assuming a 26.0 MHz crystal.

SWRS061I

Page 76 of 98

CC1101
0x12: MDMCFG2 Modem Configuration
Bit

Field Name

Reset

R/W

Description

DEM_DCFILT_OFF

R/W

Disable digital DC blocking filter before demodulator.


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 [5] to calculate correct register setting.

6:4

MOD_FORMAT[2:0]

0 (000)

R/W

The modulation format of the radio signal


Setting

Modulation format

0 (000)

2-FSK

1 (001)

GFSK

2 (010)

3 (011)

ASK/OOK

4 (100)

4-FSK

5 (101)

6 (110)

7 (111)

MSK

MSK is only supported for data rates above 26 kBaud


3

MANCHESTER_EN

R/W

Enables Manchester encoding/decoding.


0 = Disable
1 = Enable

2:0

SYNC_MODE[2:0]

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

SWRS061I

Page 77 of 98

CC1101
0x13: MDMCFG1 Modem Configuration
Bit

Field Name

Reset

R/W

Description

FEC_EN

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.
PKTCTRL0.LENGTH_CONFIG=0)

6:4

NUM_PREAMBLE[2:0]

2 (010)

3:2
1:0

CHANSPC_E[1:0]

2 (10)

R/W

Sets the minimum number of preamble bytes to be transmitted


Setting

Number of preamble bytes

0 (000)

1 (001)

2 (010)

3 (011)

4 (100)

5 (101)

12

6 (110)

16

7 (111)

24

R0

Not used

R/W

2 bit exponent of channel spacing

0x14: MDMCFG0 Modem Configuration


Bit

Field Name

Reset

R/W

Description

7:0

CHANSPC_M[7:0]

248 (0xF8)

R/W

8-bit mantissa of channel spacing. The channel spacing is


multiplied by the channel number CHAN and added to the base
frequency. It is unsigned and has the format:

f CHANNEL

f XOSC
256 CHANSPC _ M 2CHANSPC _ E
218

The default values give 199.951 kHz channel spacing (the closest
setting to 200 kHz), assuming 26.0 MHz crystal frequency.

SWRS061I

Page 78 of 98

CC1101
0x15: DEVIATN Modem Deviation Setting
Bit

Field Name

Reset

7
6:4

DEVIATION_E[2:0]

4 (100)

3
2:0

DEVIATION_M[2:0]

7 (111)

R/W

Description

R0

Not used.

R/W

Deviation exponent.

R0

Not used.

R/W

TX

2-FSK/
GFSK/
4-FSK

Specifies the nominal frequency deviation from the carrier for a


0 (-DEVIATN) and 1 (+DEVIATN) in a mantissa-exponent
format, interpreted as a 4-bit value with MSB implicit 1. The
resulting frequency deviation is given by:

f dev

f xosc
(8 DEVIATION _ M ) 2 DEVIATION _ E
217

The default values give 47.607 kHz deviation assuming 26.0


MHz crystal frequency.
MSK

Specifies the fraction of symbol period (1/8-8/8) during which a


phase change occurs (0: +90deg, 1:-90deg). Refer to the
SmartRF Studio software [5] for correct DEVIATN setting when
using MSK.

ASK/OOK

This setting has no effect.

RX
2-FSK/
GFSK/
4-FSK

Specifies the expected frequency deviation of incoming signal,


must be approximately right for demodulation to be performed
reliably and robustly.

MSK/
This setting has no effect.
ASK/OOK

SWRS061I

Page 79 of 98

CC1101
0x16: MCSM2 Main Radio Control State Machine Configuration
Bit

Field Name

Reset

7:5

R/W

Description

R0

Not used

RX_TIME_RSSI

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.

RX_TIME_QUAL

R/W

When the 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.

2:0

RX_TIME[2:0]

7 (111)

R/W

Timeout for sync word search in RX for both WOR mode and normal RX
operation. The timeout is relative to the programmed EVENT0 timeout.

The RX timeout in s is given by EVENT0C(RX_TIME, WOR_RES) 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

2 (010)

0.9014

4.5072

8.1130

11.7188

3 (011)

0.4507

2.2536

4.0565

5.8594

4 (100)

0.2254

1.1268

2.0282

2.9297

5 (101)

0.1127

0.5634

1.0141

1.4648

6 (110)

0.0563

0.2817

0.5071

0.7324

7 (111)

Until end of packet

As an example, EVENT0=34666, WOR_RES=0 and RX_TIME=6 corresponds to 1.96 ms RX timeout, 1 s polling interval and
0.195% duty cycle. Note that WOR_RES should be 0 or 1 when using WOR because using WOR_RES > 1 will give a very low
duty cycle. In applications where WOR is not used all settings of WOR_RES can be used.
The duty cycle using WOR is approximated by:
Setting

WOR_RES=0

WOR_RES=1

0 (000)

12.50%

1.95%

1 (001)

6.250%

9765ppm

2 (010)

3.125%

4883ppm

3 (011)

1.563%

2441ppm

4 (100)

0.781%

NA

5 (101)

0.391%

NA

6 (110)

0.195%

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.

SWRS061I

Page 80 of 98

CC1101
0x17: MCSM1 Main Radio Control State Machine Configuration
Bit

Field Name

Reset

7:6
5:4

3:2

CCA_MODE[1:0]

RXOFF_MODE[1:0]

3 (11)

0 (00)

R/W

Description

R0

Not used

R/W

Selects CCA_MODE; Reflected in CCA signal

R/W

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

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

SWRS061I

Page 81 of 98

CC1101
0x18: MCSM0 Main Radio Control State Machine Configuration
Bit

Field Name

Reset

7:6
5:4

FS_AUTOCAL[1:0]

0 (00)

R/W

Description

R0

Not used

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)

When going from RX or TX back to IDLE


automatically

3 (11)

Every 4th 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.
3:2

PO_TIMEOUT

1 (01)

R/W

Programs the number of times the six-bit ripple counter must expire after
[1]
XOSC has stabilized before CHP_RDYn goes low .
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 CHP_RDYn
goes low (PO_TIMEOUT=2 recommended). Typical start-up time for the
voltage regulator is 50 s.
For robust operation it is recommended to use PO_TIMEOUT = 2 or 3 when
XOSC is off during power-down.
[1]

Note that the XOSC_STABLE signal will be asserted at the same time as
the CHP_RDYn signal; i.e. the PO_TIMEOUT delays both signals and does not
insert a delay between the signals
Setting

Expire count

Timeout after XOSC start

0 (00)

Approx. 2.3 2.4 s

1 (01)

16

Approx. 37 39 s

2 (10)

64

Approx. 149 155 s

3 (11)

256

Approx. 597 620 s

Exact timeout depends on crystal frequency.


1

PIN_CTRL_EN

R/W

Enables the pin radio control option

XOSC_FORCE_ON

R/W

Force the XOSC to stay on in the SLEEP state.

SWRS061I

Page 82 of 98

CC1101
0x19: FOCCFG Frequency Offset Compensation Configuration
Bit

Field Name

Reset

7:6

R/W

Description

R0

Not used

FOC_BS_CS_GATE

R/W

If set, the demodulator freezes the frequency offset compensation and clock
recovery feedback loops until the CS signal goes high.

4:3

FOC_PRE_K[1:0]

2 (10)

R/W

The frequency compensation loop gain to be used before a sync word is


detected.

1:0

FOC_POST_K

FOC_LIMIT[1:0]

2 (10)

R/W

R/W

Setting

Freq. compensation loop gain before sync word

0 (00)

1 (01)

2K

2 (10)

3K

3 (11)

4K

The frequency compensation loop gain to be used after a sync word is detected.
Setting

Freq. compensation loop gain after sync word

Same as FOC_PRE_K

K/2

The saturation point for the frequency offset compensation algorithm:


Setting

Saturation point (max compensated offset)

0 (00)

0 (no frequency offset compensation)

1 (01)

BWCHAN/8

2 (10)

BWCHAN/4

3 (11)

BWCHAN/2

Frequency offset compensation is not supported for ASK/OOK. Always use


FOC_LIMIT=0 with these modulation formats.

SWRS061I

Page 83 of 98

CC1101
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):

5:4

1:0

BS_PRE_KP[1:0]

BS_POST_KI

BS_POST_KP

BS_LIMIT[1:0]

2 (10)

0 (00)

R/W

R/W

R/W

R/W

Setting

Clock recovery loop integral gain before sync word

0 (00)

KI

1 (01)

2KI

2 (10)

3KI

3 (11)

4KI

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

0 (00)

KP

1 (01)

2KP

2 (10)

3KP

3 (11)

4KP

The clock recovery feedback loop integral gain to be used after a sync word is
detected.
Setting

Clock recovery loop integral gain after sync word

Same as BS_PRE_KI

KI /2

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

Same as BS_PRE_KP

KP

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

SWRS061I

Page 84 of 98

CC1101
0x1B: AGCCTRL2 AGC Control
Bit

Field Name

Reset

R/W

Description

7:6

MAX_DVGA_GAIN[1:0]

0 (00)

R/W

Reduces the maximum allowable DVGA gain.

5:3

2:0

MAX_LNA_GAIN[2:0]

MAGN_TARGET[2:0]

0 (000)

3 (011)

R/W

R/W

Setting

Allowable DVGA settings

0 (00)

All gain settings can be used

1 (01)

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

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

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)

24 dB

1 (001)

27 dB

2 (010)

30 dB

3 (011)

33 dB

4 (100)

36 dB

5 (101)

38 dB

6 (110)

40 dB

7 (111)

42 dB

SWRS061I

Page 85 of 98

CC1101
0x1C: AGCCTRL1 AGC Control
Bit

Field Name

Reset

R/W

Description

R0

Not used

AGC_LNA_PRIORITY

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)

R/W

Setting

Carrier sense relative threshold

0 (00)

Relative carrier sense threshold disabled

1 (01)

6 dB increase in RSSI value

2 (10)

10 dB increase in RSSI value

3 (11)

14 dB increase in RSSI value

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.
Setting

Carrier sense absolute threshold


(Equal to channel filter amplitude when AGC
has not decreased gain)

SWRS061I

-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

Page 86 of 98

CC1101
0x1D: AGCCTRL0 AGC Control
Bit

Field Name

Reset

R/W

Description

7:6

HYST_LEVEL[1:0]

2 (10)

R/W

Sets the level of hysteresis on the magnitude deviation (internal AGC


signal that determine gain changes).

5:4

3:2

1:0

WAIT_TIME[1:0]

AGC_FREEZE[1:0]

FILTER_LENGTH[1:0]

1 (01)

0 (00)

1 (01)

R/W

R/W

R/W

Setting

Description

0 (00)

No hysteresis, small symmetric dead zone, high gain

1 (01)

Low hysteresis, small asymmetric dead zone, medium


gain

2 (10)

Medium hysteresis, medium asymmetric dead zone,


medium gain

3 (11)

Large hysteresis, large asymmetric dead zone, low


gain

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)

16

2 (10)

24

3 (11)

32

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.

2-FSK, 4-FSK, MSK: Sets the averaging length for the amplitude from
the channel filter.
ASK, OOK: Sets the OOK/ASK decision boundary for OOK/ASK
reception.
Setting

Channel filter
samples

OOK/ASK decision boundary

0 (00)

4 dB

1 (01)

16

8 dB

2 (10)

32

12 dB

3 (11)

64

16 dB

0x1E: WOREVT1 High Byte Event0 Timeout


Bit

Field Name

Reset

R/W

Description

7:0

EVENT0[15:8]

135 (0x87)

R/W

High byte of EVENT0 timeout register

t Event 0

SWRS061I

750
EVENT 0 2 5WOR _ RES
f XOSC

Page 87 of 98

CC1101
0x1F: WOREVT0 Low Byte Event0 Timeout
Bit

Field Name

Reset

R/W

Description

7:0

EVENT0[7:0]

107 (0x6B)

R/W

Low byte of EVENT0 timeout register.


The default EVENT0 value gives 1.0s timeout, assuming a 26.0 MHz crystal.

0x20: WORCTRL Wake On Radio Control


Bit

Field Name

Reset

R/W

Description

RC_PD

R/W

Power down signal to RC oscillator. When written to 0, automatic initial


calibration will be performed

6:4

EVENT1[2:0]

7 (111)

R/W

Timeout setting from register block. Decoded to Event 1 timeout. RC oscillator


clock frequency equals FXOSC/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.

RC_CAL

WOR_RES

0 (00)

2
1:0

Setting

tEvent1

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)

R/W

Enables (1) or disables (0) the RC oscillator calibration.

R0

Not used

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 29 s)

1.8 1.9 seconds

1 (01)

25 periods (0.89 0.92 ms)

58 61 seconds

2 (10)
3 (11)

10

31 32 minutes

15

16.5 17.2 hours

2 periods (28 30 ms)


2 periods (0.91 0.94 s)

Note that WOR_RES should be 0 or 1 when using WOR because


1 will give a very low duty cycle.

WOR_RES >

In normal RX operation all settings of WOR_RES can be used.

SWRS061I

Page 88 of 98

CC1101
0x21: FREND1 Front End RX Configuration
Bit

Field Name

Reset

R/W

Description

7:6

LNA_CURRENT[1:0]

1 (01)

R/W

Adjusts front-end LNA PTAT current output

5:4

LNA2MIX_CURRENT[1:0]

1 (01)

R/W

Adjusts front-end PTAT outputs

3:2

LODIV_BUF_CURRENT_RX[1:0]

1 (01)

R/W

Adjusts current in RX LO buffer (LO input to mixer)

1:0

MIX_CURRENT[1:0]

2 (10)

R/W

Adjusts current in mixer

0x22: FREND0 Front End TX Configuration


Bit

Field Name

Reset

LODIV_BUF_CURRENT_TX[1:0]

1 (0x01)

7:6
5:4
3
2:0

PA_POWER[2:0]

0 (0x00)

R/W

Description

R0

Not used

R/W

Adjusts current TX LO buffer (input to PA). The value to use


in this field is given by the SmartRF Studio software [5].

R0

Not used

R/W

Selects PA power setting. This value is an index to the


PATABLE, 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. PATABLE index zero is
used in OOK/ASK when transmitting a 0. The PATABLE
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.

0x23: FSCAL3 Frequency Synthesizer Calibration


Bit

Field Name

Reset

R/W

Description

7:6

FSCAL3[7:6]

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]

2 (0x02)

R/W

Disable charge pump calibration stage when 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
FSCAL3[3:0]/4
exponential scale: I_OUT = I02
Fast frequency hopping without calibration for each hop can
be done by calibrating upfront for each frequency and saving
the resulting FSCAL3, FSCAL2 and FSCAL1 register values.
Between each frequency hop, calibration can be replaced by
writing the FSCAL3, FSCAL2 and FSCAL1 register values
corresponding to the next RF frequency.

SWRS061I

Page 89 of 98

CC1101
0x24: FSCAL2 Frequency Synthesizer Calibration
Bit

Field Name

Reset

7:6

R/W

Description

R0

Not used

VCO_CORE_H_EN

R/W

Choose high (1) / low (0) VCO

4:0

FSCAL2[4:0]

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 FSCAL3,
FSCAL2 and FSCAL1 register values. Between each frequency hop,
calibration can be replaced by writing the FSCAL3, FSCAL2 and FSCAL1
register values corresponding to the next RF frequency.

0x25: FSCAL1 Frequency Synthesizer Calibration


Bit

Field Name

Reset

7:6
5:0

FSCAL1[5:0]

32 (0x20)

R/W

Description

R0

Not used

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 FSCAL3,
FSCAL2 and FSCAL1 register values. Between each frequency hop,
calibration can be replaced by writing the FSCAL3, FSCAL2 and FSCAL1
register values corresponding to the next RF frequency.

0x26: FSCAL0 Frequency Synthesizer Calibration


Bit

Field Name

Reset

7
6:0

FSCAL0[6:0]

13 (0x0D)

R/W

Description

R0

Not used

R/W

Frequency synthesizer calibration control. The value to use in this register is


given by the SmartRF Studio software [5].

0x27: RCCTRL1 RC Oscillator Configuration


Bit

Field Name

7
6:0

RCCTRL1[6:0]

Reset

R/W

Description

R0

Not used

65 (0x41)

R/W

RC oscillator configuration.

0x28: RCCTRL0 RC Oscillator Configuration


Bit

Field Name

7
6:0

RCCTRL0[6:0]

Reset

R/W

Description

R0

Not used

0 (0x00)

R/W

RC oscillator configuration.

SWRS061I

Page 90 of 98

CC1101
29.2 Configuration Register Details Registers that Loose Programming in SLEEP State
0x29: FSTEST Frequency Synthesizer Calibration Control
Bit

Field Name

Reset

R/W

Description

7:0

FSTEST[7:0]

89 (0x59)

R/W

For test only. Do not write to this register.

0x2A: PTEST Production Test


Bit

Field Name

Reset

R/W

Description

7:0

PTEST[7:0]

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.

0x2B: AGCTEST AGC Test


Bit

Field Name

Reset

R/W

Description

7:0

AGCTEST[7:0]

63 (0x3F)

R/W

For test only. Do not write to this register.

0x2C: TEST2 Various Test Settings


Bit

Field Name

Reset

R/W

Description

7:0

TEST2[7:0]

136 (0x88)

R/W

The value to use in this register is given by the SmartRF Studio software
[5]. This register will be forced to 0x88 or 0x81 when it wakes up from
SLEEP mode, depending on the configuration of FIFOTHR.
ADC_RETENTION.
Note that the value read from this register when waking up from SLEEP
always is the reset value (0x88) regardless of the ADC_RETENTION
setting. The inverting of some of the bits due to the ADC_RETENTION
setting is only seen INTERNALLY in the analog part.

0x2D: TEST1 Various Test Settings


Bit

Field Name

Reset

R/W

Description

7:0

TEST1[7:0]

49 (0x31)

R/W

The value to use in this register is given by the SmartRF Studio software
[5]. This register will be forced to 0x31 or 0x35 when it wakes up from
SLEEP mode, depending on the configuration of FIFOTHR.
ADC_RETENTION.
Note that the value read from this register when waking up from SLEEP
always is the reset value (0x31) regardless of the ADC_RETENTION
setting. The inverting of some of the bits due to the ADC_RETENTION
setting is only seen INTERNALLY in the analog part.

SWRS061I

Page 91 of 98

CC1101
0x2E: TEST0 Various Test Settings
Bit

Field Name

Reset

R/W

Description

7:2

TEST0[7:2]

2 (0x02)

R/W

The value to use in this register is given by the SmartRF Studio software
[5].

VCO_SEL_CAL_EN

R/W

Enable VCO selection calibration stage when 1

TEST0[0]

R/W

The value to use in this register is given by the SmartRF Studio software
[5].

29.3 Status Register Details


0x30 (0xF0): PARTNUM Chip ID
Bit

Field Name

Reset

R/W

Description

7:0

PARTNUM[7:0]

0 (0x00)

Chip part number

0x31 (0xF1): VERSION Chip ID


Bit

Field Name

Reset

R/W

Description

7:0

VERSION[7:0]

20
(0x14)

Chip version number. Subject to change without notice.

0x32 (0xF2): FREQEST Frequency Offset Estimate from Demodulator


Bit

Field Name

7:0

FREQOFF_EST

Reset

R/W

Description

The estimated frequency offset (2s complement) of the carrier. Resolution is


FXTAL/214 (1.59 - 1.65 kHz); range is 202 kHz to 210 kHz, depending on XTAL
frequency.
Frequency offset compensation is only supported for 2-FSK, GFSK, 4-FSK, and
MSK modulation. This register will read 0 when using ASK or OOK modulation.

0x33 (0xF3): LQI Demodulator Estimate for Link Quality


Bit

Field Name

7
6:0

Reset

R/W

Description

CRC OK

The last CRC comparison matched. Cleared when entering/restarting RX mode.

LQI_EST[6:0]

The Link Quality Indicator estimates how easily a received signal can be
demodulated. Calculated over the 64 symbols following the sync word

0x34 (0xF4): RSSI Received Signal Strength Indication


Bit

Field Name

7:0

RSSI

Reset

R/W

Description

Received signal strength indicator

SWRS061I

Page 92 of 98

CC1101
0x35 (0xF5): MARCSTATE Main Radio Control State Machine State
Bit

Field Name

Reset

7:5
4:0

MARC_STATE[4:0]

R/W

Description

R0

Not used

Main Radio Control FSM State


Value

State name

State (Figure 25, page 50)

0 (0x00)

SLEEP

SLEEP

1 (0x01)

IDLE

IDLE

2 (0x02)

XOFF

XOFF

3 (0x03)

VCOON_MC

MANCAL

4 (0x04)

REGON_MC

MANCAL

5 (0x05)

MANCAL

MANCAL

6 (0x06)

VCOON

FS_WAKEUP

7 (0x07)

REGON

FS_WAKEUP

8 (0x08)

STARTCAL

CALIBRATE

9 (0x09)

BWBOOST

SETTLING

10 (0x0A)

FS_LOCK

SETTLING

11 (0x0B)

IFADCON

SETTLING

12 (0x0C)

ENDCAL

CALIBRATE

13 (0x0D)

RX

RX

14 (0x0E)

RX_END

RX

15 (0x0F)

RX_RST

RX

16 (0x10)

TXRX_SWITCH

TXRX_SETTLING

17 (0x11)

RXFIFO_OVERFLOW

RXFIFO_OVERFLOW

18 (0x12)

FSTXON

FSTXON

19 (0x13)

TX

TX

20 (0x14)

TX_END

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.

0x36 (0xF6): WORTIME1 High Byte of WOR Time


Bit

Field Name

7:0

TIME[15:8]

Reset

R/W

Description

High byte of timer value in WOR module

0x37 (0xF7): WORTIME0 Low Byte of WOR Time


Bit

Field Name

7:0

TIME[7:0]

Reset

R/W

Description

Low byte of timer value in WOR module

SWRS061I

Page 93 of 98

CC1101
0x38 (0xF8): PKTSTATUS Current GDOx Status and Packet Status
Bit

Field Name

Reset

R/W

Description

CRC_OK

The last CRC comparison matched. Cleared when entering/restarting RX


mode.

CS

Carrier sense. Cleared when entering IDLE mode.

PQT_REACHED

Preamble Quality reached. If leaving RX state when this bit is set it will
remain asserted until the chip re-enters RX state (MARCSTATE=0x0D). The
bit will also be cleared if PQI goes below the programmed PQT value.

CCA

Channel is clear

SFD

Start of Frame Delimiter. In RX, this bit is asserted when sync word has
been received and de-asserted at the end of the packet. It will also deassert when a packet is discarded due to address or maximum length
filtering or the radio enters RXFIFO_OVERFLOW state. In TX this bit will
always read as 0.

GDO2

Current GDO2 value. Note: the reading gives the non-inverted value
irrespective of what IOCFG2.GDO2_INV is programmed to.
It is not recommended to check for PLL lock by reading PKTSTATUS[2]
with GDO2_CFG=0x0A.

1
0

GDO0

R0

Not used

Current GDO0 value. Note: the reading gives the non-inverted value
irrespective of what IOCFG0.GDO0_INV is programmed to.
It is not recommended to check for PLL lock by reading PKTSTATUS[0]
with GDO0_CFG=0x0A.

0x39 (0xF9): VCO_VC_DAC Current Setting from PLL Calibration Module


Bit

Field Name

Reset

7:0

VCO_VC_DAC[7:0]

R/W

Description

Status register for test only.

0x3A (0xFA): TXBYTES Underflow and Number of Bytes


Bit

Field Name

Reset

R/W

TXFIFO_UNDERFLOW

6:0

NUM_TXBYTES

Description

Number of bytes in TX FIFO

0x3B (0xFB): RXBYTES Overflow and Number of Bytes


Bit

Field Name

Reset

R/W

RXFIFO_OVERFLOW

6:0

NUM_RXBYTES

Description

Number of bytes in RX FIFO

0x3C (0xFC): RCCTRL1_STATUS Last RC Oscillator Calibration Result


Bit

Field Name

7
6:0

RCCTRL1_STATUS[6:0]

Reset

R/W

Description

R0

Not used

Contains the value from the last run of the RC oscillator calibration routine.
For usage description refer to Application Note AN047 [4]

SWRS061I

Page 94 of 98

CC1101
0x3D (0xFD): RCCTRL0_STATUS Last RC Oscillator Calibration Result
Bit

Field Name

Reset

7
6:0

RCCTRL0_STATUS[6:0]

R/W

Description

R0

Not used

Contains the value from the last run of the RC oscillator calibration routine.
For usage description refer to Application Note AN047 [4].

30 Soldering Information
The recommendations for lead-free reflow in IPC/JEDEC J-STD-020 should be followed.

31 Development Kit Ordering Information


Orderable Evaluation Module

Description

Minimum Order Quantity

CC1101DK433

CC1101 Development Kit, 433 MHz

CC1101DK868-915

CC1101 Development Kit, 868/915 MHz

CC1101EMK433

CC1101 Evaluation Module Kit, 433 MHz

CC1101EMK868-915

CC1101 Evaluation Module Kit, 868/915 MHz

Figure 34: Development Kit Ordering Information

SWRS061I

Page 95 of 98

CC1101
32

References

[1]

CC1101EM 315 - 433 MHz Reference Design (swrr046.zip)

[2]

CC1101EM 868 915 MHz Reference Design (swrr045.zip)

[3]

CC1101 Errata Notes (swrz020.pdf)

[4]

AN047 CC1100/CC2500 Wake-On-Radio (swra126.pdf)

[5]

SmartRF

[6]

CC1100 CC2500 Examples Libraries (swrc021.zip)

[7]

CC1100/CC1150DK, CC1101DK, and CC2500/CC2550DK Examples and Libraries User


Manual (swru109.pdf)

[8]

DN010 Close-in Reception with CC1101 (swra147.pdf)

[9]

DN017 CC11xx 868/915 MHz RF Matching (swra168.pdf)

[10]

DN015 Permanent Frequency Offset Compensation (swra159.pdf)

[11]

DN006 CC11xx Settings for FCC 15.247 Solutions (swra123.pdf)

[12]

DN505 RSSI Interpretation and Timing (swra114.pdf)

[13]

AN058 Antenna Selection Guide (swra161.pdf)

[14]

AN067 Wireless MBUS Implementation with CC1101 and MSP430 (swra234.pdf)

[15]

DN013 Programming Output Power on CC1101 (swra168.pdf)

[16]

DN022 CC11xx OOK/ASK register settings (swra215.pdf)

[17]

DN005 CC11xx Sensitivity versus Frequency Offset and Crystal Accuracy (swra122.pdf)

[18]

DN501 PATABLE Access (swra110.pdf)

[19]

DN504 FEC Implementation (swra113.pdf)

[20]

DN507 FEC Decoding (swra313.pdf)

[21]

CC1190 Data Sheet (swrs089.pdf)

[22]

AN094 Using the CC1190 Front End with CC1101 under EN 300 220 (swra356.pdf)

[23]

AN096 Using the CC1190 Front End with CC1101 under FCC 15.247 (swra361.pdf)

[24]

DN032 Options for Cost Optimized CC11xx Matching (swra346.pdf)

[25]

DN036 CC1101+CC1190 600 kbps Data Rate, +19 dBm transmit power without FHSS in
902-928 MHz frequency Band (swrr078.pdf)

[26]

TPS62730 Data Sheet (slvsac3.pdf)

TM

Studio (swrc046.zip)

SWRS061I

Page 96 of 98

CC1101
33

General Information

33.1 Document History


Revision

Date

Description/Changes

SWRS061I

2013.11.05

Updated the package designator from RTK to RGP


Changed description of VERSION. Reset value changed from 0x04 to 0x14

SWRS061H

2012.10.09

Added 256 Hz clock to Table 41: GDOx Signal Selection

SWRS061G

2011.07.26

SWRS061F

2010.01.10

Crystal NX3225GA added to application circuit BOM


Added reference to CC1190 range extender
Added reference to AN094 and AN096
Corrected settling times and PLL turn-on/hop time in Table 15
Added reference to design notes DN032 and DN036
Removed references to AN001 and AN050
Changed description of MCSM0.PO_TIMEOUT
Removed link to DN009
Added more detailed information about how to check for PLL lock in Section 22.1
Changed from multi-layer to wire-wound inductors in Table 38.
Included PA_PD and LNA_PD GDO signals Table 41 as they were erroneously
removed in SWRS061E.
Updated WOR current consumption figures in Table 4.
The Gaussian filter BT is changed from 1.0 to 0.5.
Changed minimum data rate to 0.6 kBaud.
Updated Table 25 with 0.6 kBaud data rate.
Added information that digital signals with sharp edges should not be routed close to
XOSC_Q1 PCB track.
Added information about 1/XOSC glitch in received data output when using
asynchronous serial mode
Added information that a 27 MHz crystal is recommended for systems targeting
compliance with modulation bandwidth requirements in the 869 to 870 MHz frequency
range under EN 300 220.

SWRS061E

2009.04.21

Updated overall state transition times in Table 34 and added table with frequency
synthesizer calibration times (Table 35).
Added -116 dBm 1% PER at 0.6 kBaud, 434 MHz
Included information about 4-FSK modulation
Added sensitivity figures for 4-FSK
Added link to DN507
Updated PKTSTATUS.SFD. In TX this bit reads as 0.
Updated PKTSTATUS.PQT_REACHED.
Removed chapter on Packet Description
Changed chapter on Ordering Information since this was duplicate information.
Maximum output power increased to +12/+11 dBm at 868/915MHz with the use of
wire-wound inductors (Murata LQW15xx series).
Changes to optimum PATABLE settings.
Added typical output power over temperature and supply voltage.
Changes to current consumption in TX mode.
Added typical TX current consumption over temperature and supply voltage.
Improved sensitivity figures at 868/915 MHz.
Added typical sensitivity figures over temperature and supply voltage.
Added typical RX current consumption over temperature and input power level.
Changes to adjacent channel rejection at 38.4 kBaud.
Changes to image rejection at 250 kBaud.
Updates to selectivity/blocking plots.
Changed bill of materials for 868/915 MHz application circuits to Murata LQW15xx
series inductors.
Changed analog temperature sensor temperature coefficient.
Added links to DN501 and DN504
Changes to section 17.6. A low LQI value indicates a good link
Changes to Package Description section
Changes to Ordering Information section

SWRS061I

Page 97 of 98

CC1101
Revision

Date

Description/Changes

SWRS061D

2008.05.22

Edited title and removed CC logo.


Formatted and edited text. Put important notes in boxes.
Corrected the 250 kBaud settings information from MSK to GFSK.
Added plot over RX current variation versus input power level and temperature.
Added tables for sensitivity, output power and TX current consumption variation
versus temperature and supply voltage.
Moved the selectivity plots to the electrical specification section and updated the 1.2
kBaud setting plot.
Added load capacitance spec for the crystal oscillator.
Updated links from AN039 to AN050.
Updated information regarding optional filtering of 699 MHz emission, updated the
868/915 MHz application figure and bills of material, and added link to DN017.
Updated and moved information regarding the crystal, a reference signal, the balun,
and PCB layout recommendations to the section regarding the application circuit.
Added information regarding antennas and link to the antenna selection guide AN058.
Added link to DN005.
Restructured Section 14.1 and added link to DN015.
Moved improved spectrum information (GFSK info) to Section 16.1.
Added information regarding the DEVIATN register in Chapter 16 and in the register
description.
Added information on ASK/OOK settings and added a link to DN022.
Updated RSSI information and added link to DN505.
Updated Section 18.2 information.
Clarified the text describing Figure 27.
Added link to DN013.
Updated Figure 33.
Updated Section 28.2.
Updated information regarding serial synchronous mode.
Added information regarding Wireless MBUS and added link to AN067.
Updated info regarding the FIFOTHR register and TEST1 and TEST2.
Updated info regarding the PKTSTAUS.SFD bit.
Updated address for reading content from 0x3D.
Updated registers information on bits that are not used.
Updated Command Strobes section.
Added link to DN009.
Updated links in the reference chapter.
Added link to the Community.

SWRS061C

2008.05.22

Added product information on the front page

SWRS061B

2007.06.05

Changed name on DN009 Close-in Reception with CC1101 to DN010 Close-in


Reception with CC1101.
Added info regarding how to reduce spurious emission at 699 MHz. Changes
regarding this was done the following places: Table: RF Transmit Section,
Figure 11: Typical Application and Evaluation Circuit 868/915 MHz, Table 20:
Overview of External Components, and Table 21: Bill Of Materials for the Application
Circuit.
Changes made to Figure 27: Power-On Reset with SRES

SWRS061A

2007.06.30

Initial release.

SWRS061

2007.04.16

First preliminary data sheet release

Table 46: Document History

SWRS061I

Page 98 of 98

PACKAGE OPTION ADDENDUM

www.ti.com

5-Nov-2013

PACKAGING INFORMATION
Orderable Device

Status
(1)

Package Type Package Pins Package


Drawing
Qty

Eco Plan

Lead/Ball Finish

MSL Peak Temp

(2)

(6)

(3)

Op Temp (C)

Device Marking
(4/5)

CC1101RGP

ACTIVE

QFN

RGP

20

92

Green (RoHS
& no Sb/Br)

CU NIPDAU

Level-3-260C-168 HR

-40 to 85

CC1101

CC1101RGPR

ACTIVE

QFN

RGP

20

3000

Green (RoHS
& no Sb/Br)

CU NIPDAU

Level-3-260C-168 HR

-40 to 85

CC1101

CC1101RGPT

ACTIVE

QFN

RGP

20

250

Green (RoHS
& no Sb/Br)

CU NIPDAU

Level-3-260C-168 HR

-40 to 85

CC1101

(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.

(4)

There may be additional marking, which relates to the logo, the lot trace code information, or the environmental category on the device.

(5)

Multiple Device Markings will be inside parentheses. Only one Device Marking contained in parentheses and separated by a "~" will appear on a device. If a line is indented then it is a continuation
of the previous line and the two combined represent the entire Device Marking for that device.
(6)

Lead/Ball Finish - Orderable Devices may have multiple material finish options. Finish options are separated by a vertical ruled line. Lead/Ball Finish values may wrap to two lines if the finish
value exceeds the maximum column width.
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

Addendum-Page 1

Samples

PACKAGE OPTION ADDENDUM

www.ti.com

5-Nov-2013

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.
OTHER QUALIFIED VERSIONS OF CC1101 :

Automotive: CC1101-Q1
NOTE: Qualified Version Definitions:

Automotive - Q100 devices qualified for high-reliability automotive applications targeting zero defects

Addendum-Page 2

IMPORTANT NOTICE
Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, enhancements, improvements and other
changes to its semiconductor products and services per JESD46, latest issue, and to discontinue any product or service per JESD48, latest
issue. Buyers should obtain the latest relevant information before placing orders and should verify that such information is current and
complete. All semiconductor products (also referred to herein as components) are sold subject to TIs terms and conditions of sale
supplied at the time of order acknowledgment.
TI warrants performance of its components to the specifications applicable at the time of sale, in accordance with the warranty in TIs terms
and conditions of sale of semiconductor products. Testing and other quality control techniques are used to the extent TI deems necessary
to support this warranty. Except where mandated by applicable law, testing of all parameters of each component is not necessarily
performed.
TI assumes no liability for applications assistance or the design of Buyers products. Buyers are responsible for their products and
applications using TI components. To minimize the risks associated with Buyers products and applications, Buyers should provide
adequate design and operating safeguards.
TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or
other intellectual property right relating to any combination, machine, or process in which TI components or services are used. Information
published by TI regarding third-party products or services does not constitute a license 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 significant portions 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. TI is not responsible or liable for such altered
documentation. Information of third parties may be subject to additional restrictions.
Resale of TI components or services with statements different from or beyond the parameters stated by TI for that component or service
voids all express and any implied warranties for the associated TI component or service and is an unfair and deceptive business practice.
TI is not responsible or liable for any such statements.
Buyer acknowledges and agrees that it is solely responsible for compliance with all legal, regulatory and safety-related requirements
concerning its products, and any use of TI components in its applications, notwithstanding any applications-related information or support
that may be provided by TI. Buyer represents and agrees that it has all the necessary expertise to create and implement safeguards which
anticipate dangerous consequences of failures, monitor failures and their consequences, lessen the likelihood of failures that might cause
harm and take appropriate remedial actions. Buyer will fully indemnify TI and its representatives against any damages arising out of the use
of any TI components in safety-critical applications.
In some cases, TI components may be promoted specifically to facilitate safety-related applications. With such components, TIs goal is to
help enable customers to design and create their own end-product solutions that meet applicable functional safety standards and
requirements. Nonetheless, such components are subject to these terms.
No TI components are authorized for use in FDA Class III (or similar life-critical medical equipment) unless authorized officers of the parties
have executed a special agreement specifically governing such use.
Only those TI components which TI has specifically designated as military grade or enhanced plastic are designed and intended for use in
military/aerospace applications or environments. Buyer acknowledges and agrees that any military or aerospace use of TI components
which have not been so designated is solely at the Buyer's risk, and that Buyer is solely responsible for compliance with all legal and
regulatory requirements in connection with such use.
TI has specifically designated certain components as meeting ISO/TS16949 requirements, mainly for automotive use. In any case of use of
non-designated products, TI will not be responsible for any failure to meet ISO/TS16949.
Products

Applications

Audio

www.ti.com/audio

Automotive and Transportation

www.ti.com/automotive

Amplifiers

amplifier.ti.com

Communications and Telecom

www.ti.com/communications

Data Converters

dataconverter.ti.com

Computers and Peripherals

www.ti.com/computers

DLP Products

www.dlp.com

Consumer Electronics

www.ti.com/consumer-apps

DSP

dsp.ti.com

Energy and Lighting

www.ti.com/energy

Clocks and Timers

www.ti.com/clocks

Industrial

www.ti.com/industrial

Interface

interface.ti.com

Medical

www.ti.com/medical

Logic

logic.ti.com

Security

www.ti.com/security

Power Mgmt

power.ti.com

Space, Avionics and Defense

www.ti.com/space-avionics-defense

Microcontrollers

microcontroller.ti.com

Video and Imaging

www.ti.com/video

RFID

www.ti-rfid.com

OMAP Applications Processors

www.ti.com/omap

TI E2E Community

e2e.ti.com

Wireless Connectivity

www.ti.com/wirelessconnectivity
Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265
Copyright 2014, Texas Instruments Incorporated

You might also like