Index: tests_lit/llvm2ice_tests/nonsfi.ll |
diff --git a/tests_lit/llvm2ice_tests/nonsfi.ll b/tests_lit/llvm2ice_tests/nonsfi.ll |
index bf40f16007b029ac4f05014799c9c427a1bd4f1a..5b80c42b64ebbb3c3a246da739aa2c280cda5c16 100644 |
--- a/tests_lit/llvm2ice_tests/nonsfi.ll |
+++ b/tests_lit/llvm2ice_tests/nonsfi.ll |
@@ -1,6 +1,8 @@ |
; RUN: %p2i -i %s --filetype=obj --assemble --disassemble --args -O2 -nonsfi=1 \ |
+; RUN: --ffunction-sections \ |
; RUN: | FileCheck --check-prefix=NONSFI %s |
; RUN: %p2i -i %s --filetype=obj --assemble --disassemble --args -O2 -nonsfi=0 \ |
+; RUN: --ffunction-sections \ |
; RUN: | FileCheck --check-prefix=DEFAULT %s |
@G1 = internal global [4 x i8] zeroinitializer, align 4 |
@@ -8,12 +10,14 @@ |
define internal void @testCallRegular() { |
entry: |
- call void @testCallRegular() |
+ ; Make a call to a *different* function, plus use -ffunction-sections, to |
+ ; force an appropriately-named relocation. |
+ call i32 @testLoadBasic() |
ret void |
} |
; Expect a simple direct call to testCallRegular. |
; NONSFI-LABEL: testCallRegular |
-; NONSFI: call {{.*}} R_386_PC32 testCallRegular |
+; NONSFI: call {{.*}} R_386_PC32 {{.*}}testLoadBasic |
; DEFAULT-LABEL: testCallRegular |
define internal double @testCallBuiltin(double %val) { |
@@ -34,7 +38,7 @@ entry: |
} |
; Expect a load with a R_386_GOTOFF relocation. |
; NONSFI-LABEL: testLoadBasic |
-; NONSFI: mov {{.*}} R_386_GOTOFF G1 |
+; NONSFI: mov {{.*}} R_386_GOTOFF {{G1|.bss}} |
; DEFAULT-LABEL: testLoadBasic |
define internal i32 @testLoadFixedOffset() { |
@@ -47,7 +51,7 @@ entry: |
} |
; Expect a load with a R_386_GOTOFF relocation plus an immediate offset. |
; NONSFI-LABEL: testLoadFixedOffset |
-; NONSFI: mov {{.*}}+0x4] {{.*}} R_386_GOTOFF G1 |
+; NONSFI: mov {{.*}}+0x4] {{.*}} R_386_GOTOFF {{G1|.bss}} |
; DEFAULT-LABEL: testLoadFixedOffset |
define internal i32 @testLoadIndexed(i32 %idx) { |
@@ -63,7 +67,7 @@ entry: |
; Expect a load with a R_386_GOTOFF relocation plus an immediate offset, plus a |
; scaled index register. |
; NONSFI-LABEL: testLoadIndexed |
-; NONSFI: mov {{.*}}*4+0xc] {{.*}} R_386_GOTOFF G1 |
+; NONSFI: mov {{.*}}*4+0xc] {{.*}} R_386_GOTOFF {{G1|.bss}} |
; DEFAULT-LABEL: testLoadIndexed |
define internal i32 @testLoadIndexedBase(i32 %base, i32 %idx) { |
@@ -80,11 +84,11 @@ entry: |
; Expect a load with a R_386_GOTOFF relocation plus an immediate offset, but |
; without the scaled index. |
; NONSFI-LABEL: testLoadIndexedBase |
-; NONSFI: mov {{.*}}*1+0xc] {{.*}} R_386_GOTOFF G1 |
+; NONSFI: mov {{.*}}*1+0xc] {{.*}} R_386_GOTOFF {{G1|.bss}} |
; By contrast, without -nonsfi, expect a load with a *R_386_32* relocation plus |
; an immediate offset, and *with* the scaled index. |
; DEFAULT-LABEL: testLoadIndexedBase |
-; DEFAULT: mov {{.*}},DWORD PTR [{{.*}}+{{.*}}*4+0xc] {{.*}} R_386_32 G1 |
+; DEFAULT: mov {{.*}},DWORD PTR [{{.*}}+{{.*}}*4+0xc] {{.*}} R_386_32 {{G1|.bss}} |
define internal i32 @testLoadOpt() { |
entry: |
@@ -97,8 +101,8 @@ entry: |
} |
; Expect a load-folding optimization with a R_386_GOTOFF relocation. |
; NONSFI-LABEL: testLoadOpt |
-; NONSFI: mov [[REG:e..]],{{.*}}+0x0] {{.*}} R_386_GOTOFF G1 |
-; NONSFI-NEXT: add [[REG]],{{.*}}+0x0] {{.*}} R_386_GOTOFF G2 |
+; NONSFI: mov [[REG:e..]],{{.*}}+0x0] {{.*}} R_386_GOTOFF {{G1|.bss}} |
+; NONSFI-NEXT: add [[REG]],{{.*}}+0x{{0|4}}] {{.*}} R_386_GOTOFF {{G2|.bss}} |
; DEFAULT-LABEL: testLoadOpt |
define internal void @testRMW() { |
@@ -111,5 +115,5 @@ entry: |
} |
; Expect an RMW optimization with a R_386_GOTOFF relocation. |
; NONSFI-LABEL: testRMW |
-; NONSFI: add DWORD PTR {{.*}}+0x0],0x4d2 {{.*}} R_386_GOTOFF G1 |
+; NONSFI: add DWORD PTR {{.*}}+0x0],0x4d2 {{.*}} R_386_GOTOFF {{G1|.bss}} |
; DEFAULT-LABEL: testRMW |