From a50d313be77ab5e50a8cc22d78f603db7a9b2853 Mon Sep 17 00:00:00 2001 From: Ana Clara Oliveira Date: Thu, 31 Oct 2024 12:14:01 -0300 Subject: [PATCH 1/4] injctrl.ENH: add protection to open topup loop when the beam is dumped --- siriuspy/siriuspy/injctrl/main.py | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/siriuspy/siriuspy/injctrl/main.py b/siriuspy/siriuspy/injctrl/main.py index 641714470..d553efc94 100644 --- a/siriuspy/siriuspy/injctrl/main.py +++ b/siriuspy/siriuspy/injctrl/main.py @@ -192,6 +192,9 @@ def __init__(self): curr_pvo = self.currinfo_dev.pv_object('Current-Mon') curr_pvo.add_callback(self._callback_autostop) curr_pvo.connection_callbacks.append(self._callback_conn_autostop) + self.currinfo_dev.set_auto_monitor('StoredEBeam-Mon', True) + stored_pvo = self.currinfo_dev.pv_object('StoredEBeam-Mon') + stored_pvo.add_callback(self._callback_havebeam) self._pu_names, self._pu_devs = list(), list() self._pu_refvolt = list() @@ -1174,6 +1177,16 @@ def _thread_is_injecting(self): _time.sleep(self._isinj_duration/1000) self.run_callbacks('IsInjecting-Mon', _Const.IdleInjecting.Idle) + def _callback_havebeam(self, value, **kws): + if value: + return + if self._mode != _Const.InjMode.TopUp: + return + if self._topup_state_sts != _Const.TopUpSts.Off: + self._update_log('FATAL:We do not have stored beam!') + self._update_log('FATAL:Opening TopUp loop...') + self.set_topup_state(_Const.OffOn.Off) + # --- auxiliary injection methods --- def _check_allok_2_inject(self, show_warn=True): From 03c313ddf5d82d901de0cbfafa8adca82fbfc465 Mon Sep 17 00:00:00 2001 From: Ana Clara Oliveira Date: Thu, 31 Oct 2024 12:52:44 -0300 Subject: [PATCH 2/4] Update version to 2.92.0 --- siriuspy/siriuspy/VERSION | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/siriuspy/siriuspy/VERSION b/siriuspy/siriuspy/VERSION index 22f0bcedd..616b45fd9 100644 --- a/siriuspy/siriuspy/VERSION +++ b/siriuspy/siriuspy/VERSION @@ -1 +1 @@ -2.91.0 +2.92.0 From fadea88aaff1bd1a0dbff4526dc33c2430d31f53 Mon Sep 17 00:00:00 2001 From: Ana Clara Oliveira Date: Fri, 1 Nov 2024 16:35:02 -0300 Subject: [PATCH 3/4] DEV.RF: update RFKillBeam device to send manual interlock to RF cavities --- siriuspy/siriuspy/devices/rf.py | 48 +++++++++------------------------ 1 file changed, 12 insertions(+), 36 deletions(-) diff --git a/siriuspy/siriuspy/devices/rf.py b/siriuspy/siriuspy/devices/rf.py index 529f1c484..d5a009f03 100644 --- a/siriuspy/siriuspy/devices/rf.py +++ b/siriuspy/siriuspy/devices/rf.py @@ -1335,53 +1335,29 @@ def set_frequency(self, value, timeout=10, tol=0.05): return self.dev_rfgen.set_frequency(value, tol=tol, timeout=timeout) -class RFKillBeam(_SILLRF): +class RFKillBeam(_DeviceSet): """RF Kill Beam Button.""" - TIMEOUT_WAIT = 20.0 # [s] - INCRATE_VALUE = ASLLRF.VoltIncRates.vel_50p0 # [mV/s] - REFMIN_VALUE = 60 # Minimum Amplitude Reference [mV] + TIMEOUT_WAIT = 10 # [s] def __init__(self): """Init.""" - super().__init__(ASLLRF.DEVICES.SIA) + props2init = ASLLRF.PROPERTIES_INTERLOCK + si_a = ASLLRF(devname=ASLLRF.DEVICES.SIA, props2init=props2init) + si_b = ASLLRF(devname=ASLLRF.DEVICES.SIB, props2init=props2init) + devs = [si_a, si_b] + super().__init__(devices=devs, devname='SI-Glob:RF-KillBeam') def cmd_kill_beam(self): """Kill beam.""" if not self.wait_for_connection(self.TIMEOUT_WAIT): return [False, 'Could not read RF PVs.'] - # get initial values - amp_incrate_init = self.voltage_incrate - amp_init = self.voltage - - # set Amplitude Increase Rate to 50 mV/s and wait - self.voltage_incrate = self.INCRATE_VALUE - if not self._wait( - 'AmpIncRate-RB', self.INCRATE_VALUE, - timeout=self.TIMEOUT_WAIT): - return [False, 'Could not set RF Amplitude Increase Rate.'] - - # set Amplitude Reference to 60mV and wait - self.voltage = self.REFMIN_VALUE - if not self._wait_float( - 'SLInpAmp-Mon', self.REFMIN_VALUE, abs_tol=1, - timeout=self.TIMEOUT_WAIT): - return [False, 'Could not set RF Voltage to low value.'] - - # set Amplitude Reference to initial value - self.voltage = amp_init - if not self._wait_float( - 'SLInpAmp-Mon', amp_init, - abs_tol=1, timeout=self.TIMEOUT_WAIT): - return [False, 'Could not set RF Voltage back to original value.'] - - # set Amplitude Increase Rate to initial value - self.voltage_incrate = amp_incrate_init - if not self._wait( - 'AmpIncRate-RB', self.INCRATE_VALUE, - timeout=self.TIMEOUT_WAIT): - return [False, 'Could not set RF Amplitude Increase Rate back.'] + for llrf in self.devices: + llrf.interlock_manual = 1 + _time.sleep(1) + for llrf in self.devices: + llrf.interlock_manual = 0 return [True, ''] From b3371ea7bb0ce99ca442eabf9d39a6cdf6f8777f Mon Sep 17 00:00:00 2001 From: Ana Clara Oliveira Date: Fri, 1 Nov 2024 16:42:30 -0300 Subject: [PATCH 4/4] injctrl.ENH: move turn off topup task in beam dump event to a separate thread --- siriuspy/siriuspy/injctrl/main.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/siriuspy/siriuspy/injctrl/main.py b/siriuspy/siriuspy/injctrl/main.py index d553efc94..04619bca8 100644 --- a/siriuspy/siriuspy/injctrl/main.py +++ b/siriuspy/siriuspy/injctrl/main.py @@ -88,6 +88,7 @@ def __init__(self): self._topup_nrpulses = 1 self._topup_job = None self._accum_job = None + self._stop_topup_job = None self._abort = False self._setting_mode = False @@ -1182,10 +1183,15 @@ def _callback_havebeam(self, value, **kws): return if self._mode != _Const.InjMode.TopUp: return + if self._stop_topup_job is not None and \ + self._stop_topup_job.is_alive(): + return if self._topup_state_sts != _Const.TopUpSts.Off: self._update_log('FATAL:We do not have stored beam!') self._update_log('FATAL:Opening TopUp loop...') - self.set_topup_state(_Const.OffOn.Off) + self._stop_topup_job = _epics.ca.CAThread( + target=self.set_topup_state, args=[_Const.OffOn.Off, ], daemon=True) + self._stop_topup_job.start() # --- auxiliary injection methods ---