From 393f814c52ae643877a451944a95b4df4eafacf2 Mon Sep 17 00:00:00 2001 From: James Wainwright Date: Tue, 7 May 2024 14:05:04 +0100 Subject: [PATCH] [sival,alert] Enable lpg_sleep_mode_pings test in more envs * FPGA support is extended to the CW340. * DV timings are corrected to match the DV. * Silicon support is added. * Unknown environments are now handled explicitly. Signed-off-by: James Wainwright (commit is original to earlgrey_1.0.0) --- sw/device/tests/BUILD | 1 + .../alert_handler_lpg_sleep_mode_pings.c | 47 ++++++++++++------- 2 files changed, 31 insertions(+), 17 deletions(-) diff --git a/sw/device/tests/BUILD b/sw/device/tests/BUILD index 348d44c943a10..188ec3312de3b 100644 --- a/sw/device/tests/BUILD +++ b/sw/device/tests/BUILD @@ -506,6 +506,7 @@ opentitan_test( # See #23038, this test requires a provisioned flash in sival. "//hw/top_earlgrey:fpga_cw310_sival_rom_ext": "broken", }, + EARLGREY_SILICON_OWNER_ROM_EXT_ENVS, ), fpga = fpga_params( timeout = "moderate", diff --git a/sw/device/tests/alert_handler_lpg_sleep_mode_pings.c b/sw/device/tests/alert_handler_lpg_sleep_mode_pings.c index 616f1d253d6f9..7a933df38b02c 100644 --- a/sw/device/tests/alert_handler_lpg_sleep_mode_pings.c +++ b/sw/device/tests/alert_handler_lpg_sleep_mode_pings.c @@ -80,23 +80,36 @@ static void init_peripherals(void) { */ void wait_enough_for_alert_ping(void) { // wait enough - if (kDeviceType == kDeviceFpgaCw310) { - // 2*margin_of_safety*(2**DW)*(1/kClockFreqPeripheralHz) - // 2*4*(2**16)*(400ns) = 0.2s - busy_spin_micros(1000 * 200); - } else if (kDeviceType == kDeviceSimDV) { - // NUM_ALERTS*2*margin_of_safety*(2**DW)*(1/kClockFreqPeripheralHz) - // 2*4*(2**3)*(40ns) = 3us - busy_spin_micros(3); - } else { - // Verilator - // 2*margin_of_safety*(2**DW)*(1/kClockFreqPeripheralHz) - // 2*4*(2**16)*(8us) = 4s - // This seems to be impractical for the current clock frequency config - // of the Verilator tests (kClockFreqPeripheralHz = 125K). - LOG_FATAL("SUPPORTED PLATFORMS: DV and FPGA"); - LOG_FATAL("TO SUPPORT THE PLATFORM %d, COMPUTE THE RIGHT WAIT-TIME", - kDeviceType); + switch (kDeviceType) { + case kDeviceFpgaCw310: + case kDeviceFpgaCw340: + // 2*margin_of_safety*(2**DW)*(1/kClockFreqPeripheralHz) + // 2*4*(2**16)*(400ns) = 0.2s + busy_spin_micros(1000 * 200); + break; + case kDeviceSilicon: + // 2*margin_of_safety*(2**DW)*(1/kClockFreqPeripheralHz) + // 2*4*(2**16)*(42ns) = 22ms + busy_spin_micros(1000 * 22); + break; + case kDeviceSimDV: + // NUM_ALERTS*2*margin_of_safety*(2**DW)*(1/kClockFreqPeripheralHz) + // 2*4*(2**16)*(42ns) = 22ms + busy_spin_micros(1000 * 22); + break; + case kDeviceSimVerilator: + // Verilator + // 2*margin_of_safety*(2**DW)*(1/kClockFreqPeripheralHz) + // 2*4*(2**16)*(8us) = 4s + // This seems to be impractical for the current clock frequency config + // of the Verilator tests (kClockFreqPeripheralHz = 125K). + OT_FALLTHROUGH_INTENDED; + default: + LOG_FATAL("SUPPORTED PLATFORMS: DV and FPGA"); + LOG_FATAL("TO SUPPORT THE PLATFORM %d, COMPUTE THE RIGHT WAIT-TIME", + kDeviceType); + test_status_set(kTestStatusFailed); + abort(); } }