| Index: tests_lit/llvm2ice_tests/reorder-global-variables.ll
|
| diff --git a/tests_lit/llvm2ice_tests/reorder-global-variables.ll b/tests_lit/llvm2ice_tests/reorder-global-variables.ll
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..2279c9d2ef065ef8d9f04c29b248a52fa139ef1c
|
| --- /dev/null
|
| +++ b/tests_lit/llvm2ice_tests/reorder-global-variables.ll
|
| @@ -0,0 +1,162 @@
|
| +; Test of global variable reordering.
|
| +
|
| +; REQUIRES: allow_dump
|
| +
|
| +; RUN: %if --need=target_X8632 --command %p2i --filetype=asm --target x8632 \
|
| +; RUN: -i %s --args -sz-seed=1 -O2 -reorder-global-variables \
|
| +; RUN: | %if --need=target_X8632 --command FileCheck %s \
|
| +; RUN: --check-prefix=X8632ASM
|
| +
|
| +; RUN: %if --need=target_X8632 --command %p2i --filetype=obj --target x8632 \
|
| +; RUN: -i %s --disassemble --dis-flags=-rD \
|
| +; RUN: --args -sz-seed=1 -O2 -reorder-global-variables \
|
| +; RUN: | %if --need=target_X8632 --command FileCheck %s \
|
| +; RUN: --check-prefix=X8632OBJ
|
| +
|
| +; RUN: %if --need=target_ARM32 --command %p2i --filetype=asm --target arm32 \
|
| +; RUN: -i %s --args -sz-seed=1 -O2 -reorder-global-variables \
|
| +; RUN: --skip-unimplemented \
|
| +; RUN: | %if --need=target_ARM32 --command FileCheck %s \
|
| +; RUN: --check-prefix=ARM32ASM
|
| +
|
| +; IAS is not implemented yet.
|
| +; RUN: %if --need=target_ARM32 --command %p2i --filetype=asm --target arm32 \
|
| +; RUN: -i %s --assemble --disassemble --dis-flags=-rD \
|
| +; RUN: --args -sz-seed=1 -O2 -reorder-global-variables \
|
| +; RUN: --skip-unimplemented \
|
| +; RUN: | %if --need=target_ARM32 --command FileCheck %s \
|
| +; RUN: --check-prefix=ARM32OBJ
|
| +
|
| +; RUN: %if --need=target_X8632 --command %p2i --filetype=asm --target x8632 \
|
| +; RUN: -i %s --args -sz-seed=1 -Om1 -reorder-global-variables \
|
| +; RUN: | %if --need=target_X8632 --command FileCheck %s \
|
| +; RUN: --check-prefix=X8632ASM
|
| +
|
| +; RUN: %if --need=target_X8632 --command %p2i --filetype=obj --target x8632 \
|
| +; RUN: -i %s --disassemble --dis-flags=-rD \
|
| +; RUN: --args -Om1 -sz-seed=1 -reorder-global-variables \
|
| +; RUN: | %if --need=target_X8632 --command FileCheck %s \
|
| +; RUN: --check-prefix=X8632OBJ
|
| +
|
| +; RUN: %if --need=target_ARM32 --command %p2i --filetype=asm --target arm32 \
|
| +; RUN: -i %s --args -sz-seed=1 -Om1 -reorder-global-variables \
|
| +; RUN: --skip-unimplemented \
|
| +; RUN: | %if --need=target_ARM32 --command FileCheck %s \
|
| +; RUN: --check-prefix=ARM32ASM
|
| +
|
| +; IAS is not implemented yet.
|
| +; RUN: %if --need=target_ARM32 --command %p2i --filetype=asm --target arm32 \
|
| +; RUN: -i %s --assemble --disassemble --dis-flags=-rD \
|
| +; RUN: --args -sz-seed=1 -Om1 -reorder-global-variables \
|
| +; RUN: --skip-unimplemented \
|
| +; RUN: | %if --need=target_ARM32 --command FileCheck %s \
|
| +; RUN: --check-prefix=ARM32OBJ
|
| +
|
| +
|
| +define internal i32 @main(i32 %argc, i32 %argv) {
|
| +entry:
|
| + %expanded1 = ptrtoint [4 x i8]* @PrimitiveInit to i32
|
| + call void @use(i32 %expanded1)
|
| + %expanded3 = ptrtoint [4 x i8]* @PrimitiveInitConst to i32
|
| + call void @use(i32 %expanded3)
|
| + %expanded5 = ptrtoint [4 x i8]* @PrimitiveInitStatic to i32
|
| + call void @use(i32 %expanded5)
|
| + %expanded7 = ptrtoint [4 x i8]* @PrimitiveUninit to i32
|
| + call void @use(i32 %expanded7)
|
| + %expanded9 = ptrtoint [20 x i8]* @ArrayInit to i32
|
| + call void @use(i32 %expanded9)
|
| + %expanded11 = ptrtoint [40 x i8]* @ArrayInitPartial to i32
|
| + call void @use(i32 %expanded11)
|
| + %expanded13 = ptrtoint [20 x i8]* @ArrayUninit to i32
|
| + call void @use(i32 %expanded13)
|
| + ret i32 0
|
| +}
|
| +declare void @use(i32)
|
| +
|
| +define internal i32 @nacl_tp_tdb_offset(i32 %__0) {
|
| +entry:
|
| + ret i32 0
|
| +}
|
| +
|
| +define internal i32 @nacl_tp_tls_offset(i32 %size) {
|
| +entry:
|
| + %result = sub i32 0, %size
|
| + ret i32 %result
|
| +}
|
| +
|
| +
|
| +@PrimitiveInit = internal global [4 x i8] c"\1B\00\00\00", align 4
|
| +
|
| +@PrimitiveInitConst = internal constant [4 x i8] c"\0D\00\00\00", align 4
|
| +
|
| +@ArrayInit = internal global [20 x i8] c"\0A\00\00\00\14\00\00\00\1E\00\00\00(\00\00\002\00\00\00", align 4
|
| +
|
| +@ArrayInitPartial = internal global [40 x i8] c"<\00\00\00F\00\00\00P\00\00\00Z\00\00\00d\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00", align 4
|
| +
|
| +@PrimitiveInitStatic = internal global [4 x i8] zeroinitializer, align 4
|
| +
|
| +@PrimitiveUninit = internal global [4 x i8] zeroinitializer, align 4
|
| +
|
| +@ArrayUninit = internal global [20 x i8] zeroinitializer, align 4
|
| +
|
| +@ArrayUninitConstDouble = internal constant [200 x i8] zeroinitializer, align 8
|
| +
|
| +@ArrayUninitConstInt = internal constant [20 x i8] zeroinitializer, align 4
|
| +
|
| +@__init_array_start = internal constant [0 x i8] zeroinitializer, align 4
|
| +@__fini_array_start = internal constant [0 x i8] zeroinitializer, align 4
|
| +@__tls_template_start = internal constant [0 x i8] zeroinitializer, align 8
|
| +@__tls_template_alignment = internal constant [4 x i8] c"\01\00\00\00", align 4
|
| +
|
| +; Make sure the shuffled order is correct.
|
| +
|
| +; X8632ASM-LABEL: PrimitiveUninit
|
| +; X8632ASM-LABEL: __init_array_start
|
| +; X8632ASM-LABEL: ArrayUninitConstDouble
|
| +; X8632ASM-LABEL: __tls_template_alignment
|
| +; X8632ASM-LABEL: ArrayInitPartial
|
| +; X8632ASM-LABEL: ArrayUninit
|
| +; X8632ASM-LABEL: ArrayInit
|
| +; X8632ASM-LABEL: __fini_array_start
|
| +; X8632ASM-LABEL: PrimitiveInitStatic
|
| +; X8632ASM-LABEL: ArrayUninitConstInt
|
| +; X8632ASM-LABEL: PrimitiveInit
|
| +; X8632ASM-LABEL: PrimitiveInitConst
|
| +; X8632ASM-LABEL: __tls_template_start
|
| +
|
| +; X8632OBJ-LABEL: ArrayInitPartial
|
| +; X8632OBJ-LABEL: ArrayInit
|
| +; X8632OBJ-LABEL: PrimitiveInit
|
| +; X8632OBJ-LABEL: PrimitiveUninit
|
| +; X8632OBJ-LABEL: ArrayUninit
|
| +; X8632OBJ-LABEL: PrimitiveInitStatic
|
| +; X8632OBJ-LABEL: ArrayUninitConstDouble
|
| +; X8632OBJ-LABEL: __tls_template_alignment
|
| +; X8632OBJ-LABEL: ArrayUninitConstInt
|
| +; X8632OBJ-LABEL: PrimitiveInitConst
|
| +
|
| +; ARM32ASM-LABEL: PrimitiveUninit
|
| +; ARM32ASM-LABEL: __init_array_start
|
| +; ARM32ASM-LABEL: ArrayUninitConstDouble
|
| +; ARM32ASM-LABEL: __tls_template_alignment
|
| +; ARM32ASM-LABEL: ArrayInitPartial
|
| +; ARM32ASM-LABEL: ArrayUninit
|
| +; ARM32ASM-LABEL: ArrayInit
|
| +; ARM32ASM-LABEL: __fini_array_start
|
| +; ARM32ASM-LABEL: PrimitiveInitStatic
|
| +; ARM32ASM-LABEL: ArrayUninitConstInt
|
| +; ARM32ASM-LABEL: PrimitiveInit
|
| +; ARM32ASM-LABEL: PrimitiveInitConst
|
| +; ARM32ASM-LABEL: __tls_template_start
|
| +
|
| +; ARM32OBJ-LABEL: ArrayInitPartial
|
| +; ARM32OBJ-LABEL: ArrayInit
|
| +; ARM32OBJ-LABEL: PrimitiveInit
|
| +; ARM32OBJ-LABEL: PrimitiveUninit
|
| +; ARM32OBJ-LABEL: ArrayUninit
|
| +; ARM32OBJ-LABEL: PrimitiveInitStatic
|
| +; ARM32OBJ-LABEL: ArrayUninitConstDouble
|
| +; ARM32OBJ-LABEL: __tls_template_alignment
|
| +; ARM32OBJ-LABEL: ArrayUninitConstInt
|
| +; ARM32OBJ-LABEL: PrimitiveInitConst
|
| +
|
|
|