From 1964c9f6c990dde20db364b687275d8d50416ff4 Mon Sep 17 00:00:00 2001 From: zhyinch <zhyinch@gmail.com> Date: 星期二, 14 四月 2020 23:15:25 +0800 Subject: [PATCH] V1.9 修改成串口距离信息整合输出 --- 源码/核心板/Src/stm32f10x_it.c | 123 ++++++++++++++++++++++++++++++---------- 1 files changed, 92 insertions(+), 31 deletions(-) diff --git "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/stm32f10x_it.c" "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/stm32f10x_it.c" index 03523c6..16657d7 100644 --- "a/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/stm32f10x_it.c" +++ "b/\346\272\220\347\240\201/\346\240\270\345\277\203\346\235\277/Src/stm32f10x_it.c" @@ -23,32 +23,88 @@ /* Includes ------------------------------------------------------------------*/ #include "stm32f10x_it.h" #include "stm32f10x.h" -#include "beep.h" - +#include "dw_app.h" +#include "global_param.h" +#include "beep_logic_app.h" +#include "led.h" +#include "Usart.h" +#include "dw_app.h" /* Tick timer count. */ volatile uint32_t time32_incr; +uint8_t tt=0; +uint8_t g_start_send_flag = 0,sync_seq=0,usart_timer=0; +uint16_t sysscal; +u16 tag_recv_timer, tag_timer; +extern uint16_t g_Resttimer,heartbeat_timer,sync_timer; +extern uint8_t g_pairstart; +u8 neartimout_timer=0; +extern u16 tyncpoll_time, checksum;; +extern u8 anc_report_num; +void TIM3_IRQHandler(void) //TIM3?? +{ + if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET) //??TIM3???????? + { + TIM_ClearITPendingBit(TIM3, TIM_IT_Update ); //??TIMx?????? + + time32_incr++; + heartbeat_timer++; + sync_timer++; + neartimout_timer++; + if(sync_timer>=1010) + {sync_timer=0;} + + if(g_Resttimer++>2000) + { + //NVIC_SystemReset(); + } -volatile uint32_t g_beep_on_time = 0; -volatile uint32_t g_beep_off_time = 0; + + + + if(!g_com_map[DEV_ROLE]) //基站 + { + tag_recv_timer++; + TagDistClear(); + if(g_com_map[ALARM_DEV]!=0) + main_logic(); + #ifdef USART_INTEGRATE_OUTPUT + if(usart_timer++>g_com_map[COM_INTERVAL]) + { + usart_timer=0; + usart_send[2] = anc_report_num;//正常模式 + checksum = Checksum_u16(&usart_send[2],anc_report_num*6+1); + memcpy(&usart_send[3+anc_report_num*6],&checksum,2); + UART_PushFrame(usart_send,5+anc_report_num*6); +anc_report_num=0; + } + #endif + if(sync_timer>500&&dev_id!=0) + { + sync_seq=0xff; + } + + if(sync_timer==0) + { + TagListUpdate(); + if(dev_id==0) + SyncPoll(0); + } + }else{ //标签同步处理 + if((sync_timer-10)%g_com_map[COM_INTERVAL]==tyncpoll_time&&sync_timer>=10) + { + GPIO_WriteBit(GPIOA, GPIO_Pin_9, Bit_SET); + g_start_send_flag=1; + } + + } + + } +} void SysTick_Handler(void) { - static uint32_t s_cycle_time = 0; - time32_incr++; -// if(s_cycle_time >= g_beep_off_time) -// { -// s_cycle_time = 0; -// } -// else if(s_cycle_time > g_beep_on_time && s_cycle_time < g_beep_off_time) -// { -// BEEP_OFF; -// } -// else if(s_cycle_time <= g_beep_on_time) -// { -// BEEP_ON; -// } - s_cycle_time++; + } /** @@ -62,18 +118,23 @@ } } -uint8_t tt=0; -uint8_t send_start=0; -void RTCAlarm_IRQHandler(void) + +void USART1_IRQHandler(void) { - EXTI_ClearITPendingBit(EXTI_Line17); - RTC_ClearITPendingBit(RTC_FLAG_ALR); - send_start=1; - RTC_SET_ALARM(1); - tt++; - //GPIO_Toggle(GPIOA,LED_PIN); - - //SYS.wake_id|=1<<17; + if(USART_GetITStatus(EXT_UART, USART_IT_RXNE) != RESET)//????????? + { + UART_CheckReceive(); + } + + + +// if(USART_GetITStatus(USARTy, USART_IT_TXE) != RESET) + +// { + +// USART_SendData(USARTy, TxBuffer1[TxCounter1++]); + +// } + } -/******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/ -- Gitblit v1.9.3