summaryrefslogtreecommitdiff
path: root/sys/arch/luna88k
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2004-08-24 12:59:52 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2004-08-24 12:59:52 +0000
commit926402bbfea3baf3e043e75d9bb125259937a8a9 (patch)
treee7f601ec69e20d21b167fa57468e4514b7572953 /sys/arch/luna88k
parent2c3cb02e61134e294bf21d0890c5b78cfc7f66b6 (diff)
Since the cpu frequency can only be an integral number on the Luna88k,
simplify the delay() code, and as a result do not use floating-point code in the kernel anymore. Tested by aoyama@
Diffstat (limited to 'sys/arch/luna88k')
-rw-r--r--sys/arch/luna88k/luna88k/locore.S26
-rw-r--r--sys/arch/luna88k/luna88k/machdep.c19
2 files changed, 16 insertions, 29 deletions
diff --git a/sys/arch/luna88k/luna88k/locore.S b/sys/arch/luna88k/luna88k/locore.S
index be8404e58a2..de7336ed029 100644
--- a/sys/arch/luna88k/luna88k/locore.S
+++ b/sys/arch/luna88k/luna88k/locore.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.S,v 1.5 2004/08/09 20:52:07 miod Exp $ */
+/* $OpenBSD: locore.S,v 1.6 2004/08/24 12:59:51 miod Exp $ */
/*
* Copyright (c) 1998 Steve Murphree, Jr.
* Copyright (c) 1996 Nivas Madhur
@@ -388,27 +388,23 @@ GLOBAL(spin_cpu)
*
* REGISTER USAGE:
* IN r1 - return address
- * IN r2 - (signed int) number of microseconds
- * r3 - (float) number of microseconds
- * r4/5 - (double) number of cycles per microsecond
- * r6 - (float) number of cycles to delay
- * r7 - (signed) number of cycles to delay
+ * IN r2 - number of microseconds
+ * r3 - cpu speed in MHz
+ * r4 - number of cycles to delay
*/
GLOBAL(delay)
- flt.ss r3, r2 /* convert microseconds from signed int to float */
- or.u r4, r0, hi16(_cycles_per_microsecond)
- ld.d r4, r4, lo16(_cycles_per_microsecond)
- fmul.ssd r6, r3, r4 /* convert microseconds to cycles */
- int.ss r7, r6 /* convert cycles from float to signed int */
- subu r7, r7, 25 /* subtract for overhead of above instruction */
+ or.u r3, r0, hi16(_cpuspeed)
+ ld r3, r3, lo16(_cpuspeed)
+ mul r4, r2, r3
+ subu r4, r4, 4 /* overhead of these instructions */
/* now loop for the given number of cycles */
1:
- bcnd.n gt0, r7, 1b
- subu r7, r7, 2 /* two cycles per iteration */
+ bcnd.n gt0, r4, 1b
+ subu r4, r4, 2 /* two cycles per iteration */
- jmp r1 /* return */
+ jmp r1
/*****************************************************************************/
diff --git a/sys/arch/luna88k/luna88k/machdep.c b/sys/arch/luna88k/luna88k/machdep.c
index fb77726cc16..ccb3568dff4 100644
--- a/sys/arch/luna88k/luna88k/machdep.c
+++ b/sys/arch/luna88k/luna88k/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.9 2004/08/18 13:29:46 aoyama Exp $ */
+/* $OpenBSD: machdep.c,v 1.10 2004/08/24 12:59:51 miod Exp $ */
/*
* Copyright (c) 1998, 1999, 2000, 2001 Steve Murphree, Jr.
* Copyright (c) 1996 Nivas Madhur
@@ -228,8 +228,7 @@ int machtype = LUNA_88K; /* may be overwritten in cpu_startup() */
int cputyp = CPU_88100; /* XXX: aoyama */
int boothowto; /* XXX: should be set in boot loader and locore.S */
int bootdev; /* XXX: should be set in boot loader and locore.S */
-int cpuspeed;
-double cycles_per_microsecond; /* used in locore.S:delay() */
+int cpuspeed = 33; /* safe guess */
int sysconsole = 1; /* 0 = ttya, 1 = keyboard/mouse, used in dev/sio.c */
u_int16_t dipswitch = 0; /* set in locore.S */
int hwplanebits; /* set in locore.S */
@@ -355,22 +354,14 @@ size_memory()
int
getcpuspeed()
{
- double clock_mhz;
-
switch(machtype) {
case LUNA_88K:
- clock_mhz = 25.0;
- break;
+ return 25;
case LUNA_88K2:
- clock_mhz = 33.0;
- break;
+ return 33;
default:
panic("getcpuspeed: can not determine CPU speed");
- break;
}
-
- cycles_per_microsecond = clock_mhz;
- return (int)clock_mhz;
}
void
@@ -423,7 +414,7 @@ cpu_startup()
/*
* Initialize error message buffer (at end of core).
- * avail_end was pre-decremented in mvme_bootstrap() to compensate.
+ * avail_end was pre-decremented in luna88k_bootstrap() to compensate.
*/
for (i = 0; i < btoc(MSGBUFSIZE); i++)
pmap_kenter_pa((paddr_t)msgbufp + i * NBPG,