diff options
author | Artur Grabowski <art@cvs.openbsd.org> | 2007-09-07 08:37:39 +0000 |
---|---|---|
committer | Artur Grabowski <art@cvs.openbsd.org> | 2007-09-07 08:37:39 +0000 |
commit | 0536dbbe989d19fcaf01c1d0dec6c72547b0ae67 (patch) | |
tree | 7027fa10c6cb20418c4724cae298c4ea18dbbf76 | |
parent | 348c2857dcafa5676b8db26793f62df3485a5e65 (diff) |
Remove some left-overs from the TSC based microtime. We don't need
to synchronize the tsc between CPUs anymore. While here, also remove
the slow TLB IPI since it's been dead for a while.
noticed by mickey
toby@ ok
-rw-r--r-- | sys/arch/i386/i386/ipifuncs.c | 4 | ||||
-rw-r--r-- | sys/arch/i386/i386/lapic.c | 49 | ||||
-rw-r--r-- | sys/arch/i386/include/cpu.h | 3 | ||||
-rw-r--r-- | sys/arch/i386/include/intr.h | 3 | ||||
-rw-r--r-- | sys/arch/i386/include/intrdefs.h | 22 |
5 files changed, 15 insertions, 66 deletions
diff --git a/sys/arch/i386/i386/ipifuncs.c b/sys/arch/i386/i386/ipifuncs.c index 711c6cf278d..3264012587e 100644 --- a/sys/arch/i386/i386/ipifuncs.c +++ b/sys/arch/i386/i386/ipifuncs.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ipifuncs.c,v 1.8 2007/05/25 15:55:26 art Exp $ */ +/* $OpenBSD: ipifuncs.c,v 1.9 2007/09/07 08:37:38 art Exp $ */ /* $NetBSD: ipifuncs.c,v 1.1.2.3 2000/06/26 02:04:06 sommerfeld Exp $ */ /*- @@ -74,10 +74,8 @@ void i386_ipi_flush_fpu(struct cpu_info *); void (*ipifunc[I386_NIPI])(struct cpu_info *) = { i386_ipi_halt, - i386_ipi_microset, i386_ipi_flush_fpu, i386_ipi_synch_fpu, - NULL, #if 0 i386_reload_mtrr, gdt_reload_cpu, diff --git a/sys/arch/i386/i386/lapic.c b/sys/arch/i386/i386/lapic.c index b4023c3f624..bca45e45ba7 100644 --- a/sys/arch/i386/i386/lapic.c +++ b/sys/arch/i386/i386/lapic.c @@ -1,4 +1,4 @@ -/* $OpenBSD: lapic.c,v 1.17 2007/08/01 13:18:18 martin Exp $ */ +/* $OpenBSD: lapic.c,v 1.18 2007/09/07 08:37:38 art Exp $ */ /* $NetBSD: lapic.c,v 1.1.2.8 2000/02/23 06:10:50 sommerfeld Exp $ */ /*- @@ -218,16 +218,10 @@ u_int32_t lapic_delaytab[26]; u_int64_t scaled_pentium_mhz; void -lapic_clockintr(arg) - void *arg; +lapic_clockintr(void *arg) { - struct cpu_info *ci = curcpu(); struct clockframe *frame = arg; - if (CPU_IS_PRIMARY(ci)) { - ci->ci_tscbase = rdtsc(); - i386_broadcast_ipi(I386_IPI_MICROSET); - } hardclock(frame); clk_count.ec_count++; @@ -423,45 +417,6 @@ lapic_delay(int usec) } } -#define LAPIC_TICK_THRESH 200 - -/* - * An IPI handler to record current timer value - */ -void -i386_ipi_microset(struct cpu_info *ci) -{ - ci->ci_tscbase = rdtsc(); -} - -#if 0 -/* - * XXX need to make work correctly on other than cpu 0. - */ -void -lapic_microtime(tv) - struct timeval *tv; -{ - struct cpu_info *ci = curcpu(); - struct timeval now; - u_int64_t tmp; - - disable_intr(); - now = time; - tmp = rdtsc() - ci->ci_tscbase; - enable_intr(); - - now.tv_usec += (tmp * scaled_pentium_mhz) >> 32; - - while (now.tv_usec >= 1000000) { - now.tv_sec += 1; - now.tv_usec -= 1000000; - } - - *tv = now; -} -#endif - /* * XXX the following belong mostly or partly elsewhere.. */ diff --git a/sys/arch/i386/include/cpu.h b/sys/arch/i386/include/cpu.h index 3997c8fd758..3456277cc71 100644 --- a/sys/arch/i386/include/cpu.h +++ b/sys/arch/i386/include/cpu.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpu.h,v 1.95 2007/06/07 11:20:58 dim Exp $ */ +/* $OpenBSD: cpu.h,v 1.96 2007/09/07 08:37:38 art Exp $ */ /* $NetBSD: cpu.h,v 1.35 1996/05/05 19:29:26 christos Exp $ */ /*- @@ -114,7 +114,6 @@ struct cpu_info { u_long ci_flags; /* flags; see below */ u_int32_t ci_ipis; /* interprocessor interrupts pending */ int sc_apic_version;/* local APIC version */ - u_int64_t ci_tscbase; u_int32_t ci_level; u_int32_t ci_vendor[4]; diff --git a/sys/arch/i386/include/intr.h b/sys/arch/i386/include/intr.h index 0d69c57277a..d6b5a187800 100644 --- a/sys/arch/i386/include/intr.h +++ b/sys/arch/i386/include/intr.h @@ -1,4 +1,4 @@ -/* $OpenBSD: intr.h,v 1.32 2007/05/25 15:55:27 art Exp $ */ +/* $OpenBSD: intr.h,v 1.33 2007/09/07 08:37:38 art Exp $ */ /* $NetBSD: intr.h,v 1.5 1996/05/13 06:11:28 mycroft Exp $ */ /* @@ -141,7 +141,6 @@ int i386_fast_ipi(struct cpu_info *, int); void i386_broadcast_ipi(int); void i386_multicast_ipi(int, int); void i386_ipi_handler(void); -void i386_ipi_microset(struct cpu_info *); void i386_intlock(int); void i386_intunlock(int); void i386_softintlock(void); diff --git a/sys/arch/i386/include/intrdefs.h b/sys/arch/i386/include/intrdefs.h index babc8966c3e..b420765376b 100644 --- a/sys/arch/i386/include/intrdefs.h +++ b/sys/arch/i386/include/intrdefs.h @@ -1,4 +1,4 @@ -/* $OpenBSD: intrdefs.h,v 1.8 2007/04/21 21:06:15 gwk Exp $ */ +/* $OpenBSD: intrdefs.h,v 1.9 2007/09/07 08:37:38 art Exp $ */ /* $NetBSD: intrdefs.h,v 1.2 2003/05/04 22:01:56 fvdl Exp $ */ #ifndef _i386_INTRDEFS_H @@ -108,19 +108,17 @@ #define IDT_INTR_HIGH 0xef #define I386_IPI_HALT 0x00000001 -#define I386_IPI_MICROSET 0x00000002 -#define I386_IPI_FLUSH_FPU 0x00000004 -#define I386_IPI_SYNCH_FPU 0x00000008 -#define I386_IPI_TLB 0x00000010 -#define I386_IPI_MTRR 0x00000020 -#define I386_IPI_GDT 0x00000040 -#define I386_IPI_DDB 0x00000080 /* synchronize while in ddb */ -#define I386_IPI_SETPERF 0x00000100 +#define I386_IPI_FLUSH_FPU 0x00000002 +#define I386_IPI_SYNCH_FPU 0x00000004 +#define I386_IPI_MTRR 0x00000008 +#define I386_IPI_GDT 0x00000010 +#define I386_IPI_DDB 0x00000020 /* synchronize while in ddb */ +#define I386_IPI_SETPERF 0x00000040 -#define I386_NIPI 9 +#define I386_NIPI 7 -#define I386_IPI_NAMES { "halt IPI", "timeset IPI", "FPU flush IPI", \ - "FPU synch IPI", "TLB shootdown IPI", \ +#define I386_IPI_NAMES { "halt IPI", "FPU flush IPI", \ + "FPU synch IPI", \ "MTRR update IPI", "GDT update IPI", \ "DDB IPI", "setperf IPI" } |