WaferHolderTaskManager.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. using Aitex.Core.Common;
  2. using Aitex.Core.RT.Log;
  3. using Aitex.Core.Util;
  4. using MECF.Framework.Common.Equipment;
  5. using MECF.Framework.Common.WaferHolder;
  6. using CyberX8_RT.Modules.Loader;
  7. using CyberX8_RT.Modules;
  8. using CyberX8_RT.Schedulers;
  9. using System;
  10. using System.Collections.Concurrent;
  11. using System.Collections.Generic;
  12. using System.Linq;
  13. using System.Text;
  14. using System.Threading.Tasks;
  15. using MECF.Framework.Common.Jobs;
  16. using CyberX8_RT.Modules.PUF;
  17. using CyberX8_Core;
  18. using CyberX8_RT.Modules.Transporter;
  19. using MECF.Framework.Common.SubstrateTrackings;
  20. using MECF.Framework.Common.RecipeCenter;
  21. namespace CyberX8_RT.Dispatch
  22. {
  23. public class WaferHolderTaskManager : Singleton<WaferHolderTaskManager>
  24. {
  25. #region 内部变量
  26. /// <summary>
  27. /// wafer Holder task字典(key-id,value-waferHolderTask实例)
  28. /// </summary>
  29. private ConcurrentDictionary<string, WaferHolderTask> _waferHolderTaskDic = new ConcurrentDictionary<string, WaferHolderTask>();
  30. /// <summary>
  31. /// WaferTask集合
  32. /// </summary>
  33. private List<WaferHolderTask> _waferTaskList = new List<WaferHolderTask>();
  34. /// <summary>
  35. /// WaferTask锁
  36. /// </summary>
  37. private object _waferHolderTaskObject = new object();
  38. #endregion
  39. /// <summary>
  40. /// 创建任务
  41. /// </summary>
  42. public bool CreateWaferHolderTask(List<ProcessJobInfo> jobs)
  43. {
  44. SequenceRecipe sequenceRecipe = jobs[0].SequenceRecipe;
  45. List<string> chemistries = SchedulerSequenceRecipeManager.Instance.GetSequenceChemistry(sequenceRecipe);
  46. WaferSize waferSize = (WaferSize)sequenceRecipe.SubstrateSize;
  47. WaferHolderInfo waferHolderInfo = SchedulerManager.Instance.GetAvaibleBufferToLoaderWaferHolder(waferSize,sequenceRecipe.CrsType,chemistries);
  48. if (waferHolderInfo != null && CheckWaferHolderNotExist(waferHolderInfo))
  49. {
  50. if (CheckEnableCreateWaferHolderTask())
  51. {
  52. if(!Enum.TryParse(waferHolderInfo.CurrentLocation,out ModuleName locationModuleName))
  53. {
  54. return false;
  55. }
  56. if (ModuleHelper.IsBuffer(locationModuleName)&&string.IsNullOrEmpty(waferHolderInfo.OriginalBuffer))
  57. {
  58. waferHolderInfo.OriginalBuffer = waferHolderInfo.CurrentLocation;
  59. }
  60. List<SchedulerSequence> sequences = SchedulerSequenceManager.Instance.AnalyWaferHolderAllSchedulerSequence(waferHolderInfo, jobs[0].SequenceRecipe);
  61. WaferHolderTask waferHolderTask = new WaferHolderTask(waferHolderInfo, jobs[0],sequences);
  62. waferHolderTask.OnTaskComplete += WaferHolderTask_OnTaskComplete;
  63. _waferHolderTaskDic.TryAdd(waferHolderTask.ID,waferHolderTask);
  64. lock (_waferHolderTaskObject)
  65. {
  66. _waferTaskList.Add(waferHolderTask);
  67. }
  68. LOG.WriteLog(eEvent.EV_SEQUENCE, "Scheduler", $"Create wafer Shuttle {waferHolderInfo.Id} task");
  69. if (GetPreLoaderHasWafer()==null)
  70. {
  71. WaferTaskManager.Instance.CreateWaferTask(jobs, waferHolderInfo, waferHolderTask);
  72. }
  73. return true;
  74. }
  75. }
  76. return false;
  77. }
  78. /// <summary>
  79. /// 检验是否可以创建WaferHolderTask
  80. /// </summary>
  81. /// <returns></returns>
  82. private bool CheckEnableCreateWaferHolderTask()
  83. {
  84. TransporterEntity loaderTransporterEntity = Singleton<RouteManager>.Instance.GetModule<TransporterEntity>(ModuleName.Transporter2.ToString());
  85. LoaderEntity loaderEntity = Singleton<RouteManager>.Instance.GetModule<LoaderEntity>(ModuleName.Loader1.ToString());
  86. if (loaderEntity == null)
  87. {
  88. return false;
  89. }
  90. if (loaderEntity.IsError)
  91. {
  92. return false;
  93. }
  94. if (loaderTransporterEntity == null)
  95. {
  96. return false;
  97. }
  98. if (loaderEntity.WaferHolderInfo != null)
  99. {
  100. return false;
  101. }
  102. if (loaderTransporterEntity.IsError)
  103. {
  104. return false;
  105. }
  106. //if (loaderTransporterEntity.WaferHolderInfo != null)
  107. //{
  108. // return false;
  109. //}
  110. //if (loaderTransporterEntity.IsBusy)
  111. //{
  112. // return false;
  113. //}
  114. //存在其他任务没有完成Loader调度
  115. if (CheckExistWaferHolderTaskNotOverLoader())
  116. {
  117. return false;
  118. }
  119. return true;
  120. }
  121. /// <summary>
  122. /// 检验Loader前面是否存在Wafer
  123. /// </summary>
  124. /// <returns></returns>
  125. public WaferInfo GetPreLoaderHasWafer()
  126. {
  127. WaferInfo waferInfo = null;
  128. if (WaferManager.Instance.CheckHasWafer(ModuleName.EfemRobot, 0))
  129. {
  130. waferInfo = WaferManager.Instance.GetWafer(ModuleName.EfemRobot, 0);
  131. return CheckWaferTaskForward(waferInfo);
  132. }
  133. if (WaferManager.Instance.CheckHasWafer(ModuleName.Aligner1, 0))
  134. {
  135. waferInfo = WaferManager.Instance.GetWafer(ModuleName.Aligner1, 0);
  136. return CheckWaferTaskForward(waferInfo);
  137. }
  138. //PUF1 B面
  139. if(WaferManager.Instance.CheckHasWafer(ModuleName.PUF1,1))
  140. {
  141. waferInfo = WaferManager.Instance.GetWafer(ModuleName.PUF1, 1);
  142. return CheckWaferTaskForward(waferInfo);
  143. }
  144. //PUF2 B面
  145. if (WaferManager.Instance.CheckHasWafer(ModuleName.PUF2, 1))
  146. {
  147. waferInfo = WaferManager.Instance.GetWafer(ModuleName.PUF2, 1);
  148. return CheckWaferTaskForward(waferInfo);
  149. }
  150. return waferInfo;
  151. }
  152. /// <summary>
  153. /// 检验Wafer是否在于Loader之前
  154. /// </summary>
  155. /// <param name="waferInfo"></param>
  156. /// <returns></returns>
  157. private WaferInfo CheckWaferTaskForward(WaferInfo waferInfo)
  158. {
  159. if (!WaferTaskManager.Instance.Contains(waferInfo.WaferID))
  160. {
  161. return null;
  162. }
  163. WaferTask waferTask = WaferTaskManager.Instance.GetWaferTask(waferInfo.WaferID);
  164. if (waferTask == null)
  165. {
  166. return null;
  167. }
  168. if (waferTask.IsSchedulerForward())
  169. {
  170. return waferInfo;
  171. }
  172. else
  173. {
  174. return null;
  175. }
  176. }
  177. /// <summary>
  178. /// 创建Dummy WaferHolder Task
  179. /// </summary>
  180. public void CreateDummyWaferHolderTask()
  181. {
  182. List<WaferHolderInfo> waferHolderInfos = DummyWaferManager.Instance.LoadCompletedWaferHolderInfo();
  183. foreach (WaferHolderInfo waferHolderInfo in waferHolderInfos)
  184. {
  185. if (CheckWaferHolderNotExist(waferHolderInfo))
  186. {
  187. if (CheckEnableCreateWaferHolderTask())
  188. {
  189. List<WaferInfo> waferInfos = DummyWaferManager.Instance.LoadDummyWafersByWaferHolder(waferHolderInfo);
  190. if (waferInfos.Count != 0)
  191. {
  192. List<SchedulerSequence> sequences = SchedulerSequenceManager.Instance.AnalyseDummyWaferHolderAllSchedulerSequence(waferHolderInfo);
  193. WaferHolderTask waferHolderTask = new WaferHolderTask(waferHolderInfo, null, sequences);
  194. waferHolderTask.OnTaskComplete += WaferHolderTask_OnTaskComplete;
  195. _waferHolderTaskDic.TryAdd(waferHolderTask.ID, waferHolderTask);
  196. lock (_waferHolderTaskObject)
  197. {
  198. _waferTaskList.Add(waferHolderTask);
  199. }
  200. LOG.WriteLog(eEvent.EV_SEQUENCE, "Scheduler", $"Create dummy wafer Shuttle {waferHolderInfo.Id} task");
  201. if (GetPreLoaderHasWafer()==null)
  202. {
  203. WaferTaskManager.Instance.CreateDummyWaferTask(waferInfos, waferHolderInfo.SequenceRecipe, waferHolderTask);
  204. }
  205. break;
  206. }
  207. }
  208. }
  209. }
  210. }
  211. /// <summary>
  212. /// wafer Holder Task完成事件
  213. /// </summary>
  214. /// <param name="id"></param>
  215. private void WaferHolderTask_OnTaskComplete(string id)
  216. {
  217. RemoveById(id);
  218. }
  219. /// <summary>
  220. /// 检验WaferHolderTask是否完成Loader调度
  221. /// </summary>
  222. /// <returns></returns>
  223. private bool CheckExistWaferHolderTaskNotOverLoader()
  224. {
  225. List<WaferHolderTask> waferHolderTasks = _waferHolderTaskDic.Values.ToList();
  226. foreach(var task in waferHolderTasks)
  227. {
  228. if (task.IsNotPassLoader())
  229. {
  230. return true;
  231. }
  232. }
  233. return false;
  234. }
  235. /// <summary>
  236. /// 是否包含该任务
  237. /// </summary>
  238. /// <param name="id"></param>
  239. /// <returns></returns>
  240. public bool CheckWaferHolderNotExist(WaferHolderInfo waferHolderInfo)
  241. {
  242. List<WaferHolderTask> waferHolderTasks = _waferHolderTaskDic.Values.ToList();
  243. return waferHolderTasks.Find(O => O.WaferHolderInfo.Id == waferHolderInfo.Id) == null;
  244. }
  245. /// <summary>
  246. /// 移除
  247. /// </summary>
  248. /// <param name="id"></param>
  249. public void RemoveById(string id)
  250. {
  251. if (_waferHolderTaskDic.ContainsKey(id))
  252. {
  253. _waferHolderTaskDic.TryRemove(id, out var waferHolderTask);
  254. waferHolderTask.Dispose();
  255. waferHolderTask.OnTaskComplete -= WaferHolderTask_OnTaskComplete;
  256. LOG.WriteBackgroundLog(eEvent.EV_SCHEDULER, "Scheduler", $"remove wafer Shuttle {waferHolderTask.WaferHolderInfo.Id} task");
  257. }
  258. lock (_waferHolderTaskObject)
  259. {
  260. int index = _waferTaskList.FindIndex(O => O.ID == id);
  261. if (index != -1)
  262. {
  263. _waferTaskList.RemoveAt(index);
  264. }
  265. }
  266. }
  267. /// <summary>
  268. /// 加载WaferHolder任务集合
  269. /// </summary>
  270. /// <returns></returns>
  271. public List<WaferHolderTask> LoaderWaferHolderTaskList()
  272. {
  273. lock (_waferHolderTaskObject)
  274. {
  275. return _waferTaskList;
  276. }
  277. }
  278. /// <summary>
  279. /// 暂停
  280. /// </summary>
  281. public void PauseAllTask()
  282. {
  283. List<WaferHolderTask> waferHolderTasks = _waferHolderTaskDic.Values.ToList();
  284. foreach (WaferHolderTask item in waferHolderTasks)
  285. {
  286. item.Pause();
  287. }
  288. }
  289. /// <summary>
  290. /// 恢复所有任务
  291. /// </summary>
  292. public void ResumeAllTask()
  293. {
  294. List<WaferHolderTask> waferHolderTasks = _waferHolderTaskDic.Values.ToList();
  295. foreach (WaferHolderTask item in waferHolderTasks)
  296. {
  297. item.Resume();
  298. }
  299. }
  300. /// <summary>
  301. /// 移除所有任务
  302. /// </summary>
  303. public void RemoveAllTask()
  304. {
  305. List<WaferHolderTask> waferHolderTasks = _waferHolderTaskDic.Values.ToList();
  306. foreach (WaferHolderTask item in waferHolderTasks)
  307. {
  308. RemoveById(item.ID);
  309. }
  310. }
  311. /// <summary>
  312. /// 中止WaferHolderTask
  313. /// </summary>
  314. /// <param name="processJobInfo"></param>
  315. public void AbortWaferHolderTaskByProcessJob(ProcessJobInfo processJobInfo)
  316. {
  317. List<string> keys = _waferHolderTaskDic.Keys.ToList();
  318. foreach (string key in keys)
  319. {
  320. WaferHolderTask waferHolderTask = _waferHolderTaskDic[key];
  321. if(waferHolderTask!=null&&waferHolderTask.ProcessJobInfo!=null&&waferHolderTask.ProcessJobInfo.InnerId == processJobInfo.InnerId)
  322. {
  323. _waferHolderTaskDic.TryRemove(key, out waferHolderTask);
  324. RemoveById(waferHolderTask.ID);
  325. LOG.WriteBackgroundLog(eEvent.EV_SCHEDULER, "Scheduler", $"remove wafer Shuttle {waferHolderTask.WaferHolderInfo.Id} task");
  326. }
  327. }
  328. }
  329. /// <summary>
  330. /// 是否存在其他WaferTask没有
  331. /// </summary>
  332. /// <returns></returns>
  333. private bool CheckExistWaferHolderTaskNotStart()
  334. {
  335. List<WaferHolderTask> tmp = _waferHolderTaskDic.Values.ToList();
  336. foreach (WaferHolderTask item in tmp)
  337. {
  338. if (item.State == WaferHolderTaskState.Created)
  339. {
  340. return true;
  341. }
  342. }
  343. return false;
  344. }
  345. }
  346. }