From 6d71f1d8264b929ca71bf133246b894ed955c079 Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期四, 12 六月 2025 15:17:50 +0800
Subject: [PATCH] Merge branch 'master' into liuyang

---
 SourceCode/Bond/Servo/CEFEM.cpp |   46 +++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 45 insertions(+), 1 deletions(-)

diff --git a/SourceCode/Bond/Servo/CEFEM.cpp b/SourceCode/Bond/Servo/CEFEM.cpp
index 6cbb23b..9732129 100644
--- a/SourceCode/Bond/Servo/CEFEM.cpp
+++ b/SourceCode/Bond/Servo/CEFEM.cpp
@@ -610,7 +610,7 @@
 			CEqWriteStep* pStep = new CEqWriteStep();
 			pStep->setName(STEP_EFEM_ROBOT_CMD);
 			pStep->setWriteSignalDev(0x14D);
-			pStep->setDataDev(0x90a);
+			pStep->setDataDev(0x5c7);
 			if (addStep(STEP_ID_ROBOT_CMD_REPLY, pStep) != 0) {
 				delete pStep;
 			}
@@ -623,6 +623,40 @@
 			pStep->setWriteSignalDev(0x070);
 			pStep->setDataDev(0x023);
 			if (addStep(STEP_ID_IN_OP_CMD_REPLY, pStep) != 0) {
+				delete pStep;
+			}
+		}
+
+		{
+			// 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 {
+					if (code == ROK && pszData != nullptr && size > 0) {
+						decodePanelDataReport((CStep*)pFrom, pszData, size);
+					}
+					return -1;
+				});
+			pStep->setName(STEP_EQ_FAC_DATA_REPORT);
+			pStep->setProp("Port", (void*)1);
+			pStep->setWriteSignalDev(0x04d);
+			if (addStep(STEP_ID_FAC_DATA_REPORT, pStep) != 0) {
 				delete pStep;
 			}
 		}
@@ -663,6 +697,16 @@
 				m_pPort[i]->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]);
 	}
 
 	int CEFEM::onReceivedJob(int port, CJobDataS* pJobDataS)

--
Gitblit v1.9.3