Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/compat Increase LINUX32_ELF_AUX_ENTRIES to avoid overrun...
details: https://anonhg.NetBSD.org/src/rev/c5781f8e958a
branches: trunk
changeset: 793619:c5781f8e958a
user: maxv <maxv%NetBSD.org@localhost>
date: Fri Feb 21 07:53:53 2014 +0000
description:
Increase LINUX32_ELF_AUX_ENTRIES to avoid overrun in linux32/. Also,
add comments and KASSERTs to make sure people don't forget to increase
XX_AUX_ENTRIES's when adding vectors.
Reported by martin@ (CV), with suggestions from chs@.
ok martin@ chs@
diffstat:
sys/compat/linux/arch/amd64/linux_exec_machdep.c | 13 ++++---------
sys/compat/linux/common/linux_exec.h | 3 ++-
sys/compat/linux/common/linux_exec_elf32.c | 5 +++--
sys/compat/linux32/arch/amd64/linux32_exec.h | 5 +++--
sys/compat/linux32/common/linux32_exec_elf32.c | 7 +++++--
5 files changed, 17 insertions(+), 16 deletions(-)
diffs (131 lines):
diff -r f21bfb11e006 -r c5781f8e958a sys/compat/linux/arch/amd64/linux_exec_machdep.c
--- a/sys/compat/linux/arch/amd64/linux_exec_machdep.c Fri Feb 21 07:47:02 2014 +0000
+++ b/sys/compat/linux/arch/amd64/linux_exec_machdep.c Fri Feb 21 07:53:53 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: linux_exec_machdep.c,v 1.20 2013/11/18 01:32:22 chs Exp $ */
+/* $NetBSD: linux_exec_machdep.c,v 1.21 2014/02/21 07:53:53 maxv Exp $ */
/*-
* Copyright (c) 2005 Emmanuel Dreyfus, all rights reserved
@@ -32,7 +32,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: linux_exec_machdep.c,v 1.20 2013/11/18 01:32:22 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: linux_exec_machdep.c,v 1.21 2014/02/21 07:53:53 maxv Exp $");
#define ELFSIZE 64
@@ -233,13 +233,8 @@
esd.ai[i].a_type = AT_NULL;
esd.ai[i++].a_v = 0;
-#ifdef DEBUG_LINUX
- if (i != LINUX_ELF_AUX_ENTRIES) {
- printf("linux_elf64_copyargs: %d Aux entries\n", i);
- return EINVAL;
- }
-#endif
-
+ KASSERT(i == LINUX_ELF_AUX_ENTRIES);
+
strcpy(esd.hw_platform, LINUX_PLATFORM);
exec_free_emul_arg(pack);
diff -r f21bfb11e006 -r c5781f8e958a sys/compat/linux/common/linux_exec.h
--- a/sys/compat/linux/common/linux_exec.h Fri Feb 21 07:47:02 2014 +0000
+++ b/sys/compat/linux/common/linux_exec.h Fri Feb 21 07:53:53 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: linux_exec.h,v 1.50 2014/02/09 16:41:42 chs Exp $ */
+/* $NetBSD: linux_exec.h,v 1.51 2014/02/21 07:53:53 maxv Exp $ */
/*-
* Copyright (c) 1995, 1998 The NetBSD Foundation, Inc.
@@ -82,6 +82,7 @@
#define LINUX_N_BSSADDR(x,m) (LINUX_N_DATADDR(x,m) + (x).a_data)
#ifndef LINUX_MACHDEP_ELF_COPYARGS
+/* Counted from linux_exec_elf32.c */
#define LINUX_ELF_AUX_ENTRIES 14
#endif
diff -r f21bfb11e006 -r c5781f8e958a sys/compat/linux/common/linux_exec_elf32.c
--- a/sys/compat/linux/common/linux_exec_elf32.c Fri Feb 21 07:47:02 2014 +0000
+++ b/sys/compat/linux/common/linux_exec_elf32.c Fri Feb 21 07:53:53 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: linux_exec_elf32.c,v 1.88 2014/02/09 16:41:42 chs Exp $ */
+/* $NetBSD: linux_exec_elf32.c,v 1.89 2014/02/21 07:53:53 maxv Exp $ */
/*-
* Copyright (c) 1995, 1998, 2000, 2001 The NetBSD Foundation, Inc.
@@ -35,7 +35,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: linux_exec_elf32.c,v 1.88 2014/02/09 16:41:42 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: linux_exec_elf32.c,v 1.89 2014/02/21 07:53:53 maxv Exp $");
#ifndef ELFSIZE
/* XXX should die */
@@ -495,6 +495,7 @@
*stackp += len;
len = (a - ai) * sizeof(AuxInfo);
+ KASSERT(len <= LINUX_ELF_AUX_ENTRIES);
if ((error = copyout(ai, *stackp, len)) != 0)
return error;
*stackp += len;
diff -r f21bfb11e006 -r c5781f8e958a sys/compat/linux32/arch/amd64/linux32_exec.h
--- a/sys/compat/linux32/arch/amd64/linux32_exec.h Fri Feb 21 07:47:02 2014 +0000
+++ b/sys/compat/linux32/arch/amd64/linux32_exec.h Fri Feb 21 07:53:53 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: linux32_exec.h,v 1.5 2014/02/09 16:41:42 chs Exp $ */
+/* $NetBSD: linux32_exec.h,v 1.6 2014/02/21 07:53:53 maxv Exp $ */
/*-
* Copyright (c) 2006 Emmanuel Dreyfus, all rights reserved.
@@ -41,7 +41,8 @@
#define LINUX32_DEBUGLINK_SIGNATURE 1
-#define LINUX32_ELF_AUX_ENTRIES 14
+/* Counted from common/linux32_exec_elf32.c */
+#define LINUX32_ELF_AUX_ENTRIES 15
#define LINUX32_RANDOM_BYTES 16 /* 16 bytes for AT_RANDOM */
diff -r f21bfb11e006 -r c5781f8e958a sys/compat/linux32/common/linux32_exec_elf32.c
--- a/sys/compat/linux32/common/linux32_exec_elf32.c Fri Feb 21 07:47:02 2014 +0000
+++ b/sys/compat/linux32/common/linux32_exec_elf32.c Fri Feb 21 07:53:53 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: linux32_exec_elf32.c,v 1.14 2014/02/09 16:41:42 chs Exp $ */
+/* $NetBSD: linux32_exec_elf32.c,v 1.15 2014/02/21 07:53:53 maxv Exp $ */
/*-
* Copyright (c) 1995, 1998, 2000, 2001,2006 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: linux32_exec_elf32.c,v 1.14 2014/02/09 16:41:42 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: linux32_exec_elf32.c,v 1.15 2014/02/21 07:53:53 maxv Exp $");
#define ELFSIZE 32
@@ -191,6 +191,8 @@
a++;
#if 0
+ /* XXX: increase LINUX32_ELF_AUX_ENTRIES if we enable those things */
+
a->a_type = LINUX_AT_SYSINFO;
a->a_v = NETBSD32PTR32I(&esdp->kernel_vsyscall[0]);
a++;
@@ -239,6 +241,7 @@
#endif
len = (a - ai) * sizeof(AuxInfo);
+ KASSERT(len <= LINUX32_ELF_AUX_ENTRIES);
if ((error = copyout(ai, *stackp, len)) != 0)
return error;
*stackp += len;
Home |
Main Index |
Thread Index |
Old Index