[Skiboot] [PATCH v2 08/11] hw/sbe-p9: Rename timer limits
Nicholas Piggin
npiggin at gmail.com
Tue Jan 14 22:46:49 AEDT 2025
These aren't "defaults", but really minimum advertised accurate timeouts.
Rename them and make them variables to accommodate changes for P10.
Signed-off-by: Nicholas Piggin <npiggin at gmail.com>
---
hw/sbe-p9.c | 22 +++++++++++++---------
1 file changed, 13 insertions(+), 9 deletions(-)
diff --git a/hw/sbe-p9.c b/hw/sbe-p9.c
index a97b972a0..a9c289622 100644
--- a/hw/sbe-p9.c
+++ b/hw/sbe-p9.c
@@ -88,8 +88,10 @@ static struct lock sbe_timer_lock;
* Minimum timeout value for P9 is 500 microseconds. After that
* SBE timer can handle granularity of 1 microsecond.
*/
-#define SBE_TIMER_DEFAULT_US 500
-static uint64_t sbe_timer_def_tb;
+#define SBE_TIMER_MIN_US_P9 500
+
+static uint64_t sbe_timer_min_us;
+static uint64_t sbe_timer_min_tb;
/*
* Rate limit continuous timer update.
@@ -802,7 +804,7 @@ static void p9_sbe_timer_resp(struct p9_sbe_msg *msg)
static void p9_sbe_timer_schedule(void)
{
int rc;
- u32 tick_us = SBE_TIMER_DEFAULT_US;
+ u64 tick_us = sbe_timer_min_us;
u64 tb_cnt, now = mftb();
/* Stop sending timer update chipop until inflight timer expires */
@@ -816,15 +818,15 @@ static void p9_sbe_timer_schedule(void)
if (now >= sbe_last_gen_stamp)
return;
- /* Remaining time of inflight timer <= sbe_timer_def_tb */
- if ((sbe_last_gen_stamp - now) <= sbe_timer_def_tb)
+ /* Remaining time of inflight timer <= sbe_timer_min_tb */
+ if ((sbe_last_gen_stamp - now) <= sbe_timer_min_tb)
return;
}
timer_update_cnt++;
if (timer_update_cnt < SBE_TIMER_UPDATE_MAX && now < sbe_timer_target) {
/* Calculate how many microseconds from now, rounded up */
- if ((sbe_timer_target - now) > sbe_timer_def_tb) {
+ if ((sbe_timer_target - now) > sbe_timer_min_tb) {
tb_cnt = sbe_timer_target - now + usecs_to_tb(1) - 1;
tick_us = tb_to_usecs(tb_cnt);
}
@@ -878,7 +880,7 @@ static bool p9_sbe_test(struct p9_sbe *sbe)
/* Same as timer_ctrl_msg */
msg = p9_sbe_mkmsg(SBE_CMD_CONTROL_TIMER, CONTROL_TIMER_START,
- SBE_TIMER_DEFAULT_US, 0, 0);
+ sbe_timer_min_us, 0, 0);
if (!msg) {
prlog(PR_ERR, "Failed to allocate msg\n");
return false;
@@ -919,7 +921,7 @@ static bool p9_sbe_test(struct p9_sbe *sbe)
ts = now;
timeout = now + msecs_to_tb(SBE_TEST_TIMEOUT_MS) +
- usecs_to_tb(SBE_TIMER_DEFAULT_US);
+ usecs_to_tb(sbe_timer_min_us);
do {
rc = xscom_read(sbe->chip_id, PSU_HOST_DOORBELL_REG_RW, &data);
if (rc) {
@@ -964,7 +966,9 @@ static void p9_sbe_timer_init(void)
sbe_timer_good = true;
sbe_timer_target = ~0ull;
sbe_last_gen_stamp = ~0ull;
- sbe_timer_def_tb = usecs_to_tb(SBE_TIMER_DEFAULT_US);
+ sbe_timer_min_us = SBE_TIMER_MIN_US_P9;
+ sbe_timer_min_tb = usecs_to_tb(sbe_timer_min_us);
+
prlog(PR_INFO, "Timer facility on chip %x\n", sbe_default_chip_id);
}
--
2.45.2
More information about the Skiboot
mailing list