LoaderInstallCRSRoutine.cs 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441
  1. using Aitex.Core.RT.Device;
  2. using Aitex.Core.RT.Log;
  3. using Aitex.Core.RT.Routine;
  4. using Aitex.Core.Util;
  5. using MECF.Framework.Common.CommonData.Loader;
  6. using MECF.Framework.Common.Equipment;
  7. using MECF.Framework.Common.Routine;
  8. using MECF.Framework.Common.Utilities;
  9. using CyberX8_Core;
  10. using CyberX8_RT.Devices.AXIS;
  11. using CyberX8_RT.Devices.AXIS.CANOpen;
  12. using CyberX8_RT.Modules.PUF;
  13. using CyberX8_RT.Modules;
  14. using System;
  15. using System.Collections.Generic;
  16. using System.Linq;
  17. using System.Text;
  18. using System.Threading.Tasks;
  19. using CyberX8_RT.Modules.Transporter;
  20. namespace CyberX8_RT.Devices.Loader
  21. {
  22. public class LoaderInstallCRSRoutine : RoutineBase, IRoutine
  23. {
  24. private enum InstallStep
  25. {
  26. DoorUnlock,
  27. DoorUnlockCheck,
  28. TiltGotoVertical,
  29. TiltGotoVerticalCheck,
  30. SwingGotoOpen,
  31. SwingGotoOpenWait,
  32. CRSGotoUnlock,
  33. CRSGotoUnlockWait,
  34. SwingGotoClose,
  35. SwingGotoCloseWait,
  36. DoorLockOn,
  37. DoorLockOnCheck,
  38. WSSideClampOn,
  39. WSSideClampOnCheck,
  40. WSClampOn,
  41. BernoulliN2On,
  42. BernoulliN2OnCheck,
  43. BernoulliBladderOn,
  44. BernoulliBladderOnCheck,
  45. TransBladderOn,
  46. TransBladderOnCheck,
  47. TranslateHighOff,
  48. TranslateHighOffCheck,
  49. CRSVacuumOn,
  50. CRSVacuumOnCheck,
  51. WSBladderOn,
  52. WSBladderOnCheck,
  53. VacuumLevel,
  54. VacuumLevelCheck,
  55. CRSGotoLock,
  56. CRSGotoLockWait,
  57. CRSVacuumOff,
  58. CRSVacuumOffCheck,
  59. WSBladderOff,
  60. WSBladderOffCheck,
  61. VacuumOffLevel,
  62. VacuumOffLevelCheck,
  63. CRSSwitchOn,
  64. CRSSwitchOnCheck,
  65. TransBladderOff,
  66. TransBladderOffCheck,
  67. LastTranslateHighOff,
  68. LastTranslateHighOffCheck,
  69. BernoulliN2Off,
  70. BernoulliN2OffCheck,
  71. HomingCRSAxis,
  72. HomingCRSAxisWait,
  73. CRSHomedGotoSetUp,
  74. CRSHomedGotoSetUpCheck,
  75. End
  76. }
  77. #region 内部变量
  78. private string _side = "";
  79. private LoaderCommonWaferHolderSideClampRoutine _waferHolderSideClampRoutine;
  80. private LoaderSideTransBladderRoutine _transBladderRoutine;
  81. private JetAxisBase _crsAxis;
  82. private LoaderSideBernoulliBladderRoutine _bernoulliBladderRoutine;
  83. private LoaderSideBernoulliN2PressureRoutine _bernoulliN2PressureRoutine;
  84. private LoaderSideTransHighRoutine _transHightRoutine;
  85. private LoaderSideVacuumRoutine _vacuumRoutine;
  86. private LoaderSideVacuumLevelCheckRoutine _vacuumLevelCheckRoutine;
  87. private LoaderSideWhBladderRoutine _whBladderRoutine;
  88. private LoaderSideUnloadVacuumLevelCheckRoutine _unloadVacuumLevelCheckRoutine;
  89. private LoaderSideDoorLockRoutine _doorLockRoutine;
  90. private JetAxisBase _shuttleAxis;
  91. private JetAxisBase _tiltAxis;
  92. private JetAxisBase _rotationAxis;
  93. private LoaderCommonDevice _loaderCommonDevice;
  94. private LoaderSideDevice _sideDevice;
  95. #endregion
  96. /// <summary>
  97. /// 构造函数
  98. /// </summary>
  99. /// <param name="module"></param>
  100. public LoaderInstallCRSRoutine(string module,string side) : base(module)
  101. {
  102. _side = side;
  103. }
  104. /// <summary>
  105. /// 中止
  106. /// </summary>
  107. public void Abort()
  108. {
  109. Runner.Stop("Manual Abort");
  110. }
  111. /// <summary>
  112. /// 监控
  113. /// </summary>
  114. /// <returns></returns>
  115. public RState Monitor()
  116. {
  117. //1.0 Door UnLock
  118. Runner.Run(InstallStep.DoorUnlock, () => { return _doorLockRoutine.Start(false) == RState.Running; }, _delay_1ms)
  119. .WaitWithStopCondition(InstallStep.DoorUnlockCheck, () => { return CommonFunction.CheckRoutineEndState(_doorLockRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_doorLockRoutine); })
  120. //1.1 Tilt Goto Vertical
  121. .Run(InstallStep.TiltGotoVertical, () => { return _tiltAxis.PositionStation("VERT",false); }, NullFun, _delay_1ms)
  122. .WaitWithStopCondition(InstallStep.TiltGotoVerticalCheck, () => { return _tiltAxis.Status == RState.End; }, () => { return _tiltAxis.Status == RState.Failed; })
  123. //1.2 Swing Goto OPEN
  124. .Run(InstallStep.SwingGotoOpen, () => { return _shuttleAxis.PositionStation("OPEN", false); }, NullFun, _delay_1ms)
  125. .WaitWithStopCondition(InstallStep.SwingGotoOpenWait, () => { return _shuttleAxis.Status == RState.End; }, () => { return _shuttleAxis.Status == RState.Failed; })
  126. //1.3 CRS Goto Unlock
  127. .Run(InstallStep.CRSGotoUnlock, () => { return _crsAxis.PositionStation("Unlock",false); }, NullFun, _delay_1ms)
  128. .WaitWithStopCondition(InstallStep.CRSGotoUnlockWait, () => { return _crsAxis.Status == RState.End; }, () => { return _crsAxis.Status == RState.Failed; })
  129. //1.4 Swing Goto CLOSE
  130. .Run(InstallStep.SwingGotoClose, () => { return _shuttleAxis.PositionStation("CLOSED", false); }, NullFun, _delay_1ms)
  131. .WaitWithStopCondition(InstallStep.SwingGotoCloseWait, () => { return _shuttleAxis.Status == RState.End; }, () => { return _shuttleAxis.Status == RState.Failed; })
  132. //1.5 Door Lock On
  133. .Run(InstallStep.DoorLockOn, () => { return _doorLockRoutine.Start(true) == RState.Running; }, _delay_1ms)
  134. .WaitWithStopCondition(InstallStep.DoorLockOnCheck, () => { return CommonFunction.CheckRoutineEndState(_doorLockRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_doorLockRoutine); })
  135. //1.6 WSSideClampOn
  136. .Run(InstallStep.WSSideClampOn, () => { return _waferHolderSideClampRoutine.Start(true) == RState.Running; }, _delay_1ms)
  137. .WaitWithStopCondition(InstallStep.WSSideClampOnCheck, () => { return CommonFunction.CheckRoutineEndState(_waferHolderSideClampRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_waferHolderSideClampRoutine); })
  138. //1.7 WSClampOn
  139. .Run(InstallStep.WSClampOn, () => { return _loaderCommonDevice.WaferHolderClampOnAction(); }, _delay_1ms)
  140. //1.8 BernoulliN2 On
  141. .Run(InstallStep.BernoulliN2On, () => { return _bernoulliN2PressureRoutine.Start(true) == RState.Running; }, _delay_1ms)
  142. .WaitWithStopCondition(InstallStep.BernoulliN2OnCheck, () => { return CommonFunction.CheckRoutineEndState(_bernoulliN2PressureRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_bernoulliN2PressureRoutine); })
  143. //1.9 BernoulliBladderOn
  144. .Run(InstallStep.BernoulliBladderOn, () => { return _bernoulliBladderRoutine.Start(true) == RState.Running; }, _delay_1ms)
  145. .WaitWithStopCondition(InstallStep.BernoulliBladderOnCheck, () => { return CommonFunction.CheckRoutineEndState(_bernoulliBladderRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_bernoulliBladderRoutine); })
  146. //2.0 Trans Bladder On
  147. .Run(InstallStep.TransBladderOn, () => { return _transBladderRoutine.Start(true) == RState.Running; }, _delay_1ms)
  148. .WaitWithStopCondition(InstallStep.TransBladderOnCheck, () => { return CommonFunction.CheckRoutineEndState(_transBladderRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_transBladderRoutine); })
  149. //2.0 Trans High Off
  150. .Run(InstallStep.TranslateHighOff, () => { return _transHightRoutine.Start(false) == RState.Running; }, _delay_1ms)
  151. .WaitWithStopCondition(InstallStep.TranslateHighOffCheck, () => { return CommonFunction.CheckRoutineEndState(_transHightRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_transHightRoutine); })
  152. //2.1 CRS Vacuum On
  153. .Run(InstallStep.CRSVacuumOn, () => { return _vacuumRoutine.Start(true) == RState.Running; }, _delay_1ms)
  154. .WaitWithStopCondition(InstallStep.CRSVacuumOnCheck, () => { return CommonFunction.CheckRoutineEndState(_vacuumRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_vacuumRoutine); })
  155. //2.2 WS Bladder On
  156. .Run(InstallStep.WSBladderOn, () => { return _whBladderRoutine.Start(true) == RState.Running; }, _delay_1ms)
  157. .WaitWithStopCondition(InstallStep.WSBladderOnCheck, () => { return CommonFunction.CheckRoutineEndState(_whBladderRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_whBladderRoutine); })
  158. //2.3 CRS Vacuum Check
  159. .Run(InstallStep.VacuumLevel, () => { return _vacuumLevelCheckRoutine.Start(true) == RState.Running; }, _delay_1ms)
  160. .WaitWithStopCondition(InstallStep.VacuumLevelCheck, () => { return CommonFunction.CheckRoutineEndState(_vacuumLevelCheckRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_vacuumLevelCheckRoutine); })
  161. //2.4 CRS Goto Lock
  162. .Run(InstallStep.CRSGotoLock, () => { return _crsAxis.PositionStation("Lock", false,0, 0, 0, false); }, NullFun, _delay_1ms)
  163. .WaitWithStopCondition(InstallStep.CRSGotoLockWait, () => { return _crsAxis.Status == RState.End; }, () => { return _crsAxis.Status == RState.Failed; })
  164. //2.5 CRS Vacuum Off
  165. .Run(InstallStep.CRSVacuumOff, () => { return _vacuumRoutine.Start(false) == RState.Running; }, _delay_1ms)
  166. .WaitWithStopCondition(InstallStep.CRSVacuumOffCheck, () => { return CommonFunction.CheckRoutineEndState(_vacuumRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_vacuumRoutine); })
  167. //2.6 WS Bladder Off
  168. .Run(InstallStep.WSBladderOff, () => { return _whBladderRoutine.Start(false) == RState.Running; }, _delay_1ms)
  169. .WaitWithStopCondition(InstallStep.WSBladderOffCheck, () => { return CommonFunction.CheckRoutineEndState(_whBladderRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_whBladderRoutine); })
  170. //2.7 CRS Vacuum Check
  171. .Run(InstallStep.VacuumOffLevel, () => { return _vacuumLevelCheckRoutine.Start(false) == RState.Running; }, _delay_1ms)
  172. .WaitWithStopCondition(InstallStep.VacuumOffLevelCheck, () => { return CommonFunction.CheckRoutineEndState(_vacuumLevelCheckRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_vacuumLevelCheckRoutine); })
  173. //2.8 CRS Switch On
  174. .Run(InstallStep.CRSSwitchOn, () => { _crsAxis.SwitchOn(); return true; }, _delay_1ms)
  175. .WaitWithStopCondition(InstallStep.CRSSwitchOnCheck, () => { return _crsAxis.Status == RState.End; }, () => { return _crsAxis.Status == RState.Failed; })
  176. //2.9 Trans Bladder Off
  177. .Run(InstallStep.TransBladderOff, () => { return _transBladderRoutine.Start(false) == RState.Running; }, _delay_1ms)
  178. .WaitWithStopCondition(InstallStep.TransBladderOff, () => { return CommonFunction.CheckRoutineEndState(_transBladderRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_transBladderRoutine); })
  179. //2.9 Trans High Off
  180. .Run(InstallStep.LastTranslateHighOff, () => { return _transHightRoutine.Start(false) == RState.Running; }, _delay_1ms)
  181. .WaitWithStopCondition(InstallStep.LastTranslateHighOffCheck, () => { return CommonFunction.CheckRoutineEndState(_transHightRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_transHightRoutine); })
  182. //3.0 BernoulliN2 Off
  183. .Run(InstallStep.BernoulliN2Off, () => { return _bernoulliN2PressureRoutine.Start(false) == RState.Running; }, _delay_1ms)
  184. .WaitWithStopCondition(InstallStep.BernoulliN2OffCheck, () => { return CommonFunction.CheckRoutineEndState(_bernoulliN2PressureRoutine); }, () => { return CommonFunction.CheckRoutineStopState(_bernoulliN2PressureRoutine); })
  185. //3.1 Home CRS Axis
  186. .Run(InstallStep.HomingCRSAxis, () => { return _crsAxis.Home(); }, _delay_1ms)
  187. .WaitWithStopCondition(InstallStep.HomingCRSAxisWait, () => { return _crsAxis.Status == RState.End; }, () => { return _crsAxis.Status == RState.Failed; })
  188. .Run(InstallStep.CRSHomedGotoSetUp, () => { return _crsAxis.PositionStation("Setup",false); }, _delay_1ms)
  189. .WaitWithStopCondition(InstallStep.CRSHomedGotoSetUpCheck, () => { return _crsAxis.Status == RState.End; }, () => { return _crsAxis.Status == RState.Failed; })
  190. .End(InstallStep.End, NullFun, 10);
  191. return Runner.Status;
  192. }
  193. /// <summary>
  194. /// 启动
  195. /// </summary>
  196. /// <param name="objs"></param>
  197. /// <returns></returns>
  198. /// <exception cref="NotImplementedException"></exception>
  199. public RState Start(params object[] objs)
  200. {
  201. _shuttleAxis = GetShuttleAxis();
  202. _crsAxis = GetCrsAxis();
  203. _tiltAxis = GetTiltAxis();
  204. _loaderCommonDevice = DEVICE.GetDevice<LoaderCommonDevice>($"{Module}.Common");
  205. _rotationAxis = DEVICE.GetDevice<JetAxisBase>($"{Module}.Rotation");
  206. _sideDevice = DEVICE.GetDevice<LoaderSideDevice>($"{Module}.{_side}");
  207. _waferHolderSideClampRoutine = new LoaderCommonWaferHolderSideClampRoutine($"{Module}");
  208. _vacuumRoutine = new LoaderSideVacuumRoutine($"{Module}.{_side}");
  209. _vacuumLevelCheckRoutine = new LoaderSideVacuumLevelCheckRoutine($"{Module}.{_side}");
  210. _unloadVacuumLevelCheckRoutine = new LoaderSideUnloadVacuumLevelCheckRoutine($"{Module}.{_side}");
  211. _doorLockRoutine = new LoaderSideDoorLockRoutine($"{Module}.{_side}");
  212. _whBladderRoutine = new LoaderSideWhBladderRoutine($"{Module}.{_side}");
  213. _transHightRoutine = new LoaderSideTransHighRoutine($"{Module}.{_side}");
  214. _bernoulliBladderRoutine = new LoaderSideBernoulliBladderRoutine($"{Module}.{_side}");
  215. _transBladderRoutine = new LoaderSideTransBladderRoutine($"{Module}.{_side}");
  216. _bernoulliN2PressureRoutine = new LoaderSideBernoulliN2PressureRoutine($"{Module}.{_side}");
  217. if(!CheckPreCondition())
  218. {
  219. return RState.Failed;
  220. }
  221. Runner.Start(Module, "InstallCRS");
  222. return RState.Running;
  223. }
  224. /// <summary>
  225. /// 获取Shuttle轴对象
  226. /// </summary>
  227. /// <returns></returns>
  228. private JetAxisBase GetShuttleAxis()
  229. {
  230. switch (_side)
  231. {
  232. case "SideA":
  233. return DEVICE.GetDevice<JetAxisBase>($"{Module}.ShuttleA");
  234. default:
  235. return DEVICE.GetDevice<JetAxisBase>($"{Module}.ShuttleB");
  236. }
  237. }
  238. /// <summary>
  239. /// 获取CRS轴对象
  240. /// </summary>
  241. /// <returns></returns>
  242. private JetAxisBase GetCrsAxis()
  243. {
  244. switch (_side)
  245. {
  246. case "SideA":
  247. return DEVICE.GetDevice<JetAxisBase>($"{Module}.LSA");
  248. default:
  249. return DEVICE.GetDevice<JetAxisBase>($"{Module}.LSB");
  250. }
  251. }
  252. /// <summary>
  253. /// 获取Tilt轴对象
  254. /// </summary>
  255. /// <returns></returns>
  256. private JetAxisBase GetTiltAxis()
  257. {
  258. switch (_side)
  259. {
  260. case "SideA":
  261. return DEVICE.GetDevice<JetAxisBase>($"{Module}.TiltA");
  262. default:
  263. return DEVICE.GetDevice<JetAxisBase>($"{Module}.TiltB");
  264. }
  265. }
  266. /// <summary>
  267. /// 检验前置条件
  268. /// </summary>
  269. /// <returns></returns>
  270. private bool CheckPreCondition()
  271. {
  272. if (!CheckHomeCondition())
  273. {
  274. return false;
  275. }
  276. if (!CheckInstallCRSAxisCondition())
  277. {
  278. return false;
  279. }
  280. if (!InstallCRSStatusCheck())
  281. {
  282. return false;
  283. }
  284. if (!InstallCRSVacuumCheck())
  285. {
  286. return false;
  287. }
  288. return true;
  289. }
  290. /// <summary>
  291. /// 检验Home条件
  292. /// </summary>
  293. /// <returns></returns>
  294. private bool CheckHomeCondition()
  295. {
  296. //检验PUF、Loader Transporter,Robot均Homed
  297. if (ModuleHelper.IsInstalled(ModuleName.PUF1))
  298. {
  299. PUFEntity puf1Entity = Singleton<RouteManager>.Instance.GetModule<PUFEntity>(ModuleName.PUF1.ToString());
  300. if (!puf1Entity.IsHomed)
  301. {
  302. LOG.WriteLog(eEvent.ERR_LOADER, Module.ToString(), "PUF1 is not homed");
  303. return false;
  304. }
  305. }
  306. if (ModuleHelper.IsInstalled(ModuleName.PUF2))
  307. {
  308. PUFEntity puf2Entity = Singleton<RouteManager>.Instance.GetModule<PUFEntity>(ModuleName.PUF2.ToString());
  309. if (!puf2Entity.IsHomed)
  310. {
  311. LOG.WriteLog(eEvent.ERR_LOADER, Module.ToString(), "PUF2 is not homed");
  312. return false;
  313. }
  314. }
  315. return true;
  316. }
  317. /// <summary>
  318. /// 检验Install Axis条件
  319. /// </summary>
  320. /// <param name="side"></param>
  321. /// <returns></returns>
  322. private bool CheckInstallCRSAxisCondition()
  323. {
  324. double rotationPosition = _rotationAxis.MotionData.MotorPosition;
  325. if (!_rotationAxis.CheckPositionIsInStation(rotationPosition, "LOADA") &&
  326. !_rotationAxis.CheckPositionIsInStation(rotationPosition, "SERVICEB"))
  327. {
  328. LOG.WriteLog(eEvent.ERR_LOADER, Module, $"rotation {rotationPosition} not in LOADA and SERVICEB");
  329. return false;
  330. }
  331. double shuttlePosition=_shuttleAxis.MotionData.MotorPosition;
  332. if (!_shuttleAxis.CheckPositionIsInStation(shuttlePosition, "OPEN") &&
  333. !_shuttleAxis.CheckPositionIsInStation(shuttlePosition, "OPENB"))
  334. {
  335. LOG.WriteLog(eEvent.ERR_LOADER, Module, $"shuttle {shuttlePosition} not in OPEN or OPENB");
  336. return false;
  337. }
  338. double tiltPosition=_tiltAxis.MotionData.MotorPosition;
  339. if (!_tiltAxis.CheckPositionIsInStation(tiltPosition, "HORI"))
  340. {
  341. LOG.WriteLog(eEvent.ERR_LOADER, Module, $"tilt {tiltPosition} not in HORI");
  342. return false;
  343. }
  344. double crsPosition= _crsAxis.MotionData.MotorPosition;
  345. if (_crsAxis.CheckPositionIsEmpty(crsPosition))
  346. {
  347. LOG.WriteLog(eEvent.ERR_LOADER, Module, $"crs {crsPosition} not at station");
  348. return false;
  349. }
  350. return true;
  351. }
  352. /// <summary>
  353. /// Install CRS Status Check
  354. /// </summary>
  355. /// <param name="side"></param>
  356. /// <returns></returns>
  357. private bool InstallCRSStatusCheck()
  358. {
  359. //Facility:CDA,N2,Vaccum均Enable且在正常范围
  360. //Side WaferPresent
  361. LoaderSideData sideData = _sideDevice.SideData;
  362. if (sideData.WaferPresent)
  363. {
  364. LOG.WriteLog(eEvent.ERR_LOADER, Module, "side wafer is present");
  365. return false;
  366. }
  367. if (sideData.DoorLowerLocked || sideData.DoorUpperLocked)
  368. {
  369. LOG.WriteLog(eEvent.ERR_LOADER, Module, "Door Lock is on");
  370. return false;
  371. }
  372. return true;
  373. }
  374. /// <summary>
  375. /// CRS Vacuum Check
  376. /// </summary>
  377. /// <param name="side"></param>
  378. /// <returns></returns>
  379. private bool InstallCRSVacuumCheck()
  380. {
  381. //CRS Vacuum检验
  382. LoaderSideData sideData = _sideDevice.SideData;
  383. if (sideData.CRSVacuum)
  384. {
  385. LOG.WriteLog(eEvent.ERR_LOADER, Module, "LS Vacuum is on");
  386. return false;
  387. }
  388. //WS Bladder
  389. if (sideData.WHBladder)
  390. {
  391. LOG.WriteLog(eEvent.ERR_LOADER, Module, "WS Bladder is on");
  392. return false;
  393. }
  394. //Translate Bladder/High Pres,且Sensor处于Retracted
  395. if (sideData.TransBladder)
  396. {
  397. LOG.WriteLog(eEvent.ERR_LOADER, Module, "TransBladder is on");
  398. return false;
  399. }
  400. if (sideData.TransHigh)
  401. {
  402. LOG.WriteLog(eEvent.ERR_LOADER, Module, "Trans High is on");
  403. return false;
  404. }
  405. //Bernoulli N2
  406. if (sideData.BernoulliN2)
  407. {
  408. LOG.WriteLog(eEvent.ERR_LOADER, Module, "Bernoulli N2 is on");
  409. return false;
  410. }
  411. //Wafer Shuttle Present
  412. LoaderCommonData commonData = _loaderCommonDevice.CommonData;
  413. if (!commonData.WaferHolderPresent)
  414. {
  415. LOG.WriteLog(eEvent.ERR_LOADER, Module, "Wafer Shuttle is absent");
  416. return false;
  417. }
  418. //Drip Tray Fluid
  419. if (commonData.DripTrayFluid)
  420. {
  421. LOG.WriteLog(eEvent.ERR_LOADER, Module, "Drip Tray Fluid is on");
  422. return false;
  423. }
  424. return true;
  425. }
  426. }
  427. }