diff options
Diffstat (limited to 'llvm/test/LTO/Resolution')
-rw-r--r-- | llvm/test/LTO/Resolution/X86/export-jumptable.ll | 2 | ||||
-rw-r--r-- | llvm/test/LTO/Resolution/X86/local-def-dllimport.ll | 2 | ||||
-rw-r--r-- | llvm/test/LTO/Resolution/X86/lowertypetests.ll | 2 | ||||
-rw-r--r-- | llvm/test/LTO/Resolution/X86/lto-unit-check.ll | 55 |
4 files changed, 58 insertions, 3 deletions
diff --git a/llvm/test/LTO/Resolution/X86/export-jumptable.ll b/llvm/test/LTO/Resolution/X86/export-jumptable.ll index d6cce854c1b..8ced9d96292 100644 --- a/llvm/test/LTO/Resolution/X86/export-jumptable.ll +++ b/llvm/test/LTO/Resolution/X86/export-jumptable.ll @@ -2,7 +2,7 @@ ; the full LTO object file; any such functions will be referenced by the jump ; table. -; RUN: opt -thinlto-bc -o %t %s +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t %s ; RUN: llvm-lto2 run -o %t2 -r %t,f1,p -r %t,f2,p -r %t,_start,px %t -save-temps ; RUN: llvm-dis %t2.1.2.internalize.bc -o - | FileCheck %s diff --git a/llvm/test/LTO/Resolution/X86/local-def-dllimport.ll b/llvm/test/LTO/Resolution/X86/local-def-dllimport.ll index ddb78fbd9a6..c97e4b7e14c 100644 --- a/llvm/test/LTO/Resolution/X86/local-def-dllimport.ll +++ b/llvm/test/LTO/Resolution/X86/local-def-dllimport.ll @@ -1,4 +1,4 @@ -; RUN: opt -thinlto-bc -o %t0.bc %s +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t0.bc %s ; RUN: llvm-lto2 run -r %t0.bc,__imp_f,l \ ; RUN: -r %t0.bc,g,p \ ; RUN: -r %t0.bc,g,l \ diff --git a/llvm/test/LTO/Resolution/X86/lowertypetests.ll b/llvm/test/LTO/Resolution/X86/lowertypetests.ll index b87452c8e7a..e5be4b98cbf 100644 --- a/llvm/test/LTO/Resolution/X86/lowertypetests.ll +++ b/llvm/test/LTO/Resolution/X86/lowertypetests.ll @@ -1,4 +1,4 @@ -; RUN: opt -thinlto-bc -o %t %s +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t %s ; RUN: llvm-lto2 run -r %t,f,plx -r %t,g_alias,plx -r %t,foo,lx -r %t,foo,plx -r %t,bar,lx -r %t,bar,plx -o %t1 %t ; RUN: llvm-nm %t1.0 | FileCheck --check-prefix=MERGED %s ; RUN: llvm-nm %t1.1 | FileCheck %s diff --git a/llvm/test/LTO/Resolution/X86/lto-unit-check.ll b/llvm/test/LTO/Resolution/X86/lto-unit-check.ll new file mode 100644 index 00000000000..1736a5b216a --- /dev/null +++ b/llvm/test/LTO/Resolution/X86/lto-unit-check.ll @@ -0,0 +1,55 @@ +; Test to ensure that the Enable Split LTO Unit flag is set properly in the +; summary, and that we correctly silently handle linking bitcode files with +; different values of this flag. + +; Linking bitcode both with EnableSplitLTOUnit set should work +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t1 %s +; RUN: llvm-bcanalyzer -dump %t1 | FileCheck %s --check-prefix=SPLITLTOUNIT +; RUN: llvm-dis -o - %t1 | FileCheck %s --check-prefix=ENABLESPLITFLAG +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t2 %s +; RUN: llvm-bcanalyzer -dump %t2 | FileCheck %s --check-prefix=SPLITLTOUNIT +; RUN: llvm-dis -o - %t2 | FileCheck %s --check-prefix=ENABLESPLITFLAG +; RUN: llvm-lto2 run -o %t3 %t1 %t2 + +; Linking bitcode both without EnableSplitLTOUnit set should work +; RUN: opt -thinlto-bc -thinlto-split-lto-unit=false -o %t1 %s +; RUN: llvm-bcanalyzer -dump %t1 | FileCheck %s --check-prefix=NOSPLITLTOUNIT +; RUN: llvm-dis -o - %t1 | FileCheck %s --check-prefix=NOENABLESPLITFLAG +; RUN: opt -thinlto-bc -thinlto-split-lto-unit=false -o %t2 %s +; RUN: llvm-bcanalyzer -dump %t2 | FileCheck %s --check-prefix=NOSPLITLTOUNIT +; RUN: llvm-dis -o - %t2 | FileCheck %s --check-prefix=NOENABLESPLITFLAG +; RUN: llvm-lto2 run -o %t3 %t1 %t2 + +; Linking bitcode with different values of EnableSplitLTOUnit should succeed +; (silently skipping any optimizations like whole program devirt that rely +; on all modules being split). +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t1 %s +; RUN: llvm-bcanalyzer -dump %t1 | FileCheck %s --check-prefix=SPLITLTOUNIT +; RUN: llvm-dis -o - %t1 | FileCheck %s --check-prefix=ENABLESPLITFLAG +; RUN: opt -thinlto-bc -thinlto-split-lto-unit=false -o %t2 %s +; RUN: llvm-bcanalyzer -dump %t2 | FileCheck %s --check-prefix=NOSPLITLTOUNIT +; RUN: llvm-dis -o - %t2 | FileCheck %s --check-prefix=NOENABLESPLITFLAG +; RUN: llvm-lto2 run -o %t3 %t1 %t2 + +; Linking bitcode with different values of EnableSplitLTOUnit (reverse order) +; should succeed (silently skipping any optimizations like whole program devirt +; that rely on all modules being split). +; RUN: opt -thinlto-bc -thinlto-split-lto-unit=false -o %t1 %s +; RUN: llvm-bcanalyzer -dump %t1 | FileCheck %s --check-prefix=NOSPLITLTOUNIT +; RUN: llvm-dis -o - %t1 | FileCheck %s --check-prefix=NOENABLESPLITFLAG +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t2 %s +; RUN: llvm-bcanalyzer -dump %t2 | FileCheck %s --check-prefix=SPLITLTOUNIT +; RUN: llvm-dis -o - %t2 | FileCheck %s --check-prefix=ENABLESPLITFLAG +; RUN: llvm-lto2 run -o %t3 %t1 %t2 + +; The flag should be set when splitting is disabled (for backwards compatibility +; with older bitcode where it was always enabled). +; SPLITLTOUNIT: <FLAGS op0=8/> +; NOSPLITLTOUNIT: <FLAGS op0=0/> + +; Check that the corresponding module flag is set when expected. +; ENABLESPLITFLAG: !{i32 1, !"EnableSplitLTOUnit", i32 1} +; NOENABLESPLITFLAG-NOT: !{i32 1, !"EnableSplitLTOUnit", i32 1} + +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" +target triple = "x86_64-unknown-linux-gnu" |