blob: aa85d01030576dd87952aed34cd22388a20ad2b0 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
// RUN: %llvmgcc -D_TESTINGUTILS_TEST %s -o %t
// RUN: %t | FileCheck %s
// XFAIL:
int printf(const char *fmt, ...);
void print_int(unsigned long long val);
#define TYPED_PRINT(_name_type, _arg_type) \
void print_ ## _name_type(_arg_type val) { print_int(val); }
TYPED_PRINT(i1, unsigned char)
TYPED_PRINT(i8, unsigned char)
TYPED_PRINT(i16, unsigned short)
TYPED_PRINT(i32, unsigned int)
TYPED_PRINT(i64, unsigned long long)
// This is a workaround to hide the "%c" only format string from the compiler --
// llvm-gcc can optimize this into putchar even at -O0, and the LLVM JIT doesn't
// recognize putchar() as a valid external function.
char *char_format_string = "%c";
void print_int(unsigned long long val) {
int cur = 1;
// effectively do a log (can't call log because it returns floats)
// do the nasty divide to prevent overflow
while (cur <= val / 10)
cur *= 10;
while (cur) {
int digit = val / cur;
printf(char_format_string, digit + '0');
val = val % cur;
cur /= 10;
}
printf(char_format_string, '\n');
}
#ifdef _TESTINGUTILS_TEST
int main(int argc, char *argv[])
{
print_i64(0xf000000000000064);
// CHECK: 17293822569102704740
print_i64(0x7000000000000064);
// CHECK: 8070450532247928932
print_i32(0xf0000032);
// CHECK: 4026531890
print_i32(0x70000032);
// CHECK: 1879048242
print_i16(0xf016);
// CHECK: 61462
print_i16(0x7016);
// CHECK: 28694
print_i8(0xf8);
// CHECK: 248
print_i8(0x78);
// CHECK: 120
printf("print_i1(0)\n");
print_i1(0);
// CHECK: i1(0)
// CHECK_NEXT: 0
printf("print_i1(1)\n");
print_i1(1);
// CHECK: i1(1)
// CHECK_NEXT: 1
}
#endif
|