From f34293f18e4fbfe4d0d025657d2bda505861066a Mon Sep 17 00:00:00 2001
From: chen <15335560115@163.com>
Date: 星期五, 15 八月 2025 19:51:53 +0800
Subject: [PATCH] 初步调好demo,升级未测试
---
keil/uwb_app.c | 632 ++++++++++++++++++++++++--------------------------------
1 files changed, 271 insertions(+), 361 deletions(-)
diff --git a/keil/uwb_app.c b/keil/uwb_app.c
index fadacac..8400434 100644
--- a/keil/uwb_app.c
+++ b/keil/uwb_app.c
@@ -5,14 +5,21 @@
#include "mk_power.h"
#include "mk_sleep_timer.h"
#include "lib_ranging.h"
+#include "lib_aoa.h"
#include "dw_app_anchor.h"
#include "global_param.h"
#include "board.h"
-
-
+#include "lib_aoa.h"
+#include <serial_at_cmd_app.h>
extern int simple_main(void);
extern int temp_main(void);
+void Calibration_Time(void);
void TagListUpdate(void);
+void TagListUpdate_person_num(void);
+void Uwb_init(void);
+void OpenUWB(void);
+void CloseUWB(void);
+int Anchor_App(void);
extern void IO_LED_control_change(uint8_t data);
extern void IO_control_init(void);
@@ -35,7 +42,7 @@
extern uint16_t tag_frequency;
extern uint16_t disoffset;
static uint8_t frame_len,recpoll_len,current_syncid,new_tagid,seize_anchor,result,g_start_sync_flag;
-extern uint8_t gps_power_state,motor_power_state,uwb_state,air780_power_state,gps_success_state,chaging_state,changed_state,air780_success_state;
+extern uint8_t gps_power_state,motor_power_state,uwb_state,air780_power_state,gps_success_state,red_charge_state,green_charge_state,air780_success_state;
int poll_rx_num,resp_tx_num;
//resp函数
void PushAnchorDataArray(uint16_t ancid,int16_t dist,uint8_t battary);//找到自己的id信息对应位置更新自己的交互信息
@@ -49,18 +56,29 @@
uint32_t temp_count1=0;
uint32_t temp_count2=0;
uint32_t temp_count3=0;
+uint32_t temp_count7=0;
uint32_t temp_internal=0;
+int16_t elevation = 0;
+int16_t azimuth = 0;
+uint8_t fom = 0;
int32_t distance;
uint8_t taglist_num;
+float *sts_rssi=NULL;
extern uint8_t recev_error_num;
-
+uint8_t uwb_rx_flag;
extern Operation_step UWB_work_state;
extern int16_t first_search_flag;
+typedef enum
+{
+ SEARCH,
+ CLOSE,
+ RANGE,
+}enumwltagstate;
/* Ranging period */
#define RANGING_PERIOD_MS (1000)
/* This is the delay from Frame RX POLL frame to send RESP Frame */
-#define POLL_RX_TO_RESP_TX_DLY_US 450U //yuan750 7500Haoyong
+#define POLL_RX_TO_RESP_TX_DLY_US 550U //yuan600 success 并且不卡busy
#define RESP_TX_TO_FINAL_RX_DLY_US 500U
@@ -79,7 +97,7 @@
/* RX window open in advance */
#define RX_WIN_IN_ADVANCE_US (150)
-#define DELAY_BETWEEN_TWO_FRAME_UUS 400
+#define DELAY_BETWEEN_TWO_FRAME_UUS 500 //yuan1400
/* Field index in frame */
#define MSG_SEQ_NUM_IDX 2
@@ -91,31 +109,35 @@
/* Length of the common part of the message */
#define MSG_COMMON_LEN 10
-#define UWB_DELAY_TIME_US 495
+#define UWB_DELAY_TIME_US 496
static uint8_t receive_flag=0;
struct mk_uwb_configure
{
uint8_t phy_work_mode; /* PHY_TX / PHY_RX / PHT_TX|PHY_RX */
struct UWB_CONFIG_T phy_cfg;
};
-
-/* Default communication configuration. */
+extern uint8_t uwb_ch;
static struct mk_uwb_configure config = {
.phy_work_mode = (uint8_t)(PHY_TX | PHY_RX),
.phy_cfg.ch_num = 5, /* Channel number. */
- .phy_cfg.code_index = 9, /* TX preamble code. */
- .phy_cfg.mean_prf = MEAN_PRF_64M, /* Data rate 6.8M */
- .phy_cfg.data_bit_rate = DATA_BR_6M8, /* data rate 6.8M. */
+ .phy_cfg.code_index = 9, /* TRX preamble code */
+ .phy_cfg.mean_prf = MEAN_PRF_64M, /* Mean prf 64/128/256M */
+ .phy_cfg.data_bit_rate = DATA_BR_6M8, /* Data rate 6.8M */
.phy_cfg.sync_sym = PREAM_LEN_128, /* Preamble duration, length of preamble 128 */
- .phy_cfg.sfd_sym = BPRF_NSFD2_8, /* Identifier for SFD sequence */
- .phy_cfg.ranging_bit = 1, /* ranging bit set. */
- .phy_cfg.trx_mode = TRX_MODE_15_4Z_BPRF, /* IEEE802.15.4z - BPRF mode */
+ .phy_cfg.sfd_sym = NON_STD_NSFD5_8, /* Identifier for SFD sequence */
+ .phy_cfg.ranging_bit = 1, /* ranging bit set 1 */
+ .phy_cfg.trx_mode = TRX_MODE_15_4A, /* IEEE802.15.4z - BPRF mode */
.phy_cfg.sts_pkt_cfg = STS_PKT_CFG_0, /* SP0 Frame */
.phy_cfg.sts_segnum = STS_SEGNUM_BPRF_1, /* Number of STS segments in the frame */
.phy_cfg.sts_seglen = STS_SEGLEN_BPRF_64, /* Number of symbols in an STS segment */
.phy_cfg.rx_ant_id = UWB_RX_ANT_3, /* UWB RX antenna port */
};
+
+static struct anchor_id_car{
+ uint16_t anchor_new_id;
+ uint16_t change_num;
+};
/* Buffer to store received frame */
/* Frames used in the ranging process
@@ -133,9 +155,6 @@
* - byte 14 - 17: response message reception timestamp.
* - byte 18 - 21: final message transmission timestamp.
*/
-static uint8_t rx_poll_msg[] = {0x41, 0x88, 0, 0x4D, 0x4B, 0x53, 0x45, 0x4D, 0x49, 0x02};
-static uint8_t tx_resp_msg[] = {0x41, 0x88, 0, 0x4D, 0x4B, 0x4D, 0x49, 0x53, 0x45, 0x03, 0x07};
-static uint8_t rx_final_msg[] = {0x41, 0x88, 0, 0x4D, 0x4B, 0x53, 0x45, 0x4D, 0x49, 0x04, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
/* Count value of phy counter when transmitting and receiving frames */
static uint32_t poll_rx_en_start_u32;
@@ -197,64 +216,31 @@
/* RX done process handler. */
int8_t rssi;
-static void rx_int_callback(struct MAC_HW_REPORT_T *rx_report)
-{
- // Power off radio
- power_off_radio();
+uint32_t range_timeout_us = 2000000;//yuan5000
+uint8_t flag_temp2,flag_temp1;
+uint16_t uwb_losttimer;
+uint16_t lorarec_tagid;
+extern uint8_t send_lora_data[250];
+uint8_t Lora_upanc_time;
+uint8_t update_tag_time;
+extern uint16_t mubiao_anchor_ID;
+uint8_t Lora_qingqiu_flag;
+extern uint16_t Lora_qingqiu_bao;
+//uint8_t shengji_flag;
+extern uint8_t Dtu_shengji_jindu[20];
+extern uint8_t shengji_flag;
- /** UWB RX success */
- if (rx_report->err_code == UWB_RX_OK)
- {
- /* Received data does not contain FCS */
- rx_length = rx_report->pkt_len;
- memcpy(rx_buf, rx_report->pkt_data, rx_length);
- memcpy(&rx_rpt, rx_report, sizeof(struct MAC_HW_REPORT_T));
- /* Calculate rx timestamp */
- temp_count= phy_timer_count_get();
- poll_rx_en_start_u32 = rx_rpt.timestamp - phy_shr_duration();
- poll_rx_ts_i64 = ranging_rx_time_correct(&rx_rpt);
- poll_rx_num++;
- rssi = rx_report->rssi;
- receive_flag=1;
- recev_error_num=0;
- }
- else
- {
- /* UWB_PLD_ERR payload error */
- /* UWB_PHR_ERR PHR error */
- /* UWB_SFD_ERR Sfd error */
- /* UWB_BD_ERR Preamble detection error */
- /* UWB_TO_ERR Receive timeout */
- /* UWB_STS_ERR STS error */
- memcpy(&rx_rpt, rx_report, sizeof(struct MAC_HW_REPORT_T));
- rx_length = 0;
-
- }
-}
-
-/* TX done process handler. */
-static void tx_int_callback(struct MAC_HW_REPORT_T *tx_report)
-{
- // Power off radio
- power_off_radio();
-
- /** UWB TX success */
- if (tx_report->err_code == UWB_TX_OK)
- {
- temp_count= phy_timer_count_get();
- temp_internal=temp_count;
- resp_tx_num++;
- //LOG_INFO(TRACE_MODULE_APP, "poll_rx_num is %d,resp_tx_num is %d\r\n",poll_rx_num,resp_tx_num);
- }
-}
uint32_t start_receive_count,end_receive_count,poll_timeout,current_count,temp_resp;
-static uint16_t anchordata_id[TAG_NUM_IN_SYS],anchordata_dist[TAG_NUM_IN_SYS];
+int16_t anchordata_id[TAG_NUM_IN_SYS],anchordata_dist[TAG_NUM_IN_SYS];
static uint8_t anchordata_bat[TAG_NUM_IN_SYS];
+static uint16_t anchordata_version[TAG_NUM_IN_SYS];
uint8_t anchordata_num = 0;
-static int32_t tagdist_list[TAG_NUM_IN_SYS];
+static int16_t tagdist_list[TAG_NUM_IN_SYS];
uint16_t random_time;
//anchor
int32_t hist_dist;
+int16_t temp_recdist_before_offset;
+int16_t dist_temp;
void PushAnchorDataArray(uint16_t ancid,int16_t dist,uint8_t battary)
{
uint8_t i;
@@ -272,17 +258,26 @@
anchordata_num++;
}
anchordata_id[i] = ancid;//与之通信的标签id存入当前表中
+ distance=dist*0.5+(int16_t)anchordata_dist[i]*0.5;
anchordata_dist[i] = dist;
anchordata_bat[i] = battary;
tagofflinetime[i]=0;//不断更新当前TAG对应离线时间
- if(dist>0)
- distance=dist*0.5+distance*0.5;
+ dist_temp=dist;
+// if(dist>0)
+
+// if(temp_recdist_before_offset!=0&&distance!=0x1ffff)
+// {
+// distance=dist*0.5+distance*0.5;
+// }else{
+// distance=dist;
+// }
+
}
uint16_t CmpTagInList(uint16_t tagid)
{ uint16_t i;
for(i=0; i<taglist_num; i++)
{
- if(memcmp(&tagid,&anchordata_id[i],2)==0)
+ if(memcmp(&tagid,&tagid_list[i],2)==0)
break;
}
if(i==taglist_num)
@@ -290,6 +285,29 @@
//tagofflinetime[i] = 0;
return i;
}
+
+uint16_t ExistInTagList(uint16_t tagid)
+{ uint16_t i;
+ for(i=0; i<taglist_num; i++)
+ {
+ if(memcmp(&tagid,&tagid_list[i],2)==0)
+ return 1;
+ }
+ return 0;
+}
+uint16_t CmpCarInExistList(uint16_t tagid)
+{ uint16_t i;
+ for(i=0; i<anchordata_num; i++)
+ {
+ if(memcmp(&tagid,&anchordata_id[i],2)==0)
+ break;
+ }
+ if(i==anchordata_num)
+ return anchordata_num;
+ //tagofflinetime[i] = 0;
+ return i;
+}
+
static void resp_msg_set_ts(uint8_t *ts_field, int64_t ts)
{
int i,ts2;
@@ -301,21 +319,75 @@
}
}
+//void TagListUpdate(void)
+//{
+// uint8_t i,j=0;
+// for(i=0; i<anchordata_num; i++)
+// {
+// if(tagofflinetime[i]++<QUIT_SLOT_TIME)
+// {
+// anchordata_id[j]=anchordata_id[i];
+// tagofflinetime[j++]=tagofflinetime[i];
+// }
+// }
+// anchordata_num=j;
+//}
void TagListUpdate(void)
{
- uint8_t i,j=0;
- for(i=0; i<anchordata_num; i++)
+uint16_t i,j=0,k=0;
+ for(i=0; i<taglist_num; i++)
{
- if(tagofflinetime[i]++<QUIT_SLOT_TIME)
+ if(tagofflinetime[i]++<TAG_KEEPTIMES)
{
- anchordata_id[j]=anchordata_id[i];
+ tagid_list[j]=tagid_list[i];
+ tagdist_list[j] = tagdist_list[i];
+ anchordata_bat[j]=anchordata_bat[i];//电量随之更新
+ anchordata_version[j]=anchordata_version[i];
tagofflinetime[j++]=tagofflinetime[i];
}
- }
- anchordata_num=j;
+ }
+ taglist_num=j;
}
+uint16_t g_com_receive_id;
+uint8_t cmd_flag,position;;
uint8_t Anchor_RecNearPoll(uint8_t ancrec_nearbasepos)//根据自己是否为新基站定制消息去发送,根据是否抢占判断
{
+ cmd_flag=0;
+ uint16_t checksum1 = 0;
+ for(uint8_t i=0; i<PWTAG_MAXGROUPNUM; i++)
+ {
+ if(pwtag.remain_time[i]!=0)
+ {
+ lorarec_tagid=g_com_receive_id;
+ if(pwtag.groupid[i][0]<=lorarec_tagid&&lorarec_tagid<=pwtag.groupid[i][1])
+ {
+ send_buffer[MSG_TYPE_IDX] = LORA_MSGTYPE_WGRESPTAG;
+ send_buffer[MSG_LENGTH] = 14;
+ memcpy(&send_buffer[SOURCE_ID_IDX],&dev_id,2);
+ memcpy(&send_buffer[DEST_ID_IDX],&lorarec_tagid,2);
+ send_buffer[RW_FLAG_IDX] = pwtag.duorxie[i];
+ send_buffer[WRITE_IDX_IDX] = pwtag.index[i];
+ memcpy(&send_buffer[WRITE_VALUE_IDX],pwtag.value[i],pwtag.len[i]);
+
+ checksum1=Checksum_u16(send_buffer,pwtag.len[i]+WRITE_VALUE_IDX);
+ memcpy(&send_buffer[pwtag.len[i]+WRITE_VALUE_IDX],&checksum1,2);
+ resp_tx_en_start_u32 = poll_rx_en_start_u32+US_TO_PHY_TIMER_COUNT(POLL_RX_TO_RESP_TX_DLY_US);
+ flag_temp2=uwb_tx(send_buffer, pwtag.len[i]+WRITE_VALUE_IDX+2,1 ,resp_tx_en_start_u32);//立即发送测试size大小
+ // temp_count1=phy_timer_count_get();
+ //while(mac_is_busy());
+ gpio_pin_clr(SCL_PIN);
+ cmd_flag=1;
+ if(send_buffer[RW_FLAG_IDX]==0x01)
+ {
+ delay_ms(100);
+ NVIC_SystemReset();
+ }
+ break;
+ }
+ }
+ }
+ if(cmd_flag==0)
+ {
temp_count2=poll_rx_en_start_u32;
memcpy(&send_buffer[GROUP_ID_IDX],&group_id,1);//组id
@@ -323,17 +395,20 @@
memcpy(&send_buffer[TAG_ID_IDX],&tag_id_recv,2);//接受者id
send_buffer[MESSAGE_TYPE_IDX]=MBX_RESPONSE;
- if(rec_nearbase_num == ancrec_nearbasepos)//抢占模式自己为新基站
- {
- random_time = (phy_timer_count_get()%1000);//多基站抢占一个位置时避免一个也收不到的情况就每一个随机错开几十uS
- //resp_tx_time = (poll_rx_ts+((random_time+rec_nearbase_num*20 + POLL_RX_TO_RESP_TX_DLY_UUS+ancrec_nearbasepos*DELAY_BETWEEN_TWO_FRAME_UUS) * UUS_TO_DWT_TIME)) >> 8;//计算Response发送时间T3。
- // (resp_tx_en_start_u32) is the moment when TX enable
- resp_tx_en_start_u32 = random_time+phy_timer_count_get()+ US_TO_PHY_TIMER_COUNT(POLL_RX_TO_RESP_TX_DLY_US)+rec_nearbase_num*US_TO_PHY_TIMER_COUNT(DELAY_BETWEEN_TWO_FRAME_UUS);//后面的需要根据已有基站数量进行更改,如果是抢占自己最后一个回复,要有底数
- } else {
- //resp_tx_time = (poll_rx_ts + ((rec_nearbase_num*20+POLL_RX_TO_RESP_TX_DLY_UUS+ancrec_nearbasepos*DELAY_BETWEEN_TWO_FRAME_UUS) * UUS_TO_DWT_TIME)) >> 8;//计算Response发送时间T3。
- resp_tx_en_start_u32 = phy_timer_count_get() + US_TO_PHY_TIMER_COUNT(POLL_RX_TO_RESP_TX_DLY_US)+(ancrec_nearbasepos+1)*US_TO_PHY_TIMER_COUNT(DELAY_BETWEEN_TWO_FRAME_UUS);//后面的需要根据已有基站数量进行更改,自己非抢占
- }//此处设置绝对时间将poll u32改为phy_timer_count_get()
-
+// if(rec_nearbase_num == ancrec_nearbasepos)//抢占模式自己为新基站
+// {
+// random_time = (phy_timer_count_get()%100);//多基站抢占一个位置时避免一个也收不到的情况就每一个随机错开几十uS
+// //resp_tx_time = (poll_rx_ts+((random_time+rec_nearbase_num*20 + POLL_RX_TO_RESP_TX_DLY_UUS+ancrec_nearbasepos*DELAY_BETWEEN_TWO_FRAME_UUS) * UUS_TO_DWT_TIME)) >> 8;//计算Response发送时间T3。
+// // (resp_tx_en_start_u32) is the moment when TX enable
+// resp_tx_en_start_u32 = phy_timer_count_get()+US_TO_PHY_TIMER_COUNT(20*rec_nearbase_num+POLL_RX_TO_RESP_TX_DLY_US+rec_nearbase_num*DELAY_BETWEEN_TWO_FRAME_UUS);//后面的需要根据已有基站数量进行更改,如果是抢占自己最后一个回复,要有底数
+//
+// } else {
+// //resp_tx_time = (poll_rx_ts + ((rec_nearbase_num*20+POLL_RX_TO_RESP_TX_DLY_UUS+ancrec_nearbasepos*DELAY_BETWEEN_TWO_FRAME_UUS) * UUS_TO_DWT_TIME)) >> 8;//计算Response发送时间T3。
+// resp_tx_en_start_u32 = phy_timer_count_get()+US_TO_PHY_TIMER_COUNT(20*rec_nearbase_num+POLL_RX_TO_RESP_TX_DLY_US+ancrec_nearbasepos*DELAY_BETWEEN_TWO_FRAME_UUS);//后面的需要根据已有基站数量进行更改,如果是抢占自己最后一个回复,要有底数
+// //这里应该有问题问一下钟工
+// }//此处设置绝对时间将poll u32改为phy_timer_count_get()
+ position=ancrec_nearbasepos;
+ resp_tx_en_start_u32 = poll_rx_en_start_u32+US_TO_PHY_TIMER_COUNT(POLL_RX_TO_RESP_TX_DLY_US)+ancrec_nearbasepos*US_TO_PHY_TIMER_COUNT(DELAY_BETWEEN_TWO_FRAME_UUS);//加入帧间隔
resp_tx_ts_i64 = ranging_tx_time_correct(resp_tx_en_start_u32 + phy_shr_duration());//修正时间戳
/* Write all timestamps in the final message. See NOTE 8 below. */
resp_msg_set_ts(&send_buffer[RESP_MSG_POLL_RX_TS_IDX], poll_rx_ts_i64);
@@ -341,301 +416,136 @@
memcpy(&send_buffer[RESP_MSG_ANC_DISTOFFSET],&disoffset,2);//差个修正offset,修正有符号但是这个com表为无符号的,传过去直接赋给Int16_t相当于还原了
temp_resp_i64=resp_tx_ts_i64;
temp_count3= phy_timer_count_get();
- uwb_tx(send_buffer, 40,1 ,resp_tx_en_start_u32);//立即发送测试size大小
- temp_count1=phy_timer_count_get();
- while(mac_is_busy());
-// gpio_pin_clr(SCL_PIN);
-}
-uint16_t uwb_searchcount,uwb_timer_reload_value = 496;
-uint8_t range_success;
-uint32_t delay_time;
-extern uint8_t g_start_send_flag,search_open_flag = 1,link_success_flag;
-int UwbRange(void)
-{
- uint8_t i;
- uint16_t tempid;
- // The following peripherals will be initialized in the uwb_open function
- // phy/mac/aes/lsp/phy timers initialized
- uwb_open();
-
-// // Set calibration parameters
-// uwb_calibration_params_set(config.phy_cfg.ch_num);
-
-// // set advanced parameters
-// struct PHY_ADV_CONFIG_T adv_config = {
-// .thres_fap_detect = 40,
-// .nth_scale_factor = 4,
-// .ranging_performance_mode = 0,
-// .skip_weakest_port_en = 0,
-// };
-// phy_adv_params_configure(&adv_config);
-
-// // uwb configure
-// uwb_configure(config.phy_work_mode, board_param.tx_power_fcc[CALIB_CH(config.phy_cfg.ch_num)], &config.phy_cfg);
-
-// ranging_frame_type_set(config.phy_cfg.sts_pkt_cfg);
-
- // Register rx interrupt callback function
- mac_register_process_handler(tx_int_callback, rx_int_callback);
- range_success = 0;
- receive_flag = 0;
- temp_count3=phy_timer_count_get();
-// gpio_pin_set(SCL_PIN);
- uwb_rx(0, 0, RX_SYNC_WIN_US);//开启接收
- temp_count2=phy_timer_count_get();
- start_receive_count=phy_timer_count_get();
- poll_timeout=US_TO_PHY_TIMER_COUNT(5000);//多一个多0.4ms默认0.4ms计算为0.125*4*100000,默认开启1mss
- end_receive_count=start_receive_count+poll_timeout;
- if(end_receive_count>=UINT32_MAX)
- {
- end_receive_count-=UINT32_MAX;
+ flag_temp2=uwb_tx(send_buffer, 40,1 ,resp_tx_en_start_u32);//立即发送测试size大小
+ tagofflinetime[taglist_pos] = 0;//更新标签通信
+// temp_count1=phy_timer_count_get();
+ //while(mac_is_busy());
+ //gpio_pin_clr(SCL_PIN);
}
- current_count=phy_timer_count_get();
- while(current_count<end_receive_count||current_count>end_receive_count+HALF_SECOND_TIME)//循环接受包体,若为124.8K则是+62400000
+
+}
+
+uint16_t uwb_searchcount;
+uint8_t flag_recsuccess;
+
+uint32_t start_receive_count_calibration;
+uint32_t current_count_calibration;
+uint32_t get_in_num,get_out_num;
+struct anchor_id_car anchor_id_in_car[TAG_NUM_IN_SYS],anchor_id_out_car[TAG_NUM_IN_SYS];
+int16_t change_count[TAG_NUM_IN_SYS];
+uint16_t anchor_id_in[TAG_NUM_IN_SYS],anchor_id_out[TAG_NUM_IN_SYS];
+uint8_t secondtask_search_count,secondtask_search_flag;
+extern uint8_t g_start_send_flag,search_open_flag = 1,link_success_flag,flag_secondtask;
+enumwltagstate wltag_state=RANGE;
+uint32_t wltag_statetimer,wltag_uwbtimer;
+uint32_t uwbtasktimer=0,uwbtagsendtimer=0;
+void UWBOneSecondTask(void)
+{
+ uwb_losttimer++;
+ TagListUpdate();
+ if(uwb_losttimer>g_com_map[UWB_RNAGE_TIME])
+ uwb_losttimer=g_com_map[UWB_RNAGE_TIME]+1;//防止溢出
+}
+uint8_t uwbsend[100];
+
+void UWBIdleTask(void)
+{
+
+ if(HIDO_TimerGetTick()-uwbtasktimer >=1)
+ {
+
+ for(uint16_t i=0;i<taglist_num-1;i++)
{
- current_count=phy_timer_count_get();
- while(mac_is_busy())
+ for(uint16_t j=0;j<taglist_num-1-i;j++)
{
- current_count=phy_timer_count_get();
- if(current_count>end_receive_count&¤t_count<end_receive_count+HALF_SECOND_TIME)
+ if(tagdist_list[j]>tagdist_list[j+1])
{
- break;
+ uint16_t id,dist,version;
+ uint8_t bat;
+ id = tagid_list[j];
+ dist = tagdist_list[j];
+ version = anchordata_version[j];
+ tagid_list[j] = tagid_list[j+1];
+ tagdist_list[j] = tagdist_list[j+1];
+ anchordata_version[j] = anchordata_version[j+1];
+ tagid_list[j+1] = id;
+ tagdist_list[j+1] = dist;
+ anchordata_version[j+1] = version;
}
}
- if(receive_flag==1)//成功接收
- {
- if(group_id==rx_buf[GROUP_ID_IDX]&&rx_buf[MESSAGE_TYPE_IDX] == MBX_POLL&&!memcmp(&rx_buf[TAG_ID_IDX],&g_com_map[BIND_DEV_ID],2))//判断是否是和自己是同一组通讯的且为poll包
- { temp_count2=phy_timer_count_get();
- frame_seq_nb2 = rx_buf[SEQUENCE_IDX];//获取包序
- battary = rx_buf[BATTARY_IDX];
- rec_nearbase_num=rx_buf[FZ_NEARBASENUM_INDEX]; //标签传过来的他与基站交互的基站id数目
- memcpy(&tag_id_recv,&rx_buf[TAG_ID_IDX],2);
- memcpy(rec_ancidlist,&rx_buf[FZ_NEARBASEID_INDEX],2*rec_nearbase_num);
- memcpy(rec_ancdistlist,&rx_buf[FZ_NEARBASEID_INDEX+2*rec_nearbase_num],2*rec_nearbase_num);
- memcpy(&rec_antdelay,&rx_buf[FZ_NEARBASEID_INDEX+rec_nearbase_num*4],2);
- for(i=0; i<rec_nearbase_num; i++)
- {
- if(rec_ancidlist[i] == dev_id)
- {
- rec_ancdistlist[i]+=(int16_t)g_com_map[DIST_OFFSET];
- PushAnchorDataArray(tag_id_recv,rec_ancdistlist[i],battary);
- }
- }
- for(i=0; i<rec_nearbase_num; i++)
- {
- memcpy(&tempid,&rx_buf[FZ_NEARBASEID_INDEX+i*2],2);
- if(tempid==dev_id)//也是比id如果有就更新没有就抢占
- {
- seize_anchor=0; //非抢占。已存在列表中
- Anchor_RecNearPoll(i);
- break;
- }
- }
-
- if(i==rec_nearbase_num)
- {
- seize_anchor=1; //抢占anchor
- Anchor_RecNearPoll(i);
-
- }
- range_success = 1;
- sleep_timer_start(__MS_TO_32K_CNT(uwb_timer_reload_value));//测试
-
- // gpio_pin_clr(SCL_PIN);
- delay_time = (current_count-start_receive_count)>>7;
-
- LOG_INFO(TRACE_MODULE_APP,"标签ID:%X,距离: %d 信号强度:%d. 等待时间%d\r\n",g_com_map[BIND_DEV_ID],distance,rssi,delay_time);
- break;
- }
- } else {
- uwb_rx(0, 0, RX_SYNC_WIN_US);//再次开启接收
- }
+
}
- if(!range_success)
- {
- sleep_timer_start(__MS_TO_32K_CNT(UWB_DELAY_TIME_US-4));//测试
- LOG_INFO(TRACE_MODULE_APP,"测距失败,计数:%d\r\n",recev_error_num);
- if(recev_error_num++>5)
+
+ if(taglist_num>6)
{
- recev_error_num=0;
- UWB_work_state=SEARCH_DEV;
- uwb_searchcount = 0;
- search_open_flag = 1;
+ taglist_num=6;
}
- }
-
+ uwbtasktimer = HIDO_TimerGetTick();
+ UWBOneSecondTask();
+ uwbsend[0]=0x55;
+ uwbsend[1]=0xaa;
+ uwbsend[2]=0x40;
+ uwbsend[3]=taglist_num;
+ memcpy(&uwbsend[4],&tagid_list,taglist_num*2);
+ memcpy(&uwbsend[4+taglist_num*2],&tagdist_list,taglist_num*2);
+ memcpy(&uwbsend[4+taglist_num*4],&anchordata_version,taglist_num*2);
+ uart_send(UART_ID0, uwbsend,taglist_num*6+4, NULL);
+ taglist_num=0;
+// for(int i=0;i<anchordata_num;i++)
+// {
+// LOG_INFO(TRACE_MODULE_APP,"当前测距基站ID:%x,距离:%d.\r\n",tagid_list[0],tagdist_list[0]);
+// }
+ }
}
-
-
-//主函数绑定接受逻辑
-int UwbSearch(void)
+int uwb_app_poll(void)
{
-
- uint8_t i;
- uint16_t tempid;
- // The following peripherals will be initialized in the uwb_open function
- // phy/mac/aes/lsp/phy timers initialized
- uwb_open();
-
+ UWBIdleTask();
+}
+void Uwb_init(void)
+{
+ uwb_open();
+ #ifdef STS_MODE
+ // Set STS key and IV
+ phy_sts_key_configure(&sts_iv_key);
+
+ // which RX ports will be used for AoA/PDoA
+ phy_rx_ant_mode_set(RX_ANT_PORTS_COMBINATION);
+ #endif
// Set calibration parameters
+// config.phy_cfg.ch_num=g_com_map[NEARBASE_ID1];
uwb_calibration_params_set(config.phy_cfg.ch_num);
-
- // set advanced parameters
+ #ifndef STS_MODE
+ // set advanced parameters
struct PHY_ADV_CONFIG_T adv_config = {
.thres_fap_detect = 40,
.nth_scale_factor = 4,
.ranging_performance_mode = 0,
.skip_weakest_port_en = 0,
};
+ #else
+ // set advanced parameters
+ struct PHY_ADV_CONFIG_T adv_config = {
+ .thres_fap_detect = 40,
+ .nth_scale_factor = 4,
+ .ranging_performance_mode = 0,
+ .skip_weakest_port_en = 0,
+ };
+ #endif
phy_adv_params_configure(&adv_config);
// uwb configure
uwb_configure(config.phy_work_mode, board_param.tx_power_fcc[CALIB_CH(config.phy_cfg.ch_num)], &config.phy_cfg);
-
+ #if (defined STS_MODE) || (defined MK_MODE)
+ ranging_lib_init();
+ #endif
ranging_frame_type_set(config.phy_cfg.sts_pkt_cfg);
+ #ifdef STS_MODE
+ aoa_aux_info_set(AOA_AUX_ANT_IQ_RSSI_PDOA_AOA_FOM);
+ aoa_steering_vector_set((const float *)((uint32_t)((config.phy_cfg.ch_num == 9) ? svec_ch9_ptr : svec_ch5_ptr) | SRAM_BASE));
- // Register rx interrupt callback function
- mac_register_process_handler(tx_int_callback, rx_int_callback);
- receive_flag = 0;
- temp_count3=phy_timer_count_get();
-// gpio_pin_set(SCL_PIN);
- uwb_rx(0, 0, RX_SYNC_WIN_US_TEMP);//开启接收
- start_receive_count=phy_timer_count_get();
- poll_timeout=US_TO_PHY_TIMER_COUNT(2000000);//多一个多0.4ms默认0.4ms计算为0.125*4*100000,默认开启1mss
- end_receive_count=start_receive_count+poll_timeout;
- if(end_receive_count>=UINT32_MAX)
- {
- end_receive_count-=UINT32_MAX;
- }
- current_count=phy_timer_count_get();
- while(current_count<end_receive_count||current_count>end_receive_count+HALF_SECOND_TIME)//循环接受包体,若为124.8K则是+62400000
- {
- while(mac_is_busy())
- {
- IdleTask();
- current_count=phy_timer_count_get();
- if(current_count>end_receive_count&¤t_count<end_receive_count+HALF_SECOND_TIME)
- {
- break;
- }
- }
-
- temp_count2=phy_timer_count_get();
- if(receive_flag==1)//成功接收
- {
- if(group_id==rx_buf[GROUP_ID_IDX]&&rx_buf[MESSAGE_TYPE_IDX] == MBX_POLL&&!memcmp(&rx_buf[TAG_ID_IDX],&g_com_map[BIND_DEV_ID],2))//判断是否是和自己是同一组通讯的且为poll包
- { temp_count2=phy_timer_count_get();
- frame_seq_nb2 = rx_buf[SEQUENCE_IDX];//获取包序
- battary = rx_buf[BATTARY_IDX];
- rec_nearbase_num=rx_buf[FZ_NEARBASENUM_INDEX]; //标签传过来的他与基站交互的基站id数目
- memcpy(&tag_id_recv,&rx_buf[TAG_ID_IDX],2);
- memcpy(rec_ancidlist,&rx_buf[FZ_NEARBASEID_INDEX],2*rec_nearbase_num);
- memcpy(rec_ancdistlist,&rx_buf[FZ_NEARBASEID_INDEX+2*rec_nearbase_num],2*rec_nearbase_num);
- memcpy(&rec_antdelay,&rx_buf[FZ_NEARBASEID_INDEX+rec_nearbase_num*4],2);
- for(i=0; i<rec_nearbase_num; i++)
- {
- if(rec_ancidlist[i] == dev_id)
- {
- PushAnchorDataArray(tag_id_recv,rec_ancdistlist[i],battary);
- }
- }
- for(i=0; i<rec_nearbase_num; i++)
- {
- memcpy(&tempid,&rx_buf[FZ_NEARBASEID_INDEX+i*2],2);
- if(tempid==dev_id)//也是比id如果有就更新没有就抢占
- {
- seize_anchor=0; //非抢占。已存在列表中
- Anchor_RecNearPoll(i);
- break;
- }
- }
-
- if(i==rec_nearbase_num)
- {
- seize_anchor=1; //抢占anchor
- Anchor_RecNearPoll(i);
- }
- sleep_timer_start(__MS_TO_32K_CNT(UWB_DELAY_TIME_US));//测试
-// gpio_pin_clr(SCL_PIN);//测试
- return 1;//返回发送成功标志
- }
-
- }
-
- uwb_rx(0, 0, RX_SYNC_WIN_US_TEMP);//再次开启接收
-
- }
- // LOG_INFO(TRACE_MODULE_APP,"超时定时器:%x,%x,%x\r\n",start_receive_count,end_receive_count,current_count);
-// gpio_pin_clr(SCL_PIN);//测试
- return 0;//返回绑定失败标志
+ aoa_param_config();
+
+ phy_rx_sts_switch_mode_set(config.phy_cfg.sts_pkt_cfg, STS_SWITCH_EVERY_4SYM, 0, 0);
+ #endif
+// mac_register_process_handler(tx_int_callback, rx_int_callback);//初始化回调
}
-//}
-
-#define SEARCH_TIMESTEMP 120
-void UWBPoll(void)
-{
- switch(UWB_work_state)
- {
- case LINK_SUCCESS:
- { //连接成功进行轮询测距
-
- uwb_led_on();
- UwbRange();
- uwb_led_off();
-
- }
- break;
- case SEARCH_DEV:
- { //接包不成功或者通讯失败进入搜索模式
- if(search_open_flag)
- {
- LOG_INFO(TRACE_MODULE_APP,"开启搜索\r\n");
- search_open_flag=0;
- uwb_led_on();
- link_success_flag=UwbSearch();//第一次开启接收2s绑定失败后则进行下面1分钟后重新开启2s绑定流程
- uwb_led_off();
- if(link_success_flag)
- UWB_work_state=LINK_SUCCESS;
- }else{
- LOG_INFO(TRACE_MODULE_APP,"等待进入搜索模式:%d\r\n",SEARCH_TIMESTEMP-uwb_searchcount);
- }
-
- }
- break;
- case UN_BIND:
- {
- uwb_led_off();//关闭uwb指示灯
- }
- break;
- }
- if(UWB_work_state==LINK_SUCCESS)
- { //成功时清0错误计数
- uwb_searchcount=0;
- }
- if(UWB_work_state==SEARCH_DEV)
- {
- if(!search_open_flag)
- {
- if(uwb_searchcount++>SEARCH_TIMESTEMP)
- {
- uwb_searchcount=0;
- search_open_flag=1;
- }
- }
- //link_error_count+=g_com_map[COM_INTERVAL];
- //if(link_error_count>=g_com_map[4G_INTERNAL])
- //link_error_count=0;
- update_led_power_state();//更新灯状态
- }
- LOG_INFO(TRACE_MODULE_APP,"UWB状态:%d\r\n",UWB_work_state);
-}
-
-uint8_t GetUWBBindState(void)
-{
- if(UWB_work_state == UN_BIND)
- {
- return 0;
- }
- return 1;
-}
-
--
Gitblit v1.9.3