blob: b9d2d993240e437b6fbb1e07149f5dd976410796 [file] [log] [blame]
Matthijs Kooijman8b69d772008-07-17 11:59:53 +00001; This test lets globalopt split the global struct and array into different
2; values. This used to crash, because globalopt forgot to put the new var in the
3; same address space as the old one.
4
Justin Bogner6f6c5f22016-04-25 23:36:50 +00005; RUN: opt < %s -globalopt -S | FileCheck %s
6
Matthijs Kooijman8b69d772008-07-17 11:59:53 +00007; Check that the new global values still have their address space
Justin Bogner6f6c5f22016-04-25 23:36:50 +00008; CHECK: addrspace(1) global
9; CHECK: addrspace(1) global
Matthijs Kooijman8b69d772008-07-17 11:59:53 +000010
Chris Lattnerac161bf2009-01-02 07:01:27 +000011@struct = internal addrspace(1) global { i32, i32 } zeroinitializer
12@array = internal addrspace(1) global [ 2 x i32 ] zeroinitializer
Matthijs Kooijman8b69d772008-07-17 11:59:53 +000013
14define i32 @foo() {
David Blaikief72d05b2015-03-13 18:20:45 +000015 %A = load i32, i32 addrspace(1) * getelementptr ({ i32, i32 }, { i32, i32 } addrspace(1) * @struct, i32 0, i32 0)
16 %B = load i32, i32 addrspace(1) * getelementptr ([ 2 x i32 ], [ 2 x i32 ] addrspace(1) * @array, i32 0, i32 0)
Matthijs Kooijman8b69d772008-07-17 11:59:53 +000017 ; Use the loaded values, so they won't get removed completely
18 %R = add i32 %A, %B
19 ret i32 %R
20}
21
22; We put stores in a different function, so that the global variables won't get
23; optimized away completely.
24define void @bar(i32 %R) {
David Blaikief72d05b2015-03-13 18:20:45 +000025 store i32 %R, i32 addrspace(1) * getelementptr ([ 2 x i32 ], [ 2 x i32 ] addrspace(1) * @array, i32 0, i32 0)
26 store i32 %R, i32 addrspace(1) * getelementptr ({ i32, i32 }, { i32, i32 } addrspace(1) * @struct, i32 0, i32 0)
Matthijs Kooijman8b69d772008-07-17 11:59:53 +000027 ret void
28}