Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Transforms / GlobalMerge / alignment-2.ll
blob99657d8f6ba7d5fe8ae5f1b883a300f4dca0f910
1 ; RUN: opt -global-merge -global-merge-max-offset=100 -S -o - %s | FileCheck %s
2 ; RUN: opt -passes='global-merge<max-offset=100>' -S -o - %s | FileCheck %s
4 target datalayout = "e-p:64:64"
5 target triple = "x86_64-unknown-linux-gnu"
7 ; This produces align 4, not the obvious align 1, to be consistent with what
8 ; the AsmPrinter would do.
9 ; CHECK: @_MergedGlobals = private global <{ [2 x i32], [2 x i32] }> <{ [2 x i32] [i32 1, i32 1], [2 x i32] [i32 2, i32 2] }>, align 4
11 ; CHECK: @a = internal alias [2 x i32], ptr @_MergedGlobals
12 @a = internal global [2 x i32] [i32 1, i32 1], align 1
14 ; CHECK: @b = internal alias [2 x i32], getelementptr inbounds (<{ [2 x i32], [2 x i32] }>, ptr @_MergedGlobals, i32 0, i32 1)
15 @b = internal global [2 x i32] [i32 2, i32 2], align 1
17 define void @use() {
18   ; CHECK: load i32, ptr @_MergedGlobals
19   %x = load i32, ptr @a
20   ; CHECK: load i32, ptr getelementptr inbounds (<{ [2 x i32], [2 x i32] }>, ptr @_MergedGlobals, i32 0, i32 1)
21   %y = load i32, ptr @b
22   ret void