Index: tests_lit/llvm2ice_tests/bitcast.ll |
diff --git a/tests_lit/llvm2ice_tests/bitcast.ll b/tests_lit/llvm2ice_tests/bitcast.ll |
index 40a654cbfeea55d82c7ccc693b5be1c635e805db..388afb1d65f56303270a7a5d524a94eb45786646 100644 |
--- a/tests_lit/llvm2ice_tests/bitcast.ll |
+++ b/tests_lit/llvm2ice_tests/bitcast.ll |
@@ -3,6 +3,16 @@ |
; RUN: %p2i --filetype=obj --disassemble -i %s --args -O2 | FileCheck %s |
; RUN: %p2i --filetype=obj --disassemble -i %s --args -Om1 | FileCheck %s |
+; RUN: %if --need=allow_dump --need=target_ARM32 --command %p2i --filetype=asm \ |
+; RUN: --target arm32 -i %s --args -O2 --skip-unimplemented \ |
+; RUN: | %if --need=allow_dump --need=target_ARM32 --command FileCheck %s \ |
+; RUN: --check-prefix=ARM32 |
+ |
+; RUN: %if --need=allow_dump --need=target_ARM32 --command %p2i --filetype=asm \ |
+; RUN: --target arm32 -i %s --args -Om1 --skip-unimplemented \ |
+; RUN: | %if --need=allow_dump --need=target_ARM32 --command FileCheck %s \ |
+; RUN: --check-prefix=ARM32 |
+ |
define internal i32 @cast_f2i(float %f) { |
entry: |
%v0 = bitcast float %f to i32 |
@@ -10,6 +20,8 @@ entry: |
} |
; CHECK-LABEL: cast_f2i |
; CHECK: mov eax |
+; ARM32-LABEL: cast_f2i |
+; ARM32: vmov r{{[0-9]+}}, s{{[0-9]+}} |
define internal float @cast_i2f(i32 %i) { |
entry: |
@@ -18,6 +30,8 @@ entry: |
} |
; CHECK-LABEL: cast_i2f |
; CHECK: fld DWORD PTR |
+; ARM32-LABEL: cast_i2f |
+; ARM32: vmov s{{[0-9]+}}, r{{[0-9]+}} |
define internal i64 @cast_d2ll(double %d) { |
entry: |
@@ -26,6 +40,8 @@ entry: |
} |
; CHECK-LABEL: cast_d2ll |
; CHECK: mov edx |
+; ARM32-LABEL: cast_d2ll |
+; ARM32: vmov r{{[0-9]+}}, r{{[0-9]+}}, d{{[0-9]+}} |
define internal i64 @cast_d2ll_const() { |
entry: |
@@ -35,6 +51,11 @@ entry: |
; CHECK-LABEL: cast_d2ll_const |
; CHECK: mov e{{..}},DWORD PTR ds:0x0 {{.*}} .L$double$0 |
; CHECK: mov e{{..}},DWORD PTR ds:0x4 {{.*}} .L$double$0 |
+; ARM32-LABEL: cast_d2ll_const |
+; ARM32-DAG: movw [[ADDR:r[0-9]+]], #:lower16:.L$ |
+; ARM32-DAG: movt [[ADDR]], #:upper16:.L$ |
+; ARM32-DAG: vldr [[DREG:d[0-9]+]], {{\[}}[[ADDR]], #0{{\]}} |
+; ARM32: vmov r{{[0-9]+}}, r{{[0-9]+}}, [[DREG]] |
define internal double @cast_ll2d(i64 %ll) { |
entry: |
@@ -43,6 +64,8 @@ entry: |
} |
; CHECK-LABEL: cast_ll2d |
; CHECK: fld QWORD PTR |
+; ARM32-LABEL: cast_ll2d |
+; ARM32: vmov d{{[0-9]+}}, r{{[0-9]+}}, r{{[0-9]+}} |
define internal double @cast_ll2d_const() { |
entry: |
@@ -53,3 +76,8 @@ entry: |
; CHECK: mov {{.*}},0x73ce2ff2 |
; CHECK: mov {{.*}},0xb3a |
; CHECK: fld QWORD PTR |
+; ARM32-LABEL: cast_ll2d_const |
+; ARM32-DAG: movw [[REG0:r[0-9]+]], #12274 |
+; ARM32-DAG: movt [[REG0:r[0-9]+]], #29646 |
+; ARM32-DAG: movw [[REG1:r[0-9]+]], #2874 |
+; ARM32: vmov d{{[0-9]+}}, [[REG0]], [[REG1]] |