From c24766a4db1a221d7023bd02ad7ca4e44cce13fe Mon Sep 17 00:00:00 2001 From: Mikayla Date: Tue, 19 Sep 2023 20:37:15 +0000 Subject: [PATCH] #329 disable reactor rather than trip on auto control stop --- reactor-plc/plc.lua | 34 +++++++++++++++++----------------- reactor-plc/startup.lua | 2 +- scada-common/comms.lua | 33 +++++++++++++-------------------- supervisor/facility.lua | 2 +- supervisor/session/plc.lua | 21 +++++++++++++++++++-- supervisor/startup.lua | 2 +- supervisor/unit.lua | 7 +++++++ 7 files changed, 59 insertions(+), 42 deletions(-) diff --git a/reactor-plc/plc.lua b/reactor-plc/plc.lua index bbb59ff..a418745 100644 --- a/reactor-plc/plc.lua +++ b/reactor-plc/plc.lua @@ -238,8 +238,9 @@ function plc.rps_init(reactor, is_formed, emer_cool) self.state[state_keys.sys_fail] = true end - -- SCRAM the reactor now (blocks waiting for server tick) + -- SCRAM the reactor now
---@return boolean success + --- EVENT_CONSUMER: this function consumes events function public.scram() log.info("RPS: reactor SCRAM") @@ -254,8 +255,9 @@ function plc.rps_init(reactor, is_formed, emer_cool) end end - -- start the reactor now (blocks waiting for server tick) + -- start the reactor now
---@return boolean success + --- EVENT_CONSUMER: this function consumes events function public.activate() if not self.tripped then log.info("RPS: reactor start") @@ -612,10 +614,7 @@ function plc.comms(id, version, nic, plc_channel, svr_channel, range, reactor, r -- send structure properties (these should not change, server will cache these) local function _send_struct() - local min_pos = { x = 0, y = 0, z = 0 } - local max_pos = { x = 0, y = 0, z = 0 } - - local mek_data = { false, 0, 0, 0, min_pos, max_pos, 0, 0, 0, 0, 0, 0, 0, 0 } + local mek_data = { false, 0, 0, 0, types.new_zero_coordinate(), types.new_zero_coordinate(), 0, 0, 0, 0, 0, 0, 0, 0 } local tasks = { function () mek_data[1] = reactor.getLength() end, @@ -685,21 +684,18 @@ function plc.comms(id, version, nic, plc_channel, svr_channel, range, reactor, r local heating_rate = 0.0 ---@type number if (not no_reactor) and rps.is_formed() then - if _update_status_cache() then - mek_data = self.status_cache - end - + if _update_status_cache() then mek_data = self.status_cache end heating_rate = reactor.getHeatingRate() end local sys_status = { - util.time(), -- timestamp - (not self.scrammed), -- requested control state - no_reactor, -- no reactor peripheral connected - formed, -- reactor formed - self.auto_ack_token, -- token to indicate auto command has been received before this status update - heating_rate, -- heating rate - mek_data -- mekanism status data + util.time(), -- timestamp + (not self.scrammed), -- requested control state + no_reactor, -- no reactor peripheral connected + formed, -- reactor formed + self.auto_ack_token, -- indicate auto command received prior to this status update + heating_rate, -- heating rate + mek_data -- mekanism status data } _send(RPLC_TYPE.STATUS, sys_status) @@ -837,6 +833,10 @@ function plc.comms(id, version, nic, plc_channel, svr_channel, range, reactor, r -- enable the reactor self.scrammed = false _send_ack(packet.type, rps.activate()) + elseif packet.type == RPLC_TYPE.RPS_DISABLE then + -- disable the reactor, but do not trip + self.scrammed = true + _send_ack(packet.type, rps.scram()) elseif packet.type == RPLC_TYPE.RPS_SCRAM then -- disable the reactor per manual request self.scrammed = true diff --git a/reactor-plc/startup.lua b/reactor-plc/startup.lua index ac20379..e008280 100644 --- a/reactor-plc/startup.lua +++ b/reactor-plc/startup.lua @@ -19,7 +19,7 @@ local plc = require("reactor-plc.plc") local renderer = require("reactor-plc.renderer") local threads = require("reactor-plc.threads") -local R_PLC_VERSION = "v1.5.8" +local R_PLC_VERSION = "v1.5.9" local println = util.println local println_ts = util.println_ts diff --git a/scada-common/comms.lua b/scada-common/comms.lua index 081950e..4bf8262 100644 --- a/scada-common/comms.lua +++ b/scada-common/comms.lua @@ -17,7 +17,7 @@ local max_distance = nil local comms = {} -- protocol version (non-protocol changes tracked by util.lua version) -comms.version = "2.3.0" +comms.version = "2.4.0" ---@enum PROTOCOL local PROTOCOL = { @@ -33,13 +33,14 @@ local RPLC_TYPE = { MEK_STRUCT = 1, -- mekanism build structure MEK_BURN_RATE = 2, -- set burn rate RPS_ENABLE = 3, -- enable reactor - RPS_SCRAM = 4, -- SCRAM reactor (manual request) - RPS_ASCRAM = 5, -- SCRAM reactor (automatic request) - RPS_STATUS = 6, -- RPS status - RPS_ALARM = 7, -- RPS alarm broadcast - RPS_RESET = 8, -- clear RPS trip (if in bad state, will trip immediately) - RPS_AUTO_RESET = 9, -- clear RPS trip if it is just a timeout or auto scram - AUTO_BURN_RATE = 10 -- set an automatic burn rate, PLC will respond with status, enable toggle speed limited + RPS_DISABLE = 4, -- disable the reactor + RPS_SCRAM = 5, -- SCRAM reactor (manual request) + RPS_ASCRAM = 6, -- SCRAM reactor (automatic request) + RPS_STATUS = 7, -- RPS status + RPS_ALARM = 8, -- RPS alarm broadcast + RPS_RESET = 9, -- clear RPS trip (if in bad state, will trip immediately) + RPS_AUTO_RESET = 10, -- clear RPS trip if it is just a timeout or auto scram + AUTO_BURN_RATE = 11 -- set an automatic burn rate, PLC will respond with status, enable toggle speed limited } ---@enum MGMT_TYPE @@ -396,9 +397,7 @@ function comms.modbus_packet() -- populate raw array self.raw = { self.txn_id, self.unit_id, self.func_code } - for i = 1, self.length do - insert(self.raw, data[i]) - end + for i = 1, self.length do insert(self.raw, data[i]) end else log.error("comms.modbus_packet.make(): data not table") end @@ -484,9 +483,7 @@ function comms.rplc_packet() -- populate raw array self.raw = { self.id, self.type } - for i = 1, #data do - insert(self.raw, data[i]) - end + for i = 1, #data do insert(self.raw, data[i]) end else log.error("comms.rplc_packet.make(): data not table") end @@ -568,9 +565,7 @@ function comms.mgmt_packet() -- populate raw array self.raw = { self.type } - for i = 1, #data do - insert(self.raw, data[i]) - end + for i = 1, #data do insert(self.raw, data[i]) end else log.error("comms.mgmt_packet.make(): data not table") end @@ -649,9 +644,7 @@ function comms.crdn_packet() -- populate raw array self.raw = { self.type } - for i = 1, #data do - insert(self.raw, data[i]) - end + for i = 1, #data do insert(self.raw, data[i]) end else log.error("comms.crdn_packet.make(): data not table") end diff --git a/supervisor/facility.lua b/supervisor/facility.lua index 8c91157..ee5f44d 100644 --- a/supervisor/facility.lua +++ b/supervisor/facility.lua @@ -402,7 +402,7 @@ function facility.new(num_reactors, cooling_conf) -- SCRAM reactors and disengage auto control -- use manual SCRAM since inactive was requested, and automatic SCRAM trips an alarm for _, u in pairs(self.prio_defs[i]) do - u.scram() + u.disable() u.auto_disengage() end end diff --git a/supervisor/session/plc.lua b/supervisor/session/plc.lua index 654ca99..23fb1c6 100644 --- a/supervisor/session/plc.lua +++ b/supervisor/session/plc.lua @@ -25,8 +25,9 @@ local PLC_S_CMDS = { SCRAM = 1, ASCRAM = 2, ENABLE = 3, - RPS_RESET = 4, - RPS_AUTO_RESET = 5 + DISABLE = 4, + RPS_RESET = 5, + RPS_AUTO_RESET = 6 } local PLC_S_DATA = { @@ -80,6 +81,7 @@ function plc.new_session(id, s_addr, reactor_id, in_queue, out_queue, timeout, f retry_times = { struct_req = (util.time() + 500), status_req = (util.time() + 500), + disable_req = 0, scram_req = 0, ascram_req = 0, burn_rate_req = 0, @@ -87,6 +89,7 @@ function plc.new_session(id, s_addr, reactor_id, in_queue, out_queue, timeout, f }, -- command acknowledgements acks = { + disable = true, scram = true, ascram = true, burn_rate = true, @@ -627,6 +630,11 @@ function plc.new_session(id, s_addr, reactor_id, in_queue, out_queue, timeout, f if not self.auto_lock then _send(RPLC_TYPE.RPS_ENABLE, {}) end + elseif cmd == PLC_S_CMDS.DISABLE then + -- disable the reactor + self.acks.disable = false + self.retry_times.disable_req = util.time() + INITIAL_WAIT + _send(RPLC_TYPE.RPS_DISABLE, {}) elseif cmd == PLC_S_CMDS.SCRAM then -- SCRAM reactor self.acks.scram = false @@ -780,6 +788,15 @@ function plc.new_session(id, s_addr, reactor_id, in_queue, out_queue, timeout, f end end + -- reactor disable request retry + + if not self.acks.disable then + if rtimes.disable_req - util.time() <= 0 then + _send(RPLC_TYPE.RPS_DISABLE, {}) + rtimes.disable_req = util.time() + RETRY_PERIOD + end + end + -- SCRAM request retry if not self.acks.scram then diff --git a/supervisor/startup.lua b/supervisor/startup.lua index a09e058..c668059 100644 --- a/supervisor/startup.lua +++ b/supervisor/startup.lua @@ -21,7 +21,7 @@ local supervisor = require("supervisor.supervisor") local svsessions = require("supervisor.session.svsessions") -local SUPERVISOR_VERSION = "v1.0.4" +local SUPERVISOR_VERSION = "v1.0.5" local println = util.println local println_ts = util.println_ts diff --git a/supervisor/unit.lua b/supervisor/unit.lua index 262de6b..e0fe65e 100644 --- a/supervisor/unit.lua +++ b/supervisor/unit.lua @@ -645,6 +645,13 @@ function unit.new(reactor_id, num_boilers, num_turbines) -- OPERATIONS -- --#region + -- queue a command to disable the reactor + function public.disable() + if self.plc_s ~= nil then + self.plc_s.in_queue.push_command(PLC_S_CMDS.DISABLE) + end + end + -- queue a command to SCRAM the reactor function public.scram() if self.plc_s ~= nil then