2N/A\ #ident "%Z%%M% %I% %E% SMI"
2N/A\ purpose:
2N/A\ copyright: Copyright 2005 Sun Microsystems, Inc. All rights reserved.
2N/A\ copyright: Use is subject to license terms.
2N/A\ copyright:
2N/A\ copyright: CDDL HEADER START
2N/A\ copyright:
2N/A\ copyright: The contents of this file are subject to the terms of the
2N/A\ copyright: Common Development and Distribution License, Version 1.0 only
2N/A\ copyright: (the "License"). You may not use this file except in compliance
2N/A\ copyright: with the License.
2N/A\ copyright:
2N/A\ copyright: You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
2N/A\ copyright: or http://www.opensolaris.org/os/licensing.
2N/A\ copyright: See the License for the specific language governing permissions
2N/A\ copyright: and limitations under the License.
2N/A\ copyright:
2N/A\ copyright: When distributing Covered Code, include this CDDL HEADER in each
2N/A\ copyright: file and include the License file at usr/src/OPENSOLARIS.LICENSE.
2N/A\ copyright: If applicable, add the following below this CDDL HEADER, with the
2N/A\ copyright: fields enclosed by brackets "[]" replaced with your own identifying
2N/A\ copyright: information: Portions Copyright [yyyy] [name of copyright owner]
2N/A\ copyright:
2N/A\ copyright: CDDL HEADER END
2N/A\ copyright:
2N/A
2N/A." Simple 0 Logic Tests: "
2N/A " 0 invert" 0 invert .passed?
2N/A " 0 0=" 0 0= .passed?
2N/A " -1 invert" -1 invert 0= .passed?
2N/A " 1 0<>" 1 0<> .passed?
2N/A " 1 0=" 1 0= invert .passed?
2N/A " 1 0<>" 1 0<> .passed?
2N/A " 0 0>=" 0 0>= .passed?
2N/A " 1 0>=" 1 0>= .passed?
2N/A " -1 0>=" -1 0>= invert .passed?
2N/A " 1 0>" 1 0> .passed?
2N/A " 0 0>" 0 0> invert .passed?
2N/A " -1 0<" -1 0< .passed?
2N/A " 0 0<" 0 0< invert .passed?
2N/A " 0 0<=" 0 0<= .passed?
2N/A " -1 0<=" -1 0<= .passed?
2N/A " 1 0<=" 1 0<= invert .passed?
2N/Acr
2N/A
2N/A." Positive Arithmetic Comparision Tests: "
2N/A " 1 0 >" 1 0 > .passed?
2N/A " 1 1 >=" 1 1 >= .passed?
2N/A " 1 1 >" 1 1 > invert .passed?
2N/A " 0 1 <" 0 1 < .passed?
2N/A " 0 0 <=" 0 0 <= .passed?
2N/A " 1 0 <" 1 0 < invert .passed?
2N/A " 0 0 =" 0 0 = .passed?
2N/A " 0 1 =" 0 1 = invert .passed?
2N/A " 0 1 <>" 0 1 <> .passed?
2N/A " 1 1 <>" 1 1 <> invert .passed?
2N/Acr
2N/A
2N/A." Signed Comparison Tests: "
2N/A " -1 1 >" -1 1 > invert .passed?
2N/A " -1 -2 >" -1 -2 > .passed?
2N/A " -1 0 <" -1 0 < .passed?
2N/A " -2 -1 <" -2 -1 < .passed?
2N/Acr
2N/A
2N/A." Unsigned Comparison Tests: "
2N/A " -1 0 u>" -1 0 u> .passed?
2N/A " -1 0 u>=" 1 1 u>= .passed?
2N/A " 1 -1 <" 2 1 >= .passed?
2N/A " 0 1 >=" 0 1 >= invert .passed?
2N/A " 0 -1 u<" 0 -1 u< .passed?
2N/A " 0 -1 u<=" 0 -1 u<= .passed?
2N/A " 2 -2 u<=" 2 -2 u<= .passed?
2N/Acr
2N/A
2N/A." Arithmetic Tests: "
2N/A " 1 1 +" 1 1 + 2 = .passed?
2N/A " 1 1 -" 1 1 - 0 = .passed?
2N/A " 1 negate " 1 negate 1+ 0= .passed?
2N/A " 0 1 -" 0 1 - -1 = .passed?
2N/A " -1 abs" -1 abs 1 = .passed?
2N/A " -1 2 min" -1 2 min 1+ 0= .passed?
2N/A " 2 -1 min" 2 -1 min 1+ 0= .passed?
2N/A " 3 2 max" 3 2 max 3 = .passed?
2N/A " 2 3 max" 2 3 max 3 = .passed?
2N/Acr
2N/A
2N/A." Binary Logic: "
2N/A " 3 1 and" 3 1 and 1 = .passed?
2N/A " 2 1 and" 2 1 and 0= .passed?
2N/A " 1 1 or" 1 1 or 1 = .passed?
2N/A " 3 1 xor" 3 1 xor 2 = .passed?
2N/Acr
2N/A
2N/A." Shifting: "
2N/A " (short) lshift" h# 11 8 lshift h# 1100 = .passed?
2N/A " (short) rshift" h# 1122 8 rshift h# 11 = .passed?
2N/A " (long) lshift" h# 1 d# 31 lshift 1- h# 7fffffff = .passed?
2N/A " (long) rshift" h# 80 d# 24 lshift d# 31 rshift 1 = .passed?
2N/A " >>a" -4 1 >>a -2 = .passed?
2N/Acr
2N/A
2N/A." Sized Arithmetic Tests: "
2N/A " u2/" 0 0 0 h# 80 bljoin u2/ h# 4000.0000 = .passed?
2N/A " 2/" -4 2/ -2 = .passed?
2N/A " 2*" h# 4000.0000 dup 1 lshift swap 2* = .passed?
2N/A " /c" 1 /c = .passed?
2N/A " /w" 2 /w = .passed?
2N/A " /l" 4 /l = .passed?
2N/A " /n" 4 /n = 8 /n = or .passed?
2N/A " ca+" h# 4000 3 ca+ h# 4003 = .passed?
2N/A " wa+" h# 4000 3 wa+ h# 4006 = .passed?
2N/A " la+" h# 4000 3 la+ h# 400c = .passed?
2N/A " na+" h# 4000 3 na+ h# 4000 3 /n * + = .passed?
2N/A " char+" h# 4000 char+ h# 4001 = .passed?
2N/A " wa1+" h# 4000 wa1+ h# 4002 = .passed?
2N/A " la1+" h# 4000 la1+ h# 4004 = .passed?
2N/A " cell+" h# 4000 cell+ h# 4000 /n + = .passed?
2N/A " chars" 4 chars 4 = .passed?
2N/A " /w*" 8 /w* h# 10 = .passed?
2N/A " /l*" 4 /l* h# 10 = .passed?
2N/A " cells" 4 cells 4 /n * = .passed?
2N/Acr
2N/A
2N/A." Division related Tests: "
2N/A " /mod (+ +)" 5 2 /mod 2 = swap 1 = and .passed?
2N/A " /mod (- -)" -5 -2 /mod 2 = swap -1 = and .passed?
2N/A " /mod (+ -)" 5 -2 /mod -3 = swap -1 = and .passed?
2N/A " /mod (- +)" -5 2 /mod -3 = swap 1 = and .passed?
2N/A " / (+ +)" 5 2 / 2 = .passed?
2N/A " / (- -)" -5 -2 / 2 = .passed?
2N/A " / (+ -)" 5 -2 / -3 = .passed?
2N/A " / (- +)" -5 2 / -3 = .passed?
2N/A " mod (+ +)" 5 2 mod 1 = .passed?
2N/A " mod (- -)" -5 -2 mod -1 = .passed?
2N/A " mod (+ -)" 5 -2 mod -1 = .passed?
2N/A " mod (- +)" -5 2 mod 1 = .passed?
2N/Acr
2N/A
2N/A." Signed Multiply/Divide Tests:"
2N/A " * (+ +)" 2 3 * 6 = .passed?
2N/A " * (- +)" -3 3 * -9 = .passed?
2N/A " * (+ -)" 4 -2 * -8 = .passed?
2N/A " * (- -)" -4 -3 * 12 = .passed?
2N/Acr
2N/A
2N/A." Unsigned Multiply/Divide Tests: "
2N/A " um*" 1 2 um* 0= swap 2 = and .passed?
2N/A " um/mod" 5 0 2 um/mod 2 = swap 1 = and .passed?
2N/A " u/mod" 5 2 u/mod 2 = swap 1 = and .passed?
2N/Acr
2N/A
2N/A." Ranged Tests: "
2N/A " within (!0)" 2 1 3 within .passed?
2N/A " within (0 hi)" 3 1 3 within 0= .passed?
2N/A " within (!0 lo)" 1 1 3 within .passed?
2N/A " within (0 >)" 0 1 3 within 0= .passed?
2N/A " within (0 <)" 4 1 3 within 0= .passed?
2N/A " within (-ve)" 0 -5 5 within .passed?
2N/A " within (- -)" -7 -10 -5 within .passed?
2N/A " between (!0)" 2 1 3 between .passed?
2N/A " between (!0 lo)" 1 1 3 between .passed?
2N/A " between (!0 hi)" 3 1 3 between .passed?
2N/A " between (0 >)" 4 1 3 between 0= .passed?
2N/A " between (0 <)" 0 1 3 between 0= .passed?
2N/A " between (-ve)" 0 -5 5 between .passed?
2N/A " between (- -)" -7 -10 -5 between .passed?
2N/A " bounds" -1 3 bounds -1 = swap 2 = and .passed?
2N/Acr
2N/A
2N/A." Double Arithmetic: "
2N/A " d+" 1 2 3 4 d+ 6 = swap 4 = and .passed?
2N/A " d-" 3 4 2 1 d- 3 = swap 1 = and .passed?
2N/Acr