Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm Switch to using FP instructions instead of cp10...



details:   https://anonhg.NetBSD.org/src/rev/c12ec3b4c4c7
branches:  trunk
changeset: 792237:c12ec3b4c4c7
user:      matt <matt%NetBSD.org@localhost>
date:      Fri Dec 27 12:16:01 2013 +0000

description:
Switch to using FP instructions instead of cp10/11 instructions.

diffstat:

 sys/arch/arm/include/armreg.h |  38 ++++++++++++++++++++++++++------------
 sys/arch/arm/vfp/vfp_init.c   |  17 +++++++++++------
 2 files changed, 37 insertions(+), 18 deletions(-)

diffs (113 lines):

diff -r 51ba037839a5 -r c12ec3b4c4c7 sys/arch/arm/include/armreg.h
--- a/sys/arch/arm/include/armreg.h     Fri Dec 27 08:40:28 2013 +0000
+++ b/sys/arch/arm/include/armreg.h     Fri Dec 27 12:16:01 2013 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: armreg.h,v 1.83 2013/09/07 00:32:33 matt Exp $ */
+/*     $NetBSD: armreg.h,v 1.84 2013/12/27 12:16:01 matt Exp $ */
 
 /*
  * Copyright (c) 1998, 2001 Ben Harris
@@ -650,6 +650,20 @@
        __asm __volatile("mcr " __insnstring :: "r"(__val));    \
 }
 
+#define        ARMREG_READ_INLINE2(name, __insnstring)                 \
+static inline uint32_t armreg_##name##_read(void)              \
+{                                                              \
+       uint32_t __rv;                                          \
+       __asm __volatile(__insnstring : "=r"(__rv));    \
+       return __rv;                                            \
+}
+
+#define        ARMREG_WRITE_INLINE2(name, __insnstring)                \
+static inline void armreg_##name##_write(uint32_t __val)       \
+{                                                              \
+       __asm __volatile(__insnstring :: "r"(__val));           \
+}
+
 #define        ARMREG_READ64_INLINE(name, __insnstring)                \
 static inline uint64_t armreg_##name##_read(void)              \
 {                                                              \
@@ -665,17 +679,17 @@
 }
 
 /* cp10 registers */
-ARMREG_READ_INLINE(fpsid, "p10,7,%0,c0,c0,0") /* VFP System ID */
-ARMREG_READ_INLINE(fpscr, "p10,7,%0,c1,c0,0") /* VFP Status/Control Register */
-ARMREG_WRITE_INLINE(fpscr, "p10,7,%0,c1,c0,0") /* VFP Status/Control Register */
-ARMREG_READ_INLINE(mvfr1, "p10,7,%0,c6,c0,0") /* Media and VFP Feature Register 1 */
-ARMREG_READ_INLINE(mvfr0, "p10,7,%0,c7,c0,0") /* Media and VFP Feature Register 0 */
-ARMREG_READ_INLINE(fpexc, "p10,7,%0,c8,c0,0") /* VFP Exception Register */
-ARMREG_WRITE_INLINE(fpexc, "p10,7,%0,c8,c0,0") /* VFP Exception Register */
-ARMREG_READ_INLINE(fpinst, "p10,7,%0,c9,c0,0") /* VFP Exception Instruction */
-ARMREG_WRITE_INLINE(fpinst, "p10,7,%0,c9,c0,0") /* VFP Exception Instruction */
-ARMREG_READ_INLINE(fpinst2, "p10,7,%0,c10,c0,0") /* VFP Exception Instruction 2 */
-ARMREG_WRITE_INLINE(fpinst2, "p10,7,%0,c10,c0,0") /* VFP Exception Instruction 2 */
+ARMREG_READ_INLINE2(fpsid, "vmrs\t%0, fpsid") /* VFP System ID */
+ARMREG_READ_INLINE2(fpscr, "vmrs\t%0, fpscr") /* VFP Status/Control Register */
+ARMREG_WRITE_INLINE2(fpscr, "vmsr\tfpscr, %0") /* VFP Status/Control Register */
+ARMREG_READ_INLINE2(mvfr1, "vmrs\t%0, mvfr1") /* Media and VFP Feature Register 1 */
+ARMREG_READ_INLINE2(mvfr0, "vmrs\t%0, mvfr0") /* Media and VFP Feature Register 0 */
+ARMREG_READ_INLINE2(fpexc, "vmrs\t%0, fpexc") /* VFP Exception Register */
+ARMREG_WRITE_INLINE2(fpexc, "vmsr\tfpexc, %0") /* VFP Exception Register */
+ARMREG_READ_INLINE2(fpinst, "fmrx\t%0, fpinst") /* VFP Exception Instruction */
+ARMREG_WRITE_INLINE2(fpinst, "fmxr\tfpinst, %0") /* VFP Exception Instruction */
+ARMREG_READ_INLINE2(fpinst2, "fmrx\t%0, fpinst2") /* VFP Exception Instruction 2 */
+ARMREG_WRITE_INLINE2(fpinst2, "fmxr\tfpinst2, %0") /* VFP Exception Instruction 2 */
 
 /* cp15 c0 registers */
 ARMREG_READ_INLINE(midr, "p15,0,%0,c0,c0,0") /* Main ID Register */
