From 6e3f1f560d618b37ee1a47fa2b0f682b70c3ef1c Mon Sep 17 00:00:00 2001
From: jinlicong <493886250@qq.com>
Date: Wed, 19 Jun 2024 17:25:45 +0800
Subject: [PATCH] 增加OTA协议

---
 Soft/system_run_fun.c |   49 ++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 36 insertions(+), 13 deletions(-)

diff --git a/Soft/system_run_fun.c b/Soft/system_run_fun.c
index bd77ad4..1fda93f 100644
--- a/Soft/system_run_fun.c
+++ b/Soft/system_run_fun.c
@@ -12,6 +12,7 @@
 #include "pulse_and_alarm_line.h"
 #include "valve_control.h"
 #include "linked_list.h"
+#include "sizhu_history_record.h"
 
 
 RS485_START_REASON	start_rs485_g = RS485_START_REASON_NONE;
@@ -35,6 +36,8 @@
 	Pulse_And_Alarm_Line_IO_Init();
 	
 	RS485_read_data_GPIO_Init();
+	
+	WRC_PWR_GPIO_Init(); //����Զ����Դ����IO
 }
 
 //����������������
@@ -67,13 +70,16 @@
 	CMU_OPCCR1_EXTICKE_Setable(ENABLE);			//EXTI����ʱ��ʹ��
 
 	GPIO_EXTI_Init( EXT_RTC_INT_PORT, EXT_RTC_INT_PIN, EXTI_FALLING, ENABLE);
+	
 	GPIO_EXTI_Init( KEY1_PORT, KEY1_PIN, EXTI_FALLING, ENABLE);
-	GPIO_EXTI_Init( KEY2_PORT, KEY2_PIN, EXTI_FALLING, ENABLE);
-	GPIO_EXTI_Init( KEY3_PORT, KEY3_PIN, EXTI_FALLING, ENABLE);
-	GPIO_EXTI_Init( KEY4_PORT, KEY4_PIN, EXTI_FALLING, ENABLE);
+//	GPIO_EXTI_Init( KEY2_PORT, KEY2_PIN, EXTI_FALLING, ENABLE);
+//	GPIO_EXTI_Init( KEY3_PORT, KEY3_PIN, EXTI_FALLING, ENABLE);
+//	GPIO_EXTI_Init( KEY4_PORT, KEY4_PIN, EXTI_FALLING, ENABLE);
 	
 	GPIO_EXTI_Init( LITH_PWR_LOSE_PORT, LITH_PWR_LOSE_PIN, EXTI_FALLING, ENABLE);
