From 0c66940a8e2cf64c9890519901f433b3668216b6 Mon Sep 17 00:00:00 2001 From: KEJ <kimeungju@diteam.co.kr> Date: 수, 26 6월 2024 15:13:18 +0900 Subject: [PATCH] Ongoing80 #4942 CF AOI Review Bin File Loading 실패 개선 1. GlassRawMessenger 동기화 2. BIN파일 FindFile 제거(RawMessenger, Review 공통) 3. Unloading 시 BIN파일 제거 --- ReviewSystem/ReviewSystem/SequenceProcessor_CPJT.cpp | 740 ++++++++++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 630 insertions(+), 110 deletions(-) diff --git a/ReviewSystem/ReviewSystem/SequenceProcessor_CPJT.cpp b/ReviewSystem/ReviewSystem/SequenceProcessor_CPJT.cpp index 8d8d1e5..ee28e1c 100644 --- a/ReviewSystem/ReviewSystem/SequenceProcessor_CPJT.cpp +++ b/ReviewSystem/ReviewSystem/SequenceProcessor_CPJT.cpp @@ -40,6 +40,11 @@ #include <fstream> #include <afxwin.h> +#include <sstream> /* < KJG 20230605 - #4517 ADD >*/ +#include <filesystem> /* < KJG 20230605 - #4517 ADD >*/ + +namespace fs = std::experimental::filesystem::v1; /* < KJG 20230605 - #4517 ADD >*/ + #define GLASS_GD_FILE_PATH _T("GD") #define SIGNAL_SEND_RESULT_SUCCESS _T("OK") @@ -48,6 +53,7 @@ #define AOIRAWBIN_PATH "\\\\126.100.100.1\\d\\DIT_ResultData\\RawBin" #define AOIRAWBIN_TEST_PATH "d:\\DIT_ResultData\\RawBin" +#define AOIRAWBIN_LOCAL_PATH "D:\\DIT_ResultData\\RawBin" #define AOIRAWBIN_NETWORK_DRIVE_PATH "Y:\\RawBin" enum CPJT_MeasureMode { CPJT_ModeAuto = 0, CPJT_ModeManual }; @@ -62,7 +68,8 @@ enum CPJT_GANTRY_TYPE { GantryType_Left, GantryType_Right }; enum Judgement_CPJT { - Judge_OK_CPJT = 0, Judge_RP_CPJT, Judge_NG_CPJT, Judge_TR_CPJT, Judge_PR_CPJT, Judge_PT_CPJT, Judge_Review_CPJT, Judge_RC_CPJT, Judge_Size_CPJT, Judge_VI_CPJT, Judge_Rework_CPJT, Judge_Unknown_CPJT +// Judge_OK_CPJT = 0, Judge_RP_CPJT, Judge_NG_CPJT, Judge_TR_CPJT, Judge_PR_CPJT, Judge_PT_CPJT, Judge_Review_CPJT, Judge_RC_CPJT, Judge_Size_CPJT, Judge_VI_CPJT, Judge_Rework_CPJT, Judge_Unknown_CPJT + Judge_OK_CPJT = 0, Judge_RP_CPJT, Judge_NG_CPJT, Judge_TR_CPJT, Judge_PR_CPJT, Judge_ND_CPJT, Judge_PT_CPJT, Judge_Review_CPJT, Judge_RC_CPJT, Judge_Size_CPJT, Judge_VI_CPJT, Judge_Rework_CPJT, Judge_LN_CPJT, Judge_Unknown_CPJT, Judge_SR_CPJT ////< KEJ 20231123 - #4669 MOD > }; enum JudgeCode_CPJT { TRDF_CPJT = 0, BATR_CPJT, DOBB_CPJT, DOBS_CPJT, DOWW_CPJT, DOWB_CPJT, DOWS_CPJT @@ -166,6 +173,9 @@ { m_bUseAFMHomePosition = TRUE; m_nGlassCount = 0; + m_nStackZeroReviewCondition = 0; + m_nUploadResultFailCount = 0; + m_nStackUploadFailGlassCount = 0; CDitGlassRawClient* pDitGlassRaw = CDitGlassRawClient::GetInstance(); if(pDitGlassRaw->ConnectServer() == FALSE) { @@ -547,10 +557,16 @@ m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::AlignStart] Send Align Fail Data!")); } - AlignCamera_CameraControl(CameraControlStop); // 210805 Align Camera Sequence 蹂�寃� - + /*< SWK 20221226 - #4403 MOD Start >*/ +// AlignCamera_CameraControl(CameraControlStop); // 210805 Align Camera Sequence 蹂�寃� +// +// SendSignalToSignalControl(PCControlSendSignalIndex_Seq, PCControlSend_AlignComplete_CPJT); +// m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::AlignStart] Send Align Complete Signal!")); SendSignalToSignalControl(PCControlSendSignalIndex_Seq, PCControlSend_AlignComplete_CPJT); m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::AlignStart] Send Align Complete Signal!")); + + AlignCamera_CameraControl(CameraControlStop); + /*< SWK 20221226 - #4403 MOD End >*/ // LJY-20180905 m_pSP2P->ISP2P_UpdateAlignResultStatus(0, pGlassResult); @@ -665,10 +681,12 @@ // m_pSP2P->ISP2P_GetWSIControl(1)->SendWsiAfmSafePosMove(); //} //Sleep(5000); - if (GetProcessStatus() != ProcessReviewEnd_CPJT && GetProcessStatus() != ProcessReviewUnloding_CPJT) + //if (GetProcessStatus() != ProcessReviewEnd_CPJT && GetProcessStatus() != ProcessReviewUnloding_CPJT) + if (GetReviewComplete() == FALSE) { SendResultToSignalControl(PCControlSendData_ReviewResult_CPJT, SIGNAL_SEND_RESULT_SUCCESS); SendSignalToSignalControl(PCControlSendSignalIndex_Seq, PCControlSend_ReviewComplete_CPJT); + SetReviewComplete(TRUE); } m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewStart] Send Review Success Signal!")); @@ -940,7 +958,14 @@ SetWsiType(-1); //wsi reflow SetLastPointCheck(FALSE); + SetReviewComplete(FALSE); + //SetUploadResultFailCount(0); + bFileFind = FALSE; + + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::GlassLoading] FileMonitor Thread Stop Ready")); + m_pSP2P->ISP2P_GetReviewProcessor()->FileMonitorThreadStop(); /* < KJG 20230630 - #4517 ADD Start >*/ + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::GlassLoading] FileMonitor Thread Stop Complete")); /*< LYW 20211109 - #3662 Delete Start >*/ //m_pSP2P->ISP2P_GetDiagnosisHistory(); @@ -1062,7 +1087,6 @@ // #3381 LYW CF AOI Review FDC TackTime ADD START pDitRawClient->GetGlassData()->m_tmReviewLoading = CTime::GetCurrentTime(); // #3381 LYW CF AOI Review FDC TackTime ADD END - CString strGlassIDTemp = NULL; CString strGlassStepIdTemp = NULL; @@ -1070,7 +1094,6 @@ strGlassIDTemp = pTransferData->strGlassID; strGlassStepIdTemp = pTransferData->strStepID; - strGlassIDTemp = pTransferData->strGlassID; strcpy(pDitRawClient->GetGlassData()->m_strGlassID, strGlassIDTemp); @@ -1095,7 +1118,8 @@ /*bFileFind = FindRawBinFile(strFileName);*/ pDitRawClient->SetReviewStart(); - Sleep(1000); + //< SWK 20221226 - #4403 DEL > +// Sleep(1000); m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::Loading] Transfer Data Read Success!")); @@ -1120,6 +1144,10 @@ } m_pSP2P->ISP2P_DisplayMessage(_T("[Glass Loading] Current Apply Recipe Name : %s"), strRecipefile); + + /*< LYW 20220610 - #4185 ADD Start >*/ + CheckGantryMode(); + /*< LYW 20220610 - #4185 ADD End >*/ // recipe data apply if(ApplyRecipeDataToGlassResult(pGlassResult)==FALSE) @@ -1308,7 +1336,8 @@ } //#3561 210908 LYW ADD End - Sleep(300); + //< SWK 20221226 - #4403 MOD > + Sleep(100); //original // if (SendSignalToSignalControl(PCControlSendSignalIndex_Ack, PCControlSend_AlignStartAck_CPJT)) @@ -1430,7 +1459,9 @@ //pDitRawClient->SetReviewStart(); - Sleep(500); + //< SWK 20221226 - #4403 DEL > +// Sleep(500); + //CString strJudgeData; m_pSP2P->ISP2P_GetSignalControl()->WriteData(_T("17110"), sizeof(pDitRawClient->GetGlassData()->m_strGlassJudge), pDitRawClient->GetGlassData()->m_strGlassJudge); m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::IN] ReadRawFile!")); @@ -1491,7 +1522,8 @@ int nTotalPlanCount = CalculatePlanData(pGlassResult); m_pSP2P->ISP2P_DisplayMessage(_T("[Read Raw File] Review All Plan Total Count : %d"), nTotalPlanCount); - Sleep(1000); + //< SWK 20221226 - #4403 DEL > +// Sleep(1000); // send review ready //#3584 210817 LYW CF AOI Review �떆裕щ젅�씠�뀡 湲곕뒫 �젙�긽�솕 MOD START if (GetSimulationMode() == FALSE) @@ -1696,6 +1728,8 @@ m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] Send Review End Ack!")); } + SetUploadResultFailCount(0); + CGlassResult* pGlassResult = m_pSP2P->ISP2P_GetCurrentGlassResult(); if (pGlassResult == NULL) return; @@ -1741,7 +1775,8 @@ m_pDitGlassRaw->GetGlassData()->m_nReviewNum = m_pSP2P->ISP2P_GetReviewProcessor()->GetPlanReviewCount(); //SendDVDataToSignalControl(); - if (GetLastPointCheck() == FALSE) + //if (GetLastPointCheck() == FALSE) + if (GetReviewComplete() == FALSE) { //#3584 210817 LYW CF AOI Review �떆裕щ젅�씠�뀡 湲곕뒫 �젙�긽�솕 MOD START if (GetSimulationMode() == FALSE) @@ -1749,6 +1784,7 @@ SendResultToSignalControl(PCControlSendData_ReviewResult_CPJT, SIGNAL_SEND_RESULT_SUCCESS); SendSignalToSignalControl(PCControlSendSignalIndex_Seq, PCControlSend_ReviewComplete_CPJT); m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewStart] Send Review Success Signal!")); + SetReviewComplete(TRUE); } //#3584 210817 LYW CF AOI Review �떆裕щ젅�씠�뀡 湲곕뒫 �젙�긽�솕 MOD END //original @@ -1787,6 +1823,24 @@ CDlgDefocusList::GetInstance()->SetDefocusData(strTime,pGlassResult->m_strGlassID,pGlassResult->m_nDeFocusCount); } + + if (CheckZeroReviewAlarm() == FALSE && m_pSP2P->ISP2P_System_GetNetworkInfo()->m_nZeroReviewAlarm != 0) + { + STransferData* pTransferData = m_pSP2P->ISP2P_GetCurrentTransferData(); + if (pTransferData->strProdType != m_pSP2P->ISP2P_System_GetNetworkInfo()->m_strZeroReviewAlarmExcept) + { + m_nStackZeroReviewCondition++; + m_pSP2P->ISP2P_DisplayMessage(_T("Zero Review Condition ProdType = %s, ConditionStack = %d, AlarmExcept = %s, AlarmCondition = %d"), pTransferData->strProdType, m_nStackZeroReviewCondition, m_pSP2P->ISP2P_System_GetNetworkInfo()->m_strZeroReviewAlarmExcept, m_pSP2P->ISP2P_System_GetNetworkInfo()->m_nZeroReviewAlarm); + if (m_nStackZeroReviewCondition >= m_pSP2P->ISP2P_System_GetNetworkInfo()->m_nZeroReviewAlarm) + { + m_pSP2P->ISP2P_DisplayMessage(_T("Zero Review Alarm! %d ea Glass Is Zero Review!"), m_nStackZeroReviewCondition); + SendSignalToSignalControl(PCControlSendSignalIndex_State, PCControlSend_Review_0Count_Alarm, 1000); + m_nStackZeroReviewCondition = 0; + } + } + else m_nStackZeroReviewCondition = 0; + } + else m_nStackZeroReviewCondition = 0; /*< LYW 20211109 - #3662 Delete Start >*/ // g_pLog->DisplayMessage(_T("History map Start")); @@ -1845,7 +1899,28 @@ //#3584 210817 LYW CF AOI Review �떆裕щ젅�씠�뀡 湲곕뒫 �젙�긽�솕 MOD END // if (SendSignalToSignalControl(PCControlSendSignalIndex_Ack, PCControlSend_ReviewUnloadingAck_CPJT)) // m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewStart] Send Review Unloading Ack!")); - + + /* < KEJ 20240621 - #4942 ADD Start > */ + STransferData* pTransferData = m_pSP2P->ISP2P_GetCurrentTransferData(); + CString strGlassStepIdTemp = pTransferData->strStepID; + CString strGlassIDTemp = pTransferData->strGlassID; + + CString strFileName; + strFileName.Format(_T("%s\\%s_%s.bin"), AOIRAWBIN_LOCAL_PATH, strGlassIDTemp, strGlassStepIdTemp); + + CFile file; + if (file.Open(strFileName, CFile::modeRead)) + { + file.Close(); + DeleteFile(strFileName); + g_pLog->DisplayMessage(_T("[SequenceProcessor] Delete RAW BIN File [%s]"), strFileName); + } + file.Close(); + /* < KEJ 20240621 - #4942 ADD End > */ + + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::IN] FileMonitor Thread Start Ready")); + m_pSP2P->ISP2P_GetReviewProcessor()->FileMonitorThreadStart(); /* < KJG 20230630 - #4517 ADD Start >*/ + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::IN] FileMonitor Thread Start Complete")); } @@ -2314,7 +2389,7 @@ int nCount = pRcpReviewInfo->GetRcpJudgeCellDefectCount(); int nOK; - int nCellTRJudge = 0, nCelllOKJuge = 0, nCelllPRJuge = 0; + int nCellTRJudge = 0, nCelllOKJuge = 0, nCelllPRJuge = 0, nCelllPTJuge = 0; m_pSP2P->ISP2P_DisplayMessage(_T("[ReviewEnd] Start Cell Defect Rejudge")); for (int nCellIndex = 0; nCellIndex < nCellCount; nCellIndex++) { @@ -2331,6 +2406,12 @@ { nCelllPRJuge = nCelllPRJuge + 1; } + /* < KEJ 20231123 - #4669 ADD Start > */ + else if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_PT_CPJT) + { + nCelllPTJuge = nCelllPTJuge + 1; + } + /* < KEJ 20231123 - #4669 ADD End > */ BOOL bReJudge = FALSE, bSubReJudge = FALSE; @@ -2384,6 +2465,19 @@ m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE Cell DefectPRCount[%d] [%d]"), nCellIndex, pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePR, pRcpJudgeInfo->GetJudgeCount()); } break; + /* < KEJ 20231123 - #4669 ADD Start > */ + case JudgeType_T8_PT: + if (pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePT >= pRcpJudgeInfo->GetJudgeCount()) + { + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell DefectPTCount[%d] >= [%d]"), nCellIndex, pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePT, pRcpJudgeInfo->GetJudgeCount()); + bReJudge = TRUE; + } + else + { + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE Cell DefectPTCount[%d] [%d]"), nCellIndex, pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePT, pRcpJudgeInfo->GetJudgeCount()); + } + break; + /* < KEJ 20231123 - #4669 ADD End > */ } // 2nd condition @@ -2434,6 +2528,19 @@ m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE Cell DefectPRCount[%d] [%d]"), nCellIndex, pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePR, pRcpJudgeInfo->GetSubJudgeCount()); } break; + /* < KEJ 20231123 - #4669 ADD Start > */ + case JudgeType_T8_PT: + if (pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePT <= pRcpJudgeInfo->GetSubJudgeCount()) + { + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell DefectPTCount[%d] <= [%d]"), nCellIndex, pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePT, pRcpJudgeInfo->GetSubJudgeCount()); + bSubReJudge = TRUE; + } + else + { + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE Cell DefectPTCount[%d] [%d]"), nCellIndex, pRawData->GetCellData(nCellIndex)->m_nDefectNumJudgePT, pRcpJudgeInfo->GetSubJudgeCount()); + } + break; + /* < KEJ 20231123 - #4669 ADD End > */ } if (bReJudge & bSubReJudge) @@ -2456,7 +2563,7 @@ { nCelllOKJuge = 0; } - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge,nCelllPRJuge); } else if (pRawData->GetCellData(nCellIndex)->m_nJudgement==Judge_PR_CPJT) @@ -2474,15 +2581,35 @@ { nCelllPRJuge = 0; } - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") - , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge); + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); } + /* < KEJ 20231123 - #4669 ADD Start > */ + else if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_PT_CPJT) + { + int nbfJudge = pRawData->GetCellData(nCellIndex)->m_nJudgement; + pRawData->GetCellData(nCellIndex)->m_nJudgement = Judge_TR_CPJT; + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition : ReJudge Cell Defect Grade! [%d]->[%s]") + , nCellIndex, nIdx, nbfJudge, pRcpJudgeInfo->GetReJudgeCode()); + + + nCelllPTJuge -= 1; + nCellTRJudge += 1; + + if (nCelllPTJuge < 0) + { + nCelllPTJuge = 0; + } + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); + } + /* < KEJ 20231123 - #4669 ADD End > */ else { m_pSP2P->ISP2P_DisplayMessage(_T("[TEST Process::ReviewEnd][%02d]Cell [%02d] ReJudge Cell Defect Grade! [%s]->[%s]"), nCellIndex, nIdx,_T("TR"), _T("TR")); - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") - , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge); + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); } } else if (pRcpJudgeInfo->GetReJudgeType() == JudgeType_T8_PR) @@ -2502,8 +2629,8 @@ { nCelllOKJuge = 0; } - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") - , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge); + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); } if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_TR_CPJT) { @@ -2520,24 +2647,110 @@ { nCellTRJudge = 0; } - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") - , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge); + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); } + /* < KEJ 20231123 - #4669 ADD Start > */ + if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_PT_CPJT) + { + int nbfJudge = pRawData->GetCellData(nCellIndex)->m_nJudgement; + pRawData->GetCellData(nCellIndex)->m_nJudgement = Judge_PR_CPJT; + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition : ReJudge Cell Defect Grade! [%d]->[%s]") + , nCellIndex, nIdx, nbfJudge, pRcpJudgeInfo->GetReJudgeCode()); + + + nCelllPTJuge -= 1; + nCelllPRJuge += 1; + + if (nCelllPTJuge < 0) + { + nCelllPTJuge = 0; + } + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); + } + /* < KEJ 20231123 - #4669 ADD End > */ else { m_pSP2P->ISP2P_DisplayMessage(_T("[TEST Process::ReviewEnd][%02d]Cell [%02d] ReJudge Cell Defect Grade! [%s]->[%s]"), nCellIndex, nIdx, _T("PR"), _T("PR")); - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") - , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge); + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); } } + /* < KEJ 20231123 - #4669 ADD Start > */ + else if (pRcpJudgeInfo->GetReJudgeType() == JudgeType_T8_PT) + { + if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_OK_CPJT) + { + int nbfJudge = pRawData->GetCellData(nCellIndex)->m_nJudgement; + pRawData->GetCellData(nCellIndex)->m_nJudgement = Judge_PT_CPJT; + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition : ReJudge Cell Defect Grade! [%d]->[%s]") + , nCellIndex, nIdx, nbfJudge, pRcpJudgeInfo->GetReJudgeCode()); + + + nCelllOKJuge -= 1; + nCelllPTJuge += 1; + + if (nCelllOKJuge < 0) + { + nCelllOKJuge = 0; + } + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); + } + if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_TR_CPJT) + { + int nbfJudge = pRawData->GetCellData(nCellIndex)->m_nJudgement; + pRawData->GetCellData(nCellIndex)->m_nJudgement = Judge_PT_CPJT; + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition : ReJudge Cell Defect Grade! [%d]->[%s]") + , nCellIndex, nIdx, nbfJudge, pRcpJudgeInfo->GetReJudgeCode()); + + + nCellTRJudge -= 1; + nCelllPTJuge += 1; + + if (nCellTRJudge < 0) + { + nCellTRJudge = 0; + } + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); + } + if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_PR_CPJT) + { + int nbfJudge = pRawData->GetCellData(nCellIndex)->m_nJudgement; + pRawData->GetCellData(nCellIndex)->m_nJudgement = Judge_PT_CPJT; + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition : ReJudge Cell Defect Grade! [%d]->[%s]") + , nCellIndex, nIdx, nbfJudge, pRcpJudgeInfo->GetReJudgeCode()); + + + nCelllPRJuge -= 1; + nCelllPTJuge += 1; + + if (nCelllPRJuge < 0) + { + nCelllPRJuge = 0; + } + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); + } + else + { + + m_pSP2P->ISP2P_DisplayMessage(_T("[TEST Process::ReviewEnd][%02d]Cell [%02d] ReJudge Cell Defect Grade! [%s]->[%s]"), nCellIndex, nIdx, _T("PT"), _T("PT")); + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); + } + } + /* < KEJ 20231123 - #4669 ADD End > */ else//OK { if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_OK_CPJT || pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_Unknown_CPJT) { m_pSP2P->ISP2P_DisplayMessage(_T("[TEST Process::ReviewEnd][%02d]Cell [%02d] ReJudge Cell Defect Grade! [%s]->[%s]"), nCellIndex, nIdx,_T("OK"), _T("OK")); - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") - , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge); + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); } else { @@ -2566,8 +2779,20 @@ nCelllPRJuge = 0; } } - m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d]") - , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge); + /* < KEJ 20231123 - #4669 ADD Start > */ + else if (pRawData->GetCellData(nCellIndex)->m_nJudgement == Judge_PT_CPJT) + { + nCelllOKJuge += 1; + nCelllPTJuge -= 1; + + if (nCelllPTJuge < 0) + { + nCelllPTJuge = 0; + } + } + /* < KEJ 20231123 - #4669 ADD End > */ + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]Cell [%02d]Condition CELL COUNT OK:[%d] TR[%d] PR[%d] PT[%d]") + , nCellIndex, nIdx, nCelllOKJuge, nCellTRJudge, nCelllPRJuge, nCelllPTJuge); } } @@ -2646,6 +2871,19 @@ m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE GLASS Defect PR Count[%d] [%d]"), nIdx, pRawData->GetGlassData()->m_nDefectNumJudgePR, pRcpJudgeInfo->GetJudgeCount()); } break; + /* < KEJ 20231123 - #4669 ADD Start > */ + case JudgeType_T8_PT: + if (pRawData->GetGlassData()->m_nDefectNumJudgePT >= pRcpJudgeInfo->GetJudgeCount()) + { + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]GLASS Defect PT Count[%d] >= [%d]"), nIdx, pRawData->GetGlassData()->m_nDefectNumJudgePT, pRcpJudgeInfo->GetJudgeCount()); + bReJudge = TRUE; + } + else + { + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE GLASS Defect PT Count[%d] [%d]"), nIdx, pRawData->GetGlassData()->m_nDefectNumJudgePT, pRcpJudgeInfo->GetJudgeCount()); + } + break; + /* < KEJ 20231123 - #4669 ADD End > */ } @@ -2695,6 +2933,18 @@ m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE GLASS Defect PR Count[%d] [%d]"), nIdx, pRawData->GetGlassData()->m_nDefectNumJudgePR, pRcpJudgeInfo->GetSubJudgeCount()); } break; + /* < KEJ 20231123 - #4669 ADD Start > */ + case JudgeType_T8_PT: + if (pRawData->GetGlassData()->m_nDefectNumJudgePT <= pRcpJudgeInfo->GetSubJudgeCount()) + { + bSubReJudge = TRUE; + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]GLASS Defect PT Count[%d] <= [%d]"), nIdx, pRawData->GetGlassData()->m_nDefectNumJudgePT, pRcpJudgeInfo->GetSubJudgeCount()); + } + else { + m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::ReviewEnd] [%02d]ELSE GLASS Defect PT Count[%d] [%d]"), nIdx, pRawData->GetGlassData()->m_nDefectNumJudgePT, pRcpJudgeInfo->GetSubJudgeCount()); + } + break; + /* < KEJ 20231123 - #4669 ADD End > */ } @@ -2852,86 +3102,175 @@ BOOL CSequenceProcessor_CPJT::FindRawBinFile(CString strFileName) { - //210128 - CString strFilePath = _T(""); - //pData->GetGlassData()->m_strFileName; - //strcpy(pData->GetGlassData()->m_strPath, AOIRAWBIN_PATH); - //strcpy(pData->GetGlassData()->m_strPath, LOCAL_AOIRAWBIN_PATH); + /* < KEJ 20240621 - #4942 MOD Start > */ +// /* < KJG 20230605 - #4517 ADD Start >*/ +// auto FuncStringSplit = [](string Sentence, char Separator, vector<string>& vec) +// { +// stringstream ss(Sentence); +// string tmp; +// +// while (getline(ss, tmp, Separator)) { +// vec.push_back(tmp); +// } +// }; +// /* < KJG 20230605 - #4517 ADD End >*/ +// +// //210128 +// CString strFilePath = _T(""); +// //pData->GetGlassData()->m_strFileName; +// //strcpy(pData->GetGlassData()->m_strPath, AOIRAWBIN_PATH); +// //strcpy(pData->GetGlassData()->m_strPath, LOCAL_AOIRAWBIN_PATH); +// +// strFilePath = AOIRAWBIN_PATH; +// +// CString strFindFile; +// int nCloseTime = 600 * 100000;//sec +// int nReTryTime = 30; +// { +// CTime tmReviewLoading = CTime::GetCurrentTime(); +// CString strWild; +// //strWild.Format("%s\\%s_*.bin", strFilePath, strFileName); +// CakFileUtil akFileFinder; +// while (nReTryTime--) +// { +// //#3359_LYW CF AOI Review REVIEW_LOADING_COMPLETE_TIMEOVER START +// if (nReTryTime%2 == 0) +// { +// strFilePath = AOIRAWBIN_NETWORK_DRIVE_PATH; +// } +// else strFilePath = AOIRAWBIN_PATH; +// +// //strWild.Format("%s\\%s_*.bin", strFilePath, strFileName); /* < KJG 20230605 - #4517 DEL >*/ +// //akFileFinder.FindFile(strWild.GetBuffer(0), FALSE); /* < KJG 20230605 - #4517 DEL >*/ +// +// /* < KJG 20230605 - #4517 ADD Start >*/ +// auto timeStart = chrono::steady_clock::now(); +// g_pLog->DisplayMessage(_T("[GlassLoading][FindRawBinFile] Start Find Path = %s, File Name = %s, TryCount = %d"), strFilePath, strFileName, 30 - nReTryTime); +// +// std::error_code err; +// vector<std::string> vtFileList; +// fs::path pathBinFile(strFilePath.GetBuffer(0)); +// int constexpr SaperatorCount = 4, DateSize = 8, TimeSize = 6; // GLASSID_STEPID_'YYYYMMDD'_'HHMMSS' �룷留� �솗�씤 +// for (auto iter = fs::directory_iterator(pathBinFile, err); iter != fs::directory_iterator(); iter++) +// { +// fs::path p = iter->path(); +// if (p.filename().stem().string().find(strFileName) != string::npos) +// { +// std::string strSearchFile = p.filename().stem().string(); +// if (p.extension().string() == _T(".bin")) +// { +// vtFileList.push_back(p.filename().stem().string()); +// } +// } +// } +// +// for (auto iter = vtFileList.begin(); iter != vtFileList.end(); ) +// { +// vector<string> vtSplit; +// FuncStringSplit(*iter, _T('_'), vtSplit); +// +// if (vtSplit.size() == SaperatorCount && vtSplit[2].size() == DateSize && vtSplit[3].size() == TimeSize) +// { +// iter++; +// } +// else +// { +// vtFileList.erase(iter); +// } +// } +// +// sort(vtFileList.begin(), vtFileList.end(), greater<>()); // 理쒖떊�닚�쑝濡� �젙�젹 +// +// string strPickFileName = vtFileList.empty() ? _T("NULL") : vtFileList.front(); +// g_pLog->DisplayMessage(_T("[GlassLoading][FindRawBinFile] End File Count = %d, Pick File Name = %s, Tact = %d, ErrorCode = %d, ErrorMsg = %s"), vtFileList.size(), strPickFileName.c_str(), chrono::duration_cast<chrono::milliseconds>(chrono::steady_clock::now() - timeStart).count(),err.value(), err.message().c_str()); +// +// if (vtFileList.empty() == FALSE) +// { +// vector<string> vtSplit; +// FuncStringSplit(strPickFileName, _T('_'), vtSplit); +// +// CTime tmTemp(stoi(vtSplit[2].substr(0, 4)), stoi(vtSplit[2].substr(4, 2)), stoi(vtSplit[2].substr(6, 2)), stoi(vtSplit[3].substr(0, 2)), stoi(vtSplit[3].substr(2, 2)), stoi(vtSplit[3].substr(4, 2))); +// CTimeSpan tmSpan = tmReviewLoading - tmTemp; +// +// if (tmSpan < nCloseTime) +// { +// strFindFile = strPickFileName.c_str(); +// g_pLog->DisplayMessage(_T("[GlassLoading][FindRawBinFile] Find File Success")); +// break; +// } +// } +// /* < KJG 20230605 - #4517 ADD End >*/ +// +// /* < KJG 20230605 - #4517 DEL Start >*/ +// //#3359_LYW CF AOI Review REVIEW_LOADING_COMPLETE_TIMEOVER END +// //VECFINDDATA* pFindData = akFileFinder.getFindData(); +// //int nFileNamePos = strlen(akFileFinder.getProcessPath()); +// //std::map<LONGLONG, CString> mapSpanFileName; +// //for (int i = 0; i < pFindData->size(); i++) +// //{ +// // char* pFileName = &((*pFindData)[i]).name[nFileNamePos]; +// // { +// // CakParser parser; +// // parser.process(pFileName, "_."); +// // if (parser.getTokNum() < 4) continue; +// // +// // if (parser.getTokNum() >= 6) continue; // 0401 +// // +// // int nDataTime[8] = {}; +// // { +// // int nTokIndex = 0; +// // const char* pGlassId = parser.getTokStr(nTokIndex++); +// // const char* pStepId = parser.getTokStr(nTokIndex++); +// // char* pDate = &pFileName[parser.getTokPos(nTokIndex++)]; +// // char* pTime = &pFileName[parser.getTokPos(nTokIndex++)]; +// // +// // nDataTime[0] = (pDate[0] - '0') * 1000 + (pDate[1] - '0') * 100 + (pDate[2] - '0') * 10 + (pDate[3] - '0') * 1; +// // nDataTime[1] = (pDate[4] - '0') * 10 + (pDate[5] - '0') * 1; +// // nDataTime[2] = (pDate[6] - '0') * 10 + (pDate[7] - '0') * 1; +// // nDataTime[3] = (pTime[0] - '0') * 10 + (pTime[1] - '0') * 1; +// // nDataTime[4] = (pTime[2] - '0') * 10 + (pTime[3] - '0') * 1; +// // nDataTime[5] = (pTime[4] - '0') * 10 + (pTime[5] - '0') * 1; +// // } +// // +// // CTime tmTemp(nDataTime[0], nDataTime[1], nDataTime[2], nDataTime[3], nDataTime[4], nDataTime[5]); +// // CTimeSpan tmSpan = tmReviewLoading - tmTemp; +// // mapSpanFileName.insert(std::make_pair(tmSpan.GetTotalSeconds(), pFileName)); +// // } +// //} +// // +// //if (mapSpanFileName.empty() == FALSE) +// //{ +// // if (mapSpanFileName.begin()->first < nCloseTime) +// // { +// // strFindFile = mapSpanFileName.begin()->second; +// // break; +// // } +// //} +// // +// //akFileFinder.clear(); +// /* < KJG 20230605 - #4517 DEL End >*/ +// +// +// Sleep(100); +// } +// } +// if (strFindFile.IsEmpty()) return FALSE; - strFilePath = AOIRAWBIN_PATH; - + CString strFilePath = _T(""); + + strFilePath = AOIRAWBIN_LOCAL_PATH; CString strFindFile; - int nCloseTime = 600 * 100000;//sec - int nReTryTime = 30; + strFindFile.Format(_T("%s\\%s.bin"), strFilePath, strFileName); + + CFile file; + if (!file.Open(strFindFile, CFile::modeRead)) { - CTime tmReviewLoading = CTime::GetCurrentTime(); - CString strWild; - //strWild.Format("%s\\%s_*.bin", strFilePath, strFileName); - CakFileUtil akFileFinder; - while (nReTryTime--) - { - //#3359_LYW CF AOI Review REVIEW_LOADING_COMPLETE_TIMEOVER START - if (nReTryTime%2 == 0) - { - strFilePath = AOIRAWBIN_PATH; - } - else strFilePath = AOIRAWBIN_NETWORK_DRIVE_PATH; - - strWild.Format("%s\\%s_*.bin", strFilePath, strFileName); - akFileFinder.FindFile(strWild.GetBuffer(0), FALSE); - //LYW LOG - g_pLog->DisplayMessage(_T("[GlassLoading][FindRawBinFile] Find Path = %s, RetryCount = %d, ResultCode = [%d]"), strFilePath, 30-nReTryTime, GetLastError()); - //#3359_LYW CF AOI Review REVIEW_LOADING_COMPLETE_TIMEOVER END - VECFINDDATA* pFindData = akFileFinder.getFindData(); - int nFileNamePos = strlen(akFileFinder.getProcessPath()); - std::map<LONGLONG, CString> mapSpanFileName; - for (int i = 0; i < pFindData->size(); i++) - { - char* pFileName = &((*pFindData)[i]).name[nFileNamePos]; - { - CakParser parser; - parser.process(pFileName, "_."); - if (parser.getTokNum() < 4) continue; - - if (parser.getTokNum() >= 6) continue; // 0401 - - int nDataTime[8] = {}; - { - int nTokIndex = 0; - const char* pGlassId = parser.getTokStr(nTokIndex++); - const char* pStepId = parser.getTokStr(nTokIndex++); - char* pDate = &pFileName[parser.getTokPos(nTokIndex++)]; - char* pTime = &pFileName[parser.getTokPos(nTokIndex++)]; - - nDataTime[0] = (pDate[0] - '0') * 1000 + (pDate[1] - '0') * 100 + (pDate[2] - '0') * 10 + (pDate[3] - '0') * 1; - nDataTime[1] = (pDate[4] - '0') * 10 + (pDate[5] - '0') * 1; - nDataTime[2] = (pDate[6] - '0') * 10 + (pDate[7] - '0') * 1; - nDataTime[3] = (pTime[0] - '0') * 10 + (pTime[1] - '0') * 1; - nDataTime[4] = (pTime[2] - '0') * 10 + (pTime[3] - '0') * 1; - nDataTime[5] = (pTime[4] - '0') * 10 + (pTime[5] - '0') * 1; - } - - CTime tmTemp(nDataTime[0], nDataTime[1], nDataTime[2], nDataTime[3], nDataTime[4], nDataTime[5]); - CTimeSpan tmSpan = tmReviewLoading - tmTemp; - mapSpanFileName.insert(std::make_pair(tmSpan.GetTotalSeconds(), pFileName)); - } - } - - if (mapSpanFileName.empty() == FALSE) - { - if (mapSpanFileName.begin()->first < nCloseTime) - { - strFindFile = mapSpanFileName.begin()->second; - break; - } - } - - akFileFinder.clear(); - Sleep(100); - } + g_pLog->DisplayMessage(_T("[GlassLoading][FindRawBinFile] Bin File Is Not Collect [%s]"), strFindFile); + return FALSE; } + file.Close(); - if (strFindFile.IsEmpty()) return FALSE; + /* < KEJ 20240621 - #4942 MOD End > */ return TRUE; } @@ -3642,7 +3981,9 @@ tmServerLoadingTime = CTime::GetCurrentTime(); m_pSP2P->ISP2P_DisplayMessage(_T("[SequenceProcessor::GlassLoading] access Shared Memory Fail")); strPath.Format(_T("%s\\%s_%04d%02d%02d%02d%02d%02d"), pNetworkInfo->m_strUploadImagePath, strGlassID, tmServerLoadingTime.GetYear(), tmServerLoadingTime.GetMonth(), tmServerLoadingTime.GetDay(), tmServerLoadingTime.GetHour(), tmServerLoadingTime.GetMinute(), tmServerLoadingTime.GetSecond()); - strImagePath.Format(_T("%s\\%s_%04d%02d%02d%02d%02d%02d"), strGlassID, tmServerLoadingTime.GetYear(), tmServerLoadingTime.GetMonth(), tmServerLoadingTime.GetDay(), tmServerLoadingTime.GetHour(), tmServerLoadingTime.GetMinute(), tmServerLoadingTime.GetSecond()); + //< SWK 20221226 - #4403 MOD > +// strImagePath.Format(_T("%s\\%s_%04d%02d%02d%02d%02d%02d"), strGlassID, tmServerLoadingTime.GetYear(), tmServerLoadingTime.GetMonth(), tmServerLoadingTime.GetDay(), tmServerLoadingTime.GetHour(), tmServerLoadingTime.GetMinute(), tmServerLoadingTime.GetSecond()); + strImagePath.Format(_T("%s_%04d%02d%02d%02d%02d%02d"), strGlassID, tmServerLoadingTime.GetYear(), tmServerLoadingTime.GetMonth(), tmServerLoadingTime.GetDay(), tmServerLoadingTime.GetHour(), tmServerLoadingTime.GetMinute(), tmServerLoadingTime.GetSecond()); CreateDirectory(strPath, NULL); pReviewProcessor->SetUploadImagePath(strPath); pReviewProcessor->SetReviewImagePath(strImagePath); @@ -4289,7 +4630,9 @@ { int XAddr = pMotorControl->GetGantryCollisionXAddr(pModuleStatus->GetGantryIndex()); g_pLog->DisplayMessage(_T("[Collision Position Set Fail] %d Module, Addr: %d, PosX: %.3lfmm"), nModuleIdx, XAddr, dCollisionPosX); - return 0; + /*< LYW 20220610 - #4185 Delete Start >*/ + //return 0; + /*< LYW 20220610 - #4185 Delete End >*/ } } @@ -4329,6 +4672,7 @@ // set offset ApplyMotorOffset(pReview->nModuleIdx, pReview->nZoomIdx, MotorOffsetCamera + MotorOffsetMag+MotorOffset_Glass, dDefectPosX, dDefectPosY); + m_pSP2P->CalcMotorOffSetValue(pReview->nModuleIdx, dDefectPosX, dDefectPosY); //< KEJ 20230622 - #4526 ADD > //xpostemp = dDefectPosX; //ypostemp = dDefectPosY; @@ -4587,7 +4931,9 @@ { int XAddr = pMotorControl->GetGantryCollisionXAddr(pModuleStatus->GetGantryIndex()); g_pLog->DisplayMessage(_T("[Collision Position Set Fail] %d Module, Addr: %d, PosX: %.3lfmm"), nModuleIdx, XAddr, dCollisionPosX); - return 0; + /*< LYW 20220610 - #4185 Delete Start >*/ + //return 0; + /*< LYW 20220610 - #4185 Delete End >*/ } } @@ -4627,6 +4973,7 @@ // set offset ApplyMotorOffset(pReview->nModuleIdx, pReview->nZoomIdx, MotorOffsetCamera + MotorOffsetMag + MotorOffset_Glass, dDefectPosX, dDefectPosY); + m_pSP2P->CalcMotorOffSetValue(pReview->nModuleIdx, dDefectPosX, dDefectPosY); //< KEJ 20230622 - #4526 ADD > //xpostemp = dDefectPosX; //ypostemp = dDefectPosY; @@ -4840,7 +5187,9 @@ { int XAddr = pMotorControl->GetGantryCollisionXAddr(pModuleStatus->GetGantryIndex()); g_pLog->DisplayMessage(_T("[Collision Position Set Fail] %d Module, Addr: %d, PosX: %.3lfmm"), nModuleIdx, XAddr, dCollisionPosX); - return 0; + /*< LYW 20220610 - #4185 Delete Start >*/ + //return 0; + /*< LYW 20220610 - #4185 Delete End >*/ } } @@ -4881,6 +5230,8 @@ // set offset ApplyMotorOffset(pWsi->nModuleIdx, -1, MotorOffsetCamera + MotorOffsetWSI + MotorOffset_Glass, dDefectPosX, dDefectPosY); + + m_pSP2P->CalcMotorOffSetValue(pWsi->nModuleIdx, dDefectPosX, dDefectPosY); //< KEJ 20230622 - #4526 ADD > m_pSP2P->GetOffSetValue(nModuleIdx, pWsi->nAOICameraIdx, pWsi->nAOIScanIdx, pWsi->nUMOriginX / 1000.0, xpostemp, ypostemp); @@ -8241,6 +8592,147 @@ return; } + +BOOL CSequenceProcessor_CPJT::CheckZeroReviewAlarm() +{ + CGlassResult* pGlassResult = m_pSP2P->ISP2P_GetCurrentGlassResult(); + if (pGlassResult == NULL) return FALSE; + + int TotalCount = 0; + + //Defect + const VectorReviewResult *pVecReviewResult = pGlassResult->GetVectorReviewResult(); + if (pVecReviewResult != NULL) + { + for (constVectorReviewResultIt it = pVecReviewResult->begin(); it != pVecReviewResult->end(); it++) + { + const CReviewResult *pReviewResult = static_cast<const CReviewResult*>(&(*it)); + + TotalCount += pReviewResult->m_vecSReviewResult.size(); + + for (constVectorSReviewResultIt its = pReviewResult->m_vecSReviewResult.begin(); its != pReviewResult->m_vecSReviewResult.end(); its++) + { + if (its->nResultCode > ReviewResult_None) + { + return TRUE; + } + else + { + continue; + } + } + } + } + + //DefectWSI + const VectorReviewResult *pVecWsiResult = pGlassResult->GetVectorWsiResult(); + if (pVecWsiResult != NULL) + { + for (constVectorReviewResultIt it = pVecWsiResult->begin(); it != pVecWsiResult->end(); it++) + { + const CReviewResult *pWsiResult = static_cast<const CReviewResult*>(&(*it)); + + TotalCount += pWsiResult->m_vecSReviewResult.size(); + + for (constVectorSReviewResultIt its = pWsiResult->m_vecSReviewResult.begin(); its != pWsiResult->m_vecSReviewResult.end(); its++) + { + if (its->nResultCode > WsiResult_None) + { + return TRUE; + } + else + { + continue; + } + } + } + } + + //User Review + const VectorReviewResult *pVecUserReviewResult = pGlassResult->GetVectorUserResult(); + if (pVecUserReviewResult != NULL) + { + for (constVectorReviewResultIt it = pVecUserReviewResult->begin(); it != pVecUserReviewResult->end(); it++) + { + const CReviewResult *pUserReviewResult = static_cast<const CReviewResult*>(&(*it)); + + TotalCount += pUserReviewResult->m_vecSReviewResult.size(); + + for (constVectorSReviewResultIt its = pUserReviewResult->m_vecSReviewResult.begin(); its != pUserReviewResult->m_vecSReviewResult.end(); its++) + { + if (its->nResultCode > ReviewResult_None) + { + return TRUE; + } + else + { + continue; + } + } + } + } + + //User WSI + const VectorReviewResult *pVecUserWsiResult = pGlassResult->GetVectorUserWsiResult(); + if (pVecUserWsiResult != NULL) + { + for (constVectorReviewResultIt it = pVecUserWsiResult->begin(); it != pVecUserWsiResult->end(); it++) + { + const CReviewResult *pUserWsiResult = static_cast<const CReviewResult*>(&(*it)); + + TotalCount += pUserWsiResult->m_vecSReviewResult.size(); + + for (constVectorSReviewResultIt its = pUserWsiResult->m_vecSReviewResult.begin(); its != pUserWsiResult->m_vecSReviewResult.end(); its++) + { + if (its->nResultCode > WsiResult_None) + { + return TRUE; + } + else + { + continue; + } + } + } + } + + if (TotalCount == 0) return TRUE; + + return FALSE; +} + +void CSequenceProcessor_CPJT::sendUploadResult2SequenceProcessor(int UploadResult) +{ + int UploadResultFailCount = GetUploadResultFailCount(); + if (UploadResult == FALSE) + { + UploadResultFailCount++; + m_pSP2P->ISP2P_DisplayMessage(_T("Upload Ack is False")); + if (UploadResultFailCount >= 3) + { + //SendSignalToSignalControl(PCControlSendSignalIndex_State, PCControlSend_ResultData_Upload_Fail, 1000); + m_nStackUploadFailGlassCount++; + m_pSP2P->ISP2P_DisplayMessage(_T("ResultFile Upload Fail Glass Count = %d"),m_nStackUploadFailGlassCount); + if (m_nStackUploadFailGlassCount >= m_pSP2P->ISP2P_System_GetNetworkInfo()->m_nResultFileUploadFailAlarmCondition) + { + SendSignalToSignalControl(PCControlSendSignalIndex_State, PCControlSend_ResultData_Upload_Fail, 1000); + m_nStackUploadFailGlassCount = 0; + m_pSP2P->ISP2P_DisplayMessage(_T("ResultFile Upload Fail Alarm!")); + } + SetUploadResultFailCount(-1); + } + else + { + SetUploadResultFailCount(UploadResultFailCount); + } + } + else + { + m_pSP2P->ISP2P_DisplayMessage(_T("Upload Ack is True")); + m_nStackUploadFailGlassCount = 0; + } +} + //#3358 KYH FDC ADD END DWORD CSequenceProcessor_CPJT::GetDiskUsage() @@ -9566,7 +10058,9 @@ { int XAddr = pMotorControl->GetGantryCollisionXAddr(pModuleStatus->GetGantryIndex()); g_pLog->DisplayMessage(_T("[Collision Position Set Fail] %d Module, Addr: %d, PosX: %.3lfmm"), nModuleIdx, XAddr, dCollisionPosX); - return 0; + /*< LYW 20220610 - #4185 Delete Start >*/ + //return 0; + /*< LYW 20220610 - #4185 Delete End >*/ } } @@ -9977,13 +10471,15 @@ int XAddr = pMotorControl->GetGantryCollisionXAddr(pModuleStatus->GetGantryIndex()); g_pLog->DisplayMessage(_T("[Review_CollisionPos] %d Module, Addr: %d, PosX: %.3lf mm"), nModuleIdx, XAddr, dCollisionPosX); - ///pGlassResult->SetCollisionXPos(nModuleIdx, dCollisionPosX); + //pGlassResult->SetCollisionXPos(nModuleIdx, dCollisionPosX); } else { int XAddr = pMotorControl->GetGantryCollisionXAddr(pModuleStatus->GetGantryIndex()); g_pLog->DisplayMessage(_T("[Collision Position Set Fail] %d Module, Addr: %d, PosX: %.3lfmm"), nModuleIdx, XAddr, dCollisionPosX); - return 0; + /*< LYW 20220610 - #4185 Delete Start >*/ + //return 0; + /*< LYW 20220610 - #4185 Delete End >*/ } // get result index int nStartIdx = pWsiMultiShotResult->GetStartSReviewResultIndex(); @@ -10482,6 +10978,30 @@ } } +/*< LYW 20220610 - #4185 ADD Start >*/ +void CSequenceProcessor_CPJT::CheckGantryMode() +{ + CSignalControl* pSignalControl = m_pSP2P->ISP2P_GetSignalControl(); + if (pSignalControl == NULL) m_pSP2P->ISP2P_DisplayMessage(_T("[CheckGantryMode] SignalControl is NULL")); + if (pSignalControl->IsConnected() == FALSE) m_pSP2P->ISP2P_DisplayMessage(_T("[CheckGantryMode] SignalControl is Not Connect")); + + int LeftGantryUse = 0; + int RightGantryUse = 0; + + pSignalControl->ReadData(_T("10003"), 1, 1, LeftGantryUse); + pSignalControl->ReadData(_T("10003"), 2, 1, RightGantryUse); + + if (LeftGantryUse == 1 && RightGantryUse == 0) + m_pSP2P->ISP2P_Recipe_GetRsRcpReviewInfo()->GetRcpSchedulingInfo()->SetSingleGantryPath(1); + else if (LeftGantryUse == 0 && RightGantryUse == 1) + m_pSP2P->ISP2P_Recipe_GetRsRcpReviewInfo()->GetRcpSchedulingInfo()->SetSingleGantryPath(2); + else + m_pSP2P->ISP2P_Recipe_GetRsRcpReviewInfo()->GetRcpSchedulingInfo()->SetSingleGantryPath(0); + + m_pSP2P->ISP2P_DisplayMessage(_T("[CheckGantryMode] GantryMode LeftBit = %d, RightBit = %d"), LeftGantryUse, RightGantryUse); +} +/*< LYW 20220610 - #4185 ADD End >*/ + BOOL CSequenceProcessor_CPJT::UpdateMemoryUserReflowPlanInfo(CDitGlassRawClient* pDitSharedGlassRaw) { CRsRcpReviewInfo* pRecipeinfo = m_pSP2P->ISP2P_Recipe_GetRsRcpReviewInfo(); -- Gitblit v1.9.3