Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/kern Introduce PTRACE_REGS_ALIGN, and on x86, enforce a ...
details: https://anonhg.NetBSD.org/src/rev/40eafc1e7ca4
branches: trunk
changeset: 972558:40eafc1e7ca4
user: maxv <maxv%NetBSD.org@localhost>
date: Sat May 30 08:41:22 2020 +0000
description:
Introduce PTRACE_REGS_ALIGN, and on x86, enforce a 16-byte alignment, due
to fpregs having fxsave which requires 16-byte alignment.
Reported-by: syzbot+f44d47e617ebf7fda081%syzkaller.appspotmail.com@localhost
diffstat:
sys/arch/amd64/include/ptrace.h | 8 +++++++-
sys/arch/i386/include/ptrace.h | 8 +++++++-
sys/kern/sys_ptrace_common.c | 10 +++++++---
3 files changed, 21 insertions(+), 5 deletions(-)
diffs (82 lines):
diff -r a802f9a22106 -r 40eafc1e7ca4 sys/arch/amd64/include/ptrace.h
--- a/sys/arch/amd64/include/ptrace.h Sat May 30 04:11:21 2020 +0000
+++ b/sys/arch/amd64/include/ptrace.h Sat May 30 08:41:22 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ptrace.h,v 1.21 2020/01/08 17:21:38 mgorny Exp $ */
+/* $NetBSD: ptrace.h,v 1.22 2020/05/30 08:41:22 maxv Exp $ */
/*
* Copyright (c) 1993 Christopher G. Demetriou
@@ -101,6 +101,12 @@
int process_machdep_doxstate(struct lwp *, struct lwp *, struct uio *);
int process_machdep_validfpu(struct proc *);
+/*
+ * The fpregs structure contains an fxsave area, which must have 16-byte
+ * alignment.
+ */
+#define PTRACE_REGS_ALIGN __aligned(16)
+
#include <sys/module_hook.h>
MODULE_HOOK(netbsd32_process_doxmmregs_hook, int,
(struct lwp *, struct lwp *, void *, bool));
diff -r a802f9a22106 -r 40eafc1e7ca4 sys/arch/i386/include/ptrace.h
--- a/sys/arch/i386/include/ptrace.h Sat May 30 04:11:21 2020 +0000
+++ b/sys/arch/i386/include/ptrace.h Sat May 30 08:41:22 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ptrace.h,v 1.25 2020/01/09 10:46:31 kamil Exp $ */
+/* $NetBSD: ptrace.h,v 1.26 2020/05/30 08:41:23 maxv Exp $ */
/*
* Copyright (c) 2001 Wasabi Systems, Inc.
@@ -187,6 +187,12 @@
struct pfsnode *, struct uio *);
int procfs_machdep_validxmmregs(struct lwp *, struct mount *);
+/*
+ * The fpregs structure contains an fxsave area, which must have 16-byte
+ * alignment.
+ */
+#define PTRACE_REGS_ALIGN __aligned(16)
+
#endif /* _KERNEL */
#endif /* _I386_PTRACE_H_ */
diff -r a802f9a22106 -r 40eafc1e7ca4 sys/kern/sys_ptrace_common.c
--- a/sys/kern/sys_ptrace_common.c Sat May 30 04:11:21 2020 +0000
+++ b/sys/kern/sys_ptrace_common.c Sat May 30 08:41:22 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sys_ptrace_common.c,v 1.82 2020/05/26 23:08:56 kamil Exp $ */
+/* $NetBSD: sys_ptrace_common.c,v 1.83 2020/05/30 08:41:22 maxv Exp $ */
/*-
* Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -118,7 +118,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sys_ptrace_common.c,v 1.82 2020/05/26 23:08:56 kamil Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sys_ptrace_common.c,v 1.83 2020/05/30 08:41:22 maxv Exp $");
#ifdef _KERNEL_OPT
#include "opt_ptrace.h"
@@ -214,6 +214,10 @@
# define PT_REGISTERS
#endif
+#ifndef PTRACE_REGS_ALIGN
+#define PTRACE_REGS_ALIGN /* nothing */
+#endif
+
static int
ptrace_listener_cb(kauth_cred_t cred, kauth_action_t action, void *cookie,
void *arg0, void *arg1, void *arg2, void *arg3)
@@ -1591,7 +1595,7 @@
proc_regio(struct lwp *l, struct uio *uio, size_t ks, regrfunc_t r,
regwfunc_t w)
{
- char buf[1024];
+ char buf[1024] PTRACE_REGS_ALIGN;
int error;
char *kv;
size_t kl;
Home |
Main Index |
Thread Index |
Old Index