diff options
Diffstat (limited to 'sys/arch/hppa/include/cpufunc.h')
-rw-r--r-- | sys/arch/hppa/include/cpufunc.h | 54 |
1 files changed, 33 insertions, 21 deletions
diff --git a/sys/arch/hppa/include/cpufunc.h b/sys/arch/hppa/include/cpufunc.h index 37a53eb18bb..b20f4111087 100644 --- a/sys/arch/hppa/include/cpufunc.h +++ b/sys/arch/hppa/include/cpufunc.h @@ -1,4 +1,4 @@ -/* $OpenBSD: cpufunc.h,v 1.5 1998/12/29 21:47:13 mickey Exp $ */ +/* $OpenBSD: cpufunc.h,v 1.6 1999/02/25 17:23:34 mickey Exp $ */ /* * Copyright (c) 1998 Michael Shalayeff @@ -111,76 +111,88 @@ void set_psw __P((u_int psw)); #endif #define fdce(sp,off) __asm __volatile("fdce 0(%0,%1)":: "i" (sp), "r" (off)) -#define fice(sp,off) __asm __volatile("fdce 0(%0,%1)":: "i" (sp), "r" (off)) +#define fice(sp,off) __asm __volatile("fice 0(%0,%1)":: "i" (sp), "r" (off)) #define sync_caches() \ __asm __volatile("sync\n\tnop\n\tnop\n\tnop\n\tnop\n\tnop\n\tnop\n\tnop") static __inline void -ficache(pa_space_t space, vm_offset_t off, vm_size_t size) +ficache(pa_space_t sp, vm_offset_t va, vm_size_t size) { + extern int icache_stride; + register vm_offset_t eva = va + size; + mtsp(sp, 1); + while (va < eva) + __asm __volatile ("fic,m %2(%%sr1, %1)" + : "=r" (va): "0" (va), "r" (icache_stride)); } static __inline void -fdcache(pa_space_t space, vm_offset_t off, vm_size_t size) +fdcache(pa_space_t sp, vm_offset_t va, vm_size_t size) { + extern int dcache_stride; + register vm_offset_t eva = va + size; + mtsp(sp, 1); + while (va < eva) + __asm __volatile ("fdc,m %2(%%sr1, %1)" + : "=r" (va): "0" (va), "r" (dcache_stride)); } static __inline void -iitlba(u_int pg, pa_space_t sp, vm_offset_t off) +iitlba(u_int pg, pa_space_t sp, vm_offset_t va) { - mtsp(1, sp); - __asm volatile("iitlba %0,(%%sr1, %1)":: "r" (pg), "r" (off)); + mtsp(sp, 1); + __asm volatile("iitlba %0,(%%sr1, %1)":: "r" (pg), "r" (va)); } static __inline void -idtlba(u_int pg, pa_space_t sp, vm_offset_t off) +idtlba(u_int pg, pa_space_t sp, vm_offset_t va) { mtsp(sp, 1); - __asm volatile("idtlba %0,(%%sr1, %1)":: "r" (pg), "r" (off)); + __asm volatile("idtlba %0,(%%sr1, %1)":: "r" (pg), "r" (va)); } static __inline void -iitlbp(u_int prot, pa_space_t sp, vm_offset_t off) +iitlbp(u_int prot, pa_space_t sp, vm_offset_t va) { mtsp(sp, 1); - __asm volatile("iitlbp %0,(%%sr1, %1)":: "r" (prot), "r" (off)); + __asm volatile("iitlbp %0,(%%sr1, %1)":: "r" (prot), "r" (va)); } static __inline void -idtlbp(u_int prot, pa_space_t sp, vm_offset_t off) +idtlbp(u_int prot, pa_space_t sp, vm_offset_t va) { mtsp(sp, 1); - __asm volatile("idtlbp %0,(%%sr1, %1)":: "r" (prot), "r" (off)); + __asm volatile("idtlbp %0,(%%sr1, %1)":: "r" (prot), "r" (va)); } static __inline void -pitlb(pa_space_t sp, vm_offset_t off) +pitlb(pa_space_t sp, vm_offset_t va) { mtsp(sp, 1); - __asm volatile("pitlb %%r0(%%sr1, %0)":: "r" (off)); + __asm volatile("pitlb %%r0(%%sr1, %0)":: "r" (va)); } static __inline void -pdtlb(pa_space_t sp, vm_offset_t off) +pdtlb(pa_space_t sp, vm_offset_t va) { mtsp(sp, 1); - __asm volatile("pdtlb %%r0(%%sr1, %0)":: "r" (off)); + __asm volatile("pdtlb %%r0(%%sr1, %0)":: "r" (va)); } static __inline void -pitlbe(pa_space_t sp, vm_offset_t off) +pitlbe(pa_space_t sp, vm_offset_t va) { mtsp(sp, 1); - __asm volatile("pitlbe %%r0(%%sr1, %0)":: "r" (off)); + __asm volatile("pitlbe %%r0(%%sr1, %0)":: "r" (va)); } static __inline void -pdtlbe(pa_space_t sp, vm_offset_t off) +pdtlbe(pa_space_t sp, vm_offset_t va) { mtsp(sp, 1); - __asm volatile("pdtlbe %%r0(%%sr1, %0)":: "r" (off)); + __asm volatile("pdtlbe %%r0(%%sr1, %0)":: "r" (va)); } #ifdef _KERNEL |