2020-12-29 11:29:03 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
2022-05-23 11:24:55 +02:00
|
|
|
"""ACU commands
|
|
|
|
@author J. Meier, R. Mueller
|
2020-12-29 11:29:03 +01:00
|
|
|
@date 21.12.2020
|
|
|
|
"""
|
2022-06-10 11:02:08 +02:00
|
|
|
import struct
|
|
|
|
|
2022-05-23 11:24:55 +02:00
|
|
|
from config.definitions import CustomServiceList
|
2022-08-12 10:18:21 +02:00
|
|
|
from tmtccmd.config import TmtcDefinitionWrapper, OpCodeEntry
|
|
|
|
from tmtccmd.config.tmtc import tmtc_definitions_provider
|
2022-07-04 15:22:53 +02:00
|
|
|
|
2022-08-08 16:32:18 +02:00
|
|
|
from tmtccmd.tc import DefaultPusQueueHelper
|
2022-05-23 11:25:33 +02:00
|
|
|
from tmtccmd.tc.pus_3_fsfw_hk import (
|
|
|
|
make_sid,
|
|
|
|
generate_one_diag_command,
|
|
|
|
generate_one_hk_command,
|
|
|
|
)
|
2022-05-23 11:24:55 +02:00
|
|
|
import gomspace.gomspace_common as gs
|
|
|
|
from gomspace.gomspace_common import GomspaceOpCodes
|
2022-08-11 18:10:15 +02:00
|
|
|
from gomspace.gomspace_common import GsInfo as GsInfo
|
2022-05-23 11:24:55 +02:00
|
|
|
from config.object_ids import ACU_HANDLER_ID
|
2022-03-04 11:02:10 +01:00
|
|
|
from pus_tc.devs.p60dock import P60DockConfigTable
|
2022-08-24 11:24:25 +02:00
|
|
|
from tmtccmd.tc.pus_8_funccmd import make_fsfw_action_cmd
|
2022-07-08 16:25:46 +02:00
|
|
|
from tmtccmd.util import ObjectIdU32
|
2022-05-23 11:24:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
class ACUConfigTable:
|
|
|
|
mppt_mode = gs.TableEntry(bytearray([0x00, 0x00]), gs.TableEntry.uint8_size)
|
|
|
|
mppt_d_mode = gs.TableEntry(bytearray([0x00, 0x01]), gs.TableEntry.uint8_size)
|
|
|
|
vboost = gs.TableEntry(bytearray([0x00, 0x02]), gs.TableEntry.uint16_size)
|
|
|
|
vbat_max_hi = gs.TableEntry(bytearray([0x00, 0x10]), gs.TableEntry.uint16_size)
|
|
|
|
vbat_max_lo = gs.TableEntry(bytearray([0x00, 0x12]), gs.TableEntry.uint16_size)
|
|
|
|
ov_mode = gs.TableEntry(bytearray([0x00, 0x1A]), gs.TableEntry.uint8_size)
|
|
|
|
|
|
|
|
|
|
|
|
class ACUHkTable:
|
|
|
|
temperature1 = gs.TableEntry(bytearray([0x00, 0x1C]), gs.TableEntry.uint16_size)
|
|
|
|
temperature2 = gs.TableEntry(bytearray([0x00, 0x1D]), gs.TableEntry.uint16_size)
|
|
|
|
temperature3 = gs.TableEntry(bytearray([0x00, 0x1E]), gs.TableEntry.uint16_size)
|
|
|
|
# Ground WDT value (remaining seconds until reboot)
|
|
|
|
wdt_gnd_left = gs.TableEntry(bytearray([0x00, 0x74]), gs.TableEntry.uint32_size)
|
|
|
|
|
|
|
|
|
|
|
|
class OpCodes:
|
|
|
|
TEST = ["0", "test"]
|
|
|
|
|
|
|
|
|
|
|
|
class Info:
|
|
|
|
TEST = "ACU Test"
|
|
|
|
|
|
|
|
|
2022-08-12 10:18:21 +02:00
|
|
|
@tmtc_definitions_provider
|
|
|
|
def add_acu_cmds(defs: TmtcDefinitionWrapper):
|
2022-07-05 02:12:54 +02:00
|
|
|
oce = OpCodeEntry()
|
|
|
|
oce.add(
|
2022-05-23 11:24:55 +02:00
|
|
|
keys=GomspaceOpCodes.REQUEST_CORE_HK_ONCE,
|
2022-05-23 11:25:33 +02:00
|
|
|
info=GsInfo.REQUEST_CORE_HK_ONCE,
|
2022-05-23 11:24:55 +02:00
|
|
|
)
|
2022-07-05 02:12:54 +02:00
|
|
|
oce.add(
|
2022-05-23 11:24:55 +02:00
|
|
|
keys=GomspaceOpCodes.REQUEST_AUX_HK_ONCE,
|
2022-05-23 11:25:33 +02:00
|
|
|
info=GsInfo.REQUEST_AUX_HK_ONCE,
|
2022-05-23 11:24:55 +02:00
|
|
|
)
|
2022-07-05 02:12:54 +02:00
|
|
|
oce.add(
|
2022-05-23 11:24:55 +02:00
|
|
|
keys=GomspaceOpCodes.REQUEST_AUX_HK_ONCE,
|
2022-05-23 11:25:33 +02:00
|
|
|
info=GsInfo.REQUEST_AUX_HK_ONCE,
|
2022-05-23 11:24:55 +02:00
|
|
|
)
|
2022-07-05 02:12:54 +02:00
|
|
|
oce.add(
|
2022-06-10 11:02:08 +02:00
|
|
|
keys=GomspaceOpCodes.GET_PARAM,
|
|
|
|
info=GsInfo.GET_PARAMETER,
|
|
|
|
)
|
2022-07-05 02:12:54 +02:00
|
|
|
oce.add(
|
2022-06-10 11:02:08 +02:00
|
|
|
keys=GomspaceOpCodes.SET_PARAM,
|
|
|
|
info=GsInfo.SET_PARAMETER,
|
|
|
|
)
|
2022-07-05 02:12:54 +02:00
|
|
|
oce.add(keys=OpCodes.TEST, info=Info.TEST)
|
|
|
|
defs.add_service(
|
2022-05-23 11:24:55 +02:00
|
|
|
name=CustomServiceList.ACU.value,
|
2022-05-23 11:25:33 +02:00
|
|
|
info="ACU Device",
|
2022-07-05 02:12:54 +02:00
|
|
|
op_code_entry=oce,
|
2022-05-23 11:24:55 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2022-08-08 16:32:18 +02:00
|
|
|
def pack_acu_commands(object_id: ObjectIdU32, q: DefaultPusQueueHelper, op_code: str):
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("Handling ACU command")
|
2022-05-23 11:24:55 +02:00
|
|
|
if op_code in GomspaceOpCodes.PRINT_SWITCH_V_I:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Print channel stats")
|
|
|
|
q.add_pus_tc(
|
2022-08-24 11:24:25 +02:00
|
|
|
make_fsfw_action_cmd(
|
2022-07-04 15:22:53 +02:00
|
|
|
object_id=object_id.as_bytes,
|
|
|
|
action_id=gs.GomspaceDeviceActionIds.PRINT_SWITCH_V_I,
|
|
|
|
)
|
2022-05-23 11:24:55 +02:00
|
|
|
)
|
|
|
|
if op_code in GomspaceOpCodes.REQUEST_CORE_HK_ONCE:
|
2022-08-24 11:19:49 +02:00
|
|
|
q.add_log_cmd(f"ACU: {GsInfo.REQUEST_CORE_HK_ONCE}")
|
2022-05-23 11:24:55 +02:00
|
|
|
hk_sid = make_sid(object_id=object_id.as_bytes, set_id=gs.SetIds.ACU_CORE)
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_pus_tc(generate_one_diag_command(sid=hk_sid))
|
2022-05-23 11:24:55 +02:00
|
|
|
if op_code in GomspaceOpCodes.REQUEST_AUX_HK_ONCE:
|
2022-08-24 11:19:49 +02:00
|
|
|
q.add_log_cmd(f"ACU: {GsInfo.REQUEST_AUX_HK_ONCE}")
|
2022-05-23 11:24:55 +02:00
|
|
|
hk_sid = make_sid(object_id=object_id.as_bytes, set_id=gs.SetIds.ACU_AUX)
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_pus_tc(generate_one_hk_command(sid=hk_sid))
|
2022-06-10 11:02:08 +02:00
|
|
|
if op_code in GomspaceOpCodes.GET_PARAM:
|
2022-08-24 11:19:49 +02:00
|
|
|
q.add_log_cmd(f"ACU: {GsInfo.GET_PARAMETER}")
|
|
|
|
gs.prompt_and_pack_get_param_command(q, object_id)
|
2022-07-04 15:22:53 +02:00
|
|
|
if op_code in GomspaceOpCodes.SET_PARAM:
|
2022-08-24 11:19:49 +02:00
|
|
|
q.add_log_cmd(f"ACU: {GsInfo.SET_PARAMETER}")
|
|
|
|
gs.prompt_and_pack_set_param_command(q, object_id)
|
2022-07-04 15:22:53 +02:00
|
|
|
pack_test_cmds(object_id=object_id, q=q)
|
2022-05-23 11:24:55 +02:00
|
|
|
|
2020-12-29 11:29:03 +01:00
|
|
|
|
|
|
|
class ACUTestProcedure:
|
|
|
|
"""
|
|
|
|
@brief Use this class to define the tests to perform for the ACU.
|
|
|
|
@details Setting all to True will run all tests.
|
|
|
|
Setting all to False will only run the tests set to True.
|
|
|
|
"""
|
2022-01-18 14:03:56 +01:00
|
|
|
|
2020-12-29 11:29:03 +01:00
|
|
|
all = False
|
|
|
|
reboot = False
|
|
|
|
read_gnd_wdt = False
|
|
|
|
gnd_wdt_reset = False
|
|
|
|
ping = False
|
|
|
|
read_temperature1 = False
|
|
|
|
read_temperature2 = False
|
2022-05-23 11:24:55 +02:00
|
|
|
read_temperature3 = False
|
|
|
|
read_mppt_mode = False
|
|
|
|
read_vboost = False
|
|
|
|
read_vbat_max_hi = False
|
|
|
|
read_vbat_max_lo = False
|
|
|
|
read_ov_mode = False
|
|
|
|
off = False
|
2020-12-29 11:29:03 +01:00
|
|
|
|
|
|
|
|
2022-08-08 16:32:18 +02:00
|
|
|
def pack_test_cmds(object_id: ObjectIdU32, q: DefaultPusQueueHelper):
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.reboot:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Reboot")
|
|
|
|
q.add_pus_tc(gs.pack_reboot_command(object_id))
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.read_gnd_wdt:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Reading ground watchdog timer value")
|
|
|
|
q.add_pus_tc(
|
|
|
|
gs.pack_get_param_command(
|
|
|
|
object_id.as_bytes,
|
|
|
|
gs.TableIds.hk,
|
|
|
|
ACUHkTable.wdt_gnd_left.parameter_address,
|
|
|
|
ACUHkTable.wdt_gnd_left.parameter_size,
|
|
|
|
)
|
2021-08-03 15:28:28 +02:00
|
|
|
)
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.gnd_wdt_reset:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Testing ground watchdog reset")
|
|
|
|
q.add_pus_tc(gs.pack_gnd_wdt_reset_command(object_id))
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.ping:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Ping Test")
|
2020-12-29 11:29:03 +01:00
|
|
|
ping_data = bytearray([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_pus_tc(gs.pack_ping_command(object_id, ping_data))
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.read_temperature3:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Reading temperature 3")
|
|
|
|
q.add_pus_tc(
|
|
|
|
gs.pack_get_param_command(
|
|
|
|
object_id.as_bytes,
|
|
|
|
gs.TableIds.hk,
|
|
|
|
ACUHkTable.temperature3.parameter_address,
|
|
|
|
ACUHkTable.temperature3.parameter_size,
|
|
|
|
)
|
2022-01-18 14:03:56 +01:00
|
|
|
)
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.read_vboost:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Reading vboost value")
|
|
|
|
q.add_pus_tc(
|
|
|
|
gs.pack_get_param_command(
|
|
|
|
object_id.as_bytes,
|
|
|
|
gs.TableIds.config,
|
|
|
|
ACUConfigTable.vboost.parameter_address,
|
|
|
|
ACUConfigTable.vboost.parameter_size,
|
|
|
|
)
|
2022-01-18 14:03:56 +01:00
|
|
|
)
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.read_vbat_max_hi:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Reading vbat_max_hi")
|
|
|
|
q.add_pus_tc(
|
|
|
|
gs.pack_get_param_command(
|
|
|
|
object_id.as_bytes,
|
|
|
|
gs.TableIds.config,
|
|
|
|
ACUConfigTable.vbat_max_hi.parameter_address,
|
|
|
|
ACUConfigTable.vbat_max_hi.parameter_size,
|
|
|
|
)
|
2022-01-18 14:03:56 +01:00
|
|
|
)
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.read_vbat_max_lo:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Reading vbat_max_lo")
|
|
|
|
q.add_pus_tc(
|
|
|
|
gs.pack_get_param_command(
|
|
|
|
object_id.as_bytes,
|
|
|
|
gs.TableIds.config,
|
|
|
|
ACUConfigTable.vbat_max_lo.parameter_address,
|
|
|
|
ACUConfigTable.vbat_max_lo.parameter_size,
|
|
|
|
)
|
2022-01-18 14:03:56 +01:00
|
|
|
)
|
2020-12-29 11:29:03 +01:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.read_ov_mode:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("ACU: Reading ov_mode")
|
|
|
|
q.add_pus_tc(
|
|
|
|
gs.pack_get_param_command(
|
|
|
|
object_id.as_bytes,
|
|
|
|
gs.TableIds.config,
|
|
|
|
ACUConfigTable.ov_mode.parameter_address,
|
|
|
|
ACUConfigTable.ov_mode.parameter_size,
|
|
|
|
)
|
2022-01-18 14:03:56 +01:00
|
|
|
)
|
2022-05-23 11:24:55 +02:00
|
|
|
if ACUTestProcedure.all or ACUTestProcedure.off:
|
2022-07-04 15:22:53 +02:00
|
|
|
q.add_log_cmd("P60 Dock: Turning off ACU")
|
|
|
|
q.add_pus_tc(
|
|
|
|
gs.pack_set_param_command(
|
|
|
|
ACU_HANDLER_ID,
|
|
|
|
P60DockConfigTable.out_en_0.parameter_address,
|
|
|
|
P60DockConfigTable.out_en_0.parameter_size,
|
|
|
|
gs.Channel.off,
|
|
|
|
)
|
2022-05-23 11:24:55 +02:00
|
|
|
)
|