Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/aarch64 Implement MD ucas(9) (__HAVE_UCAS_FULL)



details:   https://anonhg.NetBSD.org/src/rev/612015846b46
branches:  trunk
changeset: 1012598:612015846b46
user:      ryo <ryo%NetBSD.org@localhost>
date:      Mon Aug 03 06:29:59 2020 +0000

description:
Implement MD ucas(9) (__HAVE_UCAS_FULL)

diffstat:

 sys/arch/aarch64/aarch64/TODO        |   3 +-
 sys/arch/aarch64/aarch64/copyinout.S |  51 ++++++++++++++++++++++++++++++++++-
 sys/arch/aarch64/aarch64/genassym.cf |   5 ++-
 sys/arch/aarch64/include/cpufunc.h   |   3 +-
 sys/arch/aarch64/include/types.h     |   3 +-
 5 files changed, 58 insertions(+), 7 deletions(-)

diffs (141 lines):

diff -r 08d1ffbd78e4 -r 612015846b46 sys/arch/aarch64/aarch64/TODO
--- a/sys/arch/aarch64/aarch64/TODO     Mon Aug 03 05:56:49 2020 +0000
+++ b/sys/arch/aarch64/aarch64/TODO     Mon Aug 03 06:29:59 2020 +0000
@@ -1,7 +1,6 @@
-$NetBSD: TODO,v 1.8 2019/12/04 13:47:03 jmcneill Exp $
+$NetBSD: TODO,v 1.9 2020/08/03 06:29:59 ryo Exp $
 
 TODO list for NetBSD/aarch64
   - kernel preemption
