[ARM] Split large truncating MVE stores
[llvm-complete.git] / test / CodeGen / Thumb / 2011-05-11-DAGLegalizer.ll
blob1ba085916682410b487e5a3fc7de0cd7d5a60bf3
1 ; RUN: llc -mtriple=thumbv6-apple-darwin < %s
2 ; rdar://problem/9416774
3 ; ModuleID = 'reduced.ll'
5 target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:32:64-v128:32:128-a0:0:32-n32"
6 target triple = "thumbv7-apple-ios"
8 %struct.MMMMMMMMMMMM = type { [4 x %struct.RRRRRRRR] }
9 %struct.RRRRRRRR = type { [78 x i32] }
11 @kkkkkk = external constant i8*
12 @__PRETTY_FUNCTION__._ZN12CLGll = private unnamed_addr constant [62 x i8] c"static void tttttttttttt::lllllllllllll(const MMMMMMMMMMMM &)\00"
13 @.str = private unnamed_addr constant [75 x i8] c"\09GGGGGGGGGGGGGGGGGGGGGGG:,BE:0x%08lx,ALM:0x%08lx,LTO:0x%08lx,CBEE:0x%08lx\0A\00"
15 define void @_ZN12CLGll(%struct.MMMMMMMMMMMM* %aidData) ssp align 2 {
16 entry:
17   %aidData.addr = alloca %struct.MMMMMMMMMMMM*, align 4
18   %agg.tmp = alloca %struct.RRRRRRRR, align 4
19   %agg.tmp4 = alloca %struct.RRRRRRRR, align 4
20   %agg.tmp10 = alloca %struct.RRRRRRRR, align 4
21   %agg.tmp16 = alloca %struct.RRRRRRRR, align 4
22   store %struct.MMMMMMMMMMMM* %aidData, %struct.MMMMMMMMMMMM** %aidData.addr, align 4
23   br label %do.body
25 do.body:                                          ; preds = %entry
26   %tmp = load i8*, i8** @kkkkkk, align 4
27   %tmp1 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr
28   %eph = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp1, i32 0, i32 0
29   %arrayidx = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph, i32 0, i32 0
30   %tmp2 = bitcast %struct.RRRRRRRR* %agg.tmp to i8*
31   %tmp3 = bitcast %struct.RRRRRRRR* %arrayidx to i8*
32   call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %tmp2, i8* align 4 %tmp3, i32 312, i1 false)
33   %tmp5 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr
34   %eph6 = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp5, i32 0, i32 0
35   %arrayidx7 = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph6, i32 0, i32 1
36   %tmp8 = bitcast %struct.RRRRRRRR* %agg.tmp4 to i8*
37   %tmp9 = bitcast %struct.RRRRRRRR* %arrayidx7 to i8*
38   call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %tmp8, i8* align 4 %tmp9, i32 312, i1 false)
39   %tmp11 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr
40   %eph12 = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp11, i32 0, i32 0
41   %arrayidx13 = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph12, i32 0, i32 2
42   %tmp14 = bitcast %struct.RRRRRRRR* %agg.tmp10 to i8*
43   %tmp15 = bitcast %struct.RRRRRRRR* %arrayidx13 to i8*
44   call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %tmp14, i8* align 4 %tmp15, i32 312, i1 false)
45   %tmp17 = load %struct.MMMMMMMMMMMM*, %struct.MMMMMMMMMMMM** %aidData.addr
46   %eph18 = getelementptr inbounds %struct.MMMMMMMMMMMM, %struct.MMMMMMMMMMMM* %tmp17, i32 0, i32 0
47   %arrayidx19 = getelementptr inbounds [4 x %struct.RRRRRRRR], [4 x %struct.RRRRRRRR]* %eph18, i32 0, i32 3
48   %tmp20 = bitcast %struct.RRRRRRRR* %agg.tmp16 to i8*
49   %tmp21 = bitcast %struct.RRRRRRRR* %arrayidx19 to i8*
50   call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %tmp20, i8* align 4 %tmp21, i32 312, i1 false)
51   call void (i8*, i32, i8*, i8*, ...) @CLLoggingLog(i8* %tmp, i32 2, i8* getelementptr inbounds ([62 x i8], [62 x i8]* @__PRETTY_FUNCTION__._ZN12CLGll, i32 0, i32 0), i8* getelementptr inbounds ([75 x i8], [75 x i8]* @.str, i32 0, i32 0), %struct.RRRRRRRR* byval %agg.tmp, %struct.RRRRRRRR* byval %agg.tmp4, %struct.RRRRRRRR* byval %agg.tmp10, %struct.RRRRRRRR* byval %agg.tmp16)
52   br label %do.end
54 do.end:                                           ; preds = %do.body
55   ret void
58 declare void @CLLoggingLog(i8*, i32, i8*, i8*, ...)
60 declare void @llvm.memcpy.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i1) nounwind