From e4424eb6b50d0300583c422dfb71d58e040f4b9e Mon Sep 17 00:00:00 2001
From: jinlicong <493886250@qq.com>
Date: Tue, 11 Jun 2024 19:54:37 +0800
Subject: [PATCH] 继续测试优化

---
 Function/VALVE/valve_control.c |  226 ++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 169 insertions(+), 57 deletions(-)

diff --git a/Function/VALVE/valve_control.c b/Function/VALVE/valve_control.c
index b9fe480..008bab3 100644
--- a/Function/VALVE/valve_control.c
+++ b/Function/VALVE/valve_control.c
@@ -1,6 +1,10 @@
 #include "valve_control.h"
 #include "gpio.h"
 #include "system_mem_para.h"
+#include "power_manage.h"
+#include "linked_list.h"
+#include "sizhu_alarm_record.h"
+#include "sizhu_event_record.h"
 
 __IO VALVE_CTRL_PARA_T	valve_ctrl_para_g;
 
@@ -33,25 +37,43 @@
 	CloseIO(VALVE_FORCE_OPEN_PORT,VALVE_FORCE_OPEN_PIN);
 }
 
+void Valve_CTRL_GPIO_Init(void)
+{
+	Motor_AB_GPIO_Init();
+	Motor_A_LOW;
+	Motor_B_LOW;
+	Motor_OP_CL_GPIO_Init_sleep_mode();
+	
+}
+
+
+
+
 
 void ValveMotorOpenRun(void)
 {
 	Motor_AB_GPIO_Init();
 	Motor_OP_CL_GPIO_Init();
 	Motor_A_HIGH;
-	Motor_B_HIGH;
-	GPIO_EXTI_Init( Motor_OP_PORT, Motor_OP_PIN, EXTI_FALLING, ENABLE);
-	GPIO_EXTI_Init( Motor_CL_PORT, Motor_CL_PIN, EXTI_FALLING, ENABLE);
+	Motor_B_LOW;
 }
 
 void ValveMotorCloseRun(void)
 {
+	
+	//�ж��Ƿ���Ҫ���ط�,����磬����������Ƴ�״̬�½��
+	if(__SYS_STATUS_BYTES_GET(alka_remove) == SET || __SYS_STATUS_BYTES_GET(alka_down) == SET){
+		if(__SYS_STATUS_BYTES_GET(power_state) == RESET){
+			borrow_Pwr_GPIO_Clk_Init();
+			BORROW_PWR_ON;
+			delay_ms(1);
+		}
+	}
+	
 	Motor_AB_GPIO_Init();
 	Motor_OP_CL_GPIO_Init();
 	Motor_A_LOW;
-	Motor_B_LOW;
-	GPIO_EXTI_Init( Motor_OP_PORT, Motor_OP_PIN, EXTI_FALLING, ENABLE);
-	GPIO_EXTI_Init( Motor_CL_PORT, Motor_CL_PIN, EXTI_FALLING, ENABLE);
+	Motor_B_HIGH;
 }
 
 void ValveMotorStop(void)
@@ -61,7 +83,11 @@
 	GPIO_EXTI_Init( Motor_OP_PORT, Motor_OP_PIN, EXTI_FALLING, DISABLE);
 	GPIO_EXTI_Init( Motor_CL_PORT, Motor_CL_PIN, EXTI_FALLING, DISABLE);
 	Motor_A_LOW;
-	Motor_B_HIGH;
+	Motor_B_LOW;
+	
+	//���ر�
+	borrow_Pwr_GPIO_Clk_Init();
+	BORROW_PWR_OFF;
 }
 
 
