;;;; Testing swap_lispobjs. ;;;; This software is part of the SBCL system. See the README file for ;;;; more information. ;;;; ;;;; While most of SBCL is derived from the CMU CL system, the test ;;;; files (like this one) were written from scratch after the fork ;;;; from CMU CL. ;;;; ;;;; This software is in the public domain and is provided with ;;;; absolutely no warranty. See the COPYING and CREDITS files for ;;;; more information. (use-package :sb-alien) #-(or x86 x86-64) (sb-ext:exit :code 104) (defun run (program &rest arguments) (let* ((proc nil) (output (with-output-to-string (s) (setf proc (run-program program arguments :output s))))) (unless (zerop (process-exit-code proc)) (error "Bad exit code: ~S~%Output:~% ~S" (process-exit-code proc) output)) output)) (with-test (:name :swap-lispobjs/prepare :broken-on :win32) (run "/bin/sh" "run-compiler.sh" "-sbcl-pic" "-sbcl-shared" "-O3" "-I" "../src/runtime/" "swap-lispobjs.c" "-o" "swap-lispobjs.so") (load-shared-object (truename "swap-lispobjs.so")) (define-alien-routine try-to-zero-with-swap-lispobjs int (lispobj-adress unsigned-long))) (with-test (:name :swap-lispobjs :fails-on :win32) (let ((x (cons 13 27))) (try-to-zero-with-swap-lispobjs (logandc2 (sb-kernel:get-lisp-obj-address x) sb-vm:lowtag-mask)) (assert (equal x (cons 0 27))))) (when (probe-file "swap-lispobjs.so") (delete-file "swap-lispobjs.so"))