Typo fix; NFC
[llvm-project.git] / llvm / test / CodeGen / Hexagon / loop-idiom / pmpy-infinite-loop.ll
blob74c02d63d54d32b186dba2d75e3dcad2e97aa775
1 ; RUN: opt -march=hexagon -hexagon-loop-idiom -S < %s | FileCheck %s
2 ; RUN: opt -march=hexagon -p hexagon-loop-idiom -S < %s | FileCheck %s
3 ; CHECK-LABEL: define void @fred
5 ; Check that this test does not crash.
7 target datalayout = "e-m:e-p:32:32:32-a:0-n16:32-i64:64:64-i32:32:32-i16:16:16-i1:8:8-f32:32:32-f64:64:64-v32:32:32-v64:64:64-v512:512:512-v1024:1024:1024-v2048:2048:2048"
8 target triple = "hexagon"
10 %struct.0 = type { [120 x i16], [80 x i16], [80 x i16], [80 x i16], [80 x i16], [80 x i16], [40 x i16], [40 x i16], [40 x i16], [40 x i16], [40 x i16], [40 x i16] }
12 define void @fred(ptr %demod_state) local_unnamed_addr #0 {
13 entry:
14   br label %for.body309
16 for.body309:                                      ; preds = %for.body309, %entry
17   %max_diff.0300 = phi i16 [ %max_diff.1, %for.body309 ], [ 0, %entry ]
18   %arrayidx322.phi = phi ptr [ undef, %entry ], [ %arrayidx322.inc, %for.body309 ]
19   %arrayidx331.phi = phi ptr [ undef, %entry ], [ %arrayidx331.inc, %for.body309 ]
20   %lag.4299.apmt = phi i32 [ %inc376.apmt, %for.body309 ], [ 0, %entry ]
21   %0 = load i16, ptr %arrayidx322.phi, align 2
22   %conv323 = sext i16 %0 to i32
23   %sub324 = sub nsw i32 0, %conv323
24   %ispos258 = icmp sgt i32 %sub324, -1
25   %1 = select i1 %ispos258, i32 %sub324, i32 0
26   %add326 = add nsw i32 %1, 0
27   %2 = load i16, ptr %arrayidx331.phi, align 2
28   %conv332 = sext i16 %2 to i32
29   %sub333 = sub nsw i32 0, %conv332
30   %ispos260 = icmp sgt i32 %sub333, -1
31   %3 = select i1 %ispos260, i32 %sub333, i32 undef
32   %sub342 = sub nsw i32 0, %conv323
33   %ispos262 = icmp sgt i32 %sub342, -1
34   %4 = select i1 %ispos262, i32 %sub342, i32 undef
35   %sub351 = sub nsw i32 0, %conv332
36   %ispos264 = icmp sgt i32 %sub351, -1
37   %5 = select i1 %ispos264, i32 %sub351, i32 0
38   %sub360 = sub nsw i32 %conv323, %conv332
39   %ispos266 = icmp sgt i32 %sub360, -1
40   %6 = select i1 %ispos266, i32 %sub360, i32 0
41   %add335 = add nsw i32 %add326, %4
42   %add344 = add nsw i32 %add335, %3
43   %add353 = add i32 %add344, %5
44   %add362 = add i32 %add353, %6
45   %div363 = sdiv i32 %add362, 6
46   %conv364 = trunc i32 %div363 to i16
47   %sext268 = shl i32 %div363, 16
48   %conv369 = ashr exact i32 %sext268, 16
49   %conv370 = sext i16 %max_diff.0300 to i32
50   %cmp371 = icmp sgt i32 %conv369, %conv370
51   %max_diff.1 = select i1 %cmp371, i16 %conv364, i16 %max_diff.0300
52   %inc376.apmt = add nuw nsw i32 %lag.4299.apmt, 1
53   %exitcond331 = icmp ne i32 %inc376.apmt, 40
54   %arrayidx322.inc = getelementptr i16, ptr %arrayidx322.phi, i32 1
55   %arrayidx331.inc = getelementptr i16, ptr %arrayidx331.phi, i32 1
56   br i1 %exitcond331, label %for.body309, label %for.end377
58 for.end377:                                       ; preds = %for.body309
59   %max_diff.1.lcssa = phi i16 [ %max_diff.1, %for.body309 ]
60   %cmp407 = icmp sgt i16 %max_diff.1.lcssa, 4
61   br label %for.body405
63 for.body405:                                      ; preds = %if.end437, %for.end377
64   %arrayidx412 = getelementptr inbounds %struct.0, ptr %demod_state, i32 0, i32 11, i32 undef
65   br i1 %cmp407, label %if.then409, label %if.end437
67 if.then409:                                       ; preds = %for.body405
68   %arrayidx416 = getelementptr inbounds [40 x i16], ptr null, i32 0, i32 undef
69   %7 = load i16, ptr %arrayidx416, align 2
70   %conv417 = sext i16 %7 to i32
71   %shl = shl i32 %conv417, 4
72   %mul419 = mul nsw i32 %shl, 655
73   %add420 = add nsw i32 %mul419, 0
74   br label %if.end437
76 if.end437:                                        ; preds = %if.then409, %for.body405
77   %mul431.sink = phi i32 [ %add420, %if.then409 ], [ undef, %for.body405 ]
78   %shr432257 = lshr i32 %mul431.sink, 15
79   %conv433 = trunc i32 %shr432257 to i16
80   store i16 %conv433, ptr %arrayidx412, align 2
81   br label %for.body405
84 attributes #0 = { noinline nounwind "target-cpu"="hexagonv60" "target-features"="-hvx,-long-calls" }