ProcessDefine.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348
  1. using System;
  2. using System.Collections.Generic;
  3. //using System.
  4. using Venus_RT.Devices;
  5. using Venus_RT.Modules;
  6. using Aitex.Core.RT.Log;
  7. using Venus_Core;
  8. //#pragma warning disable 0436
  9. namespace Venus_RT.Modules.PMs
  10. {
  11. class ProcessHelper
  12. {
  13. static protected JetPM Chamber;
  14. private static Dictionary<string, Func<ProcessUnitBase, RecipeStep, RState>> startHelper = new Dictionary<string, Func<ProcessUnitBase, RecipeStep, RState>>
  15. {
  16. {"PressureByPressureModeUnit", PressureByPressureModeUnit_Start},
  17. {"PressureByValveModeUnit", PressureByValveModeUnit_Start},
  18. {"TCPUnit", TCPUnit_Start},
  19. {"BiasUnit", BiasUnit_Start},
  20. {"GasControlUnit", GasControlUnit_Start },
  21. {"ESCHVUnit", ESCHVUnit_Start },
  22. {"ProcessKitUnit", ProcessKitUnit_Start },
  23. };
  24. private static Dictionary<string, Func<ProcessUnitBase, RecipeStep, RState>> checkerHelper = new Dictionary<string, Func<ProcessUnitBase, RecipeStep, RState>>
  25. {
  26. {"PressureByPressureModeUnit", PressureByPressureModeUnit_Check},
  27. {"PressureByValveModeUnit", PressureByValveModeUnit_Check},
  28. {"TCPUnit", TCPUnit_Check},
  29. {"BiasUnit", BiasUnit_Check},
  30. {"GasControlUnit", GasControlUnit_Check},
  31. {"ESCHVUnit", ESCHVUnit_Check},
  32. {"ProcessKitUnit", ProcessKitUnit_Check}
  33. };
  34. private static Dictionary<string, Action<ProcessUnitBase, RecipeStep>> endHelper = new Dictionary<string, Action<ProcessUnitBase, RecipeStep>>
  35. {
  36. {"PressureByPressureModeUnit", PressureByPressureModeUnit_End},
  37. {"PressureByValveModeUnit", PressureByValveModeUnit_End},
  38. {"TCPUnit", TCPUnit_End},
  39. {"BiasUnit", BiasUnit_End},
  40. {"GasControlUnit", GasControlUnit_End},
  41. {"ESCHVUnit", ESCHVUnit_End},
  42. {"ProcessKitUnit", ProcessKitUnit_End}
  43. };
  44. public ProcessHelper(JetPM pm)
  45. {
  46. Chamber = pm;
  47. }
  48. static private RState PressureByPressureModeUnit_Start(ProcessUnitBase unit, RecipeStep step)
  49. {
  50. var ProcessUnit = unit as PressureByPressureModeUnit;
  51. if (Chamber.SetPVPressure(ProcessUnit.StartPressure))
  52. {
  53. return RState.Running;
  54. }
  55. return RState.Failed;
  56. }
  57. static private RState PressureByPressureModeUnit_Check(ProcessUnitBase unit, RecipeStep step)
  58. {
  59. var ProcessUnit = unit as PressureByPressureModeUnit;
  60. if(ProcessUnit.EnableRamp)
  61. {
  62. if (Chamber.SetPVPressure(ProcessUnit.StartPressure + (int)((ProcessUnit.TargetPressure - ProcessUnit.StartPressure) * step.RampFactor())))
  63. return RState.Running;
  64. else
  65. return RState.Failed;
  66. }
  67. if(step.Type == StepType.Stable && Chamber.ChamberPressure == ProcessUnit.StartPressure)
  68. {
  69. return RState.End;
  70. }
  71. return RState.Running;
  72. }
  73. static private void PressureByPressureModeUnit_End(ProcessUnitBase unit, RecipeStep step)
  74. {
  75. }
  76. static private RState PressureByValveModeUnit_Start(ProcessUnitBase unit, RecipeStep step)
  77. {
  78. var ProcessUnit = unit as PressureByValveModeUnit;
  79. if(Chamber.SetPVPostion(ProcessUnit.StartPosition))
  80. {
  81. return RState.Running;
  82. }
  83. return RState.Failed;
  84. }
  85. static private RState PressureByValveModeUnit_Check(ProcessUnitBase unit, RecipeStep step)
  86. {
  87. var ProcessUnit = unit as PressureByValveModeUnit;
  88. if(ProcessUnit.EnableRamp)
  89. {
  90. if (Chamber.SetPVPostion(ProcessUnit.StartPosition + (int)((ProcessUnit.TargetPosition - ProcessUnit.StartPosition) * step.RampFactor())))
  91. return RState.Running;
  92. else
  93. return RState.Failed;
  94. }
  95. return RState.Running;
  96. }
  97. static private void PressureByValveModeUnit_End(ProcessUnitBase unit, RecipeStep step)
  98. {
  99. }
  100. static private RState TCPUnit_Start(ProcessUnitBase unit, RecipeStep step)
  101. {
  102. var ProcessUnit = unit as TCPUnit;
  103. Chamber.GeneratorSetpower(ProcessUnit.RFPower);
  104. Chamber.GeneratorPowerOn(true);
  105. Chamber.SetMatchPosition(ProcessUnit.TuneCapPreset, ProcessUnit.LoadCapPreset);
  106. return RState.Running;
  107. }
  108. static private RState TCPUnit_Check(ProcessUnitBase unit, RecipeStep step)
  109. {
  110. var ProcessUnit = unit as TCPUnit;
  111. if(ProcessUnit.MaxReflectedPower > 0 && Chamber.ReflectPower > ProcessUnit.MaxReflectedPower)
  112. {
  113. LOG.Write(eEvent.ERR_PROCESS, Chamber.Module, $"Step:{step.StepNo} failed, RF Reflect Power:{Chamber.ReflectPower} exceeds the Max Limit:{ProcessUnit.MaxReflectedPower}");
  114. return RState.Failed;
  115. }
  116. if(step.ElapsedTime() > ProcessUnit.HoldTime * 1000)
  117. {
  118. Chamber.GeneratorSetpower(0);
  119. Chamber.GeneratorPowerOn(false);
  120. }
  121. return RState.Running;
  122. }
  123. static private void TCPUnit_End(ProcessUnitBase unit, RecipeStep step)
  124. {
  125. Chamber.GeneratorSetpower(0);
  126. Chamber.GeneratorPowerOn(false);
  127. }
  128. static private RState BiasUnit_Start(ProcessUnitBase unit, RecipeStep step)
  129. {
  130. var ProcessUnit = unit as BiasUnit;
  131. Chamber.GeneratorBiasSetpower(ProcessUnit.BiasRFPower);
  132. Chamber.GeneratorBiasPowerOn(true);
  133. Chamber.SetBiasMatchPosition(ProcessUnit.BiasTuneCapPreset, ProcessUnit.BiasLoadCapPreset);
  134. if(ProcessUnit.BiasGeneratorMode == GeneratorMode.Pulsing)
  135. {
  136. Chamber.SetBiasPulseMode(true);
  137. Chamber.SetBiasPulseRateFreq(ProcessUnit.PulseRateFreq);
  138. Chamber.SetDiasPulseDutyCycle(ProcessUnit.PulseDutyCycle);
  139. }
  140. return RState.Running;
  141. }
  142. static private RState BiasUnit_Check(ProcessUnitBase unit, RecipeStep step)
  143. {
  144. var ProcessUnit = unit as BiasUnit;
  145. if (ProcessUnit.BiasMaxReflectedPower > 0 && Chamber.BiasReflectPower > ProcessUnit.BiasMaxReflectedPower)
  146. {
  147. LOG.Write(eEvent.ERR_PROCESS, Chamber.Module, $"Step:{step.StepNo} failed, Bias Reflect Power:{Chamber.BiasReflectPower} exceeds the Max Limit:{ProcessUnit.BiasMaxReflectedPower}");
  148. return RState.Failed;
  149. }
  150. if (step.ElapsedTime() > ProcessUnit.BiasRFHoldTime * 1000)
  151. {
  152. Chamber.GeneratorBiasSetpower(0);
  153. Chamber.GeneratorBiasPowerOn(false);
  154. }
  155. return RState.Running;
  156. }
  157. static private void BiasUnit_End(ProcessUnitBase unit, RecipeStep step)
  158. {
  159. Chamber.GeneratorBiasSetpower(0);
  160. Chamber.GeneratorBiasPowerOn(false);
  161. }
  162. static private RState GasControlUnit_Start(ProcessUnitBase unit, RecipeStep step)
  163. {
  164. var ProcessUnit = unit as GasControlUnit;
  165. Chamber.FlowGas(0, ProcessUnit.Gas1);
  166. Chamber.FlowGas(1, ProcessUnit.Gas2);
  167. Chamber.FlowGas(2, ProcessUnit.Gas3);
  168. Chamber.FlowGas(3, ProcessUnit.Gas4);
  169. Chamber.FlowGas(4, ProcessUnit.Gas5);
  170. Chamber.FlowGas(5, ProcessUnit.Gas6);
  171. Chamber.FlowGas(6, ProcessUnit.Gas7);
  172. Chamber.FlowGas(7, ProcessUnit.Gas8);
  173. return RState.Running;
  174. }
  175. static private RState GasControlUnit_Check(ProcessUnitBase unit, RecipeStep step)
  176. {
  177. var ProcessUnit = unit as GasControlUnit;
  178. if(ProcessUnit.EnableRamp)
  179. {
  180. double rampFactor = step.RampFactor();
  181. Chamber.FlowGas(0, ProcessUnit.Gas1 + (ProcessUnit.Gas1Target - ProcessUnit.Gas1) * rampFactor);
  182. Chamber.FlowGas(1, ProcessUnit.Gas2 + (ProcessUnit.Gas2Target - ProcessUnit.Gas2) * rampFactor);
  183. Chamber.FlowGas(2, ProcessUnit.Gas3 + (ProcessUnit.Gas3Target - ProcessUnit.Gas3) * rampFactor);
  184. Chamber.FlowGas(3, ProcessUnit.Gas4 + (ProcessUnit.Gas4Target - ProcessUnit.Gas4) * rampFactor);
  185. Chamber.FlowGas(4, ProcessUnit.Gas5 + (ProcessUnit.Gas5Target - ProcessUnit.Gas5) * rampFactor);
  186. Chamber.FlowGas(5, ProcessUnit.Gas6 + (ProcessUnit.Gas6Target - ProcessUnit.Gas6) * rampFactor);
  187. Chamber.FlowGas(6, ProcessUnit.Gas7 + (ProcessUnit.Gas7Target - ProcessUnit.Gas7) * rampFactor);
  188. Chamber.FlowGas(7, ProcessUnit.Gas8 + (ProcessUnit.Gas8Target - ProcessUnit.Gas8) * rampFactor);
  189. }
  190. return RState.Running;
  191. }
  192. static private void GasControlUnit_End(ProcessUnitBase unit, RecipeStep step)
  193. {
  194. Chamber.FlowGas(0, 0);
  195. Chamber.FlowGas(1, 0);
  196. Chamber.FlowGas(2, 0);
  197. Chamber.FlowGas(3, 0);
  198. Chamber.FlowGas(4, 0);
  199. Chamber.FlowGas(5, 0);
  200. Chamber.FlowGas(6, 0);
  201. Chamber.FlowGas(7, 0);
  202. }
  203. static private RState ESCHVUnit_Start(ProcessUnitBase unit, RecipeStep step)
  204. {
  205. var ProcessUnit = unit as ESCHVUnit;
  206. Chamber.SetESCClampVoltage(ProcessUnit.ESCClampValtage);
  207. Chamber.SetBacksideHePressure(ProcessUnit.BacksideHelum * 1000);
  208. Chamber.SetBacksideHeThreshold(ProcessUnit.MinHeFlow, ProcessUnit.MaxHeFlow);
  209. return RState.Running;
  210. }
  211. static private RState ESCHVUnit_Check(ProcessUnitBase unit, RecipeStep step)
  212. {
  213. if(Chamber.BackSideHeOutOfRange)
  214. {
  215. LOG.Write(eEvent.ERR_PROCESS, Chamber.Module, $"Step:{step.StepNo} failed, Backside Helium out of range.");
  216. return RState.Failed;
  217. }
  218. return RState.Running;
  219. }
  220. static private void ESCHVUnit_End(ProcessUnitBase unit, RecipeStep step)
  221. {
  222. Chamber.SetESCClampVoltage(0);
  223. //Chamber.SetBacksideHePressure(0);
  224. Chamber.SetBacksideHeThreshold(0, 0);
  225. }
  226. static private RState ProcessKitUnit_Start(ProcessUnitBase unit, RecipeStep step)
  227. {
  228. var ProcessUnit = unit as ProcessKitUnit;
  229. return RState.Running;
  230. }
  231. static private RState ProcessKitUnit_Check(ProcessUnitBase unit, RecipeStep step)
  232. {
  233. var ProcessUnit = unit as ProcessKitUnit;
  234. return RState.Running;
  235. }
  236. static private void ProcessKitUnit_End(ProcessUnitBase unit, RecipeStep step)
  237. {
  238. }
  239. public static bool LoadMethods(ProcessUnitBase unit)
  240. {
  241. var className = unit.GetType().Name;
  242. if(startHelper.ContainsKey(className) && checkerHelper.ContainsKey(className) && endHelper.ContainsKey(className))
  243. {
  244. unit.starter = startHelper[className];
  245. unit.checker = checkerHelper[className];
  246. unit.end = endHelper[className];
  247. return true;
  248. }
  249. return false;
  250. }
  251. private static RState stepStarter(RecipeStep step)
  252. {
  253. step.StartStepTimer();
  254. switch (step.Type)
  255. {
  256. case StepType.EndPoint:
  257. Chamber.EPDStepStart(step.EPDConfigName);
  258. break;
  259. }
  260. return RState.Running;
  261. }
  262. private static RState stepChecker(RecipeStep step)
  263. {
  264. switch(step.Type)
  265. {
  266. case StepType.Time:
  267. return step.ElapsedTime() >= step.Time * 1000 ? RState.End : RState.Running;
  268. case StepType.OverEtch:
  269. return step.ElapsedTime() >= (step.GetLastEPDStepTime() * step.OverEtchPercent / 100) ? RState.End : RState.Running;
  270. case StepType.EndPoint:
  271. if (step.ElapsedTime() > step.MaxEndPointTime * 1000)
  272. {
  273. LOG.Write(eEvent.ERR_PROCESS, Chamber.Module, $"Step:{step.StepNo} timeout, did not capture endpoint signal in {step.MaxEndPointTime} seconds");
  274. return RState.Timeout;
  275. }
  276. else
  277. return Chamber.EPDCaptured ? RState.End : RState.Running;
  278. }
  279. return RState.Running;
  280. }
  281. private static RState stepEnder(RecipeStep step)
  282. {
  283. if(step.Type == StepType.EndPoint)
  284. {
  285. Chamber.EPDStepStop();
  286. }
  287. return RState.End;
  288. }
  289. public static bool LoadStepFuns(RecipeStep step)
  290. {
  291. step.starter = stepStarter;
  292. step.checker = stepChecker;
  293. step.ender = stepEnder;
  294. return true;
  295. }
  296. }
  297. }