Files
clang-p2996/clang/test/CodeGen/thinlto-inline-asm2.c
Matthias Braun 850d53a197 LTO: Decide upfront whether to use opaque/non-opaque pointer types
LTO code may end up mixing bitcode files from various sources varying in
their use of opaque pointer types. The current strategy to decide
between opaque / typed pointers upon the first bitcode file loaded does
not work here, since we could be loading a non-opaque bitcode file first
and would then be unable to load any files with opaque pointer types
later.

So for LTO this:
- Adds an `lto::Config::OpaquePointer` option and enforces an upfront
  decision between the two modes.
- Adds `-opaque-pointers`/`-no-opaque-pointers` options to the gold
  plugin; disabled by default.
- `--opaque-pointers`/`--no-opaque-pointers` options with
  `-plugin-opt=-opaque-pointers`/`-plugin-opt=-no-opaque-pointers`
  aliases to lld; disabled by default.
- Adds an `-lto-opaque-pointers` option to the `llvm-lto2` tool.
- Changes the clang driver to pass `-plugin-opt=-opaque-pointers` to
  the linker in LTO modes when clang was configured with opaque
  pointers enabled by default.

This fixes https://github.com/llvm/llvm-project/issues/55377

Differential Revision: https://reviews.llvm.org/D125847
2022-06-01 18:05:53 -07:00

30 lines
1.2 KiB
C

// REQUIRES: x86-registered-target
// RUN: split-file %s %t
// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -flto=thin -emit-llvm-bc %t/a.c -o %t/a.bc
// RUN: %clang_cc1 -triple x86_64-unknown-linux-gnu -flto=thin -emit-llvm-bc %t/b.c -o %t/b.bc
// RUN: llvm-nm %t/a.bc | FileCheck %s --check-prefix=NM
// RUN: llvm-lto2 run -lto-opaque-pointers %t/a.bc %t/b.bc -o %t/out -save-temps -r=%t/a.bc,ref,plx -r=%t/b.bc,ff_h264_cabac_tables,pl
// RUN: llvm-dis < %t/out.2.2.internalize.bc | FileCheck %s
//--- a.c
/// IR symtab does not track inline asm symbols, so we don't know
/// ff_h264_cabac_tables is undefined.
// NM-NOT: {{.}}
// NM: ---------------- T ref
// NM-NOT: {{.}}
const char *ref(void) {
const char *ret;
asm("lea ff_h264_cabac_tables(%%rip), %0" : "=r"(ret));
return ret;
}
//--- b.c
/// ff_h264_cabac_tables has __attribute__((used)) in the source code, which means
/// its definition must be retained because there can be references the compiler
/// cannot see (inline asm reference). Test we don't internalize it.
// CHECK: @ff_h264_cabac_tables = dso_local constant [1 x i8] c"\09"
__attribute__((used))
const char ff_h264_cabac_tables[1] = "\x09";