diff options
author | Owain Ainsworth <oga@cvs.openbsd.org> | 2009-12-09 14:28:47 +0000 |
---|---|---|
committer | Owain Ainsworth <oga@cvs.openbsd.org> | 2009-12-09 14:28:47 +0000 |
commit | 580e00e95ea51b295ec9285aca0df412609003ac (patch) | |
tree | 6cb584ef90edf8881adc701a7fe8e81fc7135891 | |
parent | 62e20001a22537cd09005eaa87a882f508f37eb1 (diff) |
add cpufunc functions for the clflush instruction and the mfence
instruction.
ok kettenis@ as part of a larger diff.
-rw-r--r-- | sys/arch/amd64/include/cpufunc.h | 14 | ||||
-rw-r--r-- | sys/arch/i386/include/cpufunc.h | 15 |
2 files changed, 27 insertions, 2 deletions
diff --git a/sys/arch/amd64/include/cpufunc.h b/sys/arch/amd64/include/cpufunc.h index a641b6b000b..31a2c67ebc3 100644 --- a/sys/arch/amd64/include/cpufunc.h +++ b/sys/arch/amd64/include/cpufunc.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpufunc.h,v 1.3 2008/06/26 05:42:09 ray Exp $ */ +/* $OpenBSD: cpufunc.h,v 1.4 2009/12/09 14:28:46 oga Exp $ */ /* $NetBSD: cpufunc.h,v 1.3 2003/05/08 10:27:43 fvdl Exp $ */ /*- @@ -266,6 +266,18 @@ wbinvd(void) __asm __volatile("wbinvd"); } +static __inline void +clflush(u_int64_t addr) +{ + __asm __volatile("clflush %0" : "+m" (addr)); +} + +static __inline void +mfence(void) +{ + __asm __volatile("mfence" : : : "memory"); +} + static __inline u_int64_t rdtsc(void) { diff --git a/sys/arch/i386/include/cpufunc.h b/sys/arch/i386/include/cpufunc.h index cd66ef4dde4..3f37e86627c 100644 --- a/sys/arch/i386/include/cpufunc.h +++ b/sys/arch/i386/include/cpufunc.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpufunc.h,v 1.15 2009/08/13 13:24:48 kettenis Exp $ */ +/* $OpenBSD: cpufunc.h,v 1.16 2009/12/09 14:28:46 oga Exp $ */ /* $NetBSD: cpufunc.h,v 1.8 1994/10/27 04:15:59 cgd Exp $ */ /* @@ -63,6 +63,8 @@ static __inline void enable_intr(void); static __inline u_int read_eflags(void); static __inline void write_eflags(u_int); static __inline void wbinvd(void); +static __inline void clflush(u_int32_t addr); +static __inline void mfence(void); static __inline void wrmsr(u_int, u_int64_t); static __inline u_int64_t rdmsr(u_int); static __inline void breakpoint(void); @@ -220,6 +222,17 @@ wbinvd(void) __asm __volatile("wbinvd"); } +static __inline void +clflush(u_int32_t addr) +{ + __asm __volatile("clflush %0" : "+m" (addr)); +} + +static __inline void +mfence(void) +{ + __asm __volatile("mfence" : : : "memory"); +} static __inline void wrmsr(u_int msr, u_int64_t newval) |