#include <math.h>
|
#include <string.h>
|
#include "sx126x.h"
|
#include "sx126x-board.h"
|
#include "delay.h"
|
#include "Lora.h"
|
#include "user.h"
|
#include "sx126x-board.h"
|
#include "string.h"
|
#include "stdio.h"
|
#include "delay.h"
|
#include "main.h"
|
static RadioEvents_t RadioEvents;
|
#define USE_MODEM_LORA
|
//#define USE_MODEM_FSK
|
#define REGION_CN779
|
uint32_t RxDutyCycle_RX_time =128;
|
uint32_t RxDutyCycle_SLEEP_time=256;
|
#if defined( REGION_AS923 )
|
|
#define RF_FREQUENCY 923000000 // Hz
|
|
#elif defined( REGION_AU915 )
|
|
#define RF_FREQUENCY 915000000 // Hz
|
|
#elif defined( REGION_CN779 )
|
|
#define RF_FREQUENCY 433000000 // Hz
|
#define RF_FREQUENCY_R 500000000 // Hz
|
#define RF_FREQUENCY_T 470200000 // Hz
|
|
|
#elif defined( REGION_EU868 )
|
|
#define RF_FREQUENCY 868000000 // Hz
|
|
#elif defined( REGION_KR920 )
|
|
#define RF_FREQUENCY 920000000 // Hz
|
|
#elif defined( REGION_IN865 )
|
|
#define RF_FREQUENCY 865000000 // Hz
|
|
#elif defined( REGION_US915 )
|
|
#define RF_FREQUENCY 915000000 // Hz
|
|
#elif defined( REGION_US915_HYBRID )
|
|
#define RF_FREQUENCY 915000000 // Hz
|
|
#else
|
|
#error "Please define a frequency band in the compiler 'options."
|
|
#endif
|
|
#define TX_OUTPUT_POWER 22 // 22 dBm
|
|
extern bool IrqFired;
|
|
|
|
|
//bool EnableMaster=true;//Ö÷Ñ¡Ôñ
|
bool EnableMaster=false;//´ÓÑ¡Ôñ
|
|
uint16_t crc_value;
|
/*!
|
* Radio events function pointer
|
*/
|
|
static RadioEvents_t RadioEvents;
|
|
#if defined( USE_MODEM_LORA )
|
|
#define LORA_BANDWIDTH 2 // [0: 125 kHz,
|
// 1: 250 kHz,
|
// 2: 500 kHz,
|
// 3: Reserved]
|
#define LORA_SPREADING_FACTOR 5 // [SF7..SF12]
|
#define LORA_CODINGRATE 1 // [1: 4/5,
|
// 2: 4/6,
|
// 3: 4/7,
|
// 4: 4/8]
|
#define LORA_PREAMBLE_LENGTH_T 10 // Same for Tx
|
#define LORA_PREAMBLE_LENGTH_R 64 // Same for Rx
|
//#define LORA_PREAMBLE_LENGTH 990 // Same for Tx and Rx
|
#define LORA_SYMBOL_TIMEOUT 0 // Symbols
|
#define LORA_FIX_LENGTH_PAYLOAD_ON false
|
#define LORA_IQ_INVERSION_ON_T false
|
#define LORA_IQ_INVERSION_ON_R false
|
|
|
#elif defined( USE_MODEM_FSK )
|
|
#define FSK_FDEV 5e3 // Hz
|
#define FSK_DATARATE 2.4e3 // bps
|
#define FSK_BANDWIDTH 20e3 // Hz >> DSB in sx126x
|
#define FSK_AFC_BANDWIDTH 100e3 // Hz
|
#define FSK_PREAMBLE_LENGTH 5 // Same for Tx and Rx
|
#define FSK_FIX_LENGTH_PAYLOAD_ON false
|
|
#else
|
#error "Please define a modem in the compiler options."
|
#endif
|
|
typedef enum
|
{
|
LOWPOWER,
|
RX,
|
RX_TIMEOUT,
|
RX_ERROR,
|
TX,
|
TX_TIMEOUT,
|
}States_t;
|
|
//#define RX_TIMEOUT_VALUE 1000
|
#define RX_TIMEOUT_VALUE 64000
|
#define BUFFER_SIZE 64 // Define the payload size here
|
|
const uint8_t PingMsg[] = "PING";
|
const uint8_t PongMsg[] = "PONG";
|
|
uint16_t BufferSize = BUFFER_SIZE;
|
uint8_t TX_Buffer[BUFFER_SIZE];
|
uint8_t RX_Buffer[BUFFER_SIZE];
|
|
|
States_t State = LOWPOWER;
|
|
int8_t RssiValue = 0;
|
int8_t SnrValue = 0;
|
void OnTxDone( void );
|
void OnRxDone( uint8_t *payload, uint16_t size, int16_t rssi, int8_t snr );
|
void OnTxTimeout( void );
|
void OnRxTimeout( void );
|
void OnRxError( void );
|
|
uint8_t Lora_rx_open_flag;
|
void LedToggle(void)
|
|
{
|
// HAL_GPIO_TogglePin(GPIOB, LED1_Pin);
|
}
|
|
void Lora_rx_open( void )
|
{
|
if(Lora_rx_open_flag==1)
|
{
|
Lora_Init();
|
Lora_rx_open_flag=0;
|
}
|
}
|
void OnTxDone( void )
|
{
|
Lora_rx_open_flag=1;
|
}
|
extern uint8_t frame_seq_nb2,rec_nearbase_num,ancidlist_num;
|
uint16_t RX_TIMEOUTs;
|
extern LPTIM_HandleTypeDef hlptim1;
|
uint16_t current_time,start_time,end_time;
|
void OnRxDone( uint8_t *payload, uint16_t size, int16_t rssi, int8_t snr )
|
{
|
BufferSize = size;
|
memcpy( RX_Buffer, payload, BufferSize );
|
RssiValue = rssi;
|
SnrValue = snr;
|
|
Radio.Standby();
|
{
|
// HAL_GPIO_WritePin(GPIOB, GPIO_PIN_2, GPIO_PIN_SET);
|
// Delay_Ms(10);
|
// HAL_GPIO_WritePin(GPIOB, GPIO_PIN_2, GPIO_PIN_RESET);
|
uint16_t i=0;
|
for(i=0;i<BufferSize;i++)
|
{printf("RXD %d:\r\n",RX_Buffer[i]);}
|
RX_TIMEOUTs++;
|
printf("RX_num :%d\r\n",RX_TIMEOUTs);
|
// start_time=HAL_LPTIM_ReadCounter(&hlptim1);
|
// end_time=start_time+((32768/1000)*20);
|
// if(end_time>=32768)
|
// {end_time-=32768;}
|
// current_time=HAL_LPTIM_ReadCounter(&hlptim1);
|
HAL_GPIO_WritePin(RADIO_NSS_GPIO_Port, RADIO_NSS_Pin, GPIO_PIN_SET);
|
// while(current_time<end_time||current_time>end_time+15000)
|
// {
|
// current_time=HAL_LPTIM_ReadCounter(&hlptim1);
|
Anchor_App();
|
// }
|
|
HAL_GPIO_WritePin(RADIO_NSS_GPIO_Port, RADIO_NSS_Pin, GPIO_PIN_RESET);
|
delay_ms(10);
|
|
Radio.SetChannel( 470200000 );
|
Radio.SetTxConfig( MODEM_LORA, TX_OUTPUT_POWER, 0, 0,
|
7, LORA_CODINGRATE,LORA_PREAMBLE_LENGTH_T, LORA_FIX_LENGTH_PAYLOAD_ON,
|
false, 0, 0, LORA_IQ_INVERSION_ON_T, 3000 );
|
|
Radio.Send( usart_send, 12+rec_nearbase_num*4);
|
// printf("RX_TIMEOUTs :%d\r\n",RX_TIMEOUTs);
|
// Radio.SetRxDutyCycle(RxDutyCycle_RX_time,RxDutyCycle_SLEEP_time);
|
// printf("RX_TIMEOUTs :XXXX\r\n");
|
// Radio.Rx( RX_TIMEOUT_VALUE );
|
// printf("Slave TXD XXXX\r\n");
|
|
}
|
}
|
|
void OnTxTimeout( void )
|
{
|
|
}
|
|
void OnRxTimeout( void )
|
{
|
Radio.Standby();
|
if(EnableMaster)
|
{
|
// TX_Buffer[0] = 'P';
|
// TX_Buffer[1] = 'I';
|
// TX_Buffer[2] = 'N';
|
// TX_Buffer[3] = 'G';
|
//
|
//// crc_value=RadioComputeCRC(TX_Buffer,4,CRC_TYPE_IBM);//¼ÆËãµÃ³öÒª·¢ËÍÊý¾Ý°üCRCÖµ
|
//// TX_Buffer[4]=crc_value>>8;
|
//// TX_Buffer[5]=crc_value;
|
// //Radio.Send( TX_Buffer, 6);
|
// Radio.Send( TX_Buffer, 4);
|
|
// HAL_GPIO_WritePin( OUT1_GPIO_Port, OUT1_Pin,GPIO_PIN_SET);
|
// HAL_Delay_nMS( 1 );
|
// HAL_GPIO_WritePin( OUT1_GPIO_Port, OUT1_Pin,GPIO_PIN_RESET);
|
printf("Master TXD PING!\r\n");
|
}
|
else
|
{
|
Radio.SetRxDutyCycle(RxDutyCycle_RX_time,RxDutyCycle_SLEEP_time);
|
// printf("slave OnRxTimeout\r\n");
|
|
// Radio.Rx( RX_TIMEOUT_VALUE );
|
printf("slave OnRxTimeout\r\n");
|
}
|
}
|
|
void OnRxError( void )
|
{
|
|
Radio.Standby();
|
if(EnableMaster)
|
{
|
TX_Buffer[0] = 'P';
|
TX_Buffer[1] = 'I';
|
TX_Buffer[2] = 'N';
|
TX_Buffer[3] = 'G';
|
|
// crc_value=RadioComputeCRC(TX_Buffer,4,CRC_TYPE_IBM);//¼ÆËãµÃ³öÒª·¢ËÍÊý¾Ý°üCRCÖµ
|
// TX_Buffer[4]=crc_value>>8;
|
// TX_Buffer[5]=crc_value;
|
//Radio.Send( TX_Buffer, 6);
|
Radio.Send( TX_Buffer, 4);
|
// HAL_GPIO_WritePin( OUT1_GPIO_Port, OUT1_Pin,GPIO_PIN_SET);
|
// HAL_Delay_nMS( 1 );
|
// HAL_GPIO_WritePin( OUT1_GPIO_Port, OUT1_Pin,GPIO_PIN_RESET);
|
printf("Master TXD PING!\r\n");
|
}
|
else
|
{
|
Radio.SetRxDutyCycle(RxDutyCycle_RX_time,RxDutyCycle_SLEEP_time);
|
printf("slave OnRxError\r\n");
|
// Radio.Rx( RX_TIMEOUT_VALUE );
|
|
}
|
|
}
|
|
|
|
//void T_R_Init(uint8_t kind)
|
//{
|
// Radio.Init( &RadioEvents );
|
// if(kind==1) //1:Txd config
|
// {
|
// Radio.SetChannel( RF_FREQUENCY );
|
// Radio.SetTxConfig( MODEM_LORA, TX_OUTPUT_POWER, 0, LORA_BANDWIDTH,
|
// LORA_SPREADING_FACTOR, LORA_CODINGRATE,
|
// LORA_PREAMBLE_LENGTH_T, LORA_FIX_LENGTH_PAYLOAD_ON,
|
// false, 0, 0, LORA_IQ_INVERSION_ON_T, 1000 );
|
|
// }
|
// else //0:Rxd config
|
// {
|
// Radio.SetChannel( RF_FREQUENCY );
|
// Radio.SetRxConfig( MODEM_LORA, LORA_BANDWIDTH, LORA_SPREADING_FACTOR,
|
// LORA_CODINGRATE, 0, LORA_PREAMBLE_LENGTH_R,
|
// LORA_SYMBOL_TIMEOUT, LORA_FIX_LENGTH_PAYLOAD_ON,
|
// 0, false, 0, 0, LORA_IQ_INVERSION_ON_R, false );
|
// }
|
//
|
//// Radio.SetTxConfig( MODEM_LORA, TX_OUTPUT_POWER, 0, LORA_BANDWIDTH,
|
//// LORA_SPREADING_FACTOR, LORA_CODINGRATE,
|
//// LORA_PREAMBLE_LENGTH_T, LORA_FIX_LENGTH_PAYLOAD_ON,
|
//// false, 0, 0, LORA_IQ_INVERSION_ON_T, 1000 );
|
|
//// Radio.SetRxConfig( MODEM_LORA, LORA_BANDWIDTH, LORA_SPREADING_FACTOR,
|
//// LORA_CODINGRATE, 0, LORA_PREAMBLE_LENGTH_R,
|
//// LORA_SYMBOL_TIMEOUT, LORA_FIX_LENGTH_PAYLOAD_ON,
|
//// 0, false, 0, 0, LORA_IQ_INVERSION_ON_R, false );
|
//}
|
|
void Lora_Init(void)
|
{
|
RadioEvents.TxDone = OnTxDone;
|
RadioEvents.RxDone = OnRxDone;
|
RadioEvents.TxTimeout = OnTxTimeout;
|
RadioEvents.RxTimeout = OnRxTimeout;
|
RadioEvents.RxError = OnRxError;
|
|
Radio.Init( &RadioEvents );
|
if(EnableMaster)
|
{
|
Radio.SetChannel( RF_FREQUENCY );
|
}
|
else
|
{
|
Radio.SetChannel( RF_FREQUENCY );
|
}
|
// Radio.SetStandby( STDBY_RC );
|
|
// Radio.SetTxConfig( MODEM_LORA, TX_OUTPUT_POWER, 0, LORA_BANDWIDTH,
|
// LORA_SPREADING_FACTOR, LORA_CODINGRATE,
|
// LORA_PREAMBLE_LENGTH, LORA_FIX_LENGTH_PAYLOAD_ON,
|
// true, 0, 0, LORA_IQ_INVERSION_ON, 3000 );
|
|
// Radio.SetTxConfig( MODEM_LORA, TX_OUTPUT_POWER, 0, LORA_BANDWIDTH,
|
// LORA_SPREADING_FACTOR, LORA_CODINGRATE,
|
// LORA_PREAMBLE_LENGTH_T, LORA_FIX_LENGTH_PAYLOAD_ON,
|
// false, 0, 0, LORA_IQ_INVERSION_ON_T, 1000 );
|
|
// Radio.SetRxConfig( MODEM_LORA, LORA_BANDWIDTH, LORA_SPREADING_FACTOR,
|
// LORA_CODINGRATE, 0, LORA_PREAMBLE_LENGTH,
|
// LORA_SYMBOL_TIMEOUT, LORA_FIX_LENGTH_PAYLOAD_ON,
|
// 0, true, 0, 0, LORA_IQ_INVERSION_ON, false );
|
|
Radio.SetRxConfig( MODEM_LORA, LORA_BANDWIDTH, LORA_SPREADING_FACTOR,
|
LORA_CODINGRATE, 0, LORA_PREAMBLE_LENGTH_R,
|
LORA_SYMBOL_TIMEOUT, LORA_FIX_LENGTH_PAYLOAD_ON,
|
0, false, 0, 0, LORA_IQ_INVERSION_ON_R, 1 );
|
// Radio.SetRxConfig( MODEM_LORA, LORA_BANDWIDTH, LORA_SPREADING_FACTOR,
|
// LORA_CODINGRATE, 0, LORA_PREAMBLE_LENGTH,
|
// LORA_SYMBOL_TIMEOUT, LORA_FIX_LENGTH_PAYLOAD_ON,
|
// 0, false, 0, 0, LORA_IQ_INVERSION_ON, true );
|
|
if(EnableMaster)
|
{
|
|
printf("I am Master!\r\n");
|
|
TX_Buffer[0] = 'P';
|
TX_Buffer[1] = 'I';
|
TX_Buffer[2] = 'N';
|
TX_Buffer[3] = 'G';
|
|
crc_value=RadioComputeCRC(TX_Buffer,4,CRC_TYPE_IBM);//¼ÆËãµÃ³öÒª·¢ËÍÊý¾Ý°üCRCÖµ
|
TX_Buffer[4]=crc_value>>8;
|
TX_Buffer[5]=crc_value;
|
//Radio.Send( TX_Buffer, 6);
|
Radio.Send( TX_Buffer, 4);
|
|
// HAL_GPIO_WritePin( OUT1_GPIO_Port, OUT1_Pin,GPIO_PIN_SET);
|
// HAL_Delay_nMS( 1 );
|
// HAL_GPIO_WritePin( OUT1_GPIO_Port, OUT1_Pin,GPIO_PIN_RESET);
|
|
printf("Master TXD PING!\r\n");
|
}
|
else
|
{
|
SX126xClearIrqStatus( IRQ_RADIO_ALL );
|
// SX126xSetDioIrqParams( IRQ_RX_DONE | IRQ_CRC_ERROR,
|
// IRQ_RX_DONE | IRQ_CRC_ERROR,
|
// IRQ_RADIO_NONE, IRQ_RADIO_NONE
|
// );
|
// SX126xSetDioIrqParams( IRQ_RADIO_ALL, //IRQ_RX_DONE | IRQ_RX_TX_TIMEOUT,
|
// IRQ_RADIO_ALL, //IRQ_RX_DONE | IRQ_RX_TX_TIMEOUT,
|
// IRQ_RADIO_NONE,
|
// IRQ_RADIO_NONE );
|
Radio.SetRxDutyCycle(RxDutyCycle_RX_time,RxDutyCycle_SLEEP_time);
|
// Radio.Rx( RX_TIMEOUT_VALUE );
|
// printf("I am Slave!\r\n");
|
}
|
|
}
|