1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 20:23:11 +01:00
llvm-mirror/test/CodeGen/ARM/pr39571.ll
Nirav Dave 6478e51fd7 [DAGCombiner] Fix load-store forwarding of indexed loads.
Summary:
Handle extra output from index loads in cases where we wish to
forward a load value directly from a preceeding store.

Fixes PR39571.

Reviewers: peter.smith, rengolin

Subscribers: javed.absar, hiraditya, arphaman, llvm-commits

Differential Revision: https://reviews.llvm.org/D54265

llvm-svn: 346654
2018-11-12 14:05:40 +00:00

34 lines
1.7 KiB
LLVM

; RUN: llc < %s -mtriple armv4t-unknown-linux-gnueabi -mattr=+strict-align
; Avoid crash from forwarding indexed-loads back to store.
%struct.anon = type { %struct.ma*, %struct.mb }
%struct.ma = type { i8 }
%struct.mb = type { i8, i8 }
%struct.anon.0 = type { %struct.anon.1 }
%struct.anon.1 = type { %struct.ds }
%struct.ds = type <{ i8, %union.ie }>
%union.ie = type { %struct.ib }
%struct.ib = type { i8, i8, i16 }
@a = common dso_local local_unnamed_addr global %struct.anon* null, align 4
@b = common dso_local local_unnamed_addr global %struct.anon.0 zeroinitializer, align 1
; Function Attrs: norecurse nounwind
define dso_local void @func() local_unnamed_addr {
entry:
%0 = load %struct.anon*, %struct.anon** @a, align 4
%ad = getelementptr inbounds %struct.anon, %struct.anon* %0, i32 0, i32 0
%1 = load %struct.ma*, %struct.ma** %ad, align 4
%c.sroa.0.0..sroa_idx = getelementptr inbounds %struct.ma, %struct.ma* %1, i32 0, i32 0
%c.sroa.0.0.copyload = load i8, i8* %c.sroa.0.0..sroa_idx, align 1
%cb = getelementptr inbounds %struct.anon, %struct.anon* %0, i32 0, i32 1
%band = getelementptr inbounds %struct.anon, %struct.anon* %0, i32 0, i32 1, i32 1
store i8 %c.sroa.0.0.copyload, i8* %band, align 4
store i8 6, i8* getelementptr inbounds (%struct.anon.0, %struct.anon.0* @b, i32 0, i32 0, i32 0, i32 1, i32 0, i32 0), align 1
store i8 2, i8* getelementptr inbounds (%struct.anon.0, %struct.anon.0* @b, i32 0, i32 0, i32 0, i32 1, i32 0, i32 1), align 1
%2 = bitcast %struct.mb* %cb to i32*
%3 = load i32, i32* bitcast (i8* getelementptr inbounds (%struct.anon.0, %struct.anon.0* @b, i32 0, i32 0, i32 0, i32 1, i32 0, i32 0) to i32*), align 1
store i32 %3, i32* %2, align 1
ret void
}