From 6b0d1f644233b2984d2a87553de598879cf05caf Mon Sep 17 00:00:00 2001
From: jinlicong <493886250@qq.com>
Date: Tue, 28 May 2024 17:24:59 +0800
Subject: [PATCH] 继续完善

---
 CORE/main.c |   52 +++++++++++++++++++++++++++++++++-------------------
 1 files changed, 33 insertions(+), 19 deletions(-)

diff --git a/CORE/main.c b/CORE/main.c
index 2dced65..9dce0d5 100644
--- a/CORE/main.c
+++ b/CORE/main.c
@@ -22,7 +22,10 @@
 #include "sizhu_ctrl_word.h"
 #include "sizhu_history_record.h"
 #include "power_manage.h"
-
+#include "pulse_and_alarm_line.h"
+#include "billing.h"
+#include "linked_list.h"
+#include "other_fun.h"
 
 
 FlagStatus key_awaken_flag_g = RESET;
@@ -41,13 +44,9 @@
 	//���й��ܲ�����ʼ����������ʼ״̬���
 	sysRunFunParaInit();
 	
-	//ϵͳ��ʼ״̬��⣬���б�Ҫ
-	
-	
-	
-	
 	//����Ҫһֱ�������ⲿ�����ж�
 	allExtiIRQ();
+	
 	IWDT_Clr();
 	while(1)
 	{
@@ -59,7 +58,8 @@
 			if(Get_Extern_Rtc_Time(&sys_clockBCD_g) ==FAIL) //��ȡʱ��
 			{
 				//?RTCʱ���쳣����
-				__SYS_STATUS_ALARM_BYTES_SET(rtc_err);
+				if(__SYS_ALARM_CTL_BYTES_GET(rtc_err) == SET)
+					__SYS_STATUS_ALARM_BYTES_SET(rtc_err,ALARM_ID_RTC_BAT_LOW);
 			}
 			
 			/*����ʶ��*/
@@ -69,8 +69,11 @@
 			/*LCD��ʾ*/
 			lcdDisplayPro();
 			
-			/*�������*/
+			/*��λ������,������modbus���ɼ�����*/
 			upperComPro();
+			
+			/*�Խ��豸����״̬���*/
+			PulseAndAlarmLineCheck();
 			
 					
 			/*�ɼ����ϱ��������������*/
@@ -78,30 +81,28 @@
 			//���������ϱ��ж��߼����ڲɼ�ǰ�棬�ȴ����ɼ����ٴ����ϱ�
 			sysRunFunCtrlPro(&sys_fun_run_ctrl_g,sys_clockBCD_g);
 			
-			/*��Դ״̬��ȡ*/ //����RS485�ɼ������ء�Զ��֮ǰ������Щ�߹��IJ���֮ǰ������Ҫ�Ȳɼ�һ�ε�ص�ѹ
-			GetPwrStatusPro(&pwr_vol_g);
-			
 			/*485�ɼ�*/
 			rs485ReadDataPro(&sys_fun_run_ctrl_g);
+			
+			/*���㣬�����������*/
+			SettlementPro();
 			
 			/*������ʷ��¼�洢*/
 			//������ʷ��¼�洢��������ɼ��У����Ӻ�ȴ��ɼ�����ٴ洢
 			sizhuHistoryRecord(sys_clockBCD_g);
 			
+			/*��Դ״̬��ȡ*/ //���ڷ���֮ǰ����Ϊ�����н����ƣ�����ǰ�����粻�㣬����Ҫ���
+			GetPwrStatusPro(&pwr_vol_g);
 			
 			/*����*/
 			valveCtrlPro(&sys_fun_run_ctrl_g);
 			
 			
-			/*״̬�֡������ִ���*/
-			//��ʼ״̬��⣬��while֮ǰ�ͼ�������ʼ״̬���������λ����״̬�֣����б�������Ҫ������ʾ��������Ҫ��Ҫ�����ϱ���Ҫ���ǣ�
-			//�ڸ�������ģ�鴦��ʱ�����б������ܱ��������ֿ��ƣ�����������Ӧ��״̬����λ�������ϱ��ı�������λ���ܱ����ϱ������ֿ��ƣ������ڷ��صı�������λ��ͬʱ������ʾ�������������������Ҫ����ͬʱɾ����ʾ������
-			//�����ϱ��ı����ַǿգ������ϱ�������ϱ������У����ظ������� �������ϱ��ɹ�֮����գ�
-			//���ڷ��صı�����ֻ����һ�Σ�����޶������������ñ����֣������Ҫ����������Ӧ���Ʒ��ţ������Ѿ��ر�״̬�����ڹ�ʱ����账������״̬������֮�󱨾��������  �ж��������ͬʱ���ڵģ�Ҫ�����жϣ���Ϊ�����ִ����Ĺط����Ͳ�һ�£�ǿ���Թط������ȼ����ߡ�
-			//��������״̬Ҫ���Զ��������ƣ����������ֵ���ֱ�ӿ��ص��������֮ǰ�����ط���ԭ���������ɵ�ǿ���Թط�������������֮���Զ�����������Ƿ������ɵ�ǿ���Թط��������Զ������������Ҫ��¼֮ǰ����ǿ���Թط���ԭ��
-			//��¼���ϴιط�ԭ����Ҫ�����ȼ����ǻ��ƣ� ǿ���Թط����Ƿ�ǿ���Թط��� �������ɵ�ǿ���Թط����������ɵġ�
-			//
+			/*ϵͳ������ɢС���ܴ���*/
+			OtherFunPro();
 			
+			/*״̬�֡������ִ���*/
+			SysAlarmCtrlPro();
 			
 			
 			/*����������ͨѶ��Ԥ��*/
@@ -118,11 +119,24 @@
 			//��������²������ߣ�Ҫ���жϣ��������⹩�硢RS485�ɼ������С�Զ��������
 			if(SysKeepRunningStatusGet(sys_fun_run_ctrl_g)==RESET){
 				//���ߴ���
+				if(pulse_exti_flag==SET){ //�ȴ����������
+					for(uint8_t count_i=0;count_i<(PULSE_CHECK_DELAY_MS &0xff);count_i++){
+						delay_ms(1);
+						if(pulse_exti_flag == RESET) 
+							break;						
+					}				
+				}
+				//����
+				
 				
 			}
 				
 			
 		}
+		
+		if(lcd_wake_up_flag_g)  //Ϊ�˰�����ʾû���ӳٸ�
+			lcdDisplayPro();
+		
 	}
 }
 

--
Gitblit v1.9.3