FIMSHomeRoutine.cs 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. using Aitex.Core.RT.Routine;
  2. using Aitex.Core.RT.SCCore;
  3. using MECF.Framework.Common.Equipment;
  4. using MECF.Framework.Common.SubstrateTrackings;
  5. using System;
  6. namespace FurnaceRT.Equipments.FIMSs
  7. {
  8. public class FIMSHomeRoutine : ModuleRoutine, IRoutine
  9. {
  10. enum RoutineStep
  11. {
  12. Home,
  13. Delay,
  14. CheckHomeFinish,
  15. }
  16. private int _timeout;
  17. private FIMSModule _fimsModule;
  18. public FIMSHomeRoutine(FIMSModule fimsModule)
  19. {
  20. Module = fimsModule.Module.ToString();
  21. _fimsModule = fimsModule;
  22. Name = "Home";
  23. }
  24. public Result Init()
  25. {
  26. return Result.DONE;
  27. }
  28. public Result Start(params object[] objs)
  29. {
  30. Reset();
  31. _timeout = SC.GetValue<int>($"FIMS.{Module}.HomeTimeout");
  32. if (!_fimsModule.SensorWaferRobotEX1AxisHomePosition.Value)
  33. {
  34. _fimsModule.HomeFailAlarm.Set($"wafer robot EX1 axis not at home position");
  35. return Result.FAIL;
  36. }
  37. if (!_fimsModule.SensorWaferRobotEX2AxisHomePosition.Value)
  38. {
  39. _fimsModule.HomeFailAlarm.Set($"wafer robot EX2 axis not at home position");
  40. return Result.FAIL;
  41. }
  42. //if (_fimsModule.FIMSDevice.DoorOpenCloseStatus == Devices.DeviceStatus.Open && _fimsModule.IsWaferOnRobot)
  43. //{
  44. // _fimsModule.HomeFailAlarm.Set($"wafer robot inside {Module}");
  45. // return Result.FAIL;
  46. //}
  47. Notify($"{_fimsModule.Name} {Name} start");
  48. return Result.RUN;
  49. }
  50. public override Result Monitor()
  51. {
  52. try
  53. {
  54. PauseRountine(_fimsModule.FIMSDevice.IsPause);
  55. if (_fimsModule.FIMSDevice.IsPause)
  56. return Result.RUN;
  57. Home((int)RoutineStep.Home, _timeout);
  58. Delay((int)RoutineStep.Delay, 3);
  59. CheckHomeFinish((int)RoutineStep.CheckHomeFinish, _timeout);
  60. }
  61. catch (RoutineBreakException)
  62. {
  63. return Result.RUN;
  64. }
  65. catch (RoutineFaildException)
  66. {
  67. _fimsModule.Stop();
  68. return Result.FAIL;
  69. }
  70. _fimsModule.FIMSDevice.IsInitCompleted = true;
  71. _fimsModule.FIMSDevice.IsLoadCompleted = false;
  72. _fimsModule.FIMSDevice.IsUnloadCompleted = true;
  73. _fimsModule.Stop();
  74. Notify($"{_fimsModule.Name} {Name} finished");
  75. return Result.DONE;
  76. }
  77. public void Abort()
  78. {
  79. _fimsModule.Stop();
  80. }
  81. private void Home(int id, int timeout)
  82. {
  83. Tuple<bool, Result> ret = ExecuteAndWait(id, () =>
  84. {
  85. Notify($"{Module} home");
  86. if (!_fimsModule.FIMSDevice.Init(out string reason))
  87. {
  88. Stop(reason);
  89. return false;
  90. }
  91. return true;
  92. }, () =>
  93. {
  94. return true;
  95. }, timeout * 1000);
  96. if (ret.Item1)
  97. {
  98. if (ret.Item2 == Result.FAIL)
  99. {
  100. throw (new RoutineFaildException());
  101. }
  102. else if (ret.Item2 == Result.TIMEOUT) //timeout
  103. {
  104. _fimsModule.HomeTimeoutAlarm.Set($"home timeout, can not complete in {timeout} seconds");
  105. throw (new RoutineFaildException());
  106. }
  107. else
  108. throw (new RoutineBreakException());
  109. }
  110. }
  111. private void CheckHomeFinish(int id, int timeout)
  112. {
  113. Tuple<bool, Result> ret = ExecuteAndWait(id, () =>
  114. {
  115. Notify($"Check {Module} home finish");
  116. return true;
  117. }, () =>
  118. {
  119. return _fimsModule.FIMSDevice.IsPLCInitCompleted && !_fimsModule.FIMSDevice.IsRunning;
  120. }, timeout * 1000);
  121. if (ret.Item1)
  122. {
  123. if (ret.Item2 == Result.FAIL)
  124. {
  125. throw (new RoutineFaildException());
  126. }
  127. else if (ret.Item2 == Result.TIMEOUT) //timeout
  128. {
  129. _fimsModule.HomeTimeoutAlarm.Set($"home timeout, can not complete in {timeout} seconds");
  130. throw (new RoutineFaildException());
  131. }
  132. else
  133. throw (new RoutineBreakException());
  134. }
  135. }
  136. }
  137. }