Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/powerpc/include/oea add functions to access SCOM re...



details:   https://anonhg.NetBSD.org/src/rev/f9eec0cb8565
branches:  trunk
changeset: 362250:f9eec0cb8565
user:      macallan <macallan%NetBSD.org@localhost>
date:      Fri Jun 01 18:18:11 2018 +0000

description:
add functions to access SCOM registers on 970 CPUs

diffstat:

 sys/arch/powerpc/include/oea/spr.h |  57 +++++++++++++++++++++++++++++++++++++-
 1 files changed, 56 insertions(+), 1 deletions(-)

diffs (73 lines):

diff -r 785fa55f0f4f -r f9eec0cb8565 sys/arch/powerpc/include/oea/spr.h
--- a/sys/arch/powerpc/include/oea/spr.h        Fri Jun 01 18:14:33 2018 +0000
+++ b/sys/arch/powerpc/include/oea/spr.h        Fri Jun 01 18:18:11 2018 +0000
@@ -1,8 +1,17 @@
-/*     $NetBSD: spr.h,v 1.5 2018/05/04 16:57:14 macallan Exp $ */
+/*     $NetBSD: spr.h,v 1.6 2018/06/01 18:18:11 macallan Exp $ */
 
 #ifndef _POWERPC_OEA_SPR_H_
 #define        _POWERPC_OEA_SPR_H_
 
+#if !defined(_LOCORE) && defined(_KERNEL)
+#if defined(PPC_OEA64_BRIDGE) || defined (_ARCH_PPC64)
+
+#include <powerpc/psl.h>
+#include <powerpc/spr.h>
+
+#endif
+#endif
+
 /*
  * Special Purpose Register declarations.
  *
@@ -299,4 +308,50 @@
 #define        PMCN_TBLTRANS            3 /* TBL bit transitions */
 #define        PCMN_IDISPATCH           4 /* Instructions dispatched */
 
+#if !defined(_LOCORE) && defined(_KERNEL)
+
+#if defined(PPC_OEA64_BRIDGE) || defined (_ARCH_PPC64)
+
+static inline uint64_t
+scom_read(register_t address)
+{
+       register_t msr;
+       uint64_t ret;
+
+       msr = mfmsr();
+       mtmsr(msr & ~PSL_EE);
+       __asm volatile("isync;");
+
+       mtspr(SPR_SCOMC, address | SCOMC_READ);
+       __asm volatile("isync;");
+
+       ret = mfspr(SPR_SCOMD);
+       mtmsr(msr);
+       __asm volatile("isync;");
+
+       return ret;
+}
+
+static inline void
+scom_write(register_t address, uint64_t data)
+{
+       register_t msr;
+
+       msr = mfmsr();
+       mtmsr(msr & ~PSL_EE);
+       __asm volatile("isync;");
+
+       mtspr(SPR_SCOMD, data);
+       __asm volatile("isync;");
+       mtspr(SPR_SCOMC, address | SCOMC_WRITE);
+       __asm volatile("isync;");
+       
+       mtmsr(msr);
+       __asm volatile("isync;");
+}
+
+#endif /* defined(PPC_OEA64_BRIDGE) || defined (_ARCH_PPC64) */
+
+#endif /* !defined(_LOCORE) && defined(_KERNEL) */
+
 #endif /* !_POWERPC_SPR_H_ */



Home | Main Index | Thread Index | Old Index