123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191 |
- using Aitex.Common.Util;
- using Aitex.Core.RT.Fsm;
- using Aitex.Core.RT.Log;
- using Aitex.Core.Util;
- using CyberX8_Core;
- using CyberX8_RT.Modules;
- using CyberX8_RT.Modules.Dryer;
- using CyberX8_RT.Modules.Loader;
- using CyberX8_RT.Modules.Prewet;
- using CyberX8_RT.Modules.Rinse;
- using MECF.Framework.Common.CommonData;
- using MECF.Framework.Common.Equipment;
- using MECF.Framework.Common.RecipeCenter;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- namespace CyberX8_RT.Schedulers.Rinse
- {
- public class SchedulerRinse : SchedulerModule
- {
- #region 内部变量
- private RinseEntity _rinseEntity;
- private bool _isStartRunRecipe = false;
- #endregion
- #region 属性
- /// <summary>
- /// 是否空闲
- /// </summary>
- public override bool IsIdle
- {
- get { return _state == RState.End; }
- }
- /// <summary>
- /// 是否错误
- /// </summary>
- public override bool IsError
- {
- get { return _state == RState.Failed || _state == RState.Timeout; }
- }
- #endregion
- /// <summary>
- /// 构造函数
- /// </summary>
- /// <param name="module"></param>
- public SchedulerRinse(ModuleName moduleName) : base(moduleName.ToString())
- {
- _rinseEntity = Singleton<RouteManager>.Instance.GetModule<RinseEntity>(moduleName.ToString());
- }
- /// <summary>
- /// 执行
- /// </summary>
- /// <param name="parameter"></param>
- /// <returns></returns>
- public override bool RunProcess(object recipe, object parameter, List<SchedulerSyncModuleMessage> syncModuleMessages)
- {
- if (!(recipe is QdrRecipe))
- {
- _state = RState.Failed;
- LOG.WriteLog(eEvent.ERR_RINSE, Module.ToString(), "recipe is invalid");
- return false;
- }
- _isStartRunRecipe = false;
- QdrRecipe qdrRecipe = (QdrRecipe)recipe;
- bool result = _rinseEntity.CheckToPostMessage<RinseState, RinseMsg>(eEvent.ERR_RINSE, Module.ToString(), (int)RinseMsg.RunRecipe, qdrRecipe,1);
- if (result)
- {
- _state = RState.Running;
- }
- return result;
- }
- /// <summary>
- /// 监控执行
- /// </summary>
- /// <returns></returns>
- public override bool MonitorProcess(SchedulerSequence schedulerSequence, bool hasMatchWafer)
- {
- if (!_isStartRunRecipe)
- {
- _isStartRunRecipe = _rinseEntity.State == (int)RinseState.RunReciping;
- }
- if (_rinseEntity.IsError)
- {
- _state = RState.Failed;
- _isStartRunRecipe = false;
- }
- if (_isStartRunRecipe && _rinseEntity.IsIdle)
- {
- _state = RState.End;
- _isStartRunRecipe = false;
- }
- if(_rinseEntity.State==(int)RinseState.RunRecipeComplete||_rinseEntity.State==(int)RinseState.KeepWeting)
- {
- if (schedulerSequence.NextModuleType != ModuleType.Metal)
- {
- NotifyRinseComplete();
- }
- else
- {
- bool exsitEnableCell = false;
- DepRecipe depRecipe = schedulerSequence.NextRecipe as DepRecipe;
- ModuleName moduleName = SchedulerSequenceManager.Instance.CalculateAvaibleMetalCellByChemistry(depRecipe.Chemistry,
- Module.ToString(),schedulerSequence.SequenceType,ref exsitEnableCell);
- if (moduleName != ModuleName.Unknown)
- {
- IModuleEntity moduleEntity = Singleton<RouteManager>.Instance.GetModule<IModuleEntity>(moduleName.ToString());
- if (SchedulerSequenceManager.Instance.CheckMetalCellRecipeTimeAvaible(moduleEntity, depRecipe))
- {
- NotifyRinseComplete();
- }
- else
- {
- NotifyRinseKeepWet();
- }
- }
- else
- {
- if (exsitEnableCell)
- {
- NotifyRinseKeepWet();
- }
- else
- {
- NotifyRinseComplete();
- }
- }
- }
- }
- return true;
- }
- /// <summary>
- /// 通知Rinse完成
- /// </summary>
- private void NotifyRinseComplete()
- {
- _rinseEntity.CheckToPostMessage<RinseState, RinseMsg>(eEvent.INFO_RINSE, Module.ToString(), (int)RinseMsg.RecipeComplete);
- }
- /// <summary>
- /// 通知Rinse准备Keep Wet
- /// </summary>
- private void NotifyRinseKeepWet()
- {
- if (_rinseEntity.State == (int)RinseState.KeepWeting)
- {
- return;
- }
- _rinseEntity.CheckToPostMessage<RinseState, RinseMsg>(eEvent.WARN_PREWET, Module.ToString(),
- (int)RinseMsg.Keepwet);
- }
- /// <summary>
- /// 检验前置条件
- /// </summary>
- /// <param name="sequenceIndex"></param>
- /// <param name="parameter"></param>
- /// <returns></returns>
- public override bool CheckPrecondition(List<SchedulerSequence> schedulerSequences, int sequenceIndex, object parameter, string materialId,ref string reason)
- {
- if (_state == RState.Running)
- {
- reason = "scheduler module is already running";
- return false;
- }
- if (_rinseEntity.IsBusy)
- {
- reason = $"{_rinseEntity.Module} is busy";
- return false;
- }
- if(_rinseEntity.WaferHolderInfo==null)
- {
- reason = $"{_rinseEntity.Module} has no wafer shuttle";
- return false;
- }
- if (_rinseEntity.WaferHolderInfo.Id != materialId)
- {
- reason = $"{_rinseEntity.Module} wafer shuttle {_rinseEntity.WaferHolderInfo.Id} is not matched with {materialId}";
- return false;
- }
- return true;
- }
- }
- }
|