/* RadioLib CC1101 Transmit with Interrupts Example This example transmits packets using CC1101 FSK radio module. Once a packet is transmitted, an interrupt is triggered. Each packet contains up to 64 bytes of data, in the form of: - Arduino String - null-terminated char array (C-string) - arbitrary binary data (byte array) For default module settings, see the wiki page https://github.com/jgromes/RadioLib/wiki/Default-configuration#cc1101 For full API reference, see the GitHub Pages https://jgromes.github.io/RadioLib/ */ // include the library #include // CC1101 has the following connections: // CS pin: 10 // GDO0 pin: 2 // RST pin: unused // GDO2 pin: 3 CC1101 radio = new Module(10, 2, RADIOLIB_NC, 3); // or using RadioShield // https://github.com/jgromes/RadioShield //CC1101 radio = RadioShield.ModuleA; // save transmission state between loops int transmissionState = RADIOLIB_ERR_NONE; void setup() { Serial.begin(9600); // initialize CC1101 with default settings Serial.print(F("[CC1101] Initializing ... ")); int state = radio.begin(); if (state == RADIOLIB_ERR_NONE) { Serial.println(F("success!")); } else { Serial.print(F("failed, code ")); Serial.println(state); while (true); } // set the function that will be called // when packet transmission is finished // NOTE: Unlike other modules (such as SX127x), // different GDOx pins are used for // transmit and receive interrupts! radio.setGdo2Action(setFlag, FALLING); // start transmitting the first packet Serial.print(F("[CC1101] Sending first packet ... ")); // you can transmit C-string or Arduino string up to // 64 characters long transmissionState = radio.startTransmit("Hello World!"); // you can also transmit byte array up to 64 bytes long /* byte byteArr[] = {0x01, 0x23, 0x45, 0x56, 0x78, 0xAB, 0xCD, 0xEF}; state = radio.startTransmit(byteArr, 8); */ } // flag to indicate that a packet was sent volatile bool transmittedFlag = false; // this function is called when a complete packet // is transmitted by the module // IMPORTANT: this function MUST be 'void' type // and MUST NOT have any arguments! #if defined(ESP8266) || defined(ESP32) ICACHE_RAM_ATTR #endif void setFlag(void) { // we sent a packet, set the flag transmittedFlag = true; } void loop() { // check if the previous transmission finished if(transmittedFlag) { // reset flag transmittedFlag = false; if (transmissionState == RADIOLIB_ERR_NONE) { // packet was successfully sent Serial.println(F("transmission finished!")); // NOTE: when using interrupt-driven transmit method, // it is not possible to automatically measure // transmission data rate using getDataRate() } else { Serial.print(F("failed, code ")); Serial.println(transmissionState); } // clean up after transmission is finished // this will ensure transmitter is disabled, // RF switch is powered down etc. radio.finishTransmit(); // wait a second before transmitting again delay(1000); // send another one Serial.print(F("[CC1101] Sending another packet ... ")); // you can transmit C-string or Arduino string up to // 256 characters long transmissionState = radio.startTransmit("Hello World!"); // you can also transmit byte array up to 256 bytes long /* byte byteArr[] = {0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF}; int state = radio.startTransmit(byteArr, 8); */ } }