diff -r 51ba037839a5 -r c12ec3b4c4c7 sys/arch/arm/vfp/vfp_init.c
--- a/sys/arch/arm/vfp/vfp_init.c       Fri Dec 27 08:40:28 2013 +0000
+++ b/sys/arch/arm/vfp/vfp_init.c       Fri Dec 27 12:16:01 2013 +0000
@@ -1,4 +1,4 @@
-/*      $NetBSD: vfp_init.c,v 1.28 2013/12/14 15:47:18 matt Exp $ */
+/*      $NetBSD: vfp_init.c,v 1.29 2013/12/27 12:16:01 matt Exp $ */
 
 /*
  * Copyright (c) 2008 ARM Ltd
@@ -49,19 +49,24 @@
 
 #ifdef FPU_VFP
 
+#ifdef CPU_CORTEX
+__asm(".fpu\tvfpv4");
+#else
+__asm(".fpu\tvfp");
+#endif
+
 /* FLDMD <X>, {d0-d15} */
 static inline void
 load_vfpregs_lo(const uint64_t *p)
 {
-       /* vldmia rN, {d0-d15} */
-       __asm __volatile("ldc\tp11, c0, [%0], {32}" :: "r" (p) : "memory");
+       __asm __volatile("vldmia %0, {d0-d15}" :: "r" (p) : "memory");
 }
 
 /* FSTMD <X>, {d0-d15} */
 static inline void
 save_vfpregs_lo(uint64_t *p)
 {
-       __asm __volatile("stc\tp11, c0, [%0], {32}" :: "r" (p) : "memory");
+       __asm __volatile("vstmia %0, {d0-d15}" :: "r" (p) : "memory");
 }
 
 #ifdef CPU_CORTEX
@@ -69,14 +74,14 @@
 static inline void
 load_vfpregs_hi(const uint64_t *p)
 {
-       __asm __volatile("ldcl\tp11, c0, [%0], {32}" :: "r" (&p[16]) : "memory");
+       __asm __volatile("vldmia\t%0, {d16-d31}" :: "r" (&p[16]) : "memory");
 }
 
 /* FLDMD <X>, {d16-d31} */
 static inline void
 save_vfpregs_hi(uint64_t *p)
 {
-       __asm __volatile("stcl\tp11, c0, [%0], {32}" :: "r" (&p[16]) : "memory");
+       __asm __volatile("vstmia\t%0, {d16-d31}" :: "r" (&p[16]) : "memory");
 }
 #endif
 



Home | Main Index | Thread Index | Old Index