From f03cf3ae7a36954e64fc014e6bb7afd20c5a5247 Mon Sep 17 00:00:00 2001
From: jinlicong <493886250@qq.com>
Date: Wed, 12 Jun 2024 17:22:08 +0800
Subject: [PATCH] 增加IAP功能,准备测试上位机升级
---
Soft/system_run_fun.c | 216 +++++++++++++++++++++++++++++++++++++++++++++++------
1 files changed, 189 insertions(+), 27 deletions(-)
diff --git a/Soft/system_run_fun.c b/Soft/system_run_fun.c
index 631cb1b..b79ee03 100644
--- a/Soft/system_run_fun.c
+++ b/Soft/system_run_fun.c
@@ -2,35 +2,25 @@
#include "system_eep_mem_manage.h"
#include "system_mem_para.h"
#include "eeprom.h"
-#include "mbcrc.h"
+#include "mbcrc1.h"
#include "gpio.h"
#include "extern_rtc.h"
#include "key.h"
#include "lcd_io_api.h"
+#include "wireless_remote_comm.h"
+#include "power_manage.h"
+#include "pulse_and_alarm_line.h"
+#include "valve_control.h"
+#include "linked_list.h"
-
+RS485_START_REASON start_rs485_g = RS485_START_REASON_NONE;
+WRC_START_MEANS start_wrc_g = WRC_MEANS_NONE;
void allGpioInit(void)
{
-// CMU_PERCLK_SetableEx(PADCLK, ENABLE); //PADʱ�ӣ�GPIO��ʹ�ܺ���
-//
-
-// InputtIO(UNCAP_DETECTION_PORT,UNCAP_DETECTION_PIN,IN_NORMAL);
-//
-
-// Lcd_GPIO_Init();
-// Measure_IO_Init();
-// KEY_IO_Init();
-// Valve_IO_Init();
-// ADC_LithIO_Init();
-// ADC_AlkaIO_Init();
-// Power_IO_Init();
-// Gprs_IO_Init();
-// E2p_IO_Init();
-//
-// SYS_BST_EN;
+ E2P_Ctrl_Gpio_Init();
RTC_GPIO_Init();
@@ -38,6 +28,15 @@
Lcd_GPIO_Init();
+ Power_IO_Init();//��Դ���
+
+ Valve_CTRL_GPIO_Init();
+
+ Pulse_And_Alarm_Line_IO_Init();
+
+ RS485_read_data_GPIO_Init();
+
+ WRC_PWR_GPIO_Init(); //����Զ����Դ����IO
}
//����������������
@@ -57,7 +56,7 @@
//I0������
allGpioInit();
- //��λ���������ֱ�Ҫ���蹦�ܳ�ʼ������Ҫ�õ��ſ��������蹦������ѭ������֮ǰ���ü���
+ //��λ���������ֱ�Ҫ���蹦�ܳ�ʼ������Ҫ�õ��ſ��������蹦�ܿɲ�����������
// allPeripheralDriver();
SPI3_Init(); //EEP-SPI��ʼ��
}
@@ -71,10 +70,24 @@
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( 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)&& \
+ ((flow_meter_para_g.flow_meter_conn_type==FLOW_METER_CONN_PULSE)||(flow_meter_para_g.flow_meter_conn_type==FLOW_METER_CONN_RS485_AND_PULSE))){
+ if((flow_meter_para_g.flow_meter_code !=ASMODBUS)&&(flow_meter_para_g.flow_meter_code !=AS100MODBUS)&&(flow_meter_para_g.flow_meter_code !=SIARGO_MODBUS)){
+ GPIO_EXTI_Init( LF_PULSE_INT_PORT, LF_PULSE_INT_PIN, EXTI_FALLING, ENABLE);
+ }else{
+ GPIO_EXTI_Init( LF_PULSE_INT_PORT, LF_PULSE_INT_PIN, EXTI_RISING, ENABLE);
+ }
+ }
/*NVIC�����*/
NVIC_DisableIRQ(GPIO_IRQn);
@@ -91,7 +104,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;
+
//��ȡ������ʼ�����ñ�ʶ
//�����ʶ��ʶ�������洢��Ҫȫ��д��Ĭ��ֵ
//�����ʶʶ��ɹ��������в���������ֱ�ӴӴ洢�����ȡ
@@ -127,6 +147,8 @@
//���������ʶ��ʶ�����С�ڲ���ʱ�䣬����Ҫ������
allParaPatchPro();
+ EEPROM_CTRL_DISABLE;
+
}
@@ -135,19 +157,159 @@
{
//���ֹ���ģ����������IJ�����ʼ��
+ /*״̬�ֳ�ʼ*/
+ system_status_word_g.status_word.account_state = (system_function_ctrl_word_g.fun_ctrl_word.account_open == 1)?1:0;
+ 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Ϊ���ж�
//��ȡ�ⲿRTCʱ�䣬
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();
+ ValveRunParaInit(equipment_basic_inf_g.valve_type);
+
+ //��Դ״̬���
+ PowerManagrInit();
+
+ //���״̬���
+
+ //��塢����״̬���
+
+ //�����ߡ������߳�ʼ
+ PulseAndAlarmLineInit();
+
}
-
\ No newline at end of file
+
+
+void sysRunFunCtrlPro(FUN_START_CTRL_PARA_T * sys_fun_run_ctrl_p,sClockBCD sys_clockBCD_in)
+{
+ uint8_t first_time[2] = {0,0};
+ uint16_t IntervalTime;
+
+ /*rs485�ɼ��������ƣ� ��������ʱ���쳣��������¼�洢�����*/
+
+ /*Сʱ���졢��*/
+ if((sys_clockBCD_in.min == 0)&&(sys_clockBCD_in.sec == 0)) //Сʱ��¼�洢��
+ start_rs485_g = RS485_START_REASON_RECORD;
+
+ if((sys_clockBCD_in.hour == 0)&&(sys_clockBCD_in.min == 0)&&(sys_clockBCD_in.sec == 0))//���¼�洢��
+ start_rs485_g = RS485_START_REASON_RECORD;
+
+ if((sys_clockBCD_in.day == 1)&&(sys_clockBCD_in.hour == 0)&&(sys_clockBCD_in.min == 0)&&(sys_clockBCD_in.sec == 0))//�¼�¼�洢��
+ start_rs485_g = RS485_START_REASON_RECORD;
+
+
+ if(__SYS_STATUS_BYTES_GET(power_state) == SET)
+ IntervalTime = wrc_para_sizhu_g.ext_power_data_interval;
+ else
+ IntervalTime = wrc_para_sizhu_g.bat_power_data_interval;
+
+ if(IntervalTriggerHandle(sys_clockBCD_in,IntervalTime,first_time)==SET)
+ start_rs485_g = RS485_START_REASON_RECORD;
+
+
+ //�ϱ�֮ǰ�����ɼ�
+ 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;
+ if(sys_fun_run_ctrl_p->rs485_ctrl_flag.running_flag ==RESET)
+ sys_fun_run_ctrl_p->rs485_ctrl_flag.start_flag = SET;
+ }
+
+ /*���ؿ��ƣ�����ͨ����������ָ��쳣�ȿ��ƣ���Ҫ����ʱֱ�ӵ���ValveCtrlOrder�������ɣ����ڴ˴�����*/
+
+
+
+ /*Զ��ͨѶ�������ƣ���������������ڡ��쳣�������ر���*/
+ if((wrc_para_sizhu_g.time_start_type&WRC_TIME_START_INTERVAL)==WRC_TIME_START_INTERVAL){
+ for(uint16_t count_i=0;count_i<wrc_para_sizhu_g.timing_send_num;count_i++){
+ if(count_i>=12)
+ break; //ʱ���������12���������˳�
+
+ if((sys_clockBCD_in.hour==wrc_para_sizhu_g.timing_send_time_BCD[count_i][0])&&(sys_clockBCD_in.min==wrc_para_sizhu_g.timing_send_time_BCD[count_i][1])&&(sys_clockBCD_in.sec==0))
+ start_wrc_g = WRC_MEANS_RTC_TIMING;
+ }
+ }
+
+ if((wrc_para_sizhu_g.time_start_type&WRC_TIME_START_TIMING)==WRC_TIME_START_TIMING){
+ if(__SYS_STATUS_BYTES_GET(power_state) == SET)
+ IntervalTime = wrc_para_sizhu_g.ext_power_send_interval;
+ else
+ IntervalTime = wrc_para_sizhu_g.bat_power_send_interval;
+
+ if(IntervalTriggerHandle(sys_clockBCD_in,IntervalTime,wrc_para_sizhu_g.send_first_time_BCD)==SET)
+ start_wrc_g = WRC_MEANS_RTC_INTERVAL;
+ }
+
+ if((wrc_ctrl_para_g.wrc_restart_num_cnt > 0)&&(wrc_ctrl_para_g.wrc_restart_time_sec_cnt == 0)){
+ if(start_wrc_g == WRC_MEANS_NONE){
+ //�����ر��ϱ�
+ start_wrc_g = WRC_MEANS_AGAIN;
+ wrc_ctrl_para_g.wrc_restart_num_cnt -- ;
+ }
+ }
+
+
+ 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)&&(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;
+ }
+ }
+
+}
+
+
+//ϵͳ�������в�����״̬������RESET�����������
+FlagStatus SysKeepRunningStatusGet(FUN_START_CTRL_PARA_T sys_fun_run_ctrl_in)
+{
+ if(__SYS_STATUS_BYTES_GET(power_state) == SET) //���״̬�¿��Բ�����
+ return SET;
+
+ if(sys_fun_run_ctrl_in.rs485_ctrl_flag.running_flag ==SET)
+ return SET;
+
+// if(sys_fun_run_ctrl_in.valve_ctrl_flag.running_flag ==SET) //�������������
+// return SET;
+
+ if(sys_fun_run_ctrl_in.wrc_ctrl_flag.running_flag ==SET)
+ return SET;
+
+ return RESET;
+
+
+}
+
+
+
+//״̬�ִ���
+void SysStatusWordPro(void)
+{
+
+
+
+
+
+}
+
+
+
--
Gitblit v1.9.3