@@ -116,74 +142,116 @@
 uint16_t GetValveRunMaxTime(CALIBER_TYPE caliber_type_l)
 {
 	switch (caliber_type_l){			
-						case DN25_TYPE: return VALVE_HADE_RUN_TIME_DN25 ;break;
-						case DN32_TYPE: return VALVE_HADE_RUN_TIME_DN32 ;break;
-						case DN40_TYPE: return VALVE_HADE_RUN_TIME_DN40 ;break;
-						case DN50_TYPE:	return VALVE_HADE_RUN_TIME_DN50 ;break;
-						case DN80_TYPE:	return VALVE_HADE_RUN_TIME_DN80 ;break;	
-						case DN100_TYPE:	return VALVE_HADE_RUN_TIME_DN100 ;break;
-						case DN150_TYPE:	return VALVE_HADE_RUN_TIME_DN150 ;break;							
-						case DN200_TYPE:	return VALVE_HADE_RUN_TIME_DN200 ;break;						
-						default:	return VALVE_HADE_RUN_TIME_DN200 ;break;
+						case DN25_TYPE: return VALVE_HADE_RUN_TIME_DN25 ;
+						case DN32_TYPE: return VALVE_HADE_RUN_TIME_DN32 ;
+						case DN40_TYPE: return VALVE_HADE_RUN_TIME_DN40 ;
+						case DN50_TYPE:	return VALVE_HADE_RUN_TIME_DN50 ;
+						case DN80_TYPE:	return VALVE_HADE_RUN_TIME_DN80 ;
+						case DN100_TYPE:	return VALVE_HADE_RUN_TIME_DN100 ;
+						case DN150_TYPE:	return VALVE_HADE_RUN_TIME_DN150 ;							
+						case DN200_TYPE:	return VALVE_HADE_RUN_TIME_DN200 ;						
+						default:	return VALVE_HADE_RUN_TIME_DN200 ;
 				}
 }
 
 
