Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch Revert most of ad's movs/stos change. Instead do a ...
details: https://anonhg.NetBSD.org/src/rev/d67ac98c7040
branches: trunk
changeset: 1011982:d67ac98c7040
user: maxv <maxv%NetBSD.org@localhost>
date: Sun Jul 19 07:35:08 2020 +0000
description:
Revert most of ad's movs/stos change. Instead do a lot simpler: declare
svs_quad_copy() used by SVS only, with no need for instrumentation, because
SVS is disabled when sanitizers are on.
diffstat:
sys/arch/amd64/amd64/cpufunc.S | 11 +++++++----
sys/arch/amd64/include/frameasm.h | 24 +-----------------------
sys/arch/i386/i386/cpufunc.S | 20 ++------------------
sys/arch/x86/include/pmap.h | 4 ++--
sys/arch/x86/x86/svs.c | 6 +++---
5 files changed, 15 insertions(+), 50 deletions(-)
diffs (152 lines):
diff -r 2f5c23e3168f -r d67ac98c7040 sys/arch/amd64/amd64/cpufunc.S
--- a/sys/arch/amd64/amd64/cpufunc.S Sun Jul 19 07:32:43 2020 +0000
+++ b/sys/arch/amd64/amd64/cpufunc.S Sun Jul 19 07:35:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc.S,v 1.63 2020/06/24 18:09:37 maxv Exp $ */
+/* $NetBSD: cpufunc.S,v 1.64 2020/07/19 07:35:08 maxv Exp $ */
/*
* Copyright (c) 1998, 2007, 2008, 2020 The NetBSD Foundation, Inc.
@@ -446,10 +446,13 @@
ret
END(outl)
-ENTRY(x86_movs)
+/*
+ * Used by SVS only, to make an atomic but fast copy. Doesn't have
+ * sanitizer instrumentation, but sanitizers disable SVS, so no problem.
+ */
+ENTRY(svs_quad_copy)
movq %rdx,%rcx
- KMSAN_REP_STOS(8)
rep
movsq
ret
-END(x86_movs)
+END(svs_quad_copy)
diff -r 2f5c23e3168f -r d67ac98c7040 sys/arch/amd64/include/frameasm.h
--- a/sys/arch/amd64/include/frameasm.h Sun Jul 19 07:32:43 2020 +0000
+++ b/sys/arch/amd64/include/frameasm.h Sun Jul 19 07:35:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: frameasm.h,v 1.51 2020/06/21 16:53:37 bouyer Exp $ */
+/* $NetBSD: frameasm.h,v 1.52 2020/07/19 07:35:08 maxv Exp $ */
#ifndef _AMD64_MACHINE_FRAMEASM_H
#define _AMD64_MACHINE_FRAMEASM_H
@@ -276,33 +276,11 @@
popq %rdx ; \
popq %rcx ; \
popq %rax
-#define KMSAN_REP_STOS(scale) \
- pushq %rax ; \
- pushq %rcx ; \
- pushq %rdx ; \
- pushq %rsi ; \
- pushq %rdi ; \
- pushq %r8 ; \
- pushq %r9 ; \
- pushq %r10 ; \
- pushq %r11 ; \
- leaq (,%rcx,scale),%rsi ; \
- callq _C_LABEL(__msan_instrument_asm_store); \
- popq %r11 ; \
- popq %r10 ; \
- popq %r9 ; \
- popq %r8 ; \
- popq %rdi ; \
- popq %rsi ; \
- popq %rdx ; \
- popq %rcx ; \
- popq %rax
#else
#define KMSAN_ENTER /* nothing */
#define KMSAN_LEAVE /* nothing */
#define KMSAN_INIT_ARG(sz) /* nothing */
#define KMSAN_INIT_RET(sz) /* nothing */
-#define KMSAN_REP_STOS(scale) /* nothing */
#endif
#ifdef KCOV
diff -r 2f5c23e3168f -r d67ac98c7040 sys/arch/i386/i386/cpufunc.S
--- a/sys/arch/i386/i386/cpufunc.S Sun Jul 19 07:32:43 2020 +0000
+++ b/sys/arch/i386/i386/cpufunc.S Sun Jul 19 07:35:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpufunc.S,v 1.48 2020/06/24 18:09:37 maxv Exp $ */
+/* $NetBSD: cpufunc.S,v 1.49 2020/07/19 07:35:08 maxv Exp $ */
/*-
* Copyright (c) 1998, 2007, 2020 The NetBSD Foundation, Inc.
@@ -38,7 +38,7 @@
#include <sys/errno.h>
#include <machine/asm.h>
-__KERNEL_RCSID(0, "$NetBSD: cpufunc.S,v 1.48 2020/06/24 18:09:37 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpufunc.S,v 1.49 2020/07/19 07:35:08 maxv Exp $");
#include "opt_xen.h"
@@ -353,19 +353,3 @@
outl %eax, %dx
ret
END(outl)
-
-ENTRY(x86_movs)
- pushl %ebp
- movl %esp,%ebp
- pushl %edi
- pushl %esi
- movl 8(%ebp),%edi
- movl 12(%ebp),%esi
- movl 16(%ebp),%ecx
- rep
- movsl
- popl %esi
- popl %edi
- leave
- ret
-END(x86_movs)
diff -r 2f5c23e3168f -r d67ac98c7040 sys/arch/x86/include/pmap.h
--- a/sys/arch/x86/include/pmap.h Sun Jul 19 07:32:43 2020 +0000
+++ b/sys/arch/x86/include/pmap.h Sun Jul 19 07:35:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmap.h,v 1.124 2020/07/14 00:45:53 yamaguchi Exp $ */
+/* $NetBSD: pmap.h,v 1.125 2020/07/19 07:35:08 maxv Exp $ */
/*
* Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -612,7 +612,7 @@
#endif /* __HAVE_DIRECT_MAP */
-void x86_movs(void *, void *, long);
+void svs_quad_copy(void *, void *, long);
#endif /* _KERNEL */
diff -r 2f5c23e3168f -r d67ac98c7040 sys/arch/x86/x86/svs.c
--- a/sys/arch/x86/x86/svs.c Sun Jul 19 07:32:43 2020 +0000
+++ b/sys/arch/x86/x86/svs.c Sun Jul 19 07:35:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: svs.c,v 1.38 2020/07/14 00:45:53 yamaguchi Exp $ */
+/* $NetBSD: svs.c,v 1.39 2020/07/19 07:35:08 maxv Exp $ */
/*
* Copyright (c) 2018-2020 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: svs.c,v 1.38 2020/07/14 00:45:53 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: svs.c,v 1.39 2020/07/19 07:35:08 maxv Exp $");
#include "opt_svs.h"
#include "opt_user_ldt.h"
@@ -704,7 +704,7 @@
/* Copy user slots. */
mutex_enter(&ci->ci_svs_mtx);
- x86_movs(ci->ci_svs_updir, pmap->pm_pdir, PDIR_SLOT_USERLIM);
+ svs_quad_copy(ci->ci_svs_updir, pmap->pm_pdir, PDIR_SLOT_USERLIM);
mutex_exit(&ci->ci_svs_mtx);
if (svs_pcid) {
Home |
Main Index |
Thread Index |
Old Index