/* * CC120X_protocol.h * * Created on: Apr 13, 2019 * Author: curiousmuch */ #include <stdio.h> #include <stdint.h> #include "cc1200.h" //*********************************// // IMPORTANT GPIO SIGNALS // REG DESCRIPTION // 0x1e TX CLK // 0x1d RX_CLK // 0x10 Carrier Sense Valid // 0x11 Carrier Sense //********************************// // Arrow - AX25 BELL202 AFSK Settings // ----------------------------------- // Address Config = No address check // Bit Rate = 1.2 // Carrier Frequency = 144.389954 // Deviation = 4.997253 // Device Address = 0 // Manchester Enable = false // Modulation Format = 2-FSK // Packet Bit Length = 0 // Packet Length = 255 // Packet Length Mode = Variable // RX Filter BW = 14.880952 // Symbol rate = 1.2 // Whitening = false static const cc1200_reg_settings_t AX25_SETTINGS[]= { {CC120X_IOCFG2, 0x09}, // Serial RX Data {CC120X_IOCFG3, 29}, // Serial Clock {CC120X_IOCFG0, 0x09}, // Serial RX/TX (Don't Touch) {CC120X_SYNC_CFG1, 0x00}, // Disable Sync Word {CC120X_DEVIATION_M, 0x68}, // Deviation: 2.5kHz {CC120X_MODCFG_DEV_E, 0x00}, {CC120X_DCFILT_CFG, 0x5D}, {CC120X_PREAMBLE_CFG1, 0x00}, {CC120X_PREAMBLE_CFG0, 0x00}, // Preamble Disabled {CC120X_IQIC, 0xCB}, {CC120X_CHAN_BW, 0xAA},//0x9C}, {CC120X_MDMCFG1, 0x06}, {CC120X_MDMCFG0, 0x45}, {CC120X_SYMBOL_RATE2, 0x3F}, {CC120X_SYMBOL_RATE1, 0x75}, {CC120X_SYMBOL_RATE0, 0x10}, {CC120X_AGC_REF, 0x30}, {CC120X_AGC_CS_THR, 0xEC}, {CC120X_AGC_CFG3, 0x11}, {CC120X_AGC_CFG1, 0x51}, {CC120X_AGC_CFG0, 0x87}, {CC120X_FIFO_CFG, 0x00}, {CC120X_FS_CFG, 0x1B}, {CC120X_PKT_CFG2, 0x03}, {CC120X_PKT_CFG1, 0x00}, {CC120X_PKT_CFG0, 0x28}, {CC120X_PA_CFG1, 0x3F}, {CC120X_PKT_LEN, 0xFF}, {CC120X_IF_MIX_CFG, 0x1C}, {CC120X_FREQOFF_CFG, 0x22}, // Frequency Offset Configuration, Enabled: 0x22, Disabled: 0x02 {CC120X_MDMCFG2, 0x0D}, // CFM, Enabled: 0x0D, Disabled 0x0C {CC120X_FREQ2, 0x56}, {CC120X_FREQ1, 0xA2}, {CC120X_FREQ0, 0x4C}, {CC120X_IF_ADC1, 0xEE}, {CC120X_IF_ADC0, 0x10}, {CC120X_FS_DIG1, 0x07}, {CC120X_FS_DIG0, 0xAF}, {CC120X_FS_CAL1, 0x40}, {CC120X_FS_CAL0, 0x0E}, {CC120X_FS_DIVTWO, 0x03}, {CC120X_FS_DSM0, 0x33}, {CC120X_FS_DVC0, 0x17}, {CC120X_FS_PFD, 0x00}, {CC120X_FS_PRE, 0x6E}, {CC120X_FS_REG_DIV_CML, 0x1C}, {CC120X_FS_SPARE, 0xAC}, {CC120X_FS_VCO0, 0xB5}, {CC120X_XOSC5, 0x0E}, {CC120X_XOSC1, 0x03}, {CC120X_SERIAL_STATUS, 0x08}, }; // Arrow - FSK Narrowband Settings // Address Config = No address check // Bit Rate = 1.2 // Carrier Frequency = 144.389954 // Deviation = 3.986359 // Device Address = 0 // Manchester Enable = false // Modulation Format = 2-FSK // Packet Bit Length = 0 // Packet Length = 255 // Packet Length Mode = Variable // RX Filter BW = 10.964912 // Symbol rate = 1.2 // Whitening = true static const cc1200_reg_settings_t NARROWBAND_SETTINGS[]= { {CC120X_IOCFG2, 0x06}, {CC120X_DEVIATION_M, 0xD1}, {CC120X_MODCFG_DEV_E, 0x00}, {CC120X_DCFILT_CFG, 0x5D}, {CC120X_PREAMBLE_CFG0, 0x8A}, {CC120X_IQIC, 0xCB}, {CC120X_CHAN_BW, 0xA6}, {CC120X_MDMCFG1, 0x40}, {CC120X_MDMCFG0, 0x05}, {CC120X_SYMBOL_RATE2, 0x3F}, {CC120X_SYMBOL_RATE1, 0x75}, {CC120X_SYMBOL_RATE0, 0x10}, {CC120X_AGC_REF, 0x20}, {CC120X_AGC_CS_THR, 0xEC}, {CC120X_AGC_CFG1, 0x51}, {CC120X_AGC_CFG0, 0x87}, {CC120X_FIFO_CFG, 0x00}, {CC120X_FS_CFG, 0x1B}, {CC120X_PKT_CFG2, 0x00}, {CC120X_PKT_CFG1, 0x43}, {CC120X_PKT_CFG0, 0x20}, {CC120X_PKT_LEN, 0xFF}, {CC120X_IF_MIX_CFG, 0x1C}, {CC120X_FREQOFF_CFG, 0x22}, {CC120X_MDMCFG2, 0x0C}, {CC120X_FREQ2, 0x56}, {CC120X_FREQ1, 0xA2}, {CC120X_FREQ0, 0x4C}, {CC120X_IF_ADC1, 0xEE}, {CC120X_IF_ADC0, 0x10}, {CC120X_FS_DIG1, 0x07}, {CC120X_FS_DIG0, 0xAF}, {CC120X_FS_CAL1, 0x40}, {CC120X_FS_CAL0, 0x0E}, {CC120X_FS_DIVTWO, 0x03}, {CC120X_FS_DSM0, 0x33}, {CC120X_FS_DVC0, 0x17}, {CC120X_FS_PFD, 0x00}, {CC120X_FS_PRE, 0x6E}, {CC120X_FS_REG_DIV_CML, 0x1C}, {CC120X_FS_SPARE, 0xAC}, {CC120X_FS_VCO0, 0xB5}, {CC120X_XOSC5, 0x0E}, {CC120X_XOSC1, 0x03}, };