/* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License. If not, see . */ #ifndef _IFACE_NRF24L01_H_ #define _IFACE_NRF24L01_H_ #include // Register map enum { NRF24L01_00_CONFIG = 0x00, NRF24L01_01_EN_AA = 0x01, NRF24L01_02_EN_RXADDR = 0x02, NRF24L01_03_SETUP_AW = 0x03, NRF24L01_04_SETUP_RETR = 0x04, NRF24L01_05_RF_CH = 0x05, NRF24L01_06_RF_SETUP = 0x06, NRF24L01_07_STATUS = 0x07, NRF24L01_08_OBSERVE_TX = 0x08, NRF24L01_09_CD = 0x09, NRF24L01_0A_RX_ADDR_P0 = 0x0A, NRF24L01_0B_RX_ADDR_P1 = 0x0B, NRF24L01_0C_RX_ADDR_P2 = 0x0C, NRF24L01_0D_RX_ADDR_P3 = 0x0D, NRF24L01_0E_RX_ADDR_P4 = 0x0E, NRF24L01_0F_RX_ADDR_P5 = 0x0F, NRF24L01_10_TX_ADDR = 0x10, NRF24L01_11_RX_PW_P0 = 0x11, NRF24L01_12_RX_PW_P1 = 0x12, NRF24L01_13_RX_PW_P2 = 0x13, NRF24L01_14_RX_PW_P3 = 0x14, NRF24L01_15_RX_PW_P4 = 0x15, NRF24L01_16_RX_PW_P5 = 0x16, NRF24L01_17_FIFO_STATUS = 0x17, NRF24L01_1C_DYNPD = 0x1C, NRF24L01_1D_FEATURE = 0x1D, //Instructions NRF24L01_61_RX_PAYLOAD = 0x61, NRF24L01_A0_TX_PAYLOAD = 0xA0, NRF24L01_E1_FLUSH_TX = 0xE1, NRF24L01_E2_FLUSH_RX = 0xE2, NRF24L01_E3_REUSE_TX_PL = 0xE3, NRF24L01_50_ACTIVATE = 0x50, NRF24L01_60_R_RX_PL_WID = 0x60, NRF24L01_B0_TX_PYLD_NOACK = 0xB0, NRF24L01_FF_NOP = 0xFF, NRF24L01_A8_W_ACK_PAYLOAD0 = 0xA8, NRF24L01_A8_W_ACK_PAYLOAD1 = 0xA9, NRF24L01_A8_W_ACK_PAYLOAD2 = 0xAA, NRF24L01_A8_W_ACK_PAYLOAD3 = 0xAB, NRF24L01_A8_W_ACK_PAYLOAD4 = 0xAC, NRF24L01_A8_W_ACK_PAYLOAD5 = 0xAD, }; // Bit mnemonics enum { NRF24L01_00_MASK_RX_DR = 6, NRF24L01_00_MASK_TX_DS = 5, NRF24L01_00_MASK_MAX_RT = 4, NRF24L01_00_EN_CRC = 3, NRF24L01_00_CRCO = 2, NRF24L01_00_PWR_UP = 1, NRF24L01_00_PRIM_RX = 0, NRF24L01_07_RX_DR = 6, NRF24L01_07_TX_DS = 5, NRF24L01_07_MAX_RT = 4, NRF2401_1D_EN_DYN_ACK = 0, NRF2401_1D_EN_ACK_PAY = 1, NRF2401_1D_EN_DPL = 2, }; // Bitrates enum { NRF24L01_BR_1M = 0, NRF24L01_BR_2M, NRF24L01_BR_250K, NRF24L01_BR_RSVD }; enum TXRX_State { TXRX_OFF, TX_EN, RX_EN, }; // RF Tx Power (estimations with RFX2401C PA) // RFX2401C power amp is ~+25dB (saturates at 22dBm) so: enum TX_Power { TX_POWER_5mW = 0, // -18+25 = 7dBm ~= 5mW TX_POWER_20mW, // -12+25 = 13dBm ~= 20mW TX_POWER_80mW, // -6+25 = 19dBm ~= 80mW TX_POWER_158mW // +25(sat)= 22dBm ~= 158mW }; /* Instruction Mnemonics */ #define R_REGISTER 0x00 #define W_REGISTER 0x20 #define REGISTER_MASK 0x1F #define ACTIVATE 0x50 #define R_RX_PL_WID 0x60 #define R_RX_PAYLOAD 0x61 #define W_TX_PAYLOAD 0xA0 #define W_ACK_PAYLOAD 0xA8 #define FLUSH_TX 0xE1 #define FLUSH_RX 0xE2 #define REUSE_TX_PL 0xE3 #endif