From 6ea1a42391f86e72f53042a966dae970a3fd77cb Mon Sep 17 00:00:00 2001
From: jinlicong <493886250@qq.com>
Date: Fri, 17 May 2024 17:18:57 +0800
Subject: [PATCH] 阀门控制进一步完善

---
 Soft/system_run_fun.c |  169 +++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 148 insertions(+), 21 deletions(-)

diff --git a/Soft/system_run_fun.c b/Soft/system_run_fun.c
index 631cb1b..52a7a11 100644
--- a/Soft/system_run_fun.c
+++ b/Soft/system_run_fun.c
@@ -7,30 +7,19 @@
 #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"
 
 
-
+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 +27,13 @@
 	
 	Lcd_GPIO_Init();
 	
+	Power_IO_Init();//��Դ���
+	
+	Valve_CTRL_GPIO_Init();
+	
+	Pulse_And_Alarm_Line_IO_Init();
+	
+	RS485_read_data_GPIO_Init();
 }
 
 //����������������
@@ -57,7 +53,7 @@
 	//I0������
 	allGpioInit();
 	
-	//��λ���������ֱ�Ҫ���蹦�ܳ�ʼ������Ҫ�õ��ſ��������蹦������ѭ������֮ǰ���ü���
+	//��λ���������ֱ�Ҫ���蹦�ܳ�ʼ������Ҫ�õ��ſ��������蹦�ܿɲ�����������
 //	allPeripheralDriver();
 		SPI3_Init();					//EEP-SPI��ʼ��
 }
@@ -75,6 +71,18 @@
 	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);
+	
+	/*�������ж�����ѡ��,û���������ҿ���������*/
+	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);
@@ -92,6 +100,7 @@
 	SYSTEM_EEP_IDENTIFICATION_T		sys_eep_id_B_l={0};
 	uint8_t 	eep_none_flag = 1; //0����գ���0����ǿ�
 	
+	EEPROM_CTRL_ENABLE;
 	//��ȡ������ʼ�����ñ�ʶ 
 	//�����ʶ�޷�ʶ�������洢��Ҫȫ��д��Ĭ��ֵ
 	//�����ʶʶ��ɹ��������в���������ֱ�ӴӴ洢�����ȡ
@@ -127,6 +136,8 @@
 	//���������ʶ�޷�ʶ�����С�ڲ���ʱ�䣬����Ҫ�򲹶�����
 	allParaPatchPro();
 	
+	EEPROM_CTRL_DISABLE;
+	
 }
 
 
@@ -146,8 +157,124 @@
 	}
 	
 	//�������г�ʼ��
-	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_rs485_g  != RS485_START_REASON_NONE){
+		start_rs485_g = RS485_START_REASON_NONE;
+		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(start_wrc_g  != WRC_MEANS_NONE){
+		
+		start_wrc_g = WRC_MEANS_NONE;
+		if(sys_fun_run_ctrl_p->wrc_ctrl_flag.start_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