summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/i386/i386/longrun.c4
-rw-r--r--sys/arch/i386/i386/machdep.c6
-rw-r--r--sys/arch/i386/i386/microtime.s4
-rw-r--r--sys/arch/i386/i386/pctr.c10
-rw-r--r--sys/arch/i386/include/cpu.h4
-rw-r--r--sys/arch/i386/include/cpufunc.h6
-rw-r--r--sys/arch/i386/include/pctr.h10
-rw-r--r--sys/arch/i386/isa/clock.c6
8 files changed, 25 insertions, 25 deletions
diff --git a/sys/arch/i386/i386/longrun.c b/sys/arch/i386/i386/longrun.c
index 239a1fda324..51e1fc2b036 100644
--- a/sys/arch/i386/i386/longrun.c
+++ b/sys/arch/i386/i386/longrun.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: longrun.c,v 1.2 2003/05/26 08:30:03 tedu Exp $ */
+/* $OpenBSD: longrun.c,v 1.3 2003/05/27 23:52:01 fgsch Exp $ */
/*
* Copyright (c) 2003 Ted Unangst
* Copyright (c) 2001 Tamotsu Hattori
@@ -126,7 +126,7 @@ static void
longrun_readreg(u_int32_t ax, u_int32_t *regs)
{
__asm __volatile(
- ".byte 0x0f, 0xa2;"
+ "cpuid;"
"movl %%eax, 0(%2);"
"movl %%ebx, 4(%2);"
"movl %%ecx, 8(%2);"
diff --git a/sys/arch/i386/i386/machdep.c b/sys/arch/i386/i386/machdep.c
index f3f4099b901..f6541028e97 100644
--- a/sys/arch/i386/i386/machdep.c
+++ b/sys/arch/i386/i386/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.232 2003/05/18 02:43:12 andreas Exp $ */
+/* $OpenBSD: machdep.c,v 1.233 2003/05/27 23:52:01 fgsch Exp $ */
/* $NetBSD: machdep.c,v 1.214 1996/11/10 03:16:17 thorpej Exp $ */
/*-
@@ -1219,11 +1219,11 @@ intel686_cpu_setup(cpu_device, model, step)
#define rdmsr(msr) \
({ \
u_quad_t v; \
- __asm __volatile (".byte 0xf, 0x32" : "=A" (v) : "c" (msr)); \
+ __asm __volatile ("rdmsr" : "=A" (v) : "c" (msr)); \
v; \
})
#define wrmsr(msr, v) \
- __asm __volatile (".byte 0xf, 0x30" :: "A" ((u_quad_t) (v)), "c" (msr));
+ __asm __volatile ("wrmsr" :: "A" ((u_quad_t) (v)), "c" (msr));
/*
* Original PPro returns SYSCALL in CPUID but is non-functional.
diff --git a/sys/arch/i386/i386/microtime.s b/sys/arch/i386/i386/microtime.s
index 718f20842b7..6d46c2cbeb3 100644
--- a/sys/arch/i386/i386/microtime.s
+++ b/sys/arch/i386/i386/microtime.s
@@ -1,4 +1,4 @@
-/* $OpenBSD: microtime.s,v 1.17 2003/04/17 03:42:14 drahn Exp $ */
+/* $OpenBSD: microtime.s,v 1.18 2003/05/27 23:52:01 fgsch Exp $ */
/* $NetBSD: microtime.s,v 1.16 1995/04/17 12:06:47 cgd Exp $ */
/*-
@@ -149,7 +149,7 @@ common_microtime:
pentium_microtime:
pushfl
cli
- .byte 0x0f, 0x31 # RDTSC
+ rdtsc
subl _C_LABEL(pentium_base_tsc),%eax
sbbl _C_LABEL(pentium_base_tsc)+4,%edx
/*
diff --git a/sys/arch/i386/i386/pctr.c b/sys/arch/i386/i386/pctr.c
index 72c2122af30..d8a171bdce5 100644
--- a/sys/arch/i386/i386/pctr.c
+++ b/sys/arch/i386/i386/pctr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pctr.c,v 1.15 2002/03/14 01:26:32 millert Exp $ */
+/* $OpenBSD: pctr.c,v 1.16 2003/05/27 23:52:01 fgsch Exp $ */
/*
* Pentium performance counter driver for OpenBSD.
@@ -55,16 +55,16 @@ pctrattach (num)
if (usep6ctr)
/* Enable RDTSC and RDPMC instructions from user-level. */
- __asm __volatile (".byte 0xf,0x20,0xe0 # movl %%cr4,%%eax\n"
+ __asm __volatile ("movl %%cr4,%%eax\n"
"\tandl %0,%%eax\n"
"\torl %1,%%eax\n"
- "\t.byte 0xf,0x22,0xe0 # movl %%cr4,%%eax"
+ "\tmovl %%cr4,%%eax"
:: "i" (~CR4_TSD), "i" (CR4_PCE) : "eax");
else if (usetsc)
/* Enable RDTSC instruction from user-level. */
- __asm __volatile (".byte 0xf,0x20,0xe0 # movl %%cr4,%%eax\n"
+ __asm __volatile ("movl %%cr4,%%eax\n"
"\tandl %0,%%eax\n"
- "\t.byte 0xf,0x22,0xe0 # movl %%cr4,%%eax"
+ "\tmovl %%cr4,%%eax"
:: "i" (~CR4_TSD) : "eax");
if (usep6ctr)
diff --git a/sys/arch/i386/include/cpu.h b/sys/arch/i386/include/cpu.h
index 9b6894f0c44..fa22463d0b3 100644
--- a/sys/arch/i386/include/cpu.h
+++ b/sys/arch/i386/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.47 2003/05/14 22:08:04 tedu Exp $ */
+/* $OpenBSD: cpu.h,v 1.48 2003/05/27 23:52:01 fgsch Exp $ */
/* $NetBSD: cpu.h,v 1.35 1996/05/05 19:29:26 christos Exp $ */
/*-
@@ -105,7 +105,7 @@ extern u_quad_t pentium_base_tsc;
do { \
if (pentium_mhz) { \
__asm __volatile("cli\n" \
- ".byte 0xf, 0x31\n" \
+ "rdtsc\n" \
"sti\n" \
: "=A" (pentium_base_tsc) \
: ); \
diff --git a/sys/arch/i386/include/cpufunc.h b/sys/arch/i386/include/cpufunc.h
index b7c039ab585..193c12e829e 100644
--- a/sys/arch/i386/include/cpufunc.h
+++ b/sys/arch/i386/include/cpufunc.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpufunc.h,v 1.8 2002/03/14 01:26:33 millert Exp $ */
+/* $OpenBSD: cpufunc.h,v 1.9 2003/05/27 23:52:01 fgsch Exp $ */
/* $NetBSD: cpufunc.h,v 1.8 1994/10/27 04:15:59 cgd Exp $ */
/*
@@ -171,7 +171,7 @@ wbinvd(void)
static __inline void
wrmsr(u_int msr, u_int64_t newval)
{
- __asm __volatile(".byte 0x0f, 0x30" : : "A" (newval), "c" (msr));
+ __asm __volatile("wrmsr" : : "A" (newval), "c" (msr));
}
static __inline u_int64_t
@@ -179,7 +179,7 @@ rdmsr(u_int msr)
{
u_int64_t rv;
- __asm __volatile(".byte 0x0f, 0x32" : "=A" (rv) : "c" (msr));
+ __asm __volatile("rdmsr" : "=A" (rv) : "c" (msr));
return (rv);
}
diff --git a/sys/arch/i386/include/pctr.h b/sys/arch/i386/include/pctr.h
index 3e0b6cf428c..3deb3e47582 100644
--- a/sys/arch/i386/include/pctr.h
+++ b/sys/arch/i386/include/pctr.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pctr.h,v 1.11 2001/06/05 05:05:38 pvalchev Exp $ */
+/* $OpenBSD: pctr.h,v 1.12 2003/05/27 23:52:01 fgsch Exp $ */
/*
* Pentium performance counter driver for OpenBSD.
@@ -56,7 +56,7 @@ struct pctrst {
#define rdtsc() \
({ \
pctrval v; \
- __asm __volatile (".byte 0xf, 0x31" : "=A" (v)); \
+ __asm __volatile ("rdtsc" : "=A" (v)); \
v; \
})
@@ -64,7 +64,7 @@ struct pctrst {
#define rdpmc(ctr) \
({ \
pctrval v; \
- __asm __volatile (".byte 0xf, 0x33\n" \
+ __asm __volatile ("rdpmc\n" \
"\tandl $0xff, %%edx" \
: "=A" (v) : "c" (ctr)); \
v; \
@@ -75,12 +75,12 @@ struct pctrst {
#define rdmsr(msr) \
({ \
pctrval v; \
- __asm __volatile (".byte 0xf, 0x32" : "=A" (v) : "c" (msr)); \
+ __asm __volatile ("rdmsr" : "=A" (v) : "c" (msr)); \
v; \
})
#define wrmsr(msr, v) \
- __asm __volatile (".byte 0xf, 0x30" :: "A" ((u_quad_t) (v)), "c" (msr));
+ __asm __volatile ("wrmsr" :: "A" ((u_quad_t) (v)), "c" (msr));
#endif /* _KERNEL */
#endif /* ! _I386_PCTR_H_ */
diff --git a/sys/arch/i386/isa/clock.c b/sys/arch/i386/isa/clock.c
index 7fdb55e9435..52bfc4c82c7 100644
--- a/sys/arch/i386/isa/clock.c
+++ b/sys/arch/i386/isa/clock.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: clock.c,v 1.28 2002/07/06 19:14:20 nordin Exp $ */
+/* $OpenBSD: clock.c,v 1.29 2003/05/27 23:52:01 fgsch Exp $ */
/* $NetBSD: clock.c,v 1.39 1996/05/12 23:11:54 mycroft Exp $ */
/*-
@@ -451,9 +451,9 @@ calibrate_cyclecounter()
{
unsigned long long count, last_count;
- __asm __volatile(".byte 0xf, 0x31" : "=A" (last_count));
+ __asm __volatile("rdtsc" : "=A" (last_count));
delay(1000000);
- __asm __volatile(".byte 0xf, 0x31" : "=A" (count));
+ __asm __volatile("rdtsc" : "=A" (count));
pentium_mhz = ((count - last_count) + 500000) / 1000000;
}
#endif