summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/i386/i386/machdep.c23
-rw-r--r--sys/arch/i386/i386/microtime.s165
2 files changed, 1 insertions, 187 deletions
diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c
index 6555ed29b86..b94614799a3 100644
--- a/sys/arch/i386/i386/machdep.c
+++ b/sys/arch/i386/i386/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.383 2007/04/21 21:06:14 gwk Exp $ */
+/* $OpenBSD: machdep.c,v 1.384 2007/05/04 16:39:28 art Exp $ */
/* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */
/*-
@@ -2691,27 +2691,6 @@ dumpsys()
delay(5000000); /* 5 seconds */
}
-#ifdef HZ
-/*
- * If HZ is defined we use this code, otherwise the code in
- * /sys/arch/i386/i386/microtime.s is used. The other code only works
- * for HZ=100.
- */
-void
-i8254_microtime(struct timeval *tvp)
-{
- int s = splhigh();
-
- *tvp = time;
- tvp->tv_usec += tick;
- splx(s);
- while (tvp->tv_usec >= 1000000) {
- tvp->tv_sec++;
- tvp->tv_usec -= 1000000;
- }
-}
-#endif /* HZ */
-
/*
* Clear registers on exec
*/
diff --git a/sys/arch/i386/i386/microtime.s b/sys/arch/i386/i386/microtime.s
deleted file mode 100644
index 356ed272315..00000000000
--- a/sys/arch/i386/i386/microtime.s
+++ /dev/null
@@ -1,165 +0,0 @@
-/* $OpenBSD: microtime.s,v 1.21 2006/12/20 17:50:40 gwk Exp $ */
-/* $NetBSD: microtime.s,v 1.16 1995/04/17 12:06:47 cgd Exp $ */
-
-/*-
- * Copyright (c) 1993 The Regents of the University of California.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * 3. Neither the name of the University nor the names of its contributors
- * may be used to endorse or promote products derived from this software
- * without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WArRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- */
-
-#include <machine/asm.h>
-#include <dev/isa/isareg.h>
-#include <i386/isa/timerreg.h>
-
-#define IRQ_BIT(irq_num) (1 << ((irq_num) % 8))
-#define IRQ_BYTE(irq_num) ((irq_num) / 8)
-
-/*
- * Use a higher resolution version of microtime if HZ is not
- * overridden (i.e. it is 100Hz).
- */
-#ifndef HZ
-ENTRY(i8254_microtime)
-
-#if defined(I586_CPU) || defined(I686_CPU)
- movl _C_LABEL(cpuspeed), %ecx
- testl %ecx, %ecx
- jne pentium_microtime
-#else
- xorl %ecx,%ecx
-#endif
- movb $(TIMER_SEL0|TIMER_LATCH),%al
-
- pushfl
- cli # disable interrupts
-
- outb %al,$TIMER_MODE # latch timer 0's counter
-
- # Read counter value into ecx, LSB first
- xorl %ecx,%ecx
- inb $TIMER_CNTR0,%al
- movb %al,%cl
- inb $TIMER_CNTR0,%al
- movb %al,%ch
-
- # Now check for counter overflow. This is tricky because the
- # timer chip doesn't let us atomically read the current counter
- # value and the output state (i.e., overflow state). We have
- # to read the ICU interrupt request register (IRR) to see if the
- # overflow has occurred. Because we lack atomicity, we use
- # the (very accurate) heuristic that we do not check for
- # overflow if the value read is close to 0.
- # E.g., if we just checked the IRR, we might read a non-overflowing
- # value close to 0, experience overflow, then read this overflow
- # from the IRR, and mistakenly add a correction to the "close
- # to zero" value.
- #
- # We compare the counter value to the heuristic constant 12.
- # If the counter value is less than this, we assume the counter
- # didn't overflow between disabling clock interrupts and latching
- # the counter value above. For example, we assume that the first 3
- # instructions take less than 12 microseconds to execute.
- #
- # (We used to check for overflow only if the value read was close to
- # the timer limit, but this doesn't work very well if we're at the
- # clock's ipl or higher.)
- #
- # Otherwise, the counter might have overflowed. We check for this
- # condition by reading the interrupt request register out of the ICU.
- # If it overflowed, we add in one clock period.
-
- movl $11932,%edx # counter limit
-
- testb $IRQ_BIT(0),_C_LABEL(ipending) + IRQ_BYTE(0)
- jnz 1f
-
- cmpl $12,%ecx # check for potential overflow
- jbe 2f
-
- inb $IO_ICU1,%al # read IRR in ICU
- testb $IRQ_BIT(0),%al # is a timer interrupt pending?
- jz 2f
-
-1: subl %edx,%ecx # add another tick
-
-2: subl %ecx,%edx # subtract counter value from counter limit
-
- # Divide by 1193280/1000000. We use a fast approximation of 4096/3433.
- # For values of hz more than 100, this has a maximum error of 2us.
-
- leal (%edx,%edx,2),%eax # a = 3d
- leal (%edx,%eax,4),%eax # a = 4a + d = 13d
- movl %eax,%ecx
- shll $5,%ecx
- addl %ecx,%eax # a = 33a = 429d
- leal (%edx,%eax,8),%eax # a = 8a + d = 3433d
- shrl $12,%eax # a = a/4096 = 3433d/4096
-
-common_microtime:
- movl _C_LABEL(time),%edx # get time.tv_sec
- addl _C_LABEL(time)+4,%eax # add time.tv_usec
-
- popfl # enable interrupts
-
- cmpl $1000000,%eax # carry in timeval?
- jb 3f
- subl $1000000,%eax # adjust usec
- incl %edx # bump sec
-
-3: movl 4(%esp),%ecx # load timeval pointer arg
- movl %edx,(%ecx) # tvp->tv_sec = sec
- movl %eax,4(%ecx) # tvp->tv_usec = usec
-
- ret
-
-#if defined(I586_CPU) || defined(I686_CPU)
- .data
- .globl _C_LABEL(pentium_base_tsc)
- .comm _C_LABEL(pentium_base_tsc),8
- .text
-
- .align 2, 0x90
-pentium_microtime:
- pushfl
- cli
- rdtsc
- subl _C_LABEL(pentium_base_tsc),%eax
- sbbl _C_LABEL(pentium_base_tsc)+4,%edx
- /*
- * correct the high word first so we won't
- * receive a result overflow aka div/0 fault
- */
- pushl %eax
- movl %edx, %eax
- shll $16, %edx
- divw %cx
- movzwl %dx, %edx
- popl %eax
- divl %ecx
- jmp common_microtime
-#endif
-
-#endif