123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400 |
- using Aitex.Core.RT.Device;
- using Aitex.Core.RT.Log;
- using Aitex.Core.RT.Routine;
- using Aitex.Core.RT.SCCore;
- using CyberX8_Core;
- using CyberX8_RT.Devices.AXIS;
- using CyberX8_RT.Devices.Facilities;
- using CyberX8_RT.Devices.SRD;
- using MECF.Framework.Common.Routine;
- namespace CyberX8_RT.Modules.SRD
- {
- public class SRDUnloaderRoutine : RoutineBase, IRoutine
- {
- private enum SRDUnloaderStep
- {
- ChuckVacuumOff,
- ChuckATMOn,
- CheckVacuum,
- LiftUpOn,
- CheckWaferPresent,
- OpenDoor,
- End
- }
- #region 常量
- private const int RETRY_TIMES = 3;
- #endregion
- #region 内部变量
- /// <summary>
- /// Rotation Axis
- /// </summary>
- private JetAxisBase _rotationAxis;
- /// <summary>
- /// SRD Common
- /// </summary>
- private SrdCommonDevice _srdCommon;
- /// <summary>
- /// Total SRD
- /// </summary>
- private TotalSRDDevice _totalSRDDevice;
- /// <summary>
- /// System Facility
- /// </summary>
- private SystemFacilities _systemFacilities;
- /// <summary>
- /// 当前WaferSize
- /// </summary>
- private int _waferSize = 200;
- /// <summary>
- /// 当前Retry次数
- /// </summary>
- private int _currentRetryTimes = 0;
- /// <summary>
- /// 真空值
- /// </summary>
- private int _vacuumOffLimit = 0;
- #endregion
- #region 属性
- #endregion
- /// <summary>
- /// 构造函数
- /// </summary>
- /// <param name="module"></param>
- public SRDUnloaderRoutine(string module) : base(module)
- {
- }
- /// <summary>
- /// 中止
- /// </summary>
- public void Abort()
- {
- Runner.Stop("SRD Loader Abort");
- }
- /// <summary>
- /// 监控
- /// </summary>
- /// <returns></returns>
- public RState Monitor()
- {
- Runner.Run(SRDUnloaderStep.ChuckVacuumOff, ChuckVacuumOff, CheckChuckVacuumOffEndStatus, CheckChuckVacuumOffStopStatus)
- .Run(SRDUnloaderStep.ChuckATMOn, ChuckATMOn, CheckChuckATMEndStatus, CheckChuckATMStopStatus)
- .WaitWithStopCondition(SRDUnloaderStep.CheckVacuum, CheckVacuumEndStatus, CheckVacuumStopStatus)
- .Run(SRDUnloaderStep.LiftUpOn, LiftUpOn, CheckLiftUpOnEndStatus, CheckLiftUpOnStopStatus)
- .Run(SRDUnloaderStep.CheckWaferPresent, CheckWaferPresent, _delay_1ms)
- .Run(SRDUnloaderStep.OpenDoor, OpenDoor, CheckDoorOpenedEndStatus, CheckDoorOpenedStopStatus)
- .End(SRDUnloaderStep.End, NullFun, _delay_1ms);
- return Runner.Status;
- }
- /// <summary>
- /// 启动
- /// </summary>
- /// <param name="objs"></param>
- /// <returns></returns>
- public RState Start(params object[] objs)
- {
- _srdCommon = DEVICE.GetDevice<SrdCommonDevice>($"{Module}.Common");
- _totalSRDDevice = DEVICE.GetDevice<TotalSRDDevice>("SRD");
- _rotationAxis = DEVICE.GetDevice<JetAxisBase>($"{Module}.Rotation");
- _systemFacilities = DEVICE.GetDevice<SystemFacilities>("System.Facilities");
- _vacuumOffLimit = SC.GetValue<int>("SRD.ChuckVacuumOffLimit");
- if (!CheckPreCondition())
- {
- return RState.Failed;
- }
- return Runner.Start(Module, "SRD Unloader Start");
- }
- /// <summary>
- /// Check Pre Condition
- /// </summary>
- /// <returns></returns>
- private bool CheckPreCondition()
- {
- //Check Rotation Home
- //if (!_rotationAxis.IsHomed)
- //{
- // NotifyError(eEvent.ERR_SRD, "Rotation is not homed", 0);
- // return false;
- //}
- //Check LiftUp
- if (_srdCommon.CommonData.LiftUp)
- {
- NotifyError(eEvent.ERR_SRD, "LiftUp is on", 0);
- return false;
- }
- //Check LiftUp Status
- if (_srdCommon.CommonData.LiftUpStatus)
- {
- NotifyError(eEvent.ERR_SRD, "LiftUp sensor is on", 0);
- return false;
- }
- //Check Wafer Present
- if (!_srdCommon.CommonData.WaferPresent)
- {
- NotifyError(eEvent.ERR_SRD, "WaferPresent sensor is off", 0);
- return false;
- }
- //Check LoaderDI
- if (!_systemFacilities.LoaderDiEnable)
- {
- NotifyError(eEvent.ERR_SRD, "Load DI Is Disable", 0);
- return false;
- }
- //Check Vacuum
- int vacuumOnLimit = SC.GetValue<int>("SRD.ChuckVacuumOnLimit");
- if (!_srdCommon.CommonData.ChuckVacuum)
- {
- if(_srdCommon.CommonData.VacuumValue >= vacuumOnLimit)
- {
- LOG.WriteLog(eEvent.ERR_SRD, Module, $"VacuumValue:{_srdCommon.CommonData.VacuumValue}, VacuumOn Limit:{vacuumOnLimit}");
- return false;
- }
- }
- else
- {
- LOG.WriteLog(eEvent.ERR_SRD, Module, $"Chuck Vacuum is off");
- return false;
- }
- //Check Flippers
- if (_srdCommon.CommonData.FlippersIn150 || _srdCommon.CommonData.FlippersIn200) //|| _srdCommon.CommonData.FlippersIn100
- {
- NotifyError(eEvent.ERR_SRD, "FlippersIn is on", 0);
- return false;
- }
- if (!_srdCommon.CommonData.Flipper1Out150Status || !_srdCommon.CommonData.Flipper2Out150Status || !_srdCommon.CommonData.Flipper3Out150Status
- || !_srdCommon.CommonData.Flipper1Out200Status || !_srdCommon.CommonData.Flipper2Out200Status || !_srdCommon.CommonData.Flipper3Out200Status)
- //|| !_srdCommon.CommonData.Flipper1Out100Status || !_srdCommon.CommonData.Flipper2Out100Status || !_srdCommon.CommonData.Flipper3Out100Status
- {
- NotifyError(eEvent.ERR_SRD, "Flippers are at In position", 0);
- return false;
- }
- return true;
- }
- /// <summary>
- /// ChuckATMOn
- /// </summary>
- /// <returns></returns>
- private bool ChuckATMOn()
- {
- bool result = _srdCommon.ChuckATMAction("", null);
- if (!result)
- {
- NotifyError(eEvent.ERR_SRD, "Chuck ATM Action is failed", 0);
- return result;
- }
- return true;
- }
- /// <summary>
- /// Chuck ATM On End
- /// </summary>
- /// <returns></returns>
- private bool CheckChuckATMEndStatus()
- {
- return _srdCommon.Status == RState.End && !_srdCommon.CommonData.ChuckATMOn;
- }
- /// <summary>
- /// Chuck ATM On Stop
- /// </summary>
- /// <returns></returns>
- private bool CheckChuckATMStopStatus()
- {
- if (_srdCommon.Status == RState.Failed || _srdCommon.Status == RState.Timeout)
- {
- NotifyError(eEvent.ERR_SRD, "Check ChuckATM is failed", 0);
- return true;
- }
- return false;
- }
- /// <summary>
- /// Check Vacuum End
- /// </summary>
- /// <returns></returns>
- private bool CheckVacuumEndStatus()
- {
- if(_srdCommon.Status == RState.End && CheckVacuumValue())
- {
- return true;
- }
- return false;
- }
- /// <summary>
- /// Check Vacuum Stop
- /// </summary>
- /// <returns></returns>
- private bool CheckVacuumStopStatus()
- {
- if (_srdCommon.Status == RState.Failed || _srdCommon.Status == RState.Timeout)
- {
- NotifyError(eEvent.ERR_SRD, "Check ChuckATM is failed", 0);
- return true;
- }
- else if (_srdCommon.Status == RState.End)
- {
- if (_currentRetryTimes < RETRY_TIMES)
- {
- _currentRetryTimes++;
- NotifyError(eEvent.WARN_SRD, $"Current Chuck ATM Retry Times is {_currentRetryTimes}", 0);
- _srdCommon.ChuckATMAction("", null);
- }
- else
- {
- NotifyError(eEvent.ERR_SRD, $"Chuck ATM Retry Times is over {RETRY_TIMES}. ChuckATM is failed!", 0);
- return true;
- }
- }
-
- return false;
- }
- /// <summary>
- /// Check Vacuum Value
- /// </summary>
- /// <returns></returns>
- private bool CheckVacuumValue()
- {
- if (_srdCommon.CommonData.VacuumValue >= _vacuumOffLimit)
- {
- //LOG.WriteLog(eEvent.INFO_SRD, Module, $"VacuumValue:{_srdCommon.CommonData.VacuumValue}, VacuumOn Limit:{_vacuumOffLimit}");
- return true;
- }
- else
- {
- LOG.WriteLog(eEvent.WARN_SRD, Module, $"VacuumValue:{_srdCommon.CommonData.VacuumValue}, VacuumOn Limit:{_vacuumOffLimit}");
- return false;
- }
- }
- /// <summary>
- /// LiftUpOff
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool LiftUpOn()
- {
- bool result = _srdCommon.LiftUpOnAction("", null);
- if (!result)
- {
- NotifyError(eEvent.ERR_SRD, "Lift Up On Action is failed", 0);
- return result;
- }
- return true;
- }
- /// <summary>
- /// 检验LiftUpOff结束状态
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool CheckLiftUpOnEndStatus()
- {
- return _srdCommon.Status == RState.End && _srdCommon.CommonData.LiftUpStatus;
- }
- /// <summary>
- /// 检验LiftUpOff结束状态
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool CheckLiftUpOnStopStatus()
- {
- if (_srdCommon.Status == RState.Failed || _srdCommon.Status == RState.Timeout)
- {
- NotifyError(eEvent.ERR_SRD, "Check LiftUpOn is failed", 0);
- return true;
- }
- return false;
- }
- /// <summary>
- /// ChuckVacuumOn
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool ChuckVacuumOff()
- {
- bool result = _srdCommon.ChuckVacuumOffAction("", null);
- if (!result)
- {
- NotifyError(eEvent.ERR_SRD, "ChuckVacuumOff Action is failed", 0);
- return result;
- }
- return true;
- }
- /// <summary>
- /// 检验ChuckVacuumOn结束状态
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool CheckChuckVacuumOffEndStatus()
- {
- return _srdCommon.Status == RState.End && _srdCommon.CommonData.ChuckVacuum;
- }
- /// <summary>
- /// 检验ChuckVacuumOn结束状态
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool CheckChuckVacuumOffStopStatus()
- {
- if (_srdCommon.Status == RState.Failed || _srdCommon.Status == RState.Timeout)
- {
- NotifyError(eEvent.ERR_SRD, "Check ChuckVacuumOff is failed", 0);
- return true;
- }
- return false;
- }
- /// <summary>
- /// Check WaferPresent
- /// </summary>
- /// <returns></returns>
- private bool CheckWaferPresent()
- {
- if (!_srdCommon.CommonData.WaferPresent)
- {
- NotifyError(eEvent.ERR_SRD, "WaferPresent sensor is off", 0);
- return false;
- }
- return true;
- }
- /// <summary>
- /// Open Door
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool OpenDoor()
- {
- return _srdCommon.DoorOpenAction("", null);
- }
- /// <summary>
- /// 检验DoorOpened
- /// </summary>
- /// <param name="param"></param>
- /// <returns></returns>
- private bool CheckDoorOpenedEndStatus()
- {
- bool result = _srdCommon.Status == RState.End;
- if (result)
- {
- if (_srdCommon.CommonData.DoorOpened && !_srdCommon.CommonData.DoorClosed)
- {
- return true;
- }
- else
- {
- NotifyError(eEvent.ERR_SRD, $"Opened {_srdCommon.CommonData.DoorOpened}&&Closed {_srdCommon.CommonData.DoorClosed}", 0);
- return false;
- }
- }
- return false;
- }
- /// <summary>
- /// 检验Door
- /// </summary>
- /// <returns></returns>
- private bool CheckDoorOpenedStopStatus()
- {
- return _srdCommon.Status == RState.Failed || _srdCommon.Status == RState.Timeout;
- }
- }
- }
|