-	GPIO_EXTI_Init( ALKA_PWR_LOSE_PORT, ALKA_PWR_LOSE_PIN, EXTI_FALLING, ENABLE);
+//	GPIO_EXTI_Init( ALKA_PWR_LOSE_PORT, ALKA_PWR_LOSE_PIN, EXTI_FALLING, ENABLE);
+	
+	GPIO_EXTI_Init( LIMIT_TRIGGER_PORT, LIMIT_TRIGGER_PIN, EXTI_FALLING, ENABLE);
 	
 	/*�������ж�����ѡ��,û���������ҿ���������*/
 	if(((flow_meter_para_g.broken_line_multiplex & BROKEN_LINE_MUTIPLEX_PULSE)!=BROKEN_LINE_MUTIPLEX_PULSE)&&   \
@@ -100,8 +106,14 @@
 	SYSTEM_EEP_IDENTIFICATION_T		sys_eep_id_A_l={0};
 	SYSTEM_EEP_IDENTIFICATION_T		sys_eep_id_B_l={0};
 	uint8_t 	eep_none_flag = 1; //0����գ���0����ǿ�
+	uint8_t	buf_test[10];
+	
+	//?�������
+//	EEPROM_test();
+	
 	
 	EEPROM_CTRL_ENABLE;
+
 	//��ȡ������ʼ�����ñ�ʶ 
 	//�����ʶ�޷�ʶ�������洢��Ҫȫ��д��Ĭ��ֵ
 	//�����ʶʶ��ɹ��������в���������ֱ�ӴӴ洢�����ȡ
@@ -152,7 +164,7 @@
 	system_status_word_g.status_word.valve_lock = (save_valve_para_g.valve_lock_state == VL_LOCK)?1:0;
 	system_status_word_g.status_word.virtual_billing = (system_function_ctrl_word_g.fun_ctrl_word.virtual_billing == 1)?1:0;
 	system_status_word_g.status_word.billing_type = system_function_ctrl_word_g.fun_ctrl_word.billing_type;
-	
+	system_status_word_g.status_word.lcd_mode = system_function_ctrl_word_g.fun_ctrl_word.lcd_mode;
 	
 	/****�ⲿRTC���ü�������ʼ��***********/
 	Set_Rtc_UpdataInterrupt(); //����RTCΪ���ж�
@@ -160,17 +172,18 @@
 	if(Get_Extern_Rtc_Time(&sys_clockBCD_g) ==FAIL)
 	{
 		//���ô�洢��ȡ��ʱ�����õ�RTC
-		Set_Extern_Rtc_Time(save_realtime_data_g.record_time_BCD.year,save_realtime_data_g.record_time_BCD.month,save_realtime_data_g.record_time_BCD.day,   \
-												1,save_realtime_data_g.record_time_BCD.hour,save_realtime_data_g.record_time_BCD.min,save_realtime_data_g.record_time_BCD.sec); 
+		if(Set_Extern_Rtc_Time(save_realtime_data_g.record_time_BCD.year,save_realtime_data_g.record_time_BCD.month,save_realtime_data_g.record_time_BCD.day,   \
+												1,save_realtime_data_g.record_time_BCD.hour,save_realtime_data_g.record_time_BCD.min,save_realtime_data_g.record_time_BCD.sec) ==FAIL){
+			//�洢��ʱ�����������Ĭ��ֵ
+			Set_Extern_Rtc_Time(sys_clockBCD_g.year,sys_clockBCD_g.month,sys_clockBCD_g.day, 1,sys_clockBCD_g.hour,sys_clockBCD_g.min,sys_clockBCD_g.sec)	;							
+		}													
 	}
 	
 	//�������г�ʼ��
 	ValveRunParaInit(equipment_basic_inf_g.valve_type);
 	
-	//��Դ״̬���
+	//��Դ״̬��⡢���״̬���
 	PowerManagrInit();
-	
-	//���״̬���
 	
 	//��塢����״̬���
 	
@@ -188,6 +201,10 @@
 	uint16_t	IntervalTime;
 	
 	/*rs485�ɼ��������ƣ� ��������ʱ���쳣��������¼�洢�����*/
+	
+	if(start_rs485_g == RS485_START_REASON_KEY){ //������������Ҫ�洢һ��������������ϱ�
+		interval_report_record_flag =SET;
+	}
 	
 		/*Сʱ���졢��*/
 	if((sys_clockBCD_in.min == 0)&&(sys_clockBCD_in.sec == 0)) //Сʱ��¼�洢��
@@ -209,9 +226,15 @@
 		start_rs485_g = RS485_START_REASON_RECORD;
 	
 	
-	if(start_rs485_g  != RS485_START_REASON_NONE){
+	//�ϱ�֮ǰ�����ɼ�
+	if(start_wrc_g != WRC_MEANS_NONE){
+		start_rs485_g = RS485_START_REASON_REPORT;
+	}
+	
+	if(start_rs485_g != RS485_START_REASON_NONE){
 		start_rs485_g = RS485_START_REASON_NONE;
-		sys_fun_run_ctrl_p->rs485_ctrl_flag.start_flag = SET;
+		if(sys_fun_run_ctrl_p->rs485_ctrl_flag.running_flag ==RESET)
+			sys_fun_run_ctrl_p->rs485_ctrl_flag.start_flag = SET;
 	}
 	
 	/*���ؿ��ƣ�����ͨ����������ָ��쳣�ȿ��ƣ���Ҫ����ʱֱ�ӵ���ValveCtrlOrder�������ɣ����ڴ˴�����*/
@@ -251,7 +274,7 @@
 	if(start_wrc_g  != WRC_MEANS_NONE){
 		wrc_ctrl_para_g.wrc_start_flag = start_wrc_g;
 		start_wrc_g = WRC_MEANS_NONE;
-		if(sys_fun_run_ctrl_p->wrc_ctrl_flag.start_flag == RESET){
+		if((sys_fun_run_ctrl_p->wrc_ctrl_flag.start_flag == RESET)&&(sys_fun_run_ctrl_p->wrc_ctrl_flag.running_flag == RESET )){
 			pwr_vol_g.alka_flag = AMS_WRC_BEFORE;
 			sys_fun_run_ctrl_p->wrc_ctrl_flag.start_flag = SET;
 		}

--
Gitblit v1.9.3