From bfe14e41fa5b07771d78af4511ba18d706bc23cc Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期一, 28 七月 2025 17:07:52 +0800
Subject: [PATCH] 1.Spooling Config功能EAP模拟测试;

---
 SourceCode/Bond/Servo/CEFEM.cpp |   60 +++++++++++++++++++++++++-----------------------------------
 1 files changed, 25 insertions(+), 35 deletions(-)

diff --git a/SourceCode/Bond/Servo/CEFEM.cpp b/SourceCode/Bond/Servo/CEFEM.cpp
index 8a0e9cc..941b834 100644
--- a/SourceCode/Bond/Servo/CEFEM.cpp
+++ b/SourceCode/Bond/Servo/CEFEM.cpp
@@ -473,6 +473,7 @@
 			pStep->setName(STEP_EQ_VCR1_EVENT_REPORT);
 			pStep->setProp("Port", (void*)1);
 			pStep->setWriteSignalDev(0x4a);
+			pStep->setReturnDev(0x91e);
 			if (addStep(STEP_ID_VCR1_EVENT_REPORT, pStep) != 0) {
 				delete pStep;
 			}
@@ -676,23 +677,6 @@
 		}
 
 		{
-			// Panel Data Report
-			CEqReadStep* pStep = new CEqReadStep(0x617f, 386 * 2,
-				[&](void* pFrom, int code, const char* pszData, size_t size) -> int {
-					if (code == ROK && pszData != nullptr && size > 0) {
-						decodePanelDataReport((CStep*)pFrom, pszData, size);
-					}
-					return -1;
-				});
-			pStep->setName(STEP_EQ_PANEL_DATA_REPORT);
-			pStep->setProp("Port", (void*)1);
-			pStep->setWriteSignalDev(0x15e);
-			if (addStep(STEP_ID_PANEL_DATA_REPORT, pStep) != 0) {
-				delete pStep;
-			}
-		}
-
-		{
 			// FAC Data Report
 			CEqReadStep* pStep = new CEqReadStep(0x6301, 108 * 2,
 				[&](void* pFrom, int code, const char* pszData, size_t size) -> int {
@@ -803,16 +787,27 @@
 				m_pPort[i]->onReceiveLBData(pszData, size);
 			}
 		}
+		m_pAligner->onReceiveLBData(pszData, size);
+
 
 		// 更新信号到LoadPort, Robot, Aligner, Fliper
-		m_pPort[0]->setLinkSignalBlock(0, &m_bLinkSignal[0][0]);
-		m_pPort[1]->setLinkSignalBlock(0, &m_bLinkSignal[1][0]);
-		m_pPort[2]->setLinkSignalBlock(0, &m_bLinkSignal[2][0]);
-		m_pPort[3]->setLinkSignalBlock(0, &m_bLinkSignal[3][0]);
-		m_pArmTray[0]->setLinkSignalBlock(0, &m_bLinkSignal[4][0]);
-		m_pArmTray[1]->setLinkSignalBlock(0, &m_bLinkSignal[5][0]);
-		m_pAligner->setLinkSignalBlock(0, &m_bLinkSignal[6][0]);
-		m_pFliper->setLinkSignalBlock(0, &m_bLinkSignal[7][0]);
+		m_pPort[0]->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[0][0]);
+		m_pPort[1]->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[1][0]);
+		m_pPort[2]->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[2][0]);
+		m_pPort[3]->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[3][0]);
+		m_pArmTray[0]->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[4][0]);
+		m_pArmTray[1]->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[5][0]);
+		m_pAligner->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[6][0]);
+		m_pFliper->setLinkSignalUpstreamBlock(0, &m_bLinkSignalToUpstream[7][0]);
+
+		m_pPort[0]->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[0][0]);
+		m_pPort[1]->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[1][0]);
+		m_pPort[2]->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[2][0]);
+		m_pPort[3]->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[3][0]);
+		m_pArmTray[0]->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[4][0]);
+		m_pArmTray[1]->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[5][0]);
+		m_pAligner->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[6][0]);
+		m_pFliper->setLinkSignalDownstreamBlock(0, &m_bLinkSignalToDownstream[7][0]);
 	}
 
 	int CEFEM::onReceivedJob(int port, CJobDataS* pJobDataS)
@@ -872,16 +867,11 @@
 		return 10000;
 	}
 
-	void CEFEM::printDebugString001()
+	void CEFEM::printDebugRobotState()
 	{
-		for (int i = 0; i < 8; i++) {
-			LOGI("<CEquipment-%s>%d, Signal:%s, %s, %s, %s",
-				m_strName.c_str(), i,
-				m_bLinkSignal[i][SIGNAL_UPSTREAM_INLINE] ? "ON" : "OFF",
-				m_bLinkSignal[i][SIGNAL_UPSTREAM_TROUBLE] ? "ON" : "OFF",
-				m_bLinkSignal[i][SIGNAL_INTERLOCK] ? "ON" : "OFF",
-				m_bLinkSignal[i][SIGNAL_SEND_ABLE] ? "ON" : "OFF"
-			);
-		}
+		LOGI("<CEFEM>Robot status:%d, ARM1:%s, ARM2:%s",
+			m_robotData.status,
+			m_robotData.armState[1] ? _T("ON") : _T("OFF"),
+			m_robotData.armState[2] ? _T("ON") : _T("OFF"));
 	}
 }

--
Gitblit v1.9.3