TDKBLoadPort.cs 77 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005
  1. using Aitex.Core.Common;
  2. using Aitex.Core.RT.DataCenter;
  3. using Aitex.Core.RT.Device.Unit;
  4. using Aitex.Core.RT.Event;
  5. using Aitex.Core.RT.Log;
  6. using Aitex.Core.RT.SCCore;
  7. using Aitex.Core.Util;
  8. using Aitex.Sorter.Common;
  9. using MECF.Framework.Common.Communications;
  10. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.CarrierIdReaders.CarrierIDReaderBase;
  11. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.LoadPortBase;
  12. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.TDK;
  13. using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Robots.RobotBase;
  14. using System;
  15. using System.Collections.Generic;
  16. using System.IO.Ports;
  17. using System.Linq;
  18. using System.Text;
  19. using System.Text.RegularExpressions;
  20. using System.Threading;
  21. using System.Threading.Tasks;
  22. namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.TDKB
  23. {
  24. public class TDKBLoadPort : LoadPortBaseDevice, IConnection
  25. {
  26. public TDKBLoadPort(string module, string name, string scRoot, IoTrigger[] dos = null, IoSensor[] dis = null, RobotBaseDevice robot = null, bool IsTCPconnection = false, IE84CallBack e84 =null) : base(module, name, robot,e84)
  27. {
  28. _scRoot = scRoot;
  29. _isTcpConnection = IsTCPconnection;
  30. LoadPortType = "TDKLoadPort";
  31. if (dos != null && dos.Length >= 1)
  32. {
  33. _doLoadPortOK = dos[0];
  34. }
  35. if (dis != null && dis.Length >= 1)
  36. {
  37. _diInfoPadA = dis[0];
  38. _diInfoPadA.OnSignalChanged += _diInfoPad_OnSignalChanged;
  39. }
  40. if (dis != null && dis.Length >= 2)
  41. {
  42. _diInfoPadB = dis[1];
  43. _diInfoPadB.OnSignalChanged += _diInfoPad_OnSignalChanged;
  44. }
  45. if (dis != null && dis.Length >= 3)
  46. {
  47. _diInfoPadC = dis[2];
  48. _diInfoPadC.OnSignalChanged += _diInfoPad_OnSignalChanged;
  49. }
  50. if (dis != null && dis.Length >= 4)
  51. {
  52. _diInfoPadD = dis[3];
  53. _diInfoPadD.OnSignalChanged += _diInfoPad_OnSignalChanged;
  54. }
  55. InitializeLP();
  56. SubscribeLPData();
  57. //SubscribeLPAlarm();
  58. }
  59. private void SubscribeLPData()
  60. {
  61. if (Module != "")
  62. {
  63. DATA.Subscribe($"{Module}.{Name}.SystemStatus", () => SystemStatus.ToString());
  64. DATA.Subscribe($"{Module}.{Name}.Mode", () => Mode.ToString());
  65. DATA.Subscribe($"{Module}.{Name}.InitPosMovement", () => InitPosMovement.ToString());
  66. DATA.Subscribe($"{Module}.{Name}.OperationStatus", () => OperationStatus.ToString());
  67. DATA.Subscribe($"{Module}.{Name}.ErrorCode", () => ErrorCode.ToString());
  68. DATA.Subscribe($"{Module}.{Name}.ContainerStatus", () => ContainerStatus.ToString());
  69. DATA.Subscribe($"{Module}.{Name}.ClampPosition", () => ClampPosition.ToString());
  70. DATA.Subscribe($"{Module}.{Name}.LPDoorLatchPosition", () => LPDoorLatchPosition.ToString());
  71. DATA.Subscribe($"{Module}.{Name}.VacuumStatus", () => VacuumStatus.ToString());
  72. DATA.Subscribe($"{Module}.{Name}.LPDoorState", () => LPDoorState.ToString());
  73. DATA.Subscribe($"{Module}.{Name}.WaferProtrusion", () => WaferProtrusion.ToString());
  74. DATA.Subscribe($"{Module}.{Name}.ElevatorAxisPosition", () => ElevatorAxisPosition.ToString());
  75. DATA.Subscribe($"{Module}.{Name}.MapperPostion", () => MapperPostion.ToString());
  76. DATA.Subscribe($"{Module}.{Name}.MappingStatus", () => MappingStatus.ToString());
  77. DATA.Subscribe($"{Module}.{Name}.Model", () => Model.ToString());
  78. DATA.Subscribe($"{Module}.{Name}.IsFosbModeActual", () => IsFosbModeActual.ToString());
  79. DATA.Subscribe($"{Module}.{Name}.DockPosition", () => DockPosition.ToString());
  80. }
  81. else
  82. {
  83. DATA.Subscribe($"{Name}.SystemStatus", () => SystemStatus.ToString());
  84. DATA.Subscribe($"{Name}.Mode", () => Mode.ToString());
  85. DATA.Subscribe($"{Name}.InitPosMovement", () => InitPosMovement.ToString());
  86. DATA.Subscribe($"{Name}.OperationStatus", () => OperationStatus.ToString());
  87. DATA.Subscribe($"{Name}.ErrorCode", () => ErrorCode.ToString());
  88. DATA.Subscribe($"{Name}.ContainerStatus", () => ContainerStatus.ToString());
  89. DATA.Subscribe($"{Name}.ClampPosition", () => ClampPosition.ToString());
  90. DATA.Subscribe($"{Name}.LPDoorLatchPosition", () => LPDoorLatchPosition.ToString());
  91. DATA.Subscribe($"{Name}.VacuumStatus", () => VacuumStatus.ToString());
  92. DATA.Subscribe($"{Name}.LPDoorState", () => LPDoorState.ToString());
  93. DATA.Subscribe($"{Name}.WaferProtrusion", () => WaferProtrusion.ToString());
  94. DATA.Subscribe($"{Name}.ElevatorAxisPosition", () => ElevatorAxisPosition.ToString());
  95. DATA.Subscribe($"{Name}.MapperPostion", () => MapperPostion.ToString());
  96. DATA.Subscribe($"{Name}.MappingStatus", () => MappingStatus.ToString());
  97. DATA.Subscribe($"{Name}.Model", () => Model.ToString());
  98. DATA.Subscribe($"{Name}.IsFosbModeActual", () => IsFosbModeActual.ToString());
  99. DATA.Subscribe($"{Name}.DockPosition", () => DockPosition.ToString());
  100. }
  101. }
  102. private void SubscribeLPAlarm()
  103. {
  104. EV.Subscribe(new EventItem("Alarm", AlarmTdkZLMIT, $"Load Port {Name} Z-axis position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
  105. EV.Subscribe(new EventItem("Alarm", AlarmTdkYLMIT, $"Load Port {Name} Y-axis position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
  106. EV.Subscribe(new EventItem("Alarm", AlarmTdkPROTS, $"Load Port {Name} Wafer protrusion", EventLevel.Alarm, EventType.EventUI_Notify));
  107. EV.Subscribe(new EventItem("Alarm", AlarmTdkDLMIT, $"Load Port {Name} Door forward/backward position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
  108. EV.Subscribe(new EventItem("Alarm", AlarmTdkMPBAR, $"Load Port {Name} Mapper arm position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
  109. EV.Subscribe(new EventItem("Alarm", AlarmTdkMPSTP, $"Load Port {Name} Mapper stopper position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
  110. EV.Subscribe(new EventItem("Alarm", AlarmTdkMPEDL, $"Load Port {Name} Mapping end position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
  111. EV.Subscribe(new EventItem("Alarm", AlarmTdkCLOPS, $"Load Port {Name} FOUP clamp open error", EventLevel.Alarm, EventType.EventUI_Notify));
  112. EV.Subscribe(new EventItem("Alarm", AlarmTdkCLCLS, $"Load Port {Name} FOUP clamp close error", EventLevel.Alarm, EventType.EventUI_Notify));
  113. EV.Subscribe(new EventItem("Alarm", AlarmTdkDROPS, $"Load Port {Name} Latch key open error", EventLevel.Alarm, EventType.EventUI_Notify));
  114. EV.Subscribe(new EventItem("Alarm", AlarmTdkDRCLS, $"Load Port {Name} Latch key close error", EventLevel.Alarm, EventType.EventUI_Notify));
  115. EV.Subscribe(new EventItem("Alarm", AlarmTdkVACCS, $"Load Port {Name} Vacuum on error", EventLevel.Alarm, EventType.EventUI_Notify));
  116. EV.Subscribe(new EventItem("Alarm", AlarmTdkVACOS, $"Load Port {Name} Vacuum off error", EventLevel.Alarm, EventType.EventUI_Notify));
  117. EV.Subscribe(new EventItem("Alarm", AlarmTdkAIRSN, $"Load Port {Name} Main air error", EventLevel.Alarm, EventType.EventUI_Notify));
  118. EV.Subscribe(new EventItem("Alarm", AlarmTdkINTOP, $"Load Port {Name} Normal position error at FOUP open", EventLevel.Alarm, EventType.EventUI_Notify));
  119. EV.Subscribe(new EventItem("Alarm", AlarmTdkINTCL, $"Load Port {Name} Normal position error at FOUP close", EventLevel.Alarm, EventType.EventUI_Notify));
  120. EV.Subscribe(new EventItem("Alarm", AlarmTdkINTMP, $"Load Port {Name} Mapper storage error when Z-axis lowered", EventLevel.Alarm, EventType.EventUI_Notify));
  121. EV.Subscribe(new EventItem("Alarm", AlarmTdkINTPI, $"Load Port {Name} Parallel signal error from upper machine", EventLevel.Alarm, EventType.EventUI_Notify));
  122. EV.Subscribe(new EventItem("Alarm", AlarmTdkSAFTY, $"Load Port {Name} Interlock relay failure", EventLevel.Alarm, EventType.EventUI_Notify));
  123. EV.Subscribe(new EventItem("Alarm", AlarmTdkFANST, $"Load Port {Name} Fan operation error", EventLevel.Alarm, EventType.EventUI_Notify));
  124. EV.Subscribe(new EventItem("Alarm", AlarmTdkMPDOG, $"Load Port {Name} Mapping mechanical(Adjustment) error", EventLevel.Alarm, EventType.EventUI_Notify));
  125. EV.Subscribe(new EventItem("Alarm", AlarmTdkDRDKE, $"Load Port {Name} Door detection error during dock.", EventLevel.Alarm, EventType.EventUI_Notify));
  126. EV.Subscribe(new EventItem("Alarm", AlarmTdkDRSWE, $"Load Port {Name} Door detection error except dock", EventLevel.Alarm, EventType.EventUI_Notify));
  127. //EV.Subscribe(new EventItem("Alarm", AlarmTdkNoOperation, $"Load Port {Name} No action when foup is present", EventLevel.Alarm, EventType.EventUI_Notify));-->
  128. }
  129. internal void RecordCurrentSlotMap(string str1)
  130. {
  131. CurrentSlotMapResult = str1;
  132. EV.PostInfoLog("LoadPort", $"{LPModuleName} received slot map:{str1}");
  133. }
  134. internal void OnE84Unload(string evtcontent)
  135. {
  136. }
  137. internal void OnE84Load(string evtcontent)
  138. {
  139. }
  140. private string AlarmTdkZLMIT { get => LPModuleName.ToString() + "ZLMIT"; }
  141. private string AlarmTdkYLMIT { get => LPModuleName.ToString() + "YLMIT"; }
  142. private string AlarmTdkPROTS { get => LPModuleName.ToString() + "PROTS"; }
  143. private string AlarmTdkDLMIT { get => LPModuleName.ToString() + "DLMIT"; }
  144. private string AlarmTdkMPBAR { get => LPModuleName.ToString() + "MPBAR"; }
  145. private string AlarmTdkMPSTP { get => LPModuleName.ToString() + "MPSTP"; }
  146. private string AlarmTdkMPEDL { get => LPModuleName.ToString() + "MPEDL"; }
  147. private string AlarmTdkCLOPS { get => LPModuleName.ToString() + "CLOPS"; }
  148. private string AlarmTdkCLCLS { get => LPModuleName.ToString() + "CLCLS"; }
  149. private string AlarmTdkDROPS { get => LPModuleName.ToString() + "DROPS"; }
  150. private string AlarmTdkDRCLS { get => LPModuleName.ToString() + "DRCLS"; }
  151. private string AlarmTdkVACCS { get => LPModuleName.ToString() + "VACCS"; }
  152. private string AlarmTdkVACOS { get => LPModuleName.ToString() + "VACOS"; }
  153. private string AlarmTdkAIRSN { get => LPModuleName.ToString() + "AIRSN"; }
  154. private string AlarmTdkINTOP { get => LPModuleName.ToString() + "INTOP"; }
  155. private string AlarmTdkINTCL { get => LPModuleName.ToString() + "INTCL"; }
  156. private string AlarmTdkINTMP { get => LPModuleName.ToString() + "INTMP"; }
  157. private string AlarmTdkINTPI { get => LPModuleName.ToString() + "INTPI"; }
  158. private string AlarmTdkSAFTY { get => LPModuleName.ToString() + "SAFTY"; }
  159. private string AlarmTdkFANST { get => LPModuleName.ToString() + "FANST"; }
  160. private string AlarmTdkMPDOG { get => LPModuleName.ToString() + "MPDOG"; }
  161. private string AlarmTdkDRDKE { get => LPModuleName.ToString() + "DRDKE"; }
  162. private string AlarmTdkDRSWE { get => LPModuleName.ToString() + "DRSWE"; }
  163. private string AlarmTdkNoOperation { get => LPModuleName.ToString() + "NoOperation"; }
  164. public bool IsHandlerBusy
  165. {
  166. get
  167. {
  168. return _lstHandler.Count != 0 || _connection.IsBusy;
  169. }
  170. }
  171. public E84DeviceTypeEnum E84DeviceType
  172. {
  173. get
  174. {
  175. if (LPE84Callback != null)
  176. return E84DeviceTypeEnum.External;
  177. if (SC.ContainsItem($"LoadPort.{Name}.E84DeviceType"))
  178. return (E84DeviceTypeEnum)SC.GetValue<int>($"LoadPort.{Name}.E84DeviceType");
  179. return E84DeviceTypeEnum.None;
  180. }
  181. }
  182. public override bool SetE84Available(out string reason)
  183. {
  184. if(E84DeviceType == E84DeviceTypeEnum.External)
  185. return base.SetE84Available(out reason);
  186. if(E84DeviceType == E84DeviceTypeEnum.Internal)
  187. {
  188. lock(_locker)
  189. {
  190. _lstHandler.AddLast(new TDKBSetHandler(this, "E84EN/", "ON"));
  191. }
  192. }
  193. if (SC.ContainsItem($"LoadPort.{Name}.AccessMode"))
  194. SC.SetItemValue($"LoadPort.{Name}.AccessMode", true);
  195. IsAccessAuto = true;
  196. reason = "";
  197. return true;
  198. }
  199. public override bool ChangeAccessMode(bool auto, out string reason)
  200. {
  201. if(auto)
  202. {
  203. if (E84DeviceType == E84DeviceTypeEnum.Internal)
  204. {
  205. lock (_locker)
  206. {
  207. _lstHandler.AddLast(new TDKBSetHandler(this, "E84RS", null));
  208. }
  209. }
  210. }
  211. else
  212. {
  213. if (E84DeviceType == E84DeviceTypeEnum.Internal)
  214. {
  215. lock (_locker)
  216. {
  217. _lstHandler.AddLast(new TDKBSetHandler(this, "E84EN/", "OFF"));
  218. }
  219. }
  220. if (SC.ContainsItem($"LoadPort.{Name}.AccessMode"))
  221. SC.SetItemValue($"LoadPort.{Name}.AccessMode", false);
  222. }
  223. return base.ChangeAccessMode(auto, out reason);
  224. }
  225. public override bool SetE84Unavailable(out string reason)
  226. {
  227. if (E84DeviceType == E84DeviceTypeEnum.External)
  228. return base.SetE84Unavailable(out reason);
  229. if (E84DeviceType == E84DeviceTypeEnum.Internal)
  230. {
  231. lock (_locker)
  232. {
  233. _lstHandler.AddLast(new TDKBSetHandler(this, "E84EN/", "OFF"));
  234. }
  235. }
  236. if (SC.ContainsItem($"LoadPort.{Name}.AccessMode"))
  237. SC.SetItemValue($"LoadPort.{Name}.AccessMode", false);
  238. IsAccessAuto = false;
  239. reason = "";
  240. return true;
  241. }
  242. public override bool LoadPortE84Complete(object[] param, out string reason)
  243. {
  244. if (E84DeviceType == E84DeviceTypeEnum.External)
  245. return base.LoadPortE84Complete(param, out reason);
  246. if (E84DeviceType == E84DeviceTypeEnum.Internal)
  247. {
  248. lock (_locker)
  249. {
  250. _lstHandler.AddLast(new TDKBSetHandler(this, "E84RS", null));
  251. }
  252. }
  253. reason = "";
  254. return true;
  255. }
  256. public override bool LoadPortE84Retry(object[] param, out string reason)
  257. {
  258. if (E84DeviceType == E84DeviceTypeEnum.External)
  259. return base.LoadPortE84Complete(param, out reason);
  260. if (E84DeviceType == E84DeviceTypeEnum.Internal)
  261. {
  262. lock (_locker)
  263. {
  264. _lstHandler.AddLast(new TDKBSetHandler(this, "E84RS", null));
  265. }
  266. }
  267. reason = "";
  268. return true;
  269. }
  270. internal void OnE84Error(string evtcontent)
  271. {
  272. }
  273. private bool _isE84Onload;
  274. private bool _isUndockOCBeforeHome
  275. {
  276. get
  277. {
  278. if (SC.ContainsItem($"LoadPort.{Name}.UndockOCBeforeHome"))
  279. return SC.GetValue<bool>($"LoadPort.{Name}.UndockOCBeforeHome");
  280. return false;
  281. }
  282. }
  283. internal void OnE84IOEvent(string evtcontent)
  284. {
  285. string startstr = "NF:E84IO/";
  286. string endstr = ";";
  287. Regex rg = new Regex("(?<=(" + startstr + "))[.\\s\\S]*?(?=(" + endstr + "))", RegexOptions.Multiline | RegexOptions.Singleline);
  288. string[] items = rg.Match(evtcontent).Value.Split('/');
  289. int intputValue = Convert.ToInt32(items[0], 16);
  290. char[] inputs = Convert.ToString(Convert.ToByte(items[1], 16), 2).PadLeft(8, '0').ToCharArray();
  291. Array.Reverse(inputs);
  292. LPE84SigState.VALID = inputs[0] != '0';
  293. LPE84SigState.CS_0 = inputs[1] != '0';
  294. LPE84SigState.CS_1 = inputs[2] != '0';
  295. LPE84SigState.AM_AVBL = inputs[3] != '0';
  296. LPE84SigState.TR_REQ = inputs[4] != '0';
  297. LPE84SigState.BUSY = inputs[5] != '0';
  298. if(LPE84SigState.COMPT && inputs[6] == '0')
  299. {
  300. OnE84HandOffComplete(_isE84Onload);
  301. }
  302. LPE84SigState.COMPT = inputs[6] != '0';
  303. LPE84SigState.CONT = inputs[7] != '0';
  304. inputs = Convert.ToString(Convert.ToByte(items[2], 16), 2).PadLeft(8, '0').ToCharArray();
  305. Array.Reverse(inputs);
  306. if(!LPE84SigState.L_REQ && inputs[0] != '0')
  307. {
  308. OnE84HandOffStart(true);
  309. _isE84Onload = true;
  310. }
  311. LPE84SigState.L_REQ = inputs[0] != '0';
  312. if (!LPE84SigState.U_REQ && inputs[1] != '0')
  313. {
  314. OnE84HandOffStart(false);
  315. _isE84Onload = false;
  316. }
  317. LPE84SigState.U_REQ = inputs[1] != '0';
  318. LPE84SigState.VA = inputs[2] != '0';
  319. LPE84SigState.READY = inputs[3] != '0';
  320. LPE84SigState.VS_0 = inputs[4] != '0';
  321. LPE84SigState.VS_1 = inputs[5] != '0';
  322. LPE84SigState.HO_AVBL = inputs[6] != '0';
  323. LPE84SigState.ES = inputs[7] != '0';
  324. }
  325. internal void OnCommandFailed(string moveCommand)
  326. {
  327. switch(moveCommand)
  328. {
  329. case "PODCL":
  330. break;
  331. case "PODOP":
  332. break;
  333. case "YDOOR":
  334. break;
  335. case "YWAIT":
  336. break;
  337. default:
  338. break;
  339. }
  340. EV.PostWarningLog("LoadPort", $"{LPModuleName} execute command:{moveCommand} failed");
  341. }
  342. private void _diInfoPad_OnSignalChanged(IoSensor arg1, bool arg2)
  343. {
  344. }
  345. internal void OnCommandSuccess(string moveCommand)
  346. {
  347. var dvid = new SerializableDictionary<string, object>
  348. {
  349. ["CarrierID"] = _carrierId ?? "",
  350. ["CAR_ID"] = _carrierId ?? "",
  351. ["PORT_ID"] = PortID,
  352. ["PortID"] = PortID,
  353. ["PORT_CTGRY"] = SpecPortName,
  354. ["CarrierType"] = SpecCarrierType,
  355. ["CarrierIndex"] = InfoPadCarrierIndex,
  356. ["InfoPadSensorIndex"] = InfoPadSensorIndex,
  357. };
  358. EV.PostInfoLog("LoadPort", $"{LPModuleName} execute command:{moveCommand} with carrier:{CarrierId}," +
  359. $" type:{SpecCarrierType ?? ""} successfully");
  360. switch (moveCommand)
  361. {
  362. case "PODCL":
  363. EV.Notify(EventCarrierClamped, dvid);
  364. break;
  365. case "PODOP":
  366. EV.Notify(EventCarrierUnclamped, dvid);
  367. break;
  368. case "YDOOR":
  369. EV.Notify(EventCarrierDocked, dvid);
  370. break;
  371. case "YWAIT":
  372. EV.Notify(EventCarrierUndocked, dvid);
  373. break;
  374. default:
  375. break;
  376. }
  377. }
  378. public override bool IsKeepClampAfterUnload
  379. {
  380. get
  381. {
  382. if (SC.ContainsItem($"CarrierInfo.KeepClampedAfterUnloadCarrier{InfoPadCarrierIndex}"))
  383. return SC.GetValue<bool>($"CarrierInfo.KeepClampedAfterUnloadCarrier{InfoPadCarrierIndex}");
  384. return base.IsKeepClampAfterUnload;
  385. }
  386. }
  387. public override int InfoPadCarrierIndex
  388. {
  389. get { return base.InfoPadCarrierIndex; }
  390. set
  391. {
  392. if (base.InfoPadCarrierIndex != value)
  393. {
  394. base.InfoPadCarrierIndex = value;
  395. EV.PostInfoLog("LoadPort", $"{LPModuleName} infopad index change to {value}");
  396. //if (CIDReaders != null && CIDReaders.Length > 1)
  397. //{
  398. // int cidindex = SC.GetValue<int>($"CarrierInfo.{LPModuleName}CIDReaderIndex{InfoPadCarrierIndex}");
  399. // if (CIDReaders.Length <= cidindex)
  400. // {
  401. // EV.PostAlarmLog("System", $"The carrier info configuration for CIDReaderIndex{cidindex} is invalid.");
  402. // }
  403. // else
  404. // {
  405. // CarrierIDReaderCallBack = CIDReaders[cidindex];
  406. // }
  407. //}
  408. }
  409. }
  410. }
  411. public override bool IsEnableDualTransfer(out string reason)
  412. {
  413. reason = "";
  414. if(SC.ContainsItem($"CarrierInfo.EnableDualTransfer{InfoPadCarrierIndex}") &&
  415. SC.GetValue<bool>($"CarrierInfo.EnableDualTransfer{InfoPadCarrierIndex}"))
  416. {
  417. return true;
  418. }
  419. return base.IsEnableDualTransfer(out reason);
  420. }
  421. public override CIDReaderBaseDevice[] CIDReaders
  422. {
  423. get { return base.CIDReaders; }
  424. set
  425. {
  426. base.CIDReaders = value;
  427. }
  428. }
  429. private void InitializeLP()
  430. {
  431. if (_doLoadPortOK != null)
  432. _doLoadPortOK.SetTrigger(true, out _);
  433. //_deviceAddress = SC.GetValue<int>($"{Name}.DeviceAddress");
  434. //InfoPadType,0=TDK,1=Ext,2=FixedbySC
  435. if (_isTcpConnection)
  436. {
  437. Address = SC.GetStringValue($"LoadPort.{Name}.Address");
  438. _tcpConnection = new TDKBLoadPortTCPConnection(this, Address);
  439. _tcpConnection.EnableLog(_enableLog);
  440. if (_tcpConnection.Connect())
  441. {
  442. //LOG.Write($"Connected with {Module}.{Name} .");
  443. EV.PostInfoLog(Module, $"Connected with {Module}.{Name} .");
  444. }
  445. else
  446. {
  447. EV.PostAlarmLog(Module, $"Can't connect to {Module}.{Name}.");
  448. }
  449. }
  450. else
  451. {
  452. string portName = SC.GetStringValue($"LoadPort.{Name}.PortName");
  453. int bautRate = SC.GetValue<int>($"LoadPort.{Name}.BaudRate");
  454. int dataBits = SC.GetValue<int>($"LoadPort.{Name}.DataBits");
  455. Enum.TryParse(SC.GetStringValue($"LoadPort.{Name}.Parity"), out Parity parity);
  456. Enum.TryParse(SC.GetStringValue($"LoadPort.{Name}.StopBits"), out StopBits stopBits);
  457. Address = portName;
  458. _connection = new TDKBLoadPortConnection(this, portName, bautRate, dataBits, parity, stopBits);
  459. _connection.EnableLog(_enableLog);
  460. int count = SC.ContainsItem("System.ComPortRetryCount") ? SC.GetValue<int>("System.ComPortRetryCount") : 5;
  461. int sleep = SC.ContainsItem("System.ComPortRetryDelayTime") ? SC.GetValue<int>("System.ComPortRetryDelayTime") : 2;
  462. if (sleep <= 0 || sleep > 10)
  463. sleep = 2;
  464. int retry = 0;
  465. do
  466. {
  467. _connection.Disconnect();
  468. Thread.Sleep(sleep * 1000);
  469. if (_connection.Connect())
  470. {
  471. //LOG.Write($"Connected with {Module}.{Name} .");
  472. EV.PostInfoLog(Module, $"Connected with {Module}.{Name} .");
  473. break;
  474. }
  475. if (count > 0 && retry++ > count)
  476. {
  477. EV.PostAlarmLog(Module, $"Can't connect to {Module}.{Name}.");
  478. break;
  479. }
  480. } while (true);
  481. _connection.IsEnableHandlerRetry = true;
  482. }
  483. ConnectionManager.Instance.Subscribe($"{Name}", this);
  484. _thread = new PeriodicJob(50, OnTimer, $"{Module}.{Name} MonitorHandler", true);
  485. }
  486. private int _idleMonitorInterval;
  487. private bool _isEnableIdleMonitorState
  488. {
  489. get
  490. {
  491. if (SC.ContainsItem($"LoadPort.{Name}.EnableIdleMonitorState"))
  492. return SC.GetValue<bool>($"LoadPort.{Name}.EnableIdleMonitorState");
  493. return false;
  494. }
  495. }
  496. private bool OnTimer()
  497. {
  498. try
  499. {
  500. MonitorFoupState();
  501. if (_isTcpConnection)
  502. {
  503. _tcpConnection.EnableLog(_enableLog);
  504. _trigCommunicationError.CLK = _tcpConnection.IsCommunicationError;
  505. if (_trigCommunicationError.Q)
  506. {
  507. EV.PostAlarmLog(Module, $"{Module}.{Name} communication error, {_tcpConnection.LastCommunicationError}");
  508. OnError("Communicartion Error");
  509. }
  510. }
  511. else
  512. {
  513. _connection.EnableLog(_enableLog);
  514. _trigCommunicationError.CLK = _connection.IsCommunicationError;
  515. if (_trigCommunicationError.Q)
  516. {
  517. EV.PostAlarmLog(Module, $"{Module}.{Name} communication error, {_connection.LastCommunicationError}");
  518. OnError("Communicartion Error");
  519. }
  520. }
  521. if (_isTcpConnection)
  522. {
  523. _tcpConnection.MonitorTimeout();
  524. if (!_tcpConnection.IsConnected || _tcpConnection.IsCommunicationError)
  525. {
  526. lock (_locker)
  527. {
  528. _lstHandler.Clear();
  529. }
  530. _trigRetryConnect.CLK = !_tcpConnection.IsConnected;
  531. if (_trigRetryConnect.Q)
  532. {
  533. Address = SC.GetStringValue($"LoadPort.{Name}.Address");
  534. _tcpConnection = new TDKBLoadPortTCPConnection(this, Address);
  535. _tcpConnection.EnableLog(_enableLog);
  536. if (!_tcpConnection.Connect())
  537. {
  538. EV.PostAlarmLog(Module, $"Can not connect with {_tcpConnection.Address}, {Module}.{Name}");
  539. }
  540. }
  541. return true;
  542. }
  543. //_trigActionDone.CLK = (_lstHandler.Count == 0 && !_tcpConnection.IsBusy);
  544. //if (_trigActionDone.Q)
  545. // OnActionDone(null);
  546. HandlerBase handler = null;
  547. if (!_tcpConnection.IsBusy)
  548. {
  549. lock (_locker)
  550. {
  551. if (_lstHandler.Count == 0)
  552. {
  553. }
  554. if (_lstHandler.Count > 0)
  555. {
  556. handler = _lstHandler.First.Value;
  557. if (handler != null) _tcpConnection.Execute(handler);
  558. _lstHandler.RemoveFirst();
  559. }
  560. }
  561. }
  562. }
  563. else
  564. {
  565. _connection.MonitorTimeout();
  566. if (!_connection.IsConnected || _connection.IsCommunicationError)
  567. {
  568. lock (_locker)
  569. {
  570. _lstHandler.Clear();
  571. }
  572. _trigRetryConnect.CLK = !_connection.IsConnected;
  573. if (_trigRetryConnect.Q)
  574. {
  575. _connection.SetPortAddress(SC.GetStringValue($"LoadPort.{Name}.PortName"));
  576. if (!_connection.Connect())
  577. {
  578. EV.PostAlarmLog(Module, $"Can not connect with {_connection.Address}, {Module}.{Name}");
  579. }
  580. }
  581. return true;
  582. }
  583. HandlerBase handler = null;
  584. if (!_connection.IsBusy)
  585. {
  586. lock (_locker)
  587. {
  588. if (_lstHandler.Count == 0)
  589. {
  590. if(CurrentState == LoadPortStateEnum.TransferBlock)
  591. {
  592. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  593. }
  594. if(IsReady() && _isEnableIdleMonitorState && ContainerStatus != TDKContainerStatus.Absence)
  595. {
  596. if (_idleMonitorInterval > 5)
  597. {
  598. _idleMonitorInterval = 0;
  599. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  600. }
  601. _idleMonitorInterval++;
  602. }
  603. }
  604. if (_lstHandler.Count > 0)
  605. {
  606. handler = _lstHandler.First.Value;
  607. if (handler != null) _connection.Execute(handler);
  608. _lstHandler.RemoveFirst();
  609. }
  610. }
  611. }
  612. }
  613. if (_infoPadType == 1) //Extenal
  614. {
  615. InfoPadSensorIndex = (_diInfoPadA == null || !_diInfoPadA.Value ? 0 : 1) +
  616. (_diInfoPadB == null || !_diInfoPadB.Value ? 0 : 2) +
  617. (_diInfoPadC == null || !_diInfoPadC.Value ? 0 : 4) +
  618. (_diInfoPadD == null || !_diInfoPadD.Value ? 0 : 8);
  619. }
  620. if (IsAutoDetectCarrierType)
  621. {
  622. if (_infoPadType == 2) //Fixed by SC
  623. {
  624. InfoPadCarrierIndex = SC.GetValue<int>($"LoadPort.{Name}.CarrierIndex");
  625. }
  626. if(_infoPadType == 1) //External
  627. {
  628. InfoPadCarrierIndex = InfoPadSensorIndex;
  629. }
  630. if(_infoPadType == 0) //Internal
  631. {
  632. }
  633. }
  634. else //Fixed by SC
  635. {
  636. InfoPadCarrierIndex = SC.GetValue<int>($"LoadPort.{Name}.CarrierIndex");
  637. }
  638. }
  639. catch (Exception ex)
  640. {
  641. LOG.Write(ex);
  642. }
  643. return true;
  644. }
  645. public override bool IsRequestFOSBMode
  646. {
  647. get
  648. {
  649. if (SC.ContainsItem($"CarrierInfo.CarrierFosbMode{InfoPadCarrierIndex}"))
  650. return SC.GetValue<int>($"CarrierInfo.CarrierFosbMode{InfoPadCarrierIndex}") == 1;
  651. if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierFosbMode"))
  652. return SC.GetValue<bool>($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierFosbMode");
  653. return false;
  654. }
  655. set => base.IsRequestFOSBMode = value;
  656. }
  657. public override bool IsMapWaferByLoadPort
  658. {
  659. get
  660. {
  661. if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.MappedByRobot"))
  662. return !SC.GetValue<bool>($"CarrierInfo.Carrier{InfoPadCarrierIndex}.MappedByRobot");
  663. return !IsRequestFOSBMode;
  664. }
  665. }
  666. public void LPSetInfoPadSensorIndex(int index)
  667. {
  668. if(_infoPadType ==0)
  669. {
  670. InfoPadSensorIndex = index;
  671. if(IsAutoDetectCarrierType)
  672. InfoPadCarrierIndex = InfoPadSensorIndex;
  673. }
  674. }
  675. public override void Monitor()
  676. {
  677. base.Monitor();
  678. try
  679. {
  680. }
  681. catch (Exception ex)
  682. {
  683. LOG.Write(ex);
  684. }
  685. }
  686. private void MonitorFoupState()
  687. {
  688. if (IsPlacement)
  689. {
  690. int currentfoupstatecode = (ClampPosition == TDKPosition.Close ? 0 : 1) +
  691. (DockPosition == TDKDockPosition.Dock ? 0 : 2) +
  692. (DoorState == FoupDoorState.Close ? 0 : 4) +
  693. (DoorPosition == FoupDoorPostionEnum.Down ? 0 : 8);
  694. if(currentfoupstatecode!= _foupstatecode)
  695. {
  696. _dtFoupStateStart = DateTime.Now;
  697. _foupstatecode = currentfoupstatecode;
  698. }
  699. if (DateTime.Now - _dtFoupStateStart > TimeSpan.FromSeconds(TimeLimitNoOperation) && TimeLimitNoOperation > 0)
  700. {
  701. SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
  702. dvid["AlarmDescription"] = $"carrier:{_carrierId} on {LPModuleName} no operation time over limit";
  703. //EV.Notify(AlarmTdkNoOperation, dvid);
  704. EV.PostWarningLog("LoadPort",$"Carrier:{_carrierId} on {LPModuleName} no operation time over limit");
  705. _dtFoupStateStart = DateTime.Now;
  706. }
  707. }
  708. else
  709. {
  710. _dtFoupStateStart = DateTime.Now;
  711. }
  712. }
  713. private DateTime _dtFoupStateStart = DateTime.Now;
  714. private int _foupstatecode = -1;
  715. private R_TRIG _trigActionDone = new R_TRIG();
  716. private string _scRoot;
  717. private bool _isTcpConnection;
  718. private TDKBLoadPortConnection _connection;
  719. private TDKBLoadPortTCPConnection _tcpConnection;
  720. private IoTrigger _doLoadPortOK;
  721. private IoSensor _diInfoPadA;
  722. private IoSensor _diInfoPadB;
  723. private IoSensor _diInfoPadC;
  724. private IoSensor _diInfoPadD;
  725. private IoSensor _diIronCassetteDoorOpenLeft;
  726. public IoSensor DiIronCassetteDoorOpenLeft
  727. {
  728. get => _diIronCassetteDoorOpenLeft;
  729. set
  730. {
  731. _diIronCassetteDoorOpenLeft = value;
  732. _diIronCassetteDoorOpenLeft.OnSignalChanged += _diIronCassetteDoorOpen_OnSignalChanged;
  733. }
  734. }
  735. private IoSensor _diIronCassetteDoorOpenRight;
  736. public IoSensor DiIronCassetteDoorOpenRight
  737. {
  738. get => _diIronCassetteDoorOpenRight;
  739. set
  740. {
  741. _diIronCassetteDoorOpenRight = value;
  742. _diIronCassetteDoorOpenRight.OnSignalChanged += _diIronCassetteDoorOpen_OnSignalChanged; ;
  743. }
  744. }
  745. private object _lockerIronCst = new object();
  746. private void _diIronCassetteDoorOpen_OnSignalChanged(IoSensor arg1, bool arg2)
  747. {
  748. if(!_isNeedCheckIronStickDoor) return;
  749. lock (_lockerIronCst)
  750. {
  751. if (!_diIronCassetteDoorOpenLeft.Value && !_diIronCassetteDoorOpenRight.Value)
  752. {
  753. if (!IsPlacement || DockState != FoupDockState.Undocked) return;
  754. if (!IsReady()) return;
  755. if (ClampState == FoupClampState.Close)
  756. Unclamp(out _);
  757. }
  758. if (_diIronCassetteDoorOpenLeft.Value && _diIronCassetteDoorOpenRight.Value)
  759. {
  760. if (!IsPlacement || DockState != FoupDockState.Undocked) return;
  761. if (!IsReady()) return;
  762. if (ClampState == FoupClampState.Open)
  763. Clamp(out _);
  764. }
  765. }
  766. }
  767. private bool _isNeedCheckIronStickDoor
  768. {
  769. get
  770. {
  771. if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.NeedCheckIronDoorCarrier"))
  772. return SC.GetValue<bool>($"CarrierInfo.Carrier{InfoPadCarrierIndex}.NeedCheckIronDoorCarrier");
  773. return false;
  774. }
  775. }
  776. public override bool IsEnableLoad(out string reason)
  777. {
  778. if(_isNeedCheckIronStickDoor)
  779. {
  780. if (_diIronCassetteDoorOpenRight != null && !_diIronCassetteDoorOpenRight.Value)
  781. {
  782. reason = "IronCstRightProtectionClose";
  783. return false;
  784. }
  785. if (_diIronCassetteDoorOpenLeft != null && !_diIronCassetteDoorOpenLeft.Value)
  786. {
  787. reason = "IronCstLeftProtectionClose";
  788. return false;
  789. }
  790. }
  791. return base.IsEnableLoad(out reason);
  792. }
  793. private int _infoPadType
  794. {
  795. get => SC.ContainsItem($"LoadPort.{Name}.InfoPadType") ? SC.GetValue<int>($"LoadPort.{Name}.InfoPadType") : 2;
  796. }
  797. public int InfoPadType => _infoPadType;
  798. public TDKBLoadPortConnection Connection
  799. {
  800. get => _connection;
  801. }
  802. public TDKBLoadPortTCPConnection TCPConnection => _tcpConnection;
  803. private PeriodicJob _thread;
  804. private static Object _locker = new Object();
  805. private LinkedList<HandlerBase> _lstHandler = new LinkedList<HandlerBase>();
  806. private bool _enableLog => SC.GetValue<bool>($"LoadPort.{Name}.EnableLogMessage");
  807. //private bool _commErr = false;
  808. private R_TRIG _trigError = new R_TRIG();
  809. private R_TRIG _trigWarningMessage = new R_TRIG();
  810. private R_TRIG _trigCommunicationError = new R_TRIG();
  811. private R_TRIG _trigRetryConnect = new R_TRIG();
  812. public TDKSystemStatus SystemStatus { get; set; }
  813. public TDKMode Mode { get; set; }
  814. public TDKInitPosMovement InitPosMovement { get; set; }
  815. public TDKOperationStatus OperationStatus { get; set; }
  816. public TDKContainerStatus ContainerStatus { get; set; }
  817. public TDKPosition ClampPosition { get; set; }
  818. public TDKPosition LPDoorLatchPosition { get; set; }
  819. public TDKVacummStatus VacuumStatus { get; set; }
  820. public TDKPosition LPDoorState { get; set; }
  821. public TDKWaferProtrusion WaferProtrusion { get; set; }
  822. public TDKElevatorAxisPosition ElevatorAxisPosition { get; set; }
  823. public TDKDockPosition DockPosition { get; set; }
  824. public TDKMapPosition MapperPostion { get; set; }
  825. public TDKMappingStatus MappingStatus { get; set; }
  826. public TDKModel Model { get; set; }
  827. public string Address { get; set; }
  828. public bool IsConnected => _connection.IsConnected;
  829. public override bool IsEnableTransferWafer(out string reason)
  830. {
  831. if(LPDoorState != TDKPosition.Open)
  832. {
  833. reason = "Door is not open";
  834. return false;
  835. }
  836. if(DockPosition != TDKDockPosition.Dock)
  837. {
  838. reason = "Foup is not dock";
  839. return false;
  840. }
  841. if (IsWaferProtrude)
  842. {
  843. int iCount = 0;
  844. while(true)
  845. {
  846. Thread.Sleep(100);
  847. iCount++;
  848. if (!IsWaferProtrude)
  849. break;
  850. if (iCount >15)
  851. {
  852. reason = "Wafer Protrude";
  853. return false;
  854. }
  855. }
  856. }
  857. if (_isNeedCheckIronStickDoor)
  858. {
  859. if(_diIronCassetteDoorOpenRight != null && !_diIronCassetteDoorOpenRight.Value)
  860. {
  861. reason = "IronCstRightProtectionClose";
  862. return false;
  863. }
  864. if (_diIronCassetteDoorOpenLeft != null && !_diIronCassetteDoorOpenLeft.Value)
  865. {
  866. reason = "IronCstLeftProtectionClose";
  867. return false;
  868. }
  869. }
  870. if (IsVerifyPreDefineWaferCount && WaferCount != PreDefineWaferCount)
  871. {
  872. reason = "Mapping Error:WaferCount not matched";
  873. return false;
  874. }
  875. return base.IsEnableTransferWafer(out reason);
  876. }
  877. public override bool IsEnableMapWafer(out string reason)
  878. {
  879. if (IsWaferProtrude)
  880. {
  881. int iCount = 0;
  882. while (true)
  883. {
  884. Thread.Sleep(100);
  885. iCount++;
  886. if (!IsWaferProtrude)
  887. break;
  888. if (iCount > 15)
  889. {
  890. reason = "Wafer Protrude";
  891. return false;
  892. }
  893. }
  894. }
  895. if (_isNeedCheckIronStickDoor)
  896. {
  897. if (_diIronCassetteDoorOpenRight != null && !_diIronCassetteDoorOpenRight.Value)
  898. {
  899. reason = "IronCstRightProtectionClose";
  900. return false;
  901. }
  902. if (_diIronCassetteDoorOpenLeft != null && !_diIronCassetteDoorOpenLeft.Value)
  903. {
  904. reason = "IronCstLeftProtectionClose";
  905. return false;
  906. }
  907. }
  908. return base.IsEnableMapWafer(out reason);
  909. }
  910. public bool Disconnect()
  911. {
  912. if (_isTcpConnection)
  913. return _tcpConnection.Disconnect();
  914. return _connection.Disconnect();
  915. }
  916. public void OnCarrierNotPlaced()
  917. {
  918. _isPlaced = false;
  919. ConfirmRemoveCarrier();
  920. }
  921. public void OnCarrierNotPresent()
  922. {
  923. _isPresent = false;
  924. //ConfirmRemoveCarrier();
  925. }
  926. public void OnCarrierPlaced()
  927. {
  928. _isPlaced = true;
  929. ConfirmAddCarrier();
  930. }
  931. public void OnCarrierPresent()
  932. {
  933. _isPresent = true;
  934. //ConfirmAddCarrier();
  935. }
  936. public void OnSwitchKey1()
  937. {
  938. _isAccessSwPressed = true;
  939. switch(ManualSwitchHandle)
  940. {
  941. case ManualSwHandleEnum.Clamp:
  942. if(ClampState == FoupClampState.Close)
  943. {
  944. StartClampAction(false);
  945. }
  946. if(ClampState == FoupClampState.Open)
  947. {
  948. StartClampAction(true);
  949. }
  950. break;
  951. case ManualSwHandleEnum.Load:
  952. if (DockState == FoupDockState.Docked)
  953. {
  954. Unload(out _);
  955. }
  956. if (DockState == FoupDockState.Undocked)
  957. {
  958. Load(out _);
  959. }
  960. break;
  961. case ManualSwHandleEnum.ProceedWithCarrier:
  962. RequestProceedWithCarrier(CarrierId);
  963. break;
  964. }
  965. }
  966. public void OnSwitchKey2()
  967. {
  968. }
  969. public void OffSwitchKey1()
  970. {
  971. _isAccessSwPressed = false;
  972. }
  973. public void OffSwitchKey2()
  974. {
  975. }
  976. public bool OnEvent(out string reason)
  977. {
  978. reason = string.Empty;
  979. lock (_locker)
  980. {
  981. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  982. _lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  983. _lstHandler.AddLast(new TDKBGetHandler(this, "LEDST", null));
  984. }
  985. return true;
  986. }
  987. private LoadportCassetteState _cassetteState = LoadportCassetteState.None;
  988. public override LoadportCassetteState CassetteState
  989. {
  990. get { return _cassetteState; }
  991. set
  992. {
  993. _cassetteState = value;
  994. }
  995. }
  996. public void SetCassetteState(LoadportCassetteState state)
  997. {
  998. _cassetteState = state;
  999. if (state == LoadportCassetteState.Normal)
  1000. {
  1001. OnCarrierPresent();
  1002. OnCarrierPlaced();
  1003. }
  1004. if (state == LoadportCassetteState.Absent)
  1005. {
  1006. OnCarrierNotPlaced();
  1007. OnCarrierNotPresent();
  1008. }
  1009. }
  1010. public override WaferSize GetCurrentWaferSize()
  1011. {
  1012. int intwz = 0;
  1013. if(SC.ContainsItem($"CarrierInfo.CarrierWaferSize{InfoPadCarrierIndex}"))
  1014. intwz = SC.GetValue<int>($"CarrierInfo.CarrierWaferSize{InfoPadCarrierIndex}");
  1015. if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierWaferSize"))
  1016. intwz = SC.GetValue<int>($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierWaferSize");
  1017. switch (intwz)
  1018. {
  1019. case 0:
  1020. return WaferSize.WS0;
  1021. case 1:
  1022. return WaferSize.WS0;
  1023. case 2:
  1024. return WaferSize.WS2;
  1025. case 3:
  1026. return WaferSize.WS3;
  1027. case 4:
  1028. return WaferSize.WS4;
  1029. case 5:
  1030. return WaferSize.WS5;
  1031. case 6:
  1032. return WaferSize.WS6;
  1033. case 7:
  1034. case 8:
  1035. return WaferSize.WS8;
  1036. case 12:
  1037. return WaferSize.WS12;
  1038. default:
  1039. return WaferSize.WS0;
  1040. }
  1041. }
  1042. public override string SpecCarrierType
  1043. {
  1044. get
  1045. {
  1046. if(SC.ContainsItem($"CarrierInfo.CarrierName{InfoPadCarrierIndex}"))
  1047. return SC.GetStringValue($"CarrierInfo.CarrierName{InfoPadCarrierIndex}");
  1048. if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierName"))
  1049. return SC.GetStringValue($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierName");
  1050. return "";
  1051. }
  1052. set => base.SpecCarrierType = value;
  1053. }
  1054. public override string SpecCarrierInformation
  1055. {
  1056. get
  1057. {
  1058. if (_isPresent)
  1059. return "Index:" + InfoPadCarrierIndex.ToString()
  1060. + $"\r\nInfoPad:{InfoPadSensorIndex}"
  1061. + $"\r\nType:{SpecCarrierType}"
  1062. + $"\r\nSize:{GetCurrentWaferSize()}"
  1063. + (IsVerifyPreDefineWaferCount ? ("\r\n" + "Pre-Count:" + PreDefineWaferCount.ToString()) : "")
  1064. + $"\r\n{(IsMapped ? "Mapped" : "Not Mapped")}"
  1065. + $"\r\nClamp:{ClampPosition}"
  1066. + $"\r\nDocked:{DockState}";
  1067. return "";
  1068. }
  1069. }
  1070. protected override bool fStartWrite(object[] param)
  1071. {
  1072. return true;
  1073. }
  1074. protected override bool fStartRead(object[] param)
  1075. {
  1076. return true;
  1077. }
  1078. protected override bool fStartExecute(object[] param)
  1079. {
  1080. try
  1081. {
  1082. switch (param[0].ToString())
  1083. {
  1084. case "SetIndicator":
  1085. Indicator light = (Indicator)param[1];
  1086. int lightIndex = ParseLightIndex(light);
  1087. IndicatorState state = (IndicatorState)param[2];
  1088. string[] statestr = new string[] { "", "LON", "LBL", "LOF" };
  1089. lock (_locker)
  1090. {
  1091. _lstHandler.AddLast(new TDKBSetHandler(this, statestr[(int)state]+ $"{lightIndex:D2}",null));
  1092. _lstHandler.AddLast(new TDKBGetHandler(this, "LEDST", null));
  1093. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1094. IsBusy = false;
  1095. }
  1096. break;
  1097. case "QueryIndicator":
  1098. lock (_locker)
  1099. {
  1100. _lstHandler.AddLast(new TDKBGetHandler(this, "LEDST", null));
  1101. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1102. }
  1103. break;
  1104. case "QueryState":
  1105. lock (_locker)
  1106. {
  1107. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1108. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1109. }
  1110. break;
  1111. case "Undock":
  1112. lock (_locker)
  1113. {
  1114. _lstHandler.AddLast(new TDKBMoveHandler(this, "YWAIT", null));
  1115. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1116. }
  1117. break;
  1118. case "Dock":
  1119. lock (_locker)
  1120. {
  1121. _lstHandler.AddLast(new TDKBMoveHandler(this, "YDOOR", null));
  1122. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1123. }
  1124. break;
  1125. case "CloseDoor":
  1126. lock (_locker)
  1127. {
  1128. _lstHandler.AddLast(new TDKBMoveHandler(this, "DORFW", null));
  1129. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1130. }
  1131. break;
  1132. case "OpenDoor":
  1133. lock (_locker)
  1134. {
  1135. _lstHandler.AddLast(new TDKBMoveHandler(this, "DORBK", null));
  1136. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1137. }
  1138. break;
  1139. case "Unclamp":
  1140. lock (_locker)
  1141. {
  1142. _lstHandler.AddLast(new TDKBMoveHandler(this, "PODOP", null));
  1143. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1144. }
  1145. break;
  1146. case "Clamp":
  1147. lock (_locker)
  1148. {
  1149. _lstHandler.AddLast(new TDKBMoveHandler(this, "PODCL", null));
  1150. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1151. }
  1152. break;
  1153. case "DoorUp":
  1154. lock (_locker)
  1155. {
  1156. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRUP", null));
  1157. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1158. }
  1159. break;
  1160. case "DoorDown":
  1161. lock (_locker)
  1162. {
  1163. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRDW", null));
  1164. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1165. }
  1166. break;
  1167. case "OpenDoorNoMap":
  1168. lock (_locker)
  1169. {
  1170. //_lstHandler.AddLast(new TDKMoveHandler(this, "YDOOR", null));
  1171. }
  1172. break;
  1173. case "OpenDoorAndMap":
  1174. lock (_locker)
  1175. {
  1176. //_lstHandler.AddLast(new TDKMoveHandler(this, "YDOOR", null));
  1177. }
  1178. break;
  1179. case "MapWafer":
  1180. lock (_locker)
  1181. {
  1182. if (!IsMapWaferByLoadPort)
  1183. {
  1184. if (MapRobot != null)
  1185. return MapRobot.WaferMapping(LPModuleName, out _);
  1186. return false;
  1187. }
  1188. if (DockPosition != TDKDockPosition.Dock)
  1189. _lstHandler.AddLast(new TDKBMoveHandler(this, "YDOOR", null));
  1190. if (DoorState != FoupDoorState.Open)
  1191. _lstHandler.AddLast(new TDKBMoveHandler(this, "DORBK", null));
  1192. _lstHandler.AddLast(new TDKBMoveHandler(this, "MAPDO", null));
  1193. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1194. _lstHandler.AddLast(new TDKBGetHandler(this, "MAPRD", null));
  1195. }
  1196. break;
  1197. case "DoorUpAndClose":
  1198. lock (_locker)
  1199. {
  1200. if(IsNeedMapOnUnload && IsMapWaferByLoadPort)
  1201. _lstHandler.AddLast(new TDKBMoveHandler(this, "CUMDK", null));
  1202. else
  1203. {
  1204. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRUP", null));
  1205. _lstHandler.AddLast(new TDKBMoveHandler(this, "DORFW", null));
  1206. }
  1207. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1208. }
  1209. break;
  1210. case "OpenDoorAndDown":
  1211. lock (_locker)
  1212. {
  1213. _lstHandler.AddLast(new TDKBMoveHandler(this, "DORBK", null));
  1214. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRDW", null));
  1215. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1216. }
  1217. break;
  1218. case "Move":
  1219. lock (_locker)
  1220. {
  1221. if(IsRequestFOSBMode && _isUndockOCBeforeHome && (param[1].ToString() == "ABORG" ||
  1222. param[1].ToString() == "ORGSH"))
  1223. {
  1224. _lstHandler.AddLast(new TDKBMoveHandler(this, "YWAIT", null));
  1225. }
  1226. _lstHandler.AddLast(new TDKBMoveHandler(this, param[1].ToString(), null));
  1227. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1228. }
  1229. break;
  1230. case "Set":
  1231. lock (_locker)
  1232. {
  1233. _lstHandler.AddLast(new TDKBSetHandler(this, param[1].ToString(), null));
  1234. }
  1235. break;
  1236. case "Get":
  1237. lock (_locker)
  1238. {
  1239. _lstHandler.AddLast(new TDKBGetHandler(this, param[1].ToString(), null));
  1240. }
  1241. break;
  1242. }
  1243. return true;
  1244. }
  1245. catch (Exception ex)
  1246. {
  1247. LOG.Write(ex);
  1248. EV.PostAlarmLog(Name, $"Parameter invalid");
  1249. return false;
  1250. }
  1251. }
  1252. protected override bool fMonitorExecuting(object[] param)
  1253. {
  1254. if (_lstHandler.Count == 0 && !_connection.IsBusy)
  1255. {
  1256. OnActionDone(null);
  1257. }
  1258. return false;
  1259. }
  1260. private int ParseLightIndex(Indicator light)
  1261. {
  1262. if (SC.ContainsItem($"LoadPort.{LPModuleName}.{light}_IndicatorIndex"))
  1263. return SC.GetValue<int>($"LoadPort.{LPModuleName}.{light}_IndicatorIndex");
  1264. return (int)light;
  1265. }
  1266. protected override bool fStartUnload(object[] param)
  1267. {
  1268. if (!_isPlaced)
  1269. {
  1270. EV.PostAlarmLog(Name, $"No carrier on {Name},can't unload.");
  1271. return false;
  1272. }
  1273. if (!_isDocked)
  1274. {
  1275. EV.PostAlarmLog(Name, $"Carrier is not docked on {Name},can't unload.");
  1276. return false;
  1277. }
  1278. if (IsRequestFOSBMode)
  1279. {
  1280. lock (_locker)
  1281. {
  1282. //_lstHandler.AddLast(new TDKBSetHandler(this, "FSB", "ON"));
  1283. //_lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  1284. _lstHandler.Clear();
  1285. if (IsNeedMapOnUnload && IsMapWaferByLoadPort)
  1286. {
  1287. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRUP", null));
  1288. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZMPST", null));
  1289. _lstHandler.AddLast(new TDKBMoveHandler(this, "MAPOP", null));
  1290. _lstHandler.AddLast(new TDKBMoveHandler(this, "MSTON", null));
  1291. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRMP", null));
  1292. _lstHandler.AddLast(new TDKBMoveHandler(this, "MAPCL", null));
  1293. _lstHandler.AddLast(new TDKBMoveHandler(this, "MSTOF", null));
  1294. }
  1295. _lstHandler.AddLast(new TDKBMoveHandler(this, "YWAIT", null));
  1296. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRUP", null));
  1297. _lstHandler.AddLast(new TDKBMoveHandler(this, "DORFW", null));
  1298. }
  1299. }
  1300. else
  1301. {
  1302. if (DoorPosition == FoupDoorPostionEnum.Up && DoorState == FoupDoorState.Close)
  1303. {
  1304. lock (_locker)
  1305. {
  1306. _lstHandler.AddLast(new TDKBMoveHandler(this, "CUDCL", null));
  1307. }
  1308. }
  1309. else
  1310. {
  1311. if(IsNeedMapOnUnload && IsMapWaferByLoadPort)
  1312. _lstHandler.AddLast(new TDKBMoveHandler(this, "CUMFC", null));
  1313. else
  1314. {
  1315. _lstHandler.AddLast(new TDKBMoveHandler(this, "CULFC", null));
  1316. }
  1317. }
  1318. }
  1319. if (!IsKeepClampAfterUnload)
  1320. _lstHandler.AddLast(new TDKBMoveHandler(this, "PODOP", null));
  1321. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1322. _lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  1323. _lstHandler.AddLast(new TDKBGetHandler(this, "LEDST", null));
  1324. if (IsNeedMapOnUnload && IsMapWaferByLoadPort)
  1325. _lstHandler.AddLast(new TDKBGetHandler(this, "MAPRD", null));
  1326. return true;
  1327. }
  1328. protected override bool fMonitorUnload(object[] param)
  1329. {
  1330. IsBusy = false;
  1331. if (_lstHandler.Count == 0 && !_connection.IsBusy)
  1332. OnActionDone(null);
  1333. return false;
  1334. }
  1335. protected override void StartClampAction(bool isClamp)
  1336. {
  1337. if(isClamp)
  1338. {
  1339. lock (_locker)
  1340. {
  1341. _lstHandler.AddLast(new TDKBMoveHandler(this, "PODCL", null));
  1342. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1343. }
  1344. }
  1345. else
  1346. {
  1347. lock (_locker)
  1348. {
  1349. _lstHandler.AddLast(new TDKBMoveHandler(this, "PODOP", null));
  1350. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1351. }
  1352. }
  1353. }
  1354. protected override bool fStartLoad(object[] param)
  1355. {
  1356. lock (_locker)
  1357. {
  1358. _lstHandler.Clear();
  1359. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1360. }
  1361. //int waitCount = 0;
  1362. //while(_lstHandler.Count != 0|| _connection.IsBusy)
  1363. //{
  1364. // waitCount++;
  1365. // Thread.Sleep(50);
  1366. // if(waitCount > 200)
  1367. // {
  1368. // OnError("Query State timeout before load");
  1369. // return false;
  1370. // }
  1371. //}
  1372. if (!_isPlaced)
  1373. {
  1374. EV.PostAlarmLog(Name, $"No carrier on {Name},can't load.");
  1375. return false;
  1376. }
  1377. if (_isDocked)
  1378. {
  1379. EV.PostAlarmLog(Name, $"Carrier is docked on {Name},can't load.");
  1380. return false;
  1381. }
  1382. if (IsRequestFOSBMode)
  1383. {
  1384. lock (_locker)
  1385. {
  1386. _lstHandler.Clear();
  1387. if (!IsFosbModeActual)
  1388. {
  1389. _lstHandler.AddLast(new TDKBSetHandler(this, "FSB", "ON"));
  1390. _lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  1391. }
  1392. if (ClampPosition == TDKPosition.Open)
  1393. {
  1394. _lstHandler.AddLast(new TDKBMoveHandler(this, "PODCL", null));
  1395. }
  1396. _lstHandler.AddLast(new TDKBMoveHandler(this, "DORBK", null));
  1397. if (IsMapWaferByLoadPort)
  1398. {
  1399. _lstHandler.AddLast(new TDKBMoveHandler(this, "YDOOR", null));
  1400. _lstHandler.AddLast(new TDKBMoveHandler(this, "CLMPO", null));
  1401. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1402. _lstHandler.AddLast(new TDKBGetHandler(this, "MAPRD", null));
  1403. }
  1404. else
  1405. {
  1406. _lstHandler.AddLast(new TDKBMoveHandler(this, "ZDRDW", null));
  1407. _lstHandler.AddLast(new TDKBMoveHandler(this, "YDOOR", null));
  1408. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1409. }
  1410. }
  1411. }
  1412. else
  1413. {
  1414. lock (_locker)
  1415. {
  1416. if (IsFosbModeActual)
  1417. {
  1418. _lstHandler.AddLast(new TDKBSetHandler(this, "FSB", "OF"));
  1419. _lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  1420. }
  1421. //if (ClampPosition == TDKPosition.Open)
  1422. //{
  1423. // _lstHandler.AddLast(new TDKBMoveHandler(this, "PODCL", null));
  1424. //}
  1425. //_lstHandler.AddLast(new TDKBMoveHandler(this, "YDOOR", null));
  1426. //_lstHandler.AddLast(new TDKBMoveHandler(this, "VACON", null));
  1427. //_lstHandler.AddLast(new TDKBMoveHandler(this, "DOROP", null));
  1428. if (IsMapWaferByLoadPort)
  1429. {
  1430. //_lstHandler.AddLast(new TDKBMoveHandler(this, "CLMPO", null));
  1431. _lstHandler.AddLast(new TDKBMoveHandler(this, "CLDMP", null));
  1432. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1433. _lstHandler.AddLast(new TDKBGetHandler(this, "MAPRD", null));
  1434. }
  1435. else
  1436. {
  1437. _lstHandler.AddLast(new TDKBMoveHandler(this, "CLOAD", null));
  1438. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1439. }
  1440. }
  1441. }
  1442. return true;
  1443. }
  1444. protected override bool fMonitorLoad(object[] param)
  1445. {
  1446. IsBusy = false;
  1447. if (_lstHandler.Count == 0 && !_connection.IsBusy)
  1448. {
  1449. OnLoaded();
  1450. if (IsMapWaferByLoadPort)
  1451. OnSlotMapRead(CurrentSlotMapResult);
  1452. return true;
  1453. }
  1454. return false;
  1455. }
  1456. protected override bool fStartInit(object[] param)
  1457. {
  1458. lock (_locker)
  1459. {
  1460. _lstHandler.AddLast(new TDKBModHandler(this, "ONMGV", null));
  1461. if(IsRequestFOSBMode && _isUndockOCBeforeHome)
  1462. {
  1463. _lstHandler.AddLast(new TDKBMoveHandler(this, "YWAIT", null));
  1464. }
  1465. if (param.Length >= 1 && param[0].ToString() == "ForceHome")
  1466. _lstHandler.AddLast(new TDKBMoveHandler(this, "ABORG", null));
  1467. else
  1468. _lstHandler.AddLast(new TDKBMoveHandler(this, "ORGSH", null));
  1469. if(E84DeviceType == E84DeviceTypeEnum.Internal)
  1470. {
  1471. _lstHandler.AddLast(new TDKBSetHandler(this, "E84EN/", "OFF"));
  1472. _lstHandler.AddLast(new TDKBSetHandler(this, "e84rv", "1"));
  1473. _lstHandler.AddLast(new TDKBSetHandler(this, "e84ce/", "1"));
  1474. if (SC.ContainsItem($"LoadPort.{Name}.AccessMode") && SC.GetValue<bool>($"LoadPort.{Name}.AccessMode"))
  1475. {
  1476. _lstHandler.AddLast(new TDKBSetHandler(this, "E84EN/", "ON"));
  1477. IsAccessAuto = true;
  1478. }
  1479. }
  1480. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1481. _lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  1482. _lstHandler.AddLast(new TDKBGetHandler(this, "LEDST", null));
  1483. }
  1484. return true;
  1485. }
  1486. protected override bool fMonitorInit(object[] param)
  1487. {
  1488. IsBusy = false;
  1489. if (_lstHandler.Count == 0 && !_connection.IsBusy)
  1490. OnActionDone(null);
  1491. return false;
  1492. }
  1493. public override bool SetIndicator(Indicator light, IndicatorState state, out string reason)
  1494. {
  1495. reason = "";
  1496. return fStartExecute(new object[] { "SetIndicator", light, state });
  1497. }
  1498. protected override bool fStartReset(object[] param)
  1499. {
  1500. _lstHandler.Clear();
  1501. if (_isTcpConnection)
  1502. {
  1503. if (!_tcpConnection.IsConnected)
  1504. _tcpConnection.Connect();
  1505. _tcpConnection.ForceClear();
  1506. }
  1507. else
  1508. {
  1509. if (!_connection.IsConnected)
  1510. _connection.Connect();
  1511. if(_connection.IsCommunicationError)
  1512. {
  1513. _connection.Disconnect();
  1514. Thread.Sleep(500);
  1515. _connection.Connect();
  1516. }
  1517. _connection.ForceClear();
  1518. }
  1519. lock (_locker)
  1520. {
  1521. _lstHandler.AddLast(new TDKBModHandler(this, "ONMGV", null));
  1522. _lstHandler.AddLast(new TDKBSetHandler(this, "RESET", null));
  1523. if (E84DeviceType == E84DeviceTypeEnum.Internal)
  1524. {
  1525. _lstHandler.AddLast(new TDKBSetHandler(this, "E84EN/", "OFF"));
  1526. _lstHandler.AddLast(new TDKBSetHandler(this, "e84rv", "1"));
  1527. if (SC.ContainsItem($"LoadPort.{Name}.AccessMode") && SC.GetValue<bool>($"LoadPort.{Name}.AccessMode"))
  1528. {
  1529. _lstHandler.AddLast(new TDKBSetHandler(this, "E84EN/", "ON"));
  1530. IsAccessAuto = true;
  1531. }
  1532. }
  1533. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1534. _lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  1535. _lstHandler.AddLast(new TDKBGetHandler(this, "LEDST", null));
  1536. }
  1537. return true;
  1538. }
  1539. protected override bool fMonitorReset(object[] param)
  1540. {
  1541. if (_lstHandler.Count == 0 && !_connection.IsBusy)
  1542. OnActionDone(null);
  1543. return false;
  1544. }
  1545. public override void OnError(string error = "")
  1546. {
  1547. lock (_locker)
  1548. {
  1549. _lstHandler.Clear();
  1550. if (_isTcpConnection)
  1551. _tcpConnection.ForceClear();
  1552. else
  1553. _connection.ForceClear();
  1554. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1555. _lstHandler.AddLast(new TDKBGetHandler(this, "FSBxx", null));
  1556. _lstHandler.AddLast(new TDKBGetHandler(this, "LEDST", null));
  1557. }
  1558. base.OnError(error);
  1559. }
  1560. public void OnAbs(string absMsg)
  1561. {
  1562. try
  1563. {
  1564. string absContext = absMsg.Split('/')[1].Replace(";", "").Replace("\r","");
  1565. EV.Notify($"{Name}{absContext}");
  1566. }
  1567. catch(Exception ex)
  1568. {
  1569. LOG.Write(ex);
  1570. }
  1571. OnError("Recieve ABS Message:" + absMsg);
  1572. }
  1573. public void OnNak(string absMsg)
  1574. {
  1575. try
  1576. {
  1577. string absContext = absMsg.Split('/')[1].Replace(";", "").Replace("\r", "");
  1578. EV.Notify($"{Name}{absContext}");
  1579. }
  1580. catch (Exception ex)
  1581. {
  1582. LOG.Write(ex);
  1583. }
  1584. OnError("Recieve Nak Message:" + absMsg);
  1585. }
  1586. public override void Terminate()
  1587. {
  1588. _thread.Stop();
  1589. Thread.Sleep(100);
  1590. if (!SC.ContainsItem($"{_scRoot}.{Name}.CloseConnectionOnShutDown") || SC.GetValue<bool>($"{_scRoot}.{Name}.CloseConnectionOnShutDown"))
  1591. {
  1592. LOG.Write($"Close {Address} for connection of {LPModuleName}");
  1593. _connection.Disconnect();
  1594. _connection.TerminateCom();
  1595. }
  1596. base.Terminate();
  1597. }
  1598. public override bool IsForbidAccessSlotAboveWafer()
  1599. {
  1600. if (SC.ContainsItem($"CarrierInfo.ForbidAccessAboveWaferCarrier{InfoPadCarrierIndex}"))
  1601. return SC.GetValue<bool>($"CarrierInfo.ForbidAccessAboveWaferCarrier{InfoPadCarrierIndex}");
  1602. return base.IsForbidAccessSlotAboveWafer();
  1603. }
  1604. public override void OnSlotMapRead(string _slotMap)
  1605. {
  1606. if(IsVerifyPreDefineWaferCount && CurrentState != LoadPortStateEnum.Unloading)
  1607. {
  1608. int wcount = 0;
  1609. foreach(var ch in _slotMap)
  1610. {
  1611. if(ch != '0')
  1612. {
  1613. wcount++;
  1614. }
  1615. }
  1616. WaferCount = wcount;
  1617. if (WaferCount != PreDefineWaferCount)
  1618. {
  1619. EV.PostAlarmLog("LoadPort", $"{LPModuleName} mapping error,predefine count is {PreDefineWaferCount}, " +
  1620. $"Mapping result is {WaferCount}.");
  1621. OnError("Mapping Error");
  1622. }
  1623. }
  1624. base.OnSlotMapRead(_slotMap);
  1625. }
  1626. private string m_LPStateInfo = "";
  1627. internal void ParseState(string cmddata)
  1628. {
  1629. if(m_LPStateInfo != cmddata)
  1630. {
  1631. EV.PostInfoLog("LoadPort", $"{LPModuleName} state change to {cmddata}");
  1632. m_LPStateInfo = cmddata;
  1633. }
  1634. byte[] data = Encoding.ASCII.GetBytes(cmddata.Replace("STATE/", ""));
  1635. if (data.Length < 20) return;
  1636. SystemStatus = (TDKSystemStatus)data[0];
  1637. Mode = (TDKMode)data[1];
  1638. InitPosMovement = (TDKInitPosMovement)data[2];
  1639. OperationStatus = (TDKOperationStatus)data[3];
  1640. ErrorCode = Encoding.ASCII.GetString(new byte[] { data[4], data[5] });
  1641. ContainerStatus = (TDKContainerStatus)data[6];
  1642. ClampPosition = (TDKPosition)data[7];
  1643. LPDoorLatchPosition = (TDKPosition)data[8];
  1644. VacuumStatus = (TDKVacummStatus)data[9];
  1645. LPDoorState = (TDKPosition)data[10];
  1646. WaferProtrusion = (TDKWaferProtrusion)data[11];
  1647. ElevatorAxisPosition = (TDKElevatorAxisPosition)data[12];
  1648. DockPosition = (TDKDockPosition)data[13];
  1649. MapperPostion = (TDKMapPosition)data[14];
  1650. MappingStatus = (TDKMappingStatus)data[17];
  1651. Model = (TDKModel)data[18];
  1652. int infopadstatus = Convert.ToInt16($"0x{Encoding.ASCII.GetString(new byte[] { data[19] })}", 16);
  1653. int indexValue = (((infopadstatus & 1) != 0) ? 8 : 0) + (((infopadstatus & 2) != 0) ? 4 : 0) +
  1654. (((infopadstatus & 4) != 0) ? 2 : 0) + (((infopadstatus & 8) != 0) ? 1 : 0);
  1655. LPSetInfoPadSensorIndex(indexValue);
  1656. IsError = SystemStatus != TDKSystemStatus.Normal;
  1657. ErrorCode = Encoding.ASCII.GetString(new byte[] { data[4], data[5] });
  1658. LoadportCassetteState st = LoadportCassetteState.None;
  1659. if (ContainerStatus == TDKContainerStatus.Absence) st = LoadportCassetteState.Absent;
  1660. if (ContainerStatus == TDKContainerStatus.NormalMount) st = LoadportCassetteState.Normal;
  1661. if (ContainerStatus == TDKContainerStatus.MountError)
  1662. {
  1663. st = LoadportCassetteState.Absent;
  1664. }
  1665. SetCassetteState(st);
  1666. if (ClampPosition == TDKPosition.Close)
  1667. ClampState = FoupClampState.Close;
  1668. else if (ClampPosition == TDKPosition.Open)
  1669. ClampState = FoupClampState.Open;
  1670. else if (ClampPosition == TDKPosition.TBD)
  1671. ClampState = FoupClampState.Unknown;
  1672. if (LPDoorState == TDKPosition.Close)
  1673. DoorState = FoupDoorState.Close;
  1674. if (LPDoorState == TDKPosition.Open)
  1675. DoorState = FoupDoorState.Open;
  1676. if (LPDoorState == TDKPosition.TBD)
  1677. DoorState = FoupDoorState.Unknown;
  1678. DockState = ConvertTDKDockPositin(DockPosition); // Load port dock state
  1679. if (ElevatorAxisPosition == TDKElevatorAxisPosition.UP)
  1680. DoorPosition = FoupDoorPostionEnum.Up;
  1681. if (ElevatorAxisPosition == TDKElevatorAxisPosition.Down)
  1682. DoorPosition = FoupDoorPostionEnum.Down; // = TDKZ_AxisPos.Down;
  1683. if (ElevatorAxisPosition == TDKElevatorAxisPosition.MappingEndPos)
  1684. DoorPosition = FoupDoorPostionEnum.MapEnd;// = TDKZ_AxisPos.End;
  1685. if (ElevatorAxisPosition == TDKElevatorAxisPosition.MappingStartPos)
  1686. DoorPosition = FoupDoorPostionEnum.MapStart;// = TDKZ_AxisPos.Start;
  1687. if (ElevatorAxisPosition == TDKElevatorAxisPosition.TBD)
  1688. DoorPosition = FoupDoorPostionEnum.Unknown;// = TDKZ_AxisPos.Unknown;
  1689. }
  1690. private FoupDockState ConvertTDKDockPositin(TDKDockPosition dockPosition)
  1691. {
  1692. if (dockPosition == TDKDockPosition.Dock) return FoupDockState.Docked;
  1693. if (dockPosition == TDKDockPosition.Undock) return FoupDockState.Undocked;
  1694. return FoupDockState.Unknown;
  1695. }
  1696. public override bool RequestReadyToUnload()
  1697. {
  1698. if (DockPosition != TDKDockPosition.Undock)
  1699. return false;
  1700. if (DoorState != FoupDoorState.Close)
  1701. return false;
  1702. if(ClampPosition == TDKPosition.Close)
  1703. {
  1704. lock(_locker)
  1705. {
  1706. _lstHandler.AddLast(new TDKBMoveHandler(this, "PODOP", null));
  1707. _lstHandler.AddLast(new TDKBGetHandler(this, "STATE", null));
  1708. }
  1709. return false;
  1710. }
  1711. return true;
  1712. }
  1713. }
  1714. }