-void ValveCtrlHade(CALIBER_TYPE caliber_type_l)
+void ValveCtrlHade(CALIBER_TYPE caliber_type_l,FUN_START_CTRL_PARA_T * sys_fun_run_ctrl_p)
 {
-	if(valve_ctrl_para_g.valve_ctrl_order == VC_OPEN){
+	
+	if(valve_ctrl_para_g.force_open_status ==SET){
+		//ǿ�����ȼ��ߣ���⵽ǿ����ִ�з��ſ���,�ر��жϼ�⡣  ��ⷧ��״̬���������λ��״̬���Ϊ��������״̬Ϊ������
+		GPIO_EXTI_Init( Motor_CL_PORT, Motor_CL_PIN, EXTI_FALLING, DISABLE);
+		if(Read_OP_CL_VALVE_Status(0) !=VALVE_OPEN){
+			save_valve_para_g.valve_status = VALVE_OPENING;
+			ValveMotorStop();		
+		}else{
+			save_valve_para_g.valve_status = VALVE_OPEN;
+		}
+		
+		return ;  //ǿ���ź���Чʱ��ֱ���������������жϺ����߼�
+	}else if(valve_ctrl_para_g.valve_ctrl_order == VC_OPEN){
 		if(Read_OP_CL_VALVE_Status(0) == VALVE_OPEN){
 			ValveMotorStop();
 			save_valve_para_g.valve_status = VALVE_OPEN;
 			valve_ctrl_para_g.close_time_cnt = 0;
+			sizhuValveActionLogHandle(valve_ctrl_para_g.valve_ctrl_source, valve_ctrl_para_g.valve_ctrl_order,ALARM_ID_NORMAL);
 			valve_ctrl_para_g.valve_ctrl_order = VC_NONE;
 			
 		}else{
-			if(0){ //?Զ����485�ɼ���������ӳ�ִ�з��Ŷ���
-			
+			if(sys_fun_run_ctrl_p->rs485_ctrl_flag.running_flag==SET||sys_fun_run_ctrl_p->wrc_ctrl_flag.running_flag==SET){ //?Զ����485�ɼ���������ӳ�ִ�з��Ŷ���
+				;
 			}else{
 				valve_ctrl_para_g.open_time_cnt = GetValveRunMaxTime(caliber_type_l);
 		
 				ValveMotorOpenRun();
 
 				save_valve_para_g.valve_status = VALVE_OPENING;
+				sizhuValveActionLogHandle(valve_ctrl_para_g.valve_ctrl_source, valve_ctrl_para_g.valve_ctrl_order,ALARM_ID_NORMAL);
 				valve_ctrl_para_g.valve_ctrl_order = VC_NONE;
-				
+				delay_ms(10);  //�Ӻ���ն�
+				GPIO_EXTI_Init( Motor_OP_PORT, Motor_OP_PIN, EXTI_FALLING, ENABLE);
 			}
-			
 		}
-		
-		
-	}else if(valve_ctrl_para_g.valve_ctrl_order == VC_CLOSE){
+	}else if((valve_ctrl_para_g.valve_ctrl_order == VC_CLOSE)||(valve_ctrl_para_g.valve_ctrl_order == VC_CLOSE_AND_LOCK )){
 		if(Read_OP_CL_VALVE_Status(0) == VALVE_CLOSE){
 			ValveMotorStop();
 			save_valve_para_g.valve_status = VALVE_CLOSE;
 			valve_ctrl_para_g.open_time_cnt = 0;
+			if((save_valve_para_g.valve_lock_state == VL_UNLOCK)&&(valve_ctrl_para_g.valve_ctrl_order == VC_CLOSE_AND_LOCK))
+			{
+				save_valve_para_g.valve_lock_state = VL_LOCK ;				
+			}
+			sizhuValveActionLogHandle(valve_ctrl_para_g.valve_ctrl_source, valve_ctrl_para_g.valve_ctrl_order,save_valve_para_g.valve_close_ID);
 			valve_ctrl_para_g.valve_ctrl_order = VC_NONE;
 			
-		}else{
-			if(0){ //?Զ����485�ɼ���������ӳ�ִ�з��Ŷ���
 			
+		}else{
+			if(sys_fun_run_ctrl_p->rs485_ctrl_flag.running_flag==SET||sys_fun_run_ctrl_p->wrc_ctrl_flag.running_flag==SET){ //?Զ����485�ɼ���������ӳ�ִ�з��Ŷ���
+				;
 			}else{
 				
 				valve_ctrl_para_g.close_time_cnt = GetValveRunMaxTime(caliber_type_l);
 				ValveMotorCloseRun();
 
 				save_valve_para_g.valve_status = VALVE_CLOSING;
-				valve_ctrl_para_g.valve_ctrl_order = VC_NONE;
 				
+				if((save_valve_para_g.valve_lock_state == VL_UNLOCK)&&(valve_ctrl_para_g.valve_ctrl_order == VC_CLOSE_AND_LOCK))
+				{
+					save_valve_para_g.valve_lock_state = VL_LOCK ;
+				}
+				
+				sizhuValveActionLogHandle(valve_ctrl_para_g.valve_ctrl_source, valve_ctrl_para_g.valve_ctrl_order,save_valve_para_g.valve_close_ID);
+				valve_ctrl_para_g.valve_ctrl_order = VC_NONE;	
+
+				delay_ms(10);  //�Ӻ���ն�
+				GPIO_EXTI_Init( Motor_CL_PORT, Motor_CL_PIN, EXTI_FALLING, ENABLE);
 			}
-			
 		}
 	}else if(valve_ctrl_para_g.valve_ctrl_order == VC_LOCK){
-		save_valve_para_g.valve_lock_state = VL_LOCK;
+		if(save_valve_para_g.valve_lock_state == VL_UNLOCK)
+		{
+			save_valve_para_g.valve_lock_state = VL_LOCK ;
+			sizhuValveActionLogHandle(valve_ctrl_para_g.valve_ctrl_source, valve_ctrl_para_g.valve_ctrl_order,ALARM_ID_NORMAL);
+		}
+		valve_ctrl_para_g.valve_ctrl_order = VC_NONE;	
 		
+	}else if(valve_ctrl_para_g.valve_ctrl_order == VC_UNLOCK){
+		if(save_valve_para_g.valve_lock_state == VL_LOCK)
+		{
+			save_valve_para_g.valve_lock_state =  VL_UNLOCK;
+			sizhuValveActionLogHandle(valve_ctrl_para_g.valve_ctrl_source, valve_ctrl_para_g.valve_ctrl_order,ALARM_ID_NORMAL);
+		}
+		valve_ctrl_para_g.valve_ctrl_order = VC_NONE;	
+	}else{
+
 	}
-	
 	
 	//?�жϿ��ط��Ƿ�λ
 	if(save_valve_para_g.valve_status==VALVE_OPENING){
-		if(valve_ctrl_para_g.open_time_cnt==0){
+		if(Read_OP_CL_VALVE_Status(0) ==VALVE_OPEN){
+			ValveMotorStop();//�ر�����
+			save_valve_para_g.valve_status = VALVE_OPEN;
+		}else if(valve_ctrl_para_g.open_time_cnt==0){
 			//?��ʱ����
 			ValveMotorStop();
 			save_valve_para_g.valve_status = VALVE_ERROR;
@@ -192,15 +260,15 @@
 			valve_ctrl_para_g.open_time_cnt--;
 		}
 		
-		if(valve_ctrl_para_g.force_open_status ==SET){
-			//��������������ǿ�����ر�����
-			ValveMotorStop();
-		}
-			
-			
-		
+//		if(valve_ctrl_para_g.force_open_status ==SET){
+//			//��������������ǿ�����ر�����
+//			ValveMotorStop();
+//		}
 	}else if(save_valve_para_g.valve_status==VALVE_CLOSING){
-		if(valve_ctrl_para_g.close_time_cnt==0){
+		if(Read_OP_CL_VALVE_Status(0) ==VALVE_CLOSE){
+			ValveMotorStop();//�ر�����
+			save_valve_para_g.valve_status = VALVE_CLOSE;
+		}else if(valve_ctrl_para_g.close_time_cnt==0){
 			//?��ʱ����
 			ValveMotorStop();
 			save_valve_para_g.valve_status = VALVE_ERROR;
@@ -209,45 +277,85 @@
 			valve_ctrl_para_g.close_time_cnt--;
 		}
 		
-		if(valve_ctrl_para_g.force_open_status ==SET){
-			//�ط�����������ǿ�����ر�������״̬�ı�ɿ����У����ÿ�����ʱ
-			ValveMotorStop();
-			save_valve_para_g.valve_status = VALVE_OPENING;
-			valve_ctrl_para_g.open_time_cnt = GetValveRunMaxTime(caliber_type_l);
+//		if(valve_ctrl_para_g.force_open_status ==SET){
+//			//�ط�����������ǿ�����ر�������״̬�ı�ɿ����У����ÿ�����ʱ
+//			ValveMotorStop();
+//			save_valve_para_g.valve_status = VALVE_OPENING;
+//			valve_ctrl_para_g.open_time_cnt = GetValveRunMaxTime(caliber_type_l);
+//		}
+	}
+	
+	//���Ų���������״̬��λ
+	if((save_valve_para_g.valve_status==VALVE_OPENING)||(save_valve_para_g.valve_status==VALVE_CLOSING))
+		sys_fun_run_ctrl_p->valve_ctrl_flag.running_flag = SET;
+	else
+		sys_fun_run_ctrl_p->valve_ctrl_flag.running_flag = RESET;
+	
+	
+	//״̬�ִ���
+	if(save_valve_para_g.valve_lock_state == VL_UNLOCK)
+		system_status_word_g.status_word.valve_lock = RESET;
+	else
+		system_status_word_g.status_word.valve_lock = SET;
+	
+	if(save_valve_para_g.valve_status == VALVE_ERROR){
+		if(system_status_word_g.status_word.valve_state != VALVE_ERROR){
+			//���������쳣����
+			if(__SYS_ALARM_REPORT_CTL_BYTES_GET(valve_error) == SET)
+				__SYS_ALARM_BYTES_SET(valve_error, ALARM_ID_VALVE_ABNORMAL);	
+			
+			system_alarm_word_for_valve_g.alarm_word.valve_error = SET; //�ط�����״̬��λ
 		}
+	}else{
+		system_status_word_g.status_word.valve_state = save_valve_para_g.valve_status;
 	}
 	
 }
 
 
-//����������
-ErrorStatus ValveCtrlOrder(VALVE_CTEL_TYPE_T valve_ctrl_order_l) 
+//���Ų�������������������������У������ط�������Ҫֹͣ������ת�����йط�
+ErrorStatus ValveCtrlOrder(VALVE_CTRL_TYPE_T valve_ctrl_order_l,VALVE_CTRL_SOURCE_T valve_ctrl_source) 
 {
+	valve_ctrl_para_g.valve_ctrl_source = valve_ctrl_source;
 	switch(valve_ctrl_order_l){
 		case VC_NONE:break;
 		case VC_OPEN:
+			
+			if((__SYS_STATUS_BYTES_GET(alka_remove) == SET || __SYS_STATUS_BYTES_GET(alka_down) == SET)&&(__SYS_STATUS_BYTES_GET(power_state) ==RESET)){
+				return FAIL;//���û����û����磬��������
+			}
 			if((save_valve_para_g.valve_status == VALVE_CLOSE)&&(valve_ctrl_para_g.force_open_status==RESET)){
 				valve_ctrl_para_g.valve_ctrl_order = VC_OPEN;
+				pwr_vol_g.alka_flag = AMS_VALVE_CTRL_BEFORE;
 				return PASS;
 			}
 		break;
 		
 		case VC_CLOSE:
-			if((save_valve_para_g.valve_status != VALVE_CLOSE)&&(valve_ctrl_para_g.force_open_status==RESET)){
+			if((save_valve_para_g.valve_status != VALVE_CLOSE)&&(save_valve_para_g.valve_status != VALVE_CLOSING)&&(valve_ctrl_para_g.force_open_status==RESET)){
 				valve_ctrl_para_g.valve_ctrl_order = VC_CLOSE;
-				return PASS;
+				pwr_vol_g.alka_flag = AMS_VALVE_CTRL_BEFORE;
 			}
-		break;
+			return PASS;
+//		break;
+		case VC_CLOSE_AND_LOCK:
+				valve_ctrl_para_g.valve_ctrl_order = VC_LOCK; //�Ƚ����������жϷ���״̬���費��Ҫִ�йط�
+			if((save_valve_para_g.valve_status != VALVE_CLOSE)&&(save_valve_para_g.valve_status != VALVE_CLOSING)&&(valve_ctrl_para_g.force_open_status==RESET)){
+				valve_ctrl_para_g.valve_ctrl_order = VC_CLOSE_AND_LOCK;
+				pwr_vol_g.alka_flag = AMS_VALVE_CTRL_BEFORE;
+				
+			}
+			return PASS;
 		
 		case VC_UNLOCK:
-			save_valve_para_g.valve_lock_state = VL_UNLOCK;
+			valve_ctrl_para_g.valve_ctrl_order = VC_UNLOCK;
 			return PASS;
-		break;
+//		break;
 		
 		case VC_LOCK:
-			save_valve_para_g.valve_lock_state = VL_LOCK;
+			valve_ctrl_para_g.valve_ctrl_order = VC_LOCK;
 			return PASS;
-		break;
+//		break;
 		
 		default: break;
 	}
@@ -270,13 +378,14 @@
 		if(valve_ctrl_para_g.force_open_status !=SET){
 			valve_ctrl_para_g.force_open_status =SET;
 			//��ʼ����ǿ��
+			
 		}
 			
 		
 	}else{
 		if(valve_ctrl_para_g.force_open_status ==SET){
 			valve_ctrl_para_g.force_open_status =RESET;
-			//��ʼ�ر�ǿ��
+			//ǿ������
 		}
 		
 	}
@@ -284,16 +393,19 @@
 	
 	if((valve_ctrl_para_g.force_open_status ==SET)&&(Read_OP_CL_VALVE_Status(0)==VALVE_OPEN)){
 		//?��⵽ǿ�������Ƿ���״̬��ȡ�Ѿ�����λ����ʾ�Ƴ�ǿ����Դ��
+		//
+		
+		
 	}
 	
 }
 
-void	valveCtrlPro(void) //?  ���Ҫ������������ú���ValveCtrlOrder��VC_OPEN��;��δ����������
+void	valveCtrlPro(FUN_START_CTRL_PARA_T * sys_fun_run_ctrl_p) //?  ���Ҫ������������ú���ValveCtrlOrder��VC_OPEN��;��δ����������
 {
 	
 	ValveForceOpenSignalCheck();//?ǿ���жϴ���
 	
-	ValveCtrlHade(equipment_basic_inf_g.caliber_type);//���·��Ų���������
+	ValveCtrlHade(equipment_basic_inf_g.caliber_type,sys_fun_run_ctrl_p);//���·��Ų���������
 	
 	
 }

--
Gitblit v1.9.3