Skip to main content

RTOR — Retentive Timer

Structured Text retentive timer function block. Uses FBD_TIMER; the ST equivalent of ladder RTO.

Operands

NameType
timerFBD_TIMER

FBD_TIMER Tag Members

MemberTypeMeaning
.EnableInBOOL1 lets the instruction run; 0 holds all outputs unchanged. Normally 1.
.TimerEnableBOOL1 runs the timer and advances ACC; 0 stops timing
.PREDINTPreset target time in milliseconds
.ResetBOOL1 clears EN, TT, DN and sets ACC to 0
.EnableOutBOOL1 while the instruction is executing normally
.ACCDINTAccumulated time in milliseconds
.ENBOOL1 while TimerEnable is 1 and Reset is 0
.TTBOOL1 while the timer is actively counting toward PRE
.DNBOOLDone status — each timer (TONR, TOFR, RTOR) decides when this turns on
.StatusDINTPacked status word — combines InstructFault and PresetInv bits
.InstructFaultBOOL1 when the instruction hit an execution error
.PresetInvBOOL1 when PRE is outside its valid range

How It Works

RTOR is the Structured Text function-block equivalent of the ladder RTO instruction. It operates on an FBD_TIMER tag.

Like TONR, but .ACC retains its value when TimerEnable drops to 0. Timing resumes where it left off. Clear the accumulator by setting .Reset to 1.

Example

RunHours.TimerEnable := MachineRunning;
RunHours.Reset := ResetMaint;
RunHours.PRE := 28800000;
RTOR(RunHours);

MaintAlert := RunHours.DN;

Common Mistakes

  • Setting .EnableIn := 0 to pause the timer. EnableIn = 0 freezes all outputs — .ACC, .EN, .TT, .DN — without advancing them. To stop timing, drop .TimerEnable to 0 instead and leave .EnableIn at 1.
  • RTO — the ladder-logic equivalent
  • TONR, TOFR — other ST timer function blocks