Module Name: src
Committed By: jmcneill
Date: Sat Oct 19 12:34:10 UTC 2024
Modified Files:
src/sys/arch/evbppc/wii: machdep.c
src/sys/arch/powerpc/powerpc: clock.c
Log Message:
Improve delay() accuracy on Nintendo Wii.
The PowerPC delay() implementation converts the timebase frequency to
a number of nanoseconds per tick and uses that value to compute the
delay interval. On the Wii's Broadway processor with a timebase
frequency of 60.75 MHz, some precision is lost as each tick is
approximately 16.46 nanoseconds. The end result is that we sleep for
approximately 2.875% longer than necessary. This also has an impact
on CPU speed calculation on Broadway, which incorrectly reports itself
as 750MHz instead of 729MHz (2.875% faster).
Fix this by introducing an (optional) ticks_per_msec variable that can
be set by the platform and allows delay() to improve the accuracy of
longer delays.
Measured CPU frequency before this change:
[ 1.000000] cpu0: 750.00 MHz, 256KB WB with ECC L2 cache
Measured CPU frequency after this change:
[ 1.000000] cpu0: 729.00 MHz, 256KB WB with ECC L2 cache
To generate a diff of this commit:
cvs rdiff -u -r1.7 -r1.8 src/sys/arch/evbppc/wii/machdep.c
cvs rdiff -u -r1.18 -r1.19 src/sys/arch/powerpc/powerpc/clock.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/evbppc/wii/machdep.c
diff -u src/sys/arch/evbppc/wii/machdep.c:1.7 src/sys/arch/evbppc/wii/machdep.c:1.8
--- src/sys/arch/evbppc/wii/machdep.c:1.7 Sun Oct 13 16:21:37 2024
+++ src/sys/arch/evbppc/wii/machdep.c Sat Oct 19 12:34:10 2024
@@ -1,4 +1,4 @@
-/* $NetBSD: machdep.c,v 1.7 2024/10/13 16:21:37 jmcneill Exp $ */
+/* $NetBSD: machdep.c,v 1.8 2024/10/19 12:34:10 jmcneill Exp $ */
/*
* Copyright (c) 2002, 2024 The NetBSD Foundation, Inc.
@@ -63,7 +63,7 @@
#define _POWERPC_BUS_DMA_PRIVATE
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.7 2024/10/13 16:21:37 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.8 2024/10/19 12:34:10 jmcneill Exp $");
#include "opt_compat_netbsd.h"
#include "opt_ddb.h"
@@ -231,7 +231,8 @@ static void init_decrementer(void);
void
initppc(u_int startkernel, u_int endkernel, u_int args, void *btinfo)
{
- extern u_long ticks_per_sec;
+ extern uint32_t ticks_per_sec;
+ extern uint32_t ticks_per_msec;
extern unsigned char edata[], end[];
extern struct wii_argv wii_argv;
uint32_t mem2_start, mem2_end;
@@ -319,6 +320,7 @@ initppc(u_int startkernel, u_int endkern
* Get CPU clock
*/
ticks_per_sec = TIMEBASE_FREQ_HZ;
+ ticks_per_msec = ticks_per_sec / 1000;
cpu_timebase = ticks_per_sec;
wii_setup();
@@ -441,7 +443,7 @@ init_decrementer(void)
{
extern uint32_t ns_per_tick;
extern uint32_t ticks_per_intr;
- extern u_long ticks_per_sec;
+ extern uint32_t ticks_per_sec;
int scratch, msr;
KASSERT(ticks_per_sec != 0);
Index: src/sys/arch/powerpc/powerpc/clock.c
diff -u src/sys/arch/powerpc/powerpc/clock.c:1.18 src/sys/arch/powerpc/powerpc/clock.c:1.19
--- src/sys/arch/powerpc/powerpc/clock.c:1.18 Sat Jan 20 20:49:11 2024
+++ src/sys/arch/powerpc/powerpc/clock.c Sat Oct 19 12:34:09 2024
@@ -1,4 +1,4 @@
-/* $NetBSD: clock.c,v 1.18 2024/01/20 20:49:11 jmcneill Exp $ */
+/* $NetBSD: clock.c,v 1.19 2024/10/19 12:34:09 jmcneill Exp $ */
/* $OpenBSD: clock.c,v 1.3 1997/10/13 13:42:53 pefo Exp $ */
/*
@@ -33,7 +33,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.18 2024/01/20 20:49:11 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: clock.c,v 1.19 2024/10/19 12:34:09 jmcneill Exp $");
#ifdef _KERNEL_OPT
#include "opt_ppcarch.h"
@@ -67,6 +67,7 @@ static u_int get_601_timecount(struct ti
#endif
uint32_t ticks_per_sec;
+uint32_t ticks_per_msec;
uint32_t ns_per_tick;
uint32_t ticks_per_intr = 0;
@@ -232,6 +233,10 @@ delay(unsigned int n)
#endif /* !_ARCH_PPC64 */
{
tb = mftb();
+ if (ticks_per_msec != 0 && n >= 1000) {
+ tb += (n / 1000ULL) * ticks_per_msec;
+ n = n % 1000;
+ }
tb += (n * 1000ULL + ns_per_tick - 1) / ns_per_tick;
#ifdef _ARCH_PPC64
__asm volatile ("1: mftb %0; cmpld %0,%1; blt 1b;"