From cc1186234a24910c20b6382ce77fc44680e80321 Mon Sep 17 00:00:00 2001 From: Juho Snellman Date: Sat, 24 Sep 2005 00:23:57 +0000 Subject: [PATCH] 0.9.4.85: Mostly revert 0.9.4.84, since it doesn't compile at all on modern Linux systems (see sbcl-devel message by "Dave" on 2005-09-23): * The decision of whether to use personality() should be completely a run-time property, not a compile-time one. * Change LISP_FEATURE_LINUX cpp conditionals back to LISP_FEATURE_X86 or remove them entirely (this is in linux-os.c, so LISP_FEATURE_LINUX had better be defined; randomization is only enabled on x86 so it's pointless to include the code on other platforms) Additionally: * To solve the problem that 0.9.4.84 was trying to address (no on versions of glibc more than three years old) define the prototype of personality() in linux-os.c. This might not be the optimal solution, but I suppose this isn't the right time to experiment... The syscall itself is old (goes at least back to kernel 2.0), so the system call wrapper should exist even on old versions of libc. There should thus be no problems with linking this code even on ancient systems. --- src/runtime/linux-os.c | 82 ++++++++++++++++++------------------------------ version.lisp-expr | 2 +- 2 files changed, 31 insertions(+), 53 deletions(-) diff --git a/src/runtime/linux-os.c b/src/runtime/linux-os.c index 6c77f5a..9bc5ea1 100644 --- a/src/runtime/linux-os.c +++ b/src/runtime/linux-os.c @@ -52,19 +52,10 @@ #include "gencgc-internal.h" #endif -#ifdef LISP_FEATURE_LINUX -/* Linux "man personality" on Debian 3.1 doesn't say what Linux - * version introduced support for #include , but - * judging from jesnell's code for sbcl-0.9.4, 'twas Linux 2.6. */ -#define PERSONALITY_SUPPORTED_AT_COMPILE_TIME \ - (LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,0)) -#else -/* Linux "man personality" on Debian 3.1 says that - * stuff is Linux-only. */ -#define PERSONALITY_SUPPORTED_AT_COMPILE_TIME 0 -#endif -#if PERSONALITY_SUPPORTED_AT_COMPILE_TIME -#include +#ifdef LISP_FEATURE_X86 +/* Prototype for personality(2). Done inline here since the header file + * for this isn't available on old versions of glibc. */ +int personality (unsigned long); #endif size_t os_vm_page_size; @@ -160,56 +151,43 @@ Please use a more recent kernel or a version of SBCL without threading support.\ #endif os_vm_page_size = getpagesize(); -#ifdef LISP_FEATURE_LINUX /* KLUDGE: Disable memory randomization on new Linux kernels * by setting a personality flag and re-executing. (We need * to re-execute, since the memory maps that can conflict with * the SBCL spaces have already been done at this point). + * + * Since randomization is currently implemented only on x86 kernels, + * don't do this trick on other platforms. */ +#ifdef LISP_FEATURE_X86 if ((major_version == 2 && minor_version >= 6) - || major_version >= 3) { /* i.e., if running on Linux which is new - * enough to have */ -#if PERSONALITY_SUPPORTED_AT_COMPILE_TIME - { - long pers = personality(-1); - /* 0x40000 aka. ADDR_NO_RANDOMIZE */ - if (!(pers & 0x40000)) { - if (personality(pers | 0x40000) != -1) { - /* Use /proc/self/exe instead of trying to figure out - * the executable path from PATH and argv[0], since - * that's unreliable. We follow the symlink instead of - * executing the file directly in order to prevent top - * from displaying the name of the process as "exe". */ - char runtime[PATH_MAX+1]; - int i = readlink("/proc/self/exe", runtime, PATH_MAX); - if (i != -1) { - runtime[i] = '\0'; - execve(runtime, argv, envp); - } + || major_version >= 3) + { + long pers = personality(-1); + /* 0x40000 aka. ADDR_NO_RANDOMIZE */ + if (!(pers & 0x40000)) { + if (personality(pers | 0x40000) != -1) { + /* Use /proc/self/exe instead of trying to figure out + * the executable path from PATH and argv[0], since + * that's unreliable. We follow the symlink instead of + * executing the file directly in order to prevent top + * from displaying the name of the process as "exe". */ + char runtime[PATH_MAX+1]; + int i = readlink("/proc/self/exe", runtime, PATH_MAX); + if (i != -1) { + runtime[i] = '\0'; + execve(runtime, argv, envp); } - /* Either changing the personality or execve() failed. Either - * way we might as well continue, and hope that the random - * memory maps are ok this time around. - */ - fprintf(stderr, "WARNING: Couldn't re-execute SBCL with the proper personality flags (maybe /proc isn't mounted?). Trying to continue anyway.\n"); } + /* Either changing the personality or execve() failed. Either + * way we might as well continue, and hope that the random + * memory maps are ok this time around. + */ + fprintf(stderr, "WARNING: Couldn't re-execute SBCL with the proper personality flags (maybe /proc isn't mounted?). Trying to continue anyway.\n"); } -#else - /* KLUDGE: This doesn't seem like a particularly clever thing - * to do, but I can't think of anything better at the moment. - * One rigorously-correct-seeming possibility would be to have - * personality() stuff be suppressed only at the explicit - * request of the builder (in customize-target-features.lisp), - * and then simply continue here without error, on the theory - * that the builder knew what he was doing. But even to me - * that seems like a lot of trouble to put the user to in the - * common case when he's building on the same system he's - * running on. -- WHN */ - lose("This SBCL executable was built on some system too old to have , and running it on this newer system which has is unsupported. Consider rebuilding SBCL from source on the new system."); -#endif } -} #endif +} #ifdef LISP_FEATURE_ALPHA diff --git a/version.lisp-expr b/version.lisp-expr index 46f68ff..1c1be47 100644 --- a/version.lisp-expr +++ b/version.lisp-expr @@ -17,4 +17,4 @@ ;;; checkins which aren't released. (And occasionally for internal ;;; versions, especially for internal versions off the main CVS ;;; branch, it gets hairier, e.g. "0.pre7.14.flaky4.13".) -"0.9.4.84" +"0.9.4.85" -- 1.7.10.4