IoLP.cs 55 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225
  1. using Aitex.Core.Common;
  2. using Aitex.Core.RT.DataCenter;
  3. using Aitex.Core.RT.Device;
  4. using Aitex.Core.RT.Device.Unit;
  5. using Aitex.Core.RT.Event;
  6. using Aitex.Core.RT.IOCore;
  7. using Aitex.Core.RT.Log;
  8. using Aitex.Core.RT.OperationCenter;
  9. using Aitex.Core.RT.SCCore;
  10. using Aitex.Core.Util;
  11. using Aitex.Sorter.Common;
  12. using FabConnect.SecsGemInterface.Common.ToolModel;
  13. using FACore.E87FA;
  14. using FurnaceRT.Equipments.LPs;
  15. using FurnaceRT.Equipments.PMs;
  16. using FurnaceRT.Equipments.Systems;
  17. using log4net.Repository.Hierarchy;
  18. using MECF.Framework.Common.Equipment;
  19. using MECF.Framework.Common.SubstrateTrackings;
  20. using MECF.Framework.FA.Core.E87FA;
  21. using MECF.Framework.FA.Core.FAControl;
  22. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.CarrierIdReaders.CarrierIDReaderBase;
  23. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts;
  24. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.LoadPortBase;
  25. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.TDK;
  26. using System;
  27. using System.Collections.Generic;
  28. using System.Linq;
  29. using System.Text;
  30. using System.Threading.Tasks;
  31. using System.Xml;
  32. using static Aitex.Core.RT.Device.Unit.IOE84Passive;
  33. using static MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.LoadPortBase.LoadPortBaseDevice;
  34. namespace FurnaceRT.Devices
  35. {
  36. public class IoLP : BaseDevice, IDevice, ILoadPort
  37. {
  38. private DIAccessor _diLeftClamp;
  39. private DIAccessor _diRightClamp;
  40. private DIAccessor _diLeftRelease;
  41. private DIAccessor _diRightRelease;
  42. private DIAccessor _diInPosition1;
  43. private DIAccessor _diInPosition2;
  44. private DIAccessor _diInPosition3;
  45. private DIAccessor _diDetect;
  46. private DOAccessor _doClamp;
  47. private DOAccessor _doRelease;
  48. private DOAccessor _doPresenceLight;
  49. private DOAccessor _doPlacementLight;
  50. private DOAccessor _doLoadLight;
  51. private DOAccessor _doUnloadLight;
  52. private DOAccessor _doManualLight;
  53. private IoSensor _foupPresentSensor;
  54. private bool _isSimulatorMode;
  55. private string _previousAccessMode = "";
  56. public bool IsFoupPresent
  57. {
  58. get
  59. {
  60. if (_diInPosition1 != null && _diInPosition2 != null && _diInPosition3 != null && _doPresenceLight != null)
  61. {
  62. // _doPresenceLight.Value = _diInPosition1.Value && _diInPosition2.Value && _diInPosition3.Value;
  63. _doPlacementLight.Value = _diInPosition1.Value && _diInPosition2.Value && _diInPosition3.Value;
  64. }
  65. if (_diInPosition1 != null && _diInPosition2 != null && _diInPosition3 != null && _diDetect != null && _doPlacementLight != null)
  66. {
  67. // _doPlacementLight.Value = _diDetect.Value && _diInPosition1.Value && _diInPosition2.Value && _diInPosition3.Value;
  68. _doPresenceLight.Value = _diDetect.Value;
  69. }
  70. if (_diInPosition1 != null && _diInPosition2 != null && _diInPosition3 != null && _diDetect != null)
  71. return _diInPosition1.Value && _diInPosition2.Value && _diInPosition3.Value && _diDetect.Value;
  72. return false;
  73. }
  74. }
  75. public DeviceStatus Status
  76. {
  77. get
  78. {
  79. if (_diLeftClamp != null && _diRightClamp != null && _diLeftRelease != null && _diRightRelease != null &&
  80. _diLeftClamp.Value && _diRightClamp.Value && !_diLeftRelease.Value && !_diRightRelease.Value)
  81. return DeviceStatus.Clamp;
  82. if (_diLeftClamp != null && _diRightClamp != null && _diLeftRelease != null && _diRightRelease != null &&
  83. !_diLeftClamp.Value && !_diRightClamp.Value && _diLeftRelease.Value && _diRightRelease.Value)
  84. return DeviceStatus.Release;
  85. return DeviceStatus.Unknown;
  86. }
  87. }
  88. public CarrierInfo CurrentCarrier
  89. {
  90. get
  91. {
  92. return CarrierManager.Instance.GetCarrier(Name);
  93. }
  94. }
  95. public bool ReadIDReady { get; set; } = true;
  96. private E84Passiver _e84;
  97. public RD_TRIG _trtbtrg = new RD_TRIG();
  98. public R_TRIG _cstAddtrg = new R_TRIG();
  99. public R_TRIG _cstRemovetrg = new R_TRIG();
  100. public bool IsLoadCompleted { get; set; }
  101. public bool IsUnloadCompleted { get; set; }
  102. public bool IsInitCompleted { get; set; }
  103. public CarrierOnLPState m_CarrierOnState { get; set; } = CarrierOnLPState.Unknow;
  104. public IoLP(string module, XmlElement node, string ioModule = "")
  105. {
  106. base.Module = string.IsNullOrEmpty(node.GetAttribute("module")) ? module : node.GetAttribute("module");
  107. base.Name = node.GetAttribute("id");
  108. base.Display = node.GetAttribute("display");
  109. base.DeviceID = node.GetAttribute("schematicId");
  110. LPModuleName = (ModuleName)Enum.Parse(typeof(ModuleName), Name);
  111. _diLeftClamp = ParseDiNode("diLeftClamp", node, ioModule);
  112. _diRightClamp = ParseDiNode("diRightClamp", node, ioModule);
  113. _diLeftRelease = ParseDiNode("diLeftRelease", node, ioModule);
  114. _diRightRelease = ParseDiNode("diRightRelease", node, ioModule);
  115. _diInPosition1 = ParseDiNode("diInPosition1", node, ioModule);
  116. _diInPosition2 = ParseDiNode("diInPosition2", node, ioModule);
  117. _diInPosition3 = ParseDiNode("diInPosition3", node, ioModule);
  118. _diDetect = ParseDiNode("diDetect", node, ioModule);
  119. _doClamp = ParseDoNode("doClamp", node, ioModule);
  120. _doRelease = ParseDoNode("doRelease", node, ioModule);
  121. _doPresenceLight = ParseDoNode("doPresence", node, ioModule);
  122. _doPlacementLight = ParseDoNode("doPlacement", node, ioModule);
  123. _doLoadLight = ParseDoNode("doLoad", node, ioModule);
  124. _doUnloadLight = ParseDoNode("doUnload", node, ioModule);
  125. _doManualLight = ParseDoNode("doManual", node, ioModule);
  126. }
  127. public bool Initialize()
  128. {
  129. _isSimulatorMode = SC.GetValue<bool>("System.IsSimulatorMode");
  130. DATA.Subscribe($"{Module}.{Name}.UIFoupSensor", () => GetUIFoupSensor(), SubscriptionAttribute.FLAG.IgnoreSaveDB);
  131. DATA.Subscribe($"{Name}.DeviceStatus", () => Status.ToString());
  132. var foupSensorID = Name == "LP1" ? "17" : "18";
  133. if (SC.GetStringValue("LoadPort.LoadPortPosition") == "Upper")
  134. {
  135. foupSensorID += "A";
  136. }
  137. _foupPresentSensor = DEVICE.GetDevice<IoSensor>($"System.SensorStation{foupSensorID}Presence");
  138. OP.Subscribe($"{Module}.{Name}.SetClamp", (string cmd, object[] param) =>
  139. {
  140. Clamp(out string reason);
  141. return true;
  142. });
  143. OP.Subscribe($"{Module}.{Name}.SetRelease", (string cmd, object[] param) =>
  144. {
  145. Unclamp(out string reason);
  146. return true;
  147. });
  148. SubscribeDataVariable();
  149. SubscribeAlarm();
  150. return true;
  151. }
  152. public void Monitor()
  153. {
  154. var accessMode = DATA.Poll($"{Name}.AccessMode");
  155. if (accessMode != null)
  156. {
  157. if (accessMode.ToString().ToUpper() == "AUTO")
  158. {
  159. //auto时候,默认是夹紧状态
  160. if (_doClamp != null)
  161. {
  162. if (!_doClamp.Value && _previousAccessMode != accessMode.ToString())
  163. {
  164. Clamp(out _);
  165. }
  166. }
  167. }
  168. if (accessMode.ToString().ToUpper() == "MANUAL")
  169. {
  170. ///1.manual模式,如果没有foup,不夹紧
  171. //2.manual模式,如果有foup,同时有load job,要夹紧,取走之后,不夹紧
  172. if (!IsFoupPresent && _doRelease != null && !_doRelease.Value && _previousAccessMode != accessMode.ToString())
  173. {
  174. Unclamp(out _);
  175. }
  176. }
  177. _previousAccessMode = accessMode.ToString();
  178. }
  179. if (ModuleHelper.IsLoadPort(ModuleHelper.Converter(Name)))
  180. {
  181. var lpFoupInfo = CarrierManager.Instance.GetCarrier(Name);
  182. if (lpFoupInfo != null)
  183. {
  184. SetVisibility(lpFoupInfo, !lpFoupInfo.IsEmpty);
  185. Singleton<EquipmentManager>.Instance.SetUIWaferCount(lpFoupInfo, ModuleHelper.Converter(Name), out var wafers);
  186. }
  187. }
  188. if (_e84 == null)
  189. _e84 = DEVICE.GetDevice<E84Passiver>($"{Name}.Loadport{Name.Replace("LP", "")}E84");
  190. //RecordSignalChange();
  191. //MonitorIndicator();
  192. MonitorCSTADD();
  193. MonitorCSTRemove();
  194. }
  195. public void MonitorCSTRemove()
  196. {
  197. _cstRemovetrg.CLK = !IsFoupPresent;
  198. if (!CurrentCarrier.IsEmpty)
  199. {
  200. if (_cstRemovetrg.Q)
  201. {
  202. if (IsUnloadCompleted)
  203. {
  204. ConfirmRemoveCarrier();
  205. }
  206. else if (IsLoadCompleted)
  207. {
  208. _carrierId = "";
  209. }
  210. }
  211. }
  212. }
  213. protected virtual void ConfirmRemoveCarrier()
  214. {
  215. _isPlaced = false;
  216. //IsComplete = false;
  217. _isMapped = false;
  218. //if (m_CarrierOnState != CarrierOnLPState.Off)
  219. {
  220. if (m_CarrierOnState == CarrierOnLPState.On)
  221. {
  222. //if (_lpE84Callback != null && IsAccessAuto)
  223. //{
  224. // if (_lpE84Callback.GetCurrentE84State() != E84State.Busy ||
  225. // !_lpE84Callback.GetE84SignalState(E84SignalID.VALID))
  226. // {
  227. // OnError("Unexpected carrier removed on access auto");
  228. // }
  229. //}
  230. }
  231. WaferManager.Instance.DeleteWafer(ModuleHelper.Converter(Name), 0, 25);
  232. //for (int i = 0; i < 25; i++)
  233. //{
  234. // WaferManager.Instance.DeleteWafer(ModuleHelper.Converter(Name), 0, 25);
  235. //}
  236. var removeCarrierID = _carrierId;
  237. if (CarrierManager.Instance.CheckHasCarrier(Name, 0))
  238. removeCarrierID = CarrierManager.Instance.GetCarrier(Name, 0).CarrierId;
  239. m_CarrierOnState = CarrierOnLPState.Off;
  240. SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
  241. FaLoadPort faLoadPort = FALoadPortManager.Instance.GetLoadPort(PortID);
  242. // No_state = 0,
  243. //Manual,
  244. //Auto,
  245. if (faLoadPort != null && faLoadPort.GetAccessMode() == 1)
  246. Singleton<FAJobController>.Instance.Eqp_NoteCarrierRemoved(PortID, true);
  247. else
  248. Singleton<FAJobController>.Instance.Eqp_NoteCarrierRemoved(PortID, false);
  249. dvid["PortID"] = PortID;
  250. dvid["PORT_CTGRY"] = SpecPortName;
  251. dvid["CarrierType"] = SpecCarrierType;
  252. dvid["CarrierIndex"] = InfoPadCarrierIndex;
  253. //dvid["InfoPadSensorIndex"] = InfoPadSensorIndex;
  254. dvid["CarrierID"] = removeCarrierID ?? "";
  255. dvid["CAR_ID"] = removeCarrierID ?? "";
  256. EV.Notify(EventCarrierRemoved, dvid);
  257. //EV.Notify(EventCarrierRemoved1, dvid);
  258. CarrierManager.Instance.DeleteCarrier(Name);
  259. if (_lpcallback != null) _lpcallback.CarrerRemove(removeCarrierID);
  260. EV.PostInfoLog(Name, $"{LPModuleName} carrier:{removeCarrierID} was removed.");
  261. _carrierId = "";
  262. }
  263. }
  264. public void MonitorCSTADD()
  265. {
  266. _cstAddtrg.CLK = IsFoupPresent;
  267. _trtbtrg.CLK = IsUnloadCompleted;
  268. if (IsUnloadCompleted)
  269. {
  270. FaLoadPort faLoadPort = FALoadPortManager.Instance.GetLoadPort(PortID);
  271. if (faLoadPort != null)
  272. {
  273. // No_state = 0,
  274. //Manual,
  275. //Auto,
  276. if (!IsFoupPresent && _trtbtrg.R)
  277. {
  278. if (faLoadPort.LoadPortTransferStateMachine.TransferState != FACore.E87FA.LPTransferState.OUT_OF_SERVICE &&
  279. faLoadPort.LoadPortTransferStateMachine.TransferState != FACore.E87FA.LPTransferState.READY_TO_LOAD)
  280. {
  281. FALoadPortManager.Instance.EqpInformLoadPortTransferReady(PortID, IsFoupPresent);
  282. }
  283. }
  284. if (_trtbtrg.R && IsFoupPresent)
  285. {
  286. if (faLoadPort.LoadPortTransferStateMachine.TransferState != FACore.E87FA.LPTransferState.OUT_OF_SERVICE &&
  287. faLoadPort.LoadPortTransferStateMachine.TransferState != FACore.E87FA.LPTransferState.READY_TO_UNLOAD)
  288. {
  289. FALoadPortManager.Instance.EqpInformLoadPortTransferReady(PortID, IsFoupPresent, CurrentCarrier.CarrierId);
  290. }
  291. }
  292. }
  293. }
  294. else if (!IsUnloadCompleted)
  295. {
  296. FaLoadPort faLoadPort = FALoadPortManager.Instance.GetLoadPort(PortID);
  297. if (faLoadPort != null)
  298. {
  299. if (faLoadPort.LoadPortTransferStateMachine.TransferState != FACore.E87FA.LPTransferState.OUT_OF_SERVICE &&
  300. faLoadPort.LoadPortTransferStateMachine.TransferState != FACore.E87FA.LPTransferState.TRANSFER_BLOCKED)
  301. {
  302. FALoadPortManager.Instance.EqpInformLoadPortTransferBlock(PortID);
  303. }
  304. }
  305. }
  306. if (_cstAddtrg.Q && IsUnloadCompleted)
  307. {
  308. if (!Singleton<EquipmentManager>.Instance.IsAutoMode && !Singleton<EquipmentManager>.Instance.IsReturnWaferMode)
  309. {
  310. if (!CarrierManager.Instance.CheckHasCarrier(Name, 0))
  311. {
  312. LOG.Info($"{Name} IsUnloadCompleted exec CreateCarrier");
  313. CarrierManager.Instance.CreateCarrier(Name, CarrierType.SD, Name);
  314. }
  315. }
  316. ConfirmAddCarrier();
  317. }
  318. }
  319. protected virtual void ConfirmAddCarrier()
  320. {
  321. _isPlaced = true;
  322. //IsComplete = false;
  323. //if (m_CarrierOnState != CarrierOnLPState.On)
  324. {
  325. if (m_CarrierOnState == CarrierOnLPState.Off)
  326. {
  327. //if (_lpE84Callback != null && IsAccessAuto)
  328. //{
  329. // if (_lpE84Callback.GetCurrentE84State() != E84State.Busy ||
  330. // !_lpE84Callback.GetE84SignalState(E84SignalID.VALID))
  331. // {
  332. // OnError("Unexpected carrier placed on access auto");
  333. // }
  334. //}
  335. }
  336. if (CarrierManager.Instance.GetCarrier(Name).IsEmpty)
  337. {
  338. LOG.Info($"{Name} ConfirmAddCarrier exec CreateCarrier");
  339. CarrierManager.Instance.CreateCarrier(Name);
  340. }
  341. m_CarrierOnState = CarrierOnLPState.On;
  342. Singleton<FAJobController>.Instance.Eqp_NoteCarrierArrived(PortID);
  343. var lpmodule = Singleton<EquipmentManager>.Instance.Modules[ModuleHelper.Converter(Name)] as LoadPortModule;
  344. FaLoadPort faLoadPort = FALoadPortManager.Instance.GetLoadPort(PortID);
  345. if (faLoadPort.GetAccessMode() == 1)
  346. {
  347. EV.PostInfoLog(Name, $"{LPModuleName} ReadID.");
  348. ReadIDReady = false;
  349. lpmodule.Invoke("ReadID");
  350. }
  351. if (_lpcallback != null)
  352. _lpcallback.CarrierArrive();
  353. _isMapped = false;
  354. EV.PostInfoLog(Name, $"{LPModuleName} carrier arrived.");
  355. }
  356. }
  357. public bool GetUIFoupSensor()
  358. {
  359. var foupInfo = CarrierManager.Instance.GetCarrier(Name);
  360. if (SC.GetValue<bool>("System.IsSimulatorMode"))
  361. {
  362. if (foupInfo != null && !foupInfo.IsEmpty)
  363. {
  364. return true;
  365. }
  366. }
  367. else
  368. {
  369. if (IsFoupPresent && foupInfo != null && !foupInfo.IsEmpty)
  370. {
  371. return true;
  372. }
  373. }
  374. return false;
  375. }
  376. public void SetVisibility(CarrierInfo carrierInfo, bool setValue)
  377. {
  378. if (carrierInfo == null)
  379. {
  380. return;
  381. }
  382. carrierInfo.UIExitFoup = setValue;
  383. carrierInfo.UICarrierColorVisibility = setValue;
  384. carrierInfo.UICarrierStatusVisibility = setValue;
  385. carrierInfo.UICarrierTypeVisibility = setValue;
  386. carrierInfo.UICarrierWaferCountVisibility = setValue;
  387. carrierInfo.UICarrierType = carrierInfo.CarrierType.ToString();
  388. var contianPM1 = Singleton<EquipmentManager>.Instance.Modules.ContainsKey(ModuleName.PM1);
  389. if (contianPM1 && !string.IsNullOrEmpty(carrierInfo.UICarrierType))
  390. {
  391. var pmModule = Singleton<EquipmentManager>.Instance.Modules[ModuleName.PM1] as PMModule;
  392. carrierInfo.UICarrierColor = pmModule.GetCarrierUIColor(carrierInfo.UICarrierType, carrierInfo.UICarrierStatusEnum);
  393. }
  394. }
  395. public void Reset()
  396. {
  397. }
  398. public void ReadIDComplete(string id)
  399. {
  400. ReadIDReady = true;
  401. EV.PostInfoLog(LPModuleName.ToString(), $"{LPModuleName} ReadIDComplete");
  402. Singleton<FAJobController>.Instance.Eqp_NoteCarrierIdRead(PortID, id);
  403. _carrierId = id;
  404. SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
  405. dvid["PortID"] = PortID;
  406. dvid["PORT_CTGRY"] = SpecPortName;
  407. dvid["CarrierType"] = SpecCarrierType;
  408. dvid["CarrierIndex"] = InfoPadCarrierIndex;
  409. EV.Notify(EventCarrierArrived, dvid);
  410. dvid = new SerializableDictionary<string, object>();
  411. dvid["CarrierID"] = _carrierId ?? "";
  412. dvid["CAR_ID"] = _carrierId ?? "";
  413. dvid["PORT_ID"] = PortID;
  414. dvid["PortID"] = PortID;
  415. dvid["PORT_CTGRY"] = SpecPortName;
  416. dvid["PORT_CARRIER_TYPE"] = InfoPadCarrierType;
  417. EV.Notify(EventCarrierIdRead, dvid);
  418. }
  419. public void Terminate()
  420. {
  421. }
  422. //private bool SetExtend(out string reason, int time, object[] param)
  423. //{
  424. // reason = "";
  425. // if (param == null || param.Length == 0)
  426. // {
  427. // reason = "invalid parameter";
  428. // return false;
  429. // }
  430. // bool.TryParse(param[0].ToString(), out bool isExtend);
  431. // return SetExtend(isExtend, out reason);
  432. //}
  433. //public bool SetExtend(bool isExtend, out string reason)
  434. //{
  435. // return _doExtend.SetValue(isExtend, out reason) && _doRetract.SetValue(!isExtend, out reason);
  436. //}
  437. #region ILoadPort
  438. public IndicatorState IndicatiorLoad { get; set; }
  439. public IndicatorState IndicatiorUnload { get; set; }
  440. public IndicatorState IndicatiorPresence { get; set; }
  441. public IndicatorState IndicatorAlarm { get; set; }
  442. public IndicatorState IndicatiorPlacement { get; set; }
  443. public IndicatorState IndicatiorOpAccess { get; set; }
  444. public IndicatorState IndicatiorAccessAuto { get; set; }
  445. public IndicatorState IndicatiorAccessManual { get; set; }
  446. public IndicatorState IndicatiorStatus1 { get; set; }
  447. public IndicatorState IndicatiorStatus2 { get; set; }
  448. public IndicatorState IndicatiorManualMode { get; set; }
  449. public IndicatorState IndicatiorClampUnclamp { get; set; }
  450. public IndicatorState IndicatiorDockUndock { get; set; }
  451. public static Dictionary<IndicatorType, Indicator> LoadPortIndicatorLightMap =
  452. new Dictionary<IndicatorType, Indicator>()
  453. {
  454. {IndicatorType.Load, Indicator.LOAD},
  455. {IndicatorType.Unload, Indicator.UNLOAD},
  456. {IndicatorType.AccessAuto, Indicator.ACCESSAUTO },
  457. {IndicatorType.AccessManual, Indicator.ACCESSMANUL},
  458. {IndicatorType.Alarm, Indicator.ALARM},
  459. {IndicatorType.Presence, Indicator.PRESENCE},
  460. {IndicatorType.Placement, Indicator.PLACEMENT},
  461. {IndicatorType.Status1, Indicator.RESERVE1},
  462. {IndicatorType.Status2, Indicator.RESERVE2},
  463. };
  464. public virtual DeviceState State
  465. {
  466. get
  467. {
  468. if (MapError || ReadCarrierIDError)
  469. {
  470. return DeviceState.Error;
  471. }
  472. return DeviceState.Unknown;
  473. }
  474. }
  475. public bool IsPresent
  476. {
  477. get { return _isPresent; }
  478. }
  479. public bool IsPlacement
  480. {
  481. get { return _isPlaced; }
  482. }
  483. public bool IsMapped
  484. {
  485. get { return _isMapped; }
  486. }
  487. public virtual bool IsError { get; set; }
  488. public virtual string ErrorCode { get; set; } = "";
  489. public bool MapError { get; protected set; }
  490. public bool ReadCarrierIDError { get; set; }
  491. public IndicatorState[] IndicatorStateFeedback { get; set; }
  492. public virtual FoupClampState ClampState { get; set; }
  493. public virtual FoupDockState DockState { get; set; }
  494. public virtual FoupDoorState DoorState { get; set; }
  495. public virtual FoupDoorPostionEnum DoorPosition { get; set; }
  496. public virtual bool IsVacuumON { get; set; }
  497. public virtual CasstleType CasstleType { get; set; }
  498. public string SlotMap
  499. {
  500. get { return GetSlotMap(); }
  501. }
  502. public string CarrierId
  503. {
  504. get { return _carrierId; }
  505. }
  506. public string LPLotID
  507. {
  508. get { return _lplotID; }
  509. }
  510. public RD_TRIG PresentTrig
  511. {
  512. get { return _presentTrig; }
  513. }
  514. public RD_TRIG PlacedtTrig
  515. {
  516. get { return _placetTrig; }
  517. }
  518. public RD_TRIG AccessSwPressedTrig
  519. {
  520. get { return _accessSwPressedTrig; }
  521. }
  522. public RD_TRIG ClampedTrig
  523. {
  524. get { return _clampTrig; }
  525. }
  526. public RD_TRIG DockTrig
  527. {
  528. get { return _dockTrig; }
  529. }
  530. public RD_TRIG DoorTrig
  531. {
  532. get { return _doorTrig; }
  533. }
  534. protected virtual bool _isPresent { get; set; }
  535. protected virtual bool _isPlaced { get; set; }
  536. protected bool _isDocked { get => DockState == FoupDockState.Docked; }
  537. public string InfoPadCarrierType { get; set; }
  538. protected bool _isAccessSwPressed;
  539. protected string _carrierId = string.Empty;
  540. protected string _rfid;
  541. protected string _lplotID;
  542. protected bool _isMapped;
  543. private readonly RD_TRIG _presentTrig = new RD_TRIG();
  544. private readonly RD_TRIG _placetTrig = new RD_TRIG();
  545. private readonly RD_TRIG _accessSwPressedTrig = new RD_TRIG();
  546. private readonly RD_TRIG _clampTrig = new RD_TRIG();
  547. private readonly RD_TRIG _dockTrig = new RD_TRIG();
  548. private readonly RD_TRIG _doorTrig = new RD_TRIG();
  549. public R_TRIG TrigWaferProtrude = new R_TRIG();
  550. public int PortID
  551. {
  552. get => (int)LPModuleName;
  553. }
  554. protected string EventCarrierArrived = "CARRIER_ARRIVED";
  555. protected string EventCarrierIdRead = "CARRIER_ID_READ";
  556. protected string EventCarrierIdReadFailed = "CARRIER_ID_READ_FAILED";
  557. protected string EventCarrierIdWrite = "CARRIER_ID_WRITE";
  558. protected string EventCarrierIdWriteFailed = "CARRIER_ID_WRITE_FAILED";
  559. protected string EventSlotMapAvailable = "SLOT_MAP_AVAILABLE";
  560. protected string EventCarrierRemoved = "CARRIER_REMOVED";
  561. protected string EventCarrierUnloaded = "CARRIER_UNLOADED";
  562. protected string EventCarrierLoaded = "CARRIER_LOADED";
  563. protected string EventLPHomed = "LP_HOMED";
  564. //protected string PORT_ID = "PORT_ID";
  565. //protected string CAR_ID = "CAR_ID";
  566. //protected string SLOT_MAP = "SLOT_MAP";
  567. //protected string PORT_CTGRY = "PORT_CTGRY";
  568. //protected string RF_ID = "RF_ID";
  569. //protected string PORT_CARRIER_TYPE = "PORT_CARRIER_TYPE";
  570. private string EventRfIdRead = "RF_ID_READ";
  571. private string EventRfIdReadFailed = "RF_ID_READ_FAILED";
  572. private string EventRfIdWrite = "RF_ID_WRITE";
  573. private string EventRfIdWriteFailed = "RF_ID_WRITE_FAILED";
  574. public string AlarmLoadPortError { get => LPModuleName.ToString() + "Error"; }
  575. public string AlarmLoadPortCommunicationError { get => LPModuleName.ToString() + "CommunicationError"; }
  576. public string AlarmLoadPortWaferProtrusion { get => LPModuleName.ToString() + "WaferProtrusion"; }
  577. public string AlarmLoadPortLoadTimeOut { get => LPModuleName.ToString() + "LoadTimeOut"; }
  578. public string AlarmLoadPortLoadFailed { get => LPModuleName.ToString() + "LoadFailed"; }
  579. public string AlarmLoadPortUnloadTimeOut { get => LPModuleName.ToString() + "UnloadTimeOut"; }
  580. public string AlarmLoadPortUnloadFailed { get => LPModuleName.ToString() + "UnloadFailed"; }
  581. public string AlarmLoadPortMappingError { get => LPModuleName.ToString() + "MappingError"; }
  582. public string AlarmLoadPortMappingTimeout { get => LPModuleName.ToString() + "MappingTimeout"; }
  583. public string AlarmCarrierIDReadError { get => LPModuleName.ToString() + "CarrierIDReadFail"; }
  584. public string AlarmCarrierIDWriteError { get => LPModuleName.ToString() + "CarrierIDWriteFail"; }
  585. public string AlarmLoadPortHomeFailed { get => LPModuleName.ToString() + "HomeFailed"; }
  586. public string AlarmLoadPortHomeTimeout { get => LPModuleName.ToString() + "HomeTimeout"; }
  587. public string AlarmLoadE84TP1Timeout { get => LPModuleName.ToString() + "E84LoadTP1TimeOut"; }
  588. public string AlarmLoadE84TP2Timeout { get => LPModuleName.ToString() + "E84LoadTP2TimeOut"; }
  589. public string AlarmLoadE84TP3Timeout { get => LPModuleName.ToString() + "E84LoadTP3TimeOut"; }
  590. public string AlarmLoadE84TP4Timeout { get => LPModuleName.ToString() + "E84LoadTP4TimeOut"; }
  591. public string AlarmLoadE84TP5Timeout { get => LPModuleName.ToString() + "E84LoadTP5TimeOut"; }
  592. public string AlarmLoadE84TP6Timeout { get => LPModuleName.ToString() + "E84LoadTP6TimeOut"; }
  593. public string AlarmUnloadE84TP1Timeout { get => LPModuleName.ToString() + "E84UnloadTP1TimeOut"; }
  594. public string AlarmUnloadE84TP2Timeout { get => LPModuleName.ToString() + "E84UnloadTP2TimeOut"; }
  595. public string AlarmUnloadE84TP3Timeout { get => LPModuleName.ToString() + "E84UnloadTP3TimeOut"; }
  596. public string AlarmUnloadE84TP4Timeout { get => LPModuleName.ToString() + "E84UnloadTP4TimeOut"; }
  597. public string AlarmUnloadE84TP5Timeout { get => LPModuleName.ToString() + "E84UnloadTP5TimeOut"; }
  598. public string AlarmUnloadE84TP6Timeout { get => LPModuleName.ToString() + "E84UnloadTP6TimeOut"; }
  599. public string AlarmLoadPortMapCrossedWafer => LPModuleName.ToString() + "MapCrossedWafer";
  600. public string AlarmLoadPortMapDoubleWafer => LPModuleName.ToString() + "MapDoubleWafer";
  601. public string AlarmLoadPortMapUnknownWafer => LPModuleName.ToString() + "MapUnknownWafer";
  602. public string AlarmLoadPortCarrierIDIndexConfigError => LPModuleName.ToString() + "LoadPortCarrierIDIndexConfigError";
  603. private IE87CallBack _lpcallback = null;
  604. public IE87CallBack LPCallBack
  605. {
  606. get { return _lpcallback; }
  607. set { _lpcallback = value; }
  608. }
  609. private IE84CallBack _lpE84Callback = null;
  610. public IE84CallBack LPE84Callback
  611. {
  612. get { return _lpE84Callback; }
  613. set
  614. {
  615. _lpE84Callback = value;
  616. _lpE84Callback.OnE84ActiveSignalChange += _lpE84Callback_OnE84ActiveSignalChange;
  617. _lpE84Callback.OnE84PassiveSignalChange += _lpE84Callback_OnE84PassiveSignalChange;
  618. _lpE84Callback.OnE84HandOffComplete += _lpE84Callback_OnE84HandOffComplete;
  619. _lpE84Callback.OnE84HandOffStart += _lpE84Callback_OnE84HandOffStart;
  620. _lpE84Callback.OnE84HandOffTimeout += _lpE84Callback_OnE84HandOffTimeout;
  621. }
  622. }
  623. private ICarrierIDReader _carrierIDReadercallback = null;
  624. public ICarrierIDReader CarrierIDReaderCallBack
  625. {
  626. get { return _carrierIDReadercallback; }
  627. set { _carrierIDReadercallback = value; }
  628. }
  629. public virtual CIDReaderBaseDevice CurrentReader
  630. {
  631. get;
  632. set;
  633. }
  634. public virtual CIDReaderBaseDevice[] CIDReaders
  635. {
  636. get;
  637. set;
  638. }
  639. public virtual bool IsBypassCarrierIDReader
  640. {
  641. get
  642. {
  643. return SC.ContainsItem($"LoadPort.{LPModuleName}.BypassCarrierIDReader") ?
  644. SC.GetValue<bool>($"LoadPort.{LPModuleName}.BypassCarrierIDReader") : false;
  645. }
  646. }
  647. public virtual bool IsAutoDetectCarrierType
  648. {
  649. get
  650. {
  651. return SC.ContainsItem($"LoadPort.{LPModuleName}.AutoDetectCarrierType") ?
  652. SC.GetValue<bool>($"LoadPort.{LPModuleName}.AutoDetectCarrierType") : true;
  653. }
  654. }
  655. public virtual bool IsAutoReadCarrierID
  656. {
  657. get
  658. {
  659. return SC.ContainsItem($"LoadPort.{LPModuleName}.EnableAutoCarrierIdRead") ?
  660. SC.GetValue<bool>($"LoadPort.{LPModuleName}.EnableAutoCarrierIdRead") : true;
  661. }
  662. }
  663. public virtual LoadportCassetteState CassetteState
  664. {
  665. get;
  666. set;
  667. }
  668. public virtual int ValidSlotsNumber
  669. {
  670. get => 25;
  671. }
  672. public ModuleName LPModuleName { get; protected set; }
  673. public WaferSize Size
  674. {
  675. get; set;
  676. } = WaferSize.WS12;
  677. public virtual WaferSize GetCurrentWaferSize()
  678. {
  679. return Size;
  680. }
  681. public virtual bool IsVerifyPreDefineWaferCount
  682. {
  683. get => false;
  684. }
  685. public virtual int PreDefineWaferCount
  686. {
  687. get; set;
  688. }
  689. public virtual int InfoPadCarrierIndex { get; set; }
  690. public string SpecPortName { get; set; } = string.Empty;
  691. public virtual string SpecCarrierType
  692. {
  693. get; set;
  694. } = "";
  695. public virtual string SpecCarrierInformation
  696. {
  697. get
  698. {
  699. if (_isPresent)
  700. return "Index:" + InfoPadCarrierIndex.ToString() + "\r\n"
  701. + "Type:" + SpecCarrierType + "\r\n"
  702. + "Size:" + GetCurrentWaferSize().ToString() +
  703. (IsVerifyPreDefineWaferCount ? ("\r\n" + "Pre-Count:" + PreDefineWaferCount.ToString()) : "");
  704. return "";
  705. }
  706. }
  707. public bool IsAccessSwPressed
  708. {
  709. get { return _isAccessSwPressed; }
  710. }
  711. private void SubscribeDataVariable()
  712. {
  713. DoorState = FoupDoorState.Unknown;
  714. WaferManager.Instance.SubscribeLocation(LPModuleName, 25);
  715. CarrierManager.Instance.SubscribeLocation(LPModuleName.ToString());
  716. DATA.Subscribe(Name, "IsPresent", () => IsFoupPresent);
  717. DATA.Subscribe(Name, "IsPlaced", () => _isPlaced);
  718. DATA.Subscribe(Name, "IsClamped", () => ClampState == FoupClampState.Close);
  719. DATA.Subscribe(Name, "IsDocked", () => DockState == FoupDockState.Docked);
  720. DATA.Subscribe(Name, "IsDoorOpen", () => DoorState == FoupDoorState.Open);
  721. DATA.Subscribe(Name, "IsAccessSwPressed", () => IsAccessSwPressed);
  722. //DATA.Subscribe(Name, "CarrierId", () => _carrierId);
  723. DATA.Subscribe(Name, "LPLotID", () => _lplotID);
  724. DATA.Subscribe(Name, "IsMapped", () => _isMapped);
  725. DATA.Subscribe(Name, "IsAutoDetectCarrierType", () => IsAutoDetectCarrierType);
  726. //DATA.Subscribe($"{Name}.LoadportState", () => Status.ToString());
  727. //DATA.Subscribe($"{Name}.Status", () => "");
  728. //DATA.Subscribe($"{Name}.LoadportBusy", () => );
  729. DATA.Subscribe($"{Name}.LoadportError", () => ErrorCode);
  730. DATA.Subscribe($"{Name}.CassetteState", () => CassetteState);
  731. DATA.Subscribe($"{Name}.FoupClampState", () => ClampState);
  732. DATA.Subscribe($"{Name}.FoupDockState", () => DockState);
  733. DATA.Subscribe($"{Name}.FoupDoorState", () => DoorState);
  734. DATA.Subscribe($"{Name}.FoupDoorPosition", () => DoorPosition);
  735. DATA.Subscribe($"{Name}.SlotMap", () => SlotMap);
  736. DATA.Subscribe($"{Name}.IndicatiorLoad", () => IndicatiorLoad);
  737. DATA.Subscribe($"{Name}.IndicatiorUnload", () => IndicatiorUnload);
  738. DATA.Subscribe($"{Name}.IndicatiorPresence", () => IndicatiorPresence);
  739. DATA.Subscribe($"{Name}.IndicatiorPlacement", () => IndicatiorPlacement);
  740. DATA.Subscribe($"{Name}.IndicatiorAlarm", () => IndicatorAlarm);
  741. DATA.Subscribe($"{Name}.IndicatiorAccessAuto", () => IndicatiorAccessAuto);
  742. DATA.Subscribe($"{Name}.IndicatiorAccessManual", () => IndicatiorAccessManual);
  743. DATA.Subscribe($"{Name}.IndicatiorOpAccess", () => IndicatiorOpAccess);
  744. DATA.Subscribe($"{Name}.IndicatiorStatus1", () => IndicatiorStatus1);
  745. DATA.Subscribe($"{Name}.IndicatiorStatus2", () => IndicatiorStatus2);
  746. DATA.Subscribe($"{Name}.CasstleType", () => (int)CasstleType);
  747. DATA.Subscribe($"{Name}.InfoPadCarrierType", () => SpecCarrierType);
  748. DATA.Subscribe($"{Name}.InfoPadCarrierTypeInformation", () => SpecCarrierInformation);
  749. DATA.Subscribe($"{Name}.InfoPadCarrierIndex", () => InfoPadCarrierIndex);
  750. DATA.Subscribe($"{Name}.CarrierWaferSize", () => GetCurrentWaferSize().ToString());
  751. DATA.Subscribe($"{Name}.PreDefineWaferCount", () => PreDefineWaferCount);
  752. DATA.Subscribe($"{Name}.IsVerifyPreDefineWaferCount", () => IsVerifyPreDefineWaferCount);
  753. EV.Subscribe(new EventItem("Event", EventCarrierArrived, "Carrier arrived"));
  754. EV.Subscribe(new EventItem("Event", EventCarrierRemoved, "Carrier removed"));
  755. EV.Subscribe(new EventItem("Event", EventCarrierIdRead, "Carrier ID read"));
  756. EV.Subscribe(new EventItem("Event", EventCarrierIdReadFailed, "Carrier ID read failed"));
  757. EV.Subscribe(new EventItem("Event", EventCarrierIdWrite, "Carrier ID write"));
  758. EV.Subscribe(new EventItem("Event", EventCarrierIdWriteFailed, "Carrier ID write failed"));
  759. EV.Subscribe(new EventItem("Event", EventSlotMapAvailable, "Slot map available"));
  760. EV.Subscribe(new EventItem("Event", EventCarrierUnloaded, "Carrier unloaded"));
  761. EV.Subscribe(new EventItem("Event", EventCarrierLoaded, "Carrier loaded"));
  762. EV.Subscribe(new EventItem("Event", EventRfIdRead, "Carrier RFID read"));
  763. EV.Subscribe(new EventItem("Event", EventRfIdReadFailed, "Carrier RFID read failed"));
  764. EV.Subscribe(new EventItem("Event", EventRfIdWrite, "Carrier RFID write"));
  765. EV.Subscribe(new EventItem("Event", EventRfIdWriteFailed, "Carrier RFID write failed"));
  766. SubscribeAlarm();
  767. IndicatorStateFeedback = new IndicatorState[20];
  768. if (_lpE84Callback != null)
  769. {
  770. _lpE84Callback.OnE84ActiveSignalChange += _lpE84Callback_OnE84ActiveSignalChange;
  771. _lpE84Callback.OnE84PassiveSignalChange += _lpE84Callback_OnE84PassiveSignalChange;
  772. _lpE84Callback.OnE84HandOffComplete += _lpE84Callback_OnE84HandOffComplete;
  773. _lpE84Callback.OnE84HandOffStart += _lpE84Callback_OnE84HandOffStart;
  774. _lpE84Callback.OnE84HandOffTimeout += _lpE84Callback_OnE84HandOffTimeout;
  775. }
  776. }
  777. private void SubscribeAlarm()
  778. {
  779. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortError, $"Load Port {Name} occurred error.", EventLevel.Alarm, EventType.EventUI_Notify));
  780. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortCommunicationError, $"Load Port {Name}error.", EventLevel.Alarm, EventType.EventUI_Notify));
  781. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortWaferProtrusion, $"Load Port {Name} wafer protrusion error.", EventLevel.Alarm, EventType.EventUI_Notify));
  782. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortLoadTimeOut, $"Load Port {Name} load timeout.", EventLevel.Alarm, EventType.EventUI_Notify));
  783. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortLoadFailed, $"Load Port {Name} load failed.", EventLevel.Alarm, EventType.EventUI_Notify));
  784. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortUnloadTimeOut, $"Load Port {Name} unload timeout.", EventLevel.Alarm, EventType.EventUI_Notify));
  785. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortUnloadFailed, $"Load Port {Name} unload failed.", EventLevel.Alarm, EventType.EventUI_Notify));
  786. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortMappingError, $"Load Port {Name} mapping error.", EventLevel.Alarm, EventType.EventUI_Notify));
  787. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortMappingTimeout, $"Load Port {Name} mapping Timeout.", EventLevel.Alarm, EventType.EventUI_Notify));
  788. EV.Subscribe(new EventItem("Alarm", AlarmCarrierIDReadError, $"Load Port {Name} occurred error when read carrier ID.", EventLevel.Alarm, EventType.EventUI_Notify));
  789. EV.Subscribe(new EventItem("Alarm", AlarmCarrierIDWriteError, $"Load Port {Name} occurred error when write carrierID.", EventLevel.Alarm, EventType.EventUI_Notify));
  790. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortMapCrossedWafer, $"Load Port {Name} mapped crossed wafer.", EventLevel.Alarm, EventType.EventUI_Notify));
  791. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortMapDoubleWafer, $"Load Port {Name} mapped double wafer.", EventLevel.Alarm, EventType.EventUI_Notify));
  792. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortMapUnknownWafer, $"Load Port {Name} mapped unknown wafer.", EventLevel.Alarm, EventType.EventUI_Notify));
  793. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortCarrierIDIndexConfigError, $"Load Port {Name} carrierID reader configuration is invalid.", EventLevel.Alarm, EventType.EventUI_Notify));
  794. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortHomeFailed, $"Load Port {Name} occurred error when home.", EventLevel.Alarm, EventType.EventUI_Notify));
  795. EV.Subscribe(new EventItem("Alarm", AlarmLoadPortHomeTimeout, $"Load Port {Name} home timeout.", EventLevel.Alarm, EventType.EventUI_Notify));
  796. EV.Subscribe(new EventItem("Alarm", AlarmLoadE84TP1Timeout, $"Load Port {Name} occurred TP1 timeout during loading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  797. EV.Subscribe(new EventItem("Alarm", AlarmLoadE84TP2Timeout, $"Load Port {Name} occurred TP2 timeout during loading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  798. EV.Subscribe(new EventItem("Alarm", AlarmLoadE84TP3Timeout, $"Load Port {Name} occurred TP3 timeout during loading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  799. EV.Subscribe(new EventItem("Alarm", AlarmLoadE84TP4Timeout, $"Load Port {Name} occurred TP4 timeout during loading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  800. EV.Subscribe(new EventItem("Alarm", AlarmLoadE84TP5Timeout, $"Load Port {Name} occurred TP5 timeout during loading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  801. EV.Subscribe(new EventItem("Alarm", AlarmLoadE84TP6Timeout, $"Load Port {Name} occurred TP6 timeout during loading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  802. EV.Subscribe(new EventItem("Alarm", AlarmUnloadE84TP1Timeout, $"Load Port {Name} occurred TP1 timeout during unloading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  803. EV.Subscribe(new EventItem("Alarm", AlarmUnloadE84TP2Timeout, $"Load Port {Name} occurred TP2 timeout during unloading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  804. EV.Subscribe(new EventItem("Alarm", AlarmUnloadE84TP3Timeout, $"Load Port {Name} occurred TP3 timeout during unloading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  805. EV.Subscribe(new EventItem("Alarm", AlarmUnloadE84TP4Timeout, $"Load Port {Name} occurred TP4 timeout during unloading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  806. EV.Subscribe(new EventItem("Alarm", AlarmUnloadE84TP5Timeout, $"Load Port {Name} occurred TP5 timeout during unloading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  807. EV.Subscribe(new EventItem("Alarm", AlarmUnloadE84TP6Timeout, $"Load Port {Name} occurred TP6 timeout during unloading foup.", EventLevel.Alarm, EventType.EventUI_Notify));
  808. }
  809. private void _lpE84Callback_OnE84PassiveSignalChange(E84SignalID arg2, bool arg3)
  810. {
  811. }
  812. private void _lpE84Callback_OnE84HandOffTimeout(IOE84Passive.E84Timeout _timeout, string LoadorUnload)
  813. {
  814. if (LoadorUnload == "Load")
  815. {
  816. switch (_timeout)
  817. {
  818. case IOE84Passive.E84Timeout.TP1:
  819. EV.Notify(AlarmLoadE84TP1Timeout);
  820. //OnError(AlarmLoadE84TP1Timeout);
  821. break;
  822. case IOE84Passive.E84Timeout.TP2:
  823. EV.Notify(AlarmLoadE84TP2Timeout);
  824. //OnError(AlarmLoadE84TP2Timeout);
  825. break;
  826. case IOE84Passive.E84Timeout.TP3:
  827. EV.Notify(AlarmLoadE84TP3Timeout);
  828. //OnError(AlarmLoadE84TP3Timeout);
  829. break;
  830. case IOE84Passive.E84Timeout.TP4:
  831. EV.Notify(AlarmLoadE84TP4Timeout);
  832. //OnError(AlarmLoadE84TP4Timeout);
  833. break;
  834. case IOE84Passive.E84Timeout.TP5:
  835. EV.Notify(AlarmLoadE84TP5Timeout);
  836. //OnError(AlarmLoadE84TP5Timeout);
  837. break;
  838. default:
  839. break;
  840. }
  841. }
  842. if (LoadorUnload == "Unload")
  843. {
  844. switch (_timeout)
  845. {
  846. case IOE84Passive.E84Timeout.TP1:
  847. EV.Notify(AlarmUnloadE84TP1Timeout);
  848. //OnError(AlarmUnloadE84TP1Timeout);
  849. break;
  850. case IOE84Passive.E84Timeout.TP2:
  851. EV.Notify(AlarmUnloadE84TP2Timeout);
  852. //OnError(AlarmUnloadE84TP2Timeout);
  853. break;
  854. case IOE84Passive.E84Timeout.TP3:
  855. EV.Notify(AlarmUnloadE84TP3Timeout);
  856. //OnError(AlarmUnloadE84TP3Timeout);
  857. break;
  858. case IOE84Passive.E84Timeout.TP4:
  859. EV.Notify(AlarmUnloadE84TP4Timeout);
  860. //OnError(AlarmUnloadE84TP4Timeout);
  861. break;
  862. case IOE84Passive.E84Timeout.TP5:
  863. EV.Notify(AlarmUnloadE84TP5Timeout);
  864. //OnError(AlarmUnloadE84TP5Timeout);
  865. break;
  866. default:
  867. break;
  868. }
  869. }
  870. }
  871. public void OnE84HandOffStart(bool isload)
  872. {
  873. if (_lpcallback != null) _lpcallback.OnE84HandoffStart(isload);
  874. }
  875. public void OnE84HandOffComplete(bool isload)
  876. {
  877. if (_lpcallback != null) _lpcallback.OnE84HandoffComplete(isload);
  878. }
  879. private void _lpE84Callback_OnE84HandOffStart(string arg2)
  880. {
  881. OnE84HandOffStart(arg2 == "Load");
  882. }
  883. private void _lpE84Callback_OnE84HandOffComplete(string arg2)
  884. {
  885. OnE84HandOffComplete(arg2 == "Load");
  886. }
  887. private void _lpE84Callback_OnE84ActiveSignalChange(E84SignalID arg2, bool arg3)
  888. {
  889. ;
  890. }
  891. public virtual void OnSlotMapRead(string _slotMap)
  892. {
  893. if (_slotMap.Length != ValidSlotsNumber)
  894. {
  895. EV.PostAlarmLog(Name, "Mapping Data Error.");
  896. }
  897. for (int i = 0; i < _slotMap.Length; i++)
  898. {
  899. // No wafer: "0", Wafer: "1", Crossed:"2", Undefined: "?", Overlapping wafers: "W"
  900. WaferInfo wafer = null;
  901. switch (_slotMap[i])
  902. {
  903. case '0':
  904. WaferManager.Instance.DeleteWafer(LPModuleName, i);
  905. CarrierManager.Instance.UnregisterCarrierWafer(Name, i);
  906. break;
  907. case '1':
  908. wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Normal);
  909. WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
  910. CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
  911. break;
  912. case '2':
  913. wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Crossed);
  914. WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
  915. CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
  916. EV.Notify(AlarmLoadPortMapCrossedWafer);
  917. EV.PostInfoLog(Name, $"{LPModuleName} map crossed wafer on carrier:{_carrierId},slot:{i + 1}.");
  918. break;
  919. case 'W':
  920. wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Double);
  921. WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
  922. CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
  923. EV.Notify(AlarmLoadPortMapDoubleWafer);
  924. EV.PostInfoLog(Name, $"{LPModuleName} map double wafer on carrier:{_carrierId},slot:{i + 1}.");
  925. break;
  926. case '?':
  927. wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Unknown);
  928. WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
  929. CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
  930. EV.PostInfoLog(Name, $"{LPModuleName} map unknown wafer on carrier:{_carrierId},slot:{i + 1}.");
  931. break;
  932. }
  933. }
  934. SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
  935. dvid["SlotMap"] = _slotMap;
  936. dvid["PortID"] = PortID;
  937. dvid["PORT_CTGRY"] = SpecPortName;
  938. dvid["CarrierType"] = SpecCarrierType;
  939. dvid["CarrierID"] = CarrierId;
  940. EV.Notify(EventSlotMapAvailable, dvid);
  941. if (_slotMap.Contains("2"))
  942. {
  943. MapError = true;
  944. EV.Notify(AlarmLoadPortMappingError);
  945. }
  946. if (_slotMap.Contains("W"))
  947. {
  948. MapError = true;
  949. EV.Notify(AlarmLoadPortMappingError);
  950. }
  951. if (_slotMap.Contains("?"))
  952. {
  953. MapError = true;
  954. EV.Notify(AlarmLoadPortMappingError);
  955. }
  956. if (LPCallBack != null)
  957. LPCallBack.MappingComplete(_carrierId, _slotMap);
  958. _isMapped = true;
  959. }
  960. private string GetSlotMap()
  961. {
  962. WaferInfo[] wafers = WaferManager.Instance.GetWafers(ModuleHelper.Converter(Name));
  963. string slot = "";
  964. for (int i = 0; i < 25; i++)
  965. {
  966. slot += wafers[i].IsEmpty ? "0" : "1";
  967. }
  968. return slot;
  969. }
  970. public void ProceedSetCarrierID(string cid)
  971. {
  972. _carrierId = cid;
  973. CarrierManager.Instance.UpdateCarrierId(Name, cid);
  974. }
  975. public virtual bool SetE84Available(out string reason)
  976. {
  977. if (_lpE84Callback != null)
  978. {
  979. _lpE84Callback.SetHoAutoControl(false);
  980. _lpE84Callback.SetHoAvailable(true);
  981. }
  982. reason = "";
  983. return true;
  984. }
  985. public virtual bool SetE84Unavailable(out string reason)
  986. {
  987. if (_lpE84Callback != null)
  988. {
  989. _lpE84Callback.SetHoAutoControl(false);
  990. _lpE84Callback.SetHoAvailable(false);
  991. }
  992. reason = "";
  993. return true;
  994. }
  995. public virtual bool SetIndicator(IndicatorType light, IndicatorState state)
  996. {
  997. return true;
  998. }
  999. public virtual bool Unload(out string reason)
  1000. {
  1001. reason = "";
  1002. //_doUnloadFoup.SetValue(true, out reason);
  1003. //_doLoadFoup.SetValue(false, out reason);
  1004. //_doInit.SetValue(false, out reason);
  1005. LOG.Info($"Unload-{Name} IsLoadCompleted from {IsLoadCompleted} to {false} and IsUnloadCompleted from {IsUnloadCompleted} to {true}");
  1006. IsLoadCompleted = false;
  1007. IsUnloadCompleted = true;
  1008. return true;
  1009. }
  1010. public bool Load(out string reason)
  1011. {
  1012. reason = "";
  1013. LOG.Info($"Load-{Name} IsUnloadCompleted from {IsUnloadCompleted} to {false} and IsLoadCompleted from {IsLoadCompleted} to {true}");
  1014. //_doUnloadFoup.SetValue(false, out reason);
  1015. //_doLoadFoup.SetValue(true, out reason);
  1016. //_doInit.SetValue(false, out reason);
  1017. IsUnloadCompleted = false;
  1018. IsLoadCompleted = true;
  1019. return true;
  1020. }
  1021. public bool Init(out string reason)
  1022. {
  1023. reason = "";
  1024. //_doUnloadFoup.SetValue(false, out reason);
  1025. //_doLoadFoup.SetValue(false, out reason);
  1026. //_doInit.SetValue(true, out reason);
  1027. IsLoadCompleted = false;
  1028. IsUnloadCompleted = true;
  1029. return true;
  1030. }
  1031. public bool Stop()
  1032. {
  1033. var reason = "";
  1034. //_doLoadFoup.SetValue(false, out reason);
  1035. //_doUnloadFoup.SetValue(false, out reason);
  1036. //_doInit.SetValue(false, out reason);
  1037. return true;
  1038. }
  1039. public virtual bool FALoad(out string reason)
  1040. {
  1041. reason = "";
  1042. //_doLoadFoup.SetValue(true, out reason);
  1043. return true;
  1044. }
  1045. public virtual bool WriteRfid(string cid, int startpage, int length, out string reason)
  1046. {
  1047. reason = "";
  1048. return true;
  1049. }
  1050. public virtual bool ReadRfId(out string reason)
  1051. {
  1052. reason = "";
  1053. return true;
  1054. }
  1055. public virtual bool FAUnload(out string reason)
  1056. {
  1057. reason = "";
  1058. //_doUnloadFoup.SetValue(true, out reason);
  1059. return true;
  1060. }
  1061. public virtual bool Unclamp(out string reason)
  1062. {
  1063. reason = "";
  1064. _doClamp?.SetValue(false, out reason);
  1065. _doRelease?.SetValue(true, out reason);
  1066. return true;
  1067. }
  1068. public virtual bool Clamp(out string reason)
  1069. {
  1070. reason = "";
  1071. _doClamp?.SetValue(true, out reason);
  1072. _doRelease?.SetValue(false, out reason);
  1073. return true;
  1074. }
  1075. public virtual bool ReadCarrierID()
  1076. {
  1077. int offset = SC.ContainsItem($"LoadPort.{LPModuleName}.StartPage") ?
  1078. SC.GetValue<int>($"LoadPort.{LPModuleName}.StartPage") : 0;
  1079. int length = SC.ContainsItem($"LoadPort.{LPModuleName}.DataReadSize") ?
  1080. SC.GetValue<int>($"LoadPort.{LPModuleName}.DataReadSize") : 16;
  1081. if (SC.ContainsItem($"CarrierInfo.{LPModuleName}CIDReaderIndex{InfoPadCarrierIndex}"))
  1082. {
  1083. int cidindex = SC.GetValue<int>($"CarrierInfo.{LPModuleName}CIDReaderIndex{InfoPadCarrierIndex}");
  1084. if (CIDReaders != null && CIDReaders.Length > cidindex)
  1085. _carrierIDReadercallback = CIDReaders[cidindex];
  1086. else
  1087. {
  1088. return true;
  1089. }
  1090. }
  1091. if (_carrierIDReadercallback != null)
  1092. {
  1093. if (SC.ContainsItem("CarrierID.CarrierIdReaderProtocolType") && SC.GetStringValue("CarrierID.CarrierIdReaderProtocolType") == "1:N")
  1094. return _carrierIDReadercallback.ReadCarrierID(offset, length, int.Parse(Name.ToString().Replace("LP", "")));
  1095. return _carrierIDReadercallback.ReadCarrierID(offset, length);
  1096. }
  1097. return false;
  1098. }
  1099. #endregion
  1100. }
  1101. }