### **Keywords** - CC1100 - CC1101 - CC1150CC2500 - CC2550 - SPI - Reset - Burst Access - Command Strobes #### 1 Introduction The purpose of this design note is to show how the SPI interface must be configured to be able to communicate with the CC1100/CC1101/CC1150/CC2500/CC2550. It also shows how the status bytes should be interpreted, how SW reset is done over the SPI interface, in addition to describing the different SPI accesses that can be used (read/write, single access/burst access, and command strobes). SWRA112B Page 1 of 9 ## **Table of Contents** | Κ | KEYWORDS1 | | | | | | | | |-------|-----------|-----------------------------------|---|--|--|--|--|--| | 1 | | INTRODUCTION | 1 | | | | | | | 2 | | ABBREVIATIONS | 2 | | | | | | | 3 | | SPI INTERFACE | | | | | | | | | 3.1 | CONFIGURING THE SPI INTERFACE | 3 | | | | | | | | 3.2 | SPI Interface Timing Requirements | 3 | | | | | | | 4 | | SPI ACCESSES | | | | | | | | | 4.1 | SINGLE ACCESS | 4 | | | | | | | | 4.2 | Burst Access | 5 | | | | | | | | 4.3 | COMMAND STROBES | 5 | | | | | | | 5 | | CHIP STATUS BYTE | 6 | | | | | | | RESET | | | | | | | | | | 6 | | GENERAL INFORMATION | | | | | | | | | 6.1 | DOCUMENT HISTORY | 9 | | | | | | ### 2 Abbreviations MCU Micro Controller Unit SPI Serial Peripheral Interface SWRA112B Page 2 of 9 #### 3 SPI Interface CC1100/CC1101/CC1150/CC2500/CC2550 are all configured via a simple 4-wire SPI compatible interface (SI, SO, SCLK and CSn) where the radio is the slave and the MCU is the master. This interface is also used to read and write buffered data. All address and data transfer on the SPI interface is done most significant bit first. Figure 1. 4-Wire SPI Interface #### 3.1 Configuring the SPI Interface The SPI interface on the MCU must be configured to operate in master mode. The Clock phase should be configured so that data is centered on the first positive going edge of the SCLK period and the polarity should be chosen so that the SCLK line is low in idle state. Figure 2. SPI Clock Phase and Clock Polarity #### 3.2 SPI Interface Timing Requirements Please see the chip's data sheet for details on the SPI Interface timing requirements. Pay special attention to how the max SCLK frequency ( $f_{sclk}$ ) changes, depending on how the SPI interface is used. The SPI clock can run at max 10 MHz, given that there is a minimum delay of 100 ns inserted between address byte and data byte (single access), or between address and data, and between each data byte (burst access). See Figure 3. Figure 3. f<sub>SCLK</sub> = 10 MHz Max If no delay is inserted between bytes, max clock speed is 9 MHz for single access (see Figure 4) and 6.5 MHz for burst access (Figure 5). SWRA112B Page 3 of 9 Figure 4. f<sub>SCLK</sub> = 9 MHz Max Figure 5. f<sub>SCLK</sub> = 6.5 MHz Max #### 4 SPI Accesses The chips have 47 configuration registers (address 0 to address 0x2E). The R/W bit in the address header controls if the register should be written or read, and the burst bit controls if it is a single access or a burst access. Figure 6. Address Header After pulling CSn, one should always wait for the MISO to go low (CHIP\_RDYn), before writing the address header. The CHIP\_RDYn signal indicates that the crystal is running and the regulated digital supply voltage is stable. Unless the chip is in the SLEEP or XOFF states or an SRES command strobe is issued, the SO pin will always go low immediately after taking CSn low. Figure 7. Waiting for CHIP\_RDYn After Waking the Radio from SLEEP Figure 7 shows how it looks like if the radio is put in SLEEP state (SPWD) from IDLE (1), and then woken from SLEEP state by transmitting a TX strobe (STX) (2). The radio wakes from SLEEP when CSn goes low. The first time CSn goes low, MISO goes high and then low again immediately, indicating that the chip is ready. Next time CSn goes low, the radio is in SLEEP state, and MISO is therefore high. When the voltage regulator has stabilized and the crystal is up and running MISO goes low and it is safe to transmit the TX strobe. ### 4.1 Single Access For single access to the registers, the burst bit has to be set to 0. After transmitting the address header, one can either transmit one data byte or read one byte, depending on the R/W bit. After the data byte a new address is expected; hence, CSn can remain low. Figure 8 shows how 0x0A is first written to register 0x02, and then read from the same register. SWRA112B Page 4 of 9 Figure 8. Single Byte Access (Write and Read) #### 4.2 Burst Access When the burst bit is set, the radio expects one address byte and then consecutive data bytes until terminating the access by setting CSn high. ``` BYTE xdata regValues[] = {1,2,3}; halSpiWriteBurstReg(0x00, regValues, sizeof(regValues)); halSpiReadReg(0x00); halSpiReadReg(0x01); halSpiReadReg(0x02); ``` Figure 9. Burst Write Followed by Single Read #### 4.3 Command Strobes Command strobes are single byte instructions which will start an internal sequence (start RX, enter power down mode etc). The command strobes share addresses with a set of status registers (address 0x30 to address 0x3F). These status registers can not be accessed in burst mode. If the burst bit is 1, a status register is accessed, if the burst bit is 0, a command strobe is sent. A command strobe may be followed by any other SPI access without pulling CSn high. After issuing an SRES command strobe the next command strobe can be issued when the MISO pin goes low. The command strobes are executed immediately, with the exception of the SPWD and the SXOFF strobes that are executed when CSn goes high. SWRA112B Page 5 of 9 ``` // Strobe IDLE NSSMD0 = 0; while (P0_1); // Wait for CHIP_RDYn SPIODAT = CCxxx0_SIDLE; SPI_WAIT(); // Write 0x0A to register 0x00 while (P0_1); // Wait for CHIP_RDYn SPIODAT = 0x00i SPI_WAIT(); SPIODAT = 0x0A; SPI_WAIT(); Reset while (P0_1); // Wait for CHIP_RDYn SPI0DAT = CCxxx0_SRES; SPI_WAIT(); // Read Register 0x00 while (P0_1); // Wait for CHIP_RDYn \, SPIODAT = (0x00 | READ_SINGLE); SPI_WAIT(); SPIODAT = 0; SPI_WAIT(); x = SPIODAT; NSSMD0 = 1; ``` Figure 10. Several SPI Accesses with CSn Kept Low When CSn is pulled low, MISO is already low, indicating that the chip is ready. The SIDLE strobe is followed by a register write and an SRES strobe without having to wait for CHIP\_RDYn. After the reset strobe, it takes some time before MISO goes low and register 0x00 can be read. The value read from this register is 0x29 (the default values after reset). #### 5 Chip Status Byte When the header byte, data byte or command strobe is sent on the SPI interface, the chip status byte is sent from the radio on the MISO pin. The status byte contains key status signals, useful for the MCU. SWRA112B Page 6 of 9 | Bits | Name | Description | | | | | |------|---------------------------|--------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------|--|--| | 7 | 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) | | | | | | 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.<br>Read out any useful data,<br>then flush the FIFO with<br>SFRX | | | | | | 111 | TXFIFO_UNDERFLOW | TX FIFO has underflowed. Acknowledge with SFTX | | | | 3:0 | FIFO_BYTES_AVAILABLE[3:0] | The number of bytes available in the RX FIFO or free bytes in the TX FIFO | | | | | **Table 1. Status Byte Summary** When writing to registers, the status byte is sent on the MISO pin each time a header byte or data byte is transmitted on the MOSI pin. When reading from registers, the status byte is sent on the MISO pin each time a header byte is transmitted on the MOSI pin. Be aware that the 4 LSB of the status byte (FIFO\_BYTES\_AVAILABLE) can give information on either the TX FIFO (R/W = 0) or the RX FIFO (R/W = 1). Figure 11. Status Byte Interpretation The first transfer writes 0x0A to register 0x02. Since it is a write operation, the status byte is transmitted on the MISO line both when the address header is transmitted (1) and when the data byte is transmitted (2). The status bytes (0x0F) tell us that the radio is in IDLE state and that there are 15 or more free bytes in the TX FIFO (FIFO\_BYTES\_AVAILABLE = 15). The second transfer reads register 0x02. Since this is a read operation, the status byte is only returned on the MISO line when the address header is transmitted (3). The next byte on the MISO line is the content of register 0x02, which is 0x0A. The status byte tells us that the radio is in IDLE state (STATE = 0) and that there are 0 bytes available in the RX FIFO (FIFO\_BYTES\_AVAILABLE = 0). SWRA112B Page 7 of 9 #### Reset When the power supply complies with the requirements specified in the data sheet, proper Power-On-Reset functionality is guaranteed. Otherwise, the chip should be assumed to have unknown state until a SW reset is implemented (see Figure 12). - Strobe CSn low / high. - Hold CSn high for at least 40 µs relative to pulling CSn low - Pull CSn low and wait for SO to go low (CHIP\_RDYn). - Issue the SRES strobe on the SI line. Figure 12. Power-On-Reset with SRES #### See code below: ``` // Macro to reset the CCxxx0 and wait for it to be ready #define RESET_CCxxx0() do { NSSMD0 = 0; while (P0_1); SPI0DAT = CCxxx0_SRES; SPI_WAIT(); NSSMD0 = 1; } while (0) // Macro to reset the CCxxx0 after power_on and wait for it to be IMPORTANT NOTICE: The file Wait.c must be included if this macro shall be used The file is located under: ..\Lib\Chipcon\Hal\CCxx00 11 min 40 us 11 CSn // // MISO Unknown / don't care // MOSI SRES #define POWER_UP_RESET_CCxxx0() \ do { \ NSSMD0 = 1; \ halWait(1); \ NSSMD0 = 0; \ halWait(1); \ NSSMD0 = 1; \ halWait(41); RESET_CCxxx0(); \ } while (0) ``` SWRA112B Page 8 of 9 ## 6 General Information ### 6.1 Document History | Revision | Date | Description/Changes | |----------|------------|-------------------------------------------------------------| | SWRA112B | 2007.10.22 | Removed logo from header. Added CC1101. Changed Table 1 and | | | | Figure 12. | | SWRA112A | 2006.10.27 | Figure 12 has been changed. | | SWRA112 | 2006.07.06 | Initial release. | SWRA112B Page 9 of 9 #### **IMPORTANT NOTICE** Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment. TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed. TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards. TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI. Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions. Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements. TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications. TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use. TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements. Following are URLs where you can obtain information on other Texas Instruments products and application solutions: | Products | | Applications | | |-----------------------|------------------------|--------------------|---------------------------| | Amplifiers | amplifier.ti.com | Audio | www.ti.com/audio | | Data Converters | dataconverter.ti.com | Automotive | www.ti.com/automotive | | DSP | dsp.ti.com | Broadband | www.ti.com/broadband | | Interface | interface.ti.com | Digital Control | www.ti.com/digitalcontrol | | Logic | logic.ti.com | Military | www.ti.com/military | | Power Mgmt | power.ti.com | Optical Networking | www.ti.com/opticalnetwork | | Microcontrollers | microcontroller.ti.com | Security | www.ti.com/security | | RFID | www.ti-rfid.com | Telephony | www.ti.com/telephony | | Low Power<br>Wireless | www.ti.com/lpw | Video & Imaging | www.ti.com/video | | | | Wireless | www.ti.com/wireless | Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2007, Texas Instruments Incorporated