3 #define branch(mask,_v1,_v2) \
8 asm volatile( " alr %[b1],%[b2]\n\t" \
9 " brc " #mask " ,1f\n\t" \
10 " mvi %[taken],0\n\t" \
12 "1: mvi %[taken],1\n\t" \
13 "0: bcr 0,0 /* nop */\n\t" \
14 : [taken] "=Q" (taken), [b1] "+d"(b1) \
27 printf("Test #1 cc == 0\n");
31 if (branch(0, v1
, v2
)) ++wrong
; else ++ok
;
32 if (branch(1, v1
, v2
)) ++wrong
; else ++ok
;
33 if (branch(2, v1
, v2
)) ++wrong
; else ++ok
;
34 if (branch(3, v1
, v2
)) ++wrong
; else ++ok
;
35 if (branch(4, v1
, v2
)) ++wrong
; else ++ok
;
36 if (branch(5, v1
, v2
)) ++wrong
; else ++ok
;
37 if (branch(6, v1
, v2
)) ++wrong
; else ++ok
;
38 if (branch(7, v1
, v2
)) ++wrong
; else ++ok
;
39 if (branch(8, v1
, v2
)) ++ok
; else ++wrong
;
40 if (branch(9, v1
, v2
)) ++ok
; else ++wrong
;
41 if (branch(10, v1
, v2
)) ++ok
; else ++wrong
;
42 if (branch(11, v1
, v2
)) ++ok
; else ++wrong
;
43 if (branch(12, v1
, v2
)) ++ok
; else ++wrong
;
44 if (branch(13, v1
, v2
)) ++ok
; else ++wrong
;
45 if (branch(14, v1
, v2
)) ++ok
; else ++wrong
;
46 if (branch(15, v1
, v2
)) ++ok
; else ++wrong
;
48 if (wrong
!= 0 || ok
!= 16)
60 printf("Test #2 cc == 1\n");
65 if (branch(0, v1
, v2
)) ++wrong
; else ++ok
;
66 if (branch(1, v1
, v2
)) ++wrong
; else ++ok
;
67 if (branch(2, v1
, v2
)) ++wrong
; else ++ok
;
68 if (branch(3, v1
, v2
)) ++wrong
; else ++ok
;
69 if (branch(4, v1
, v2
)) ++ok
; else ++wrong
;
70 if (branch(5, v1
, v2
)) ++ok
; else ++wrong
;
71 if (branch(6, v1
, v2
)) ++ok
; else ++wrong
;
72 if (branch(7, v1
, v2
)) ++ok
; else ++wrong
;
73 if (branch(8, v1
, v2
)) ++wrong
; else ++ok
;
74 if (branch(9, v1
, v2
)) ++wrong
; else ++ok
;
75 if (branch(10, v1
, v2
)) ++wrong
; else ++ok
;
76 if (branch(11, v1
, v2
)) ++wrong
; else ++ok
;
77 if (branch(12, v1
, v2
)) ++ok
; else ++wrong
;
78 if (branch(13, v1
, v2
)) ++ok
; else ++wrong
;
79 if (branch(14, v1
, v2
)) ++ok
; else ++wrong
;
80 if (branch(15, v1
, v2
)) ++ok
; else ++wrong
;
82 if (wrong
!= 0 || ok
!= 16)
94 printf("Test #3 cc == 2\n");
101 if (branch(0, v1
, v2
)) ++wrong
; else ++ok
;
102 if (branch(1, v1
, v2
)) ++wrong
; else ++ok
;
103 if (branch(2, v1
, v2
)) ++ok
; else ++wrong
;
104 if (branch(3, v1
, v2
)) ++ok
; else ++wrong
;
105 if (branch(4, v1
, v2
)) ++wrong
; else ++ok
;
106 if (branch(5, v1
, v2
)) ++wrong
; else ++ok
;
107 if (branch(6, v1
, v2
)) ++ok
; else ++wrong
;
108 if (branch(7, v1
, v2
)) ++ok
; else ++wrong
;
109 if (branch(8, v1
, v2
)) ++wrong
; else ++ok
;
110 if (branch(9, v1
, v2
)) ++wrong
; else ++ok
;
111 if (branch(10, v1
, v2
)) ++ok
; else ++wrong
;
112 if (branch(11, v1
, v2
)) ++ok
; else ++wrong
;
113 if (branch(12, v1
, v2
)) ++wrong
; else ++ok
;
114 if (branch(13, v1
, v2
)) ++wrong
; else ++ok
;
115 if (branch(14, v1
, v2
)) ++ok
; else ++wrong
;
116 if (branch(15, v1
, v2
)) ++ok
; else ++wrong
;
118 if (wrong
!= 0 /* || ok != 16 */)
130 printf("Test #4 cc == 3\n");
137 if (branch(0, v1
, v2
)) ++wrong
; else ++ok
;
138 if (branch(1, v1
, v2
)) ++ok
; else ++wrong
;
139 if (branch(2, v1
, v2
)) ++wrong
; else ++ok
;
140 if (branch(3, v1
, v2
)) ++ok
; else ++wrong
;
141 if (branch(4, v1
, v2
)) ++wrong
; else ++ok
;
142 if (branch(5, v1
, v2
)) ++ok
; else ++wrong
;
143 if (branch(6, v1
, v2
)) ++wrong
; else ++ok
;
144 if (branch(7, v1
, v2
)) ++ok
; else ++wrong
;
145 if (branch(8, v1
, v2
)) ++wrong
; else ++ok
;
146 if (branch(9, v1
, v2
)) ++ok
; else ++wrong
;
147 if (branch(10, v1
, v2
)) ++wrong
; else ++ok
;
148 if (branch(11, v1
, v2
)) ++ok
; else ++wrong
;
149 if (branch(12, v1
, v2
)) ++wrong
; else ++ok
;
150 if (branch(13, v1
, v2
)) ++ok
; else ++wrong
;
151 if (branch(14, v1
, v2
)) ++wrong
; else ++ok
;
152 if (branch(15, v1
, v2
)) ++ok
; else ++wrong
;
154 if (wrong
!= 0 || ok
!= 16)