Skip to content
Freddie Akeroyd edited this page Dec 11, 2023 · 9 revisions

Wiki > The Backend System > System components > Run Control

Run control is implemented purely in EPICS. A DB file support/RunControl/runcontrol.db can be loaded into any IOC and given the name of each PV that needs this feature. It defines a few PVs for this:

$(PV):RC:LOW
$(PV):RC:HIGH
$(PV):RC:ENABLE
$(PV):RC:INRANGE

When a values is out of range, it will push this information into variables managed by INSTETC which will ultimately pause/resume data collection. Feedback can be obtained via:

$(P):CS:RC:OUT:CNT      number of items out of range
$(P):CS:RC:OUT:LIST     names of PVs out of range (space separated in char waveform)

CA monitors can be posted on either CNT or LIST, CNT is guaranteed to see all transitions, LIST will be up to date but may not see all transitions

(LIST is actually a set which can be added to/removed from via PVs; it is called generically via aSub records so provides a general mechanism for keeping a more readable list of things if we need it).

Run testRunControl from iocBoot for an example. You need to start INSTETC first if you wish to use the above CS variables.

To do run control on SECI blocks a separate IOC ioc/RUNCTRL will be used. This will need to be restarted by the blockserver as appropriate and the blockserver will also need to (re)write a startup file for it containing lines like:

The system is implemented by a set of db files in support/RunControl called gencontrol.db and gencontrolMgr.db. These define logic for calling an action when values go in and out of range, as well as adding case insensitive aliases. In the ioc/RUNCONTROL these are loaded twice to create:

  • :RC: (run control) PVs who allow setting limits and triggering WAITING on out of range
  • :AC: (alert control) PVs who allow setting limits and triggering sending a message on out of range

On LOQ a separate :DC: instance is also created, this calls a procedure to put in the aperture when the detector count rate exceeds a limit

Troubleshooting

If the system gets stuck in a WAITING state with no blocks being outside of runcontrol limits, then you can force a resync of the system with e.g. for OFFSPEC caput IN:OFFSPEC:CS:RC:SYNC:SP 1

Clone this wiki locally