Index: tests_lit/reader_tests/globalrelocs.ll |
diff --git a/tests_lit/reader_tests/globalrelocs.ll b/tests_lit/reader_tests/globalrelocs.ll |
new file mode 100644 |
index 0000000000000000000000000000000000000000..bcbb1968ae5640d5c679f3d038bdd15c88c1a976 |
--- /dev/null |
+++ b/tests_lit/reader_tests/globalrelocs.ll |
@@ -0,0 +1,59 @@ |
+; Tests if we handle global variables with relocation initializers. |
Jim Stichnoth
2014/10/03 01:28:09
I'd also like to see a basic cross test for global
Karl
2014/10/04 16:28:34
Done. See crosstest/test_global.cpp
|
+ |
+; Test that we handle it in the ICE converter. |
+; RUN: %lc2i -i %s --insts | FileCheck %s |
+ |
+; Test that we handle it using Subzero's bitcode reader. |
+; RUN: %p2i -i %s --insts | FileCheck %s |
+ |
+@bytes = internal global [7 x i8] c"abcdefg" |
+; CHECK: @bytes = internal global [7 x i8] c"abcdefg" |
+ |
+@ptr_to_ptr = internal global i32 ptrtoint (i32* @ptr to i32) |
+; CHECK-NEXT: @ptr_to_ptr = internal global i32 ptrtoint (i32* @ptr to i32) |
+ |
+@ptr_to_func = internal global i32 ptrtoint (void ()* @func to i32) |
+; CHECK-NEXT: @ptr_to_func = internal global i32 ptrtoint (void ()* @func to i32) |
+ |
+@compound = internal global <{ [3 x i8], i32 }> <{ [3 x i8] c"foo", i32 ptrtoint (void ()* @func to i32) }> |
+; CHECK-NEXT: @compound = internal global <{ [3 x i8], i32 }> <{ [3 x i8] c"foo", i32 ptrtoint (void ()* @func to i32) }> |
+ |
+@ptr = internal global i32 ptrtoint ([7 x i8]* @bytes to i32) |
+; CHECK-NEXT: @ptr = internal global i32 ptrtoint ([7 x i8]* @bytes to i32) |
+ |
+@addend_ptr = internal global i32 add (i32 ptrtoint (i32* @ptr to i32), i32 1) |
+; CHECK-NEXT: @addend_ptr = internal global i32 add (i32 ptrtoint (i32* @ptr to i32), i32 1) |
+ |
+@addend_negative = internal global i32 add (i32 ptrtoint (i32* @ptr to i32), i32 -1) |
+; CHECK-NEXT: @addend_negative = internal global i32 add (i32 ptrtoint (i32* @ptr to i32), i32 -1) |
+ |
+@addend_array1 = internal global i32 add (i32 ptrtoint ([7 x i8]* @bytes to i32), i32 1) |
+; CHECK-NEXT: @addend_array1 = internal global i32 add (i32 ptrtoint ([7 x i8]* @bytes to i32), i32 1) |
+ |
+@addend_array2 = internal global i32 add (i32 ptrtoint ([7 x i8]* @bytes to i32), i32 7) |
+; CHECK-NEXT: @addend_array2 = internal global i32 add (i32 ptrtoint ([7 x i8]* @bytes to i32), i32 7) |
+ |
+@addend_array3 = internal global i32 add (i32 ptrtoint ([7 x i8]* @bytes to i32), i32 9) |
+; CHECK-NEXT: @addend_array3 = internal global i32 add (i32 ptrtoint ([7 x i8]* @bytes to i32), i32 9) |
+ |
+@addend_struct1 = internal global i32 add (i32 ptrtoint (<{ [3 x i8], i32 }>* @compound to i32), i32 1) |
+; CHECK-NEXT: @addend_struct1 = internal global i32 add (i32 ptrtoint (<{ [3 x i8], i32 }>* @compound to i32), i32 1) |
+ |
+@addend_struct2 = internal global i32 add (i32 ptrtoint (<{ [3 x i8], i32 }>* @compound to i32), i32 4) |
+; CHECK-NEXT: @addend_struct2 = internal global i32 add (i32 ptrtoint (<{ [3 x i8], i32 }>* @compound to i32), i32 4) |
+ |
+@ptr_to_func_align = internal global i32 ptrtoint (void ()* @func to i32), align 8 |
+; CHECK-NEXT: @ptr_to_func_align = internal global i32 ptrtoint (void ()* @func to i32), align 8 |
+ |
+@char = internal constant [1 x i8] c"0" |
+; CHECK-NEXT: @char = internal constant [1 x i8] c"0" |
+ |
+@short = internal constant [2 x i8] zeroinitializer |
+; CHECK-NEXT: @short = internal constant [2 x i8] zeroinitializer |
+ |
jvoung (off chromium)
2014/10/03 16:15:30
Maybe test a constant w/ a compound initializer al
Karl
2014/10/04 16:28:34
Done.
|
+define void @func() { |
+ ret void |
+} |
+ |
+; CHECK-NEXT: define void @func() { |
+ |