Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/sparc64/include Revert workarounds for clang.



details:   https://anonhg.NetBSD.org/src/rev/b95f4c77434a
branches:  trunk
changeset: 465237:b95f4c77434a
user:      nakayama <nakayama%NetBSD.org@localhost>
date:      Wed Nov 13 10:06:38 2019 +0000

description:
Revert workarounds for clang.
In-tree clang can now handle the "r" asm constraint for 64-bit values properly.

diffstat:

 sys/arch/sparc64/include/ctlreg.h |  35 ++++++++++++++++-------------------
 sys/arch/sparc64/include/psl.h    |  16 ++++------------
 2 files changed, 20 insertions(+), 31 deletions(-)

diffs (128 lines):

diff -r af684950b68a -r b95f4c77434a sys/arch/sparc64/include/ctlreg.h
--- a/sys/arch/sparc64/include/ctlreg.h Wed Nov 13 09:59:02 2019 +0000
+++ b/sys/arch/sparc64/include/ctlreg.h Wed Nov 13 10:06:38 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ctlreg.h,v 1.66 2019/04/05 23:09:18 nakayama Exp $ */
+/*     $NetBSD: ctlreg.h,v 1.67 2019/11/13 10:06:38 nakayama Exp $ */
 
 /*
  * Copyright (c) 1996-2002 Eduardo Horvath
@@ -485,13 +485,12 @@
 #ifdef __arch64__
 
 /* 64-bit kernel, non-constant */
-#define SPARC64_LD_NONCONST(ld, type)  \
+#define SPARC64_LD_NONCONST(ld)        \
        __asm volatile(                                                 \
                "wr %2,%%g0,%%asi;      "                               \
                #ld " [%1]%%asi,%0      "                               \
                : "=r" (_v)                                             \
-               : "r" ((__uintptr_t)(loc)), "r" (asi),                  \
-                 "m" (*(type *)(__uintptr_t)(loc)))
+               : "r" ((__uintptr_t)(loc)), "r" (asi))
 
 #if defined(__GNUC__) && defined(__OPTIMIZE__)
 #define SPARC64_LD_DEF(ld, type, vtype)        \
@@ -502,10 +501,9 @@
                __asm volatile(                                         \
                        #ld " [%1]%2,%0         "                       \
                        : "=r" (_v)                                     \
-                       : "r" ((__uintptr_t)(loc)), "n" (asi),          \
-                         "m" (*(type *)(__uintptr_t)(loc)));           \
+                       : "r" ((__uintptr_t)(loc)), "n" (asi));         \
        else                                                            \
-               SPARC64_LD_NONCONST(ld, type);                          \
+               SPARC64_LD_NONCONST(ld);                                \
        return _v;                                                      \
 }
 #else
@@ -513,7 +511,7 @@
 static __inline type ld(paddr_t loc, int asi)                          \
 {                                                                      \
        vtype _v;                                                       \
-       SPARC64_LD_NONCONST(ld, type);                                  \
+       SPARC64_LD_NONCONST(ld);                                        \
        return _v;                                                      \
 }
 #endif
@@ -679,12 +677,12 @@
 #ifdef __arch64__
 
 /* 64-bit kernel, non-constant */
-#define SPARC64_ST_NONCONST(st, type)  \
+#define SPARC64_ST_NONCONST(st)        \
        __asm volatile(                                                 \
-               "wr %3,%%g0,%%asi;      "                               \
-               #st " %1,[%2]%%asi      "                               \
-               : "=m" (*(type *)(__uintptr_t)(loc))                    \
-               : "r" (value), "r" ((__uintptr_t)(loc)), "r" (asi))
+               "wr %2,%%g0,%%asi;      "                               \
+               #st " %0,[%1]%%asi      "                               \
+               : : "r" (value), "r" ((__uintptr_t)(loc)),              \
+                   "r" (asi))
 
 #if defined(__GNUC__) && defined(__OPTIMIZE__)
 #define SPARC64_ST_DEF(st, type)       \
@@ -692,18 +690,17 @@
 {                                                                      \
        if (__builtin_constant_p(asi))                                  \
                __asm volatile(                                         \
-                       #st " %1,[%2]%3         "                       \
-                       : "=m" (*(type *)(__uintptr_t)(loc))            \
-                       : "r" (value), "r" ((__uintptr_t)(loc)),        \
-                         "n" (asi));                                   \
+                       #st " %0,[%1]%2         "                       \
+                       : : "r" (value), "r" ((__uintptr_t)(loc)),      \
+                           "n" (asi));                                 \
        else                                                            \
-               SPARC64_ST_NONCONST(st, type);                          \
+               SPARC64_ST_NONCONST(st);                                \
 }
 #else
 #define SPARC64_ST_DEF(st, type)       \
 static __inline void st(paddr_t loc, int asi, type value)              \
 {                                                                      \
-       SPARC64_ST_NONCONST(st, type);                                  \
+       SPARC64_ST_NONCONST(st);                                        \
 }
 #endif
 #define SPARC64_ST_DEF64(st, type)     SPARC64_ST_DEF(st, type)
diff -r af684950b68a -r b95f4c77434a sys/arch/sparc64/include/psl.h
--- a/sys/arch/sparc64/include/psl.h    Wed Nov 13 09:59:02 2019 +0000
+++ b/sys/arch/sparc64/include/psl.h    Wed Nov 13 10:06:38 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: psl.h,v 1.60 2019/04/06 21:40:15 nakayama Exp $ */
+/*     $NetBSD: psl.h,v 1.61 2019/11/13 10:06:38 nakayama Exp $ */
 
 /*
  * Copyright (c) 1992, 1993
@@ -322,13 +322,11 @@
        __asm volatile(#wr " %0,0,%" #reg : : "r" (_val) : "memory");   \
 }
 
-/*
- * XXX: clang's "r" constraint cannot handle 64-bit,
- * so use 32-bit kernel code as a workaround.
- */
-#if defined(__arch64__) && !defined(__clang__)
+#ifdef __arch64__
 #define SPARC64_RDCONST64_DEF(rd, name, reg) \
        SPARC64_RDCONST_DEF(rd, name, reg, uint64_t)
+#define SPARC64_RD64_DEF(rd, name, reg) SPARC64_RD_DEF(rd, name, reg, uint64_t)
+#define SPARC64_WR64_DEF(wr, name, reg) SPARC64_WR_DEF(wr, name, reg, uint64_t)
 #else
 #define SPARC64_RDCONST64_DEF(rd, name, reg)                           \
 static __inline __constfunc uint64_t get##name(void)                   \
@@ -338,12 +336,6 @@
                : "=r" (_hi), "=r" (_lo) : : constasm_clobbers);        \
        return ((uint64_t)_hi << 32) | _lo;                             \
 }
-#endif
-
-#ifdef __arch64__
-#define SPARC64_RD64_DEF(rd, name, reg) SPARC64_RD_DEF(rd, name, reg, uint64_t)
-#define SPARC64_WR64_DEF(wr, name, reg) SPARC64_WR_DEF(wr, name, reg, uint64_t)
-#else
 #define SPARC64_RD64_DEF(rd, name, reg)                                        \
 static __inline uint64_t get##name(void)                               \
 {                                                                      \



Home | Main Index | Thread Index | Old Index