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