SchedulerPM.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. using Aitex.Core.Common;
  2. using Aitex.Core.RT.Fsm;
  3. using Aitex.Core.RT.Log;
  4. using Aitex.Core.RT.SCCore;
  5. using Aitex.Core.Util;
  6. using Aitex.Sorter.Common;
  7. using MECF.Framework.Common.Equipment;
  8. using MECF.Framework.Common.Schedulers;
  9. using MECF.Framework.Common.SubstrateTrackings;
  10. using FurnaceRT.Equipments.PMs;
  11. using FurnaceRT.Equipments.Systems;
  12. using System;
  13. namespace FurnaceRT.Equipments.Schedulers
  14. {
  15. public class SchedulerPM : SchedulerModule
  16. {
  17. public override bool IsAvailable
  18. {
  19. get { return _pm.IsReady && _pm.IsOnline && CheckTaskDone(); }
  20. }
  21. public override bool IsOnline
  22. {
  23. get { return _pm.IsOnline; }
  24. }
  25. public override bool IsError
  26. {
  27. get { return _pm.IsError; }
  28. }
  29. private PMModuleBase _pm = null;
  30. private ModuleName _taskRobot;
  31. private EnumTransferType _taskTransferType;
  32. private int _taskSlot;
  33. private DeviceTimer _timer = new DeviceTimer();
  34. public DateTime RecipeStartTime => _recipeStartTime;
  35. private DateTime _recipeStartTime;
  36. public SchedulerPM(ModuleName chamber) : base(chamber.ToString())
  37. {
  38. _pm = Singleton<EquipmentManager>.Instance.Modules[chamber] as PMModuleBase;
  39. //System.Diagnostics.Trace.Assert(_pm!=null);
  40. }
  41. public override bool IsReadyForPick(ModuleName robot, int slot)
  42. {
  43. return _pm.CheckReadyForTransfer(robot, Hand.Blade1, slot, EnumTransferType.Pick, out _)
  44. && WaferManager.Instance.CheckHasWafer(ModuleHelper.Converter(_module), 0);
  45. }
  46. public override bool IsReadyForPlace(ModuleName robot, int slot)
  47. {
  48. return _pm.CheckReadyForTransfer(robot, Hand.Blade1, slot, EnumTransferType.Place, out _)
  49. && WaferManager.Instance.CheckNoWafer(ModuleHelper.Converter(_module), 0);
  50. }
  51. public override bool PrepareTransfer(ModuleName robot, EnumTransferType type, int slot)
  52. {
  53. _task = TaskType.PrepareTransfer;
  54. _taskRobot = robot;
  55. _taskSlot = slot;
  56. _taskTransferType = type;
  57. if (!_pm.PrepareTransfer(robot, Hand.Blade1, slot, type, out string reason))
  58. {
  59. LOG.Write(reason);
  60. return false;
  61. }
  62. LogTaskStart(_task, $"{robot} {type} slot {slot + 1}");
  63. return true;
  64. }
  65. public bool IsPrepareTransfer(ModuleName robot, EnumTransferType type, int slot)
  66. {
  67. return _task == TaskType.PrepareTransfer && _taskRobot == robot && _taskSlot == slot &&
  68. _taskTransferType == type;
  69. }
  70. public override bool Process(string recipeName, bool isCleanRecipe, bool withWafer)
  71. {
  72. _task = TaskType.Process;
  73. _recipeStartTime = DateTime.Now;
  74. if (!_pm.Process(recipeName, isCleanRecipe, withWafer, out string reason))
  75. {
  76. LOG.Write(reason);
  77. return false;
  78. }
  79. LogTaskStart(_task, $"recipe: {recipeName}, clean: {isCleanRecipe}, with wafer: {withWafer}");
  80. return true;
  81. }
  82. public override bool Standby(string recipeName)
  83. {
  84. _task = TaskType.Standby;
  85. if (!_pm.Standby(recipeName, out string reason))
  86. {
  87. LOG.Write(reason);
  88. }
  89. LogTaskStart(_task, $"recipe: {recipeName}");
  90. return true;
  91. }
  92. public bool CheckStandbyCondition()
  93. {
  94. return _pm.CheckStandbyCondition();
  95. }
  96. public bool CheckTaskDone()
  97. {
  98. bool ret = false;
  99. switch (_task)
  100. {
  101. case TaskType.None:
  102. case TaskType.Standby:
  103. ret = true;
  104. break;
  105. case TaskType.PrepareTransfer:
  106. ret = _pm.CheckReadyForTransfer(_taskRobot, Hand.Blade1, _taskSlot, _taskTransferType, out _);
  107. break;
  108. case TaskType.Process:
  109. ret = _pm.IsReady;
  110. break;
  111. }
  112. if (ret && _task != TaskType.None)
  113. {
  114. LogTaskDone(_task, "");
  115. _task = TaskType.None;
  116. }
  117. return ret;
  118. }
  119. public bool Monitor()
  120. {
  121. return true;
  122. }
  123. }
  124. }