OLD | NEW |
1 ; Trivial smoke test of bitcast between integer and FP types. | 1 ; Trivial smoke test of bitcast between integer and FP types. |
2 | 2 |
3 ; RUN: %llvm2ice -O2 --verbose none %s | FileCheck %s | 3 ; TODO(jvoung): remove -ffunction-sections. Sadly... diassembling some |
4 ; RUN: %llvm2ice -O2 --verbose none %s \ | 4 ; "ret" within a section are broken in llvm-objdump for LLVM 3.4, and 3.5. |
5 ; RUN: | llvm-mc -triple=i686-none-nacl -x86-asm-syntax=intel -filetype=obj | 5 ; It was only fixed in 3.6. |
6 ; RUN: %llvm2ice -Om1 --verbose none %s \ | 6 |
7 ; RUN: | llvm-mc -triple=i686-none-nacl -x86-asm-syntax=intel -filetype=obj | 7 ; RUN: %llvm2ice -O2 --verbose none -ffunction-sections %s \ |
| 8 ; RUN: | llvm-mc -triple=i686-none-nacl -x86-asm-syntax=intel -filetype=obj \ |
| 9 ; RUN: | llvm-objdump -d --symbolize -x86-asm-syntax=intel - | FileCheck %s |
| 10 ; RUN: %llvm2ice -Om1 --verbose none -ffunction-sections %s \ |
| 11 ; RUN: | llvm-mc -triple=i686-none-nacl -x86-asm-syntax=intel -filetype=obj \ |
| 12 ; RUN: | llvm-objdump -d --symbolize -x86-asm-syntax=intel - | FileCheck %s |
8 ; RUN: %llvm2ice --verbose none %s | FileCheck --check-prefix=ERRORS %s | 13 ; RUN: %llvm2ice --verbose none %s | FileCheck --check-prefix=ERRORS %s |
9 ; RUN: %llvm2iceinsts %s | %szdiff %s | FileCheck --check-prefix=DUMP %s | 14 ; RUN: %llvm2iceinsts %s | %szdiff %s | FileCheck --check-prefix=DUMP %s |
10 ; RUN: %llvm2iceinsts --pnacl %s | %szdiff %s \ | 15 ; RUN: %llvm2iceinsts --pnacl %s | %szdiff %s \ |
11 ; RUN: | FileCheck --check-prefix=DUMP %s | 16 ; RUN: | FileCheck --check-prefix=DUMP %s |
12 | 17 |
13 define internal i32 @cast_f2i(float %f) { | 18 define internal i32 @cast_f2i(float %f) { |
14 entry: | 19 entry: |
15 %v0 = bitcast float %f to i32 | 20 %v0 = bitcast float %f to i32 |
16 ret i32 %v0 | 21 ret i32 %v0 |
17 } | 22 } |
(...skipping 18 matching lines...) Expand all Loading... |
36 ; CHECK-LABEL: cast_d2ll | 41 ; CHECK-LABEL: cast_d2ll |
37 ; CHECK: mov edx | 42 ; CHECK: mov edx |
38 ; CHECK: ret | 43 ; CHECK: ret |
39 | 44 |
40 define internal i64 @cast_d2ll_const() { | 45 define internal i64 @cast_d2ll_const() { |
41 entry: | 46 entry: |
42 %v0 = bitcast double 0x12345678901234 to i64 | 47 %v0 = bitcast double 0x12345678901234 to i64 |
43 ret i64 %v0 | 48 ret i64 %v0 |
44 } | 49 } |
45 ; CHECK-LABEL: cast_d2ll_const | 50 ; CHECK-LABEL: cast_d2ll_const |
46 ; CHECK: movsd xmm{{.*}}, {{.*}}L$double | 51 ; CHECK: movsd xmm{{.*}}, qword ptr |
47 ; CHECK: mov edx | 52 ; CHECK: mov edx |
48 ; CHECK: ret | 53 ; CHECK: ret |
49 | 54 |
50 define internal double @cast_ll2d(i64 %ll) { | 55 define internal double @cast_ll2d(i64 %ll) { |
51 entry: | 56 entry: |
52 %v0 = bitcast i64 %ll to double | 57 %v0 = bitcast i64 %ll to double |
53 ret double %v0 | 58 ret double %v0 |
54 } | 59 } |
55 ; CHECK-LABEL: cast_ll2d | 60 ; CHECK-LABEL: cast_ll2d |
56 ; CHECK: fld qword ptr | 61 ; CHECK: fld qword ptr |
57 ; CHECK: ret | 62 ; CHECK: ret |
58 | 63 |
59 define internal double @cast_ll2d_const() { | 64 define internal double @cast_ll2d_const() { |
60 entry: | 65 entry: |
61 %v0 = bitcast i64 12345678901234 to double | 66 %v0 = bitcast i64 12345678901234 to double |
62 ret double %v0 | 67 ret double %v0 |
63 } | 68 } |
64 ; CHECK-LABEL: cast_ll2d_const | 69 ; CHECK-LABEL: cast_ll2d_const |
65 ; CHECK: mov {{.*}}, 1942892530 | 70 ; CHECK: mov {{.*}}, 1942892530 |
66 ; CHECK: mov {{.*}}, 2874 | 71 ; CHECK: mov {{.*}}, 2874 |
67 ; CHECK: fld qword ptr | 72 ; CHECK: fld qword ptr |
68 ; CHECK: ret | 73 ; CHECK: ret |
69 | 74 |
70 ; ERRORS-NOT: ICE translation error | 75 ; ERRORS-NOT: ICE translation error |
71 ; DUMP-NOT: SZ | 76 ; DUMP-NOT: SZ |
OLD | NEW |