X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=make-config.sh;h=7fc58f01b42c6327129dc9065fe1b0801a4a304e;hb=93be0089fe7b2a9e34bf1cb6da9fe6e902769f5e;hp=9fc7c2d3e0af741846d69c3cde99984d5ac739bd;hpb=02c3d0ab1ec217b075c577cb778b3fdf7f6b9a8a;p=sbcl.git diff --git a/make-config.sh b/make-config.sh index 9fc7c2d..7fc58f0 100644 --- a/make-config.sh +++ b/make-config.sh @@ -1,4 +1,5 @@ #!/bin/sh +set -e # The make-config.sh script uses information about the target machine # to set things up for compilation. It's vaguely like a stripped-down @@ -31,6 +32,7 @@ printf '(' >> $ltf echo //guessing default target CPU architecture from host architecture case `uname -m` in *86) guessed_sbcl_arch=x86 ;; + i86pc) guessed_sbcl_arch=x86 ;; *x86_64) guessed_sbcl_arch=x86-64 ;; [Aa]lpha) guessed_sbcl_arch=alpha ;; sparc*) guessed_sbcl_arch=sparc ;; @@ -194,14 +196,16 @@ cd $original_dir # similar with :STACK-GROWS-FOOWARD, too. -- WHN 2002-03-03 if [ "$sbcl_arch" = "x86" ]; then printf ' :gencgc :stack-grows-downward-not-upward :c-stack-is-control-stack' >> $ltf - printf ' :stack-allocatable-closures' >> $ltf - if [ "$sbcl_os" = "linux" ] || [ "$sbcl_os" = "freebsd" ] || [ "$sbcl_os" = "netbsd" ]; then + printf ' :stack-allocatable-closures :alien-callbacks' >> $ltf + if [ "$sbcl_os" = "linux" ] || [ "$sbcl_os" = "freebsd" ] || [ "$sbcl_os" = "netbsd" ] || [ "$sbcl_os" = "sunos" ]; then printf ' :linkage-table' >> $ltf fi elif [ "$sbcl_arch" = "x86-64" ]; then printf ' :gencgc :stack-grows-downward-not-upward :c-stack-is-control-stack :linkage-table' >> $ltf - printf ' :stack-allocatable-closures' >> $ltf + printf ' :stack-allocatable-closures :alien-callbacks' >> $ltf elif [ "$sbcl_arch" = "mips" ]; then + printf ' :linkage-table' >> $ltf + printf ' :stack-allocatable-closures' >> $ltf # Use a little C program to try to guess the endianness. Ware # cross-compilers! # @@ -220,7 +224,7 @@ elif [ "$sbcl_arch" = "ppc" -a "$sbcl_os" = "linux" ]; then elif [ "$sbcl_arch" = "ppc" -a "$sbcl_os" = "darwin" ]; then printf ' :stack-allocatable-closures' >> $ltf # We provide a dlopen shim, so a little lie won't hurt - printf " :os-provides-dlopen :linkage-table" >> $ltf + printf " :os-provides-dlopen :linkage-table :alien-callbacks" >> $ltf # The default stack ulimit under darwin is too small to run PURIFY. # Best we can do is complain and exit at this stage if [ "`ulimit -s`" = "512" ]; then @@ -237,6 +241,7 @@ elif [ "$sbcl_arch" = "sparc" ]; then if [ "$sbcl_os" = "sunos" ] || [ "$sbcl_os" = "linux" ]; then printf ' :linkage-table' >> $ltf fi + printf ' :stack-allocatable-closures' >> $ltf elif [ "$sbcl_arch" = "alpha" ]; then printf ' :stack-allocatable-closures' >> $ltf else @@ -265,4 +270,3 @@ if [ `uname` = "SunOS" ] ; then PATH=/usr/xpg4/bin:$PATH fi echo '"'`hostname`-`id -un`-`date +%Y-%m-%d-%H-%M-%S`'"' > output/build-id.tmp -