[AMDGPU][True16][CodeGen] true16 codegen pattern for v_med3_u/i16 (#121850)
[llvm-project.git] / llvm / test / LTO / X86 / linkonce_odr_func.ll
blob3451a1196ff7fea82c4f1c743314f103af24dc19
1 ; RUN: llvm-as < %s >%t1
2 ; RUN: llvm-lto -o %t2 -dso-symbol=foo1 -dso-symbol=foo2 -dso-symbol=foo3 \
3 ; RUN:     -dso-symbol=v1 -dso-symbol=v2 -dso-symbol=v3 \
4 ; RUN:     -dso-symbol=v4 -dso-symbol=v5 -dso-symbol=v6 %t1 -O0
5 ; RUN: llvm-nm %t2 | FileCheck %s
7 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
8 target triple = "x86_64-unknown-linux-gnu"
10 ; CHECK: W foo1
11 define linkonce_odr void @foo1() noinline {
12   ret void
15 ; CHECK: t foo2
16 define linkonce_odr void @foo2() local_unnamed_addr noinline {
17   ret void
20 ; CHECK: t foo3
21 define linkonce_odr void @foo3() unnamed_addr noinline {
22   ret void
25 ; CHECK: V v1
26 @v1 = linkonce_odr constant i32 32
28 ; CHECK: r v2
29 @v2 = linkonce_odr local_unnamed_addr constant i32 32
31 ; CHECK: r v3
32 @v3 = linkonce_odr unnamed_addr constant i32 32
34 ; CHECK: V v4
35 @v4 = linkonce_odr global i32 32
37 ; CHECK: V v5
38 @v5 = linkonce_odr local_unnamed_addr global i32 32
40 ; CHECK: d v6
41 @v6 = linkonce_odr unnamed_addr global i32 32
43 define void @use() {
44   call void @foo1()
45   call void @foo2()
46   call void @foo3()
47   %x1 = load i32, ptr @v1
48   %x2 = load i32, ptr @v2
49   %x3 = load i32, ptr @v3
50   %x4 = load i32, ptr @v4
51   %x5 = load i32, ptr @v5
52   %x6 = load i32, ptr @v6
53   ret void