| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686 | using System;using System.Collections.Generic;using System.IO.Ports;using System.Linq;using Aitex.Core.Common.DeviceData;using Aitex.Core.RT.DataCenter;using Aitex.Core.RT.Device;using Aitex.Core.RT.Device.Unit;using Aitex.Core.RT.Event;using Aitex.Core.RT.Log;using Aitex.Core.RT.OperationCenter;using Aitex.Core.RT.SCCore;using Aitex.Core.Util;using MECF.Framework.Common.Communications;using MECF.Framework.Common.Device.Bases;using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.Common;using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.TDK;using Newtonsoft.Json;namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.VCE.SiasunVCE{    public class SiasunVCE : VCEBase, IConnection    {        #region Fields        private SiasunVCEConnection _connection;        private bool _isIdle;        private R_TRIG _trigError = new R_TRIG();        private R_TRIG _trigCommunicationError = new R_TRIG();        private R_TRIG _trigRetryConnect = new R_TRIG();        private PeriodicJob _thread;        private LinkedList<HandlerBase> _lstHandler = new LinkedList<HandlerBase>();        private LinkedList<HandlerBase> _lstMonitorHandler = new LinkedList<HandlerBase>();        public Dictionary<string, string> ErrorCodeReference;        private object _locker = new object();        private SCConfigItem _scHomeTimeout;        private SCConfigItem _scMappingTimeout;        private SCConfigItem _scMotionTimeout;        private bool _enableLog;        private string _scRoot;        private string _portName;        private DeviceTimer _QueryTimer = new DeviceTimer();        private readonly int _QueryInterval = 2000;        private RD_TRIG _trigDoorOpen = new RD_TRIG();        #endregion Fields        #region Properties        public string Address => _connection.Address;        public override bool IsConnected => _connection.IsConnected && !_connection.IsCommunicationError;        public string PortStatus { get; set; } = "Closed";        public override bool IsIdle        {            get => _isIdle && _lstHandler.Count == 0 && !IsAlarm && !_connection.IsCommunicationError;            set => _isIdle = value;        }        public List<IOResponse> IOResponseList { get; set; } = new List<IOResponse>();        public string Error { get; private set; }        public string ArmRPosition { get; private set; }        public string CommunicationMode { get; private set; }        public string ZAxisPosition { get; private set; }        public bool LoadCompleted { get; private set; }        public bool LoadPosition { get; private set; }        public bool RetractPosition { get; private set; }        public bool Picked { get; private set; }        public bool Placed { get; private set; }        public bool ExtendPosition { get; private set; }        public bool Unloaded { get; private set; }        public string MovedPosition { get; private set; }        public string ArmZPosition { get; private set; }        public string CurrentCommunicationMode { get; private set; }        public string CurrentErrorStatus { get; private set; }        #endregion Properties        public SiasunVCE(string module, string name, string scRoot) : base(module, name)        {            _scRoot = scRoot;        }        public bool Connect()        {            return _connection.Connect();        }        public bool Disconnect()        {            return _connection.Disconnect();        }        private void ResetPropertiesAndResponses()        {            foreach (var ioResponse in IOResponseList)            {                ioResponse.ResonseContent = null;                ioResponse.ResonseRecievedTime = DateTime.Now;            }        }        //private string _address = "00";        public override bool Initialize()        {            base.Initialize();            ResetPropertiesAndResponses();            if (_connection != null && _connection.IsConnected)                return true;            if (string.IsNullOrEmpty(_scRoot))            {                _portName = SC.GetStringValue($"{Module}.Address");                _enableLog = SC.GetValue<bool>($"{Module}.EnableLogMessage");                _scHomeTimeout = SC.GetConfigItem($"{Module}.HomeTimeout");                _scMappingTimeout = SC.GetConfigItem($"{Module}.MappingTimeout");                _scMotionTimeout = SC.GetConfigItem($"{Module}.MotionTimeout");            }            else            {                _portName = SC.GetStringValue($"{_scRoot}.Address");                _enableLog = SC.GetValue<bool>($"{_scRoot}.EnableLogMessage");                _scHomeTimeout = SC.GetConfigItem($"{_scRoot}.HomeTimeout");                _scMappingTimeout = SC.GetConfigItem($"{_scRoot}.MappingTimeout");                _scMotionTimeout = SC.GetConfigItem($"{_scRoot}.MotionTimeout");            }            _connection = new SiasunVCEConnection(_portName);            _connection.EnableLog(_enableLog);            if (_connection.Connect())            {                PortStatus = "Open";                EV.PostInfoLog(Module, $"{Module}.{Name} connected");            }            _thread = new PeriodicJob(100, OnTimer, $"{Module}.{Name} MonitorHandler", true);            //_lstMonitorHandler.AddLast(new SiasunVCERequestWaferSlideOutHandler(this));   // R,SO            //_lstMonitorHandler.AddLast(new SiasunVCERequestCassettePresentHandler(this)); // R,W2            //_lstMonitorHandler.AddLast(new SiasunVCERequestDoorStatusHandler(this));      // R,STAT,DOOR            //_lstMonitorHandler.AddLast(new SiasunVCERequestArmPositionHandler(this));     // R,STAT,ATM            _QueryTimer.Start(_QueryInterval);            DATA.Subscribe($"{Module}.IsConnected", () => IsConnected);            DATA.Subscribe($"{Module}.IsMapped", () => IsMapped);            DATA.Subscribe($"{Module}.Address", () => Address);            DATA.Subscribe($"{Module}.IsDoorOpened", () => IsDoorOpened);            DATA.Subscribe($"{Module}.IsDoorClosed", () => IsDoorClosed);            OP.Subscribe($"{Module}.Reconnect", (string cmd, object[] args) => {                Disconnect();                Connect();                return true;            });            ErrorCodeReference = new Dictionary<string, string>()            {                { "40","E2PROM initialize hardware fail"},                { "E2","E2PROM initialize hardware fail"},                { "41","VCE is busy"},                { "C10","VCE is busy"},                { "42","Illegal command type"},                { "A37","Illegal command type"},                { "43","Illegal request command"},                { "A38","Illegal request command"},                { "44","Illegal set parameter command"},                { "A39","Illegal set parameter command"},                { "45","Illegal save parameter command"},                { "A40","Illegal save parameter command"},                { "46","Illegal action command"},                { "A41","Illegal action command"},                { "47","Command string error"},                { "A42","Command string error"},                { "48","Bad command parameter"},                { "50","Z axis move position is exceeded"},                { "Z02","Z axis move position is exceeded"},                { "51","Z axis current position is exceeded"},                { "Z03","Z axis current position is exceeded"},                { "52","Z axis limit"},                { "Z04","Z axis limit"},                { "54","Z axis is not homed"},                { "Z06","Z axis is not homed"},                { "55","Door is opened"},                { "Z07","Door is opened"},                { "56","Cassette is not present"},                { "Z08","Cassette is not present"},                { "63","Door motion is obstructed"},                { "D01","Door motion is obstructed"},                { "64","Door motion timeout"},                { "D02","Door motion timeout"},                { "66","Emergency stop"},                { "M10","Emergency stop"},                { "67","Motor motion error"},                { "M26","Motor motion error"},                { "68","Motion is collided"},                { "M27","Motion is collided"},                { "69","Mapping failed, for the result is non-integral multiple"},                { "M28","Mapping failed, for the result is non-integral multiple"},                { "71","Z axis motion timeout"},                { "T02","Z axis motion timeout"},                { "72","CAN open failed for illegal frame"},                { "CTX","CAN open failed for illegal frame"},                { "73","CAN open failed for Emcy error"},                { "CEM","CAN open failed for Emcy error"},                { "74","CAN open failed for sdo error"},                { "CSD","CAN open failed for sdo error"},                { "WOT","Wafer slide out"},                { "75","Wafer slide out"},            };            if(SC.ContainsItem($"{Module}.StatusPersistence"))            {                var sPersistentStatus = SC.GetStringValue($"{Module}.StatusPersistence");                if (sPersistentStatus.ToString().ToUpper() == "LOADED")                {                    IsMapped = true;                }            }            return true;        }        private bool OnTimer()        {            try            {                //return true;                _connection.MonitorTimeout();                if (!_connection.IsConnected || _connection.IsCommunicationError)                {                    lock (_locker)                    {                        _lstHandler.Clear();                    }                    _trigRetryConnect.CLK = !_connection.IsConnected;                    if (_trigRetryConnect.Q)                    {                        _connection.SetPortAddress(_portName);                        if (!_connection.Connect())                        {                            EV.PostAlarmLog(Module, $"Can not connect with {_connection.Address}, {Module}.{Name}");                        }                    }                    return true;                }                HandlerBase handler = null;                if (!_connection.IsBusy)                {                    lock (_locker)                    {                        if (_lstHandler.Count == 0 && _QueryTimer.IsTimeout())                        {                            foreach (var monitorHandler in _lstMonitorHandler)                            {                                _lstHandler.AddLast(monitorHandler);                            }                            _QueryTimer.Start(_QueryInterval);                        }                        if (_lstHandler.Count > 0)                        {                            handler = _lstHandler.First.Value;                            _lstHandler.RemoveFirst();                        }                    }                    if (handler != null)                    {                        _connection.Execute(handler);                    }                }            }            catch (Exception ex)            {                LOG.Write(ex);            }            return true;        }        internal void NoteZAxisPosition(string pos)        {            ZAxisPosition = pos;        }        internal void NoteHomed(bool homed)        {            IsHomed = homed;        }        internal void NoteMoveResult(string position)        {            MovedPosition = position;        }        public override void Monitor()        {            try            {                //_connection.EnableLog(_enableLog);                _trigDoorOpen.CLK = this.IsDoorOpened;                if (_trigDoorOpen.R)                {                    _lstMonitorHandler.AddLast(new SiasunVCERequestCassettePresentHandler(this));                }                if (_trigDoorOpen.T)                {                    _lstMonitorHandler.RemoveLast();                }                _trigCommunicationError.CLK = _connection.IsCommunicationError;                if (_trigCommunicationError.Q)                {                    EV.PostAlarmLog(Module, $"{Module}.{Name} communication error, {_connection.LastCommunicationError}");                }            }            catch (Exception ex)            {                LOG.Write(ex);            }        }        public override void Reset()        {            _trigError.RST = true;            _connection.SetCommunicationError(false, "");            _trigCommunicationError.RST = true;            //_enableLog = SC.GetValue<bool>($"{ScBasePath}.{Name}.EnableLogMessage");            _trigRetryConnect.RST = true;            if (IsAlarm)            {                lock (_locker)                {                    _lstHandler.AddLast(new SiasunVCEResetErrorHandler(this));                }            }            IsAlarm = false;            base.Reset();        }        public override void Terminate()        {            SC.SetItemValue($"{Module}.StatusPersistence", $"{(IsMapped ? "Loaded" : "Unloaded")}");        }        #region Command Functions        public void PerformRawCommand(string commandType)        {            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCERawCommandHandler(this, commandType, ""));            }        }        public void PerformRawCommand(string commandType, string command)        {            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCERawCommandHandler(this, commandType, command));            }        }        internal void NoteCurrentCommunicationMode(string data)        {            CurrentCommunicationMode = data;        }        public void PerformRawCommand(string commandType, string command, string comandArgument)        {            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCERawCommandHandler(this, commandType, command, comandArgument));            }        }        public void MonitorRawCommand(bool isSelected, string commandType, string command, string comandArgument)        {            lock (_locker)            {                string msg = comandArgument == null ? $"{command}\r" : $"{command} {comandArgument}\r";//??                var existHandlers = _lstMonitorHandler                    .Where(handler => handler.GetType() == typeof(SiasunVCERawCommandHandler) && ((SiasunVCERawCommandHandler)handler)                    .IsSendText(commandType, command, comandArgument));                if (isSelected)                {                    if (!existHandlers.Any())                        _lstMonitorHandler.AddFirst(new SiasunVCERawCommandHandler(this, commandType, command, comandArgument));                }                else                {                    if (existHandlers.Any())                    {                        _lstMonitorHandler.Remove(existHandlers.First());                    }                }            }        }        internal void NoteCurrentErrorStatus(string data)        {            CurrentErrorStatus = data;        }        internal void NoteCurrentMappingInfo(string data)        {            SlotMap = data;        }        public void RequestErrorStatus(bool isSelected)        {            lock (_locker)            {                var existHandlers = _lstMonitorHandler.Where(handler => handler.GetType() == typeof(SiasunVCERequestErrorInfoHandler));                if (isSelected)                {                    if (!existHandlers.Any())                        _lstMonitorHandler.AddFirst(new SiasunVCERequestErrorInfoHandler(this));                }                else                {                    if (existHandlers.Any())                    {                        _lstMonitorHandler.Remove(existHandlers.First());                    }                }            }        }        public void RequestMappingInfo(bool isSelected)        {            lock (_locker)            {                var existHandlers = _lstMonitorHandler.Where(handler => handler.GetType() == typeof(SiasunVCERequestMappingInfoHandler));                if (isSelected)                {                    if (!existHandlers.Any())                        _lstMonitorHandler.AddFirst(new SiasunVCERequestMappingInfoHandler(this));                }                else                {                    if (existHandlers.Any())                    {                        _lstMonitorHandler.Remove(existHandlers.First());                    }                }            }        }        public override bool QuerySlotMap(out string reason)        {            reason = string.Empty;            SlotMap = "";            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCERequestMappingInfoHandler(this));            }            return true;        }        public override bool CheckCassettePresent(bool isCheckPresent, out string reason)        {            reason = string.Empty;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCERequestCassettePresentHandler(this));            }            IsIdle = false;            return true;        }        public override void Abort()        {            lock (_locker)            {                _lstHandler.Clear();            }        }        public override bool MoveToSlot(int slot, out string reason)        {            reason = string.Empty;            IsIdle = false;            ZAxisAtSlot = -1;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCEZAxisGotoSlotHandler(this, slot, _scMotionTimeout.IntValue));                _lstHandler.AddLast(new SiasunVCERequestArmPositionHandler(this));            }            return true;        }        public override bool MoveToLoadPositon(out string reason)        {            reason = string.Empty;            IsZAxisAtLoadPostion = false;            IsIdle = false;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCEZAxisMoveToLoadPositionHandler(this, _scMotionTimeout.IntValue));                _lstHandler.AddLast(new SiasunVCERequestArmPositionHandler(this));            }            return true;        }        public override bool PlatformIn(out string reason)        {            reason = string.Empty;            IsIdle = false;            IsPlatformIn = false;            IsPlatformOut = false;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCEPlatformInHandler(this, _scMotionTimeout.IntValue));            }            return true;        }        public override bool PlatformOut(out string reason)        {            reason = string.Empty;            IsIdle = false;            IsPlatformIn = false;            IsPlatformOut = false;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCEPlatformOutHandler(this, _scMotionTimeout.IntValue));            }            return true;        }        public override bool CheckOutsideDoorStatus()        {            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCERequestDoorStatusHandler(this));            }            IsIdle = false;            return true;        }        public override bool CloseDoor(out string reason)        {            reason = string.Empty;            IsIdle = false;            IsDoorOpened = false;            IsDoorClosed = false;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCECloseDoorHandler(this, _scMotionTimeout.IntValue));                //_lstHandler.AddLast(new SiasunVCERequestDoorStatusHandler(this));            }            return true;        }        public override bool OpenDoor(out string reason)        {            reason = string.Empty;            IsIdle = false;            IsDoorOpened = false;            IsDoorClosed = false;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCEOpenDoorHandler(this, _scMotionTimeout.IntValue));                //_lstHandler.AddLast(new SiasunVCERequestDoorStatusHandler(this));            }            return true;        }        public override bool MapCassette(out string reason)        {            reason = string.Empty;            IsMapped = false;            IsIdle = false;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCESetMappingTeachFlagHandler(this, false));                _lstHandler.AddLast(new SiasunVCEMappingHandler(this, _scMappingTimeout.IntValue));            }            return true;        }        public void Move(string axis, string type, string value)        {            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCEMoveHandler(this, axis, type, value));            }        }        public override bool Home(out string reason)        {            IsHomed = false;            IsIdle = false;            reason = string.Empty;            lock (_locker)            {                _lstHandler.AddLast(new SiasunVCEResetErrorHandler(this));                          // S,ER                _lstHandler.AddLast(new SiasunVCEDoorInterlockHandler(this, false));                // S,ZD,N                _lstHandler.AddLast(new SiasunVCEHomeRAxisHandler(this, _scHomeTimeout.IntValue));  // A,HM,R                _lstHandler.AddLast(new SiasunVCECloseDoorHandler(this, _scMotionTimeout.IntValue));// A,DC                _lstHandler.AddLast(new SiasunVCECassetteInterlockHandler(this, false));            // S,CE,N                _lstHandler.AddLast(new SiasunVCEHomeZAxisHandler(this, _scHomeTimeout.IntValue));  // A,HM,Z                _lstHandler.AddLast(new SiasunVCEZAxisMoveToLoadPositionHandler(this, _scMotionTimeout.IntValue));  // A,LP                _lstHandler.AddLast(new SiasunVCERequestArmPositionHandler(this));                  // R,STAT,ARM                //_lstHandler.AddLast(new SiasunVCECassetteInterlockHandler(this, true));             // S,CE,Y            }            return true;        }        #endregion Command Functions        #region Note Functions        private R_TRIG _trigWarningMessage = new R_TRIG();        public void NoteError(string reason)        {            if (reason != null)            {                IsAlarm = true;                var content = reason;                if (ErrorCodeReference.ContainsKey(reason))                    content = ErrorCodeReference[reason];                _trigWarningMessage.CLK = true;                if (_trigWarningMessage.Q)                {                    EV.PostWarningLog(Module, $"{Module}.{Name} error, {reason} {content}");                }                Error = reason;            }            else            {                Error = null;            }        }        internal void NoteRawCommandInfo(string commandType, string command, string data)        {            //var curIOResponse = IOResponseList.Find(res => res.SourceCommandName == command);            //if (curIOResponse != null)            //{            //    IOResponseList.Remove(curIOResponse);            //}            //IOResponseList.Add(new IOResponse() { SourceCommandType = commandType, SourceCommand = command, ResonseContent = data, ResonseRecievedTime = DateTime.Now });        }        internal void NoteArmRPositon(string armRPosition)        {            ArmRPosition = armRPosition;        }        internal void NoteArmZPositon(string armPosition)        {            ArmZPosition = armPosition;        }        #endregion Note Functions    }}
 |