TOP Contributors

  1. MIKROE (2784 codes)
  2. Alcides Ramos (405 codes)
  3. Shawon Shahryiar (307 codes)
  4. jm_palomino (133 codes)
  5. Bugz Bensce (97 codes)
  6. S P (73 codes)
  7. dany (71 codes)
  8. MikroBUS.NET Team (35 codes)
  9. NART SCHINACKOW (34 codes)
  10. Armstrong Subero (27 codes)

Most Downloaded

  1. Timer Calculator (141936 times)
  2. FAT32 Library (75086 times)
  3. Network Ethernet Library (59381 times)
  4. USB Device Library (49373 times)
  5. Network WiFi Library (45195 times)
  6. FT800 Library (44753 times)
  7. GSM click (31329 times)
  8. mikroSDK (30291 times)
  9. microSD click (27699 times)
  10. PID Library (27584 times)
Libstock prefers package manager

Package Manager

We strongly encourage users to use Package manager for sharing their code on Libstock website, because it boosts your efficiency and leaves the end user with no room for error. [more info]

< Back
mikroSDK Library

ccRF 2 click

Rating:

1

Author: MIKROE

Last Updated: 2019-07-31

Package Version: 1.0.0.1

mikroSDK Library: 1.0.0.0

Category: Sub-1 GHz Transceivers

Downloaded: 5401 times

Not followed.

License: MIT license  

This is a sample program which demonstrates the use of ccRF2 click. Programmer uses RF module for communication between two development systems. Each module can be used as transmitter and receiver.

No Abuse Reported

Do you want to subscribe in order to receive notifications regarding "ccRF 2 click" changes.

Do you want to unsubscribe in order to stop receiving notifications regarding "ccRF 2 click" changes.

Do you want to report abuse regarding "ccRF 2 click".

  • mikroSDK Library 2.0.0.0
  • Comments (1)
DOWNLOAD LINK RELATED COMPILER CONTAINS
mikroBasic PRO for ARM
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroBasic PRO for AVR
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroBasic PRO for dsPIC30/33 & PIC24
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroBasic PRO for FT90x
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroBasic PRO for PIC
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroBasic PRO for PIC32
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroC PRO for ARM
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroC PRO for AVR
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroC PRO for dsPIC30/33 & PIC24
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroC PRO for FT90x
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroC PRO for PIC
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroC PRO for PIC32
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroPascal PRO for ARM
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroPascal PRO for AVR
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroPascal PRO for dsPIC30/33 & PIC24
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroPascal PRO for FT90x
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroPascal PRO for PIC
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc
mikroPascal PRO for PIC32
  • lib
  • src
  • exa
  • hlp
  • hex
  • sch
  • pcb
  • doc

mikroSDK Library Blog

ccRF2 click

ccRF2 click

Front and back side appearance of the ccRF2 click Board.

View full image

Library Description

The library covers all the necessary functions to control ccRF 2 Click board. A library performs the communication with the device via SPI interface with CC1120 single-chip radio transceiver.

Key functions:

  • uint8_t ccrf2_readByteReg( uint16_t regAddress ) - Read the byte of data function.
  • void ccrf2_writeBytesReg( uint16_t regAddress, uint8_t *writeData, uint8_t nBytes ) - Sequential write data function.
  • uint8_t ccrf2_writeTXfifo( uint8_t *writeData, uint8_t nBytes ) - Write TX FIFO register function.

Examples description

The application is composed of the three sections :

  • System Initialization - Initializes SPI and LOG structures sets AN, INT and PWM pin as input and CS and RST pins as output and start to write log.
  • Application Initialization - Initialization driver enables - SPI, hardware reset chip, sets default configuration, sets manual calibration, sets operation mode, also write log.
  • Application Task - This is an example which demonstrates the use of ccRF 2 click board. If RX mode selected, checks if new data byte has received in RX buffer ( ready for reading ), and if ready than reads one byte from RX buffer. In the second case, the application task writes received message data via UART. Results are being sent to the Usart Terminal where you can track their changes.
  • Commands : â€‹'T' - TX mode; 'R' - RX mode; 'I' - Idle mode;
