Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src allow pcu_save() and pcu_discard() to be called on other thr...
details: https://anonhg.NetBSD.org/src/rev/d4b611110afa
branches: trunk
changeset: 352112:d4b611110afa
user: chs <chs%NetBSD.org@localhost>
date: Thu Mar 16 16:13:19 2017 +0000
description:
allow pcu_save() and pcu_discard() to be called on other threads,
ptrace needs to use it that way.
diffstat:
share/man/man9/pcu.9 | 6 +++---
sys/arch/aarch64/include/locore.h | 11 ++++-------
sys/arch/alpha/alpha/compat_13_machdep.c | 6 +++---
sys/arch/alpha/alpha/compat_16_machdep.c | 8 ++++----
sys/arch/alpha/alpha/machdep.c | 8 ++++----
sys/arch/alpha/alpha/process_machdep.c | 8 ++++----
sys/arch/alpha/alpha/trap.c | 8 ++++----
sys/arch/alpha/include/alpha.h | 13 ++++++-------
sys/arch/arm/arm/arm_machdep.c | 6 +++---
sys/arch/arm/arm/process_machdep.c | 8 ++++----
sys/arch/arm/arm32/sys_machdep.c | 8 ++++----
sys/arch/arm/include/locore.h | 8 ++++----
sys/arch/arm/vfp/vfp_init.c | 26 ++++++++++++++------------
sys/arch/mips/include/locore.h | 14 +++++++-------
sys/arch/mips/mips/compat_16_machdep.c | 10 +++++-----
sys/arch/mips/mips/cpu_subr.c | 10 +++++-----
sys/arch/mips/mips/mips_dsp.c | 16 ++++++++--------
sys/arch/mips/mips/mips_fpu.c | 16 ++++++++--------
sys/arch/mips/mips/netbsd32_machdep.c | 7 +++----
sys/arch/mips/mips/process_machdep.c | 8 ++++----
sys/arch/powerpc/booke/spe.c | 8 ++++----
sys/arch/powerpc/include/altivec.h | 10 +++++-----
sys/arch/powerpc/include/fpu.h | 10 +++++-----
sys/arch/powerpc/oea/altivec.c | 13 +++++++------
sys/arch/powerpc/powerpc/fpu.c | 17 ++++++++---------
sys/arch/powerpc/powerpc/process_machdep.c | 26 +++++++-------------------
sys/arch/powerpc/powerpc/trap.c | 18 +++++++++---------
sys/arch/riscv/include/locore.h | 18 +++++++++---------
sys/arch/riscv/riscv/netbsd32_machdep.c | 9 ++++-----
sys/arch/riscv/riscv/process_machdep.c | 23 ++++++++---------------
sys/arch/riscv/riscv/riscv_machdep.c | 8 ++++----
sys/compat/linux/arch/powerpc/linux_machdep.c | 6 +++---
sys/kern/subr_pcu.c | 17 +++++++----------
sys/sys/pcu.h | 8 ++++----
34 files changed, 185 insertions(+), 211 deletions(-)
diffs (truncated from 1386 to 300 lines):
diff -r c88ba83aadb2 -r d4b611110afa share/man/man9/pcu.9
--- a/share/man/man9/pcu.9 Thu Mar 16 13:21:59 2017 +0000
+++ b/share/man/man9/pcu.9 Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: pcu.9,v 1.10 2014/05/25 14:56:23 rmind Exp $
+.\" $NetBSD: pcu.9,v 1.11 2017/03/16 16:13:19 chs Exp $
.\"
.\" Copyright (c) 2012-2014 The NetBSD Foundation, Inc.
.\" All rights reserved.
@@ -38,11 +38,11 @@
.Ft void
.Fn pcu_load "const pcu_ops_t *pcu"
.Ft void
-.Fn pcu_save "const pcu_ops_t *pcu"
+.Fn pcu_save "const pcu_ops_t *pcu" "lwp_t *l"
.Ft void
.Fn pcu_save_all "lwp_t *l"
.Ft void
-.Fn pcu_discard "const pcu_ops_t *pcu" "bool valid"
+.Fn pcu_discard "const pcu_ops_t *pcu" "lwp_t *l" "bool valid"
.Ft void
.Fn pcu_discard_all "lwp_t *l"
.Ft bool
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/aarch64/include/locore.h
--- a/sys/arch/aarch64/include/locore.h Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/aarch64/include/locore.h Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: locore.h,v 1.1 2014/08/10 05:47:38 matt Exp $ */
+/* $NetBSD: locore.h,v 1.2 2017/03/16 16:13:19 chs Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -69,22 +69,19 @@
static inline bool
fpu_used_p(lwp_t *l)
{
- KASSERT(l == curlwp);
- return pcu_valid_p(&pcu_fpu_ops);
+ return pcu_valid_p(&pcu_fpu_ops, l);
}
static inline void
fpu_discard(lwp_t *l, bool usesw)
{
- KASSERT(l == curlwp);
- pcu_discard(&pcu_fpu_ops, usesw);
+ pcu_discard(&pcu_fpu_ops, l, usesw);
}
static inline void
fpu_save(lwp_t *l)
{
- KASSERT(l == curlwp);
- pcu_save(&pcu_fpu_ops);
+ pcu_save(&pcu_fpu_ops, l);
}
static inline void cpsie(register_t psw) __attribute__((__unused__));
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/alpha/alpha/compat_13_machdep.c
--- a/sys/arch/alpha/alpha/compat_13_machdep.c Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/alpha/alpha/compat_13_machdep.c Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: compat_13_machdep.c,v 1.21 2014/05/16 19:18:21 matt Exp $ */
+/* $NetBSD: compat_13_machdep.c,v 1.22 2017/03/16 16:13:20 chs Exp $ */
/*
* Copyright (c) 1994, 1995, 1996 Carnegie-Mellon University.
@@ -29,7 +29,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: compat_13_machdep.c,v 1.21 2014/05/16 19:18:21 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: compat_13_machdep.c,v 1.22 2017/03/16 16:13:20 chs Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -94,7 +94,7 @@
/* XXX ksc.sc_ownedfp ? */
pcb = lwp_getpcb(l);
- fpu_discard(true);
+ fpu_discard(l, true);
memcpy(&pcb->pcb_fp, (struct fpreg *)ksc.sc_fpregs,
sizeof(struct fpreg));
/* XXX ksc.sc_fp_control ? */
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/alpha/alpha/compat_16_machdep.c
--- a/sys/arch/alpha/alpha/compat_16_machdep.c Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/alpha/alpha/compat_16_machdep.c Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: compat_16_machdep.c,v 1.20 2016/03/19 20:57:48 mrg Exp $ */
+/* $NetBSD: compat_16_machdep.c,v 1.21 2017/03/16 16:13:20 chs Exp $ */
/*-
* Copyright (c) 2003 The NetBSD Foundation, Inc.
@@ -86,7 +86,7 @@
#include <machine/cpu.h>
#include <machine/reg.h>
-__KERNEL_RCSID(0, "$NetBSD: compat_16_machdep.c,v 1.20 2016/03/19 20:57:48 mrg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: compat_16_machdep.c,v 1.21 2017/03/16 16:13:20 chs Exp $");
#ifdef DEBUG
@@ -132,7 +132,7 @@
frame.sf_sc.sc_regs[R_SP] = alpha_pal_rdusp();
/* save the floating-point state, if necessary, then copy it. */
- fpu_save();
+ fpu_save(l);
frame.sf_sc.sc_ownedfp = fpu_valid_p(l);
memcpy((struct fpreg *)frame.sf_sc.sc_fpregs, &pcb->pcb_fp,
sizeof(struct fpreg));
@@ -281,7 +281,7 @@
alpha_pal_wrusp(ksc.sc_regs[R_SP]);
pcb = lwp_getpcb(l);
- fpu_discard(true);
+ fpu_discard(l, true);
memcpy(&pcb->pcb_fp, (struct fpreg *)ksc.sc_fpregs,
sizeof(struct fpreg));
pcb->pcb_fp.fpr_cr = ksc.sc_fpcr;
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/alpha/alpha/machdep.c
--- a/sys/arch/alpha/alpha/machdep.c Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/alpha/alpha/machdep.c Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: machdep.c,v 1.349 2016/12/23 07:15:27 cherry Exp $ */
+/* $NetBSD: machdep.c,v 1.350 2017/03/16 16:13:20 chs Exp $ */
/*-
* Copyright (c) 1998, 1999, 2000 The NetBSD Foundation, Inc.
@@ -68,7 +68,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.349 2016/12/23 07:15:27 cherry Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.350 2017/03/16 16:13:20 chs Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -1796,7 +1796,7 @@
/* Save floating point register context, if any, and copy it. */
if (fpu_valid_p(l)) {
- fpu_save();
+ fpu_save(l);
(void)memcpy(&mcp->__fpregs, &pcb->pcb_fp,
sizeof (mcp->__fpregs));
mcp->__fpregs.__fp_fpcr = alpha_read_fp_c(l);
@@ -1844,7 +1844,7 @@
/* Restore floating point register context, if any. */
if (flags & _UC_FPU) {
/* If we have an FP register context, get rid of it. */
- fpu_discard(true);
+ fpu_discard(l, true);
(void)memcpy(&pcb->pcb_fp, &mcp->__fpregs,
sizeof (pcb->pcb_fp));
l->l_md.md_flags = mcp->__fpregs.__fp_fpcr & MDLWP_FP_C;
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/alpha/alpha/process_machdep.c
--- a/sys/arch/alpha/alpha/process_machdep.c Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/alpha/alpha/process_machdep.c Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: process_machdep.c,v 1.29 2014/05/16 19:18:21 matt Exp $ */
+/* $NetBSD: process_machdep.c,v 1.30 2017/03/16 16:13:20 chs Exp $ */
/*
* Copyright (c) 1994 Christopher G. Demetriou
@@ -54,7 +54,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: process_machdep.c,v 1.29 2014/05/16 19:18:21 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: process_machdep.c,v 1.30 2017/03/16 16:13:20 chs Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -116,7 +116,7 @@
{
struct pcb *pcb = lwp_getpcb(l);
- fpu_save();
+ fpu_save(l);
memcpy(regs, &pcb->pcb_fp, sizeof(struct fpreg));
return (0);
@@ -127,7 +127,7 @@
{
struct pcb *pcb = lwp_getpcb(l);
- fpu_discard(true);
+ fpu_discard(l, true);
memcpy(&pcb->pcb_fp, regs, sizeof(struct fpreg));
return (0);
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/alpha/alpha/trap.c
--- a/sys/arch/alpha/alpha/trap.c Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/alpha/alpha/trap.c Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: trap.c,v 1.132 2015/03/02 11:07:16 martin Exp $ */
+/* $NetBSD: trap.c,v 1.133 2017/03/16 16:13:20 chs Exp $ */
/*-
* Copyright (c) 2000, 2001 The NetBSD Foundation, Inc.
@@ -93,7 +93,7 @@
#include <sys/cdefs.h> /* RCS ID & Copyright macro defns */
-__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.132 2015/03/02 11:07:16 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: trap.c,v 1.133 2017/03/16 16:13:20 chs Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -641,13 +641,13 @@
#define unaligned_load_floating(storage, mod) do { \
struct pcb * const pcb = lwp_getpcb(l); \
- fpu_save(); \
+ fpu_save(l); \
unaligned_load(storage, frp, mod) \
} while (/*CONSTCOND*/0)
#define unaligned_store_floating(storage, mod) do { \
struct pcb * const pcb = lwp_getpcb(l); \
- fpu_save(); \
+ fpu_save(l); \
unaligned_store(storage, frp, mod) \
} while (/*CONSTCOND*/0)
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/alpha/include/alpha.h
--- a/sys/arch/alpha/include/alpha.h Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/alpha/include/alpha.h Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: alpha.h,v 1.34 2014/05/16 19:18:21 matt Exp $ */
+/* $NetBSD: alpha.h,v 1.35 2017/03/16 16:13:20 chs Exp $ */
/*
* Copyright (c) 1988 University of Utah.
@@ -116,8 +116,7 @@
static inline bool
fpu_valid_p(struct lwp *l)
{
- KASSERT(l == curlwp);
- return pcu_valid_p(&fpu_ops);
+ return pcu_valid_p(&fpu_ops, l);
}
static inline void
@@ -127,15 +126,15 @@
}
static inline void
-fpu_save(void)
+fpu_save(lwp_t *l)
{
- pcu_save(&fpu_ops);
+ pcu_save(&fpu_ops, l);
}
static inline void
-fpu_discard(bool valid_p)
+fpu_discard(lwp_t *l, bool valid_p)
{
- pcu_discard(&fpu_ops, valid_p);
+ pcu_discard(&fpu_ops, l, valid_p);
}
void alpha_patch(bool);
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/arm/arm/arm_machdep.c
--- a/sys/arch/arm/arm/arm_machdep.c Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/arm/arm/arm_machdep.c Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: arm_machdep.c,v 1.49 2015/05/02 16:20:41 skrll Exp $ */
+/* $NetBSD: arm_machdep.c,v 1.50 2017/03/16 16:13:20 chs Exp $ */
/*
* Copyright (c) 2001 Wasabi Systems, Inc.
@@ -80,7 +80,7 @@
#include <sys/param.h>
-__KERNEL_RCSID(0, "$NetBSD: arm_machdep.c,v 1.49 2015/05/02 16:20:41 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: arm_machdep.c,v 1.50 2017/03/16 16:13:20 chs Exp $");
#include <sys/exec.h>
#include <sys/proc.h>
@@ -201,7 +201,7 @@
l->l_md.md_flags |= MDLWP_NOALIGNFLT;
#endif
#ifdef FPU_VFP
- vfp_discardcontext(false);
+ vfp_discardcontext(l, false);
#endif
}
diff -r c88ba83aadb2 -r d4b611110afa sys/arch/arm/arm/process_machdep.c
--- a/sys/arch/arm/arm/process_machdep.c Thu Mar 16 13:21:59 2017 +0000
+++ b/sys/arch/arm/arm/process_machdep.c Thu Mar 16 16:13:19 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: process_machdep.c,v 1.31 2017/02/21 07:40:28 skrll Exp $ */
+/* $NetBSD: process_machdep.c,v 1.32 2017/03/16 16:13:20 chs Exp $ */
Home |
Main Index |
Thread Index |
Old Index