X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fforeign-stack-alignment.impure.lisp;h=ee14cd9b8341c56572162fff0370a8b41e0afb30;hb=0b3f5cc5fa9e6b121d232960ccd964d2eb15f695;hp=2ed55a3f432d37802844056fbbcc44aad285f63e;hpb=af6edc5adaeac6535c88cfaa81fcfb5b20734ab8;p=sbcl.git diff --git a/tests/foreign-stack-alignment.impure.lisp b/tests/foreign-stack-alignment.impure.lisp index 2ed55a3..ee14cd9 100644 --- a/tests/foreign-stack-alignment.impure.lisp +++ b/tests/foreign-stack-alignment.impure.lisp @@ -22,7 +22,7 @@ (output (with-output-to-string (s) (setf proc (run-program program arguments - :search (not (eql #\. (char program 0))) + :environment (test-util::test-env) :output s))))) (unless (zerop (process-exit-code proc)) (error "Bad exit code: ~S~%Output:~% ~S" @@ -32,38 +32,48 @@ (defvar *required-alignment* #+(and ppc darwin) 16 - #+(and ppc linux) 16 - #+(or mips x86-64) 8 - #+x86 4 - #-(or x86 x86-64 mips (and ppc (or darwin linux))) (error "Unknown platform")) + #+(and ppc (not darwin)) 8 + #+x86-64 16 + #+mips 8 + #+(and x86 (not darwin)) 4 + #+(and x86 darwin) 16 + #-(or x86 x86-64 mips ppc) (error "Unknown platform")) ;;;; Build the offset-tool as regular excutable, and run it with ;;;; fork/exec, so that no lisp is on the stack. This is our known-good ;;;; number. -(run "cc" "stack-alignment-offset.c" "-o" "stack-alignment-offset") +#-win32 +(progn + (run "/bin/sh" "run-compiler.sh" "-sbcl-pic" + "stack-alignment-offset.c" "-o" "stack-alignment-offset") -(defparameter *good-offset* - (parse-integer (run "./stack-alignment-offset" - (princ-to-string *required-alignment*)))) + (defparameter *good-offset* + (parse-integer (run "./stack-alignment-offset" + (princ-to-string *required-alignment*)))) -;;;; Build the tool again, this time as a shared object, and load it + ;; Build the tool again, this time as a shared object, and load it -(run "cc" "stack-alignment-offset.c" - #+darwin "-bundle" #-darwin "-shared" - "-o" "stack-alignment-offset.so") + (run "/bin/sh" "run-compiler.sh" "-sbcl-pic" "-sbcl-shared" + "stack-alignment-offset.c" "-o" "stack-alignment-offset.so") -(load-shared-object "stack-alignment-offset.so") + (load-shared-object (truename "stack-alignment-offset.so")) -(define-alien-routine stack-alignment-offset int (alignment int)) -(define-alien-routine trampoline int (callback (function int))) + (define-alien-routine stack-alignment-offset int (alignment int)) + (define-alien-routine trampoline int (callback (function int)))) ;;;; Now get the offset by calling from lisp, first with a regular foreign function ;;;; call, then with an intervening callback. -(assert (= *good-offset* (stack-alignment-offset *required-alignment*))) +(with-test (:name :regular :fails-on :win32) + (assert (= *good-offset* (stack-alignment-offset *required-alignment*)))) -(assert (= *good-offset* (trampoline (alien-lambda int () - (stack-alignment-offset *required-alignment*))))) +(with-test (:name :callback :fails-on :win32) + (assert (= *good-offset* (trampoline (alien-lambda int () + (stack-alignment-offset *required-alignment*)))))) + +(when (probe-file "stack-alignment-offset.so") + (delete-file "stack-alignment-offset") + (delete-file "stack-alignment-offset.so")) ;;;; success!