1 #include <stdio.h>
2
3 #define get_cc() \
4 ({ \
5 char __cc; \
6 /* don't use IPM to better test spechelpers */ \
7 asm volatile( "brc 8,1f\n\t" \
8 "brc 4,2f\n\t" \
9 "brc 2,3f\n\t" \
10 "brc 1,4f\n\t" \
11 "mvi %0,4\n\t" \
12 "j 0f\n\t" \
13 "1: mvi %0,0\n\t" \
14 "j 0f\n\t" \
15 "2: mvi %0,1\n\t" \
16 "j 0f\n\t" \
17 "3: mvi %0,2\n\t" \
18 "j 0f\n\t" \
19 "4: mvi %0,3\n\t" \
20 "j 0f\n\t" \
21 "0: /* nop */ brc 0,0\n\t" \
22 : "=m" (__cc) : : "memory"); \
23 __cc; \
24 })
25
check_cc(int value,int cc)26 void check_cc(int value, int cc)
27 {
28 if (cc != value) {
29 printf("wrong cc: ");
30 if (value == 0) printf("expected 0 ");
31 if (value == 1) printf("expected 1 ");
32 if (value == 2) printf("expected 2 ");
33 if (value == 3) printf("expected 3 ");
34 if (cc == 0) printf("got 0");
35 if (cc == 1) printf("got 1");
36 if (cc == 2) printf("got 2");
37 if (cc == 3) printf("got 3");
38 } else {
39 printf("OK");
40 }
41 printf("\n");
42 }
43
tmll(void)44 void tmll(void)
45 {
46 unsigned long v;
47
48 /* test #1: value is zero, all bits selected */
49 v = 0;
50 asm volatile( "tmll %[v],0xFFFF\n\t" : : [v] "d"(v) : "cc");
51 check_cc(0, get_cc());
52
53 /* test #2: value is all-ones, mask is zero */
54 v = 0xFFFF;
55 asm volatile( "tmll %[v],0\n\t" : : [v] "d"(v) : "cc");
56 check_cc(0, get_cc());
57
58 /* test #3: selected bits are 0 */
59 v = 0x0F;
60 asm volatile( "tmll %[v],0xf0\n\t" : : [v] "d"(v) : "cc");
61 check_cc(0, get_cc());
62
63 /* test #4: selected bits are all 1 */
64 v = 0xF0;
65 asm volatile( "tmll %[v],0x70\n\t" : : [v] "d"(v) : "cc");
66 check_cc(3, get_cc());
67
68 /* test #5: selected bits are mixed, leftmost bit is 0 */
69 v = 0x0F;
70 asm volatile( "tmll %[v],0x81\n\t" : : [v] "d"(v) : "cc");
71 check_cc(1, get_cc());
72
73 /* test #6: selected bits are mixed, leftmost bit is 1 */
74 v = 0xF0;
75 asm volatile( "tmll %[v],0x81\n\t" : : [v] "d"(v) : "cc");
76 check_cc(2, get_cc());
77 }
78
main(void)79 int main(void)
80 {
81 tmll();
82
83 return 0;
84 }
85