SchedulerLoader.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. using Aitex.Core.RT.Fsm;
  2. using Aitex.Core.RT.Log;
  3. using Aitex.Core.Util;
  4. using MECF.Framework.Common.CommonData;
  5. using MECF.Framework.Common.Equipment;
  6. using CyberX8_Core;
  7. using CyberX8_RT.Modules;
  8. using CyberX8_RT.Modules.Loader;
  9. using CyberX8_RT.Modules.PUF;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.Linq;
  13. using System.Text;
  14. using System.Threading.Tasks;
  15. using MECF.Framework.Common.SubstrateTrackings;
  16. using CyberX8_RT.Modules.Metal;
  17. namespace CyberX8_RT.Schedulers.Loader
  18. {
  19. public class SchedulerLoader : SchedulerModule
  20. {
  21. private enum SchedulerStep
  22. {
  23. WaitLoad,
  24. Loading,
  25. }
  26. #region 内部变量
  27. private LoaderEntity _loaderEntity;
  28. private PUFEntity _puf1Entity;
  29. private PUFEntity _puf2Entity;
  30. private SchedulerStep _currentStep;
  31. #endregion
  32. #region 属性
  33. public override bool IsIdle
  34. {
  35. get { return _state == RState.End; }
  36. }
  37. public override bool IsError
  38. {
  39. get { return _state == RState.Failed || _state == RState.Timeout; }
  40. }
  41. #endregion
  42. /// <summary>
  43. /// 构造函数
  44. /// </summary>
  45. /// <param name="module"></param>
  46. public SchedulerLoader(ModuleName module) : base(module.ToString())
  47. {
  48. _loaderEntity = Singleton<RouteManager>.Instance.GetModule<LoaderEntity>(module.ToString());
  49. _puf1Entity = Singleton<RouteManager>.Instance.GetModule<PUFEntity>(ModuleName.PUF1.ToString());
  50. _puf2Entity = Singleton<RouteManager>.Instance.GetModule<PUFEntity>(ModuleName.PUF2.ToString());
  51. }
  52. /// <summary>
  53. /// 执行
  54. /// </summary>
  55. /// <param name="parameter"></param>
  56. /// <returns></returns>
  57. public override bool RunProcess(object recipe, object parameter, List<SchedulerSyncModuleMessage> syncModuleMessages)
  58. {
  59. _state = RState.Running;
  60. _currentStep = SchedulerStep.WaitLoad;
  61. return true;
  62. }
  63. /// <summary>
  64. /// 监控执行
  65. /// </summary>
  66. /// <returns></returns>
  67. public override bool MonitorProcess(SchedulerSequence schedulerSequence, bool hasMatchWafer)
  68. {
  69. if (_currentStep == SchedulerStep.WaitLoad)
  70. {
  71. if (_loaderEntity.State != (int)LOADERSTATE.WaitForLoad)
  72. {
  73. return false;
  74. }
  75. if (_puf1Entity.State == (int)PUFSTATE.AferSwapParkStation)
  76. {
  77. if (_puf2Entity.IsIdle&&_puf2Entity.IsBackToParkStation)
  78. {
  79. bool puf2AHasWafer = WaferManager.Instance.CheckHasWafer(ModuleName.PUF2, 0);
  80. bool puf2BHasWafer = WaferManager.Instance.CheckHasWafer(ModuleName.PUF2, 1);
  81. if (puf2AHasWafer || puf2BHasWafer)
  82. {
  83. return false;
  84. }
  85. bool result = _loaderEntity.CheckToPostMessage<LOADERSTATE, LoaderMSG>(eEvent.WARN_LOADER, Module.ToString(),
  86. (int)LoaderMSG.LoadAll);
  87. if (result)
  88. {
  89. _puf2Entity.CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.WARN_PUF, ModuleName.PUF2.ToString(), (int)PUFMSG.FlipSideA);
  90. _currentStep = SchedulerStep.Loading;
  91. }
  92. }
  93. }
  94. else if(_puf1Entity.IsIdle&&_puf1Entity.IsBackToParkStation && _puf2Entity.IsIdle && _puf2Entity.IsBackToParkStation)
  95. {
  96. bool puf1AHasWafer = WaferManager.Instance.CheckHasWafer(ModuleName.PUF1, 0);
  97. bool puf1BHasWafer = WaferManager.Instance.CheckHasWafer(ModuleName.PUF1, 1);
  98. if (puf1AHasWafer || puf1BHasWafer)
  99. {
  100. return false;
  101. }
  102. bool puf2AHasWafer = WaferManager.Instance.CheckHasWafer(ModuleName.PUF2, 0);
  103. bool puf2BHasWafer = WaferManager.Instance.CheckHasWafer(ModuleName.PUF2, 1);
  104. if (puf2AHasWafer || puf2BHasWafer)
  105. {
  106. return false;
  107. }
  108. bool result = _loaderEntity.CheckToPostMessage<LOADERSTATE, LoaderMSG>(eEvent.WARN_LOADER, Module.ToString(),
  109. (int)LoaderMSG.LoadAll);
  110. if (result)
  111. {
  112. _puf2Entity.CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.WARN_PUF, ModuleName.PUF2.ToString(), (int)PUFMSG.FlipSideA);
  113. _currentStep = SchedulerStep.Loading;
  114. }
  115. }
  116. }
  117. if(_currentStep==SchedulerStep.Loading)
  118. {
  119. if(_loaderEntity.IsIdle)
  120. {
  121. if (_puf2Entity.IsBusy)
  122. {
  123. return false;
  124. }
  125. if (_puf2Entity.IsFlipSideA)
  126. {
  127. _state = RState.End;
  128. }
  129. else
  130. {
  131. _puf2Entity.CheckToPostMessage<PUFSTATE, PUFMSG>(eEvent.WARN_PUF, ModuleName.PUF2.ToString(), (int)PUFMSG.FlipSideA);
  132. }
  133. }
  134. }
  135. return true;
  136. }
  137. /// <summary>
  138. /// 检验前置条件
  139. /// </summary>
  140. /// <param name="sequenceIndex"></param>
  141. /// <param name="parameter"></param>
  142. /// <returns></returns>
  143. public override bool CheckPrecondition(List<SchedulerSequence> schedulerSequences, int sequenceIndex, object parameter, string materialId,ref string reason)
  144. {
  145. if (_state == RState.Running)
  146. {
  147. reason = "scheduler module is already running";
  148. return false;
  149. }
  150. if (_loaderEntity.IsIdle)
  151. {
  152. reason = "loader is idle";
  153. return false;
  154. }
  155. if (_loaderEntity.WaferHolderInfo == null)
  156. {
  157. reason = "loader has no wafer shuttle";
  158. return false;
  159. }
  160. if (_loaderEntity.WaferHolderInfo.Id != materialId)
  161. {
  162. reason = $"{_loaderEntity.Module} wafer shuttle {_loaderEntity.WaferHolderInfo.Id} is not matched with {materialId}";
  163. return false;
  164. }
  165. return true;
  166. }
  167. }
  168. }