void applicationTask()
{
    char receivedData;
    
    if ( UART_Rdy_Ptr() )
    {
        receivedData = UART_Rd_Ptr();

        switch ( receivedData )
        {
            case 'T' :
            {
                modeSelected = _CCRF2_TX_MODE;
                sendFlag = 0;
                readingFlag = 0;
                Delay_ms( 200 );
                ccrf2_setTXmode();

                mikrobus_logWrite( "       TX  Mode       ", _LOG_LINE );
                mikrobus_logWrite( "----------------------", _LOG_LINE );
                break;
            }
            case 'R' :
            {
                modeSelected = _CCRF2_RX_MODE;
                receiveFlag = 0;
                ccrf2_setRXmode();
                readingFlag = 1;

                mikrobus_logWrite( "       RX  Mode       ", _LOG_LINE );
                mikrobus_logWrite( "----------------------", _LOG_LINE );
                break;
            }
            case 'I' :
            {
                modeSelected = _CCRF2_IDLE_MODE;

                mikrobus_logWrite( "      Idle  Mode      ", _LOG_LINE );
                mikrobus_logWrite( "----------------------", _LOG_LINE );
                break;
            }
        }
    }

    switch( modeSelected )
    {
        case _CCRF2_TX_MODE:
        {
            ccrf2_sendTXdata( &txBuffer[ 0 ], 8 );
            Delay_ms( 1000 );
            break;
        }
        case _CCRF_RX_MODE:
        {
            if ( readingFlag )
            {
                ccrf2_receiveRXdata( &rxBuffer[ 0 ] );
                lengthRx = sizeof( rxBuffer );
    
                for ( cnt = 0; cnt < lengthRx; cnt++ )
                {
                    mikrobus_logWrite( " rxBuffer[ ", _LOG_TEXT );
                    ByteToStr( cnt, logText );
                    ltrim( logText );
                    rtrim( logText );
                    mikrobus_logWrite( logText, _LOG_TEXT );
                    mikrobus_logWrite( " ] = ", _LOG_TEXT );
                    ByteToStr( rxBuffer[ cnt ], logText );
                    ltrim( logText );
                    mikrobus_logWrite( logText, _LOG_LINE );
                }

                Delay_ms( 1000 );
                mikrobus_logWrite( "----------------------", _LOG_LINE );
            }
            break;
        }
    }
}

Other mikroE Libraries used in the example:

  • SPI
  • UART
  • Conversion

Additional notes and informations

Depending on the development board you are using, you may need USB UART clickUSB UART 2 click or RS232 click to connect to your PC, for development systems with no UART to USB interface available on the board. The terminal available in all MikroElektronika compilers, or any other terminal application of your choice, can be used to read the message.

ALSO FROM THIS AUTHOR

I2C Isolator 6 Click

0

I2C Isolator 6 Click is a compact add-on board that offers completely isolated bidirectional communication. This board features the ADUM2250, a two-channel, 5kVRMS I2C digital isolator from Analog Devices. The ADUM2250 provides two bidirectional channels, supporting a completely isolated I2C interface that eliminates the need for splitting I2C signals into separate transmit and receive signals for use with standalone optocouplers. It supports data rates from DC up to 1MHz and has a hot swap circuitry to prevent data glitches.

[Learn More]

LR 11 915MHz Click

0

LR 11 Click - 915MHz is a compact add-on board for long-range, low-power wireless communication in IoT applications. This board features the 453-00139R, an ultra-low power LoraWAN module Ezurio (part of the RM126x series), integrating the Silicon Labs EFR32 SoC and the Semtech SX1262 radio. It supports LoRaWAN classes A, B, and C, offering secure, scalable, and bi-directional communication. It operates in the 902-928MHz frequency range with a typical transmit power of up to 22dBm and a communication range of up to 15km.

[Learn More]

UVB click

5

UVB Click is based on GUVB-C31SM ultraviolet sensor from GenUV. UVB Click supports integrated functions of ultraviolet light sensors such that can be easily configured and used in user applications.

[Learn More]