SchedulerLoaderTransporter.cs 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692
  1. using Aitex.Core.RT.Fsm;
  2. using Aitex.Core.Util;
  3. using MECF.Framework.Common.CommonData;
  4. using MECF.Framework.Common.Equipment;
  5. using MECF.Framework.Common.SubstrateTrackings;
  6. using CyberX8_Core;
  7. using CyberX8_RT.Modules;
  8. using CyberX8_RT.Modules.Loader;
  9. using CyberX8_RT.Modules.Transporter;
  10. using CyberX8_RT.Modules.PUF;
  11. using System;
  12. using System.Collections.Generic;
  13. using System.Linq;
  14. using System.ServiceModel.Syndication;
  15. using System.Text;
  16. using System.Threading.Tasks;
  17. using CyberX8_RT.Modules.Prewet;
  18. using Aitex.Core.RT.Device;
  19. using CyberX8_RT.Devices.AXIS;
  20. using MECF.Framework.Common.WaferHolder;
  21. using Aitex.Core.RT.Log;
  22. using MECF.Framework.Common.Schedulers;
  23. namespace CyberX8_RT.Schedulers.Transporter
  24. {
  25. public class SchedulerLoaderTransporter : SchedulerModule
  26. {
  27. private enum TransBufferToLoaderStep
  28. {
  29. None,
  30. NotifyLoaderPrepare,
  31. WaitLoaderPrePare,
  32. PickUpValidate,
  33. PickUpValidateMoveto,
  34. Place,
  35. End
  36. }
  37. private enum TransporterFlip
  38. {
  39. None,
  40. WaitPickUp,
  41. LoaderFlip,
  42. WaitLoader,
  43. WaitPlace,
  44. }
  45. #region 内部变量
  46. private LoaderEntity _loaderEntity;
  47. private TransporterEntity _loaderTransporterEntity;
  48. private TransporterEntity _processTransporterEntity;
  49. private TransBufferToLoaderStep _transBufferToLoaderStep = TransBufferToLoaderStep.None;
  50. private SchedulerPostMsg _schedulerPostMsg = new SchedulerPostMsg();
  51. private bool _postMsgResult = false;
  52. private TransporterFlip _transporterFlip=TransporterFlip.None;
  53. #endregion
  54. #region 属性
  55. public override bool IsIdle
  56. {
  57. get { return _state == RState.End; }
  58. }
  59. public bool IsBusy
  60. {
  61. get { return _state == RState.Running; }
  62. }
  63. public override bool IsError
  64. {
  65. get { return _state==RState.Failed||_state==RState.Timeout; }
  66. }
  67. #endregion
  68. /// <summary>
  69. /// 构造函数
  70. /// </summary>
  71. /// <param name="module"></param>
  72. public SchedulerLoaderTransporter(ModuleName module) : base(module.ToString())
  73. {
  74. _loaderEntity = Singleton<RouteManager>.Instance.GetModule<LoaderEntity>(ModuleName.Loader1.ToString());
  75. _loaderTransporterEntity = Singleton<RouteManager>.Instance.GetModule<TransporterEntity>(ModuleName.Transporter2.ToString());
  76. _processTransporterEntity = Singleton<RouteManager>.Instance.GetModule<TransporterEntity>(ModuleName.Transporter1.ToString());
  77. }
  78. /// <summary>
  79. /// 执行
  80. /// </summary>
  81. /// <param name="parameter"></param>
  82. /// <returns></returns>
  83. public override bool RunProcess(object recipe, object parameter,List<SchedulerSyncModuleMessage> syncMessages)
  84. {
  85. if (parameter==null)
  86. {
  87. return false;
  88. }
  89. TransporterAction action = (TransporterAction)parameter;
  90. if (action.ActionMsg == TransporterMSG.Transfer)
  91. {
  92. SynchorinzeModuleMessages(syncMessages);
  93. WaferHolderMoveItem waferHolderMoveItem = (WaferHolderMoveItem)action.Parameter;
  94. if (waferHolderMoveItem.SourceModule != ModuleName.Unknown && waferHolderMoveItem.DestModule != ModuleName.Unknown)
  95. {
  96. SchedulerProcessTransporter schedulerProcessTransporter = (SchedulerProcessTransporter)SchedulerManager.Instance.GetScheduler(ModuleName.Transporter1);
  97. if (schedulerProcessTransporter.IsBusy && _processTransporterEntity.IsIdle)
  98. {
  99. return false;
  100. }
  101. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))
  102. {
  103. return false;
  104. }
  105. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))
  106. {
  107. return false;
  108. }
  109. string strSource = waferHolderMoveItem.SourceModule.ToString();
  110. if (waferHolderMoveItem.SourceModule == ModuleName.Loader1)
  111. {
  112. strSource = "Loader";
  113. }
  114. //由于PickUpValidate可能存在校验失败的现象
  115. if (!WaferHolderManager.Instance.HasWaferHolder(strSource) && _loaderTransporterEntity.State != (int)TransporterState.PickUpValidateComplete)
  116. {
  117. return false;
  118. }
  119. string strDest = waferHolderMoveItem.DestModule.ToString();
  120. if (waferHolderMoveItem.DestModule == ModuleName.Loader1)
  121. {
  122. strDest = "Loader";
  123. }
  124. if (WaferHolderManager.Instance.HasWaferHolder(strDest))
  125. {
  126. return false;
  127. }
  128. if (waferHolderMoveItem.DestModule == ModuleName.Loader1)
  129. {
  130. return TransferWaferHolderToLoader(waferHolderMoveItem);
  131. }
  132. else if (waferHolderMoveItem.SourceModule == ModuleName.Loader1)
  133. {
  134. return TransWaferHolderFromLoader(waferHolderMoveItem);
  135. }
  136. else if (waferHolderMoveItem.SourceModuleType != ModuleType.Loader && waferHolderMoveItem.DestModuleType != ModuleType.Loader)
  137. {
  138. return TransferWaferHolderNonLoader(waferHolderMoveItem);
  139. }
  140. }
  141. }
  142. else if (action.ActionMsg == TransporterMSG.Flip)
  143. {
  144. return FlipLoader();
  145. }
  146. return true;
  147. }
  148. /// <summary>
  149. /// Loader 开始Flip
  150. /// </summary>
  151. /// <returns></returns>
  152. private bool FlipLoader()
  153. {
  154. if (_loaderEntity.WaferHolderInfo == null)
  155. {
  156. return false;
  157. }
  158. if (_loaderTransporterEntity.WaferHolderInfo != null)
  159. {
  160. return false;
  161. }
  162. bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(eEvent.WARN_TRANSPORTER,
  163. Module.ToString(), (int)TransporterMSG.PickUpFrom, "Loader");
  164. if (result)
  165. {
  166. _state = RState.Running;
  167. _schedulerPostMsg.Reset();
  168. _postMsgResult = false;
  169. _transporterFlip = TransporterFlip.WaitPickUp;
  170. }
  171. return result;
  172. }
  173. /// <summary>
  174. /// WaferHolder从Loader移动至Buffer
  175. /// </summary>
  176. private bool TransWaferHolderFromLoader(WaferHolderMoveItem waferHolderMoveItem)
  177. {
  178. if (_loaderEntity.IsBusy)
  179. {
  180. return false;
  181. }
  182. if (_loaderEntity.WaferHolderInfo == null)
  183. {
  184. return false;
  185. }
  186. bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,
  187. Module.ToString(), (int)TransporterMSG.Transfer, "Loader", waferHolderMoveItem.DestModule.ToString());
  188. if (result)
  189. {
  190. _state = RState.Running;
  191. _schedulerPostMsg.Reset();
  192. _postMsgResult = false;
  193. }
  194. return result;
  195. }
  196. /// <summary>
  197. /// WaferHolder从Buffer移动至Loader
  198. /// </summary>
  199. private bool TransferWaferHolderToLoader(WaferHolderMoveItem waferHolderMoveItem)
  200. {
  201. if (_loaderEntity.WaferHolderInfo != null)
  202. {
  203. return false;
  204. }
  205. if (_loaderEntity.IsIdle)
  206. {
  207. bool loaderResult = _loaderEntity.CheckToPostMessage<LOADERSTATE, LoaderMSG>(eEvent.WARN_LOADER,
  208. _loaderEntity.Module.ToString(), (int)LoaderMSG.PrepareForPlace);
  209. if (loaderResult)
  210. {
  211. _transBufferToLoaderStep = TransBufferToLoaderStep.WaitLoaderPrePare;
  212. }
  213. return false;
  214. }
  215. else if (_loaderEntity.State == (int)LOADERSTATE.WaitForUnload&&_transBufferToLoaderStep<TransBufferToLoaderStep.PickUpValidate)
  216. {
  217. _transBufferToLoaderStep = TransBufferToLoaderStep.PickUpValidate;
  218. return false;
  219. }
  220. else if (_transBufferToLoaderStep == TransBufferToLoaderStep.WaitLoaderPrePare)
  221. {
  222. if (_loaderEntity.State == (int)LOADERSTATE.WaitForUnload)
  223. {
  224. _transBufferToLoaderStep = TransBufferToLoaderStep.PickUpValidate;
  225. }
  226. return false;
  227. }
  228. else if (_transBufferToLoaderStep == TransBufferToLoaderStep.PickUpValidate)
  229. {
  230. if(_loaderTransporterEntity.IsBusy)
  231. {
  232. return false;
  233. }
  234. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))
  235. {
  236. return false;
  237. }
  238. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))
  239. {
  240. return false;
  241. }
  242. bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,
  243. Module.ToString(), (int)TransporterMSG.PickUpValidate, waferHolderMoveItem.SourceModule.ToString());
  244. if (result)
  245. {
  246. _transBufferToLoaderStep= TransBufferToLoaderStep.PickUpValidateMoveto;
  247. _state = RState.Running;
  248. _schedulerPostMsg.Reset();
  249. _postMsgResult = false;
  250. return true;
  251. }
  252. }
  253. return false;
  254. }
  255. /// <summary>
  256. /// 传输WaferHolder(无WaferHolder)
  257. /// </summary>
  258. /// <param name="waferHolderMoveItem"></param>
  259. private bool TransferWaferHolderNonLoader(WaferHolderMoveItem waferHolderMoveItem)
  260. {
  261. IModuleEntity moduleEntity = Singleton<RouteManager>.Instance.GetModule<IModuleEntity>(waferHolderMoveItem.DestModule.ToString());
  262. if (moduleEntity != null)
  263. {
  264. if (waferHolderMoveItem.SourceModule == ModuleName.Unknown || waferHolderMoveItem.DestModule == ModuleName.Unknown)
  265. {
  266. return false;
  267. }
  268. if (moduleEntity.Module == ModuleName.Prewet1)
  269. {
  270. PrewetEntity prewetEntity = moduleEntity as PrewetEntity;
  271. if(prewetEntity.State!=(int)PrewetState.WaitForPlace)
  272. {
  273. return false;
  274. }
  275. }
  276. else
  277. {
  278. if (!moduleEntity.IsIdle)
  279. {
  280. return false;
  281. }
  282. }
  283. if (waferHolderMoveItem.SourceModule != ModuleName.Unknown)
  284. {
  285. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))
  286. {
  287. return false;
  288. }
  289. }
  290. if (waferHolderMoveItem.DestModule != ModuleName.Unknown)
  291. {
  292. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))
  293. {
  294. return false;
  295. }
  296. }
  297. bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,
  298. Module.ToString(), (int)TransporterMSG.Transfer, waferHolderMoveItem.SourceModule.ToString(), waferHolderMoveItem.DestModule.ToString());
  299. if (result)
  300. {
  301. _state = RState.Running;
  302. _postMsgResult = false;
  303. _schedulerPostMsg.Reset();
  304. }
  305. return result;
  306. }
  307. return false;
  308. }
  309. /// <summary>
  310. /// 监控执行
  311. /// </summary>
  312. /// <returns></returns>
  313. public override bool MonitorProcess(SchedulerSequence schedulerSequence, bool hasMatchWafer)
  314. {
  315. TransporterAction action=schedulerSequence.Parameters as TransporterAction;
  316. if (action.ActionMsg == TransporterMSG.Transfer)
  317. {
  318. WaferHolderMoveItem moveItem = action.Parameter as WaferHolderMoveItem;
  319. //检验PostMsg的结果
  320. if (!_postMsgResult)
  321. {
  322. if (_loaderTransporterEntity.IsError)
  323. {
  324. return false;
  325. }
  326. _postMsgResult = CheckPostMsg(moveItem);
  327. if (!_postMsgResult)
  328. {
  329. return false;
  330. }
  331. }
  332. if (moveItem.DestModule == ModuleName.Loader1)
  333. {
  334. if (_transBufferToLoaderStep == TransBufferToLoaderStep.PickUpValidateMoveto)
  335. {
  336. if (_loaderTransporterEntity.IsIdle)
  337. {
  338. _state = RState.Failed;
  339. _transBufferToLoaderStep = TransBufferToLoaderStep.None;
  340. return false;
  341. }
  342. if (_loaderTransporterEntity.State == (int)TransporterState.PickUpValidateComplete)
  343. {
  344. if (!_loaderTransporterEntity.CheckOtherEntityStatus("Loader"))
  345. {
  346. return false;
  347. }
  348. bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,
  349. Module.ToString(), (int)TransporterMSG.MoveTo, "Loader");
  350. if (result)
  351. {
  352. _transBufferToLoaderStep = TransBufferToLoaderStep.Place;
  353. }
  354. }
  355. return true;
  356. }
  357. else if (_transBufferToLoaderStep == TransBufferToLoaderStep.Place)
  358. {
  359. if (_loaderTransporterEntity.State == (int)TransporterState.ValidateMoveToComplete)
  360. {
  361. bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,
  362. Module.ToString(), (int)TransporterMSG.Place, "Loader");
  363. if (result)
  364. {
  365. _transBufferToLoaderStep = TransBufferToLoaderStep.End;
  366. }
  367. }
  368. return true;
  369. }
  370. }
  371. if (_loaderTransporterEntity.IsIdle)
  372. {
  373. if (_loaderTransporterEntity.WaferHolderInfo != null)
  374. {
  375. return false;
  376. }
  377. PrewetPickComplete(schedulerSequence);
  378. _state = RState.End;
  379. _transBufferToLoaderStep=TransBufferToLoaderStep.None;
  380. }
  381. }
  382. else if (action.ActionMsg == TransporterMSG.Flip)
  383. {
  384. LoaderTransporterFlip(action.Parameter.ToString());
  385. }
  386. return true;
  387. }
  388. /// <summary>
  389. /// Flip
  390. /// </summary>
  391. private void LoaderTransporterFlip(string strTransporter)
  392. {
  393. if(_transporterFlip==TransporterFlip.WaitPickUp)
  394. {
  395. //检验PostMsg的结果
  396. if (!_postMsgResult)
  397. {
  398. if (_loaderTransporterEntity.IsError)
  399. {
  400. return;
  401. }
  402. _postMsgResult = _schedulerPostMsg.PostMsg<TransporterState, TransporterMSG>(_loaderTransporterEntity, _loaderTransporterEntity.State,
  403. eEvent.WARN_TRANSPORTER, Module.ToString(), (int)TransporterMSG.PickUpFrom,(int)TransporterState.PickUping, "Loader");
  404. if (!_postMsgResult)
  405. {
  406. return;
  407. }
  408. }
  409. if (_loaderTransporterEntity.IsIdle && _loaderTransporterEntity.WaferHolderInfo != null)
  410. {
  411. _transporterFlip = TransporterFlip.LoaderFlip;
  412. }
  413. }
  414. else if (_transporterFlip == TransporterFlip.LoaderFlip)
  415. {
  416. bool result = _loaderEntity.CheckToPostMessage<LOADERSTATE, LoaderMSG>(eEvent.WARN_LOADER, Module.ToString(), (int)LoaderMSG.PrepareForPlace, strTransporter);
  417. if (result)
  418. {
  419. _transporterFlip = TransporterFlip.WaitLoader;
  420. }
  421. }
  422. else if(_transporterFlip==TransporterFlip.WaitLoader)
  423. {
  424. if (_loaderEntity.State == (int)LOADERSTATE.WaitForUnload)
  425. {
  426. bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(eEvent.WARN_TRANSPORTER,
  427. Module.ToString(), (int)TransporterMSG.Place, "Loader");
  428. if (result)
  429. {
  430. _transporterFlip = TransporterFlip.WaitPlace;
  431. }
  432. }
  433. }
  434. else if (_transporterFlip == TransporterFlip.WaitPlace)
  435. {
  436. if (_loaderTransporterEntity.IsIdle && _loaderTransporterEntity.WaferHolderInfo == null)
  437. {
  438. _state = RState.End;
  439. _transporterFlip = TransporterFlip.None;
  440. }
  441. }
  442. }
  443. /// <summary>
  444. /// 检验PostMsg的结果
  445. /// </summary>
  446. /// <param name="waferHolderMoveItem"></param>
  447. /// <returns></returns>
  448. private bool CheckPostMsg(WaferHolderMoveItem waferHolderMoveItem)
  449. {
  450. if (waferHolderMoveItem.DestModule == ModuleName.Loader1)
  451. {
  452. return _schedulerPostMsg.PostMsg<TransporterState,TransporterMSG>(_loaderTransporterEntity, _loaderTransporterEntity.State,
  453. eEvent.WARN_TRANSPORTER,Module.ToString(), (int)TransporterMSG.PickUpValidate,
  454. (int)TransporterState.PickUpValidating, waferHolderMoveItem.SourceModule.ToString());
  455. }
  456. else
  457. {
  458. return _schedulerPostMsg.PostMsg<TransporterState, TransporterMSG>(_loaderTransporterEntity, _loaderTransporterEntity.State,
  459. eEvent.WARN_TRANSPORTER, Module.ToString(), (int)TransporterMSG.Transfer,
  460. (int)TransporterState.Transfering, waferHolderMoveItem.SourceModule.ToString(),waferHolderMoveItem.DestModule.ToString());
  461. }
  462. }
  463. /// <summary>
  464. /// PrewetPick完成事件
  465. /// </summary>
  466. private void PrewetPickComplete(SchedulerSequence sequence)
  467. {
  468. if (sequence.Parameters is TransporterAction)
  469. {
  470. TransporterAction action = (TransporterAction)sequence.Parameters;
  471. if (action.ActionMsg!=TransporterMSG.Transfer)
  472. {
  473. return;
  474. }
  475. WaferHolderMoveItem waferHolderMoveItem = (WaferHolderMoveItem)action.Parameter;
  476. if (waferHolderMoveItem.SourceModule == ModuleName.Prewet1)
  477. {
  478. PrewetEntity prewetEntity = Singleton<RouteManager>.Instance.GetModule<PrewetEntity>(ModuleName.Prewet1.ToString());
  479. if (prewetEntity.State == (int)PrewetState.WaitForPick)
  480. {
  481. prewetEntity.CheckToPostMessage<PrewetState, PrewetMsg>(Aitex.Core.RT.Log.eEvent.WARN_PREWET, ModuleName.Prewet1.ToString(),
  482. (int)PrewetMsg.PickComplete);
  483. }
  484. }
  485. }
  486. }
  487. /// <summary>
  488. /// 检验前置条件
  489. /// </summary>
  490. /// <param name="sequenceIndex"></param>
  491. /// <param name="parameter"></param>
  492. /// <returns></returns>
  493. public override bool CheckPrecondition(List<SchedulerSequence> schedulerSequences, int sequenceIndex, object parameter, string materialId, ref string reason)
  494. {
  495. _state = RState.Init;
  496. if(!(parameter is TransporterAction))
  497. {
  498. reason = "parameter is not TransporterAction";
  499. return false;
  500. }
  501. TransporterAction action = (TransporterAction)parameter;
  502. if (_state == RState.Running)
  503. {
  504. reason = "scheduler module is already running";
  505. return false;
  506. }
  507. if (_loaderTransporterEntity.IsBusy)
  508. {
  509. reason = "loader transporter entity is busy";
  510. return false;
  511. }
  512. if (_loaderTransporterEntity.WaferHolderInfo != null&& _loaderTransporterEntity.State != (int)TransporterState.PickUpValidateComplete)
  513. {
  514. reason = "loader transporter has wafer shuttle,but state is not PickUpValidateComplete";
  515. return false;
  516. }
  517. //电机是否还在执行动作
  518. JetAxisBase gantryAxis = DEVICE.GetDevice<JetAxisBase>($"{ModuleName.Transporter2}.Gantry");
  519. if (gantryAxis == null)
  520. {
  521. reason = "loader transporter gantry is null";
  522. return false;
  523. }
  524. if (gantryAxis.Status == RState.Running)
  525. {
  526. reason = "loader transporter gantry is running";
  527. return false;
  528. }
  529. JetAxisBase elevatorAxis = DEVICE.GetDevice<JetAxisBase>($"{ModuleName.Transporter2}.Elevator");
  530. if (elevatorAxis == null)
  531. {
  532. reason = "loader transporter elevator is null";
  533. return false;
  534. }
  535. if (elevatorAxis.Status == RState.Running)
  536. {
  537. reason = "loader transporter elevator is running";
  538. return false;
  539. }
  540. if (action.ActionMsg == TransporterMSG.Transfer)
  541. {
  542. WaferHolderMoveItem waferHolderMoveItem = (WaferHolderMoveItem)action.Parameter;
  543. //更新未知目标模块
  544. bool result = UpdateUnkownTargetModule(schedulerSequences, waferHolderMoveItem, sequenceIndex, materialId);
  545. if (!result)
  546. {
  547. reason = "loader transporter moveitem target module is unknown";
  548. return false;
  549. }
  550. //更新未知源模块
  551. UpdateUnkownSourceModule(schedulerSequences, waferHolderMoveItem, sequenceIndex, materialId);
  552. if (waferHolderMoveItem.SourceModule != ModuleName.Unknown)
  553. {
  554. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))
  555. {
  556. reason = $"loader transporter {waferHolderMoveItem.SourceModule} conflict process transporter";
  557. return false;
  558. }
  559. }
  560. if (waferHolderMoveItem.DestModule != ModuleName.Unknown)
  561. {
  562. if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))
  563. {
  564. reason = $"loader transporter {waferHolderMoveItem.DestModule} conflict process transporter";
  565. return false;
  566. }
  567. }
  568. //目标为Prewet
  569. if (waferHolderMoveItem.DestModule == ModuleName.Prewet1)
  570. {
  571. bool prewetCondition = CheckTargetPrewetCondition();
  572. if (!prewetCondition)
  573. {
  574. reason = "loader transporter destmodule prewet condition is not avaible";
  575. }
  576. return prewetCondition;
  577. }
  578. //源为Prewet
  579. if (waferHolderMoveItem.SourceModule == ModuleName.Prewet1)
  580. {
  581. bool prewetCondition = CheckSourcePrewetCondition();
  582. if (!prewetCondition)
  583. {
  584. reason = "loader transporter sourcemodule prewet condition is not avaible";
  585. }
  586. }
  587. }
  588. return true;
  589. }
  590. /// <summary>
  591. /// 更新未知目标模块
  592. /// </summary>
  593. private bool UpdateUnkownTargetModule(List<SchedulerSequence> schedulerSequences, WaferHolderMoveItem waferHolderMoveItem, int sequenceIndex,string materialId)
  594. {
  595. SchedulerSequence currentSequence = schedulerSequences[sequenceIndex];
  596. if (waferHolderMoveItem.DestModule == ModuleName.Unknown)
  597. {
  598. ModuleName moduleName = SchedulerSequenceManager.Instance.GetAvaibleEmptyModuleCell(waferHolderMoveItem.DestModuleType,currentSequence.SequenceType);
  599. if (moduleName == ModuleName.Unknown)
  600. {
  601. return false;
  602. }
  603. else
  604. {
  605. waferHolderMoveItem.DestModule = moduleName;
  606. if (sequenceIndex + 1 < schedulerSequences.Count)
  607. {
  608. SchedulerSequence sequence = schedulerSequences[sequenceIndex + 1];
  609. if (sequence.SchedulerModule == null)
  610. {
  611. sequence.SchedulerModule = SchedulerManager.Instance.GetScheduler(moduleName);
  612. sequence.ModuleName = moduleName;
  613. LOG.WriteLog(eEvent.INFO_TRANSPORTER, Module.ToString(), $"{materialId} loadertransporter confirm source module {moduleName}");
  614. }
  615. }
  616. }
  617. }
  618. return true;
  619. }
  620. /// <summary>
  621. /// 更新未知源模块
  622. /// </summary>
  623. private void UpdateUnkownSourceModule(List<SchedulerSequence> schedulerSequences, WaferHolderMoveItem waferHolderMoveItem,int sequenceIndex,string materialId)
  624. {
  625. if (waferHolderMoveItem.SourceModule == ModuleName.Unknown)
  626. {
  627. if (sequenceIndex >= 1 && sequenceIndex - 1 < schedulerSequences.Count)
  628. {
  629. SchedulerSequence preSchedulerSequence = schedulerSequences[sequenceIndex - 1];
  630. if (preSchedulerSequence != null && preSchedulerSequence.SchedulerModule != null)
  631. {
  632. waferHolderMoveItem.SourceModule = preSchedulerSequence.SchedulerModule.Module;
  633. LOG.WriteLog(eEvent.INFO_TRANSPORTER, Module.ToString(), $"{materialId} loadertransporter confirm source module {preSchedulerSequence.SchedulerModule.Module}");
  634. }
  635. }
  636. }
  637. }
  638. /// <summary>
  639. /// 检验目标Prewet前置条件
  640. /// </summary>
  641. /// <returns></returns>
  642. private bool CheckTargetPrewetCondition()
  643. {
  644. PrewetEntity prewetEntity = Singleton<RouteManager>.Instance.GetModule<PrewetEntity>(ModuleName.Prewet1.ToString());
  645. if(prewetEntity.IsIdle)
  646. {
  647. prewetEntity.CheckToPostMessage<PrewetState, PrewetMsg>(Aitex.Core.RT.Log.eEvent.WARN_PREWET, ModuleName.Prewet1.ToString(),
  648. (int)PrewetMsg.PrepareToPlace);
  649. }
  650. else if(prewetEntity.State==(int)PrewetState.WaitForPlace)
  651. {
  652. return true;
  653. }
  654. return false;
  655. }
  656. /// <summary>
  657. /// 检验源Prewet前置条件
  658. /// </summary>
  659. /// <returns></returns>
  660. private bool CheckSourcePrewetCondition()
  661. {
  662. PrewetEntity prewetEntity = Singleton<RouteManager>.Instance.GetModule<PrewetEntity>(ModuleName.Prewet1.ToString());
  663. if (prewetEntity.State == (int)PrewetState.WaitForPick||prewetEntity.IsError)
  664. {
  665. return true;
  666. }
  667. return false;
  668. }
  669. public override void ResetTask()
  670. {
  671. base.ResetTask();
  672. _schedulerPostMsg.Reset();
  673. _postMsgResult = false;
  674. }
  675. }
  676. }