123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773 |
- using Aitex.Core.Common;
- using Aitex.Core.RT.DataCenter;
- using Aitex.Core.RT.Device.Unit;
- using Aitex.Core.RT.Event;
- using Aitex.Core.RT.Log;
- using Aitex.Core.RT.SCCore;
- using Aitex.Core.Util;
- using Aitex.Sorter.Common;
- using MECF.Framework.Common.Communications;
- using MECF.Framework.Common.SubstrateTrackings;
- using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.CarrierIdReaders.CarrierIDReaderBase;
- using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.LoadPortBase;
- using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.TDK;
- using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Robots.RobotBase;
- using System;
- using System.Collections.Generic;
- using System.Diagnostics;
- using System.IO.Ports;
- using System.Linq;
- using System.Text;
- using System.Threading;
- using System.Threading.Tasks;
- namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.SG
- {
- public class SELP8LoadPort : LoadPortBaseDevice, IConnection
- {
- public SELP8LoadPort(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)
- {
- _scRoot = scRoot;
- _isTcpConnection = IsTCPconnection;
- LoadPortType = "SELP8LoadPort";
- if (dos != null && dos.Length >= 1)
- {
- _doLoadPortOK = dos[0];
- }
- if (dis != null && dis.Length >= 1)
- {
- _diInfoPadA = dis[0];
- _diInfoPadA.OnSignalChanged += _diInfoPad_OnSignalChanged;
- }
- if (dis != null && dis.Length >= 2)
- {
- _diInfoPadB = dis[1];
- _diInfoPadB.OnSignalChanged += _diInfoPad_OnSignalChanged;
- }
- if (dis != null && dis.Length >= 3)
- {
- _diInfoPadC = dis[2];
- _diInfoPadC.OnSignalChanged += _diInfoPad_OnSignalChanged;
- }
- if (dis != null && dis.Length >= 4)
- {
- _diInfoPadD = dis[3];
- _diInfoPadB.OnSignalChanged += _diInfoPad_OnSignalChanged;
- }
- InitializeLP();
- SubscribeLPData();
- //SubscribeLPAlarm();
- }
- protected Stopwatch _timerActionMonitor = new Stopwatch();
- private void SubscribeLPData()
- {
- if (Module != "")
- {
- DATA.Subscribe($"{Module}.{Name}.SystemStatus", () => SystemStatus.ToString());
- DATA.Subscribe($"{Module}.{Name}.Mode", () => Mode.ToString());
- DATA.Subscribe($"{Module}.{Name}.InitPosMovement", () => InitPosMovement.ToString());
- DATA.Subscribe($"{Module}.{Name}.OperationStatus", () => OperationStatus.ToString());
- DATA.Subscribe($"{Module}.{Name}.ErrorCode", () => ErrorCode.ToString());
- DATA.Subscribe($"{Module}.{Name}.ContainerStatus", () => ContainerStatus.ToString());
- DATA.Subscribe($"{Module}.{Name}.ClampPosition", () => ClampPosition.ToString());
- DATA.Subscribe($"{Module}.{Name}.LPDoorLatchPosition", () => LPDoorLatchPosition.ToString());
- DATA.Subscribe($"{Module}.{Name}.VacuumStatus", () => VacuumStatus.ToString());
- DATA.Subscribe($"{Module}.{Name}.LPDoorState", () => LPDoorState.ToString());
- DATA.Subscribe($"{Module}.{Name}.WaferProtrusion", () => WaferProtrusion.ToString());
- DATA.Subscribe($"{Module}.{Name}.ElevatorAxisPosition", () => ElevatorAxisPosition.ToString());
- DATA.Subscribe($"{Module}.{Name}.MapperPostion", () => MapperPostion.ToString());
- DATA.Subscribe($"{Module}.{Name}.MappingStatus", () => MappingStatus.ToString());
- DATA.Subscribe($"{Module}.{Name}.Model", () => Model.ToString());
- DATA.Subscribe($"{Module}.{Name}.IsFosbModeActual", () => IsFosbModeActual.ToString());
- DATA.Subscribe($"{Module}.{Name}.DockPosition", () => DockPosition.ToString());
- }
- else
- {
- DATA.Subscribe($"{Name}.SystemStatus", () => SystemStatus.ToString());
- DATA.Subscribe($"{Name}.Mode", () => Mode.ToString());
- DATA.Subscribe($"{Name}.InitPosMovement", () => InitPosMovement.ToString());
- DATA.Subscribe($"{Name}.OperationStatus", () => OperationStatus.ToString());
- DATA.Subscribe($"{Name}.ErrorCode", () => ErrorCode.ToString());
- DATA.Subscribe($"{Name}.ContainerStatus", () => ContainerStatus.ToString());
- DATA.Subscribe($"{Name}.ClampPosition", () => ClampPosition.ToString());
- DATA.Subscribe($"{Name}.LPDoorLatchPosition", () => LPDoorLatchPosition.ToString());
- DATA.Subscribe($"{Name}.VacuumStatus", () => VacuumStatus.ToString());
- DATA.Subscribe($"{Name}.LPDoorState", () => LPDoorState.ToString());
- DATA.Subscribe($"{Name}.WaferProtrusion", () => WaferProtrusion.ToString());
- DATA.Subscribe($"{Name}.ElevatorAxisPosition", () => ElevatorAxisPosition.ToString());
- DATA.Subscribe($"{Name}.MapperPostion", () => MapperPostion.ToString());
- DATA.Subscribe($"{Name}.MappingStatus", () => MappingStatus.ToString());
- DATA.Subscribe($"{Name}.Model", () => Model.ToString());
- DATA.Subscribe($"{Name}.IsFosbModeActual", () => IsFosbModeActual.ToString());
- DATA.Subscribe($"{Name}.DockPosition", () => DockPosition.ToString());
- }
- }
- public void OnInputSignaChange(string evtcontent)
- {
- string data = evtcontent.Split('/').LastOrDefault().Replace("\r", "").Replace(";", "");
- int value11 = Convert.ToInt32(data.Substring(0, 1), 16);
- int value7 = Convert.ToInt32(data.Substring(4, 1), 16);
- InfoPadSensorIndex = ((value11 & 0x1) == 0x1 ? 8 : 0) + ((value11 & 0x2) == 0x2 ? 4 : 0) +
- ((value7 & 0x2) == 0x2 ? 2 : 0) + ((value7 & 0x4) == 0x4 ? 1 : 0);
-
-
- }
- private void SubscribeLPAlarm()
- {
- EV.Subscribe(new EventItem("Alarm", AlarmTdkZLMIT, $"Load Port {Name} Z-axis position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkYLMIT, $"Load Port {Name} Y-axis position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkPROTS, $"Load Port {Name} Wafer protrusion", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkDLMIT, $"Load Port {Name} Door forward/backward position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkMPBAR, $"Load Port {Name} Mapper arm position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
-
-
- EV.Subscribe(new EventItem("Alarm", AlarmTdkMPSTP, $"Load Port {Name} Mapper stopper position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkMPEDL, $"Load Port {Name} Mapping end position: NG", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkCLOPS, $"Load Port {Name} FOUP clamp open error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkCLCLS, $"Load Port {Name} FOUP clamp close error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkDROPS, $"Load Port {Name} Latch key open error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkDRCLS, $"Load Port {Name} Latch key close error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkVACCS, $"Load Port {Name} Vacuum on error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkVACOS, $"Load Port {Name} Vacuum off error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkAIRSN, $"Load Port {Name} Main air error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkINTOP, $"Load Port {Name} Normal position error at FOUP open", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkINTCL, $"Load Port {Name} Normal position error at FOUP close", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkINTMP, $"Load Port {Name} Mapper storage error when Z-axis lowered", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkINTPI, $"Load Port {Name} Parallel signal error from upper machine", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkSAFTY, $"Load Port {Name} Interlock relay failure", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkFANST, $"Load Port {Name} Fan operation error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkMPDOG, $"Load Port {Name} Mapping mechanical(Adjustment) error", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkDRDKE, $"Load Port {Name} Door detection error during dock.", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkDRSWE, $"Load Port {Name} Door detection error except dock", EventLevel.Alarm, EventType.EventUI_Notify));
- EV.Subscribe(new EventItem("Alarm", AlarmTdkNoOperation, $"Load Port {Name} No action when foup is present", EventLevel.Alarm, EventType.EventUI_Notify));
- }
- private string AlarmTdkZLMIT { get => LPModuleName.ToString() + "ZLMIT"; }
- private string AlarmTdkYLMIT { get => LPModuleName.ToString() + "YLMIT"; }
- private string AlarmTdkPROTS { get => LPModuleName.ToString() + "PROTS"; }
- private string AlarmTdkDLMIT { get => LPModuleName.ToString() + "DLMIT"; }
- private string AlarmTdkMPBAR { get => LPModuleName.ToString() + "MPBAR"; }
- private string AlarmTdkMPSTP { get => LPModuleName.ToString() + "MPSTP"; }
- private string AlarmTdkMPEDL { get => LPModuleName.ToString() + "MPEDL"; }
- private string AlarmTdkCLOPS { get => LPModuleName.ToString() + "CLOPS"; }
- private string AlarmTdkCLCLS { get => LPModuleName.ToString() + "CLCLS"; }
- private string AlarmTdkDROPS { get => LPModuleName.ToString() + "DROPS"; }
- private string AlarmTdkDRCLS { get => LPModuleName.ToString() + "DRCLS"; }
- private string AlarmTdkVACCS { get => LPModuleName.ToString() + "VACCS"; }
- private string AlarmTdkVACOS { get => LPModuleName.ToString() + "VACOS"; }
- private string AlarmTdkAIRSN { get => LPModuleName.ToString() + "AIRSN"; }
- private string AlarmTdkINTOP { get => LPModuleName.ToString() + "INTOP"; }
- private string AlarmTdkINTCL { get => LPModuleName.ToString() + "INTCL"; }
- private string AlarmTdkINTMP { get => LPModuleName.ToString() + "INTMP"; }
- private string AlarmTdkINTPI { get => LPModuleName.ToString() + "INTPI"; }
- private string AlarmTdkSAFTY { get => LPModuleName.ToString() + "SAFTY"; }
- private string AlarmTdkFANST { get => LPModuleName.ToString() + "FANST"; }
- private string AlarmTdkMPDOG { get => LPModuleName.ToString() + "MPDOG"; }
- private string AlarmTdkDRDKE { get => LPModuleName.ToString() + "DRDKE"; }
- private string AlarmTdkDRSWE { get => LPModuleName.ToString() + "DRSWE"; }
- private string AlarmTdkNoOperation { get => LPModuleName.ToString() + "NoOperation"; }
- private void _diInfoPad_OnSignalChanged(IoSensor arg1, bool arg2)
- {
- //if (_infoPadType == 1)
- // InfoPadCarrierIndex = (_diInfoPadA == null || !_diInfoPadA.Value ? 0 : 1) +
- // (_diInfoPadB == null || !_diInfoPadB.Value ? 0 : 2) +
- // (_diInfoPadC == null || !_diInfoPadC.Value ? 0 : 4) +
- // (_diInfoPadD == null || !_diInfoPadD.Value ? 0 : 8);
- }
- public override int InfoPadCarrierIndex
- {
- get { return base.InfoPadCarrierIndex; }
- set
- {
- if (base.InfoPadCarrierIndex != value)
- {
- base.InfoPadCarrierIndex = value;
- EV.PostInfoLog("LoadPort", $"{LPModuleName} infopad index change to {value}");
-
- }
- }
- }
- public override bool IsEnableDualTransfer(out string reason)
- {
- return base.IsEnableDualTransfer(out reason);
- }
- public override CIDReaderBaseDevice[] CIDReaders
- {
- get { return base.CIDReaders; }
- set
- {
- base.CIDReaders = value;
- //EV.PostInfoLog("LoadPort", $"{LPModuleName} infopad index change to {value}");
- //if (CIDReaders != null && CIDReaders.Length > 1)
- //{
- // int cidindex = SC.GetValue<int>($"CarrierInfo.{LPModuleName}CIDReaderIndex{InfoPadCarrierIndex}");
-
- // if (CIDReaders.Length <= cidindex)
- // {
- // EV.PostAlarmLog("System", $"The carrier info configuration for CIDReaderIndex{cidindex} is invalid.");
- // }
- // else
- // {
- // CarrierIDReaderCallBack = CIDReaders[cidindex];
- // }
- //}
- }
- }
- public bool IsHandlerBusy
- {
- get
- {
- return _lstHandler.Count != 0 || _connection.IsBusy;
- }
- }
- public LinkedList<Tuple<int, int>> WaferPositionData { get; set; } = new LinkedList<Tuple<int, int>>();
- private void InitializeLP()
- {
- IsMapWaferByLoadPort = true;
- if (_doLoadPortOK != null)
- _doLoadPortOK.SetTrigger(true, out _);
- //_deviceAddress = SC.GetValue<int>($"{Name}.DeviceAddress");
- //InfoPadType,0=TDK,1=Ext,2=FixedbySC
-
- _enableLog = SC.GetValue<bool>($"LoadPort.{Name}.EnableLogMessage");
- if (_isTcpConnection)
- {
- Address = SC.GetStringValue($"LoadPort.{Name}.Address");
- _tcpConnection = new SELP8LoadPortTCPConnection(this, Address);
- _tcpConnection.EnableLog(_enableLog);
- if (_tcpConnection.Connect())
- {
- //LOG.Write($"Connected with {Module}.{Name} .");
- EV.PostInfoLog(Module, $"Connected with {Module}.{Name} .");
- }
- else
- {
- EV.PostAlarmLog(Module, $"Can't connect to {Module}.{Name}.");
- }
- }
- else
- {
- string portName = SC.GetStringValue($"LoadPort.{Name}.PortName");
- int bautRate = SC.GetValue<int>($"LoadPort.{Name}.BaudRate");
- int dataBits = SC.GetValue<int>($"LoadPort.{Name}.DataBits");
- Enum.TryParse(SC.GetStringValue($"LoadPort.{Name}.Parity"), out Parity parity);
- Enum.TryParse(SC.GetStringValue($"LoadPort.{Name}.StopBits"), out StopBits stopBits);
- Address = portName;
- _connection = new SELP8LoadPortConnection(this, portName, bautRate, dataBits, parity, stopBits);
- _connection.IsEnableHandlerRetry = true;
- _connection.EnableLog(_enableLog);
- int count = SC.ContainsItem("System.ComPortRetryCount") ? SC.GetValue<int>("System.ComPortRetryCount") : 5;
- int sleep = SC.ContainsItem("System.ComPortRetryDelayTime") ? SC.GetValue<int>("System.ComPortRetryDelayTime") : 2;
- if (sleep <= 0 || sleep > 10)
- sleep = 2;
- int retry = 0;
- do
- {
- _connection.Disconnect();
- Thread.Sleep(sleep * 1000);
- if (_connection.Connect())
- {
- //LOG.Write($"Connected with {Module}.{Name} .");
- EV.PostInfoLog(Module, $"Connected with {Module}.{Name} .");
- break;
- }
- if (count > 0 && retry++ > count)
- {
- EV.PostAlarmLog(Module, $"Can't connect to {Module}.{Name}.");
- break;
- }
- } while (true);
- }
-
- ConnectionManager.Instance.Subscribe($"{Name}", this);
- _thread = new PeriodicJob(50, OnTimer, $"{Module}.{Name} MonitorHandler", true);
- }
- private HandlerBase _currentHandler;
- private bool OnTimer()
- {
- try
- {
- MonitorFoupState();
- if (_isTcpConnection)
- {
- _tcpConnection.EnableLog(_enableLog);
- _trigCommunicationError.CLK = _tcpConnection.IsCommunicationError;
- if (_trigCommunicationError.Q)
- {
- EV.PostAlarmLog(Module, $"{Module}.{Name} communication error, {_tcpConnection.LastCommunicationError}");
- OnError("Communicartion Error");
- }
- }
- else
- {
- _connection.EnableLog(_enableLog);
- _trigCommunicationError.CLK = _connection.IsCommunicationError;
- if (_trigCommunicationError.Q)
- {
- EV.PostAlarmLog(Module, $"{Module}.{Name} communication error, {_connection.LastCommunicationError}");
- OnError("Communicartion Error");
- }
- }
- if (_isTcpConnection)
- {
- _tcpConnection.MonitorTimeout();
- if (!_tcpConnection.IsConnected || _tcpConnection.IsCommunicationError)
- {
- lock (_locker)
- {
- _lstHandler.Clear();
- }
- _trigRetryConnect.CLK = !_tcpConnection.IsConnected;
- if (_trigRetryConnect.Q)
- {
- Address = SC.GetStringValue($"LoadPort.{Name}.Address");
- _tcpConnection = new SELP8LoadPortTCPConnection(this, Address);
- _tcpConnection.EnableLog(_enableLog);
- if (!_tcpConnection.Connect())
- {
- EV.PostAlarmLog(Module, $"Can not connect with {_tcpConnection.Address}, {Module}.{Name}");
- }
- }
- return true;
- }
- //_trigActionDone.CLK = (_lstHandler.Count == 0 && !_tcpConnection.IsBusy);
- //if (_trigActionDone.Q)
- // OnActionDone(null);
- //HandlerBase handler = null;
- if (!_tcpConnection.IsBusy)
- {
- lock (_locker)
- {
- if (_lstHandler.Count == 0)
- {
- }
- if (_lstHandler.Count > 0)
- {
- _currentHandler = _lstHandler.First.Value;
- if (_currentHandler != null) _tcpConnection.Execute(_currentHandler);
- _lstHandler.RemoveFirst();
- }
- }
- }
- }
- else
- {
- _connection.MonitorTimeout();
- if (!_connection.IsConnected || _connection.IsCommunicationError)
- {
- lock (_locker)
- {
- _lstHandler.Clear();
- }
- _trigRetryConnect.CLK = !_connection.IsConnected;
- if (_trigRetryConnect.Q)
- {
- _connection.SetPortAddress(SC.GetStringValue($"{Name}.Address"));
- if (!_connection.Connect())
- {
- EV.PostAlarmLog(Module, $"Can not connect with {_connection.Address}, {Module}.{Name}");
- }
- }
- return true;
- }
- //_trigActionDone.CLK = (_lstHandler.Count == 0 && !_connection.IsBusy);
- //if (_trigActionDone.Q)
- // OnActionDone(null);
- //HandlerBase handler = null;
- if (!_connection.IsBusy)
- {
- lock (_locker)
- {
- if (_lstHandler.Count == 0)
- {
- }
- if (_lstHandler.Count > 0)
- {
- _currentHandler = _lstHandler.First.Value;
- if (_currentHandler != null) _connection.Execute(_currentHandler);
- _lstHandler.RemoveFirst();
- }
- }
- }
- }
- if (_infoPadType == 1) //External
- {
- InfoPadSensorIndex = (_diInfoPadA == null || !_diInfoPadA.Value ? 0 : 1) +
- (_diInfoPadB == null || !_diInfoPadB.Value ? 0 : 2) +
- (_diInfoPadC == null || !_diInfoPadC.Value ? 0 : 4) +
- (_diInfoPadD == null || !_diInfoPadD.Value ? 0 : 8);
- }
- if (IsAutoDetectCarrierType)
- {
- if (_infoPadType == 2) //Fixed by SC
- {
- InfoPadCarrierIndex = SC.GetValue<int>($"LoadPort.{Name}.CarrierIndex");
- }
- if (_infoPadType == 0 || _infoPadType == 1)
- {
- InfoPadCarrierIndex = InfoPadSensorIndex;
- }
- }
- else //Fixed by SC
- {
- InfoPadCarrierIndex = SC.GetValue<int>($"LoadPort.{Name}.CarrierIndex");
- }
-
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- }
- return true;
- }
- public void LPSetInfoPadSensorIndex(int index)
- {
- if (_infoPadType == 0)
- {
- InfoPadSensorIndex = index;
- }
- }
- protected int _retryTimes;
- public bool RetryHandler()
- {
- if (_currentHandler == null) return false;
- if (_retryTimes > 6) return false;
- Thread.Sleep(500);
- lock(_locker)
- {
- _lstHandler.AddFirst(_currentHandler);
- //if(_isTcpConnection)
- //{
- // _tcpConnection.Execute(_currentHandler);
- //}
- //else
- //{
- // _connection.Execute(_currentHandler);
- //}
- }
- _retryTimes++;
- return true;
- }
- public override void Monitor()
- {
- base.Monitor();
-
- try
- {
-
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- }
- }
- private void MonitorFoupState()
- {
- if (IsPlacement)
- {
- int currentfoupstatecode = (ClampPosition == TDKPosition.Close ? 0 : 1) +
- (DockPosition == TDKDockPosition.Dock ? 0 : 2) +
- (DoorState == FoupDoorState.Close ? 0 : 4) +
- (DoorPosition == FoupDoorPostionEnum.Down ? 0 : 8);
- if(currentfoupstatecode!= _foupstatecode)
- {
- _dtFoupStateStart = DateTime.Now;
- _foupstatecode = currentfoupstatecode;
- }
-
- if(DateTime.Now - _dtFoupStateStart > TimeSpan.FromSeconds(TimeLimitNoOperation) && TimeLimitNoOperation>0)
- {
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"carrier:{_carrierId} on {LPModuleName} no operation time over limit";
- EV.Notify(AlarmTdkNoOperation,dvid);
- _dtFoupStateStart = DateTime.Now;
- }
- }
- else
- {
- _dtFoupStateStart = DateTime.Now;
- }
- }
- private DateTime _dtFoupStateStart = DateTime.Now;
- private int _foupstatecode = -1;
- private R_TRIG _trigActionDone = new R_TRIG();
- private string _scRoot;
- private bool _isTcpConnection;
- private SELP8LoadPortConnection _connection;
- private SELP8LoadPortTCPConnection _tcpConnection;
- private IoTrigger _doLoadPortOK;
- private IoSensor _diInfoPadA;
- private IoSensor _diInfoPadB;
- private IoSensor _diInfoPadC;
- private IoSensor _diInfoPadD;
- private int _infoPadType
- {
- get
- {
- return SC.ContainsItem($"LoadPort.{Name}.InfoPadType") ?
- SC.GetValue<int>($"LoadPort.{Name}.InfoPadType") : 2;
- }
- }
- public int InfoPadType => _infoPadType;
- public SELP8LoadPortConnection Connection
- {
- get => _connection;
- }
- public SELP8LoadPortTCPConnection TCPConnection => _tcpConnection;
- private PeriodicJob _thread;
- protected static Object _locker = new Object();
- protected LinkedList<HandlerBase> _lstHandler = new LinkedList<HandlerBase>();
- private bool _enableLog = true;
- //private bool _commErr = false;
- private R_TRIG _trigError = new R_TRIG();
- private R_TRIG _trigWarningMessage = new R_TRIG();
- private R_TRIG _trigCommunicationError = new R_TRIG();
- private R_TRIG _trigRetryConnect = new R_TRIG();
- public TDKSystemStatus SystemStatus { get; set; }
- public TDKMode Mode { get; set; }
- public TDKInitPosMovement InitPosMovement { get; set; }
- public TDKOperationStatus OperationStatus { get; set; }
- public TDKContainerStatus ContainerStatus { get; set; }
- public TDKPosition ClampPosition { get; set; }
- public TDKPosition LPDoorLatchPosition { get; set; }
- public TDKVacummStatus VacuumStatus { get; set; }
- public TDKPosition LPDoorState { get; set; }
- public TDKWaferProtrusion WaferProtrusion { get; set; }
- public TDKElevatorAxisPosition ElevatorAxisPosition { get; set; }
- public TDKDockPosition DockPosition { get; set; }
- public TDKMapPosition MapperPostion { get; set; }
- public TDKMappingStatus MappingStatus { get; set; }
- public TDKModel Model { get; set; }
- public string Address { get; set; }
- public bool IsConnected
- {
- get
- {
- if (_isTcpConnection)
- return TCPConnection.IsConnected;
- return _connection.IsConnected;
- }
- }
- public override bool IsEnableTransferWafer(out string reason)
- {
- if(!IsLoaded)
- {
- reason = "Not loaded";
- return false;
- }
- if(LPDoorState != TDKPosition.Open)
- {
- reason = "Door is not open";
- return false;
- }
- if(DockPosition != TDKDockPosition.Dock)
- {
- reason = "Foup is not dock";
- return false;
- }
- return base.IsEnableTransferWafer(out reason);
- }
- public bool Disconnect()
- {
- if (_isTcpConnection)
- return _tcpConnection.Disconnect();
- return _connection.Disconnect();
- }
- public void OnCarrierNotPlaced()
- {
- _isPlaced = false;
- ConfirmRemoveCarrier();
- }
- public void OnCarrierNotPresent()
- {
- _isPresent = false;
- //ConfirmRemoveCarrier();
- }
- public void OnCarrierPlaced()
- {
- _isPlaced = true;
- ConfirmAddCarrier();
- }
- public void OnCarrierPresent()
- {
- _isPresent = true;
- //ConfirmAddCarrier();
- }
- public void OnSwitchKey1()
- {
- _isAccessSwPressed = true;
- }
- public void OnSwitchKey2()
- {
- }
- public void OffSwitchKey1()
- {
- _isAccessSwPressed = false;
- }
- public void OffSwitchKey2()
- {
- }
- public bool OnEvent(out string reason)
- {
- reason = string.Empty;
- lock (_locker)
- {
-
- //_lstHandler.AddLast(new SELP8GetHandler(this, "FSBxx", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "LEDST", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- return true;
- }
- private LoadportCassetteState _cassetteState = LoadportCassetteState.None;
- public override LoadportCassetteState CassetteState
- {
- get { return _cassetteState; }
- set
- {
- _cassetteState = value;
- }
- }
- public void SetCassetteState(LoadportCassetteState state)
- {
- _cassetteState = state;
- if (state == LoadportCassetteState.Normal)
- {
- OnCarrierPresent();
- OnCarrierPlaced();
-
- }
- if(state == LoadportCassetteState.Absent)
- {
- OnCarrierNotPlaced();
- OnCarrierNotPresent();
- }
- }
- public override bool IsRequestFOSBMode
- {
- get
- {
- //if (SC.ContainsItem($"CarrierInfo.CarrierFosbMode{InfoPadCarrierIndex}"))
- // return SC.GetValue<int>($"CarrierInfo.CarrierFosbMode{InfoPadCarrierIndex}") == 1;
- if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierFosbMode"))
- return SC.GetValue<bool>($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierFosbMode");
- return false;
- }
- set => base.IsRequestFOSBMode = value;
- }
- public override bool IsMapWaferByLoadPort
- {
- get
- {
- if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.MappedByRobot"))
- return !SC.GetValue<bool>($"CarrierInfo.Carrier{InfoPadCarrierIndex}.MappedByRobot");
- return !IsRequestFOSBMode;
- }
- }
- public override WaferSize GetCurrentWaferSize()
- {
- return base.GetCurrentWaferSize();
- //int intwz = SC.GetValue<int>($"CarrierInfo.CarrierWaferSize{InfoPadCarrierIndex}");
- //switch(intwz)
- //{
- // case 0:
- // return WaferSize.WS0;
- // case 1:
- // return WaferSize.WS0;
- // case 2:
- // return WaferSize.WS2;
- // case 3:
- // return WaferSize.WS3;
- // case 4:
- // return WaferSize.WS4;
- // case 5:
- // return WaferSize.WS5;
- // case 6:
- // return WaferSize.WS6;
- // case 7:
- // case 8:
- // return WaferSize.WS8;
- // case 12:
- // return WaferSize.WS12;
- // default:
- // return WaferSize.WS0;
- //}
- }
- public override string SpecCarrierType
- {
- get
- {
- if (SC.ContainsItem($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierName"))
- return SC.GetStringValue($"CarrierInfo.Carrier{InfoPadCarrierIndex}.CarrierName");
- if (SC.ContainsItem($"CarrierInfo.CarrierName{InfoPadCarrierIndex}"))
- return SC.GetStringValue($"CarrierInfo.CarrierName{InfoPadCarrierIndex}");
- return "";
- }
- set => base.SpecCarrierType = value;
- }
- protected override bool fStartWrite(object[] param)
- {
- return true;
- }
- protected override bool fStartRead(object[] param)
- {
- return true;
- }
- protected override bool fStartExecute(object[] param)
- {
- _retryTimes = 0;
- try
- {
- EV.PostInfoLog("LoadPort", $"{LPModuleName} start to execute command {param[0]}");
- switch (param[0].ToString())
- {
- case "SetIndicator":
- Indicator light = (Indicator)param[1];
- IndicatorState state = (IndicatorState)param[2];
- string[] statestr = new string[] { "", "LON", "LBL", "LOF" };
- int lightNo = (int)light;
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8SetHandler(this, statestr[(int)state]+ $"{lightNo:D2}",null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "LEDST", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- IsBusy = false;
- }
- break;
-
- case "QueryIndicator":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8GetHandler(this, "LEDST", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- break;
- case "QueryState":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- break;
- case "Undock":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "YWAIT", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- break;
- case "Dock":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "YDOOR", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- break;
- case "CloseDoor":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "DORFW", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- break;
- case "OpenDoor":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "DORBK", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
-
- }
- break;
- case "Unclamp":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "PODOP", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
-
- }
- break;
- case "Clamp":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "PODCL", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
-
- }
- break;
- case "DoorUp":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "ZDRUP", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
-
- }
- break;
- case "DoorDown":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "ZDRDW", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
-
- }
- break;
- case "OpenDoorNoMap":
- lock (_locker)
- {
- //_lstHandler.AddLast(new TDKMoveHandler(this, "YDOOR", null));
- }
- break;
- case "OpenDoorAndMap":
- lock (_locker)
- {
- //_lstHandler.AddLast(new TDKMoveHandler(this, "YDOOR", null));
- }
- break;
- case "MapWafer":
- lock (_locker)
- {
- if (!IsMapWaferByLoadPort)
- {
- if (MapRobot != null)
- return MapRobot.WaferMapping(LPModuleName, out _);
- return false;
- }
- if (DockPosition != TDKDockPosition.Dock)
- _lstHandler.AddLast(new SELP8MoveHandler(this, "YDOOR", null));
- if (DoorState != FoupDoorState.Open)
- _lstHandler.AddLast(new SELP8MoveHandler(this, "DORBK", null));
- _lstHandler.AddLast(new SELP8MoveHandler(this, "MAPDO", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MAPRD", null));
- }
- break;
- case "DoorUpAndClose":
- lock (_locker)
- {
- WaferPositionData.Clear();
- _lstHandler.AddLast(new SELP8MoveHandler(this, "CUMDK", null));
- //_lstHandler.AddLast(new SELP8MoveHandler(this, "ZDRUP", null));
- //_lstHandler.AddLast(new SELP8MoveHandler(this, "DORFW", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
-
- break;
- case "OpenDoorAndDown":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "DORBK", null));
- _lstHandler.AddLast(new SELP8MoveHandler(this, "ZDRDW", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- break;
- case "Move":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, param[1].ToString(), null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- break;
- case "Set":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8SetHandler(this, param[1].ToString(), null));
- }
- break;
- case "Get":
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8GetHandler(this, param[1].ToString(), null));
- }
- break;
- }
- _timerActionMonitor.Restart();
- return true;
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- EV.PostAlarmLog(Name, $"Parameter invalid");
- return false;
- }
- }
- protected override bool fStartUnload(object[] param)
- {
- WaferPositionData.Clear();
- _retryTimes = 0;
- if (!_isPlaced)
- {
- EV.PostAlarmLog(Name, $"No carrier on {Name},can't unload.");
- return false;
- }
- if (!_isDocked)
- {
- EV.PostAlarmLog(Name, $"Carrier is not docked on {Name},can't unload.");
- return false;
- }
- lock (_locker)
- {
- if (DoorPosition == FoupDoorPostionEnum.Up && DoorState == FoupDoorState.Close)
- {
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "CUDNC", null));
- }
- }
- else
- {
- if(IsNeedMapOnUnload)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "CUDMP", null));
- }
- else
- _lstHandler.AddLast(new SELP8MoveHandler(this, "CULOD", null));
- }
- if (IsKeepClampAfterUnload)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "PODCL", null));
- }
- if (IsNeedMapOnUnload)
- {
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+01"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+02"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+03"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+04"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+05"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+06"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+07"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+08"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+09"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+10"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+11"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+12"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+13"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+14"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+15"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+16"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+17"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+18"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+19"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+20"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+21"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+22"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+23"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+24"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+25"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MAPRD", null));
- }
- }
- _timerActionMonitor.Restart();
- return true;
- }
- protected override bool fStartLoad(object[] param)
- {
- WaferPositionData.Clear();
- _retryTimes = 0;
- if (!_isPlaced)
- {
- EV.PostAlarmLog(Name, $"No carrier on {Name},can't load.");
- return false;
- }
- if (_isDocked)
- {
- EV.PostAlarmLog(Name, $"Carrier is docked on {Name},can't load.");
- return false;
- }
- if (IsRequestFOSBMode)
- {
- lock (_locker)
- {
- if (ClampPosition == TDKPosition.Open)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "PODCL", null));
- }
- _lstHandler.AddLast(new SELP8MoveHandler(this, "DORBK", null));
- _lstHandler.AddLast(new SELP8MoveHandler(this, "YDOOR", null));
- _lstHandler.AddLast(new SELP8MoveHandler(this, "ZDRDW", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
- }
- else
- {
-
- lock (_locker)
- {
- if (IsMapWaferByLoadPort)
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "CLDMP", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+01"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+02"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+03"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+04"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+05"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+06"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+07"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+08"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+09"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+10"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+11"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+12"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+13"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+14"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+15"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+16"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+17"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+18"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+19"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+20"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+21"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+22"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+23"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+24"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MPENC", "/+25"));
- _lstHandler.AddLast(new SELP8GetHandler(this, "MAPRD", null));
- }
- else
- {
- _lstHandler.AddLast(new SELP8MoveHandler(this, "CLOAD", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- }
-
- }
- }
- _timerActionMonitor.Restart();
- return true;
- }
- protected override bool fMonitorLoad(object[] param)
- {
- IsBusy = false;
- if (_timerActionMonitor.IsRunning && _timerActionMonitor.Elapsed > TimeSpan.FromSeconds(TimelimitAction))
- {
- _timerActionMonitor.Stop();
- OnError("LoadTimeout");
- }
- if (!IsHandlerBusy)
- {
- OnLoaded();
- _timerActionMonitor.Stop();
- return true;
- }
- return false;
- }
- protected override bool fStartInit(object[] param)
- {
- _retryTimes = 0;
- lock (_locker)
- {
-
- _lstHandler.AddLast(new SELP8ModHandler(this, "ONMGV", null));
- if (param.Length >= 1 && param[0].ToString() == "ForceHome")
- _lstHandler.AddLast(new SELP8MoveHandler(this, "ABORG", null));
- else
- _lstHandler.AddLast(new SELP8MoveHandler(this, "ORGSH", null));
- _lstHandler.AddLast(new SELP8EvtHandler(this, "EVTON", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- //_lstHandler.AddLast(new SELP8GetHandler(this, "FSBxx", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "LEDST", null));
-
- }
- _timerActionMonitor.Restart();
- return true;
- }
- protected override bool fMonitorInit(object[] param)
- {
-
- IsBusy = false;
- if (_timerActionMonitor.IsRunning && _timerActionMonitor.Elapsed > TimeSpan.FromSeconds(TimelimitHome))
- {
- _timerActionMonitor.Stop();
- OnError("HomeTimeout");
- }
- if (!IsHandlerBusy)
- {
- OnHomed();
- return true;
- }
- return false;
- }
- protected override bool fMonitorHome(object[] param)
- {
- IsBusy = false;
- if (_timerActionMonitor.IsRunning && _timerActionMonitor.Elapsed > TimeSpan.FromSeconds(TimelimitHome))
- {
- _timerActionMonitor.Stop();
- OnError("HomeTimeout");
- }
- if (!IsHandlerBusy)
- {
- OnHomed();
- return true;
- }
- return false;
- }
- protected override bool fMonitorUnload(object[] param)
- {
- IsBusy = false;
- if (_timerActionMonitor.IsRunning && _timerActionMonitor.Elapsed > TimeSpan.FromSeconds(TimelimitAction))
- {
- _timerActionMonitor.Stop();
- OnError("UnloadTimeout");
- }
- if (!IsHandlerBusy)
- {
- OnUnloaded();
- return true;
- }
- return false;
- }
- protected override bool fMonitorReset(object[] param)
- {
- IsBusy = false;
- if (!IsHandlerBusy)
- {
-
- return true;
- }
- return false;
- }
- protected override bool fMonitorExecuting(object[] param)
- {
- IsBusy = false;
- if (_timerActionMonitor.IsRunning && _timerActionMonitor.Elapsed > TimeSpan.FromSeconds(TimelimitAction))
- {
- _timerActionMonitor.Stop();
- OnError($"Execute{CurrentParamter[0]}Timeout");
- }
- if (!IsHandlerBusy)
- {
- EV.PostInfoLog("LoadPort", $"{LPModuleName} success to execute command {CurrentParamter[0]}");
- return true;
- }
- return false;
- }
- public override bool SetIndicator(Indicator light, IndicatorState state, out string reason)
- {
- reason = "";
- return fStartExecute(new object[] { "SetIndicator", light, state });
- }
- protected override bool fStartReset(object[] param)
- {
- _retryTimes = 0;
- _lstHandler.Clear();
- if (_isTcpConnection)
- {
- if (!_tcpConnection.IsConnected)
- _tcpConnection.Connect();
- _tcpConnection.ForceClear();
- }
- else
- {
- if (!_connection.IsConnected)
- _connection.Connect();
- _connection.ForceClear();
- }
- lock (_locker)
- {
- _lstHandler.AddLast(new SELP8ModHandler(this, "ONMGV", null));
- _lstHandler.AddLast(new SELP8SetHandler(this, "RESET", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- //_lstHandler.AddLast(new SELP8GetHandler(this, "FSBxx", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "LEDST", null));
- }
- return true;
- }
- public override void OnError(string error = "")
- {
- lock (_locker)
- {
- _lstHandler.Clear();
- if (_isTcpConnection)
- _tcpConnection.ForceClear();
- else
- _connection.ForceClear();
- _lstHandler.AddLast(new SELP8GetHandler(this, "STATE", null));
- //_lstHandler.AddLast(new SELP8GetHandler(this, "FSBxx", null));
- _lstHandler.AddLast(new SELP8GetHandler(this, "LEDST", null));
- }
- base.OnError(error);
- }
- public void OnAbs(string absMsg)
- {
- try
- {
- string absContext = absMsg.Split('/')[1].Replace(";", "").Replace("\r","");
- EV.Notify($"{Name}{absContext}");
- }
- catch(Exception ex)
- {
- LOG.Write(ex);
- }
- OnError("Recieve ABS Message:" + absMsg);
- }
- public void OnNak(string absMsg)
- {
- try
- {
- string absContext = absMsg.Split('/')[1].Replace(";", "").Replace("\r", "");
- EV.Notify($"{Name}{absContext}");
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- }
- OnError("Recieve Nak Message:" + absMsg);
- }
- public override void Terminate()
- {
- _thread.Stop();
- Thread.Sleep(100);
- if (!SC.ContainsItem($"{_scRoot}.{Name}.CloseConnectionOnShutDown") || SC.GetValue<bool>($"{_scRoot}.{Name}.CloseConnectionOnShutDown"))
- {
- LOG.Write($"Close {Address} for connection of {LPModuleName}");
- _connection.Disconnect();
- _connection.TerminateCom();
- }
- base.Terminate();
- }
- public override bool IsForbidAccessSlotAboveWafer()
- {
- if (SC.ContainsItem($"CarrierInfo.ForbidAccessAboveWaferCarrier{InfoPadCarrierIndex}"))
- return SC.GetValue<bool>($"CarrierInfo.ForbidAccessAboveWaferCarrier{InfoPadCarrierIndex}");
- return false;
- }
- public override void OnSlotMapRead(string _slotMap)
- {
- CurrentSlotMapResult = _slotMap;
-
- if (CurrentSlotMapResult.Length != ValidSlotsNumber)
- {
- EV.PostAlarmLog("LoadPort", $"{LPModuleName} Mapping Data Error," +
- $"slotmap length is {CurrentSlotMapResult.Length} not match the valid slots number:{ValidSlotsNumber}.");
- }
- if (CurrentState == LoadPortStateEnum.Unloading)
- {
- if (CurrentSlotMapResult.Contains("2"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == '2')
- {
- if (slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} unload map crossed wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMapCrossedWafer, dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:crossed wafer when unload carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMappingError, dvid1);
- }
- if (CurrentSlotMapResult.Contains("3"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == '3')
- {
- if (slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} unload map double wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMapDoubleWafer, dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:double wafer when unload carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMappingError, dvid1);
- }
- if (CurrentSlotMapResult.Contains("W"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == 'W')
- {
- if (slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} unload map double wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMapDoubleWafer, dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:double wafer when unload carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMappingError, dvid1);
- }
- if (CurrentSlotMapResult.Contains("?"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == '?')
- {
- if (slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} unload map unknow wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMapUnknownWafer, dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:unknow wafer when unload carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortUnloadMappingError, dvid1);
- }
- return;
- }
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (!_isPlaced)
- break;
- // No wafer: "0", Wafer: "1", Crossed:"2", Undefined: "?", Overlapping wafers: "W"
- WaferInfo wafer = null;
- switch (CurrentSlotMapResult[i])
- {
- case '0':
- WaferManager.Instance.DeleteWafer(LPModuleName, i);
- CarrierManager.Instance.UnregisterCarrierWafer(Name, i);
- break;
- case '1':
- if (WaferManager.Instance.CheckNoWafer(LPModuleName, i))
- {
- wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Normal);
- }
- else
- WaferManager.Instance.GetWafer(LPModuleName, i).Status = WaferStatus.Normal;
- WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
- CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
- break;
- case '2':
- if (WaferManager.Instance.CheckNoWafer(LPModuleName, i))
- {
- wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Crossed);
- }
- else
- WaferManager.Instance.GetWafer(LPModuleName, i).Status = WaferStatus.Crossed;
- WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
- CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
- //EV.Notify(AlarmLoadPortMapCrossedWafer);
- EV.PostInfoLog("LoadPort", $"{LPModuleName} map crossed wafer on carrier:{_carrierId},slot:{i + 1}.");
- break;
- case 'W':
- if (WaferManager.Instance.CheckNoWafer(LPModuleName, i))
- {
- wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Double);
- }
- else
- WaferManager.Instance.GetWafer(LPModuleName, i).Status = WaferStatus.Double;
- WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
- CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
- //EV.Notify(AlarmLoadPortMapDoubleWafer);
- EV.PostInfoLog("LoadPort", $"{LPModuleName} map double wafer on carrier:{_carrierId},slot:{i + 1}.");
- break;
- case '?':
- if (WaferManager.Instance.CheckNoWafer(LPModuleName, i))
- {
- wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Unknown);
- }
- else
- WaferManager.Instance.GetWafer(LPModuleName, i).Status = WaferStatus.Unknown;
- WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
- CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
- EV.PostInfoLog("LoadPort", $"{LPModuleName} map unknown wafer on carrier:{_carrierId},slot:{i + 1}.");
- break;
- default:
- CurrentSlotMapResult = CurrentSlotMapResult.Substring(0, i) + "?" + CurrentSlotMapResult.Substring(i + 1);
- if (WaferManager.Instance.CheckNoWafer(LPModuleName, i))
- {
- wafer = WaferManager.Instance.CreateWafer(LPModuleName, i, WaferStatus.Unknown);
- }
- else
- WaferManager.Instance.GetWafer(LPModuleName, i).Status = WaferStatus.Unknown;
- WaferManager.Instance.UpdateWaferSize(LPModuleName, i, GetCurrentWaferSize());
- CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);
- EV.PostInfoLog("LoadPort", $"{LPModuleName} map unknown wafer on carrier:{_carrierId},slot:{i + 1}.");
- break;
- }
- }
-
- SerializableDictionary<string, object> dvidmp = new SerializableDictionary<string, object>();
- dvidmp["SlotMap"] = CurrentSlotMapResult;
- dvidmp["PortID"] = PortID;
- dvidmp["PORT_CTGRY"] = SpecPortName;
- dvidmp["CarrierType"] = SpecCarrierType;
- dvidmp["CarrierIndex"] = InfoPadCarrierIndex;
- dvidmp["InfoPadSensorIndex"] = InfoPadSensorIndex;
- dvidmp["CarrierID"] = CarrierId;
- EV.Notify(EventSlotMapAvailable, dvidmp);
- EV.Notify(EventMapComplete, dvidmp);
-
-
-
- if (CurrentSlotMapResult.Contains("2"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == '2')
- {
- if (slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} load map crossed wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMapCrossedWafer, dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:crossed wafer when load carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMappingError, dvid1);
- }
- if (CurrentSlotMapResult.Contains("3"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == '3')
- {
- if (slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} load map double wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMapDoubleWafer,dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:double wafer when load carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMappingError, dvid1);
- }
- if (CurrentSlotMapResult.Contains("W"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == 'W')
- {
- if (slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
-
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} load map double wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMapDoubleWafer,dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:double wafer when load carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMappingError,dvid1);
- }
- if (CurrentSlotMapResult.Contains("?"))
- {
- MapError = true;
- string slotSpec = "";
- for (int i = 0; i < CurrentSlotMapResult.Length; i++)
- {
- if (CurrentSlotMapResult[i] == '?')
- {
- if(slotSpec == "")
- slotSpec += $"{i + 1}";
- else
- slotSpec += $",{i + 1}";
- }
-
- }
- SerializableDictionary<string, object> dvid = new SerializableDictionary<string, object>();
- dvid["AlarmDescription"] = $"{LPModuleName} load unknow wafer on slot:{slotSpec} of carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMapUnknownWafer,dvid);
- SerializableDictionary<string, object> dvid1 = new SerializableDictionary<string, object>();
- dvid1["AlarmDescription"] = $"{LPModuleName} map error:unknow wafer when load carrier:{_carrierId}";
- EV.Notify(AlarmLoadPortMappingError,dvid1);
- }
- if (LPCallBack != null && IsPlacement)
- LPCallBack.MappingComplete(_carrierId, CurrentSlotMapResult);
-
- _isMapped = true;
- WaferMapThickness = new double[_slotMap.Length];
- int wIndex = 0;
- string thicknessMsg = "";
- for (int i = 0; i < _slotMap.Length; i++)
- {
- if (_slotMap[i] != '0')
- {
- WaferMapThickness[i] = Math.Abs(WaferPositionData.ToArray()[wIndex].Item2 - WaferPositionData.ToArray()[wIndex].Item1);
-
- if (WaferMapThickness[i] > WaferThicknessTolerance.Item2)
- {
- EV.PostAlarmLog("LoadPort", $"{LPModuleName} Wafer on slot {i + 1} " +
- $"thickness is {WaferMapThickness[i]} um more than highlimit {WaferThicknessTolerance.Item2}.");
- OnError("Mapping Data Error");
- }
- if (WaferMapThickness[i] < WaferThicknessTolerance.Item1)
- {
- EV.PostAlarmLog("LoadPort", $"{LPModuleName} Wafer on slot {i + 1} " +
- $"thickness is {WaferMapThickness[i]} um less than lowlimit {WaferThicknessTolerance.Item1}.");
- OnError("Mapping Data Error");
- }
- int slotBasePos = SlotPositionBaseLine + (SlotPitch * i);
- int wafercenterpos = (WaferPositionData.ToArray()[wIndex].Item2 + WaferPositionData.ToArray()[wIndex].Item1) / 2;
- EV.PostInfoLog("LoadPort",$"{LPModuleName} Wafer on slot{i + 1} wafer horizontal center is {wafercenterpos}um,thickness is {WaferMapThickness[i]}um.");
- wIndex++;
- }
- else
- WaferMapThickness[i] = 0;
- thicknessMsg += $"Slot:{i + 1},Thickness:{WaferMapThickness[i] *0.001} mm;";
- }
- LOG.Write($"{Name} map carrier:{CarrierId},slotmap:{_slotMap},thickness data:{thicknessMsg}.");
- base.OnSlotMapRead(_slotMap);
- }
-
- }
-
- }
|