TransporterPickUpValidateRoutine.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. using Aitex.Core.RT.Device;
  2. using Aitex.Core.RT.Log;
  3. using Aitex.Core.RT.Routine;
  4. using Aitex.Core.RT.SCCore;
  5. using Aitex.Core.Util;
  6. using MECF.Framework.Common.Routine;
  7. using MECF.Framework.Common.Utilities;
  8. using MECF.Framework.Common.WaferHolder;
  9. using CyberX8_Core;
  10. using CyberX8_RT.Devices.AXIS;
  11. using CyberX8_RT.Devices.TransPorter;
  12. using CyberX8_RT.Modules.Loader;
  13. using System;
  14. using System.Collections.Generic;
  15. using System.Linq;
  16. using System.Text;
  17. using System.Threading.Tasks;
  18. using Aitex.Core.Common;
  19. using MECF.Framework.Common.Alarm;
  20. using MECF.Framework.Common.CommonData;
  21. using System.Threading;
  22. using MECF.Framework.Common.SubstrateTrackings;
  23. namespace CyberX8_RT.Modules.Transporter
  24. {
  25. public class TransporterPickUpValidateRoutine : RoutineBase, IRoutine
  26. {
  27. private enum PickUpStep
  28. {
  29. PickUp,
  30. PickUpWait,
  31. ReadBarcodeConfirm,
  32. Place,
  33. PlaceWait,
  34. End
  35. }
  36. #region 内部变量
  37. private string _cellName;
  38. private TransporterPickUpFromRoutine _pickupFromRoutine;
  39. private TransporterPickDownToRoutine _placeRoutine;
  40. private JetAxisBase _gantryAxis;
  41. private TransporterCommon _transporterCommon;
  42. private bool _validate = false;
  43. #endregion
  44. /// <summary>
  45. /// 构造函数
  46. /// </summary>
  47. /// <param name="module"></param>
  48. public TransporterPickUpValidateRoutine(string module) : base(module)
  49. {
  50. _pickupFromRoutine=new TransporterPickUpFromRoutine(module);
  51. _placeRoutine=new TransporterPickDownToRoutine(module);
  52. }
  53. /// <summary>
  54. /// 中止
  55. /// </summary>
  56. public void Abort()
  57. {
  58. Runner.Stop("Manual Abort");
  59. }
  60. /// <summary>
  61. /// 监控
  62. /// </summary>
  63. /// <returns></returns>
  64. public RState Monitor()
  65. {
  66. //1.1 PickupFrom
  67. Runner .Run(PickUpStep.PickUp, () => { return _pickupFromRoutine.Start(_cellName) == RState.Running; }, _delay_1ms)
  68. .WaitWithStopCondition(PickUpStep.PickUpWait, () => CommonFunction.CheckRoutineEndState(_pickupFromRoutine),
  69. () => CheckRoutineStopStatus(_pickupFromRoutine, "PickUpValidate Routine", _pickupFromRoutine.ErrorMsg, 0))
  70. //2.1 Read Barcode 确认与Material Tracking的转移是否一致
  71. .Run(PickUpStep.ReadBarcodeConfirm, ReadBarcode, _delay_1ms)
  72. .RunIf(PickUpStep.Place, !_validate, ()=> { return _placeRoutine.Start(_cellName) == RState.Running; },_delay_1ms )
  73. .WaitWithStopConditionIf(PickUpStep.PlaceWait,!_validate, () => CommonFunction.CheckRoutineEndState(_placeRoutine),
  74. () => CheckRoutineStopStatus(_placeRoutine, "Place Routine", _placeRoutine.ErrorMsg, 1))
  75. .End(PickUpStep.End,NullFun,100);
  76. return Runner.Status;
  77. }
  78. /// <summary>
  79. /// 检验Routine异常结束状态
  80. /// </summary>
  81. /// <param name="routine"></param>
  82. /// <returns></returns>
  83. private bool CheckRoutineStopStatus(IRoutine routine, string routineName, string errorMsg, int step)
  84. {
  85. RState ret = routine.Monitor();
  86. if (ret == RState.Failed || ret == RState.Timeout)
  87. {
  88. NotifyError(eEvent.ERR_TRANSPORTER, $"PickUp Validate WaferHolder Routine\r\n{routineName}\\r\n{errorMsg}", step);
  89. return true;
  90. }
  91. return false;
  92. }
  93. /// <summary>
  94. /// 读取条码
  95. /// </summary>
  96. /// <returns></returns>
  97. private bool ReadBarcode()
  98. {
  99. TransporterEntity transporterEntity = Singleton<RouteManager>.Instance.GetModule<TransporterEntity>(Module.ToString());
  100. if (transporterEntity == null)
  101. {
  102. return true;
  103. }
  104. WaferHolderInfo waferHolderInfo = transporterEntity.WaferHolderInfo;
  105. if (waferHolderInfo == null)
  106. {
  107. return true;
  108. }
  109. bool isSimulator = SC.GetValue<bool>("System.IsSimulatorMode");
  110. string str = CycleReadBarcode(isSimulator);
  111. string error = "";
  112. if(!string.IsNullOrEmpty(str))
  113. {
  114. if (waferHolderInfo.Id == str)
  115. {
  116. _validate = true;
  117. }
  118. else
  119. {
  120. error = $"Wafer Shuttle Id {waferHolderInfo?.Id} is not matched with reader {str}";
  121. _validate = false;
  122. }
  123. }
  124. else
  125. {
  126. if (isSimulator)
  127. {
  128. _validate = true;
  129. return true;
  130. }
  131. error = $"reader data is empty";
  132. }
  133. if (!_validate)
  134. {
  135. if (CheckWaferHolderAllAssistWafers(waferHolderInfo))
  136. {
  137. WaferHolderManager.Instance.DisableWaferHolder(waferHolderInfo);
  138. LOG.WriteLog(eEvent.WARN_TRANSPORTER, Module, error);
  139. LOG.WriteLog(eEvent.WARN_TRANSPORTER, Module, $"disable WaferHolder {waferHolderInfo.Id}");
  140. AlarmList alarmList = new AlarmList(Module.ToString(), "", 0, error, 0, (int)AlarmType.Warning);
  141. AlarmListManager.Instance.AddAlarm(alarmList);
  142. }
  143. else
  144. {
  145. _validate = true;
  146. }
  147. }
  148. return true;
  149. }
  150. /// <summary>
  151. /// 检验WaferHolder所有的Wafer是辅助片
  152. /// </summary>
  153. /// <param name="waferHolderInfo"></param>
  154. /// <returns></returns>
  155. private bool CheckWaferHolderAllAssistWafers(WaferHolderInfo waferHolderInfo)
  156. {
  157. if (!string.IsNullOrEmpty(waferHolderInfo.WaferAId))
  158. {
  159. WaferInfo waferInfo = WaferManager.Instance.GetWaferByWaferId(waferHolderInfo.WaferAId);
  160. if (waferInfo!=null&&waferInfo.WaferType!=WaferType.Assit)
  161. {
  162. return false;
  163. }
  164. }
  165. if (!string.IsNullOrEmpty(waferHolderInfo.WaferBId))
  166. {
  167. WaferInfo waferInfo = WaferManager.Instance.GetWaferByWaferId(waferHolderInfo.WaferBId);
  168. if (waferInfo != null && waferInfo.WaferType != WaferType.Assit)
  169. {
  170. return false;
  171. }
  172. }
  173. return true;
  174. }
  175. /// <summary>
  176. /// 循环读取Barcode
  177. /// </summary>
  178. /// <param name="isSimulator"></param>
  179. /// <returns></returns>
  180. private string CycleReadBarcode(bool isSimulator)
  181. {
  182. int count = 0;
  183. string str = "";
  184. //读取Barcode3遍
  185. while (count < 3)
  186. {
  187. str = _transporterCommon.ReaderBarcode();
  188. str = str.Trim();
  189. if (!string.IsNullOrEmpty(str))
  190. {
  191. break;
  192. }
  193. if (isSimulator)
  194. {
  195. break;
  196. }
  197. Thread.Sleep(10);
  198. }
  199. return str;
  200. }
  201. /// <summary>
  202. /// 启动
  203. /// </summary>
  204. /// <param name="objs"></param>
  205. /// <returns></returns>
  206. public RState Start(params object[] objs)
  207. {
  208. _cellName = objs[0].ToString();
  209. _transporterCommon = DEVICE.GetDevice<TransporterCommon>($"{Module}.Common");
  210. _gantryAxis = DEVICE.GetDevice<JetAxisBase>($"{Module}.Gantry");
  211. _validate = false;
  212. return Runner.Start(Module, $"PickUpValidate {_cellName}");
  213. }
  214. /// <summary>
  215. /// 重试
  216. /// </summary>
  217. /// <param name="step"></param>
  218. public RState Retry(int step)
  219. {
  220. if (string.IsNullOrEmpty(_cellName))
  221. {
  222. NotifyError(eEvent.ERR_TRANSPORTER, "source cell is empty", step);
  223. return RState.Failed;
  224. }
  225. List<Enum> preStepIds = new List<Enum>();
  226. if (step == 0 || step == -1)
  227. {
  228. return Runner.Retry(PickUpStep.PickUp, preStepIds, Module, "PickUp Validate Retry");
  229. }
  230. else
  231. {
  232. AddPreSteps(PickUpStep.Place, preStepIds);
  233. return Runner.Retry(PickUpStep.Place, preStepIds, Module, $"Pickup Validate step {PickUpStep.Place} Retry");
  234. }
  235. }
  236. /// <summary>
  237. /// 忽略前步骤
  238. /// </summary>
  239. /// <param name="step"></param>
  240. /// <param name="preStepIds"></param>
  241. private void AddPreSteps(PickUpStep step, List<Enum> preStepIds)
  242. {
  243. for (int i = 0; i < (int)step; i++)
  244. {
  245. preStepIds.Add((PickUpStep)i);
  246. }
  247. }
  248. /// <summary>
  249. /// 检验前面Unload完成状态
  250. /// </summary>
  251. /// <returns></returns>
  252. public bool CheckCompleteCondition(int index)
  253. {
  254. TransporterEntity transporterEntity = Singleton<RouteManager>.Instance.GetModule<TransporterEntity>(Module);
  255. if (transporterEntity.WaferHolderInfo == null)
  256. {
  257. NotifyError(eEvent.ERR_TRANSPORTER, $"{Module} does not have waferholder", index);
  258. return false;
  259. }
  260. double gantryPsition = _gantryAxis.MotionData.MotorPosition;
  261. if (!_gantryAxis.CheckPositionIsInStation(gantryPsition, _cellName))
  262. {
  263. NotifyError(eEvent.ERR_TRANSPORTER, $"{Module} gantry not in {_cellName}", index);
  264. return false;
  265. }
  266. return true;
  267. }
  268. }
  269. }