X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=contrib%2Fsb-rotate-byte%2Frotate-byte-tests.lisp;h=252e06d0590e9b2f29c4f38ac68a2d65ccef2ed9;hb=22a6702974b7d6ff4e8f2b3b7b5ff446fc632de0;hp=bf463ad399177d8b1d4915681f6f1ce06cf50214;hpb=cec71f1e4e1ead387f2ea642f760e553b6053f2b;p=sbcl.git diff --git a/contrib/sb-rotate-byte/rotate-byte-tests.lisp b/contrib/sb-rotate-byte/rotate-byte-tests.lisp index bf463ad..252e06d 100644 --- a/contrib/sb-rotate-byte/rotate-byte-tests.lisp +++ b/contrib/sb-rotate-byte/rotate-byte-tests.lisp @@ -25,7 +25,7 @@ (defun pfixnum (count integer) (declare (type (unsigned-byte 29) integer) - (type (integer -31 31) count)) + (type (integer -31 31) count)) (rotate-byte count (byte 32 0) integer)) (assert (= (pfixnum 5 5) 160)) @@ -44,10 +44,24 @@ (defun ub32 (count integer) (declare (type (unsigned-byte 32) integer) - (type (integer -31 31) count)) + (type (integer -31 31) count)) (rotate-byte count (byte 32 0) integer)) (assert (= (ub32 5 5) 160)) (assert (= (ub32 5 1) 32)) (assert (= (ub32 5 (ash 1 26)) (ash 1 31))) (assert (= (ub32 5 (ash 1 27)) 1)) + +;;; test with (contrived) register pressure on the x86 to ensure that the +;;; rotatee doesn't get clobbered by the count. + +(defun ub32-reg-pressure (count integer) + (declare (type (unsigned-byte 32) integer) + (type (integer -31 31) count)) + (rotate-byte count (byte 32 0) (ldb (byte 32 0) (+ (* 67 count) + integer)))) + +(assert (= (ub32-reg-pressure 1 5) 144)) +(assert (= (ub32-reg-pressure 5 5) 10880)) +(assert (= (ub32-reg-pressure 5 (ash 1 26)) 2147494368)) +(assert (= (ub32-reg-pressure 5 (ash 1 27)) 10721))