/* This project 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. Multiprotocol 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 along with Multiprotocol. If not, see . */ #if defined(E016H_CC2500_INO) #include "iface_nrf250k.h" #define FORCE_E016H_ORIGINAL_ID #define E016H_INITIAL_WAIT 500 #define E016H_PACKET_PERIOD 10000 #define E016H_RF_BIND_CHANNEL 5 #define E016H_PAYLOAD_SIZE 11 #define E016H_BIND_COUNT 300 //3sec static void __attribute__((unused)) E016H_send_packet() { packet[0 ] = rx_tx_addr[0]; if(IS_BIND_IN_PROGRESS) { packet[1 ] = 0x02; if(bind_counter) bind_counter--; else { BIND_DONE; XN297L_RFChannel(hopping_frequency_no); // Set main channel } } else packet[1 ] = 0x20; packet[2 ] = rx_tx_addr[2]; packet[3 ] = rx_tx_addr[3]; //channels TREA uint8_t channel; if(IS_BIND_IN_PROGRESS) channel=0x64; // Throttle must be centered during bind else channel=convert_channel_8b_limit_deadband(THROTTLE,0x00,0x64,0xC8, 160); packet[4 ] = channel; channel=convert_channel_16b_limit(RUDDER,0x00,0xC8); packet[5 ] = channel; channel=convert_channel_16b_limit(ELEVATOR,0x00,0xC8); packet[6 ] = channel; channel=convert_channel_16b_limit(AILERON,0x00,0xC8); packet[7 ] = channel; //flags packet[8 ] = GET_FLAG(CH7_SW, 0x01) // 0x01=Flip | GET_FLAG(CH8_SW, 0x02) // 0x02=Headless | GET_FLAG(CH9_SW, 0x04); // 0x04=One Key Return packet[9 ] = 0x02; // Speed control 0x00:low, 0x01:medium, 0x02:high packet[10] = GET_FLAG(CH5_SW, 0x01) // 0x01=TakeOff/Land (momentary switch) | GET_FLAG(CH6_SW, 0x04); // 0x04=Emergeny Stop (momentary switch) if(option==0) option=1; // Select the CC2500 XN297L_SetPower(); // Set tx_power XN297L_SetFreqOffset(); // Set frequency offset //Build real packet and send it static uint8_t pid=0; crc=0; // stop TX/RX CC2500_Strobe(CC2500_SIDLE); // flush tx FIFO CC2500_Strobe(CC2500_SFTX); // packet length CC2500_WriteReg(CC2500_3F_TXFIFO, 6 + 4 + 1 + 11 + 2); // preamble + address + packet_control + payload + crc // preamble+address CC2500_WriteRegisterMulti(CC2500_3F_TXFIFO, (uint8_t*)"\xAA\xAA\xAA\xAA\xAA\xAA\xE7\xE7\xE7\xE7", 10); // packet control CC2500_WriteReg(CC2500_3F_TXFIFO, 0x50+(pid<<2)); pid++; // payload debug("P:") for (uint8_t i = 0; i < E016H_PAYLOAD_SIZE; ++i) { uint8_t byte = (bit_reverse(packet[i])<<1) | (packet[i+1]&0x01); debug(" %02X",byte) CC2500_WriteReg(CC2500_3F_TXFIFO,byte); crc=crc16_update(crc, byte, 8); } // crc CC2500_WriteReg(CC2500_3F_TXFIFO,crc >> 8); CC2500_WriteReg(CC2500_3F_TXFIFO,crc); debugln(" %04X",crc) // transmit CC2500_Strobe(CC2500_STX); } uint16_t E016H_callback() { E016H_send_packet(); return E016H_PACKET_PERIOD; } static void __attribute__((unused)) E016H_initialize_txid() { //need to figure out ID&Freq #ifdef FORCE_E016H_ORIGINAL_ID rx_tx_addr[0]=0x0A; rx_tx_addr[1]=0x02; // not used in the code rx_tx_addr[2]=0x27; rx_tx_addr[3]=0x1B; hopping_frequency_no = 44; #endif } uint16_t initE016H() { //Config CC2500 if(option==0) option=1; // Select the CC2500 XN297L_Init(); XN297L_RFChannel(E016H_RF_BIND_CHANNEL); // Set bind channel E016H_initialize_txid(); bind_counter = E016H_BIND_COUNT; BIND_IN_PROGRESS; // Autobind protocol return E016H_INITIAL_WAIT; } #endif