X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fdynamic-extent.impure.lisp;h=3ac193fbaebdc3e10a2a5f04228a9de692967b19;hb=81e608991b9f616a412564b26186fa29933d814c;hp=0b1b6f6dab2baa0cadcce8d20ab705854b796e92;hpb=175c318c892b0627b36fa3c4db66f59680242204;p=sbcl.git diff --git a/tests/dynamic-extent.impure.lisp b/tests/dynamic-extent.impure.lisp index 0b1b6f6..3ac193f 100644 --- a/tests/dynamic-extent.impure.lisp +++ b/tests/dynamic-extent.impure.lisp @@ -11,6 +11,9 @@ ;;;; absolutely no warranty. See the COPYING and CREDITS files for ;;;; more information. +(when (eq sb-ext:*evaluator-mode* :interpret) + (sb-ext:quit :unix-status 104)) + (setq sb-c::*check-consistency* t) (defmacro defun-with-dx (name arglist &body body) @@ -123,6 +126,33 @@ (assert (eq t (dxclosure 13))) +;;; value-cells + +(defun-with-dx dx-value-cell (x) + ;; Not implemented everywhere, yet. + #+(or x86 x86-64) + (let ((cell x)) + (declare (dynamic-extent cell)) + (flet ((f () + (incf cell))) + (declare (dynamic-extent #'f)) + (true #'f)))) + +;;; with-spinlock should use DX and not cons + +(defvar *slock* (sb-thread::make-spinlock :name "slocklock")) + +(defun test-spinlock () + (sb-thread::with-spinlock (*slock*) + (true *slock*))) + +;;; not really DX, but GETHASH and (SETF GETHASH) should not cons + +(defvar *table* (make-hash-table)) + +(defun test-hash-table () + (setf (gethash 5 *table*) 13) + (gethash 5 *table*)) (defmacro assert-no-consing (form &optional times) `(%assert-no-consing (lambda () ,form) ,times)) @@ -134,7 +164,7 @@ (funcall thunk)) (assert (< (- (get-bytes-consed) before) times)))) -#+(or x86 x86-64 alpha ppc sparc) +#+(or x86 x86-64 alpha ppc sparc mips) (progn (assert-no-consing (dxclosure 42)) (assert-no-consing (dxlength 1 2 3)) @@ -144,7 +174,12 @@ (assert-no-consing (test-nip-values)) (assert-no-consing (test-let-var-subst1 17)) (assert-no-consing (test-let-var-subst2 17)) - (assert-no-consing (test-lvar-subst 11))) + (assert-no-consing (test-lvar-subst 11)) + (assert-no-consing (dx-value-cell 13)) + ;; Not strictly DX.. + (assert-no-consing (test-hash-table)) + #+sb-thread + (assert-no-consing (test-spinlock))) ;;; Bugs found by Paul F. Dietz