aboutsummaryrefslogtreecommitdiff
path: root/lib/libthr/arch/amd64
diff options
context:
space:
mode:
Diffstat (limited to 'lib/libthr/arch/amd64')
-rw-r--r--lib/libthr/arch/amd64/Makefile.inc4
-rw-r--r--lib/libthr/arch/amd64/amd64/_umtx_op_err.S42
-rw-r--r--lib/libthr/arch/amd64/include/pthread_md.h65
-rw-r--r--lib/libthr/arch/amd64/include/pthread_tls.h4
4 files changed, 10 insertions, 105 deletions
diff --git a/lib/libthr/arch/amd64/Makefile.inc b/lib/libthr/arch/amd64/Makefile.inc
index 43f6e839ff10..f8013ea914ed 100644
--- a/lib/libthr/arch/amd64/Makefile.inc
+++ b/lib/libthr/arch/amd64/Makefile.inc
@@ -1,7 +1,3 @@
-#$FreeBSD$
-
-SRCS+= _umtx_op_err.S
-
# With the current compiler and libthr code, using SSE in libthr
# does not provide enough performance improvement to outweigh
# the extra context switch cost. This can measurably impact
diff --git a/lib/libthr/arch/amd64/amd64/_umtx_op_err.S b/lib/libthr/arch/amd64/amd64/_umtx_op_err.S
deleted file mode 100644
index 1e9f7d607f7a..000000000000
--- a/lib/libthr/arch/amd64/amd64/_umtx_op_err.S
+++ /dev/null
@@ -1,42 +0,0 @@
-/*-
- * Copyright (C) 2008 David Xu <davidxu@freebsd.org>
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Neither the name of the author nor the names of its contributors
- * may be used to endorse or promote products derived from this software
- * without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- *
- * $FreeBSD$
- */
-
-#include <sys/syscall.h>
-#include <machine/asm.h>
-
-#define RSYSCALL_ERR(x) ENTRY(__CONCAT(x, _err)); \
- mov __CONCAT($SYS_,x),%rax; \
- KERNCALL; \
- ret; \
- END(__CONCAT(x, _err));
-
-#define KERNCALL movq %rcx, %r10; syscall
-
-RSYSCALL_ERR(_umtx_op)
-
- .section .note.GNU-stack,"",%progbits
diff --git a/lib/libthr/arch/amd64/include/pthread_md.h b/lib/libthr/arch/amd64/include/pthread_md.h
index 1d393d9cbbed..f43578a8241a 100644
--- a/lib/libthr/arch/amd64/include/pthread_md.h
+++ b/lib/libthr/arch/amd64/include/pthread_md.h
@@ -1,5 +1,5 @@
/*-
- * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
+ * SPDX-License-Identifier: BSD-2-Clause
*
* Copyright (C) 2003 David Xu <davidxu@freebsd.org>
* Copyright (c) 2001 Daniel Eischen <deischen@freebsd.org>
@@ -25,8 +25,6 @@
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
- *
- * $FreeBSD$
*/
/*
@@ -37,66 +35,21 @@
#include <stddef.h>
#include <sys/types.h>
-#include <machine/sysarch.h>
+#include <machine/tls.h>
#define CPU_SPINWAIT __asm __volatile("pause")
-#define DTV_OFFSET offsetof(struct tcb, tcb_dtv)
-
-/*
- * Variant II tcb, first two members are required by rtld,
- * %fs points to the structure.
- */
-struct tcb {
- struct tcb *tcb_self; /* required by rtld */
- void *tcb_dtv; /* required by rtld */
- struct pthread *tcb_thread;
- void *tcb_spare[1];
-};
-
-/*
- * Evaluates to the byte offset of the per-tcb variable name.
- */
-#define __tcb_offset(name) __offsetof(struct tcb, name)
-
-/*
- * Evaluates to the type of the per-tcb variable name.
- */
-#define __tcb_type(name) __typeof(((struct tcb *)0)->name)
-
-/*
- * Evaluates to the value of the per-tcb variable name.
- */
-#define TCB_GET64(name) ({ \
- __tcb_type(name) __result; \
- \
- u_long __i; \
- __asm __volatile("movq %%fs:%1, %0" \
- : "=r" (__i) \
- : "m" (*(volatile u_long *)(__tcb_offset(name)))); \
- __result = (__tcb_type(name))__i; \
- \
- __result; \
-})
-
-static __inline void
-_tcb_set(struct tcb *tcb)
-{
- amd64_set_fsbase(tcb);
-}
-
-static __inline struct tcb *
-_tcb_get(void)
-{
- return (TCB_GET64(tcb_self));
-}
+/* For use in _Static_assert to check structs will fit in a page */
+#define THR_PAGE_SIZE_MIN PAGE_SIZE
static __inline struct pthread *
_get_curthread(void)
{
- return (TCB_GET64(tcb_thread));
-}
+ struct pthread *thr;
-#define HAS__UMTX_OP_ERR 1
+ __asm __volatile("movq %%fs:%1, %0" : "=r" (thr)
+ : "m" (*(volatile u_long *)offsetof(struct tcb, tcb_thread)));
+ return (thr);
+}
#endif
diff --git a/lib/libthr/arch/amd64/include/pthread_tls.h b/lib/libthr/arch/amd64/include/pthread_tls.h
index c0ca6201d41c..2af0aeda4c85 100644
--- a/lib/libthr/arch/amd64/include/pthread_tls.h
+++ b/lib/libthr/arch/amd64/include/pthread_tls.h
@@ -1,5 +1,5 @@
/*-
- * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
+ * SPDX-License-Identifier: BSD-2-Clause
*
* Copyright (c) 2019 The FreeBSD Foundation
*
@@ -26,8 +26,6 @@
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
- *
- * $FreeBSD$
*/
#ifndef _ARCH_AMD64_PTHREAD_TLS_H