xref: /aosp_15_r20/external/llvm/test/CodeGen/Hexagon/rdf-copy-undef2.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=hexagon < %s
2*9880d681SAndroid Build Coastguard Worker; REQUIRES: asserts
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workertarget triple = "hexagon"
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.lifetime.start(i64, i8* nocapture) #0
7*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.lifetime.end(i64, i8* nocapture) #0
8*9880d681SAndroid Build Coastguard Workerdeclare signext i16 @cat(i16 signext) #1
9*9880d681SAndroid Build Coastguard Workerdeclare void @danny(i16 signext, i16 signext, i16 signext, i16* nocapture readonly, i16 signext, i16* nocapture) #1
10*9880d681SAndroid Build Coastguard Workerdeclare void @sammy(i16* nocapture readonly, i16* nocapture readonly, i16* nocapture readonly, i32* nocapture, i16* nocapture, i16 signext, i16 signext, i16 signext) #1
11*9880d681SAndroid Build Coastguard Workerdeclare i8* @llvm.stacksave() #2
12*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.stackrestore(i8*) #2
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Workerdefine i32 @fred(i16 signext %p0, i16 signext %p1, i16* nocapture readonly %p2, i16 signext %p3, i16* nocapture readonly %p4, i16* nocapture %p5) #1 {
15*9880d681SAndroid Build Coastguard Workerentry:
16*9880d681SAndroid Build Coastguard Worker  %0 = tail call i8* @llvm.stacksave()
17*9880d681SAndroid Build Coastguard Worker  %vla = alloca i16, i32 undef, align 8
18*9880d681SAndroid Build Coastguard Worker  %call17 = call signext i16 @cat(i16 signext 1) #1
19*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %for.cond23.preheader, label %for.end47
20*9880d681SAndroid Build Coastguard Worker
21*9880d681SAndroid Build Coastguard Workerfor.cond23.preheader:                             ; preds = %for.end40, %entry
22*9880d681SAndroid Build Coastguard Worker  %i.190 = phi i16 [ %inc46, %for.end40 ], [ 0, %entry ]
23*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %for.body27, label %for.end40
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Workerfor.body27:                                       ; preds = %for.body27, %for.cond23.preheader
26*9880d681SAndroid Build Coastguard Worker  %indvars.iv = phi i32 [ %indvars.iv.next, %for.body27 ], [ 0, %for.cond23.preheader ]
27*9880d681SAndroid Build Coastguard Worker  %call30 = call signext i16 @cat(i16 signext 7) #1
28*9880d681SAndroid Build Coastguard Worker  %arrayidx32 = getelementptr inbounds i16, i16* %vla, i32 %indvars.iv
29*9880d681SAndroid Build Coastguard Worker  store i16 %call30, i16* %arrayidx32, align 2
30*9880d681SAndroid Build Coastguard Worker  %arrayidx37 = getelementptr inbounds i16, i16* undef, i32 %indvars.iv
31*9880d681SAndroid Build Coastguard Worker  %indvars.iv.next = add nuw nsw i32 %indvars.iv, 1
32*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp eq i16 undef, %p3
33*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %for.end40, label %for.body27
34*9880d681SAndroid Build Coastguard Worker
35*9880d681SAndroid Build Coastguard Workerfor.end40:                                        ; preds = %for.body27, %for.cond23.preheader
36*9880d681SAndroid Build Coastguard Worker  call void @sammy(i16* nonnull undef, i16* undef, i16* %p4, i32* null, i16* undef, i16 signext undef, i16 signext undef, i16 signext undef) #1
37*9880d681SAndroid Build Coastguard Worker  %inc46 = add nuw nsw i16 %i.190, 1
38*9880d681SAndroid Build Coastguard Worker  %exitcond94 = icmp eq i16 %inc46, %call17
39*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond94, label %for.end47.loopexit, label %for.cond23.preheader
40*9880d681SAndroid Build Coastguard Worker
41*9880d681SAndroid Build Coastguard Workerfor.end47.loopexit:                               ; preds = %for.end40
42*9880d681SAndroid Build Coastguard Worker  %.pre = load i16, i16* undef, align 2
43*9880d681SAndroid Build Coastguard Worker  br label %for.end47
44*9880d681SAndroid Build Coastguard Worker
45*9880d681SAndroid Build Coastguard Workerfor.end47:                                        ; preds = %for.end47.loopexit, %entry
46*9880d681SAndroid Build Coastguard Worker  %1 = phi i16 [ %.pre, %for.end47.loopexit ], [ 0, %entry ]
47*9880d681SAndroid Build Coastguard Worker  call void @danny(i16 signext %1, i16 signext %p0, i16 signext %p1, i16* %p2, i16 signext %p3, i16* %p5) #1
48*9880d681SAndroid Build Coastguard Worker  call void @llvm.stackrestore(i8* %0)
49*9880d681SAndroid Build Coastguard Worker  ret i32 undef
50*9880d681SAndroid Build Coastguard Worker}
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Worker
53*9880d681SAndroid Build Coastguard Workerattributes #0 = { argmemonly nounwind }
54*9880d681SAndroid Build Coastguard Workerattributes #1 = { optsize }
55*9880d681SAndroid Build Coastguard Workerattributes #2 = { nounwind }
56