-  - Implement __HAVE_UCAS_FULL or __HAVE_UCAS_MP (don't use full generic impl)
   - pmap should be work even if PID_MAX >= 65536 (don't depend 16bit ASID)
   - TLB ASID in pmap should be randomized
diff -r 08d1ffbd78e4 -r 612015846b46 sys/arch/aarch64/aarch64/copyinout.S
--- a/sys/arch/aarch64/aarch64/copyinout.S      Mon Aug 03 05:56:49 2020 +0000
+++ b/sys/arch/aarch64/aarch64/copyinout.S      Mon Aug 03 06:29:59 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: copyinout.S,v 1.12 2020/08/03 05:56:49 ryo Exp $ */
+/* $NetBSD: copyinout.S,v 1.13 2020/08/03 06:29:59 ryo Exp $ */
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -33,7 +33,7 @@
 #include <aarch64/asm.h>
 #include "assym.h"
 
-RCSID("$NetBSD: copyinout.S,v 1.12 2020/08/03 05:56:49 ryo Exp $");
+RCSID("$NetBSD: copyinout.S,v 1.13 2020/08/03 06:29:59 ryo Exp $");
 
 #ifdef ARMV81_PAN
 #define PAN_ENABLE     \
@@ -348,3 +348,50 @@
        exit_cpu_onfault
        ret
 END(kcopy)
+
+
+/* LINTSTUB: int _ucas_32(volatile uint32_t *uptr, uint32_t old, uint32_t new, uint32_t *retp); */
+ENTRY(_ucas_32)
+       tbnz    x0, AARCH64_ADDRTOP_TAG_BIT, 3f /* not userspace */
+       ands    x8, x0, #3
+       cbnz    x8, 3f                          /* not aligned */
+
+       enter_cpu_onfault
+
+1:     ldxr    w4, [x0]                /* load old value */
+       cmp     w4, w1                  /*   compare? */
+       b.ne    2f                      /*     return if different */
+       stxr    w5, w2, [x0]            /* store new value */
+       cbnz    w5, 1b                  /*   succeed? nope, try again. */
+2:     str     w4, [x3]
+       mov     x8, #0                  /* error = 0 */
+
+       exit_cpu_onfault
+       ret
+3:
+       mov     x0, #EFAULT
+       ret
+END(_ucas_32)
+
+/* LINTSTUB: int _ucas_64(volatile uint64_t *uptr, uint64_t old, uint64_t new, uint64_t *retp); */
+ENTRY(_ucas_64)
+       tbnz    x0, AARCH64_ADDRTOP_TAG_BIT, 3f /* not userspace */
+       ands    x8, x0, #7
+       cbnz    x8, 3f                          /* not aligned */
+
+       enter_cpu_onfault
+
+1:     ldxr    x4, [x0]                /* load old value */
+       cmp     x4, x1                  /*   compare? */
+       b.ne    2f                      /*     return if different */
+       stxr    w5, x2, [x0]            /* store new value */
+       cbnz    w5, 1b                  /*   succeed? nope, try again. */
+2:     str     x4, [x3]
+       mov     x8, #0                  /* error = 0 */
+
+       exit_cpu_onfault
+       ret
+3:
+       mov     x0, #EFAULT
+       ret
+END(_ucas_64)
diff -r 08d1ffbd78e4 -r 612015846b46 sys/arch/aarch64/aarch64/genassym.cf
--- a/sys/arch/aarch64/aarch64/genassym.cf      Mon Aug 03 05:56:49 2020 +0000
+++ b/sys/arch/aarch64/aarch64/genassym.cf      Mon Aug 03 06:29:59 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: genassym.cf,v 1.27 2020/08/03 05:56:50 ryo Exp $
+# $NetBSD: genassym.cf,v 1.28 2020/08/03 06:29:59 ryo Exp $
 #-
 # Copyright (c) 2014 The NetBSD Foundation, Inc.
 # All rights reserved.
@@ -56,6 +56,7 @@
 include <aarch64/vmparam.h>
 include <aarch64/frame.h>
 include <aarch64/armreg.h>
+include <aarch64/cpufunc.h>
 include <aarch64/pte.h>
 
 define __HAVE_FAST_SOFTINTS    1
@@ -76,6 +77,8 @@
 
 #define        PV_PA                   offsetof(pv_addr_t, pv_pa)
 
+define AARCH64_ADDRTOP_TAG_BIT AARCH64_ADDRTOP_TAG_BIT
+
 define L0_ADDR_BITS            L0_ADDR_BITS
 define L0_SHIFT                L0_SHIFT
 define L0_TABLE                L0_TABLE
diff -r 08d1ffbd78e4 -r 612015846b46 sys/arch/aarch64/include/cpufunc.h
--- a/sys/arch/aarch64/include/cpufunc.h        Mon Aug 03 05:56:49 2020 +0000
+++ b/sys/arch/aarch64/include/cpufunc.h        Mon Aug 03 06:29:59 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cpufunc.h,v 1.17 2020/08/02 06:58:16 maxv Exp $        */
+/*     $NetBSD: cpufunc.h,v 1.18 2020/08/03 06:30:00 ryo Exp $ */
 
 /*
  * Copyright (c) 2017 Ryo Shimizu <ryo%nerv.org@localhost>
@@ -167,6 +167,7 @@
 #endif /* _KERNEL */
 
 /* definitions of TAG and PAC in pointers */
+#define AARCH64_ADDRTOP_TAG_BIT                55
 #define AARCH64_ADDRTOP_TAG            __BIT(55)       /* ECR_EL1.TBI[01]=1 */
 #define AARCH64_ADDRTOP_MSB            __BIT(63)       /* ECR_EL1.TBI[01]=0 */
 #define AARCH64_ADDRESS_TAG_MASK       __BITS(63,56)   /* if TCR.TBI[01]=1 */
diff -r 08d1ffbd78e4 -r 612015846b46 sys/arch/aarch64/include/types.h
--- a/sys/arch/aarch64/include/types.h  Mon Aug 03 05:56:49 2020 +0000
+++ b/sys/arch/aarch64/include/types.h  Mon Aug 03 06:29:59 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: types.h,v 1.14 2020/02/14 07:21:02 skrll Exp $ */
+/* $NetBSD: types.h,v 1.15 2020/08/03 06:30:00 ryo Exp $ */
 
 /*-
  * Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -105,6 +105,7 @@
 #define __HAVE_SYSCALL_INTERN
 #define __HAVE_TLS_VARIANT_I
 #define __HAVE___LWP_GETPRIVATE_FAST
+#define __HAVE_UCAS_FULL
 
 #if defined(_KERNEL) || defined(_KMEMUSER)
 #define PCU_FPU                        0



Home | Main Index | Thread Index | Old Index