xref: /llvm-project/llvm/test/CodeGen/PowerPC/register-pressure.ll (revision 41af6ece6c6272ab2045e754f64d149079e899b5)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc-unknown-linux-gnu \
3; RUN:          -mattr=+spe | FileCheck %s -check-prefixes=CHECK,SPE
4
5target datalayout = "E-m:e-p:32:32-Fn32-i64:64-n32"
6target triple = "ppc32"
7
8%struct.cmplx = type { double, double }
9
10; Function Attrs: noinline nounwind optnone uwtable
11define dso_local i32 @main() #0 {
12; CHECK-LABEL: main:
13; CHECK:       # %bb.0:
14; CHECK-NEXT:    mflr 0
15; CHECK-NEXT:    stwu 1, -48(1)
16; CHECK-NEXT:    stw 31, 44(1)
17; CHECK-NEXT:    stw 0, 52(1)
18; CHECK-NEXT:    .cfi_def_cfa_offset 48
19; CHECK-NEXT:    .cfi_offset r31, -4
20; CHECK-NEXT:    .cfi_offset lr, 4
21; CHECK-NEXT:    mr 31, 1
22; CHECK-NEXT:    .cfi_def_cfa_register r31
23; CHECK-NEXT:    li 3, 10
24; CHECK-NEXT:    stw 3, 40(31)
25; CHECK-NEXT:    li 3, 0
26; CHECK-NEXT:    stw 3, 28(31)
27; CHECK-NEXT:    lis 4, 16404
28; CHECK-NEXT:    stw 4, 24(31)
29; CHECK-NEXT:    stw 3, 36(31)
30; CHECK-NEXT:    lis 3, 16420
31; CHECK-NEXT:    stw 3, 32(31)
32; CHECK-NEXT:    lwz 3, 40(31)
33; CHECK-NEXT:    slwi 3, 3, 4
34; CHECK-NEXT:    bl malloc
35; CHECK-NEXT:    stw 3, 20(31)
36; CHECK-NEXT:    addi 7, 31, 24
37; CHECK-NEXT:    stw 7, 16(31)
38; CHECK-NEXT:    lwz 3, 20(31)
39; CHECK-NEXT:    stw 3, 12(31)
40; CHECK-NEXT:    lwz 5, 16(31)
41; CHECK-NEXT:    lwz 6, 12(31)
42; CHECK-NEXT:    li 3, 5
43; CHECK-NEXT:    li 4, 1
44; CHECK-NEXT:    li 8, 1
45; CHECK-NEXT:    bl pass11
46; CHECK-NEXT:    li 3, 0
47; CHECK-NEXT:    lwz 0, 52(1)
48; CHECK-NEXT:    lwz 31, 44(1)
49; CHECK-NEXT:    addi 1, 1, 48
50; CHECK-NEXT:    mtlr 0
51; CHECK-NEXT:    blr
52  %1 = alloca i32, align 4
53  %2 = alloca %struct.cmplx, align 8
54  %3 = alloca ptr, align 4
55  %4 = alloca ptr, align 4
56  %5 = alloca ptr, align 4
57  store i32 10, ptr %1, align 4
58  %6 = getelementptr inbounds %struct.cmplx, ptr %2, i32 0, i32 0
59  store double 5.000000e+00, ptr %6, align 8
60  %7 = getelementptr inbounds %struct.cmplx, ptr %2, i32 0, i32 1
61  store double 1.000000e+01, ptr %7, align 8
62  %8 = load i32, ptr %1, align 4
63  %9 = mul i32 %8, 16
64  %10 = call ptr @malloc(i32 noundef %9)
65  store ptr %10, ptr %3, align 4
66  store ptr %2, ptr %4, align 4
67  %11 = load ptr, ptr %3, align 4
68  store ptr %11, ptr %5, align 4
69  %12 = load ptr, ptr %4, align 4
70  %13 = load ptr, ptr %5, align 4
71  call void @pass11(i32 noundef 5, i32 noundef 1, ptr noundef %12, ptr noundef %13, ptr noundef %2, i32 noundef 1)
72  ret i32 0
73}
74
75declare dso_local ptr @malloc(i32 noundef) #1
76
77; Function Attrs: noinline nounwind optnone uwtable
78define internal void @pass11(i32 noundef %0, i32 noundef %1, ptr noalias noundef %2, ptr noalias noundef %3, ptr noalias noundef %4, i32 noundef %5) #0 {
79; CHECK-LABEL: pass11:
80; CHECK:       # %bb.0:
81; CHECK-NEXT:    stwu 1, -1088(1)
82; CHECK-NEXT:    stw 31, 1084(1)
83; CHECK-NEXT:    .cfi_def_cfa_offset 1088
84; CHECK-NEXT:    .cfi_offset r31, -4
85; CHECK-NEXT:    mr 31, 1
86; CHECK-NEXT:    .cfi_def_cfa_register r31
87; CHECK-NEXT:    .cfi_offset r15, -68
88; CHECK-NEXT:    .cfi_offset r16, -208
89; CHECK-NEXT:    .cfi_offset r17, -200
90; CHECK-NEXT:    .cfi_offset r18, -192
91; CHECK-NEXT:    .cfi_offset r19, -184
92; CHECK-NEXT:    .cfi_offset r20, -176
93; CHECK-NEXT:    .cfi_offset r21, -168
94; CHECK-NEXT:    .cfi_offset r22, -160
95; CHECK-NEXT:    .cfi_offset r23, -152
96; CHECK-NEXT:    .cfi_offset r24, -144
97; CHECK-NEXT:    .cfi_offset r25, -136
98; CHECK-NEXT:    .cfi_offset r26, -128
99; CHECK-NEXT:    .cfi_offset r27, -120
100; CHECK-NEXT:    .cfi_offset r28, -112
101; CHECK-NEXT:    .cfi_offset r29, -104
102; CHECK-NEXT:    .cfi_offset r30, -8
103; CHECK-NEXT:    stw 15, 1020(31) # 4-byte Folded Spill
104; CHECK-NEXT:    li 9, 880
105; CHECK-NEXT:    evstddx 16, 31, 9 # 8-byte Folded Spill
106; CHECK-NEXT:    li 9, 888
107; CHECK-NEXT:    evstddx 17, 31, 9 # 8-byte Folded Spill
108; CHECK-NEXT:    li 9, 896
109; CHECK-NEXT:    evstddx 18, 31, 9 # 8-byte Folded Spill
110; CHECK-NEXT:    li 9, 904
111; CHECK-NEXT:    evstddx 19, 31, 9 # 8-byte Folded Spill
112; CHECK-NEXT:    li 9, 912
113; CHECK-NEXT:    evstddx 20, 31, 9 # 8-byte Folded Spill
114; CHECK-NEXT:    li 9, 920
115; CHECK-NEXT:    evstddx 21, 31, 9 # 8-byte Folded Spill
116; CHECK-NEXT:    li 9, 928
117; CHECK-NEXT:    evstddx 22, 31, 9 # 8-byte Folded Spill
118; CHECK-NEXT:    li 9, 936
119; CHECK-NEXT:    evstddx 23, 31, 9 # 8-byte Folded Spill
120; CHECK-NEXT:    li 9, 944
121; CHECK-NEXT:    evstddx 24, 31, 9 # 8-byte Folded Spill
122; CHECK-NEXT:    li 9, 952
123; CHECK-NEXT:    evstddx 25, 31, 9 # 8-byte Folded Spill
124; CHECK-NEXT:    li 9, 960
125; CHECK-NEXT:    evstddx 26, 31, 9 # 8-byte Folded Spill
126; CHECK-NEXT:    li 9, 968
127; CHECK-NEXT:    evstddx 27, 31, 9 # 8-byte Folded Spill
128; CHECK-NEXT:    li 9, 976
129; CHECK-NEXT:    evstddx 28, 31, 9 # 8-byte Folded Spill
130; CHECK-NEXT:    li 9, 984
131; CHECK-NEXT:    evstddx 29, 31, 9 # 8-byte Folded Spill
132; CHECK-NEXT:    stw 30, 1080(31) # 4-byte Folded Spill
133; CHECK-NEXT:    stw 3, 876(31)
134; CHECK-NEXT:    stw 4, 872(31)
135; CHECK-NEXT:    stw 5, 868(31)
136; CHECK-NEXT:    stw 6, 864(31)
137; CHECK-NEXT:    stw 7, 860(31)
138; CHECK-NEXT:    stw 8, 856(31)
139; CHECK-NEXT:    li 3, 11
140; CHECK-NEXT:    stw 3, 852(31)
141; CHECK-NEXT:    lis 3, -30876
142; CHECK-NEXT:    ori 3, 3, 61626
143; CHECK-NEXT:    stw 3, 844(31)
144; CHECK-NEXT:    lis 3, 16362
145; CHECK-NEXT:    ori 3, 3, 60300
146; CHECK-NEXT:    stw 3, 840(31)
147; CHECK-NEXT:    lwz 3, 856(31)
148; CHECK-NEXT:    efdcfsi 3, 3
149; CHECK-NEXT:    li 4, .LCPI1_0@l
150; CHECK-NEXT:    lis 5, .LCPI1_0@ha
151; CHECK-NEXT:    evlddx 4, 5, 4
152; CHECK-NEXT:    efdmul 3, 3, 4
153; CHECK-NEXT:    li 4, 832
154; CHECK-NEXT:    evstddx 3, 31, 4
155; CHECK-NEXT:    lis 3, -9785
156; CHECK-NEXT:    ori 3, 3, 4790
157; CHECK-NEXT:    stw 3, 828(31)
158; CHECK-NEXT:    lis 3, 16346
159; CHECK-NEXT:    ori 3, 3, 38440
160; CHECK-NEXT:    stw 3, 824(31)
161; CHECK-NEXT:    lwz 3, 856(31)
162; CHECK-NEXT:    efdcfsi 3, 3
163; CHECK-NEXT:    li 4, .LCPI1_1@l
164; CHECK-NEXT:    lis 5, .LCPI1_1@ha
165; CHECK-NEXT:    evlddx 4, 5, 4
166; CHECK-NEXT:    efdmul 3, 3, 4
167; CHECK-NEXT:    li 4, 816
168; CHECK-NEXT:    evstddx 3, 31, 4
169; CHECK-NEXT:    lis 3, 25615
170; CHECK-NEXT:    ori 3, 3, 17627
171; CHECK-NEXT:    stw 3, 812(31)
172; CHECK-NEXT:    lis 3, -16446
173; CHECK-NEXT:    ori 3, 3, 14175
174; CHECK-NEXT:    stw 3, 808(31)
175; CHECK-NEXT:    lwz 3, 856(31)
176; CHECK-NEXT:    efdcfsi 3, 3
177; CHECK-NEXT:    li 4, .LCPI1_2@l
178; CHECK-NEXT:    lis 5, .LCPI1_2@ha
179; CHECK-NEXT:    evlddx 4, 5, 4
180; CHECK-NEXT:    efdmul 3, 3, 4
181; CHECK-NEXT:    li 4, 800
182; CHECK-NEXT:    evstddx 3, 31, 4
183; CHECK-NEXT:    lis 3, 32631
184; CHECK-NEXT:    ori 3, 3, 22663
185; CHECK-NEXT:    stw 3, 796(31)
186; CHECK-NEXT:    lis 3, -16412
187; CHECK-NEXT:    ori 3, 3, 62622
188; CHECK-NEXT:    stw 3, 792(31)
189; CHECK-NEXT:    lwz 3, 856(31)
190; CHECK-NEXT:    efdcfsi 3, 3
191; CHECK-NEXT:    li 4, .LCPI1_3@l
192; CHECK-NEXT:    lis 5, .LCPI1_3@ha
193; CHECK-NEXT:    evlddx 4, 5, 4
194; CHECK-NEXT:    efdmul 3, 3, 4
195; CHECK-NEXT:    li 4, 784
196; CHECK-NEXT:    evstddx 3, 31, 4
197; CHECK-NEXT:    lis 3, -25651
198; CHECK-NEXT:    ori 3, 3, 20567
199; CHECK-NEXT:    stw 3, 780(31)
200; CHECK-NEXT:    lis 3, -16402
201; CHECK-NEXT:    ori 3, 3, 46122
202; CHECK-NEXT:    stw 3, 776(31)
203; CHECK-NEXT:    lwz 3, 856(31)
204; CHECK-NEXT:    efdcfsi 3, 3
205; CHECK-NEXT:    li 4, .LCPI1_4@l
206; CHECK-NEXT:    lis 5, .LCPI1_4@ha
207; CHECK-NEXT:    evlddx 4, 5, 4
208; CHECK-NEXT:    efdmul 3, 3, 4
209; CHECK-NEXT:    li 4, 768
210; CHECK-NEXT:    evstddx 3, 31, 4
211; CHECK-NEXT:    li 3, 0
212; CHECK-NEXT:    stw 3, 764(31)
213; CHECK-NEXT:    b .LBB1_1
214; CHECK-NEXT:  .LBB1_1: # =>This Loop Header: Depth=1
215; CHECK-NEXT:    # Child Loop BB1_3 Depth 2
216; CHECK-NEXT:    lwz 3, 764(31)
217; CHECK-NEXT:    lwz 4, 872(31)
218; CHECK-NEXT:    cmplw 3, 4
219; CHECK-NEXT:    bge 0, .LBB1_8
220; CHECK-NEXT:    b .LBB1_2
221; CHECK-NEXT:  .LBB1_2:
222; CHECK-NEXT:    lwz 3, 868(31)
223; CHECK-NEXT:    lwz 4, 876(31)
224; CHECK-NEXT:    lwz 5, 764(31)
225; CHECK-NEXT:    mullw 4, 5, 4
226; CHECK-NEXT:    mulli 4, 4, 176
227; CHECK-NEXT:    lwzux 4, 3, 4
228; CHECK-NEXT:    stw 4, 744(31)
229; CHECK-NEXT:    lwz 4, 12(3)
230; CHECK-NEXT:    stw 4, 756(31)
231; CHECK-NEXT:    lwz 4, 8(3)
232; CHECK-NEXT:    stw 4, 752(31)
233; CHECK-NEXT:    lwz 3, 4(3)
234; CHECK-NEXT:    stw 3, 748(31)
235; CHECK-NEXT:    lwz 3, 868(31)
236; CHECK-NEXT:    lwz 4, 876(31)
237; CHECK-NEXT:    lwz 5, 764(31)
238; CHECK-NEXT:    mulli 5, 5, 11
239; CHECK-NEXT:    addi 6, 5, 1
240; CHECK-NEXT:    mullw 6, 4, 6
241; CHECK-NEXT:    slwi 6, 6, 4
242; CHECK-NEXT:    evlddx 6, 3, 6
243; CHECK-NEXT:    addi 5, 5, 10
244; CHECK-NEXT:    mullw 4, 4, 5
245; CHECK-NEXT:    slwi 4, 4, 4
246; CHECK-NEXT:    evlddx 3, 3, 4
247; CHECK-NEXT:    efdadd 3, 6, 3
248; CHECK-NEXT:    li 4, 728
249; CHECK-NEXT:    evstddx 3, 31, 4
250; CHECK-NEXT:    lwz 4, 868(31)
251; CHECK-NEXT:    lwz 5, 876(31)
252; CHECK-NEXT:    lwz 3, 764(31)
253; CHECK-NEXT:    mulli 6, 3, 11
254; CHECK-NEXT:    addi 3, 6, 1
255; CHECK-NEXT:    mullw 3, 5, 3
256; CHECK-NEXT:    slwi 3, 3, 4
257; CHECK-NEXT:    add 7, 4, 3
258; CHECK-NEXT:    li 3, 8
259; CHECK-NEXT:    evlddx 7, 7, 3
260; CHECK-NEXT:    addi 6, 6, 10
261; CHECK-NEXT:    mullw 5, 5, 6
262; CHECK-NEXT:    slwi 5, 5, 4
263; CHECK-NEXT:    add 4, 4, 5
264; CHECK-NEXT:    evlddx 4, 4, 3
265; CHECK-NEXT:    efdadd 4, 7, 4
266; CHECK-NEXT:    addi 5, 31, 728
267; CHECK-NEXT:    evstddx 4, 5, 3
268; CHECK-NEXT:    lwz 4, 868(31)
269; CHECK-NEXT:    lwz 6, 876(31)
270; CHECK-NEXT:    lwz 7, 764(31)
271; CHECK-NEXT:    mulli 7, 7, 11
272; CHECK-NEXT:    addi 8, 7, 1
273; CHECK-NEXT:    mullw 8, 6, 8
274; CHECK-NEXT:    slwi 8, 8, 4
275; CHECK-NEXT:    evlddx 8, 4, 8
276; CHECK-NEXT:    addi 7, 7, 10
277; CHECK-NEXT:    mullw 6, 6, 7
278; CHECK-NEXT:    slwi 6, 6, 4
279; CHECK-NEXT:    evlddx 4, 4, 6
280; CHECK-NEXT:    efdsub 4, 8, 4
281; CHECK-NEXT:    li 6, 584
282; CHECK-NEXT:    evstddx 4, 31, 6
283; CHECK-NEXT:    lwz 4, 868(31)
284; CHECK-NEXT:    lwz 6, 876(31)
285; CHECK-NEXT:    lwz 7, 764(31)
286; CHECK-NEXT:    mulli 7, 7, 11
287; CHECK-NEXT:    addi 8, 7, 1
288; CHECK-NEXT:    mullw 8, 6, 8
289; CHECK-NEXT:    slwi 8, 8, 4
290; CHECK-NEXT:    add 8, 4, 8
291; CHECK-NEXT:    evlddx 8, 8, 3
292; CHECK-NEXT:    addi 7, 7, 10
293; CHECK-NEXT:    mullw 6, 6, 7
294; CHECK-NEXT:    slwi 6, 6, 4
295; CHECK-NEXT:    add 4, 4, 6
296; CHECK-NEXT:    evlddx 4, 4, 3
297; CHECK-NEXT:    efdsub 6, 8, 4
298; CHECK-NEXT:    addi 4, 31, 584
299; CHECK-NEXT:    evstddx 6, 4, 3
300; CHECK-NEXT:    lwz 6, 868(31)
301; CHECK-NEXT:    lwz 7, 876(31)
302; CHECK-NEXT:    lwz 8, 764(31)
303; CHECK-NEXT:    mulli 8, 8, 11
304; CHECK-NEXT:    addi 9, 8, 2
305; CHECK-NEXT:    mullw 9, 7, 9
306; CHECK-NEXT:    slwi 9, 9, 4
307; CHECK-NEXT:    evlddx 9, 6, 9
308; CHECK-NEXT:    addi 8, 8, 9
309; CHECK-NEXT:    mullw 7, 7, 8
310; CHECK-NEXT:    slwi 7, 7, 4
311; CHECK-NEXT:    evlddx 6, 6, 7
312; CHECK-NEXT:    efdadd 6, 9, 6
313; CHECK-NEXT:    li 7, 712
314; CHECK-NEXT:    evstddx 6, 31, 7
315; CHECK-NEXT:    lwz 6, 868(31)
316; CHECK-NEXT:    lwz 7, 876(31)
317; CHECK-NEXT:    lwz 8, 764(31)
318; CHECK-NEXT:    mulli 8, 8, 11
319; CHECK-NEXT:    addi 9, 8, 2
320; CHECK-NEXT:    mullw 9, 7, 9
321; CHECK-NEXT:    slwi 9, 9, 4
322; CHECK-NEXT:    add 9, 6, 9
323; CHECK-NEXT:    evlddx 9, 9, 3
324; CHECK-NEXT:    addi 8, 8, 9
325; CHECK-NEXT:    mullw 7, 7, 8
326; CHECK-NEXT:    slwi 7, 7, 4
327; CHECK-NEXT:    add 6, 6, 7
328; CHECK-NEXT:    evlddx 6, 6, 3
329; CHECK-NEXT:    efdadd 6, 9, 6
330; CHECK-NEXT:    addi 7, 31, 712
331; CHECK-NEXT:    evstddx 6, 7, 3
332; CHECK-NEXT:    lwz 6, 868(31)
333; CHECK-NEXT:    lwz 8, 876(31)
334; CHECK-NEXT:    lwz 9, 764(31)
335; CHECK-NEXT:    mulli 9, 9, 11
336; CHECK-NEXT:    addi 10, 9, 2
337; CHECK-NEXT:    mullw 10, 8, 10
338; CHECK-NEXT:    slwi 10, 10, 4
339; CHECK-NEXT:    evlddx 10, 6, 10
340; CHECK-NEXT:    addi 9, 9, 9
341; CHECK-NEXT:    mullw 8, 8, 9
342; CHECK-NEXT:    slwi 8, 8, 4
343; CHECK-NEXT:    evlddx 6, 6, 8
344; CHECK-NEXT:    efdsub 6, 10, 6
345; CHECK-NEXT:    li 8, 600
346; CHECK-NEXT:    evstddx 6, 31, 8
347; CHECK-NEXT:    lwz 6, 868(31)
348; CHECK-NEXT:    lwz 8, 876(31)
349; CHECK-NEXT:    lwz 9, 764(31)
350; CHECK-NEXT:    mulli 9, 9, 11
351; CHECK-NEXT:    addi 10, 9, 2
352; CHECK-NEXT:    mullw 10, 8, 10
353; CHECK-NEXT:    slwi 10, 10, 4
354; CHECK-NEXT:    add 10, 6, 10
355; CHECK-NEXT:    evlddx 10, 10, 3
356; CHECK-NEXT:    addi 9, 9, 9
357; CHECK-NEXT:    mullw 8, 8, 9
358; CHECK-NEXT:    slwi 8, 8, 4
359; CHECK-NEXT:    add 6, 6, 8
360; CHECK-NEXT:    evlddx 6, 6, 3
361; CHECK-NEXT:    efdsub 8, 10, 6
362; CHECK-NEXT:    addi 6, 31, 600
363; CHECK-NEXT:    evstddx 8, 6, 3
364; CHECK-NEXT:    lwz 8, 868(31)
365; CHECK-NEXT:    lwz 9, 876(31)
366; CHECK-NEXT:    lwz 10, 764(31)
367; CHECK-NEXT:    mulli 10, 10, 11
368; CHECK-NEXT:    addi 11, 10, 3
369; CHECK-NEXT:    mullw 11, 9, 11
370; CHECK-NEXT:    slwi 11, 11, 4
371; CHECK-NEXT:    evlddx 11, 8, 11
372; CHECK-NEXT:    addi 10, 10, 8
373; CHECK-NEXT:    mullw 9, 9, 10
374; CHECK-NEXT:    slwi 9, 9, 4
375; CHECK-NEXT:    evlddx 8, 8, 9
376; CHECK-NEXT:    efdadd 8, 11, 8
377; CHECK-NEXT:    li 9, 696
378; CHECK-NEXT:    evstddx 8, 31, 9
379; CHECK-NEXT:    lwz 8, 868(31)
380; CHECK-NEXT:    lwz 9, 876(31)
381; CHECK-NEXT:    lwz 10, 764(31)
382; CHECK-NEXT:    mulli 10, 10, 11
383; CHECK-NEXT:    addi 11, 10, 3
384; CHECK-NEXT:    mullw 11, 9, 11
385; CHECK-NEXT:    slwi 11, 11, 4
386; CHECK-NEXT:    add 11, 8, 11
387; CHECK-NEXT:    evlddx 11, 11, 3
388; CHECK-NEXT:    addi 10, 10, 8
389; CHECK-NEXT:    mullw 9, 9, 10
390; CHECK-NEXT:    slwi 9, 9, 4
391; CHECK-NEXT:    add 8, 8, 9
392; CHECK-NEXT:    evlddx 8, 8, 3
393; CHECK-NEXT:    efdadd 8, 11, 8
394; CHECK-NEXT:    addi 9, 31, 696
395; CHECK-NEXT:    evstddx 8, 9, 3
396; CHECK-NEXT:    lwz 8, 868(31)
397; CHECK-NEXT:    lwz 10, 876(31)
398; CHECK-NEXT:    lwz 11, 764(31)
399; CHECK-NEXT:    mulli 11, 11, 11
400; CHECK-NEXT:    addi 12, 11, 3
401; CHECK-NEXT:    mullw 12, 10, 12
402; CHECK-NEXT:    slwi 12, 12, 4
403; CHECK-NEXT:    evlddx 12, 8, 12
404; CHECK-NEXT:    addi 11, 11, 8
405; CHECK-NEXT:    mullw 10, 10, 11
406; CHECK-NEXT:    slwi 10, 10, 4
407; CHECK-NEXT:    evlddx 8, 8, 10
408; CHECK-NEXT:    efdsub 8, 12, 8
409; CHECK-NEXT:    li 10, 616
410; CHECK-NEXT:    evstddx 8, 31, 10
411; CHECK-NEXT:    lwz 8, 868(31)
412; CHECK-NEXT:    lwz 10, 876(31)
413; CHECK-NEXT:    lwz 11, 764(31)
414; CHECK-NEXT:    mulli 11, 11, 11
415; CHECK-NEXT:    addi 12, 11, 3
416; CHECK-NEXT:    mullw 12, 10, 12
417; CHECK-NEXT:    slwi 12, 12, 4
418; CHECK-NEXT:    add 12, 8, 12
419; CHECK-NEXT:    evlddx 12, 12, 3
420; CHECK-NEXT:    addi 11, 11, 8
421; CHECK-NEXT:    mullw 10, 10, 11
422; CHECK-NEXT:    slwi 10, 10, 4
423; CHECK-NEXT:    add 8, 8, 10
424; CHECK-NEXT:    evlddx 8, 8, 3
425; CHECK-NEXT:    efdsub 10, 12, 8
426; CHECK-NEXT:    addi 8, 31, 616
427; CHECK-NEXT:    evstddx 10, 8, 3
428; CHECK-NEXT:    lwz 10, 868(31)
429; CHECK-NEXT:    lwz 11, 876(31)
430; CHECK-NEXT:    lwz 12, 764(31)
431; CHECK-NEXT:    mulli 12, 12, 11
432; CHECK-NEXT:    addi 0, 12, 4
433; CHECK-NEXT:    mullw 0, 11, 0
434; CHECK-NEXT:    slwi 0, 0, 4
435; CHECK-NEXT:    evlddx 0, 10, 0
436; CHECK-NEXT:    addi 12, 12, 7
437; CHECK-NEXT:    mullw 11, 11, 12
438; CHECK-NEXT:    slwi 11, 11, 4
439; CHECK-NEXT:    evlddx 10, 10, 11
440; CHECK-NEXT:    efdadd 10, 0, 10
441; CHECK-NEXT:    li 11, 680
442; CHECK-NEXT:    evstddx 10, 31, 11
443; CHECK-NEXT:    lwz 10, 868(31)
444; CHECK-NEXT:    lwz 11, 876(31)
445; CHECK-NEXT:    lwz 12, 764(31)
446; CHECK-NEXT:    mulli 12, 12, 11
447; CHECK-NEXT:    addi 0, 12, 4
448; CHECK-NEXT:    mullw 0, 11, 0
449; CHECK-NEXT:    slwi 0, 0, 4
450; CHECK-NEXT:    add 30, 10, 0
451; CHECK-NEXT:    evlddx 0, 30, 3
452; CHECK-NEXT:    addi 12, 12, 7
453; CHECK-NEXT:    mullw 11, 11, 12
454; CHECK-NEXT:    slwi 11, 11, 4
455; CHECK-NEXT:    add 10, 10, 11
456; CHECK-NEXT:    evlddx 10, 10, 3
457; CHECK-NEXT:    efdadd 10, 0, 10
458; CHECK-NEXT:    addi 11, 31, 680
459; CHECK-NEXT:    evstddx 10, 11, 3
460; CHECK-NEXT:    lwz 10, 868(31)
461; CHECK-NEXT:    lwz 12, 876(31)
462; CHECK-NEXT:    lwz 0, 764(31)
463; CHECK-NEXT:    mulli 30, 0, 11
464; CHECK-NEXT:    addi 0, 30, 4
465; CHECK-NEXT:    mullw 0, 12, 0
466; CHECK-NEXT:    slwi 0, 0, 4
467; CHECK-NEXT:    evlddx 0, 10, 0
468; CHECK-NEXT:    addi 30, 30, 7
469; CHECK-NEXT:    mullw 12, 12, 30
470; CHECK-NEXT:    slwi 12, 12, 4
471; CHECK-NEXT:    evlddx 10, 10, 12
472; CHECK-NEXT:    efdsub 10, 0, 10
473; CHECK-NEXT:    li 12, 632
474; CHECK-NEXT:    evstddx 10, 31, 12
475; CHECK-NEXT:    lwz 10, 868(31)
476; CHECK-NEXT:    lwz 12, 876(31)
477; CHECK-NEXT:    lwz 0, 764(31)
478; CHECK-NEXT:    mulli 30, 0, 11
479; CHECK-NEXT:    addi 0, 30, 4
480; CHECK-NEXT:    mullw 0, 12, 0
481; CHECK-NEXT:    slwi 0, 0, 4
482; CHECK-NEXT:    add 29, 10, 0
483; CHECK-NEXT:    evlddx 0, 29, 3
484; CHECK-NEXT:    addi 30, 30, 7
485; CHECK-NEXT:    mullw 12, 12, 30
486; CHECK-NEXT:    slwi 12, 12, 4
487; CHECK-NEXT:    add 10, 10, 12
488; CHECK-NEXT:    evlddx 10, 10, 3
489; CHECK-NEXT:    efdsub 12, 0, 10
490; CHECK-NEXT:    addi 10, 31, 632
491; CHECK-NEXT:    evstddx 12, 10, 3
492; CHECK-NEXT:    lwz 12, 868(31)
493; CHECK-NEXT:    lwz 0, 876(31)
494; CHECK-NEXT:    lwz 30, 764(31)
495; CHECK-NEXT:    mulli 30, 30, 11
496; CHECK-NEXT:    addi 29, 30, 5
497; CHECK-NEXT:    mullw 29, 0, 29
498; CHECK-NEXT:    slwi 29, 29, 4
499; CHECK-NEXT:    evlddx 29, 12, 29
500; CHECK-NEXT:    addi 30, 30, 6
501; CHECK-NEXT:    mullw 0, 0, 30
502; CHECK-NEXT:    slwi 0, 0, 4
503; CHECK-NEXT:    evlddx 12, 12, 0
504; CHECK-NEXT:    efdadd 12, 29, 12
505; CHECK-NEXT:    li 30, 664
506; CHECK-NEXT:    evstddx 12, 31, 30
507; CHECK-NEXT:    lwz 12, 868(31)
508; CHECK-NEXT:    lwz 0, 876(31)
509; CHECK-NEXT:    lwz 30, 764(31)
510; CHECK-NEXT:    mulli 30, 30, 11
511; CHECK-NEXT:    addi 29, 30, 5
512; CHECK-NEXT:    mullw 29, 0, 29
513; CHECK-NEXT:    slwi 29, 29, 4
514; CHECK-NEXT:    add 29, 12, 29
515; CHECK-NEXT:    evlddx 29, 29, 3
516; CHECK-NEXT:    addi 30, 30, 6
517; CHECK-NEXT:    mullw 0, 0, 30
518; CHECK-NEXT:    slwi 0, 0, 4
519; CHECK-NEXT:    add 12, 12, 0
520; CHECK-NEXT:    evlddx 12, 12, 3
521; CHECK-NEXT:    efdadd 12, 29, 12
522; CHECK-NEXT:    addi 30, 31, 664
523; CHECK-NEXT:    evstddx 12, 30, 3
524; CHECK-NEXT:    lwz 12, 868(31)
525; CHECK-NEXT:    lwz 0, 876(31)
526; CHECK-NEXT:    lwz 29, 764(31)
527; CHECK-NEXT:    mulli 29, 29, 11
528; CHECK-NEXT:    addi 28, 29, 5
529; CHECK-NEXT:    mullw 28, 0, 28
530; CHECK-NEXT:    slwi 28, 28, 4
531; CHECK-NEXT:    evlddx 28, 12, 28
532; CHECK-NEXT:    addi 29, 29, 6
533; CHECK-NEXT:    mullw 0, 0, 29
534; CHECK-NEXT:    slwi 0, 0, 4
535; CHECK-NEXT:    evlddx 12, 12, 0
536; CHECK-NEXT:    efdsub 12, 28, 12
537; CHECK-NEXT:    li 29, 648
538; CHECK-NEXT:    evstddx 12, 31, 29
539; CHECK-NEXT:    lwz 12, 868(31)
540; CHECK-NEXT:    lwz 0, 876(31)
541; CHECK-NEXT:    lwz 29, 764(31)
542; CHECK-NEXT:    mulli 29, 29, 11
543; CHECK-NEXT:    addi 28, 29, 5
544; CHECK-NEXT:    mullw 28, 0, 28
545; CHECK-NEXT:    slwi 28, 28, 4
546; CHECK-NEXT:    add 28, 12, 28
547; CHECK-NEXT:    evlddx 28, 28, 3
548; CHECK-NEXT:    addi 29, 29, 6
549; CHECK-NEXT:    mullw 0, 0, 29
550; CHECK-NEXT:    slwi 0, 0, 4
551; CHECK-NEXT:    add 12, 12, 0
552; CHECK-NEXT:    evlddx 12, 12, 3
553; CHECK-NEXT:    efdsub 0, 28, 12
554; CHECK-NEXT:    addi 12, 31, 648
555; CHECK-NEXT:    evstddx 0, 12, 3
556; CHECK-NEXT:    li 29, 744
557; CHECK-NEXT:    evlddx 0, 31, 29
558; CHECK-NEXT:    li 29, 728
559; CHECK-NEXT:    evlddx 29, 31, 29
560; CHECK-NEXT:    efdadd 0, 0, 29
561; CHECK-NEXT:    li 29, 712
562; CHECK-NEXT:    evlddx 29, 31, 29
563; CHECK-NEXT:    efdadd 0, 0, 29
564; CHECK-NEXT:    li 29, 696
565; CHECK-NEXT:    evlddx 29, 31, 29
566; CHECK-NEXT:    efdadd 0, 0, 29
567; CHECK-NEXT:    li 29, 680
568; CHECK-NEXT:    evlddx 29, 31, 29
569; CHECK-NEXT:    efdadd 0, 0, 29
570; CHECK-NEXT:    li 29, 664
571; CHECK-NEXT:    evlddx 29, 31, 29
572; CHECK-NEXT:    efdadd 0, 0, 29
573; CHECK-NEXT:    lwz 29, 864(31)
574; CHECK-NEXT:    lwz 28, 876(31)
575; CHECK-NEXT:    lwz 27, 764(31)
576; CHECK-NEXT:    mullw 28, 28, 27
577; CHECK-NEXT:    slwi 28, 28, 4
578; CHECK-NEXT:    evstddx 0, 29, 28
579; CHECK-NEXT:    addi 29, 31, 744
580; CHECK-NEXT:    evlddx 0, 29, 3
581; CHECK-NEXT:    evlddx 28, 5, 3
582; CHECK-NEXT:    efdadd 0, 0, 28
583; CHECK-NEXT:    evlddx 28, 7, 3
584; CHECK-NEXT:    efdadd 0, 0, 28
585; CHECK-NEXT:    evlddx 28, 9, 3
586; CHECK-NEXT:    efdadd 0, 0, 28
587; CHECK-NEXT:    evlddx 28, 11, 3
588; CHECK-NEXT:    efdadd 0, 0, 28
589; CHECK-NEXT:    evlddx 28, 30, 3
590; CHECK-NEXT:    efdadd 0, 0, 28
591; CHECK-NEXT:    lwz 28, 864(31)
592; CHECK-NEXT:    lwz 27, 876(31)
593; CHECK-NEXT:    lwz 26, 764(31)
594; CHECK-NEXT:    mullw 27, 27, 26
595; CHECK-NEXT:    slwi 27, 27, 4
596; CHECK-NEXT:    add 28, 28, 27
597; CHECK-NEXT:    evstddx 0, 28, 3
598; CHECK-NEXT:    li 28, 744
599; CHECK-NEXT:    evlddx 28, 31, 28
600; CHECK-NEXT:    li 27, 728
601; CHECK-NEXT:    evlddx 27, 31, 27
602; CHECK-NEXT:    li 0, .LCPI1_5@l
603; CHECK-NEXT:    lis 26, .LCPI1_5@ha
604; CHECK-NEXT:    evlddx 0, 26, 0
605; CHECK-NEXT:    efdmul 27, 27, 0
606; CHECK-NEXT:    efdadd 27, 27, 28
607; CHECK-NEXT:    li 28, 712
608; CHECK-NEXT:    evlddx 26, 31, 28
609; CHECK-NEXT:    li 28, .LCPI1_6@l
610; CHECK-NEXT:    lis 25, .LCPI1_6@ha
611; CHECK-NEXT:    evlddx 28, 25, 28
612; CHECK-NEXT:    efdmul 26, 26, 28
613; CHECK-NEXT:    efdadd 26, 26, 27
614; CHECK-NEXT:    li 27, 696
615; CHECK-NEXT:    evlddx 25, 31, 27
616; CHECK-NEXT:    li 27, .LCPI1_7@l
617; CHECK-NEXT:    lis 24, .LCPI1_7@ha
618; CHECK-NEXT:    evlddx 27, 24, 27
619; CHECK-NEXT:    efdmul 25, 25, 27
620; CHECK-NEXT:    efdadd 26, 25, 26
621; CHECK-NEXT:    li 25, 680
622; CHECK-NEXT:    evlddx 24, 31, 25
623; CHECK-NEXT:    li 25, .LCPI1_8@l
624; CHECK-NEXT:    lis 23, .LCPI1_8@ha
625; CHECK-NEXT:    evlddx 25, 23, 25
626; CHECK-NEXT:    efdmul 24, 24, 25
627; CHECK-NEXT:    efdadd 24, 24, 26
628; CHECK-NEXT:    li 26, 664
629; CHECK-NEXT:    evlddx 23, 31, 26
630; CHECK-NEXT:    li 26, .LCPI1_9@l
631; CHECK-NEXT:    lis 22, .LCPI1_9@ha
632; CHECK-NEXT:    evlddx 26, 22, 26
633; CHECK-NEXT:    efdmul 23, 23, 26
634; CHECK-NEXT:    efdadd 24, 23, 24
635; CHECK-NEXT:    li 23, 568
636; CHECK-NEXT:    evstddx 24, 31, 23
637; CHECK-NEXT:    evlddx 24, 29, 3
638; CHECK-NEXT:    evlddx 23, 5, 3
639; CHECK-NEXT:    efdmul 23, 23, 0
640; CHECK-NEXT:    efdadd 24, 23, 24
641; CHECK-NEXT:    evlddx 23, 7, 3
642; CHECK-NEXT:    efdmul 23, 23, 28
643; CHECK-NEXT:    efdadd 24, 23, 24
644; CHECK-NEXT:    evlddx 23, 9, 3
645; CHECK-NEXT:    efdmul 23, 23, 27
646; CHECK-NEXT:    efdadd 24, 23, 24
647; CHECK-NEXT:    evlddx 23, 11, 3
648; CHECK-NEXT:    efdmul 23, 23, 25
649; CHECK-NEXT:    efdadd 24, 23, 24
650; CHECK-NEXT:    evlddx 23, 30, 3
651; CHECK-NEXT:    efdmul 23, 23, 26
652; CHECK-NEXT:    efdadd 23, 23, 24
653; CHECK-NEXT:    addi 24, 31, 568
654; CHECK-NEXT:    evstddx 23, 24, 3
655; CHECK-NEXT:    li 23, 832
656; CHECK-NEXT:    evlddx 23, 31, 23
657; CHECK-NEXT:    li 22, 584
658; CHECK-NEXT:    evlddx 22, 31, 22
659; CHECK-NEXT:    li 21, 816
660; CHECK-NEXT:    evlddx 21, 31, 21
661; CHECK-NEXT:    li 20, 600
662; CHECK-NEXT:    evlddx 20, 31, 20
663; CHECK-NEXT:    efdmul 21, 21, 20
664; CHECK-NEXT:    efdmul 23, 23, 22
665; CHECK-NEXT:    efdadd 23, 23, 21
666; CHECK-NEXT:    li 22, 800
667; CHECK-NEXT:    evlddx 22, 31, 22
668; CHECK-NEXT:    li 21, 616
669; CHECK-NEXT:    evlddx 21, 31, 21
670; CHECK-NEXT:    efdmul 22, 22, 21
671; CHECK-NEXT:    efdadd 23, 22, 23
672; CHECK-NEXT:    li 22, 784
673; CHECK-NEXT:    evlddx 22, 31, 22
674; CHECK-NEXT:    li 21, 632
675; CHECK-NEXT:    evlddx 21, 31, 21
676; CHECK-NEXT:    efdmul 22, 22, 21
677; CHECK-NEXT:    efdadd 23, 22, 23
678; CHECK-NEXT:    li 22, 768
679; CHECK-NEXT:    evlddx 22, 31, 22
680; CHECK-NEXT:    li 21, 648
681; CHECK-NEXT:    evlddx 21, 31, 21
682; CHECK-NEXT:    efdmul 22, 22, 21
683; CHECK-NEXT:    efdadd 22, 22, 23
684; CHECK-NEXT:    addi 23, 31, 552
685; CHECK-NEXT:    evstddx 22, 23, 3
686; CHECK-NEXT:    li 22, 832
687; CHECK-NEXT:    evlddx 22, 31, 22
688; CHECK-NEXT:    evlddx 21, 4, 3
689; CHECK-NEXT:    li 20, 816
690; CHECK-NEXT:    evlddx 20, 31, 20
691; CHECK-NEXT:    evlddx 19, 6, 3
692; CHECK-NEXT:    efdmul 20, 20, 19
693; CHECK-NEXT:    efdmul 22, 22, 21
694; CHECK-NEXT:    efdadd 22, 22, 20
695; CHECK-NEXT:    li 21, 800
696; CHECK-NEXT:    evlddx 21, 31, 21
697; CHECK-NEXT:    evlddx 20, 8, 3
698; CHECK-NEXT:    efdmul 21, 21, 20
699; CHECK-NEXT:    efdadd 22, 21, 22
700; CHECK-NEXT:    li 21, 784
701; CHECK-NEXT:    evlddx 21, 31, 21
702; CHECK-NEXT:    evlddx 20, 10, 3
703; CHECK-NEXT:    efdmul 21, 21, 20
704; CHECK-NEXT:    efdadd 22, 21, 22
705; CHECK-NEXT:    li 21, 768
706; CHECK-NEXT:    evlddx 21, 31, 21
707; CHECK-NEXT:    evlddx 20, 12, 3
708; CHECK-NEXT:    efdmul 21, 21, 20
709; CHECK-NEXT:    efdadd 22, 21, 22
710; CHECK-NEXT:    efdneg 22, 22
711; CHECK-NEXT:    li 21, 552
712; CHECK-NEXT:    evstddx 22, 31, 21
713; CHECK-NEXT:    li 22, 568
714; CHECK-NEXT:    evlddx 22, 31, 22
715; CHECK-NEXT:    li 21, 552
716; CHECK-NEXT:    evlddx 21, 31, 21
717; CHECK-NEXT:    efdadd 22, 22, 21
718; CHECK-NEXT:    lwz 21, 864(31)
719; CHECK-NEXT:    lwz 20, 876(31)
720; CHECK-NEXT:    lwz 19, 764(31)
721; CHECK-NEXT:    lwz 18, 872(31)
722; CHECK-NEXT:    add 19, 19, 18
723; CHECK-NEXT:    mullw 20, 20, 19
724; CHECK-NEXT:    slwi 20, 20, 4
725; CHECK-NEXT:    evstddx 22, 21, 20
726; CHECK-NEXT:    evlddx 22, 24, 3
727; CHECK-NEXT:    evlddx 21, 23, 3
728; CHECK-NEXT:    efdadd 22, 22, 21
729; CHECK-NEXT:    lwz 21, 864(31)
730; CHECK-NEXT:    lwz 20, 876(31)
731; CHECK-NEXT:    lwz 19, 764(31)
732; CHECK-NEXT:    lwz 18, 872(31)
733; CHECK-NEXT:    add 19, 19, 18
734; CHECK-NEXT:    mullw 20, 20, 19
735; CHECK-NEXT:    slwi 20, 20, 4
736; CHECK-NEXT:    add 21, 21, 20
737; CHECK-NEXT:    evstddx 22, 21, 3
738; CHECK-NEXT:    li 22, 568
739; CHECK-NEXT:    evlddx 22, 31, 22
740; CHECK-NEXT:    li 21, 552
741; CHECK-NEXT:    evlddx 21, 31, 21
742; CHECK-NEXT:    efdsub 22, 22, 21
743; CHECK-NEXT:    lwz 21, 864(31)
744; CHECK-NEXT:    lwz 20, 876(31)
745; CHECK-NEXT:    lwz 19, 764(31)
746; CHECK-NEXT:    lwz 18, 872(31)
747; CHECK-NEXT:    mulli 18, 18, 10
748; CHECK-NEXT:    add 19, 19, 18
749; CHECK-NEXT:    mullw 20, 20, 19
750; CHECK-NEXT:    slwi 20, 20, 4
751; CHECK-NEXT:    evstddx 22, 21, 20
752; CHECK-NEXT:    evlddx 24, 24, 3
753; CHECK-NEXT:    evlddx 23, 23, 3
754; CHECK-NEXT:    efdsub 24, 24, 23
755; CHECK-NEXT:    lwz 23, 864(31)
756; CHECK-NEXT:    lwz 22, 876(31)
757; CHECK-NEXT:    lwz 21, 764(31)
758; CHECK-NEXT:    lwz 20, 872(31)
759; CHECK-NEXT:    mulli 20, 20, 10
760; CHECK-NEXT:    add 21, 21, 20
761; CHECK-NEXT:    mullw 22, 22, 21
762; CHECK-NEXT:    slwi 22, 22, 4
763; CHECK-NEXT:    add 23, 23, 22
764; CHECK-NEXT:    evstddx 24, 23, 3
765; CHECK-NEXT:    li 24, 744
766; CHECK-NEXT:    evlddx 24, 31, 24
767; CHECK-NEXT:    li 23, 728
768; CHECK-NEXT:    evlddx 23, 31, 23
769; CHECK-NEXT:    efdmul 23, 23, 28
770; CHECK-NEXT:    efdadd 24, 23, 24
771; CHECK-NEXT:    li 23, 712
772; CHECK-NEXT:    evlddx 23, 31, 23
773; CHECK-NEXT:    efdmul 23, 23, 25
774; CHECK-NEXT:    efdadd 24, 23, 24
775; CHECK-NEXT:    li 23, 696
776; CHECK-NEXT:    evlddx 23, 31, 23
777; CHECK-NEXT:    efdmul 23, 23, 26
778; CHECK-NEXT:    efdadd 24, 23, 24
779; CHECK-NEXT:    li 23, 680
780; CHECK-NEXT:    evlddx 23, 31, 23
781; CHECK-NEXT:    efdmul 23, 23, 27
782; CHECK-NEXT:    efdadd 24, 23, 24
783; CHECK-NEXT:    li 23, 664
784; CHECK-NEXT:    evlddx 23, 31, 23
785; CHECK-NEXT:    efdmul 23, 23, 0
786; CHECK-NEXT:    efdadd 24, 23, 24
787; CHECK-NEXT:    li 23, 536
788; CHECK-NEXT:    evstddx 24, 31, 23
789; CHECK-NEXT:    evlddx 24, 29, 3
790; CHECK-NEXT:    evlddx 23, 5, 3
791; CHECK-NEXT:    efdmul 23, 23, 28
792; CHECK-NEXT:    efdadd 24, 23, 24
793; CHECK-NEXT:    evlddx 23, 7, 3
794; CHECK-NEXT:    efdmul 23, 23, 25
795; CHECK-NEXT:    efdadd 24, 23, 24
796; CHECK-NEXT:    evlddx 23, 9, 3
797; CHECK-NEXT:    efdmul 23, 23, 26
798; CHECK-NEXT:    efdadd 24, 23, 24
799; CHECK-NEXT:    evlddx 23, 11, 3
800; CHECK-NEXT:    efdmul 23, 23, 27
801; CHECK-NEXT:    efdadd 24, 23, 24
802; CHECK-NEXT:    evlddx 23, 30, 3
803; CHECK-NEXT:    efdmul 23, 23, 0
804; CHECK-NEXT:    efdadd 23, 23, 24
805; CHECK-NEXT:    addi 24, 31, 536
806; CHECK-NEXT:    evstddx 23, 24, 3
807; CHECK-NEXT:    li 23, 816
808; CHECK-NEXT:    evlddx 23, 31, 23
809; CHECK-NEXT:    li 22, 584
810; CHECK-NEXT:    evlddx 22, 31, 22
811; CHECK-NEXT:    li 21, 784
812; CHECK-NEXT:    evlddx 21, 31, 21
813; CHECK-NEXT:    li 20, 600
814; CHECK-NEXT:    evlddx 20, 31, 20
815; CHECK-NEXT:    efdmul 21, 21, 20
816; CHECK-NEXT:    efdmul 23, 23, 22
817; CHECK-NEXT:    efdadd 23, 23, 21
818; CHECK-NEXT:    li 22, 768
819; CHECK-NEXT:    evlddx 22, 31, 22
820; CHECK-NEXT:    li 21, 616
821; CHECK-NEXT:    evlddx 21, 31, 21
822; CHECK-NEXT:    efdmul 22, 22, 21
823; CHECK-NEXT:    efdsub 23, 23, 22
824; CHECK-NEXT:    li 22, 800
825; CHECK-NEXT:    evlddx 22, 31, 22
826; CHECK-NEXT:    li 21, 632
827; CHECK-NEXT:    evlddx 21, 31, 21
828; CHECK-NEXT:    efdmul 22, 22, 21
829; CHECK-NEXT:    efdsub 23, 23, 22
830; CHECK-NEXT:    li 22, 832
831; CHECK-NEXT:    evlddx 22, 31, 22
832; CHECK-NEXT:    li 21, 648
833; CHECK-NEXT:    evlddx 21, 31, 21
834; CHECK-NEXT:    efdmul 22, 22, 21
835; CHECK-NEXT:    efdsub 22, 23, 22
836; CHECK-NEXT:    addi 23, 31, 520
837; CHECK-NEXT:    evstddx 22, 23, 3
838; CHECK-NEXT:    li 22, 816
839; CHECK-NEXT:    evlddx 22, 31, 22
840; CHECK-NEXT:    evlddx 21, 4, 3
841; CHECK-NEXT:    li 20, 784
842; CHECK-NEXT:    evlddx 20, 31, 20
843; CHECK-NEXT:    evlddx 19, 6, 3
844; CHECK-NEXT:    efdmul 20, 20, 19
845; CHECK-NEXT:    efdmul 22, 22, 21
846; CHECK-NEXT:    efdadd 22, 22, 20
847; CHECK-NEXT:    li 21, 768
848; CHECK-NEXT:    evlddx 21, 31, 21
849; CHECK-NEXT:    evlddx 20, 8, 3
850; CHECK-NEXT:    efdmul 21, 21, 20
851; CHECK-NEXT:    efdsub 22, 22, 21
852; CHECK-NEXT:    li 21, 800
853; CHECK-NEXT:    evlddx 21, 31, 21
854; CHECK-NEXT:    evlddx 20, 10, 3
855; CHECK-NEXT:    efdmul 21, 21, 20
856; CHECK-NEXT:    efdsub 22, 22, 21
857; CHECK-NEXT:    li 21, 832
858; CHECK-NEXT:    evlddx 21, 31, 21
859; CHECK-NEXT:    evlddx 20, 12, 3
860; CHECK-NEXT:    efdmul 21, 21, 20
861; CHECK-NEXT:    efdsub 22, 22, 21
862; CHECK-NEXT:    efdneg 22, 22
863; CHECK-NEXT:    li 21, 520
864; CHECK-NEXT:    evstddx 22, 31, 21
865; CHECK-NEXT:    li 22, 536
866; CHECK-NEXT:    evlddx 22, 31, 22
867; CHECK-NEXT:    li 21, 520
868; CHECK-NEXT:    evlddx 21, 31, 21
869; CHECK-NEXT:    efdadd 22, 22, 21
870; CHECK-NEXT:    lwz 21, 864(31)
871; CHECK-NEXT:    lwz 20, 876(31)
872; CHECK-NEXT:    lwz 19, 764(31)
873; CHECK-NEXT:    lwz 18, 872(31)
874; CHECK-NEXT:    slwi 18, 18, 1
875; CHECK-NEXT:    add 19, 19, 18
876; CHECK-NEXT:    mullw 20, 20, 19
877; CHECK-NEXT:    slwi 20, 20, 4
878; CHECK-NEXT:    evstddx 22, 21, 20
879; CHECK-NEXT:    evlddx 22, 24, 3
880; CHECK-NEXT:    evlddx 21, 23, 3
881; CHECK-NEXT:    efdadd 22, 22, 21
882; CHECK-NEXT:    lwz 21, 864(31)
883; CHECK-NEXT:    lwz 20, 876(31)
884; CHECK-NEXT:    lwz 19, 764(31)
885; CHECK-NEXT:    lwz 18, 872(31)
886; CHECK-NEXT:    slwi 18, 18, 1
887; CHECK-NEXT:    add 19, 19, 18
888; CHECK-NEXT:    mullw 20, 20, 19
889; CHECK-NEXT:    slwi 20, 20, 4
890; CHECK-NEXT:    add 21, 21, 20
891; CHECK-NEXT:    evstddx 22, 21, 3
892; CHECK-NEXT:    li 22, 536
893; CHECK-NEXT:    evlddx 22, 31, 22
894; CHECK-NEXT:    li 21, 520
895; CHECK-NEXT:    evlddx 21, 31, 21
896; CHECK-NEXT:    efdsub 22, 22, 21
897; CHECK-NEXT:    lwz 21, 864(31)
898; CHECK-NEXT:    lwz 20, 876(31)
899; CHECK-NEXT:    lwz 19, 764(31)
900; CHECK-NEXT:    lwz 18, 872(31)
901; CHECK-NEXT:    mulli 18, 18, 9
902; CHECK-NEXT:    add 19, 19, 18
903; CHECK-NEXT:    mullw 20, 20, 19
904; CHECK-NEXT:    slwi 20, 20, 4
905; CHECK-NEXT:    evstddx 22, 21, 20
906; CHECK-NEXT:    evlddx 24, 24, 3
907; CHECK-NEXT:    evlddx 23, 23, 3
908; CHECK-NEXT:    efdsub 24, 24, 23
909; CHECK-NEXT:    lwz 23, 864(31)
910; CHECK-NEXT:    lwz 22, 876(31)
911; CHECK-NEXT:    lwz 21, 764(31)
912; CHECK-NEXT:    lwz 20, 872(31)
913; CHECK-NEXT:    mulli 20, 20, 9
914; CHECK-NEXT:    add 21, 21, 20
915; CHECK-NEXT:    mullw 22, 22, 21
916; CHECK-NEXT:    slwi 22, 22, 4
917; CHECK-NEXT:    add 23, 23, 22
918; CHECK-NEXT:    evstddx 24, 23, 3
919; CHECK-NEXT:    li 24, 744
920; CHECK-NEXT:    evlddx 24, 31, 24
921; CHECK-NEXT:    li 23, 728
922; CHECK-NEXT:    evlddx 23, 31, 23
923; CHECK-NEXT:    efdmul 23, 23, 27
924; CHECK-NEXT:    efdadd 24, 23, 24
925; CHECK-NEXT:    li 23, 712
926; CHECK-NEXT:    evlddx 23, 31, 23
927; CHECK-NEXT:    efdmul 23, 23, 26
928; CHECK-NEXT:    efdadd 24, 23, 24
929; CHECK-NEXT:    li 23, 696
930; CHECK-NEXT:    evlddx 23, 31, 23
931; CHECK-NEXT:    efdmul 23, 23, 28
932; CHECK-NEXT:    efdadd 24, 23, 24
933; CHECK-NEXT:    li 23, 680
934; CHECK-NEXT:    evlddx 23, 31, 23
935; CHECK-NEXT:    efdmul 23, 23, 0
936; CHECK-NEXT:    efdadd 24, 23, 24
937; CHECK-NEXT:    li 23, 664
938; CHECK-NEXT:    evlddx 23, 31, 23
939; CHECK-NEXT:    efdmul 23, 23, 25
940; CHECK-NEXT:    efdadd 24, 23, 24
941; CHECK-NEXT:    li 23, 504
942; CHECK-NEXT:    evstddx 24, 31, 23
943; CHECK-NEXT:    evlddx 24, 29, 3
944; CHECK-NEXT:    evlddx 23, 5, 3
945; CHECK-NEXT:    efdmul 23, 23, 27
946; CHECK-NEXT:    efdadd 24, 23, 24
947; CHECK-NEXT:    evlddx 23, 7, 3
948; CHECK-NEXT:    efdmul 23, 23, 26
949; CHECK-NEXT:    efdadd 24, 23, 24
950; CHECK-NEXT:    evlddx 23, 9, 3
951; CHECK-NEXT:    efdmul 23, 23, 28
952; CHECK-NEXT:    efdadd 24, 23, 24
953; CHECK-NEXT:    evlddx 23, 11, 3
954; CHECK-NEXT:    efdmul 23, 23, 0
955; CHECK-NEXT:    efdadd 24, 23, 24
956; CHECK-NEXT:    evlddx 23, 30, 3
957; CHECK-NEXT:    efdmul 23, 23, 25
958; CHECK-NEXT:    efdadd 23, 23, 24
959; CHECK-NEXT:    addi 24, 31, 504
960; CHECK-NEXT:    evstddx 23, 24, 3
961; CHECK-NEXT:    li 23, 800
962; CHECK-NEXT:    evlddx 23, 31, 23
963; CHECK-NEXT:    li 22, 584
964; CHECK-NEXT:    evlddx 22, 31, 22
965; CHECK-NEXT:    li 21, 768
966; CHECK-NEXT:    evlddx 21, 31, 21
967; CHECK-NEXT:    li 20, 600
968; CHECK-NEXT:    evlddx 20, 31, 20
969; CHECK-NEXT:    efdmul 21, 21, 20
970; CHECK-NEXT:    efdmul 23, 23, 22
971; CHECK-NEXT:    efdsub 23, 23, 21
972; CHECK-NEXT:    li 22, 816
973; CHECK-NEXT:    evlddx 22, 31, 22
974; CHECK-NEXT:    li 21, 616
975; CHECK-NEXT:    evlddx 21, 31, 21
976; CHECK-NEXT:    efdmul 22, 22, 21
977; CHECK-NEXT:    efdsub 23, 23, 22
978; CHECK-NEXT:    li 22, 832
979; CHECK-NEXT:    evlddx 22, 31, 22
980; CHECK-NEXT:    li 21, 632
981; CHECK-NEXT:    evlddx 21, 31, 21
982; CHECK-NEXT:    efdmul 22, 22, 21
983; CHECK-NEXT:    efdadd 23, 22, 23
984; CHECK-NEXT:    li 22, 784
985; CHECK-NEXT:    evlddx 22, 31, 22
986; CHECK-NEXT:    li 21, 648
987; CHECK-NEXT:    evlddx 21, 31, 21
988; CHECK-NEXT:    efdmul 22, 22, 21
989; CHECK-NEXT:    efdadd 22, 22, 23
990; CHECK-NEXT:    addi 23, 31, 488
991; CHECK-NEXT:    evstddx 22, 23, 3
992; CHECK-NEXT:    li 22, 800
993; CHECK-NEXT:    evlddx 22, 31, 22
994; CHECK-NEXT:    evlddx 21, 4, 3
995; CHECK-NEXT:    li 20, 768
996; CHECK-NEXT:    evlddx 20, 31, 20
997; CHECK-NEXT:    evlddx 19, 6, 3
998; CHECK-NEXT:    efdmul 20, 20, 19
999; CHECK-NEXT:    efdmul 22, 22, 21
1000; CHECK-NEXT:    efdsub 22, 22, 20
1001; CHECK-NEXT:    li 21, 816
1002; CHECK-NEXT:    evlddx 21, 31, 21
1003; CHECK-NEXT:    evlddx 20, 8, 3
1004; CHECK-NEXT:    efdmul 21, 21, 20
1005; CHECK-NEXT:    efdsub 22, 22, 21
1006; CHECK-NEXT:    li 21, 832
1007; CHECK-NEXT:    evlddx 21, 31, 21
1008; CHECK-NEXT:    evlddx 20, 10, 3
1009; CHECK-NEXT:    efdmul 21, 21, 20
1010; CHECK-NEXT:    efdadd 22, 21, 22
1011; CHECK-NEXT:    li 21, 784
1012; CHECK-NEXT:    evlddx 21, 31, 21
1013; CHECK-NEXT:    evlddx 20, 12, 3
1014; CHECK-NEXT:    efdmul 21, 21, 20
1015; CHECK-NEXT:    efdadd 22, 21, 22
1016; CHECK-NEXT:    efdneg 22, 22
1017; CHECK-NEXT:    li 21, 488
1018; CHECK-NEXT:    evstddx 22, 31, 21
1019; CHECK-NEXT:    li 22, 504
1020; CHECK-NEXT:    evlddx 22, 31, 22
1021; CHECK-NEXT:    li 21, 488
1022; CHECK-NEXT:    evlddx 21, 31, 21
1023; CHECK-NEXT:    efdadd 22, 22, 21
1024; CHECK-NEXT:    lwz 21, 864(31)
1025; CHECK-NEXT:    lwz 20, 876(31)
1026; CHECK-NEXT:    lwz 19, 764(31)
1027; CHECK-NEXT:    lwz 18, 872(31)
1028; CHECK-NEXT:    mulli 18, 18, 3
1029; CHECK-NEXT:    add 19, 19, 18
1030; CHECK-NEXT:    mullw 20, 20, 19
1031; CHECK-NEXT:    slwi 20, 20, 4
1032; CHECK-NEXT:    evstddx 22, 21, 20
1033; CHECK-NEXT:    evlddx 22, 24, 3
1034; CHECK-NEXT:    evlddx 21, 23, 3
1035; CHECK-NEXT:    efdadd 22, 22, 21
1036; CHECK-NEXT:    lwz 21, 864(31)
1037; CHECK-NEXT:    lwz 20, 876(31)
1038; CHECK-NEXT:    lwz 19, 764(31)
1039; CHECK-NEXT:    lwz 18, 872(31)
1040; CHECK-NEXT:    mulli 18, 18, 3
1041; CHECK-NEXT:    add 19, 19, 18
1042; CHECK-NEXT:    mullw 20, 20, 19
1043; CHECK-NEXT:    slwi 20, 20, 4
1044; CHECK-NEXT:    add 21, 21, 20
1045; CHECK-NEXT:    evstddx 22, 21, 3
1046; CHECK-NEXT:    li 22, 504
1047; CHECK-NEXT:    evlddx 22, 31, 22
1048; CHECK-NEXT:    li 21, 488
1049; CHECK-NEXT:    evlddx 21, 31, 21
1050; CHECK-NEXT:    efdsub 22, 22, 21
1051; CHECK-NEXT:    lwz 21, 864(31)
1052; CHECK-NEXT:    lwz 20, 876(31)
1053; CHECK-NEXT:    lwz 19, 764(31)
1054; CHECK-NEXT:    lwz 18, 872(31)
1055; CHECK-NEXT:    slwi 18, 18, 3
1056; CHECK-NEXT:    add 19, 19, 18
1057; CHECK-NEXT:    mullw 20, 20, 19
1058; CHECK-NEXT:    slwi 20, 20, 4
1059; CHECK-NEXT:    evstddx 22, 21, 20
1060; CHECK-NEXT:    evlddx 24, 24, 3
1061; CHECK-NEXT:    evlddx 23, 23, 3
1062; CHECK-NEXT:    efdsub 24, 24, 23
1063; CHECK-NEXT:    lwz 23, 864(31)
1064; CHECK-NEXT:    lwz 22, 876(31)
1065; CHECK-NEXT:    lwz 21, 764(31)
1066; CHECK-NEXT:    lwz 20, 872(31)
1067; CHECK-NEXT:    slwi 20, 20, 3
1068; CHECK-NEXT:    add 21, 21, 20
1069; CHECK-NEXT:    mullw 22, 22, 21
1070; CHECK-NEXT:    slwi 22, 22, 4
1071; CHECK-NEXT:    add 23, 23, 22
1072; CHECK-NEXT:    evstddx 24, 23, 3
1073; CHECK-NEXT:    li 24, 744
1074; CHECK-NEXT:    evlddx 24, 31, 24
1075; CHECK-NEXT:    li 23, 728
1076; CHECK-NEXT:    evlddx 23, 31, 23
1077; CHECK-NEXT:    efdmul 23, 23, 25
1078; CHECK-NEXT:    efdadd 24, 23, 24
1079; CHECK-NEXT:    li 23, 712
1080; CHECK-NEXT:    evlddx 23, 31, 23
1081; CHECK-NEXT:    efdmul 23, 23, 27
1082; CHECK-NEXT:    efdadd 24, 23, 24
1083; CHECK-NEXT:    li 23, 696
1084; CHECK-NEXT:    evlddx 23, 31, 23
1085; CHECK-NEXT:    efdmul 23, 23, 0
1086; CHECK-NEXT:    efdadd 24, 23, 24
1087; CHECK-NEXT:    li 23, 680
1088; CHECK-NEXT:    evlddx 23, 31, 23
1089; CHECK-NEXT:    efdmul 23, 23, 26
1090; CHECK-NEXT:    efdadd 24, 23, 24
1091; CHECK-NEXT:    li 23, 664
1092; CHECK-NEXT:    evlddx 23, 31, 23
1093; CHECK-NEXT:    efdmul 23, 23, 28
1094; CHECK-NEXT:    efdadd 24, 23, 24
1095; CHECK-NEXT:    li 23, 472
1096; CHECK-NEXT:    evstddx 24, 31, 23
1097; CHECK-NEXT:    evlddx 29, 29, 3
1098; CHECK-NEXT:    evlddx 5, 5, 3
1099; CHECK-NEXT:    efdmul 5, 5, 25
1100; CHECK-NEXT:    efdadd 5, 5, 29
1101; CHECK-NEXT:    evlddx 7, 7, 3
1102; CHECK-NEXT:    efdmul 7, 7, 27
1103; CHECK-NEXT:    efdadd 5, 7, 5
1104; CHECK-NEXT:    evlddx 7, 9, 3
1105; CHECK-NEXT:    efdmul 7, 7, 0
1106; CHECK-NEXT:    efdadd 5, 7, 5
1107; CHECK-NEXT:    evlddx 7, 11, 3
1108; CHECK-NEXT:    efdmul 7, 7, 26
1109; CHECK-NEXT:    efdadd 5, 7, 5
1110; CHECK-NEXT:    evlddx 7, 30, 3
1111; CHECK-NEXT:    efdmul 7, 7, 28
1112; CHECK-NEXT:    efdadd 7, 7, 5
1113; CHECK-NEXT:    addi 5, 31, 472
1114; CHECK-NEXT:    evstddx 7, 5, 3
1115; CHECK-NEXT:    li 7, 784
1116; CHECK-NEXT:    evlddx 7, 31, 7
1117; CHECK-NEXT:    li 9, 584
1118; CHECK-NEXT:    evlddx 9, 31, 9
1119; CHECK-NEXT:    li 11, 800
1120; CHECK-NEXT:    evlddx 11, 31, 11
1121; CHECK-NEXT:    li 30, 600
1122; CHECK-NEXT:    evlddx 0, 31, 30
1123; CHECK-NEXT:    efdmul 11, 11, 0
1124; CHECK-NEXT:    efdmul 7, 7, 9
1125; CHECK-NEXT:    efdsub 7, 7, 11
1126; CHECK-NEXT:    li 9, 832
1127; CHECK-NEXT:    evlddx 9, 31, 9
1128; CHECK-NEXT:    li 11, 616
1129; CHECK-NEXT:    evlddx 11, 31, 11
1130; CHECK-NEXT:    efdmul 9, 9, 11
1131; CHECK-NEXT:    efdadd 7, 9, 7
1132; CHECK-NEXT:    li 9, 768
1133; CHECK-NEXT:    evlddx 9, 31, 9
1134; CHECK-NEXT:    li 11, 632
1135; CHECK-NEXT:    evlddx 11, 31, 11
1136; CHECK-NEXT:    efdmul 9, 9, 11
1137; CHECK-NEXT:    efdadd 7, 9, 7
1138; CHECK-NEXT:    li 9, 816
1139; CHECK-NEXT:    evlddx 9, 31, 9
1140; CHECK-NEXT:    li 11, 648
1141; CHECK-NEXT:    evlddx 11, 31, 11
1142; CHECK-NEXT:    efdmul 9, 9, 11
1143; CHECK-NEXT:    efdsub 9, 7, 9
1144; CHECK-NEXT:    addi 7, 31, 456
1145; CHECK-NEXT:    evstddx 9, 7, 3
1146; CHECK-NEXT:    li 9, 784
1147; CHECK-NEXT:    evlddx 9, 31, 9
1148; CHECK-NEXT:    evlddx 4, 4, 3
1149; CHECK-NEXT:    li 11, 800
1150; CHECK-NEXT:    evlddx 11, 31, 11
1151; CHECK-NEXT:    evlddx 6, 6, 3
1152; CHECK-NEXT:    efdmul 6, 11, 6
1153; CHECK-NEXT:    efdmul 4, 9, 4
1154; CHECK-NEXT:    efdsub 4, 4, 6
1155; CHECK-NEXT:    li 6, 832
1156; CHECK-NEXT:    evlddx 6, 31, 6
1157; CHECK-NEXT:    evlddx 8, 8, 3
1158; CHECK-NEXT:    efdmul 6, 6, 8
1159; CHECK-NEXT:    efdadd 4, 6, 4
1160; CHECK-NEXT:    li 6, 768
1161; CHECK-NEXT:    evlddx 6, 31, 6
1162; CHECK-NEXT:    evlddx 8, 10, 3
1163; CHECK-NEXT:    efdmul 6, 6, 8
1164; CHECK-NEXT:    efdadd 4, 6, 4
1165; CHECK-NEXT:    li 6, 816
1166; CHECK-NEXT:    evlddx 6, 31, 6
1167; CHECK-NEXT:    evlddx 8, 12, 3
1168; CHECK-NEXT:    efdmul 6, 6, 8
1169; CHECK-NEXT:    efdsub 4, 4, 6
1170; CHECK-NEXT:    efdneg 4, 4
1171; CHECK-NEXT:    li 6, 456
1172; CHECK-NEXT:    evstddx 4, 31, 6
1173; CHECK-NEXT:    li 4, 472
1174; CHECK-NEXT:    evlddx 4, 31, 4
1175; CHECK-NEXT:    li 6, 456
1176; CHECK-NEXT:    evlddx 6, 31, 6
1177; CHECK-NEXT:    efdadd 4, 4, 6
1178; CHECK-NEXT:    lwz 6, 864(31)
1179; CHECK-NEXT:    lwz 8, 876(31)
1180; CHECK-NEXT:    lwz 9, 764(31)
1181; CHECK-NEXT:    lwz 10, 872(31)
1182; CHECK-NEXT:    slwi 10, 10, 2
1183; CHECK-NEXT:    add 9, 9, 10
1184; CHECK-NEXT:    mullw 8, 8, 9
1185; CHECK-NEXT:    slwi 8, 8, 4
1186; CHECK-NEXT:    evstddx 4, 6, 8
1187; CHECK-NEXT:    evlddx 4, 5, 3
1188; CHECK-NEXT:    evlddx 6, 7, 3
1189; CHECK-NEXT:    efdadd 4, 4, 6
1190; CHECK-NEXT:    lwz 6, 864(31)
1191; CHECK-NEXT:    lwz 8, 876(31)
1192; CHECK-NEXT:    lwz 9, 764(31)
1193; CHECK-NEXT:    lwz 10, 872(31)
1194; CHECK-NEXT:    slwi 10, 10, 2
1195; CHECK-NEXT:    add 9, 9, 10
1196; CHECK-NEXT:    mullw 8, 8, 9
1197; CHECK-NEXT:    slwi 8, 8, 4
1198; CHECK-NEXT:    add 6, 6, 8
1199; CHECK-NEXT:    evstddx 4, 6, 3
1200; CHECK-NEXT:    li 4, 472
1201; CHECK-NEXT:    evlddx 4, 31, 4
1202; CHECK-NEXT:    li 6, 456
1203; CHECK-NEXT:    evlddx 6, 31, 6
1204; CHECK-NEXT:    efdsub 4, 4, 6
1205; CHECK-NEXT:    lwz 6, 864(31)
1206; CHECK-NEXT:    lwz 8, 876(31)
1207; CHECK-NEXT:    lwz 9, 764(31)
1208; CHECK-NEXT:    lwz 10, 872(31)
1209; CHECK-NEXT:    mulli 10, 10, 7
1210; CHECK-NEXT:    add 9, 9, 10
1211; CHECK-NEXT:    mullw 8, 8, 9
1212; CHECK-NEXT:    slwi 8, 8, 4
1213; CHECK-NEXT:    evstddx 4, 6, 8
1214; CHECK-NEXT:    evlddx 4, 5, 3
1215; CHECK-NEXT:    evlddx 5, 7, 3
1216; CHECK-NEXT:    efdsub 4, 4, 5
1217; CHECK-NEXT:    lwz 5, 864(31)
1218; CHECK-NEXT:    lwz 6, 876(31)
1219; CHECK-NEXT:    lwz 7, 764(31)
1220; CHECK-NEXT:    lwz 8, 872(31)
1221; CHECK-NEXT:    mulli 8, 8, 7
1222; CHECK-NEXT:    add 7, 7, 8
1223; CHECK-NEXT:    mullw 6, 6, 7
1224; CHECK-NEXT:    slwi 6, 6, 4
1225; CHECK-NEXT:    add 5, 5, 6
1226; CHECK-NEXT:    evstddx 4, 5, 3
1227; CHECK-NEXT:    li 3, 1
1228; CHECK-NEXT:    stw 3, 452(31)
1229; CHECK-NEXT:    b .LBB1_3
1230; CHECK-NEXT:  .LBB1_3: # Parent Loop BB1_1 Depth=1
1231; CHECK-NEXT:    # => This Inner Loop Header: Depth=2
1232; CHECK-NEXT:    lwz 3, 452(31)
1233; CHECK-NEXT:    lwz 4, 876(31)
1234; CHECK-NEXT:    cmplw 3, 4
1235; CHECK-NEXT:    bge 0, .LBB1_6
1236; CHECK-NEXT:    b .LBB1_4
1237; CHECK-NEXT:  .LBB1_4:
1238; CHECK-NEXT:    lwz 3, 868(31)
1239; CHECK-NEXT:    lwz 4, 452(31)
1240; CHECK-NEXT:    lwz 5, 876(31)
1241; CHECK-NEXT:    lwz 6, 764(31)
1242; CHECK-NEXT:    mullw 5, 6, 5
1243; CHECK-NEXT:    mulli 5, 5, 11
1244; CHECK-NEXT:    add 4, 4, 5
1245; CHECK-NEXT:    slwi 4, 4, 4
1246; CHECK-NEXT:    lwzux 4, 3, 4
1247; CHECK-NEXT:    stw 4, 432(31)
1248; CHECK-NEXT:    lwz 4, 12(3)
1249; CHECK-NEXT:    stw 4, 444(31)
1250; CHECK-NEXT:    lwz 4, 8(3)
1251; CHECK-NEXT:    stw 4, 440(31)
1252; CHECK-NEXT:    lwz 3, 4(3)
1253; CHECK-NEXT:    stw 3, 436(31)
1254; CHECK-NEXT:    lwz 3, 868(31)
1255; CHECK-NEXT:    lwz 4, 452(31)
1256; CHECK-NEXT:    lwz 5, 876(31)
1257; CHECK-NEXT:    lwz 6, 764(31)
1258; CHECK-NEXT:    mulli 6, 6, 11
1259; CHECK-NEXT:    addi 7, 6, 1
1260; CHECK-NEXT:    mullw 7, 5, 7
1261; CHECK-NEXT:    add 7, 4, 7
1262; CHECK-NEXT:    slwi 7, 7, 4
1263; CHECK-NEXT:    evlddx 7, 3, 7
1264; CHECK-NEXT:    addi 6, 6, 10
1265; CHECK-NEXT:    mullw 5, 5, 6
1266; CHECK-NEXT:    add 4, 4, 5
1267; CHECK-NEXT:    slwi 4, 4, 4
1268; CHECK-NEXT:    evlddx 3, 3, 4
1269; CHECK-NEXT:    efdadd 3, 7, 3
1270; CHECK-NEXT:    li 4, 416
1271; CHECK-NEXT:    evstddx 3, 31, 4
1272; CHECK-NEXT:    lwz 4, 868(31)
1273; CHECK-NEXT:    lwz 5, 452(31)
1274; CHECK-NEXT:    lwz 6, 876(31)
1275; CHECK-NEXT:    lwz 3, 764(31)
1276; CHECK-NEXT:    mulli 7, 3, 11
1277; CHECK-NEXT:    addi 3, 7, 1
1278; CHECK-NEXT:    mullw 3, 6, 3
1279; CHECK-NEXT:    add 3, 5, 3
1280; CHECK-NEXT:    slwi 3, 3, 4
1281; CHECK-NEXT:    add 8, 4, 3
1282; CHECK-NEXT:    li 3, 8
1283; CHECK-NEXT:    evlddx 8, 8, 3
1284; CHECK-NEXT:    addi 7, 7, 10
1285; CHECK-NEXT:    mullw 6, 6, 7
1286; CHECK-NEXT:    add 5, 5, 6
1287; CHECK-NEXT:    slwi 5, 5, 4
1288; CHECK-NEXT:    add 4, 4, 5
1289; CHECK-NEXT:    evlddx 4, 4, 3
1290; CHECK-NEXT:    efdadd 4, 8, 4
1291; CHECK-NEXT:    addi 5, 31, 416
1292; CHECK-NEXT:    evstddx 4, 5, 3
1293; CHECK-NEXT:    lwz 4, 868(31)
1294; CHECK-NEXT:    lwz 6, 452(31)
1295; CHECK-NEXT:    lwz 7, 876(31)
1296; CHECK-NEXT:    lwz 8, 764(31)
1297; CHECK-NEXT:    mulli 8, 8, 11
1298; CHECK-NEXT:    addi 9, 8, 1
1299; CHECK-NEXT:    mullw 9, 7, 9
1300; CHECK-NEXT:    add 9, 6, 9
1301; CHECK-NEXT:    slwi 9, 9, 4
1302; CHECK-NEXT:    evlddx 9, 4, 9
1303; CHECK-NEXT:    addi 8, 8, 10
1304; CHECK-NEXT:    mullw 7, 7, 8
1305; CHECK-NEXT:    add 6, 6, 7
1306; CHECK-NEXT:    slwi 6, 6, 4
1307; CHECK-NEXT:    evlddx 4, 4, 6
1308; CHECK-NEXT:    efdsub 4, 9, 4
1309; CHECK-NEXT:    li 6, 272
1310; CHECK-NEXT:    evstddx 4, 31, 6
1311; CHECK-NEXT:    lwz 4, 868(31)
1312; CHECK-NEXT:    lwz 6, 452(31)
1313; CHECK-NEXT:    lwz 7, 876(31)
1314; CHECK-NEXT:    lwz 8, 764(31)
1315; CHECK-NEXT:    mulli 8, 8, 11
1316; CHECK-NEXT:    addi 9, 8, 1
1317; CHECK-NEXT:    mullw 9, 7, 9
1318; CHECK-NEXT:    add 9, 6, 9
1319; CHECK-NEXT:    slwi 9, 9, 4
1320; CHECK-NEXT:    add 9, 4, 9
1321; CHECK-NEXT:    evlddx 9, 9, 3
1322; CHECK-NEXT:    addi 8, 8, 10
1323; CHECK-NEXT:    mullw 7, 7, 8
1324; CHECK-NEXT:    add 6, 6, 7
1325; CHECK-NEXT:    slwi 6, 6, 4
1326; CHECK-NEXT:    add 4, 4, 6
1327; CHECK-NEXT:    evlddx 4, 4, 3
1328; CHECK-NEXT:    efdsub 6, 9, 4
1329; CHECK-NEXT:    addi 4, 31, 272
1330; CHECK-NEXT:    evstddx 6, 4, 3
1331; CHECK-NEXT:    lwz 6, 868(31)
1332; CHECK-NEXT:    lwz 7, 452(31)
1333; CHECK-NEXT:    lwz 8, 876(31)
1334; CHECK-NEXT:    lwz 9, 764(31)
1335; CHECK-NEXT:    mulli 9, 9, 11
1336; CHECK-NEXT:    addi 10, 9, 2
1337; CHECK-NEXT:    mullw 10, 8, 10
1338; CHECK-NEXT:    add 10, 7, 10
1339; CHECK-NEXT:    slwi 10, 10, 4
1340; CHECK-NEXT:    evlddx 10, 6, 10
1341; CHECK-NEXT:    addi 9, 9, 9
1342; CHECK-NEXT:    mullw 8, 8, 9
1343; CHECK-NEXT:    add 7, 7, 8
1344; CHECK-NEXT:    slwi 7, 7, 4
1345; CHECK-NEXT:    evlddx 6, 6, 7
1346; CHECK-NEXT:    efdadd 6, 10, 6
1347; CHECK-NEXT:    li 7, 400
1348; CHECK-NEXT:    evstddx 6, 31, 7
1349; CHECK-NEXT:    lwz 6, 868(31)
1350; CHECK-NEXT:    lwz 7, 452(31)
1351; CHECK-NEXT:    lwz 8, 876(31)
1352; CHECK-NEXT:    lwz 9, 764(31)
1353; CHECK-NEXT:    mulli 9, 9, 11
1354; CHECK-NEXT:    addi 10, 9, 2
1355; CHECK-NEXT:    mullw 10, 8, 10
1356; CHECK-NEXT:    add 10, 7, 10
1357; CHECK-NEXT:    slwi 10, 10, 4
1358; CHECK-NEXT:    add 10, 6, 10
1359; CHECK-NEXT:    evlddx 10, 10, 3
1360; CHECK-NEXT:    addi 9, 9, 9
1361; CHECK-NEXT:    mullw 8, 8, 9
1362; CHECK-NEXT:    add 7, 7, 8
1363; CHECK-NEXT:    slwi 7, 7, 4
1364; CHECK-NEXT:    add 6, 6, 7
1365; CHECK-NEXT:    evlddx 6, 6, 3
1366; CHECK-NEXT:    efdadd 6, 10, 6
1367; CHECK-NEXT:    addi 7, 31, 400
1368; CHECK-NEXT:    evstddx 6, 7, 3
1369; CHECK-NEXT:    lwz 6, 868(31)
1370; CHECK-NEXT:    lwz 8, 452(31)
1371; CHECK-NEXT:    lwz 9, 876(31)
1372; CHECK-NEXT:    lwz 10, 764(31)
1373; CHECK-NEXT:    mulli 10, 10, 11
1374; CHECK-NEXT:    addi 11, 10, 2
1375; CHECK-NEXT:    mullw 11, 9, 11
1376; CHECK-NEXT:    add 11, 8, 11
1377; CHECK-NEXT:    slwi 11, 11, 4
1378; CHECK-NEXT:    evlddx 11, 6, 11
1379; CHECK-NEXT:    addi 10, 10, 9
1380; CHECK-NEXT:    mullw 9, 9, 10
1381; CHECK-NEXT:    add 8, 8, 9
1382; CHECK-NEXT:    slwi 8, 8, 4
1383; CHECK-NEXT:    evlddx 6, 6, 8
1384; CHECK-NEXT:    efdsub 6, 11, 6
1385; CHECK-NEXT:    li 8, 288
1386; CHECK-NEXT:    evstddx 6, 31, 8
1387; CHECK-NEXT:    lwz 6, 868(31)
1388; CHECK-NEXT:    lwz 8, 452(31)
1389; CHECK-NEXT:    lwz 9, 876(31)
1390; CHECK-NEXT:    lwz 10, 764(31)
1391; CHECK-NEXT:    mulli 10, 10, 11
1392; CHECK-NEXT:    addi 11, 10, 2
1393; CHECK-NEXT:    mullw 11, 9, 11
1394; CHECK-NEXT:    add 11, 8, 11
1395; CHECK-NEXT:    slwi 11, 11, 4
1396; CHECK-NEXT:    add 11, 6, 11
1397; CHECK-NEXT:    evlddx 11, 11, 3
1398; CHECK-NEXT:    addi 10, 10, 9
1399; CHECK-NEXT:    mullw 9, 9, 10
1400; CHECK-NEXT:    add 8, 8, 9
1401; CHECK-NEXT:    slwi 8, 8, 4
1402; CHECK-NEXT:    add 6, 6, 8
1403; CHECK-NEXT:    evlddx 6, 6, 3
1404; CHECK-NEXT:    efdsub 8, 11, 6
1405; CHECK-NEXT:    addi 6, 31, 288
1406; CHECK-NEXT:    evstddx 8, 6, 3
1407; CHECK-NEXT:    lwz 8, 868(31)
1408; CHECK-NEXT:    lwz 9, 452(31)
1409; CHECK-NEXT:    lwz 10, 876(31)
1410; CHECK-NEXT:    lwz 11, 764(31)
1411; CHECK-NEXT:    mulli 11, 11, 11
1412; CHECK-NEXT:    addi 12, 11, 3
1413; CHECK-NEXT:    mullw 12, 10, 12
1414; CHECK-NEXT:    add 12, 9, 12
1415; CHECK-NEXT:    slwi 12, 12, 4
1416; CHECK-NEXT:    evlddx 12, 8, 12
1417; CHECK-NEXT:    addi 11, 11, 8
1418; CHECK-NEXT:    mullw 10, 10, 11
1419; CHECK-NEXT:    add 9, 9, 10
1420; CHECK-NEXT:    slwi 9, 9, 4
1421; CHECK-NEXT:    evlddx 8, 8, 9
1422; CHECK-NEXT:    efdadd 8, 12, 8
1423; CHECK-NEXT:    li 9, 384
1424; CHECK-NEXT:    evstddx 8, 31, 9
1425; CHECK-NEXT:    lwz 8, 868(31)
1426; CHECK-NEXT:    lwz 9, 452(31)
1427; CHECK-NEXT:    lwz 10, 876(31)
1428; CHECK-NEXT:    lwz 11, 764(31)
1429; CHECK-NEXT:    mulli 11, 11, 11
1430; CHECK-NEXT:    addi 12, 11, 3
1431; CHECK-NEXT:    mullw 12, 10, 12
1432; CHECK-NEXT:    add 12, 9, 12
1433; CHECK-NEXT:    slwi 12, 12, 4
1434; CHECK-NEXT:    add 12, 8, 12
1435; CHECK-NEXT:    evlddx 12, 12, 3
1436; CHECK-NEXT:    addi 11, 11, 8
1437; CHECK-NEXT:    mullw 10, 10, 11
1438; CHECK-NEXT:    add 9, 9, 10
1439; CHECK-NEXT:    slwi 9, 9, 4
1440; CHECK-NEXT:    add 8, 8, 9
1441; CHECK-NEXT:    evlddx 8, 8, 3
1442; CHECK-NEXT:    efdadd 8, 12, 8
1443; CHECK-NEXT:    addi 9, 31, 384
1444; CHECK-NEXT:    evstddx 8, 9, 3
1445; CHECK-NEXT:    lwz 8, 868(31)
1446; CHECK-NEXT:    lwz 10, 452(31)
1447; CHECK-NEXT:    lwz 11, 876(31)
1448; CHECK-NEXT:    lwz 12, 764(31)
1449; CHECK-NEXT:    mulli 12, 12, 11
1450; CHECK-NEXT:    addi 0, 12, 3
1451; CHECK-NEXT:    mullw 0, 11, 0
1452; CHECK-NEXT:    add 0, 10, 0
1453; CHECK-NEXT:    slwi 0, 0, 4
1454; CHECK-NEXT:    evlddx 0, 8, 0
1455; CHECK-NEXT:    addi 12, 12, 8
1456; CHECK-NEXT:    mullw 11, 11, 12
1457; CHECK-NEXT:    add 10, 10, 11
1458; CHECK-NEXT:    slwi 10, 10, 4
1459; CHECK-NEXT:    evlddx 8, 8, 10
1460; CHECK-NEXT:    efdsub 8, 0, 8
1461; CHECK-NEXT:    li 10, 304
1462; CHECK-NEXT:    evstddx 8, 31, 10
1463; CHECK-NEXT:    lwz 8, 868(31)
1464; CHECK-NEXT:    lwz 10, 452(31)
1465; CHECK-NEXT:    lwz 11, 876(31)
1466; CHECK-NEXT:    lwz 12, 764(31)
1467; CHECK-NEXT:    mulli 12, 12, 11
1468; CHECK-NEXT:    addi 0, 12, 3
1469; CHECK-NEXT:    mullw 0, 11, 0
1470; CHECK-NEXT:    add 0, 10, 0
1471; CHECK-NEXT:    slwi 0, 0, 4
1472; CHECK-NEXT:    add 30, 8, 0
1473; CHECK-NEXT:    evlddx 0, 30, 3
1474; CHECK-NEXT:    addi 12, 12, 8
1475; CHECK-NEXT:    mullw 11, 11, 12
1476; CHECK-NEXT:    add 10, 10, 11
1477; CHECK-NEXT:    slwi 10, 10, 4
1478; CHECK-NEXT:    add 8, 8, 10
1479; CHECK-NEXT:    evlddx 8, 8, 3
1480; CHECK-NEXT:    efdsub 10, 0, 8
1481; CHECK-NEXT:    addi 8, 31, 304
1482; CHECK-NEXT:    evstddx 10, 8, 3
1483; CHECK-NEXT:    lwz 10, 868(31)
1484; CHECK-NEXT:    lwz 11, 452(31)
1485; CHECK-NEXT:    lwz 12, 876(31)
1486; CHECK-NEXT:    lwz 0, 764(31)
1487; CHECK-NEXT:    mulli 30, 0, 11
1488; CHECK-NEXT:    addi 0, 30, 4
1489; CHECK-NEXT:    mullw 0, 12, 0
1490; CHECK-NEXT:    add 0, 11, 0
1491; CHECK-NEXT:    slwi 0, 0, 4
1492; CHECK-NEXT:    evlddx 0, 10, 0
1493; CHECK-NEXT:    addi 30, 30, 7
1494; CHECK-NEXT:    mullw 12, 12, 30
1495; CHECK-NEXT:    add 11, 11, 12
1496; CHECK-NEXT:    slwi 11, 11, 4
1497; CHECK-NEXT:    evlddx 10, 10, 11
1498; CHECK-NEXT:    efdadd 10, 0, 10
1499; CHECK-NEXT:    li 11, 368
1500; CHECK-NEXT:    evstddx 10, 31, 11
1501; CHECK-NEXT:    lwz 10, 868(31)
1502; CHECK-NEXT:    lwz 11, 452(31)
1503; CHECK-NEXT:    lwz 12, 876(31)
1504; CHECK-NEXT:    lwz 0, 764(31)
1505; CHECK-NEXT:    mulli 30, 0, 11
1506; CHECK-NEXT:    addi 0, 30, 4
1507; CHECK-NEXT:    mullw 0, 12, 0
1508; CHECK-NEXT:    add 0, 11, 0
1509; CHECK-NEXT:    slwi 0, 0, 4
1510; CHECK-NEXT:    add 29, 10, 0
1511; CHECK-NEXT:    evlddx 0, 29, 3
1512; CHECK-NEXT:    addi 30, 30, 7
1513; CHECK-NEXT:    mullw 12, 12, 30
1514; CHECK-NEXT:    add 11, 11, 12
1515; CHECK-NEXT:    slwi 11, 11, 4
1516; CHECK-NEXT:    add 10, 10, 11
1517; CHECK-NEXT:    evlddx 10, 10, 3
1518; CHECK-NEXT:    efdadd 10, 0, 10
1519; CHECK-NEXT:    addi 11, 31, 368
1520; CHECK-NEXT:    evstddx 10, 11, 3
1521; CHECK-NEXT:    lwz 10, 868(31)
1522; CHECK-NEXT:    lwz 12, 452(31)
1523; CHECK-NEXT:    lwz 0, 876(31)
1524; CHECK-NEXT:    lwz 30, 764(31)
1525; CHECK-NEXT:    mulli 30, 30, 11
1526; CHECK-NEXT:    addi 29, 30, 4
1527; CHECK-NEXT:    mullw 29, 0, 29
1528; CHECK-NEXT:    add 29, 12, 29
1529; CHECK-NEXT:    slwi 29, 29, 4
1530; CHECK-NEXT:    evlddx 29, 10, 29
1531; CHECK-NEXT:    addi 30, 30, 7
1532; CHECK-NEXT:    mullw 0, 0, 30
1533; CHECK-NEXT:    add 12, 12, 0
1534; CHECK-NEXT:    slwi 12, 12, 4
1535; CHECK-NEXT:    evlddx 10, 10, 12
1536; CHECK-NEXT:    efdsub 10, 29, 10
1537; CHECK-NEXT:    li 12, 320
1538; CHECK-NEXT:    evstddx 10, 31, 12
1539; CHECK-NEXT:    lwz 10, 868(31)
1540; CHECK-NEXT:    lwz 12, 452(31)
1541; CHECK-NEXT:    lwz 0, 876(31)
1542; CHECK-NEXT:    lwz 30, 764(31)
1543; CHECK-NEXT:    mulli 30, 30, 11
1544; CHECK-NEXT:    addi 29, 30, 4
1545; CHECK-NEXT:    mullw 29, 0, 29
1546; CHECK-NEXT:    add 29, 12, 29
1547; CHECK-NEXT:    slwi 29, 29, 4
1548; CHECK-NEXT:    add 29, 10, 29
1549; CHECK-NEXT:    evlddx 29, 29, 3
1550; CHECK-NEXT:    addi 30, 30, 7
1551; CHECK-NEXT:    mullw 0, 0, 30
1552; CHECK-NEXT:    add 12, 12, 0
1553; CHECK-NEXT:    slwi 12, 12, 4
1554; CHECK-NEXT:    add 10, 10, 12
1555; CHECK-NEXT:    evlddx 10, 10, 3
1556; CHECK-NEXT:    efdsub 12, 29, 10
1557; CHECK-NEXT:    addi 10, 31, 320
1558; CHECK-NEXT:    evstddx 12, 10, 3
1559; CHECK-NEXT:    lwz 12, 868(31)
1560; CHECK-NEXT:    lwz 0, 452(31)
1561; CHECK-NEXT:    lwz 30, 876(31)
1562; CHECK-NEXT:    lwz 29, 764(31)
1563; CHECK-NEXT:    mulli 29, 29, 11
1564; CHECK-NEXT:    addi 28, 29, 5
1565; CHECK-NEXT:    mullw 28, 30, 28
1566; CHECK-NEXT:    add 28, 0, 28
1567; CHECK-NEXT:    slwi 28, 28, 4
1568; CHECK-NEXT:    evlddx 28, 12, 28
1569; CHECK-NEXT:    addi 29, 29, 6
1570; CHECK-NEXT:    mullw 30, 30, 29
1571; CHECK-NEXT:    add 0, 0, 30
1572; CHECK-NEXT:    slwi 0, 0, 4
1573; CHECK-NEXT:    evlddx 12, 12, 0
1574; CHECK-NEXT:    efdadd 12, 28, 12
1575; CHECK-NEXT:    li 30, 352
1576; CHECK-NEXT:    evstddx 12, 31, 30
1577; CHECK-NEXT:    lwz 12, 868(31)
1578; CHECK-NEXT:    lwz 0, 452(31)
1579; CHECK-NEXT:    lwz 30, 876(31)
1580; CHECK-NEXT:    lwz 29, 764(31)
1581; CHECK-NEXT:    mulli 29, 29, 11
1582; CHECK-NEXT:    addi 28, 29, 5
1583; CHECK-NEXT:    mullw 28, 30, 28
1584; CHECK-NEXT:    add 28, 0, 28
1585; CHECK-NEXT:    slwi 28, 28, 4
1586; CHECK-NEXT:    add 28, 12, 28
1587; CHECK-NEXT:    evlddx 28, 28, 3
1588; CHECK-NEXT:    addi 29, 29, 6
1589; CHECK-NEXT:    mullw 30, 30, 29
1590; CHECK-NEXT:    add 0, 0, 30
1591; CHECK-NEXT:    slwi 0, 0, 4
1592; CHECK-NEXT:    add 12, 12, 0
1593; CHECK-NEXT:    evlddx 12, 12, 3
1594; CHECK-NEXT:    efdadd 12, 28, 12
1595; CHECK-NEXT:    addi 30, 31, 352
1596; CHECK-NEXT:    evstddx 12, 30, 3
1597; CHECK-NEXT:    lwz 12, 868(31)
1598; CHECK-NEXT:    lwz 0, 452(31)
1599; CHECK-NEXT:    lwz 29, 876(31)
1600; CHECK-NEXT:    lwz 28, 764(31)
1601; CHECK-NEXT:    mulli 28, 28, 11
1602; CHECK-NEXT:    addi 27, 28, 5
1603; CHECK-NEXT:    mullw 27, 29, 27
1604; CHECK-NEXT:    add 27, 0, 27
1605; CHECK-NEXT:    slwi 27, 27, 4
1606; CHECK-NEXT:    evlddx 27, 12, 27
1607; CHECK-NEXT:    addi 28, 28, 6
1608; CHECK-NEXT:    mullw 29, 29, 28
1609; CHECK-NEXT:    add 0, 0, 29
1610; CHECK-NEXT:    slwi 0, 0, 4
1611; CHECK-NEXT:    evlddx 12, 12, 0
1612; CHECK-NEXT:    efdsub 12, 27, 12
1613; CHECK-NEXT:    li 29, 336
1614; CHECK-NEXT:    evstddx 12, 31, 29
1615; CHECK-NEXT:    lwz 12, 868(31)
1616; CHECK-NEXT:    lwz 0, 452(31)
1617; CHECK-NEXT:    lwz 29, 876(31)
1618; CHECK-NEXT:    lwz 28, 764(31)
1619; CHECK-NEXT:    mulli 28, 28, 11
1620; CHECK-NEXT:    addi 27, 28, 5
1621; CHECK-NEXT:    mullw 27, 29, 27
1622; CHECK-NEXT:    add 27, 0, 27
1623; CHECK-NEXT:    slwi 27, 27, 4
1624; CHECK-NEXT:    add 27, 12, 27
1625; CHECK-NEXT:    evlddx 27, 27, 3
1626; CHECK-NEXT:    addi 28, 28, 6
1627; CHECK-NEXT:    mullw 29, 29, 28
1628; CHECK-NEXT:    add 0, 0, 29
1629; CHECK-NEXT:    slwi 0, 0, 4
1630; CHECK-NEXT:    add 12, 12, 0
1631; CHECK-NEXT:    evlddx 12, 12, 3
1632; CHECK-NEXT:    efdsub 0, 27, 12
1633; CHECK-NEXT:    addi 12, 31, 336
1634; CHECK-NEXT:    evstddx 0, 12, 3
1635; CHECK-NEXT:    li 29, 432
1636; CHECK-NEXT:    evlddx 0, 31, 29
1637; CHECK-NEXT:    li 29, 416
1638; CHECK-NEXT:    evlddx 29, 31, 29
1639; CHECK-NEXT:    efdadd 0, 0, 29
1640; CHECK-NEXT:    li 29, 400
1641; CHECK-NEXT:    evlddx 29, 31, 29
1642; CHECK-NEXT:    efdadd 0, 0, 29
1643; CHECK-NEXT:    li 29, 384
1644; CHECK-NEXT:    evlddx 29, 31, 29
1645; CHECK-NEXT:    efdadd 0, 0, 29
1646; CHECK-NEXT:    li 29, 368
1647; CHECK-NEXT:    evlddx 29, 31, 29
1648; CHECK-NEXT:    efdadd 0, 0, 29
1649; CHECK-NEXT:    li 29, 352
1650; CHECK-NEXT:    evlddx 29, 31, 29
1651; CHECK-NEXT:    efdadd 0, 0, 29
1652; CHECK-NEXT:    lwz 29, 864(31)
1653; CHECK-NEXT:    lwz 28, 452(31)
1654; CHECK-NEXT:    lwz 27, 876(31)
1655; CHECK-NEXT:    lwz 26, 764(31)
1656; CHECK-NEXT:    mullw 27, 27, 26
1657; CHECK-NEXT:    add 28, 28, 27
1658; CHECK-NEXT:    slwi 28, 28, 4
1659; CHECK-NEXT:    evstddx 0, 29, 28
1660; CHECK-NEXT:    addi 29, 31, 432
1661; CHECK-NEXT:    evlddx 0, 29, 3
1662; CHECK-NEXT:    evlddx 28, 5, 3
1663; CHECK-NEXT:    efdadd 0, 0, 28
1664; CHECK-NEXT:    evlddx 28, 7, 3
1665; CHECK-NEXT:    efdadd 0, 0, 28
1666; CHECK-NEXT:    evlddx 28, 9, 3
1667; CHECK-NEXT:    efdadd 0, 0, 28
1668; CHECK-NEXT:    evlddx 28, 11, 3
1669; CHECK-NEXT:    efdadd 0, 0, 28
1670; CHECK-NEXT:    evlddx 28, 30, 3
1671; CHECK-NEXT:    efdadd 0, 0, 28
1672; CHECK-NEXT:    lwz 28, 864(31)
1673; CHECK-NEXT:    lwz 27, 452(31)
1674; CHECK-NEXT:    lwz 26, 876(31)
1675; CHECK-NEXT:    lwz 25, 764(31)
1676; CHECK-NEXT:    mullw 26, 26, 25
1677; CHECK-NEXT:    add 27, 27, 26
1678; CHECK-NEXT:    slwi 27, 27, 4
1679; CHECK-NEXT:    add 28, 28, 27
1680; CHECK-NEXT:    evstddx 0, 28, 3
1681; CHECK-NEXT:    li 28, 432
1682; CHECK-NEXT:    evlddx 28, 31, 28
1683; CHECK-NEXT:    li 27, 416
1684; CHECK-NEXT:    evlddx 27, 31, 27
1685; CHECK-NEXT:    li 0, .LCPI1_5@l
1686; CHECK-NEXT:    lis 26, .LCPI1_5@ha
1687; CHECK-NEXT:    evlddx 0, 26, 0
1688; CHECK-NEXT:    efdmul 27, 27, 0
1689; CHECK-NEXT:    efdadd 27, 27, 28
1690; CHECK-NEXT:    li 28, 400
1691; CHECK-NEXT:    evlddx 26, 31, 28
1692; CHECK-NEXT:    li 28, .LCPI1_6@l
1693; CHECK-NEXT:    lis 25, .LCPI1_6@ha
1694; CHECK-NEXT:    evlddx 28, 25, 28
1695; CHECK-NEXT:    efdmul 26, 26, 28
1696; CHECK-NEXT:    efdadd 26, 26, 27
1697; CHECK-NEXT:    li 27, 384
1698; CHECK-NEXT:    evlddx 25, 31, 27
1699; CHECK-NEXT:    li 27, .LCPI1_7@l
1700; CHECK-NEXT:    lis 24, .LCPI1_7@ha
1701; CHECK-NEXT:    evlddx 27, 24, 27
1702; CHECK-NEXT:    efdmul 25, 25, 27
1703; CHECK-NEXT:    efdadd 26, 25, 26
1704; CHECK-NEXT:    li 25, 368
1705; CHECK-NEXT:    evlddx 24, 31, 25
1706; CHECK-NEXT:    li 25, .LCPI1_8@l
1707; CHECK-NEXT:    lis 23, .LCPI1_8@ha
1708; CHECK-NEXT:    evlddx 25, 23, 25
1709; CHECK-NEXT:    efdmul 24, 24, 25
1710; CHECK-NEXT:    efdadd 24, 24, 26
1711; CHECK-NEXT:    li 26, 352
1712; CHECK-NEXT:    evlddx 23, 31, 26
1713; CHECK-NEXT:    li 26, .LCPI1_9@l
1714; CHECK-NEXT:    lis 22, .LCPI1_9@ha
1715; CHECK-NEXT:    evlddx 26, 22, 26
1716; CHECK-NEXT:    efdmul 23, 23, 26
1717; CHECK-NEXT:    efdadd 24, 23, 24
1718; CHECK-NEXT:    evstdd 24, 224(31)
1719; CHECK-NEXT:    evlddx 24, 29, 3
1720; CHECK-NEXT:    evlddx 23, 5, 3
1721; CHECK-NEXT:    efdmul 23, 23, 0
1722; CHECK-NEXT:    efdadd 24, 23, 24
1723; CHECK-NEXT:    evlddx 23, 7, 3
1724; CHECK-NEXT:    efdmul 23, 23, 28
1725; CHECK-NEXT:    efdadd 24, 23, 24
1726; CHECK-NEXT:    evlddx 23, 9, 3
1727; CHECK-NEXT:    efdmul 23, 23, 27
1728; CHECK-NEXT:    efdadd 24, 23, 24
1729; CHECK-NEXT:    evlddx 23, 11, 3
1730; CHECK-NEXT:    efdmul 23, 23, 25
1731; CHECK-NEXT:    efdadd 24, 23, 24
1732; CHECK-NEXT:    evlddx 23, 30, 3
1733; CHECK-NEXT:    efdmul 23, 23, 26
1734; CHECK-NEXT:    efdadd 23, 23, 24
1735; CHECK-NEXT:    addi 24, 31, 224
1736; CHECK-NEXT:    evstddx 23, 24, 3
1737; CHECK-NEXT:    li 23, 832
1738; CHECK-NEXT:    evlddx 23, 31, 23
1739; CHECK-NEXT:    li 22, 272
1740; CHECK-NEXT:    evlddx 22, 31, 22
1741; CHECK-NEXT:    li 21, 816
1742; CHECK-NEXT:    evlddx 21, 31, 21
1743; CHECK-NEXT:    li 20, 288
1744; CHECK-NEXT:    evlddx 20, 31, 20
1745; CHECK-NEXT:    efdmul 21, 21, 20
1746; CHECK-NEXT:    efdmul 23, 23, 22
1747; CHECK-NEXT:    efdadd 23, 23, 21
1748; CHECK-NEXT:    li 22, 800
1749; CHECK-NEXT:    evlddx 22, 31, 22
1750; CHECK-NEXT:    li 21, 304
1751; CHECK-NEXT:    evlddx 21, 31, 21
1752; CHECK-NEXT:    efdmul 22, 22, 21
1753; CHECK-NEXT:    efdadd 23, 22, 23
1754; CHECK-NEXT:    li 22, 784
1755; CHECK-NEXT:    evlddx 22, 31, 22
1756; CHECK-NEXT:    li 21, 320
1757; CHECK-NEXT:    evlddx 21, 31, 21
1758; CHECK-NEXT:    efdmul 22, 22, 21
1759; CHECK-NEXT:    efdadd 23, 22, 23
1760; CHECK-NEXT:    li 22, 768
1761; CHECK-NEXT:    evlddx 22, 31, 22
1762; CHECK-NEXT:    li 21, 336
1763; CHECK-NEXT:    evlddx 21, 31, 21
1764; CHECK-NEXT:    efdmul 22, 22, 21
1765; CHECK-NEXT:    efdadd 23, 22, 23
1766; CHECK-NEXT:    addi 22, 31, 208
1767; CHECK-NEXT:    evstddx 23, 22, 3
1768; CHECK-NEXT:    li 23, 832
1769; CHECK-NEXT:    evlddx 23, 31, 23
1770; CHECK-NEXT:    evlddx 21, 4, 3
1771; CHECK-NEXT:    li 20, 816
1772; CHECK-NEXT:    evlddx 20, 31, 20
1773; CHECK-NEXT:    evlddx 19, 6, 3
1774; CHECK-NEXT:    efdmul 20, 20, 19
1775; CHECK-NEXT:    efdmul 23, 23, 21
1776; CHECK-NEXT:    efdadd 23, 23, 20
1777; CHECK-NEXT:    li 21, 800
1778; CHECK-NEXT:    evlddx 21, 31, 21
1779; CHECK-NEXT:    evlddx 20, 8, 3
1780; CHECK-NEXT:    efdmul 21, 21, 20
1781; CHECK-NEXT:    efdadd 23, 21, 23
1782; CHECK-NEXT:    li 21, 784
1783; CHECK-NEXT:    evlddx 21, 31, 21
1784; CHECK-NEXT:    evlddx 20, 10, 3
1785; CHECK-NEXT:    efdmul 21, 21, 20
1786; CHECK-NEXT:    efdadd 23, 21, 23
1787; CHECK-NEXT:    li 21, 768
1788; CHECK-NEXT:    evlddx 21, 31, 21
1789; CHECK-NEXT:    evlddx 20, 12, 3
1790; CHECK-NEXT:    efdmul 21, 21, 20
1791; CHECK-NEXT:    efdadd 23, 21, 23
1792; CHECK-NEXT:    efdneg 23, 23
1793; CHECK-NEXT:    evstdd 23, 208(31)
1794; CHECK-NEXT:    evldd 23, 224(31)
1795; CHECK-NEXT:    evldd 21, 208(31)
1796; CHECK-NEXT:    efdadd 23, 23, 21
1797; CHECK-NEXT:    li 21, 256
1798; CHECK-NEXT:    evstddx 23, 31, 21
1799; CHECK-NEXT:    evlddx 23, 24, 3
1800; CHECK-NEXT:    evlddx 21, 22, 3
1801; CHECK-NEXT:    efdadd 23, 23, 21
1802; CHECK-NEXT:    addi 21, 31, 256
1803; CHECK-NEXT:    evstddx 23, 21, 3
1804; CHECK-NEXT:    evldd 23, 224(31)
1805; CHECK-NEXT:    evldd 20, 208(31)
1806; CHECK-NEXT:    efdsub 23, 23, 20
1807; CHECK-NEXT:    evstdd 23, 240(31)
1808; CHECK-NEXT:    evlddx 24, 24, 3
1809; CHECK-NEXT:    evlddx 23, 22, 3
1810; CHECK-NEXT:    efdsub 23, 24, 23
1811; CHECK-NEXT:    addi 24, 31, 240
1812; CHECK-NEXT:    evstddx 23, 24, 3
1813; CHECK-NEXT:    lwz 23, 860(31)
1814; CHECK-NEXT:    lwz 22, 452(31)
1815; CHECK-NEXT:    slwi 20, 22, 4
1816; CHECK-NEXT:    lwz 19, 876(31)
1817; CHECK-NEXT:    add 23, 20, 23
1818; CHECK-NEXT:    li 20, -16
1819; CHECK-NEXT:    evlddx 18, 23, 20
1820; CHECK-NEXT:    li 17, 256
1821; CHECK-NEXT:    evlddx 17, 31, 17
1822; CHECK-NEXT:    lwz 16, 856(31)
1823; CHECK-NEXT:    efdcfsi 16, 16
1824; CHECK-NEXT:    li 15, -8
1825; CHECK-NEXT:    evlddx 23, 23, 15
1826; CHECK-NEXT:    efdmul 23, 16, 23
1827; CHECK-NEXT:    evlddx 16, 21, 3
1828; CHECK-NEXT:    efdmul 23, 23, 16
1829; CHECK-NEXT:    efdmul 18, 18, 17
1830; CHECK-NEXT:    efdsub 23, 18, 23
1831; CHECK-NEXT:    lwz 18, 864(31)
1832; CHECK-NEXT:    lwz 17, 764(31)
1833; CHECK-NEXT:    lwz 16, 872(31)
1834; CHECK-NEXT:    add 17, 17, 16
1835; CHECK-NEXT:    mullw 19, 19, 17
1836; CHECK-NEXT:    add 22, 22, 19
1837; CHECK-NEXT:    slwi 22, 22, 4
1838; CHECK-NEXT:    evstddx 23, 18, 22
1839; CHECK-NEXT:    lwz 23, 860(31)
1840; CHECK-NEXT:    lwz 22, 452(31)
1841; CHECK-NEXT:    slwi 19, 22, 4
1842; CHECK-NEXT:    lwz 18, 876(31)
1843; CHECK-NEXT:    add 23, 19, 23
1844; CHECK-NEXT:    evlddx 20, 23, 20
1845; CHECK-NEXT:    evlddx 21, 21, 3
1846; CHECK-NEXT:    lwz 19, 856(31)
1847; CHECK-NEXT:    efdcfsi 19, 19
1848; CHECK-NEXT:    evlddx 23, 23, 15
1849; CHECK-NEXT:    efdmul 23, 19, 23
1850; CHECK-NEXT:    li 19, 256
1851; CHECK-NEXT:    evlddx 19, 31, 19
1852; CHECK-NEXT:    efdmul 23, 23, 19
1853; CHECK-NEXT:    efdmul 21, 20, 21
1854; CHECK-NEXT:    efdadd 23, 21, 23
1855; CHECK-NEXT:    lwz 21, 864(31)
1856; CHECK-NEXT:    lwz 20, 764(31)
1857; CHECK-NEXT:    lwz 19, 872(31)
1858; CHECK-NEXT:    add 20, 20, 19
1859; CHECK-NEXT:    mullw 20, 18, 20
1860; CHECK-NEXT:    add 22, 22, 20
1861; CHECK-NEXT:    slwi 22, 22, 4
1862; CHECK-NEXT:    add 22, 21, 22
1863; CHECK-NEXT:    evstddx 23, 22, 3
1864; CHECK-NEXT:    lwz 23, 860(31)
1865; CHECK-NEXT:    lwz 22, 452(31)
1866; CHECK-NEXT:    lwz 21, 876(31)
1867; CHECK-NEXT:    mulli 20, 21, 9
1868; CHECK-NEXT:    add 20, 20, 22
1869; CHECK-NEXT:    slwi 20, 20, 4
1870; CHECK-NEXT:    add 23, 20, 23
1871; CHECK-NEXT:    li 20, -160
1872; CHECK-NEXT:    evlddx 19, 23, 20
1873; CHECK-NEXT:    evldd 18, 240(31)
1874; CHECK-NEXT:    lwz 17, 856(31)
1875; CHECK-NEXT:    efdcfsi 17, 17
1876; CHECK-NEXT:    li 16, -152
1877; CHECK-NEXT:    evlddx 23, 23, 16
1878; CHECK-NEXT:    efdmul 23, 17, 23
1879; CHECK-NEXT:    evlddx 17, 24, 3
1880; CHECK-NEXT:    efdmul 23, 23, 17
1881; CHECK-NEXT:    efdmul 19, 19, 18
1882; CHECK-NEXT:    efdsub 23, 19, 23
1883; CHECK-NEXT:    lwz 19, 864(31)
1884; CHECK-NEXT:    lwz 18, 764(31)
1885; CHECK-NEXT:    lwz 17, 872(31)
1886; CHECK-NEXT:    mulli 17, 17, 10
1887; CHECK-NEXT:    add 18, 18, 17
1888; CHECK-NEXT:    mullw 21, 21, 18
1889; CHECK-NEXT:    add 22, 22, 21
1890; CHECK-NEXT:    slwi 22, 22, 4
1891; CHECK-NEXT:    evstddx 23, 19, 22
1892; CHECK-NEXT:    lwz 23, 860(31)
1893; CHECK-NEXT:    lwz 22, 452(31)
1894; CHECK-NEXT:    lwz 21, 876(31)
1895; CHECK-NEXT:    mulli 19, 21, 9
1896; CHECK-NEXT:    add 19, 19, 22
1897; CHECK-NEXT:    slwi 19, 19, 4
1898; CHECK-NEXT:    add 23, 19, 23
1899; CHECK-NEXT:    evlddx 20, 23, 20
1900; CHECK-NEXT:    evlddx 24, 24, 3
1901; CHECK-NEXT:    lwz 19, 856(31)
1902; CHECK-NEXT:    efdcfsi 19, 19
1903; CHECK-NEXT:    evlddx 23, 23, 16
1904; CHECK-NEXT:    efdmul 23, 19, 23
1905; CHECK-NEXT:    evldd 19, 240(31)
1906; CHECK-NEXT:    efdmul 23, 23, 19
1907; CHECK-NEXT:    efdmul 24, 20, 24
1908; CHECK-NEXT:    efdadd 24, 24, 23
1909; CHECK-NEXT:    lwz 23, 864(31)
1910; CHECK-NEXT:    lwz 20, 764(31)
1911; CHECK-NEXT:    lwz 19, 872(31)
1912; CHECK-NEXT:    mulli 19, 19, 10
1913; CHECK-NEXT:    add 20, 20, 19
1914; CHECK-NEXT:    mullw 21, 21, 20
1915; CHECK-NEXT:    add 22, 22, 21
1916; CHECK-NEXT:    slwi 22, 22, 4
1917; CHECK-NEXT:    add 23, 23, 22
1918; CHECK-NEXT:    evstddx 24, 23, 3
1919; CHECK-NEXT:    li 24, 432
1920; CHECK-NEXT:    evlddx 24, 31, 24
1921; CHECK-NEXT:    li 23, 416
1922; CHECK-NEXT:    evlddx 23, 31, 23
1923; CHECK-NEXT:    efdmul 23, 23, 28
1924; CHECK-NEXT:    efdadd 24, 23, 24
1925; CHECK-NEXT:    li 23, 400
1926; CHECK-NEXT:    evlddx 23, 31, 23
1927; CHECK-NEXT:    efdmul 23, 23, 25
1928; CHECK-NEXT:    efdadd 24, 23, 24
1929; CHECK-NEXT:    li 23, 384
1930; CHECK-NEXT:    evlddx 23, 31, 23
1931; CHECK-NEXT:    efdmul 23, 23, 26
1932; CHECK-NEXT:    efdadd 24, 23, 24
1933; CHECK-NEXT:    li 23, 368
1934; CHECK-NEXT:    evlddx 23, 31, 23
1935; CHECK-NEXT:    efdmul 23, 23, 27
1936; CHECK-NEXT:    efdadd 24, 23, 24
1937; CHECK-NEXT:    li 23, 352
1938; CHECK-NEXT:    evlddx 23, 31, 23
1939; CHECK-NEXT:    efdmul 23, 23, 0
1940; CHECK-NEXT:    efdadd 24, 23, 24
1941; CHECK-NEXT:    evstdd 24, 160(31)
1942; CHECK-NEXT:    evlddx 24, 29, 3
1943; CHECK-NEXT:    evlddx 23, 5, 3
1944; CHECK-NEXT:    efdmul 23, 23, 28
1945; CHECK-NEXT:    efdadd 24, 23, 24
1946; CHECK-NEXT:    evlddx 23, 7, 3
1947; CHECK-NEXT:    efdmul 23, 23, 25
1948; CHECK-NEXT:    efdadd 24, 23, 24
1949; CHECK-NEXT:    evlddx 23, 9, 3
1950; CHECK-NEXT:    efdmul 23, 23, 26
1951; CHECK-NEXT:    efdadd 24, 23, 24
1952; CHECK-NEXT:    evlddx 23, 11, 3
1953; CHECK-NEXT:    efdmul 23, 23, 27
1954; CHECK-NEXT:    efdadd 24, 23, 24
1955; CHECK-NEXT:    evlddx 23, 30, 3
1956; CHECK-NEXT:    efdmul 23, 23, 0
1957; CHECK-NEXT:    efdadd 23, 23, 24
1958; CHECK-NEXT:    addi 24, 31, 160
1959; CHECK-NEXT:    evstddx 23, 24, 3
1960; CHECK-NEXT:    li 23, 816
1961; CHECK-NEXT:    evlddx 23, 31, 23
1962; CHECK-NEXT:    li 22, 272
1963; CHECK-NEXT:    evlddx 22, 31, 22
1964; CHECK-NEXT:    li 21, 784
1965; CHECK-NEXT:    evlddx 21, 31, 21
1966; CHECK-NEXT:    li 20, 288
1967; CHECK-NEXT:    evlddx 20, 31, 20
1968; CHECK-NEXT:    efdmul 21, 21, 20
1969; CHECK-NEXT:    efdmul 23, 23, 22
1970; CHECK-NEXT:    efdadd 23, 23, 21
1971; CHECK-NEXT:    li 22, 768
1972; CHECK-NEXT:    evlddx 22, 31, 22
1973; CHECK-NEXT:    li 21, 304
1974; CHECK-NEXT:    evlddx 21, 31, 21
1975; CHECK-NEXT:    efdmul 22, 22, 21
1976; CHECK-NEXT:    efdsub 23, 23, 22
1977; CHECK-NEXT:    li 22, 800
1978; CHECK-NEXT:    evlddx 22, 31, 22
1979; CHECK-NEXT:    li 21, 320
1980; CHECK-NEXT:    evlddx 21, 31, 21
1981; CHECK-NEXT:    efdmul 22, 22, 21
1982; CHECK-NEXT:    efdsub 23, 23, 22
1983; CHECK-NEXT:    li 22, 832
1984; CHECK-NEXT:    evlddx 22, 31, 22
1985; CHECK-NEXT:    li 21, 336
1986; CHECK-NEXT:    evlddx 21, 31, 21
1987; CHECK-NEXT:    efdmul 22, 22, 21
1988; CHECK-NEXT:    efdsub 23, 23, 22
1989; CHECK-NEXT:    addi 22, 31, 144
1990; CHECK-NEXT:    evstddx 23, 22, 3
1991; CHECK-NEXT:    li 23, 816
1992; CHECK-NEXT:    evlddx 23, 31, 23
1993; CHECK-NEXT:    evlddx 21, 4, 3
1994; CHECK-NEXT:    li 20, 784
1995; CHECK-NEXT:    evlddx 20, 31, 20
1996; CHECK-NEXT:    evlddx 19, 6, 3
1997; CHECK-NEXT:    efdmul 20, 20, 19
1998; CHECK-NEXT:    efdmul 23, 23, 21
1999; CHECK-NEXT:    efdadd 23, 23, 20
2000; CHECK-NEXT:    li 21, 768
2001; CHECK-NEXT:    evlddx 21, 31, 21
2002; CHECK-NEXT:    evlddx 20, 8, 3
2003; CHECK-NEXT:    efdmul 21, 21, 20
2004; CHECK-NEXT:    efdsub 23, 23, 21
2005; CHECK-NEXT:    li 21, 800
2006; CHECK-NEXT:    evlddx 21, 31, 21
2007; CHECK-NEXT:    evlddx 20, 10, 3
2008; CHECK-NEXT:    efdmul 21, 21, 20
2009; CHECK-NEXT:    efdsub 23, 23, 21
2010; CHECK-NEXT:    li 21, 832
2011; CHECK-NEXT:    evlddx 21, 31, 21
2012; CHECK-NEXT:    evlddx 20, 12, 3
2013; CHECK-NEXT:    efdmul 21, 21, 20
2014; CHECK-NEXT:    efdsub 23, 23, 21
2015; CHECK-NEXT:    efdneg 23, 23
2016; CHECK-NEXT:    evstdd 23, 144(31)
2017; CHECK-NEXT:    evldd 23, 160(31)
2018; CHECK-NEXT:    evldd 21, 144(31)
2019; CHECK-NEXT:    efdadd 23, 23, 21
2020; CHECK-NEXT:    evstdd 23, 192(31)
2021; CHECK-NEXT:    evlddx 23, 24, 3
2022; CHECK-NEXT:    evlddx 21, 22, 3
2023; CHECK-NEXT:    efdadd 23, 23, 21
2024; CHECK-NEXT:    addi 21, 31, 192
2025; CHECK-NEXT:    evstddx 23, 21, 3
2026; CHECK-NEXT:    evldd 23, 160(31)
2027; CHECK-NEXT:    evldd 20, 144(31)
2028; CHECK-NEXT:    efdsub 23, 23, 20
2029; CHECK-NEXT:    evstdd 23, 176(31)
2030; CHECK-NEXT:    evlddx 24, 24, 3
2031; CHECK-NEXT:    evlddx 23, 22, 3
2032; CHECK-NEXT:    efdsub 23, 24, 23
2033; CHECK-NEXT:    addi 24, 31, 176
2034; CHECK-NEXT:    evstddx 23, 24, 3
2035; CHECK-NEXT:    lwz 23, 860(31)
2036; CHECK-NEXT:    lwz 22, 452(31)
2037; CHECK-NEXT:    lwz 20, 876(31)
2038; CHECK-NEXT:    add 19, 20, 22
2039; CHECK-NEXT:    slwi 19, 19, 4
2040; CHECK-NEXT:    add 23, 19, 23
2041; CHECK-NEXT:    li 19, -32
2042; CHECK-NEXT:    evlddx 18, 23, 19
2043; CHECK-NEXT:    evldd 17, 192(31)
2044; CHECK-NEXT:    lwz 16, 856(31)
2045; CHECK-NEXT:    efdcfsi 16, 16
2046; CHECK-NEXT:    li 15, -24
2047; CHECK-NEXT:    evlddx 23, 23, 15
2048; CHECK-NEXT:    efdmul 23, 16, 23
2049; CHECK-NEXT:    evlddx 16, 21, 3
2050; CHECK-NEXT:    efdmul 23, 23, 16
2051; CHECK-NEXT:    efdmul 18, 18, 17
2052; CHECK-NEXT:    efdsub 23, 18, 23
2053; CHECK-NEXT:    lwz 18, 864(31)
2054; CHECK-NEXT:    lwz 17, 764(31)
2055; CHECK-NEXT:    lwz 16, 872(31)
2056; CHECK-NEXT:    slwi 16, 16, 1
2057; CHECK-NEXT:    add 17, 17, 16
2058; CHECK-NEXT:    mullw 20, 20, 17
2059; CHECK-NEXT:    add 22, 22, 20
2060; CHECK-NEXT:    slwi 22, 22, 4
2061; CHECK-NEXT:    evstddx 23, 18, 22
2062; CHECK-NEXT:    lwz 23, 860(31)
2063; CHECK-NEXT:    lwz 22, 452(31)
2064; CHECK-NEXT:    lwz 20, 876(31)
2065; CHECK-NEXT:    add 18, 20, 22
2066; CHECK-NEXT:    slwi 18, 18, 4
2067; CHECK-NEXT:    add 23, 18, 23
2068; CHECK-NEXT:    evlddx 19, 23, 19
2069; CHECK-NEXT:    evlddx 21, 21, 3
2070; CHECK-NEXT:    lwz 18, 856(31)
2071; CHECK-NEXT:    efdcfsi 18, 18
2072; CHECK-NEXT:    evlddx 23, 23, 15
2073; CHECK-NEXT:    efdmul 23, 18, 23
2074; CHECK-NEXT:    evldd 18, 192(31)
2075; CHECK-NEXT:    efdmul 23, 23, 18
2076; CHECK-NEXT:    efdmul 21, 19, 21
2077; CHECK-NEXT:    efdadd 23, 21, 23
2078; CHECK-NEXT:    lwz 21, 864(31)
2079; CHECK-NEXT:    lwz 19, 764(31)
2080; CHECK-NEXT:    lwz 18, 872(31)
2081; CHECK-NEXT:    slwi 18, 18, 1
2082; CHECK-NEXT:    add 19, 19, 18
2083; CHECK-NEXT:    mullw 20, 20, 19
2084; CHECK-NEXT:    add 22, 22, 20
2085; CHECK-NEXT:    slwi 22, 22, 4
2086; CHECK-NEXT:    add 22, 21, 22
2087; CHECK-NEXT:    evstddx 23, 22, 3
2088; CHECK-NEXT:    lwz 23, 860(31)
2089; CHECK-NEXT:    lwz 22, 452(31)
2090; CHECK-NEXT:    lwz 21, 876(31)
2091; CHECK-NEXT:    slwi 20, 21, 3
2092; CHECK-NEXT:    add 20, 20, 22
2093; CHECK-NEXT:    slwi 20, 20, 4
2094; CHECK-NEXT:    add 23, 20, 23
2095; CHECK-NEXT:    li 20, -144
2096; CHECK-NEXT:    evlddx 19, 23, 20
2097; CHECK-NEXT:    evldd 18, 176(31)
2098; CHECK-NEXT:    lwz 17, 856(31)
2099; CHECK-NEXT:    efdcfsi 17, 17
2100; CHECK-NEXT:    li 16, -136
2101; CHECK-NEXT:    evlddx 23, 23, 16
2102; CHECK-NEXT:    efdmul 23, 17, 23
2103; CHECK-NEXT:    evlddx 17, 24, 3
2104; CHECK-NEXT:    efdmul 23, 23, 17
2105; CHECK-NEXT:    efdmul 19, 19, 18
2106; CHECK-NEXT:    efdsub 23, 19, 23
2107; CHECK-NEXT:    lwz 19, 864(31)
2108; CHECK-NEXT:    lwz 18, 764(31)
2109; CHECK-NEXT:    lwz 17, 872(31)
2110; CHECK-NEXT:    mulli 17, 17, 9
2111; CHECK-NEXT:    add 18, 18, 17
2112; CHECK-NEXT:    mullw 21, 21, 18
2113; CHECK-NEXT:    add 22, 22, 21
2114; CHECK-NEXT:    slwi 22, 22, 4
2115; CHECK-NEXT:    evstddx 23, 19, 22
2116; CHECK-NEXT:    lwz 23, 860(31)
2117; CHECK-NEXT:    lwz 22, 452(31)
2118; CHECK-NEXT:    lwz 21, 876(31)
2119; CHECK-NEXT:    slwi 19, 21, 3
2120; CHECK-NEXT:    add 19, 19, 22
2121; CHECK-NEXT:    slwi 19, 19, 4
2122; CHECK-NEXT:    add 23, 19, 23
2123; CHECK-NEXT:    evlddx 20, 23, 20
2124; CHECK-NEXT:    evlddx 24, 24, 3
2125; CHECK-NEXT:    lwz 19, 856(31)
2126; CHECK-NEXT:    efdcfsi 19, 19
2127; CHECK-NEXT:    evlddx 23, 23, 16
2128; CHECK-NEXT:    efdmul 23, 19, 23
2129; CHECK-NEXT:    evldd 19, 176(31)
2130; CHECK-NEXT:    efdmul 23, 23, 19
2131; CHECK-NEXT:    efdmul 24, 20, 24
2132; CHECK-NEXT:    efdadd 24, 24, 23
2133; CHECK-NEXT:    lwz 23, 864(31)
2134; CHECK-NEXT:    lwz 20, 764(31)
2135; CHECK-NEXT:    lwz 19, 872(31)
2136; CHECK-NEXT:    mulli 19, 19, 9
2137; CHECK-NEXT:    add 20, 20, 19
2138; CHECK-NEXT:    mullw 21, 21, 20
2139; CHECK-NEXT:    add 22, 22, 21
2140; CHECK-NEXT:    slwi 22, 22, 4
2141; CHECK-NEXT:    add 23, 23, 22
2142; CHECK-NEXT:    evstddx 24, 23, 3
2143; CHECK-NEXT:    li 24, 432
2144; CHECK-NEXT:    evlddx 24, 31, 24
2145; CHECK-NEXT:    li 23, 416
2146; CHECK-NEXT:    evlddx 23, 31, 23
2147; CHECK-NEXT:    efdmul 23, 23, 27
2148; CHECK-NEXT:    efdadd 24, 23, 24
2149; CHECK-NEXT:    li 23, 400
2150; CHECK-NEXT:    evlddx 23, 31, 23
2151; CHECK-NEXT:    efdmul 23, 23, 26
2152; CHECK-NEXT:    efdadd 24, 23, 24
2153; CHECK-NEXT:    li 23, 384
2154; CHECK-NEXT:    evlddx 23, 31, 23
2155; CHECK-NEXT:    efdmul 23, 23, 28
2156; CHECK-NEXT:    efdadd 24, 23, 24
2157; CHECK-NEXT:    li 23, 368
2158; CHECK-NEXT:    evlddx 23, 31, 23
2159; CHECK-NEXT:    efdmul 23, 23, 0
2160; CHECK-NEXT:    efdadd 24, 23, 24
2161; CHECK-NEXT:    li 23, 352
2162; CHECK-NEXT:    evlddx 23, 31, 23
2163; CHECK-NEXT:    efdmul 23, 23, 25
2164; CHECK-NEXT:    efdadd 24, 23, 24
2165; CHECK-NEXT:    evstdd 24, 96(31)
2166; CHECK-NEXT:    evlddx 24, 29, 3
2167; CHECK-NEXT:    evlddx 23, 5, 3
2168; CHECK-NEXT:    efdmul 23, 23, 27
2169; CHECK-NEXT:    efdadd 24, 23, 24
2170; CHECK-NEXT:    evlddx 23, 7, 3
2171; CHECK-NEXT:    efdmul 23, 23, 26
2172; CHECK-NEXT:    efdadd 24, 23, 24
2173; CHECK-NEXT:    evlddx 23, 9, 3
2174; CHECK-NEXT:    efdmul 23, 23, 28
2175; CHECK-NEXT:    efdadd 24, 23, 24
2176; CHECK-NEXT:    evlddx 23, 11, 3
2177; CHECK-NEXT:    efdmul 23, 23, 0
2178; CHECK-NEXT:    efdadd 24, 23, 24
2179; CHECK-NEXT:    evlddx 23, 30, 3
2180; CHECK-NEXT:    efdmul 23, 23, 25
2181; CHECK-NEXT:    efdadd 23, 23, 24
2182; CHECK-NEXT:    addi 24, 31, 96
2183; CHECK-NEXT:    evstddx 23, 24, 3
2184; CHECK-NEXT:    li 23, 800
2185; CHECK-NEXT:    evlddx 23, 31, 23
2186; CHECK-NEXT:    li 22, 272
2187; CHECK-NEXT:    evlddx 22, 31, 22
2188; CHECK-NEXT:    li 21, 768
2189; CHECK-NEXT:    evlddx 21, 31, 21
2190; CHECK-NEXT:    li 20, 288
2191; CHECK-NEXT:    evlddx 20, 31, 20
2192; CHECK-NEXT:    efdmul 21, 21, 20
2193; CHECK-NEXT:    efdmul 23, 23, 22
2194; CHECK-NEXT:    efdsub 23, 23, 21
2195; CHECK-NEXT:    li 22, 816
2196; CHECK-NEXT:    evlddx 22, 31, 22
2197; CHECK-NEXT:    li 21, 304
2198; CHECK-NEXT:    evlddx 21, 31, 21
2199; CHECK-NEXT:    efdmul 22, 22, 21
2200; CHECK-NEXT:    efdsub 23, 23, 22
2201; CHECK-NEXT:    li 22, 832
2202; CHECK-NEXT:    evlddx 22, 31, 22
2203; CHECK-NEXT:    li 21, 320
2204; CHECK-NEXT:    evlddx 21, 31, 21
2205; CHECK-NEXT:    efdmul 22, 22, 21
2206; CHECK-NEXT:    efdadd 23, 22, 23
2207; CHECK-NEXT:    li 22, 784
2208; CHECK-NEXT:    evlddx 22, 31, 22
2209; CHECK-NEXT:    li 21, 336
2210; CHECK-NEXT:    evlddx 21, 31, 21
2211; CHECK-NEXT:    efdmul 22, 22, 21
2212; CHECK-NEXT:    efdadd 23, 22, 23
2213; CHECK-NEXT:    addi 22, 31, 80
2214; CHECK-NEXT:    evstddx 23, 22, 3
2215; CHECK-NEXT:    li 23, 800
2216; CHECK-NEXT:    evlddx 23, 31, 23
2217; CHECK-NEXT:    evlddx 21, 4, 3
2218; CHECK-NEXT:    li 20, 768
2219; CHECK-NEXT:    evlddx 20, 31, 20
2220; CHECK-NEXT:    evlddx 19, 6, 3
2221; CHECK-NEXT:    efdmul 20, 20, 19
2222; CHECK-NEXT:    efdmul 23, 23, 21
2223; CHECK-NEXT:    efdsub 23, 23, 20
2224; CHECK-NEXT:    li 21, 816
2225; CHECK-NEXT:    evlddx 21, 31, 21
2226; CHECK-NEXT:    evlddx 20, 8, 3
2227; CHECK-NEXT:    efdmul 21, 21, 20
2228; CHECK-NEXT:    efdsub 23, 23, 21
2229; CHECK-NEXT:    li 21, 832
2230; CHECK-NEXT:    evlddx 21, 31, 21
2231; CHECK-NEXT:    evlddx 20, 10, 3
2232; CHECK-NEXT:    efdmul 21, 21, 20
2233; CHECK-NEXT:    efdadd 23, 21, 23
2234; CHECK-NEXT:    li 21, 784
2235; CHECK-NEXT:    evlddx 21, 31, 21
2236; CHECK-NEXT:    evlddx 20, 12, 3
2237; CHECK-NEXT:    efdmul 21, 21, 20
2238; CHECK-NEXT:    efdadd 23, 21, 23
2239; CHECK-NEXT:    efdneg 23, 23
2240; CHECK-NEXT:    evstdd 23, 80(31)
2241; CHECK-NEXT:    evldd 23, 96(31)
2242; CHECK-NEXT:    evldd 21, 80(31)
2243; CHECK-NEXT:    efdadd 23, 23, 21
2244; CHECK-NEXT:    evstdd 23, 128(31)
2245; CHECK-NEXT:    evlddx 23, 24, 3
2246; CHECK-NEXT:    evlddx 21, 22, 3
2247; CHECK-NEXT:    efdadd 23, 23, 21
2248; CHECK-NEXT:    addi 21, 31, 128
2249; CHECK-NEXT:    evstddx 23, 21, 3
2250; CHECK-NEXT:    evldd 23, 96(31)
2251; CHECK-NEXT:    evldd 20, 80(31)
2252; CHECK-NEXT:    efdsub 23, 23, 20
2253; CHECK-NEXT:    evstdd 23, 112(31)
2254; CHECK-NEXT:    evlddx 24, 24, 3
2255; CHECK-NEXT:    evlddx 23, 22, 3
2256; CHECK-NEXT:    efdsub 23, 24, 23
2257; CHECK-NEXT:    addi 24, 31, 112
2258; CHECK-NEXT:    evstddx 23, 24, 3
2259; CHECK-NEXT:    lwz 23, 860(31)
2260; CHECK-NEXT:    lwz 22, 452(31)
2261; CHECK-NEXT:    lwz 20, 876(31)
2262; CHECK-NEXT:    slwi 19, 20, 1
2263; CHECK-NEXT:    add 19, 19, 22
2264; CHECK-NEXT:    slwi 19, 19, 4
2265; CHECK-NEXT:    add 23, 19, 23
2266; CHECK-NEXT:    li 19, -48
2267; CHECK-NEXT:    evlddx 18, 23, 19
2268; CHECK-NEXT:    evldd 17, 128(31)
2269; CHECK-NEXT:    lwz 16, 856(31)
2270; CHECK-NEXT:    efdcfsi 16, 16
2271; CHECK-NEXT:    li 15, -40
2272; CHECK-NEXT:    evlddx 23, 23, 15
2273; CHECK-NEXT:    efdmul 23, 16, 23
2274; CHECK-NEXT:    evlddx 16, 21, 3
2275; CHECK-NEXT:    efdmul 23, 23, 16
2276; CHECK-NEXT:    efdmul 18, 18, 17
2277; CHECK-NEXT:    efdsub 23, 18, 23
2278; CHECK-NEXT:    lwz 18, 864(31)
2279; CHECK-NEXT:    lwz 17, 764(31)
2280; CHECK-NEXT:    lwz 16, 872(31)
2281; CHECK-NEXT:    mulli 16, 16, 3
2282; CHECK-NEXT:    add 17, 17, 16
2283; CHECK-NEXT:    mullw 20, 20, 17
2284; CHECK-NEXT:    add 22, 22, 20
2285; CHECK-NEXT:    slwi 22, 22, 4
2286; CHECK-NEXT:    evstddx 23, 18, 22
2287; CHECK-NEXT:    lwz 23, 860(31)
2288; CHECK-NEXT:    lwz 22, 452(31)
2289; CHECK-NEXT:    lwz 20, 876(31)
2290; CHECK-NEXT:    slwi 18, 20, 1
2291; CHECK-NEXT:    add 18, 18, 22
2292; CHECK-NEXT:    slwi 18, 18, 4
2293; CHECK-NEXT:    add 23, 18, 23
2294; CHECK-NEXT:    evlddx 19, 23, 19
2295; CHECK-NEXT:    evlddx 21, 21, 3
2296; CHECK-NEXT:    lwz 18, 856(31)
2297; CHECK-NEXT:    efdcfsi 18, 18
2298; CHECK-NEXT:    evlddx 23, 23, 15
2299; CHECK-NEXT:    efdmul 23, 18, 23
2300; CHECK-NEXT:    evldd 18, 128(31)
2301; CHECK-NEXT:    efdmul 23, 23, 18
2302; CHECK-NEXT:    efdmul 21, 19, 21
2303; CHECK-NEXT:    efdadd 23, 21, 23
2304; CHECK-NEXT:    lwz 21, 864(31)
2305; CHECK-NEXT:    lwz 19, 764(31)
2306; CHECK-NEXT:    lwz 18, 872(31)
2307; CHECK-NEXT:    mulli 18, 18, 3
2308; CHECK-NEXT:    add 19, 19, 18
2309; CHECK-NEXT:    mullw 20, 20, 19
2310; CHECK-NEXT:    add 22, 22, 20
2311; CHECK-NEXT:    slwi 22, 22, 4
2312; CHECK-NEXT:    add 22, 21, 22
2313; CHECK-NEXT:    evstddx 23, 22, 3
2314; CHECK-NEXT:    lwz 23, 860(31)
2315; CHECK-NEXT:    lwz 22, 452(31)
2316; CHECK-NEXT:    lwz 21, 876(31)
2317; CHECK-NEXT:    mulli 20, 21, 7
2318; CHECK-NEXT:    add 20, 20, 22
2319; CHECK-NEXT:    slwi 20, 20, 4
2320; CHECK-NEXT:    add 23, 20, 23
2321; CHECK-NEXT:    li 20, -128
2322; CHECK-NEXT:    evlddx 19, 23, 20
2323; CHECK-NEXT:    evldd 18, 112(31)
2324; CHECK-NEXT:    lwz 17, 856(31)
2325; CHECK-NEXT:    efdcfsi 17, 17
2326; CHECK-NEXT:    li 16, -120
2327; CHECK-NEXT:    evlddx 23, 23, 16
2328; CHECK-NEXT:    efdmul 23, 17, 23
2329; CHECK-NEXT:    evlddx 17, 24, 3
2330; CHECK-NEXT:    efdmul 23, 23, 17
2331; CHECK-NEXT:    efdmul 19, 19, 18
2332; CHECK-NEXT:    efdsub 23, 19, 23
2333; CHECK-NEXT:    lwz 19, 864(31)
2334; CHECK-NEXT:    lwz 18, 764(31)
2335; CHECK-NEXT:    lwz 17, 872(31)
2336; CHECK-NEXT:    slwi 17, 17, 3
2337; CHECK-NEXT:    add 18, 18, 17
2338; CHECK-NEXT:    mullw 21, 21, 18
2339; CHECK-NEXT:    add 22, 22, 21
2340; CHECK-NEXT:    slwi 22, 22, 4
2341; CHECK-NEXT:    evstddx 23, 19, 22
2342; CHECK-NEXT:    lwz 23, 860(31)
2343; CHECK-NEXT:    lwz 22, 452(31)
2344; CHECK-NEXT:    lwz 21, 876(31)
2345; CHECK-NEXT:    mulli 19, 21, 7
2346; CHECK-NEXT:    add 19, 19, 22
2347; CHECK-NEXT:    slwi 19, 19, 4
2348; CHECK-NEXT:    add 23, 19, 23
2349; CHECK-NEXT:    evlddx 20, 23, 20
2350; CHECK-NEXT:    evlddx 24, 24, 3
2351; CHECK-NEXT:    lwz 19, 856(31)
2352; CHECK-NEXT:    efdcfsi 19, 19
2353; CHECK-NEXT:    evlddx 23, 23, 16
2354; CHECK-NEXT:    efdmul 23, 19, 23
2355; CHECK-NEXT:    evldd 19, 112(31)
2356; CHECK-NEXT:    efdmul 23, 23, 19
2357; CHECK-NEXT:    efdmul 24, 20, 24
2358; CHECK-NEXT:    efdadd 24, 24, 23
2359; CHECK-NEXT:    lwz 23, 864(31)
2360; CHECK-NEXT:    lwz 20, 764(31)
2361; CHECK-NEXT:    lwz 19, 872(31)
2362; CHECK-NEXT:    slwi 19, 19, 3
2363; CHECK-NEXT:    add 20, 20, 19
2364; CHECK-NEXT:    mullw 21, 21, 20
2365; CHECK-NEXT:    add 22, 22, 21
2366; CHECK-NEXT:    slwi 22, 22, 4
2367; CHECK-NEXT:    add 23, 23, 22
2368; CHECK-NEXT:    evstddx 24, 23, 3
2369; CHECK-NEXT:    li 24, 432
2370; CHECK-NEXT:    evlddx 24, 31, 24
2371; CHECK-NEXT:    li 23, 416
2372; CHECK-NEXT:    evlddx 23, 31, 23
2373; CHECK-NEXT:    efdmul 23, 23, 25
2374; CHECK-NEXT:    efdadd 24, 23, 24
2375; CHECK-NEXT:    li 23, 400
2376; CHECK-NEXT:    evlddx 23, 31, 23
2377; CHECK-NEXT:    efdmul 23, 23, 27
2378; CHECK-NEXT:    efdadd 24, 23, 24
2379; CHECK-NEXT:    li 23, 384
2380; CHECK-NEXT:    evlddx 23, 31, 23
2381; CHECK-NEXT:    efdmul 23, 23, 0
2382; CHECK-NEXT:    efdadd 24, 23, 24
2383; CHECK-NEXT:    li 23, 368
2384; CHECK-NEXT:    evlddx 23, 31, 23
2385; CHECK-NEXT:    efdmul 23, 23, 26
2386; CHECK-NEXT:    efdadd 24, 23, 24
2387; CHECK-NEXT:    li 23, 352
2388; CHECK-NEXT:    evlddx 23, 31, 23
2389; CHECK-NEXT:    efdmul 23, 23, 28
2390; CHECK-NEXT:    efdadd 24, 23, 24
2391; CHECK-NEXT:    evstdd 24, 32(31)
2392; CHECK-NEXT:    evlddx 29, 29, 3
2393; CHECK-NEXT:    evlddx 5, 5, 3
2394; CHECK-NEXT:    efdmul 5, 5, 25
2395; CHECK-NEXT:    efdadd 5, 5, 29
2396; CHECK-NEXT:    evlddx 7, 7, 3
2397; CHECK-NEXT:    efdmul 7, 7, 27
2398; CHECK-NEXT:    efdadd 5, 7, 5
2399; CHECK-NEXT:    evlddx 7, 9, 3
2400; CHECK-NEXT:    efdmul 7, 7, 0
2401; CHECK-NEXT:    efdadd 5, 7, 5
2402; CHECK-NEXT:    evlddx 7, 11, 3
2403; CHECK-NEXT:    efdmul 7, 7, 26
2404; CHECK-NEXT:    efdadd 5, 7, 5
2405; CHECK-NEXT:    evlddx 7, 30, 3
2406; CHECK-NEXT:    efdmul 7, 7, 28
2407; CHECK-NEXT:    efdadd 7, 7, 5
2408; CHECK-NEXT:    addi 5, 31, 32
2409; CHECK-NEXT:    evstddx 7, 5, 3
2410; CHECK-NEXT:    li 7, 784
2411; CHECK-NEXT:    evlddx 7, 31, 7
2412; CHECK-NEXT:    li 9, 272
2413; CHECK-NEXT:    evlddx 9, 31, 9
2414; CHECK-NEXT:    li 11, 800
2415; CHECK-NEXT:    evlddx 11, 31, 11
2416; CHECK-NEXT:    li 30, 288
2417; CHECK-NEXT:    evlddx 0, 31, 30
2418; CHECK-NEXT:    efdmul 11, 11, 0
2419; CHECK-NEXT:    efdmul 7, 7, 9
2420; CHECK-NEXT:    efdsub 7, 7, 11
2421; CHECK-NEXT:    li 9, 832
2422; CHECK-NEXT:    evlddx 9, 31, 9
2423; CHECK-NEXT:    li 11, 304
2424; CHECK-NEXT:    evlddx 11, 31, 11
2425; CHECK-NEXT:    efdmul 9, 9, 11
2426; CHECK-NEXT:    efdadd 7, 9, 7
2427; CHECK-NEXT:    li 9, 768
2428; CHECK-NEXT:    evlddx 9, 31, 9
2429; CHECK-NEXT:    li 11, 320
2430; CHECK-NEXT:    evlddx 11, 31, 11
2431; CHECK-NEXT:    efdmul 9, 9, 11
2432; CHECK-NEXT:    efdadd 7, 9, 7
2433; CHECK-NEXT:    li 9, 816
2434; CHECK-NEXT:    evlddx 9, 31, 9
2435; CHECK-NEXT:    li 11, 336
2436; CHECK-NEXT:    evlddx 11, 31, 11
2437; CHECK-NEXT:    efdmul 9, 9, 11
2438; CHECK-NEXT:    efdsub 7, 7, 9
2439; CHECK-NEXT:    addi 9, 31, 16
2440; CHECK-NEXT:    evstddx 7, 9, 3
2441; CHECK-NEXT:    li 7, 784
2442; CHECK-NEXT:    evlddx 7, 31, 7
2443; CHECK-NEXT:    evlddx 4, 4, 3
2444; CHECK-NEXT:    li 11, 800
2445; CHECK-NEXT:    evlddx 11, 31, 11
2446; CHECK-NEXT:    evlddx 6, 6, 3
2447; CHECK-NEXT:    efdmul 6, 11, 6
2448; CHECK-NEXT:    efdmul 4, 7, 4
2449; CHECK-NEXT:    efdsub 4, 4, 6
2450; CHECK-NEXT:    li 6, 832
2451; CHECK-NEXT:    evlddx 6, 31, 6
2452; CHECK-NEXT:    evlddx 7, 8, 3
2453; CHECK-NEXT:    efdmul 6, 6, 7
2454; CHECK-NEXT:    efdadd 4, 6, 4
2455; CHECK-NEXT:    li 6, 768
2456; CHECK-NEXT:    evlddx 6, 31, 6
2457; CHECK-NEXT:    evlddx 7, 10, 3
2458; CHECK-NEXT:    efdmul 6, 6, 7
2459; CHECK-NEXT:    efdadd 4, 6, 4
2460; CHECK-NEXT:    li 6, 816
2461; CHECK-NEXT:    evlddx 6, 31, 6
2462; CHECK-NEXT:    evlddx 7, 12, 3
2463; CHECK-NEXT:    efdmul 6, 6, 7
2464; CHECK-NEXT:    efdsub 4, 4, 6
2465; CHECK-NEXT:    efdneg 4, 4
2466; CHECK-NEXT:    evstdd 4, 16(31)
2467; CHECK-NEXT:    evldd 4, 32(31)
2468; CHECK-NEXT:    evldd 6, 16(31)
2469; CHECK-NEXT:    efdadd 4, 4, 6
2470; CHECK-NEXT:    evstdd 4, 64(31)
2471; CHECK-NEXT:    evlddx 4, 5, 3
2472; CHECK-NEXT:    evlddx 6, 9, 3
2473; CHECK-NEXT:    efdadd 4, 4, 6
2474; CHECK-NEXT:    addi 6, 31, 64
2475; CHECK-NEXT:    evstddx 4, 6, 3
2476; CHECK-NEXT:    evldd 4, 32(31)
2477; CHECK-NEXT:    evldd 7, 16(31)
2478; CHECK-NEXT:    efdsub 4, 4, 7
2479; CHECK-NEXT:    evstdd 4, 48(31)
2480; CHECK-NEXT:    evlddx 4, 5, 3
2481; CHECK-NEXT:    evlddx 5, 9, 3
2482; CHECK-NEXT:    efdsub 5, 4, 5
2483; CHECK-NEXT:    addi 4, 31, 48
2484; CHECK-NEXT:    evstddx 5, 4, 3
2485; CHECK-NEXT:    lwz 5, 860(31)
2486; CHECK-NEXT:    lwz 7, 452(31)
2487; CHECK-NEXT:    lwz 8, 876(31)
2488; CHECK-NEXT:    mulli 9, 8, 3
2489; CHECK-NEXT:    add 9, 9, 7
2490; CHECK-NEXT:    slwi 9, 9, 4
2491; CHECK-NEXT:    add 5, 9, 5
2492; CHECK-NEXT:    li 9, -64
2493; CHECK-NEXT:    evlddx 10, 5, 9
2494; CHECK-NEXT:    evldd 11, 64(31)
2495; CHECK-NEXT:    lwz 12, 856(31)
2496; CHECK-NEXT:    efdcfsi 12, 12
2497; CHECK-NEXT:    li 0, -56
2498; CHECK-NEXT:    evlddx 5, 5, 0
2499; CHECK-NEXT:    efdmul 5, 12, 5
2500; CHECK-NEXT:    evlddx 12, 6, 3
2501; CHECK-NEXT:    efdmul 5, 5, 12
2502; CHECK-NEXT:    efdmul 10, 10, 11
2503; CHECK-NEXT:    efdsub 5, 10, 5
2504; CHECK-NEXT:    lwz 10, 864(31)
2505; CHECK-NEXT:    lwz 11, 764(31)
2506; CHECK-NEXT:    lwz 12, 872(31)
2507; CHECK-NEXT:    slwi 12, 12, 2
2508; CHECK-NEXT:    add 11, 11, 12
2509; CHECK-NEXT:    mullw 8, 8, 11
2510; CHECK-NEXT:    add 7, 7, 8
2511; CHECK-NEXT:    slwi 7, 7, 4
2512; CHECK-NEXT:    evstddx 5, 10, 7
2513; CHECK-NEXT:    lwz 5, 860(31)
2514; CHECK-NEXT:    lwz 7, 452(31)
2515; CHECK-NEXT:    lwz 8, 876(31)
2516; CHECK-NEXT:    mulli 10, 8, 3
2517; CHECK-NEXT:    add 10, 10, 7
2518; CHECK-NEXT:    slwi 10, 10, 4
2519; CHECK-NEXT:    add 5, 10, 5
2520; CHECK-NEXT:    evlddx 9, 5, 9
2521; CHECK-NEXT:    evlddx 6, 6, 3
2522; CHECK-NEXT:    lwz 10, 856(31)
2523; CHECK-NEXT:    efdcfsi 10, 10
2524; CHECK-NEXT:    evlddx 5, 5, 0
2525; CHECK-NEXT:    efdmul 5, 10, 5
2526; CHECK-NEXT:    evldd 10, 64(31)
2527; CHECK-NEXT:    efdmul 5, 5, 10
2528; CHECK-NEXT:    efdmul 6, 9, 6
2529; CHECK-NEXT:    efdadd 5, 6, 5
2530; CHECK-NEXT:    lwz 6, 864(31)
2531; CHECK-NEXT:    lwz 9, 764(31)
2532; CHECK-NEXT:    lwz 10, 872(31)
2533; CHECK-NEXT:    slwi 10, 10, 2
2534; CHECK-NEXT:    add 9, 9, 10
2535; CHECK-NEXT:    mullw 8, 8, 9
2536; CHECK-NEXT:    add 7, 7, 8
2537; CHECK-NEXT:    slwi 7, 7, 4
2538; CHECK-NEXT:    add 6, 6, 7
2539; CHECK-NEXT:    evstddx 5, 6, 3
2540; CHECK-NEXT:    lwz 5, 860(31)
2541; CHECK-NEXT:    lwz 6, 452(31)
2542; CHECK-NEXT:    lwz 7, 876(31)
2543; CHECK-NEXT:    mulli 8, 7, 6
2544; CHECK-NEXT:    add 8, 8, 6
2545; CHECK-NEXT:    slwi 8, 8, 4
2546; CHECK-NEXT:    add 5, 8, 5
2547; CHECK-NEXT:    li 8, -112
2548; CHECK-NEXT:    evlddx 9, 5, 8
2549; CHECK-NEXT:    evldd 10, 48(31)
2550; CHECK-NEXT:    lwz 11, 856(31)
2551; CHECK-NEXT:    efdcfsi 11, 11
2552; CHECK-NEXT:    li 12, -104
2553; CHECK-NEXT:    evlddx 5, 5, 12
2554; CHECK-NEXT:    efdmul 5, 11, 5
2555; CHECK-NEXT:    evlddx 11, 4, 3
2556; CHECK-NEXT:    efdmul 5, 5, 11
2557; CHECK-NEXT:    efdmul 9, 9, 10
2558; CHECK-NEXT:    efdsub 5, 9, 5
2559; CHECK-NEXT:    lwz 9, 864(31)
2560; CHECK-NEXT:    lwz 10, 764(31)
2561; CHECK-NEXT:    lwz 11, 872(31)
2562; CHECK-NEXT:    mulli 11, 11, 7
2563; CHECK-NEXT:    add 10, 10, 11
2564; CHECK-NEXT:    mullw 7, 7, 10
2565; CHECK-NEXT:    add 6, 6, 7
2566; CHECK-NEXT:    slwi 6, 6, 4
2567; CHECK-NEXT:    evstddx 5, 9, 6
2568; CHECK-NEXT:    lwz 5, 860(31)
2569; CHECK-NEXT:    lwz 6, 452(31)
2570; CHECK-NEXT:    lwz 7, 876(31)
2571; CHECK-NEXT:    mulli 9, 7, 6
2572; CHECK-NEXT:    add 9, 9, 6
2573; CHECK-NEXT:    slwi 9, 9, 4
2574; CHECK-NEXT:    add 5, 9, 5
2575; CHECK-NEXT:    evlddx 8, 5, 8
2576; CHECK-NEXT:    evlddx 4, 4, 3
2577; CHECK-NEXT:    lwz 9, 856(31)
2578; CHECK-NEXT:    efdcfsi 9, 9
2579; CHECK-NEXT:    evlddx 5, 5, 12
2580; CHECK-NEXT:    efdmul 5, 9, 5
2581; CHECK-NEXT:    evldd 9, 48(31)
2582; CHECK-NEXT:    efdmul 5, 5, 9
2583; CHECK-NEXT:    efdmul 4, 8, 4
2584; CHECK-NEXT:    efdadd 4, 4, 5
2585; CHECK-NEXT:    lwz 5, 864(31)
2586; CHECK-NEXT:    lwz 8, 764(31)
2587; CHECK-NEXT:    lwz 9, 872(31)
2588; CHECK-NEXT:    mulli 9, 9, 7
2589; CHECK-NEXT:    add 8, 8, 9
2590; CHECK-NEXT:    mullw 7, 7, 8
2591; CHECK-NEXT:    add 6, 6, 7
2592; CHECK-NEXT:    slwi 6, 6, 4
2593; CHECK-NEXT:    add 5, 5, 6
2594; CHECK-NEXT:    evstddx 4, 5, 3
2595; CHECK-NEXT:    b .LBB1_5
2596; CHECK-NEXT:  .LBB1_5:
2597; CHECK-NEXT:    lwz 3, 452(31)
2598; CHECK-NEXT:    addi 3, 3, 1
2599; CHECK-NEXT:    stw 3, 452(31)
2600; CHECK-NEXT:    b .LBB1_3
2601; CHECK-NEXT:  .LBB1_6:
2602; CHECK-NEXT:    b .LBB1_7
2603; CHECK-NEXT:  .LBB1_7:
2604; CHECK-NEXT:    lwz 3, 764(31)
2605; CHECK-NEXT:    addi 3, 3, 1
2606; CHECK-NEXT:    stw 3, 764(31)
2607; CHECK-NEXT:    b .LBB1_1
2608; CHECK-NEXT:  .LBB1_8:
2609; CHECK-NEXT:    lwz 30, 1080(31) # 4-byte Folded Reload
2610; CHECK-NEXT:    li 3, 984
2611; CHECK-NEXT:    evlddx 29, 31, 3 # 8-byte Folded Reload
2612; CHECK-NEXT:    li 3, 976
2613; CHECK-NEXT:    evlddx 28, 31, 3 # 8-byte Folded Reload
2614; CHECK-NEXT:    li 3, 968
2615; CHECK-NEXT:    evlddx 27, 31, 3 # 8-byte Folded Reload
2616; CHECK-NEXT:    li 3, 960
2617; CHECK-NEXT:    evlddx 26, 31, 3 # 8-byte Folded Reload
2618; CHECK-NEXT:    li 3, 952
2619; CHECK-NEXT:    evlddx 25, 31, 3 # 8-byte Folded Reload
2620; CHECK-NEXT:    li 3, 944
2621; CHECK-NEXT:    evlddx 24, 31, 3 # 8-byte Folded Reload
2622; CHECK-NEXT:    li 3, 936
2623; CHECK-NEXT:    evlddx 23, 31, 3 # 8-byte Folded Reload
2624; CHECK-NEXT:    li 3, 928
2625; CHECK-NEXT:    evlddx 22, 31, 3 # 8-byte Folded Reload
2626; CHECK-NEXT:    li 3, 920
2627; CHECK-NEXT:    evlddx 21, 31, 3 # 8-byte Folded Reload
2628; CHECK-NEXT:    li 3, 912
2629; CHECK-NEXT:    evlddx 20, 31, 3 # 8-byte Folded Reload
2630; CHECK-NEXT:    li 3, 904
2631; CHECK-NEXT:    evlddx 19, 31, 3 # 8-byte Folded Reload
2632; CHECK-NEXT:    li 3, 896
2633; CHECK-NEXT:    evlddx 18, 31, 3 # 8-byte Folded Reload
2634; CHECK-NEXT:    li 3, 888
2635; CHECK-NEXT:    evlddx 17, 31, 3 # 8-byte Folded Reload
2636; CHECK-NEXT:    li 3, 880
2637; CHECK-NEXT:    evlddx 16, 31, 3 # 8-byte Folded Reload
2638; CHECK-NEXT:    lwz 15, 1020(31) # 4-byte Folded Reload
2639; CHECK-NEXT:    lwz 31, 1084(1)
2640; CHECK-NEXT:    addi 1, 1, 1088
2641; CHECK-NEXT:    blr
2642  %7 = alloca i32, align 4
2643  %8 = alloca i32, align 4
2644  %9 = alloca ptr, align 4
2645  %10 = alloca ptr, align 4
2646  %11 = alloca ptr, align 4
2647  %12 = alloca i32, align 4
2648  %13 = alloca i32, align 4
2649  %14 = alloca double, align 8
2650  %15 = alloca double, align 8
2651  %16 = alloca double, align 8
2652  %17 = alloca double, align 8
2653  %18 = alloca double, align 8
2654  %19 = alloca double, align 8
2655  %20 = alloca double, align 8
2656  %21 = alloca double, align 8
2657  %22 = alloca double, align 8
2658  %23 = alloca double, align 8
2659  %24 = alloca i32, align 4
2660  %25 = alloca %struct.cmplx, align 8
2661  %26 = alloca %struct.cmplx, align 8
2662  %27 = alloca %struct.cmplx, align 8
2663  %28 = alloca %struct.cmplx, align 8
2664  %29 = alloca %struct.cmplx, align 8
2665  %30 = alloca %struct.cmplx, align 8
2666  %31 = alloca %struct.cmplx, align 8
2667  %32 = alloca %struct.cmplx, align 8
2668  %33 = alloca %struct.cmplx, align 8
2669  %34 = alloca %struct.cmplx, align 8
2670  %35 = alloca %struct.cmplx, align 8
2671  %36 = alloca %struct.cmplx, align 8
2672  %37 = alloca %struct.cmplx, align 8
2673  %38 = alloca %struct.cmplx, align 8
2674  %39 = alloca %struct.cmplx, align 8
2675  %40 = alloca %struct.cmplx, align 8
2676  %41 = alloca %struct.cmplx, align 8
2677  %42 = alloca %struct.cmplx, align 8
2678  %43 = alloca %struct.cmplx, align 8
2679  %44 = alloca i32, align 4
2680  %45 = alloca %struct.cmplx, align 8
2681  %46 = alloca %struct.cmplx, align 8
2682  %47 = alloca %struct.cmplx, align 8
2683  %48 = alloca %struct.cmplx, align 8
2684  %49 = alloca %struct.cmplx, align 8
2685  %50 = alloca %struct.cmplx, align 8
2686  %51 = alloca %struct.cmplx, align 8
2687  %52 = alloca %struct.cmplx, align 8
2688  %53 = alloca %struct.cmplx, align 8
2689  %54 = alloca %struct.cmplx, align 8
2690  %55 = alloca %struct.cmplx, align 8
2691  %56 = alloca %struct.cmplx, align 8
2692  %57 = alloca %struct.cmplx, align 8
2693  %58 = alloca %struct.cmplx, align 8
2694  %59 = alloca %struct.cmplx, align 8
2695  %60 = alloca %struct.cmplx, align 8
2696  %61 = alloca %struct.cmplx, align 8
2697  %62 = alloca %struct.cmplx, align 8
2698  %63 = alloca %struct.cmplx, align 8
2699  %64 = alloca %struct.cmplx, align 8
2700  %65 = alloca %struct.cmplx, align 8
2701  %66 = alloca %struct.cmplx, align 8
2702  %67 = alloca %struct.cmplx, align 8
2703  %68 = alloca %struct.cmplx, align 8
2704  %69 = alloca %struct.cmplx, align 8
2705  %70 = alloca %struct.cmplx, align 8
2706  %71 = alloca %struct.cmplx, align 8
2707  store i32 %0, ptr %7, align 4
2708  store i32 %1, ptr %8, align 4
2709  store ptr %2, ptr %9, align 4
2710  store ptr %3, ptr %10, align 4
2711  store ptr %4, ptr %11, align 4
2712  store i32 %5, ptr %12, align 4
2713  store i32 11, ptr %13, align 4
2714  store double 0x3FEAEB8C8764F0BA, ptr %14, align 8
2715  %72 = load i32, ptr %12, align 4
2716  %73 = sitofp i32 %72 to double
2717  %74 = fmul double %73, 0x3FE14CEDF8BB580B
2718  store double %74, ptr %15, align 8
2719  store double 0x3FDA9628D9C712B6, ptr %16, align 8
2720  %75 = load i32, ptr %12, align 4
2721  %76 = sitofp i32 %75 to double
2722  %77 = fmul double %76, 0x3FED1BB48EEE2C13
2723  store double %77, ptr %17, align 8
2724  store double 0xBFC2375F640F44DB, ptr %18, align 8
2725  %78 = load i32, ptr %12, align 4
2726  %79 = sitofp i32 %78 to double
2727  %80 = fmul double %79, 0x3FEFAC9E043842EF
2728  store double %80, ptr %19, align 8
2729  store double 0xBFE4F49E7F775887, ptr %20, align 8
2730  %81 = load i32, ptr %12, align 4
2731  %82 = sitofp i32 %81 to double
2732  %83 = fmul double %82, 0x3FE82F19BB3A28A1
2733  store double %83, ptr %21, align 8
2734  store double 0xBFEEB42A9BCD5057, ptr %22, align 8
2735  %84 = load i32, ptr %12, align 4
2736  %85 = sitofp i32 %84 to double
2737  %86 = fmul double %85, 0x3FD207E7FD768DBF
2738  store double %86, ptr %23, align 8
2739  store i32 0, ptr %24, align 4
2740  br label %87
2741
274287:                                               ; preds = %2792, %6
2743  %88 = load i32, ptr %24, align 4
2744  %89 = load i32, ptr %8, align 4
2745  %90 = icmp ult i32 %88, %89
2746  br i1 %90, label %91, label %2795
2747
274891:                                               ; preds = %87
2749  %92 = load ptr, ptr %9, align 4
2750  %93 = load i32, ptr %7, align 4
2751  %94 = load i32, ptr %24, align 4
2752  %95 = mul i32 11, %94
2753  %96 = add i32 0, %95
2754  %97 = mul i32 %93, %96
2755  %98 = add i32 0, %97
2756  %99 = getelementptr inbounds %struct.cmplx, ptr %92, i32 %98
2757  call void @llvm.memcpy.p0.p0.i32(ptr align 8 %25, ptr align 8 %99, i32 16, i1 false)
2758  %100 = load ptr, ptr %9, align 4
2759  %101 = load i32, ptr %7, align 4
2760  %102 = load i32, ptr %24, align 4
2761  %103 = mul i32 11, %102
2762  %104 = add i32 1, %103
2763  %105 = mul i32 %101, %104
2764  %106 = add i32 0, %105
2765  %107 = getelementptr inbounds %struct.cmplx, ptr %100, i32 %106
2766  %108 = getelementptr inbounds %struct.cmplx, ptr %107, i32 0, i32 0
2767  %109 = load double, ptr %108, align 8
2768  %110 = load ptr, ptr %9, align 4
2769  %111 = load i32, ptr %7, align 4
2770  %112 = load i32, ptr %24, align 4
2771  %113 = mul i32 11, %112
2772  %114 = add i32 10, %113
2773  %115 = mul i32 %111, %114
2774  %116 = add i32 0, %115
2775  %117 = getelementptr inbounds %struct.cmplx, ptr %110, i32 %116
2776  %118 = getelementptr inbounds %struct.cmplx, ptr %117, i32 0, i32 0
2777  %119 = load double, ptr %118, align 8
2778  %120 = fadd double %109, %119
2779  %121 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 0
2780  store double %120, ptr %121, align 8
2781  %122 = load ptr, ptr %9, align 4
2782  %123 = load i32, ptr %7, align 4
2783  %124 = load i32, ptr %24, align 4
2784  %125 = mul i32 11, %124
2785  %126 = add i32 1, %125
2786  %127 = mul i32 %123, %126
2787  %128 = add i32 0, %127
2788  %129 = getelementptr inbounds %struct.cmplx, ptr %122, i32 %128
2789  %130 = getelementptr inbounds %struct.cmplx, ptr %129, i32 0, i32 1
2790  %131 = load double, ptr %130, align 8
2791  %132 = load ptr, ptr %9, align 4
2792  %133 = load i32, ptr %7, align 4
2793  %134 = load i32, ptr %24, align 4
2794  %135 = mul i32 11, %134
2795  %136 = add i32 10, %135
2796  %137 = mul i32 %133, %136
2797  %138 = add i32 0, %137
2798  %139 = getelementptr inbounds %struct.cmplx, ptr %132, i32 %138
2799  %140 = getelementptr inbounds %struct.cmplx, ptr %139, i32 0, i32 1
2800  %141 = load double, ptr %140, align 8
2801  %142 = fadd double %131, %141
2802  %143 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 1
2803  store double %142, ptr %143, align 8
2804  %144 = load ptr, ptr %9, align 4
2805  %145 = load i32, ptr %7, align 4
2806  %146 = load i32, ptr %24, align 4
2807  %147 = mul i32 11, %146
2808  %148 = add i32 1, %147
2809  %149 = mul i32 %145, %148
2810  %150 = add i32 0, %149
2811  %151 = getelementptr inbounds %struct.cmplx, ptr %144, i32 %150
2812  %152 = getelementptr inbounds %struct.cmplx, ptr %151, i32 0, i32 0
2813  %153 = load double, ptr %152, align 8
2814  %154 = load ptr, ptr %9, align 4
2815  %155 = load i32, ptr %7, align 4
2816  %156 = load i32, ptr %24, align 4
2817  %157 = mul i32 11, %156
2818  %158 = add i32 10, %157
2819  %159 = mul i32 %155, %158
2820  %160 = add i32 0, %159
2821  %161 = getelementptr inbounds %struct.cmplx, ptr %154, i32 %160
2822  %162 = getelementptr inbounds %struct.cmplx, ptr %161, i32 0, i32 0
2823  %163 = load double, ptr %162, align 8
2824  %164 = fsub double %153, %163
2825  %165 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 0
2826  store double %164, ptr %165, align 8
2827  %166 = load ptr, ptr %9, align 4
2828  %167 = load i32, ptr %7, align 4
2829  %168 = load i32, ptr %24, align 4
2830  %169 = mul i32 11, %168
2831  %170 = add i32 1, %169
2832  %171 = mul i32 %167, %170
2833  %172 = add i32 0, %171
2834  %173 = getelementptr inbounds %struct.cmplx, ptr %166, i32 %172
2835  %174 = getelementptr inbounds %struct.cmplx, ptr %173, i32 0, i32 1
2836  %175 = load double, ptr %174, align 8
2837  %176 = load ptr, ptr %9, align 4
2838  %177 = load i32, ptr %7, align 4
2839  %178 = load i32, ptr %24, align 4
2840  %179 = mul i32 11, %178
2841  %180 = add i32 10, %179
2842  %181 = mul i32 %177, %180
2843  %182 = add i32 0, %181
2844  %183 = getelementptr inbounds %struct.cmplx, ptr %176, i32 %182
2845  %184 = getelementptr inbounds %struct.cmplx, ptr %183, i32 0, i32 1
2846  %185 = load double, ptr %184, align 8
2847  %186 = fsub double %175, %185
2848  %187 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 1
2849  store double %186, ptr %187, align 8
2850  %188 = load ptr, ptr %9, align 4
2851  %189 = load i32, ptr %7, align 4
2852  %190 = load i32, ptr %24, align 4
2853  %191 = mul i32 11, %190
2854  %192 = add i32 2, %191
2855  %193 = mul i32 %189, %192
2856  %194 = add i32 0, %193
2857  %195 = getelementptr inbounds %struct.cmplx, ptr %188, i32 %194
2858  %196 = getelementptr inbounds %struct.cmplx, ptr %195, i32 0, i32 0
2859  %197 = load double, ptr %196, align 8
2860  %198 = load ptr, ptr %9, align 4
2861  %199 = load i32, ptr %7, align 4
2862  %200 = load i32, ptr %24, align 4
2863  %201 = mul i32 11, %200
2864  %202 = add i32 9, %201
2865  %203 = mul i32 %199, %202
2866  %204 = add i32 0, %203
2867  %205 = getelementptr inbounds %struct.cmplx, ptr %198, i32 %204
2868  %206 = getelementptr inbounds %struct.cmplx, ptr %205, i32 0, i32 0
2869  %207 = load double, ptr %206, align 8
2870  %208 = fadd double %197, %207
2871  %209 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 0
2872  store double %208, ptr %209, align 8
2873  %210 = load ptr, ptr %9, align 4
2874  %211 = load i32, ptr %7, align 4
2875  %212 = load i32, ptr %24, align 4
2876  %213 = mul i32 11, %212
2877  %214 = add i32 2, %213
2878  %215 = mul i32 %211, %214
2879  %216 = add i32 0, %215
2880  %217 = getelementptr inbounds %struct.cmplx, ptr %210, i32 %216
2881  %218 = getelementptr inbounds %struct.cmplx, ptr %217, i32 0, i32 1
2882  %219 = load double, ptr %218, align 8
2883  %220 = load ptr, ptr %9, align 4
2884  %221 = load i32, ptr %7, align 4
2885  %222 = load i32, ptr %24, align 4
2886  %223 = mul i32 11, %222
2887  %224 = add i32 9, %223
2888  %225 = mul i32 %221, %224
2889  %226 = add i32 0, %225
2890  %227 = getelementptr inbounds %struct.cmplx, ptr %220, i32 %226
2891  %228 = getelementptr inbounds %struct.cmplx, ptr %227, i32 0, i32 1
2892  %229 = load double, ptr %228, align 8
2893  %230 = fadd double %219, %229
2894  %231 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 1
2895  store double %230, ptr %231, align 8
2896  %232 = load ptr, ptr %9, align 4
2897  %233 = load i32, ptr %7, align 4
2898  %234 = load i32, ptr %24, align 4
2899  %235 = mul i32 11, %234
2900  %236 = add i32 2, %235
2901  %237 = mul i32 %233, %236
2902  %238 = add i32 0, %237
2903  %239 = getelementptr inbounds %struct.cmplx, ptr %232, i32 %238
2904  %240 = getelementptr inbounds %struct.cmplx, ptr %239, i32 0, i32 0
2905  %241 = load double, ptr %240, align 8
2906  %242 = load ptr, ptr %9, align 4
2907  %243 = load i32, ptr %7, align 4
2908  %244 = load i32, ptr %24, align 4
2909  %245 = mul i32 11, %244
2910  %246 = add i32 9, %245
2911  %247 = mul i32 %243, %246
2912  %248 = add i32 0, %247
2913  %249 = getelementptr inbounds %struct.cmplx, ptr %242, i32 %248
2914  %250 = getelementptr inbounds %struct.cmplx, ptr %249, i32 0, i32 0
2915  %251 = load double, ptr %250, align 8
2916  %252 = fsub double %241, %251
2917  %253 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 0
2918  store double %252, ptr %253, align 8
2919  %254 = load ptr, ptr %9, align 4
2920  %255 = load i32, ptr %7, align 4
2921  %256 = load i32, ptr %24, align 4
2922  %257 = mul i32 11, %256
2923  %258 = add i32 2, %257
2924  %259 = mul i32 %255, %258
2925  %260 = add i32 0, %259
2926  %261 = getelementptr inbounds %struct.cmplx, ptr %254, i32 %260
2927  %262 = getelementptr inbounds %struct.cmplx, ptr %261, i32 0, i32 1
2928  %263 = load double, ptr %262, align 8
2929  %264 = load ptr, ptr %9, align 4
2930  %265 = load i32, ptr %7, align 4
2931  %266 = load i32, ptr %24, align 4
2932  %267 = mul i32 11, %266
2933  %268 = add i32 9, %267
2934  %269 = mul i32 %265, %268
2935  %270 = add i32 0, %269
2936  %271 = getelementptr inbounds %struct.cmplx, ptr %264, i32 %270
2937  %272 = getelementptr inbounds %struct.cmplx, ptr %271, i32 0, i32 1
2938  %273 = load double, ptr %272, align 8
2939  %274 = fsub double %263, %273
2940  %275 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 1
2941  store double %274, ptr %275, align 8
2942  %276 = load ptr, ptr %9, align 4
2943  %277 = load i32, ptr %7, align 4
2944  %278 = load i32, ptr %24, align 4
2945  %279 = mul i32 11, %278
2946  %280 = add i32 3, %279
2947  %281 = mul i32 %277, %280
2948  %282 = add i32 0, %281
2949  %283 = getelementptr inbounds %struct.cmplx, ptr %276, i32 %282
2950  %284 = getelementptr inbounds %struct.cmplx, ptr %283, i32 0, i32 0
2951  %285 = load double, ptr %284, align 8
2952  %286 = load ptr, ptr %9, align 4
2953  %287 = load i32, ptr %7, align 4
2954  %288 = load i32, ptr %24, align 4
2955  %289 = mul i32 11, %288
2956  %290 = add i32 8, %289
2957  %291 = mul i32 %287, %290
2958  %292 = add i32 0, %291
2959  %293 = getelementptr inbounds %struct.cmplx, ptr %286, i32 %292
2960  %294 = getelementptr inbounds %struct.cmplx, ptr %293, i32 0, i32 0
2961  %295 = load double, ptr %294, align 8
2962  %296 = fadd double %285, %295
2963  %297 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 0
2964  store double %296, ptr %297, align 8
2965  %298 = load ptr, ptr %9, align 4
2966  %299 = load i32, ptr %7, align 4
2967  %300 = load i32, ptr %24, align 4
2968  %301 = mul i32 11, %300
2969  %302 = add i32 3, %301
2970  %303 = mul i32 %299, %302
2971  %304 = add i32 0, %303
2972  %305 = getelementptr inbounds %struct.cmplx, ptr %298, i32 %304
2973  %306 = getelementptr inbounds %struct.cmplx, ptr %305, i32 0, i32 1
2974  %307 = load double, ptr %306, align 8
2975  %308 = load ptr, ptr %9, align 4
2976  %309 = load i32, ptr %7, align 4
2977  %310 = load i32, ptr %24, align 4
2978  %311 = mul i32 11, %310
2979  %312 = add i32 8, %311
2980  %313 = mul i32 %309, %312
2981  %314 = add i32 0, %313
2982  %315 = getelementptr inbounds %struct.cmplx, ptr %308, i32 %314
2983  %316 = getelementptr inbounds %struct.cmplx, ptr %315, i32 0, i32 1
2984  %317 = load double, ptr %316, align 8
2985  %318 = fadd double %307, %317
2986  %319 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 1
2987  store double %318, ptr %319, align 8
2988  %320 = load ptr, ptr %9, align 4
2989  %321 = load i32, ptr %7, align 4
2990  %322 = load i32, ptr %24, align 4
2991  %323 = mul i32 11, %322
2992  %324 = add i32 3, %323
2993  %325 = mul i32 %321, %324
2994  %326 = add i32 0, %325
2995  %327 = getelementptr inbounds %struct.cmplx, ptr %320, i32 %326
2996  %328 = getelementptr inbounds %struct.cmplx, ptr %327, i32 0, i32 0
2997  %329 = load double, ptr %328, align 8
2998  %330 = load ptr, ptr %9, align 4
2999  %331 = load i32, ptr %7, align 4
3000  %332 = load i32, ptr %24, align 4
3001  %333 = mul i32 11, %332
3002  %334 = add i32 8, %333
3003  %335 = mul i32 %331, %334
3004  %336 = add i32 0, %335
3005  %337 = getelementptr inbounds %struct.cmplx, ptr %330, i32 %336
3006  %338 = getelementptr inbounds %struct.cmplx, ptr %337, i32 0, i32 0
3007  %339 = load double, ptr %338, align 8
3008  %340 = fsub double %329, %339
3009  %341 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 0
3010  store double %340, ptr %341, align 8
3011  %342 = load ptr, ptr %9, align 4
3012  %343 = load i32, ptr %7, align 4
3013  %344 = load i32, ptr %24, align 4
3014  %345 = mul i32 11, %344
3015  %346 = add i32 3, %345
3016  %347 = mul i32 %343, %346
3017  %348 = add i32 0, %347
3018  %349 = getelementptr inbounds %struct.cmplx, ptr %342, i32 %348
3019  %350 = getelementptr inbounds %struct.cmplx, ptr %349, i32 0, i32 1
3020  %351 = load double, ptr %350, align 8
3021  %352 = load ptr, ptr %9, align 4
3022  %353 = load i32, ptr %7, align 4
3023  %354 = load i32, ptr %24, align 4
3024  %355 = mul i32 11, %354
3025  %356 = add i32 8, %355
3026  %357 = mul i32 %353, %356
3027  %358 = add i32 0, %357
3028  %359 = getelementptr inbounds %struct.cmplx, ptr %352, i32 %358
3029  %360 = getelementptr inbounds %struct.cmplx, ptr %359, i32 0, i32 1
3030  %361 = load double, ptr %360, align 8
3031  %362 = fsub double %351, %361
3032  %363 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 1
3033  store double %362, ptr %363, align 8
3034  %364 = load ptr, ptr %9, align 4
3035  %365 = load i32, ptr %7, align 4
3036  %366 = load i32, ptr %24, align 4
3037  %367 = mul i32 11, %366
3038  %368 = add i32 4, %367
3039  %369 = mul i32 %365, %368
3040  %370 = add i32 0, %369
3041  %371 = getelementptr inbounds %struct.cmplx, ptr %364, i32 %370
3042  %372 = getelementptr inbounds %struct.cmplx, ptr %371, i32 0, i32 0
3043  %373 = load double, ptr %372, align 8
3044  %374 = load ptr, ptr %9, align 4
3045  %375 = load i32, ptr %7, align 4
3046  %376 = load i32, ptr %24, align 4
3047  %377 = mul i32 11, %376
3048  %378 = add i32 7, %377
3049  %379 = mul i32 %375, %378
3050  %380 = add i32 0, %379
3051  %381 = getelementptr inbounds %struct.cmplx, ptr %374, i32 %380
3052  %382 = getelementptr inbounds %struct.cmplx, ptr %381, i32 0, i32 0
3053  %383 = load double, ptr %382, align 8
3054  %384 = fadd double %373, %383
3055  %385 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 0
3056  store double %384, ptr %385, align 8
3057  %386 = load ptr, ptr %9, align 4
3058  %387 = load i32, ptr %7, align 4
3059  %388 = load i32, ptr %24, align 4
3060  %389 = mul i32 11, %388
3061  %390 = add i32 4, %389
3062  %391 = mul i32 %387, %390
3063  %392 = add i32 0, %391
3064  %393 = getelementptr inbounds %struct.cmplx, ptr %386, i32 %392
3065  %394 = getelementptr inbounds %struct.cmplx, ptr %393, i32 0, i32 1
3066  %395 = load double, ptr %394, align 8
3067  %396 = load ptr, ptr %9, align 4
3068  %397 = load i32, ptr %7, align 4
3069  %398 = load i32, ptr %24, align 4
3070  %399 = mul i32 11, %398
3071  %400 = add i32 7, %399
3072  %401 = mul i32 %397, %400
3073  %402 = add i32 0, %401
3074  %403 = getelementptr inbounds %struct.cmplx, ptr %396, i32 %402
3075  %404 = getelementptr inbounds %struct.cmplx, ptr %403, i32 0, i32 1
3076  %405 = load double, ptr %404, align 8
3077  %406 = fadd double %395, %405
3078  %407 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 1
3079  store double %406, ptr %407, align 8
3080  %408 = load ptr, ptr %9, align 4
3081  %409 = load i32, ptr %7, align 4
3082  %410 = load i32, ptr %24, align 4
3083  %411 = mul i32 11, %410
3084  %412 = add i32 4, %411
3085  %413 = mul i32 %409, %412
3086  %414 = add i32 0, %413
3087  %415 = getelementptr inbounds %struct.cmplx, ptr %408, i32 %414
3088  %416 = getelementptr inbounds %struct.cmplx, ptr %415, i32 0, i32 0
3089  %417 = load double, ptr %416, align 8
3090  %418 = load ptr, ptr %9, align 4
3091  %419 = load i32, ptr %7, align 4
3092  %420 = load i32, ptr %24, align 4
3093  %421 = mul i32 11, %420
3094  %422 = add i32 7, %421
3095  %423 = mul i32 %419, %422
3096  %424 = add i32 0, %423
3097  %425 = getelementptr inbounds %struct.cmplx, ptr %418, i32 %424
3098  %426 = getelementptr inbounds %struct.cmplx, ptr %425, i32 0, i32 0
3099  %427 = load double, ptr %426, align 8
3100  %428 = fsub double %417, %427
3101  %429 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 0
3102  store double %428, ptr %429, align 8
3103  %430 = load ptr, ptr %9, align 4
3104  %431 = load i32, ptr %7, align 4
3105  %432 = load i32, ptr %24, align 4
3106  %433 = mul i32 11, %432
3107  %434 = add i32 4, %433
3108  %435 = mul i32 %431, %434
3109  %436 = add i32 0, %435
3110  %437 = getelementptr inbounds %struct.cmplx, ptr %430, i32 %436
3111  %438 = getelementptr inbounds %struct.cmplx, ptr %437, i32 0, i32 1
3112  %439 = load double, ptr %438, align 8
3113  %440 = load ptr, ptr %9, align 4
3114  %441 = load i32, ptr %7, align 4
3115  %442 = load i32, ptr %24, align 4
3116  %443 = mul i32 11, %442
3117  %444 = add i32 7, %443
3118  %445 = mul i32 %441, %444
3119  %446 = add i32 0, %445
3120  %447 = getelementptr inbounds %struct.cmplx, ptr %440, i32 %446
3121  %448 = getelementptr inbounds %struct.cmplx, ptr %447, i32 0, i32 1
3122  %449 = load double, ptr %448, align 8
3123  %450 = fsub double %439, %449
3124  %451 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 1
3125  store double %450, ptr %451, align 8
3126  %452 = load ptr, ptr %9, align 4
3127  %453 = load i32, ptr %7, align 4
3128  %454 = load i32, ptr %24, align 4
3129  %455 = mul i32 11, %454
3130  %456 = add i32 5, %455
3131  %457 = mul i32 %453, %456
3132  %458 = add i32 0, %457
3133  %459 = getelementptr inbounds %struct.cmplx, ptr %452, i32 %458
3134  %460 = getelementptr inbounds %struct.cmplx, ptr %459, i32 0, i32 0
3135  %461 = load double, ptr %460, align 8
3136  %462 = load ptr, ptr %9, align 4
3137  %463 = load i32, ptr %7, align 4
3138  %464 = load i32, ptr %24, align 4
3139  %465 = mul i32 11, %464
3140  %466 = add i32 6, %465
3141  %467 = mul i32 %463, %466
3142  %468 = add i32 0, %467
3143  %469 = getelementptr inbounds %struct.cmplx, ptr %462, i32 %468
3144  %470 = getelementptr inbounds %struct.cmplx, ptr %469, i32 0, i32 0
3145  %471 = load double, ptr %470, align 8
3146  %472 = fadd double %461, %471
3147  %473 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 0
3148  store double %472, ptr %473, align 8
3149  %474 = load ptr, ptr %9, align 4
3150  %475 = load i32, ptr %7, align 4
3151  %476 = load i32, ptr %24, align 4
3152  %477 = mul i32 11, %476
3153  %478 = add i32 5, %477
3154  %479 = mul i32 %475, %478
3155  %480 = add i32 0, %479
3156  %481 = getelementptr inbounds %struct.cmplx, ptr %474, i32 %480
3157  %482 = getelementptr inbounds %struct.cmplx, ptr %481, i32 0, i32 1
3158  %483 = load double, ptr %482, align 8
3159  %484 = load ptr, ptr %9, align 4
3160  %485 = load i32, ptr %7, align 4
3161  %486 = load i32, ptr %24, align 4
3162  %487 = mul i32 11, %486
3163  %488 = add i32 6, %487
3164  %489 = mul i32 %485, %488
3165  %490 = add i32 0, %489
3166  %491 = getelementptr inbounds %struct.cmplx, ptr %484, i32 %490
3167  %492 = getelementptr inbounds %struct.cmplx, ptr %491, i32 0, i32 1
3168  %493 = load double, ptr %492, align 8
3169  %494 = fadd double %483, %493
3170  %495 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 1
3171  store double %494, ptr %495, align 8
3172  %496 = load ptr, ptr %9, align 4
3173  %497 = load i32, ptr %7, align 4
3174  %498 = load i32, ptr %24, align 4
3175  %499 = mul i32 11, %498
3176  %500 = add i32 5, %499
3177  %501 = mul i32 %497, %500
3178  %502 = add i32 0, %501
3179  %503 = getelementptr inbounds %struct.cmplx, ptr %496, i32 %502
3180  %504 = getelementptr inbounds %struct.cmplx, ptr %503, i32 0, i32 0
3181  %505 = load double, ptr %504, align 8
3182  %506 = load ptr, ptr %9, align 4
3183  %507 = load i32, ptr %7, align 4
3184  %508 = load i32, ptr %24, align 4
3185  %509 = mul i32 11, %508
3186  %510 = add i32 6, %509
3187  %511 = mul i32 %507, %510
3188  %512 = add i32 0, %511
3189  %513 = getelementptr inbounds %struct.cmplx, ptr %506, i32 %512
3190  %514 = getelementptr inbounds %struct.cmplx, ptr %513, i32 0, i32 0
3191  %515 = load double, ptr %514, align 8
3192  %516 = fsub double %505, %515
3193  %517 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 0
3194  store double %516, ptr %517, align 8
3195  %518 = load ptr, ptr %9, align 4
3196  %519 = load i32, ptr %7, align 4
3197  %520 = load i32, ptr %24, align 4
3198  %521 = mul i32 11, %520
3199  %522 = add i32 5, %521
3200  %523 = mul i32 %519, %522
3201  %524 = add i32 0, %523
3202  %525 = getelementptr inbounds %struct.cmplx, ptr %518, i32 %524
3203  %526 = getelementptr inbounds %struct.cmplx, ptr %525, i32 0, i32 1
3204  %527 = load double, ptr %526, align 8
3205  %528 = load ptr, ptr %9, align 4
3206  %529 = load i32, ptr %7, align 4
3207  %530 = load i32, ptr %24, align 4
3208  %531 = mul i32 11, %530
3209  %532 = add i32 6, %531
3210  %533 = mul i32 %529, %532
3211  %534 = add i32 0, %533
3212  %535 = getelementptr inbounds %struct.cmplx, ptr %528, i32 %534
3213  %536 = getelementptr inbounds %struct.cmplx, ptr %535, i32 0, i32 1
3214  %537 = load double, ptr %536, align 8
3215  %538 = fsub double %527, %537
3216  %539 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 1
3217  store double %538, ptr %539, align 8
3218  %540 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 0
3219  %541 = load double, ptr %540, align 8
3220  %542 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 0
3221  %543 = load double, ptr %542, align 8
3222  %544 = fadd double %541, %543
3223  %545 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 0
3224  %546 = load double, ptr %545, align 8
3225  %547 = fadd double %544, %546
3226  %548 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 0
3227  %549 = load double, ptr %548, align 8
3228  %550 = fadd double %547, %549
3229  %551 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 0
3230  %552 = load double, ptr %551, align 8
3231  %553 = fadd double %550, %552
3232  %554 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 0
3233  %555 = load double, ptr %554, align 8
3234  %556 = fadd double %553, %555
3235  %557 = load ptr, ptr %10, align 4
3236  %558 = load i32, ptr %7, align 4
3237  %559 = load i32, ptr %24, align 4
3238  %560 = load i32, ptr %8, align 4
3239  %561 = mul i32 %560, 0
3240  %562 = add i32 %559, %561
3241  %563 = mul i32 %558, %562
3242  %564 = add i32 0, %563
3243  %565 = getelementptr inbounds %struct.cmplx, ptr %557, i32 %564
3244  %566 = getelementptr inbounds %struct.cmplx, ptr %565, i32 0, i32 0
3245  store double %556, ptr %566, align 8
3246  %567 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 1
3247  %568 = load double, ptr %567, align 8
3248  %569 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 1
3249  %570 = load double, ptr %569, align 8
3250  %571 = fadd double %568, %570
3251  %572 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 1
3252  %573 = load double, ptr %572, align 8
3253  %574 = fadd double %571, %573
3254  %575 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 1
3255  %576 = load double, ptr %575, align 8
3256  %577 = fadd double %574, %576
3257  %578 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 1
3258  %579 = load double, ptr %578, align 8
3259  %580 = fadd double %577, %579
3260  %581 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 1
3261  %582 = load double, ptr %581, align 8
3262  %583 = fadd double %580, %582
3263  %584 = load ptr, ptr %10, align 4
3264  %585 = load i32, ptr %7, align 4
3265  %586 = load i32, ptr %24, align 4
3266  %587 = load i32, ptr %8, align 4
3267  %588 = mul i32 %587, 0
3268  %589 = add i32 %586, %588
3269  %590 = mul i32 %585, %589
3270  %591 = add i32 0, %590
3271  %592 = getelementptr inbounds %struct.cmplx, ptr %584, i32 %591
3272  %593 = getelementptr inbounds %struct.cmplx, ptr %592, i32 0, i32 1
3273  store double %583, ptr %593, align 8
3274  %594 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 0
3275  %595 = load double, ptr %594, align 8
3276  %596 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 0
3277  %597 = load double, ptr %596, align 8
3278  %598 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %597, double %595)
3279  %599 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 0
3280  %600 = load double, ptr %599, align 8
3281  %601 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %600, double %598)
3282  %602 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 0
3283  %603 = load double, ptr %602, align 8
3284  %604 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %603, double %601)
3285  %605 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 0
3286  %606 = load double, ptr %605, align 8
3287  %607 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %606, double %604)
3288  %608 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 0
3289  %609 = load double, ptr %608, align 8
3290  %610 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %609, double %607)
3291  %611 = getelementptr inbounds %struct.cmplx, ptr %36, i32 0, i32 0
3292  store double %610, ptr %611, align 8
3293  %612 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 1
3294  %613 = load double, ptr %612, align 8
3295  %614 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 1
3296  %615 = load double, ptr %614, align 8
3297  %616 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %615, double %613)
3298  %617 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 1
3299  %618 = load double, ptr %617, align 8
3300  %619 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %618, double %616)
3301  %620 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 1
3302  %621 = load double, ptr %620, align 8
3303  %622 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %621, double %619)
3304  %623 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 1
3305  %624 = load double, ptr %623, align 8
3306  %625 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %624, double %622)
3307  %626 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 1
3308  %627 = load double, ptr %626, align 8
3309  %628 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %627, double %625)
3310  %629 = getelementptr inbounds %struct.cmplx, ptr %36, i32 0, i32 1
3311  store double %628, ptr %629, align 8
3312  %630 = load double, ptr %15, align 8
3313  %631 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 0
3314  %632 = load double, ptr %631, align 8
3315  %633 = load double, ptr %17, align 8
3316  %634 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 0
3317  %635 = load double, ptr %634, align 8
3318  %636 = fmul double %633, %635
3319  %637 = call double @llvm.fmuladd.f64(double %630, double %632, double %636)
3320  %638 = load double, ptr %19, align 8
3321  %639 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 0
3322  %640 = load double, ptr %639, align 8
3323  %641 = call double @llvm.fmuladd.f64(double %638, double %640, double %637)
3324  %642 = load double, ptr %21, align 8
3325  %643 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 0
3326  %644 = load double, ptr %643, align 8
3327  %645 = call double @llvm.fmuladd.f64(double %642, double %644, double %641)
3328  %646 = load double, ptr %23, align 8
3329  %647 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 0
3330  %648 = load double, ptr %647, align 8
3331  %649 = call double @llvm.fmuladd.f64(double %646, double %648, double %645)
3332  %650 = getelementptr inbounds %struct.cmplx, ptr %37, i32 0, i32 1
3333  store double %649, ptr %650, align 8
3334  %651 = load double, ptr %15, align 8
3335  %652 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 1
3336  %653 = load double, ptr %652, align 8
3337  %654 = load double, ptr %17, align 8
3338  %655 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 1
3339  %656 = load double, ptr %655, align 8
3340  %657 = fmul double %654, %656
3341  %658 = call double @llvm.fmuladd.f64(double %651, double %653, double %657)
3342  %659 = load double, ptr %19, align 8
3343  %660 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 1
3344  %661 = load double, ptr %660, align 8
3345  %662 = call double @llvm.fmuladd.f64(double %659, double %661, double %658)
3346  %663 = load double, ptr %21, align 8
3347  %664 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 1
3348  %665 = load double, ptr %664, align 8
3349  %666 = call double @llvm.fmuladd.f64(double %663, double %665, double %662)
3350  %667 = load double, ptr %23, align 8
3351  %668 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 1
3352  %669 = load double, ptr %668, align 8
3353  %670 = call double @llvm.fmuladd.f64(double %667, double %669, double %666)
3354  %671 = fneg double %670
3355  %672 = getelementptr inbounds %struct.cmplx, ptr %37, i32 0, i32 0
3356  store double %671, ptr %672, align 8
3357  %673 = getelementptr inbounds %struct.cmplx, ptr %36, i32 0, i32 0
3358  %674 = load double, ptr %673, align 8
3359  %675 = getelementptr inbounds %struct.cmplx, ptr %37, i32 0, i32 0
3360  %676 = load double, ptr %675, align 8
3361  %677 = fadd double %674, %676
3362  %678 = load ptr, ptr %10, align 4
3363  %679 = load i32, ptr %7, align 4
3364  %680 = load i32, ptr %24, align 4
3365  %681 = load i32, ptr %8, align 4
3366  %682 = mul i32 %681, 1
3367  %683 = add i32 %680, %682
3368  %684 = mul i32 %679, %683
3369  %685 = add i32 0, %684
3370  %686 = getelementptr inbounds %struct.cmplx, ptr %678, i32 %685
3371  %687 = getelementptr inbounds %struct.cmplx, ptr %686, i32 0, i32 0
3372  store double %677, ptr %687, align 8
3373  %688 = getelementptr inbounds %struct.cmplx, ptr %36, i32 0, i32 1
3374  %689 = load double, ptr %688, align 8
3375  %690 = getelementptr inbounds %struct.cmplx, ptr %37, i32 0, i32 1
3376  %691 = load double, ptr %690, align 8
3377  %692 = fadd double %689, %691
3378  %693 = load ptr, ptr %10, align 4
3379  %694 = load i32, ptr %7, align 4
3380  %695 = load i32, ptr %24, align 4
3381  %696 = load i32, ptr %8, align 4
3382  %697 = mul i32 %696, 1
3383  %698 = add i32 %695, %697
3384  %699 = mul i32 %694, %698
3385  %700 = add i32 0, %699
3386  %701 = getelementptr inbounds %struct.cmplx, ptr %693, i32 %700
3387  %702 = getelementptr inbounds %struct.cmplx, ptr %701, i32 0, i32 1
3388  store double %692, ptr %702, align 8
3389  %703 = getelementptr inbounds %struct.cmplx, ptr %36, i32 0, i32 0
3390  %704 = load double, ptr %703, align 8
3391  %705 = getelementptr inbounds %struct.cmplx, ptr %37, i32 0, i32 0
3392  %706 = load double, ptr %705, align 8
3393  %707 = fsub double %704, %706
3394  %708 = load ptr, ptr %10, align 4
3395  %709 = load i32, ptr %7, align 4
3396  %710 = load i32, ptr %24, align 4
3397  %711 = load i32, ptr %8, align 4
3398  %712 = mul i32 %711, 10
3399  %713 = add i32 %710, %712
3400  %714 = mul i32 %709, %713
3401  %715 = add i32 0, %714
3402  %716 = getelementptr inbounds %struct.cmplx, ptr %708, i32 %715
3403  %717 = getelementptr inbounds %struct.cmplx, ptr %716, i32 0, i32 0
3404  store double %707, ptr %717, align 8
3405  %718 = getelementptr inbounds %struct.cmplx, ptr %36, i32 0, i32 1
3406  %719 = load double, ptr %718, align 8
3407  %720 = getelementptr inbounds %struct.cmplx, ptr %37, i32 0, i32 1
3408  %721 = load double, ptr %720, align 8
3409  %722 = fsub double %719, %721
3410  %723 = load ptr, ptr %10, align 4
3411  %724 = load i32, ptr %7, align 4
3412  %725 = load i32, ptr %24, align 4
3413  %726 = load i32, ptr %8, align 4
3414  %727 = mul i32 %726, 10
3415  %728 = add i32 %725, %727
3416  %729 = mul i32 %724, %728
3417  %730 = add i32 0, %729
3418  %731 = getelementptr inbounds %struct.cmplx, ptr %723, i32 %730
3419  %732 = getelementptr inbounds %struct.cmplx, ptr %731, i32 0, i32 1
3420  store double %722, ptr %732, align 8
3421  %733 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 0
3422  %734 = load double, ptr %733, align 8
3423  %735 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 0
3424  %736 = load double, ptr %735, align 8
3425  %737 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %736, double %734)
3426  %738 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 0
3427  %739 = load double, ptr %738, align 8
3428  %740 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %739, double %737)
3429  %741 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 0
3430  %742 = load double, ptr %741, align 8
3431  %743 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %742, double %740)
3432  %744 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 0
3433  %745 = load double, ptr %744, align 8
3434  %746 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %745, double %743)
3435  %747 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 0
3436  %748 = load double, ptr %747, align 8
3437  %749 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %748, double %746)
3438  %750 = getelementptr inbounds %struct.cmplx, ptr %38, i32 0, i32 0
3439  store double %749, ptr %750, align 8
3440  %751 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 1
3441  %752 = load double, ptr %751, align 8
3442  %753 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 1
3443  %754 = load double, ptr %753, align 8
3444  %755 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %754, double %752)
3445  %756 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 1
3446  %757 = load double, ptr %756, align 8
3447  %758 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %757, double %755)
3448  %759 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 1
3449  %760 = load double, ptr %759, align 8
3450  %761 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %760, double %758)
3451  %762 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 1
3452  %763 = load double, ptr %762, align 8
3453  %764 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %763, double %761)
3454  %765 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 1
3455  %766 = load double, ptr %765, align 8
3456  %767 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %766, double %764)
3457  %768 = getelementptr inbounds %struct.cmplx, ptr %38, i32 0, i32 1
3458  store double %767, ptr %768, align 8
3459  %769 = load double, ptr %17, align 8
3460  %770 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 0
3461  %771 = load double, ptr %770, align 8
3462  %772 = load double, ptr %21, align 8
3463  %773 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 0
3464  %774 = load double, ptr %773, align 8
3465  %775 = fmul double %772, %774
3466  %776 = call double @llvm.fmuladd.f64(double %769, double %771, double %775)
3467  %777 = load double, ptr %23, align 8
3468  %778 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 0
3469  %779 = load double, ptr %778, align 8
3470  %780 = fneg double %777
3471  %781 = call double @llvm.fmuladd.f64(double %780, double %779, double %776)
3472  %782 = load double, ptr %19, align 8
3473  %783 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 0
3474  %784 = load double, ptr %783, align 8
3475  %785 = fneg double %782
3476  %786 = call double @llvm.fmuladd.f64(double %785, double %784, double %781)
3477  %787 = load double, ptr %15, align 8
3478  %788 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 0
3479  %789 = load double, ptr %788, align 8
3480  %790 = fneg double %787
3481  %791 = call double @llvm.fmuladd.f64(double %790, double %789, double %786)
3482  %792 = getelementptr inbounds %struct.cmplx, ptr %39, i32 0, i32 1
3483  store double %791, ptr %792, align 8
3484  %793 = load double, ptr %17, align 8
3485  %794 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 1
3486  %795 = load double, ptr %794, align 8
3487  %796 = load double, ptr %21, align 8
3488  %797 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 1
3489  %798 = load double, ptr %797, align 8
3490  %799 = fmul double %796, %798
3491  %800 = call double @llvm.fmuladd.f64(double %793, double %795, double %799)
3492  %801 = load double, ptr %23, align 8
3493  %802 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 1
3494  %803 = load double, ptr %802, align 8
3495  %804 = fneg double %801
3496  %805 = call double @llvm.fmuladd.f64(double %804, double %803, double %800)
3497  %806 = load double, ptr %19, align 8
3498  %807 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 1
3499  %808 = load double, ptr %807, align 8
3500  %809 = fneg double %806
3501  %810 = call double @llvm.fmuladd.f64(double %809, double %808, double %805)
3502  %811 = load double, ptr %15, align 8
3503  %812 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 1
3504  %813 = load double, ptr %812, align 8
3505  %814 = fneg double %811
3506  %815 = call double @llvm.fmuladd.f64(double %814, double %813, double %810)
3507  %816 = fneg double %815
3508  %817 = getelementptr inbounds %struct.cmplx, ptr %39, i32 0, i32 0
3509  store double %816, ptr %817, align 8
3510  %818 = getelementptr inbounds %struct.cmplx, ptr %38, i32 0, i32 0
3511  %819 = load double, ptr %818, align 8
3512  %820 = getelementptr inbounds %struct.cmplx, ptr %39, i32 0, i32 0
3513  %821 = load double, ptr %820, align 8
3514  %822 = fadd double %819, %821
3515  %823 = load ptr, ptr %10, align 4
3516  %824 = load i32, ptr %7, align 4
3517  %825 = load i32, ptr %24, align 4
3518  %826 = load i32, ptr %8, align 4
3519  %827 = mul i32 %826, 2
3520  %828 = add i32 %825, %827
3521  %829 = mul i32 %824, %828
3522  %830 = add i32 0, %829
3523  %831 = getelementptr inbounds %struct.cmplx, ptr %823, i32 %830
3524  %832 = getelementptr inbounds %struct.cmplx, ptr %831, i32 0, i32 0
3525  store double %822, ptr %832, align 8
3526  %833 = getelementptr inbounds %struct.cmplx, ptr %38, i32 0, i32 1
3527  %834 = load double, ptr %833, align 8
3528  %835 = getelementptr inbounds %struct.cmplx, ptr %39, i32 0, i32 1
3529  %836 = load double, ptr %835, align 8
3530  %837 = fadd double %834, %836
3531  %838 = load ptr, ptr %10, align 4
3532  %839 = load i32, ptr %7, align 4
3533  %840 = load i32, ptr %24, align 4
3534  %841 = load i32, ptr %8, align 4
3535  %842 = mul i32 %841, 2
3536  %843 = add i32 %840, %842
3537  %844 = mul i32 %839, %843
3538  %845 = add i32 0, %844
3539  %846 = getelementptr inbounds %struct.cmplx, ptr %838, i32 %845
3540  %847 = getelementptr inbounds %struct.cmplx, ptr %846, i32 0, i32 1
3541  store double %837, ptr %847, align 8
3542  %848 = getelementptr inbounds %struct.cmplx, ptr %38, i32 0, i32 0
3543  %849 = load double, ptr %848, align 8
3544  %850 = getelementptr inbounds %struct.cmplx, ptr %39, i32 0, i32 0
3545  %851 = load double, ptr %850, align 8
3546  %852 = fsub double %849, %851
3547  %853 = load ptr, ptr %10, align 4
3548  %854 = load i32, ptr %7, align 4
3549  %855 = load i32, ptr %24, align 4
3550  %856 = load i32, ptr %8, align 4
3551  %857 = mul i32 %856, 9
3552  %858 = add i32 %855, %857
3553  %859 = mul i32 %854, %858
3554  %860 = add i32 0, %859
3555  %861 = getelementptr inbounds %struct.cmplx, ptr %853, i32 %860
3556  %862 = getelementptr inbounds %struct.cmplx, ptr %861, i32 0, i32 0
3557  store double %852, ptr %862, align 8
3558  %863 = getelementptr inbounds %struct.cmplx, ptr %38, i32 0, i32 1
3559  %864 = load double, ptr %863, align 8
3560  %865 = getelementptr inbounds %struct.cmplx, ptr %39, i32 0, i32 1
3561  %866 = load double, ptr %865, align 8
3562  %867 = fsub double %864, %866
3563  %868 = load ptr, ptr %10, align 4
3564  %869 = load i32, ptr %7, align 4
3565  %870 = load i32, ptr %24, align 4
3566  %871 = load i32, ptr %8, align 4
3567  %872 = mul i32 %871, 9
3568  %873 = add i32 %870, %872
3569  %874 = mul i32 %869, %873
3570  %875 = add i32 0, %874
3571  %876 = getelementptr inbounds %struct.cmplx, ptr %868, i32 %875
3572  %877 = getelementptr inbounds %struct.cmplx, ptr %876, i32 0, i32 1
3573  store double %867, ptr %877, align 8
3574  %878 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 0
3575  %879 = load double, ptr %878, align 8
3576  %880 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 0
3577  %881 = load double, ptr %880, align 8
3578  %882 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %881, double %879)
3579  %883 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 0
3580  %884 = load double, ptr %883, align 8
3581  %885 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %884, double %882)
3582  %886 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 0
3583  %887 = load double, ptr %886, align 8
3584  %888 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %887, double %885)
3585  %889 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 0
3586  %890 = load double, ptr %889, align 8
3587  %891 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %890, double %888)
3588  %892 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 0
3589  %893 = load double, ptr %892, align 8
3590  %894 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %893, double %891)
3591  %895 = getelementptr inbounds %struct.cmplx, ptr %40, i32 0, i32 0
3592  store double %894, ptr %895, align 8
3593  %896 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 1
3594  %897 = load double, ptr %896, align 8
3595  %898 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 1
3596  %899 = load double, ptr %898, align 8
3597  %900 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %899, double %897)
3598  %901 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 1
3599  %902 = load double, ptr %901, align 8
3600  %903 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %902, double %900)
3601  %904 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 1
3602  %905 = load double, ptr %904, align 8
3603  %906 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %905, double %903)
3604  %907 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 1
3605  %908 = load double, ptr %907, align 8
3606  %909 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %908, double %906)
3607  %910 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 1
3608  %911 = load double, ptr %910, align 8
3609  %912 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %911, double %909)
3610  %913 = getelementptr inbounds %struct.cmplx, ptr %40, i32 0, i32 1
3611  store double %912, ptr %913, align 8
3612  %914 = load double, ptr %19, align 8
3613  %915 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 0
3614  %916 = load double, ptr %915, align 8
3615  %917 = load double, ptr %23, align 8
3616  %918 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 0
3617  %919 = load double, ptr %918, align 8
3618  %920 = fmul double %917, %919
3619  %921 = fneg double %920
3620  %922 = call double @llvm.fmuladd.f64(double %914, double %916, double %921)
3621  %923 = load double, ptr %17, align 8
3622  %924 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 0
3623  %925 = load double, ptr %924, align 8
3624  %926 = fneg double %923
3625  %927 = call double @llvm.fmuladd.f64(double %926, double %925, double %922)
3626  %928 = load double, ptr %15, align 8
3627  %929 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 0
3628  %930 = load double, ptr %929, align 8
3629  %931 = call double @llvm.fmuladd.f64(double %928, double %930, double %927)
3630  %932 = load double, ptr %21, align 8
3631  %933 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 0
3632  %934 = load double, ptr %933, align 8
3633  %935 = call double @llvm.fmuladd.f64(double %932, double %934, double %931)
3634  %936 = getelementptr inbounds %struct.cmplx, ptr %41, i32 0, i32 1
3635  store double %935, ptr %936, align 8
3636  %937 = load double, ptr %19, align 8
3637  %938 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 1
3638  %939 = load double, ptr %938, align 8
3639  %940 = load double, ptr %23, align 8
3640  %941 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 1
3641  %942 = load double, ptr %941, align 8
3642  %943 = fmul double %940, %942
3643  %944 = fneg double %943
3644  %945 = call double @llvm.fmuladd.f64(double %937, double %939, double %944)
3645  %946 = load double, ptr %17, align 8
3646  %947 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 1
3647  %948 = load double, ptr %947, align 8
3648  %949 = fneg double %946
3649  %950 = call double @llvm.fmuladd.f64(double %949, double %948, double %945)
3650  %951 = load double, ptr %15, align 8
3651  %952 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 1
3652  %953 = load double, ptr %952, align 8
3653  %954 = call double @llvm.fmuladd.f64(double %951, double %953, double %950)
3654  %955 = load double, ptr %21, align 8
3655  %956 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 1
3656  %957 = load double, ptr %956, align 8
3657  %958 = call double @llvm.fmuladd.f64(double %955, double %957, double %954)
3658  %959 = fneg double %958
3659  %960 = getelementptr inbounds %struct.cmplx, ptr %41, i32 0, i32 0
3660  store double %959, ptr %960, align 8
3661  %961 = getelementptr inbounds %struct.cmplx, ptr %40, i32 0, i32 0
3662  %962 = load double, ptr %961, align 8
3663  %963 = getelementptr inbounds %struct.cmplx, ptr %41, i32 0, i32 0
3664  %964 = load double, ptr %963, align 8
3665  %965 = fadd double %962, %964
3666  %966 = load ptr, ptr %10, align 4
3667  %967 = load i32, ptr %7, align 4
3668  %968 = load i32, ptr %24, align 4
3669  %969 = load i32, ptr %8, align 4
3670  %970 = mul i32 %969, 3
3671  %971 = add i32 %968, %970
3672  %972 = mul i32 %967, %971
3673  %973 = add i32 0, %972
3674  %974 = getelementptr inbounds %struct.cmplx, ptr %966, i32 %973
3675  %975 = getelementptr inbounds %struct.cmplx, ptr %974, i32 0, i32 0
3676  store double %965, ptr %975, align 8
3677  %976 = getelementptr inbounds %struct.cmplx, ptr %40, i32 0, i32 1
3678  %977 = load double, ptr %976, align 8
3679  %978 = getelementptr inbounds %struct.cmplx, ptr %41, i32 0, i32 1
3680  %979 = load double, ptr %978, align 8
3681  %980 = fadd double %977, %979
3682  %981 = load ptr, ptr %10, align 4
3683  %982 = load i32, ptr %7, align 4
3684  %983 = load i32, ptr %24, align 4
3685  %984 = load i32, ptr %8, align 4
3686  %985 = mul i32 %984, 3
3687  %986 = add i32 %983, %985
3688  %987 = mul i32 %982, %986
3689  %988 = add i32 0, %987
3690  %989 = getelementptr inbounds %struct.cmplx, ptr %981, i32 %988
3691  %990 = getelementptr inbounds %struct.cmplx, ptr %989, i32 0, i32 1
3692  store double %980, ptr %990, align 8
3693  %991 = getelementptr inbounds %struct.cmplx, ptr %40, i32 0, i32 0
3694  %992 = load double, ptr %991, align 8
3695  %993 = getelementptr inbounds %struct.cmplx, ptr %41, i32 0, i32 0
3696  %994 = load double, ptr %993, align 8
3697  %995 = fsub double %992, %994
3698  %996 = load ptr, ptr %10, align 4
3699  %997 = load i32, ptr %7, align 4
3700  %998 = load i32, ptr %24, align 4
3701  %999 = load i32, ptr %8, align 4
3702  %1000 = mul i32 %999, 8
3703  %1001 = add i32 %998, %1000
3704  %1002 = mul i32 %997, %1001
3705  %1003 = add i32 0, %1002
3706  %1004 = getelementptr inbounds %struct.cmplx, ptr %996, i32 %1003
3707  %1005 = getelementptr inbounds %struct.cmplx, ptr %1004, i32 0, i32 0
3708  store double %995, ptr %1005, align 8
3709  %1006 = getelementptr inbounds %struct.cmplx, ptr %40, i32 0, i32 1
3710  %1007 = load double, ptr %1006, align 8
3711  %1008 = getelementptr inbounds %struct.cmplx, ptr %41, i32 0, i32 1
3712  %1009 = load double, ptr %1008, align 8
3713  %1010 = fsub double %1007, %1009
3714  %1011 = load ptr, ptr %10, align 4
3715  %1012 = load i32, ptr %7, align 4
3716  %1013 = load i32, ptr %24, align 4
3717  %1014 = load i32, ptr %8, align 4
3718  %1015 = mul i32 %1014, 8
3719  %1016 = add i32 %1013, %1015
3720  %1017 = mul i32 %1012, %1016
3721  %1018 = add i32 0, %1017
3722  %1019 = getelementptr inbounds %struct.cmplx, ptr %1011, i32 %1018
3723  %1020 = getelementptr inbounds %struct.cmplx, ptr %1019, i32 0, i32 1
3724  store double %1010, ptr %1020, align 8
3725  %1021 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 0
3726  %1022 = load double, ptr %1021, align 8
3727  %1023 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 0
3728  %1024 = load double, ptr %1023, align 8
3729  %1025 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %1024, double %1022)
3730  %1026 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 0
3731  %1027 = load double, ptr %1026, align 8
3732  %1028 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %1027, double %1025)
3733  %1029 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 0
3734  %1030 = load double, ptr %1029, align 8
3735  %1031 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %1030, double %1028)
3736  %1032 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 0
3737  %1033 = load double, ptr %1032, align 8
3738  %1034 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %1033, double %1031)
3739  %1035 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 0
3740  %1036 = load double, ptr %1035, align 8
3741  %1037 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %1036, double %1034)
3742  %1038 = getelementptr inbounds %struct.cmplx, ptr %42, i32 0, i32 0
3743  store double %1037, ptr %1038, align 8
3744  %1039 = getelementptr inbounds %struct.cmplx, ptr %25, i32 0, i32 1
3745  %1040 = load double, ptr %1039, align 8
3746  %1041 = getelementptr inbounds %struct.cmplx, ptr %26, i32 0, i32 1
3747  %1042 = load double, ptr %1041, align 8
3748  %1043 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %1042, double %1040)
3749  %1044 = getelementptr inbounds %struct.cmplx, ptr %27, i32 0, i32 1
3750  %1045 = load double, ptr %1044, align 8
3751  %1046 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %1045, double %1043)
3752  %1047 = getelementptr inbounds %struct.cmplx, ptr %28, i32 0, i32 1
3753  %1048 = load double, ptr %1047, align 8
3754  %1049 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %1048, double %1046)
3755  %1050 = getelementptr inbounds %struct.cmplx, ptr %29, i32 0, i32 1
3756  %1051 = load double, ptr %1050, align 8
3757  %1052 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %1051, double %1049)
3758  %1053 = getelementptr inbounds %struct.cmplx, ptr %30, i32 0, i32 1
3759  %1054 = load double, ptr %1053, align 8
3760  %1055 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %1054, double %1052)
3761  %1056 = getelementptr inbounds %struct.cmplx, ptr %42, i32 0, i32 1
3762  store double %1055, ptr %1056, align 8
3763  %1057 = load double, ptr %21, align 8
3764  %1058 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 0
3765  %1059 = load double, ptr %1058, align 8
3766  %1060 = load double, ptr %19, align 8
3767  %1061 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 0
3768  %1062 = load double, ptr %1061, align 8
3769  %1063 = fmul double %1060, %1062
3770  %1064 = fneg double %1063
3771  %1065 = call double @llvm.fmuladd.f64(double %1057, double %1059, double %1064)
3772  %1066 = load double, ptr %15, align 8
3773  %1067 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 0
3774  %1068 = load double, ptr %1067, align 8
3775  %1069 = call double @llvm.fmuladd.f64(double %1066, double %1068, double %1065)
3776  %1070 = load double, ptr %23, align 8
3777  %1071 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 0
3778  %1072 = load double, ptr %1071, align 8
3779  %1073 = call double @llvm.fmuladd.f64(double %1070, double %1072, double %1069)
3780  %1074 = load double, ptr %17, align 8
3781  %1075 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 0
3782  %1076 = load double, ptr %1075, align 8
3783  %1077 = fneg double %1074
3784  %1078 = call double @llvm.fmuladd.f64(double %1077, double %1076, double %1073)
3785  %1079 = getelementptr inbounds %struct.cmplx, ptr %43, i32 0, i32 1
3786  store double %1078, ptr %1079, align 8
3787  %1080 = load double, ptr %21, align 8
3788  %1081 = getelementptr inbounds %struct.cmplx, ptr %35, i32 0, i32 1
3789  %1082 = load double, ptr %1081, align 8
3790  %1083 = load double, ptr %19, align 8
3791  %1084 = getelementptr inbounds %struct.cmplx, ptr %34, i32 0, i32 1
3792  %1085 = load double, ptr %1084, align 8
3793  %1086 = fmul double %1083, %1085
3794  %1087 = fneg double %1086
3795  %1088 = call double @llvm.fmuladd.f64(double %1080, double %1082, double %1087)
3796  %1089 = load double, ptr %15, align 8
3797  %1090 = getelementptr inbounds %struct.cmplx, ptr %33, i32 0, i32 1
3798  %1091 = load double, ptr %1090, align 8
3799  %1092 = call double @llvm.fmuladd.f64(double %1089, double %1091, double %1088)
3800  %1093 = load double, ptr %23, align 8
3801  %1094 = getelementptr inbounds %struct.cmplx, ptr %32, i32 0, i32 1
3802  %1095 = load double, ptr %1094, align 8
3803  %1096 = call double @llvm.fmuladd.f64(double %1093, double %1095, double %1092)
3804  %1097 = load double, ptr %17, align 8
3805  %1098 = getelementptr inbounds %struct.cmplx, ptr %31, i32 0, i32 1
3806  %1099 = load double, ptr %1098, align 8
3807  %1100 = fneg double %1097
3808  %1101 = call double @llvm.fmuladd.f64(double %1100, double %1099, double %1096)
3809  %1102 = fneg double %1101
3810  %1103 = getelementptr inbounds %struct.cmplx, ptr %43, i32 0, i32 0
3811  store double %1102, ptr %1103, align 8
3812  %1104 = getelementptr inbounds %struct.cmplx, ptr %42, i32 0, i32 0
3813  %1105 = load double, ptr %1104, align 8
3814  %1106 = getelementptr inbounds %struct.cmplx, ptr %43, i32 0, i32 0
3815  %1107 = load double, ptr %1106, align 8
3816  %1108 = fadd double %1105, %1107
3817  %1109 = load ptr, ptr %10, align 4
3818  %1110 = load i32, ptr %7, align 4
3819  %1111 = load i32, ptr %24, align 4
3820  %1112 = load i32, ptr %8, align 4
3821  %1113 = mul i32 %1112, 4
3822  %1114 = add i32 %1111, %1113
3823  %1115 = mul i32 %1110, %1114
3824  %1116 = add i32 0, %1115
3825  %1117 = getelementptr inbounds %struct.cmplx, ptr %1109, i32 %1116
3826  %1118 = getelementptr inbounds %struct.cmplx, ptr %1117, i32 0, i32 0
3827  store double %1108, ptr %1118, align 8
3828  %1119 = getelementptr inbounds %struct.cmplx, ptr %42, i32 0, i32 1
3829  %1120 = load double, ptr %1119, align 8
3830  %1121 = getelementptr inbounds %struct.cmplx, ptr %43, i32 0, i32 1
3831  %1122 = load double, ptr %1121, align 8
3832  %1123 = fadd double %1120, %1122
3833  %1124 = load ptr, ptr %10, align 4
3834  %1125 = load i32, ptr %7, align 4
3835  %1126 = load i32, ptr %24, align 4
3836  %1127 = load i32, ptr %8, align 4
3837  %1128 = mul i32 %1127, 4
3838  %1129 = add i32 %1126, %1128
3839  %1130 = mul i32 %1125, %1129
3840  %1131 = add i32 0, %1130
3841  %1132 = getelementptr inbounds %struct.cmplx, ptr %1124, i32 %1131
3842  %1133 = getelementptr inbounds %struct.cmplx, ptr %1132, i32 0, i32 1
3843  store double %1123, ptr %1133, align 8
3844  %1134 = getelementptr inbounds %struct.cmplx, ptr %42, i32 0, i32 0
3845  %1135 = load double, ptr %1134, align 8
3846  %1136 = getelementptr inbounds %struct.cmplx, ptr %43, i32 0, i32 0
3847  %1137 = load double, ptr %1136, align 8
3848  %1138 = fsub double %1135, %1137
3849  %1139 = load ptr, ptr %10, align 4
3850  %1140 = load i32, ptr %7, align 4
3851  %1141 = load i32, ptr %24, align 4
3852  %1142 = load i32, ptr %8, align 4
3853  %1143 = mul i32 %1142, 7
3854  %1144 = add i32 %1141, %1143
3855  %1145 = mul i32 %1140, %1144
3856  %1146 = add i32 0, %1145
3857  %1147 = getelementptr inbounds %struct.cmplx, ptr %1139, i32 %1146
3858  %1148 = getelementptr inbounds %struct.cmplx, ptr %1147, i32 0, i32 0
3859  store double %1138, ptr %1148, align 8
3860  %1149 = getelementptr inbounds %struct.cmplx, ptr %42, i32 0, i32 1
3861  %1150 = load double, ptr %1149, align 8
3862  %1151 = getelementptr inbounds %struct.cmplx, ptr %43, i32 0, i32 1
3863  %1152 = load double, ptr %1151, align 8
3864  %1153 = fsub double %1150, %1152
3865  %1154 = load ptr, ptr %10, align 4
3866  %1155 = load i32, ptr %7, align 4
3867  %1156 = load i32, ptr %24, align 4
3868  %1157 = load i32, ptr %8, align 4
3869  %1158 = mul i32 %1157, 7
3870  %1159 = add i32 %1156, %1158
3871  %1160 = mul i32 %1155, %1159
3872  %1161 = add i32 0, %1160
3873  %1162 = getelementptr inbounds %struct.cmplx, ptr %1154, i32 %1161
3874  %1163 = getelementptr inbounds %struct.cmplx, ptr %1162, i32 0, i32 1
3875  store double %1153, ptr %1163, align 8
3876  store i32 1, ptr %44, align 4
3877  br label %1164
3878
38791164:                                             ; preds = %2788, %91
3880  %1165 = load i32, ptr %44, align 4
3881  %1166 = load i32, ptr %7, align 4
3882  %1167 = icmp ult i32 %1165, %1166
3883  br i1 %1167, label %1168, label %2791
3884
38851168:                                             ; preds = %1164
3886  %1169 = load ptr, ptr %9, align 4
3887  %1170 = load i32, ptr %44, align 4
3888  %1171 = load i32, ptr %7, align 4
3889  %1172 = load i32, ptr %24, align 4
3890  %1173 = mul i32 11, %1172
3891  %1174 = add i32 0, %1173
3892  %1175 = mul i32 %1171, %1174
3893  %1176 = add i32 %1170, %1175
3894  %1177 = getelementptr inbounds %struct.cmplx, ptr %1169, i32 %1176
3895  call void @llvm.memcpy.p0.p0.i32(ptr align 8 %45, ptr align 8 %1177, i32 16, i1 false)
3896  %1178 = load ptr, ptr %9, align 4
3897  %1179 = load i32, ptr %44, align 4
3898  %1180 = load i32, ptr %7, align 4
3899  %1181 = load i32, ptr %24, align 4
3900  %1182 = mul i32 11, %1181
3901  %1183 = add i32 1, %1182
3902  %1184 = mul i32 %1180, %1183
3903  %1185 = add i32 %1179, %1184
3904  %1186 = getelementptr inbounds %struct.cmplx, ptr %1178, i32 %1185
3905  %1187 = getelementptr inbounds %struct.cmplx, ptr %1186, i32 0, i32 0
3906  %1188 = load double, ptr %1187, align 8
3907  %1189 = load ptr, ptr %9, align 4
3908  %1190 = load i32, ptr %44, align 4
3909  %1191 = load i32, ptr %7, align 4
3910  %1192 = load i32, ptr %24, align 4
3911  %1193 = mul i32 11, %1192
3912  %1194 = add i32 10, %1193
3913  %1195 = mul i32 %1191, %1194
3914  %1196 = add i32 %1190, %1195
3915  %1197 = getelementptr inbounds %struct.cmplx, ptr %1189, i32 %1196
3916  %1198 = getelementptr inbounds %struct.cmplx, ptr %1197, i32 0, i32 0
3917  %1199 = load double, ptr %1198, align 8
3918  %1200 = fadd double %1188, %1199
3919  %1201 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 0
3920  store double %1200, ptr %1201, align 8
3921  %1202 = load ptr, ptr %9, align 4
3922  %1203 = load i32, ptr %44, align 4
3923  %1204 = load i32, ptr %7, align 4
3924  %1205 = load i32, ptr %24, align 4
3925  %1206 = mul i32 11, %1205
3926  %1207 = add i32 1, %1206
3927  %1208 = mul i32 %1204, %1207
3928  %1209 = add i32 %1203, %1208
3929  %1210 = getelementptr inbounds %struct.cmplx, ptr %1202, i32 %1209
3930  %1211 = getelementptr inbounds %struct.cmplx, ptr %1210, i32 0, i32 1
3931  %1212 = load double, ptr %1211, align 8
3932  %1213 = load ptr, ptr %9, align 4
3933  %1214 = load i32, ptr %44, align 4
3934  %1215 = load i32, ptr %7, align 4
3935  %1216 = load i32, ptr %24, align 4
3936  %1217 = mul i32 11, %1216
3937  %1218 = add i32 10, %1217
3938  %1219 = mul i32 %1215, %1218
3939  %1220 = add i32 %1214, %1219
3940  %1221 = getelementptr inbounds %struct.cmplx, ptr %1213, i32 %1220
3941  %1222 = getelementptr inbounds %struct.cmplx, ptr %1221, i32 0, i32 1
3942  %1223 = load double, ptr %1222, align 8
3943  %1224 = fadd double %1212, %1223
3944  %1225 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 1
3945  store double %1224, ptr %1225, align 8
3946  %1226 = load ptr, ptr %9, align 4
3947  %1227 = load i32, ptr %44, align 4
3948  %1228 = load i32, ptr %7, align 4
3949  %1229 = load i32, ptr %24, align 4
3950  %1230 = mul i32 11, %1229
3951  %1231 = add i32 1, %1230
3952  %1232 = mul i32 %1228, %1231
3953  %1233 = add i32 %1227, %1232
3954  %1234 = getelementptr inbounds %struct.cmplx, ptr %1226, i32 %1233
3955  %1235 = getelementptr inbounds %struct.cmplx, ptr %1234, i32 0, i32 0
3956  %1236 = load double, ptr %1235, align 8
3957  %1237 = load ptr, ptr %9, align 4
3958  %1238 = load i32, ptr %44, align 4
3959  %1239 = load i32, ptr %7, align 4
3960  %1240 = load i32, ptr %24, align 4
3961  %1241 = mul i32 11, %1240
3962  %1242 = add i32 10, %1241
3963  %1243 = mul i32 %1239, %1242
3964  %1244 = add i32 %1238, %1243
3965  %1245 = getelementptr inbounds %struct.cmplx, ptr %1237, i32 %1244
3966  %1246 = getelementptr inbounds %struct.cmplx, ptr %1245, i32 0, i32 0
3967  %1247 = load double, ptr %1246, align 8
3968  %1248 = fsub double %1236, %1247
3969  %1249 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 0
3970  store double %1248, ptr %1249, align 8
3971  %1250 = load ptr, ptr %9, align 4
3972  %1251 = load i32, ptr %44, align 4
3973  %1252 = load i32, ptr %7, align 4
3974  %1253 = load i32, ptr %24, align 4
3975  %1254 = mul i32 11, %1253
3976  %1255 = add i32 1, %1254
3977  %1256 = mul i32 %1252, %1255
3978  %1257 = add i32 %1251, %1256
3979  %1258 = getelementptr inbounds %struct.cmplx, ptr %1250, i32 %1257
3980  %1259 = getelementptr inbounds %struct.cmplx, ptr %1258, i32 0, i32 1
3981  %1260 = load double, ptr %1259, align 8
3982  %1261 = load ptr, ptr %9, align 4
3983  %1262 = load i32, ptr %44, align 4
3984  %1263 = load i32, ptr %7, align 4
3985  %1264 = load i32, ptr %24, align 4
3986  %1265 = mul i32 11, %1264
3987  %1266 = add i32 10, %1265
3988  %1267 = mul i32 %1263, %1266
3989  %1268 = add i32 %1262, %1267
3990  %1269 = getelementptr inbounds %struct.cmplx, ptr %1261, i32 %1268
3991  %1270 = getelementptr inbounds %struct.cmplx, ptr %1269, i32 0, i32 1
3992  %1271 = load double, ptr %1270, align 8
3993  %1272 = fsub double %1260, %1271
3994  %1273 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 1
3995  store double %1272, ptr %1273, align 8
3996  %1274 = load ptr, ptr %9, align 4
3997  %1275 = load i32, ptr %44, align 4
3998  %1276 = load i32, ptr %7, align 4
3999  %1277 = load i32, ptr %24, align 4
4000  %1278 = mul i32 11, %1277
4001  %1279 = add i32 2, %1278
4002  %1280 = mul i32 %1276, %1279
4003  %1281 = add i32 %1275, %1280
4004  %1282 = getelementptr inbounds %struct.cmplx, ptr %1274, i32 %1281
4005  %1283 = getelementptr inbounds %struct.cmplx, ptr %1282, i32 0, i32 0
4006  %1284 = load double, ptr %1283, align 8
4007  %1285 = load ptr, ptr %9, align 4
4008  %1286 = load i32, ptr %44, align 4
4009  %1287 = load i32, ptr %7, align 4
4010  %1288 = load i32, ptr %24, align 4
4011  %1289 = mul i32 11, %1288
4012  %1290 = add i32 9, %1289
4013  %1291 = mul i32 %1287, %1290
4014  %1292 = add i32 %1286, %1291
4015  %1293 = getelementptr inbounds %struct.cmplx, ptr %1285, i32 %1292
4016  %1294 = getelementptr inbounds %struct.cmplx, ptr %1293, i32 0, i32 0
4017  %1295 = load double, ptr %1294, align 8
4018  %1296 = fadd double %1284, %1295
4019  %1297 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 0
4020  store double %1296, ptr %1297, align 8
4021  %1298 = load ptr, ptr %9, align 4
4022  %1299 = load i32, ptr %44, align 4
4023  %1300 = load i32, ptr %7, align 4
4024  %1301 = load i32, ptr %24, align 4
4025  %1302 = mul i32 11, %1301
4026  %1303 = add i32 2, %1302
4027  %1304 = mul i32 %1300, %1303
4028  %1305 = add i32 %1299, %1304
4029  %1306 = getelementptr inbounds %struct.cmplx, ptr %1298, i32 %1305
4030  %1307 = getelementptr inbounds %struct.cmplx, ptr %1306, i32 0, i32 1
4031  %1308 = load double, ptr %1307, align 8
4032  %1309 = load ptr, ptr %9, align 4
4033  %1310 = load i32, ptr %44, align 4
4034  %1311 = load i32, ptr %7, align 4
4035  %1312 = load i32, ptr %24, align 4
4036  %1313 = mul i32 11, %1312
4037  %1314 = add i32 9, %1313
4038  %1315 = mul i32 %1311, %1314
4039  %1316 = add i32 %1310, %1315
4040  %1317 = getelementptr inbounds %struct.cmplx, ptr %1309, i32 %1316
4041  %1318 = getelementptr inbounds %struct.cmplx, ptr %1317, i32 0, i32 1
4042  %1319 = load double, ptr %1318, align 8
4043  %1320 = fadd double %1308, %1319
4044  %1321 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 1
4045  store double %1320, ptr %1321, align 8
4046  %1322 = load ptr, ptr %9, align 4
4047  %1323 = load i32, ptr %44, align 4
4048  %1324 = load i32, ptr %7, align 4
4049  %1325 = load i32, ptr %24, align 4
4050  %1326 = mul i32 11, %1325
4051  %1327 = add i32 2, %1326
4052  %1328 = mul i32 %1324, %1327
4053  %1329 = add i32 %1323, %1328
4054  %1330 = getelementptr inbounds %struct.cmplx, ptr %1322, i32 %1329
4055  %1331 = getelementptr inbounds %struct.cmplx, ptr %1330, i32 0, i32 0
4056  %1332 = load double, ptr %1331, align 8
4057  %1333 = load ptr, ptr %9, align 4
4058  %1334 = load i32, ptr %44, align 4
4059  %1335 = load i32, ptr %7, align 4
4060  %1336 = load i32, ptr %24, align 4
4061  %1337 = mul i32 11, %1336
4062  %1338 = add i32 9, %1337
4063  %1339 = mul i32 %1335, %1338
4064  %1340 = add i32 %1334, %1339
4065  %1341 = getelementptr inbounds %struct.cmplx, ptr %1333, i32 %1340
4066  %1342 = getelementptr inbounds %struct.cmplx, ptr %1341, i32 0, i32 0
4067  %1343 = load double, ptr %1342, align 8
4068  %1344 = fsub double %1332, %1343
4069  %1345 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 0
4070  store double %1344, ptr %1345, align 8
4071  %1346 = load ptr, ptr %9, align 4
4072  %1347 = load i32, ptr %44, align 4
4073  %1348 = load i32, ptr %7, align 4
4074  %1349 = load i32, ptr %24, align 4
4075  %1350 = mul i32 11, %1349
4076  %1351 = add i32 2, %1350
4077  %1352 = mul i32 %1348, %1351
4078  %1353 = add i32 %1347, %1352
4079  %1354 = getelementptr inbounds %struct.cmplx, ptr %1346, i32 %1353
4080  %1355 = getelementptr inbounds %struct.cmplx, ptr %1354, i32 0, i32 1
4081  %1356 = load double, ptr %1355, align 8
4082  %1357 = load ptr, ptr %9, align 4
4083  %1358 = load i32, ptr %44, align 4
4084  %1359 = load i32, ptr %7, align 4
4085  %1360 = load i32, ptr %24, align 4
4086  %1361 = mul i32 11, %1360
4087  %1362 = add i32 9, %1361
4088  %1363 = mul i32 %1359, %1362
4089  %1364 = add i32 %1358, %1363
4090  %1365 = getelementptr inbounds %struct.cmplx, ptr %1357, i32 %1364
4091  %1366 = getelementptr inbounds %struct.cmplx, ptr %1365, i32 0, i32 1
4092  %1367 = load double, ptr %1366, align 8
4093  %1368 = fsub double %1356, %1367
4094  %1369 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 1
4095  store double %1368, ptr %1369, align 8
4096  %1370 = load ptr, ptr %9, align 4
4097  %1371 = load i32, ptr %44, align 4
4098  %1372 = load i32, ptr %7, align 4
4099  %1373 = load i32, ptr %24, align 4
4100  %1374 = mul i32 11, %1373
4101  %1375 = add i32 3, %1374
4102  %1376 = mul i32 %1372, %1375
4103  %1377 = add i32 %1371, %1376
4104  %1378 = getelementptr inbounds %struct.cmplx, ptr %1370, i32 %1377
4105  %1379 = getelementptr inbounds %struct.cmplx, ptr %1378, i32 0, i32 0
4106  %1380 = load double, ptr %1379, align 8
4107  %1381 = load ptr, ptr %9, align 4
4108  %1382 = load i32, ptr %44, align 4
4109  %1383 = load i32, ptr %7, align 4
4110  %1384 = load i32, ptr %24, align 4
4111  %1385 = mul i32 11, %1384
4112  %1386 = add i32 8, %1385
4113  %1387 = mul i32 %1383, %1386
4114  %1388 = add i32 %1382, %1387
4115  %1389 = getelementptr inbounds %struct.cmplx, ptr %1381, i32 %1388
4116  %1390 = getelementptr inbounds %struct.cmplx, ptr %1389, i32 0, i32 0
4117  %1391 = load double, ptr %1390, align 8
4118  %1392 = fadd double %1380, %1391
4119  %1393 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 0
4120  store double %1392, ptr %1393, align 8
4121  %1394 = load ptr, ptr %9, align 4
4122  %1395 = load i32, ptr %44, align 4
4123  %1396 = load i32, ptr %7, align 4
4124  %1397 = load i32, ptr %24, align 4
4125  %1398 = mul i32 11, %1397
4126  %1399 = add i32 3, %1398
4127  %1400 = mul i32 %1396, %1399
4128  %1401 = add i32 %1395, %1400
4129  %1402 = getelementptr inbounds %struct.cmplx, ptr %1394, i32 %1401
4130  %1403 = getelementptr inbounds %struct.cmplx, ptr %1402, i32 0, i32 1
4131  %1404 = load double, ptr %1403, align 8
4132  %1405 = load ptr, ptr %9, align 4
4133  %1406 = load i32, ptr %44, align 4
4134  %1407 = load i32, ptr %7, align 4
4135  %1408 = load i32, ptr %24, align 4
4136  %1409 = mul i32 11, %1408
4137  %1410 = add i32 8, %1409
4138  %1411 = mul i32 %1407, %1410
4139  %1412 = add i32 %1406, %1411
4140  %1413 = getelementptr inbounds %struct.cmplx, ptr %1405, i32 %1412
4141  %1414 = getelementptr inbounds %struct.cmplx, ptr %1413, i32 0, i32 1
4142  %1415 = load double, ptr %1414, align 8
4143  %1416 = fadd double %1404, %1415
4144  %1417 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 1
4145  store double %1416, ptr %1417, align 8
4146  %1418 = load ptr, ptr %9, align 4
4147  %1419 = load i32, ptr %44, align 4
4148  %1420 = load i32, ptr %7, align 4
4149  %1421 = load i32, ptr %24, align 4
4150  %1422 = mul i32 11, %1421
4151  %1423 = add i32 3, %1422
4152  %1424 = mul i32 %1420, %1423
4153  %1425 = add i32 %1419, %1424
4154  %1426 = getelementptr inbounds %struct.cmplx, ptr %1418, i32 %1425
4155  %1427 = getelementptr inbounds %struct.cmplx, ptr %1426, i32 0, i32 0
4156  %1428 = load double, ptr %1427, align 8
4157  %1429 = load ptr, ptr %9, align 4
4158  %1430 = load i32, ptr %44, align 4
4159  %1431 = load i32, ptr %7, align 4
4160  %1432 = load i32, ptr %24, align 4
4161  %1433 = mul i32 11, %1432
4162  %1434 = add i32 8, %1433
4163  %1435 = mul i32 %1431, %1434
4164  %1436 = add i32 %1430, %1435
4165  %1437 = getelementptr inbounds %struct.cmplx, ptr %1429, i32 %1436
4166  %1438 = getelementptr inbounds %struct.cmplx, ptr %1437, i32 0, i32 0
4167  %1439 = load double, ptr %1438, align 8
4168  %1440 = fsub double %1428, %1439
4169  %1441 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 0
4170  store double %1440, ptr %1441, align 8
4171  %1442 = load ptr, ptr %9, align 4
4172  %1443 = load i32, ptr %44, align 4
4173  %1444 = load i32, ptr %7, align 4
4174  %1445 = load i32, ptr %24, align 4
4175  %1446 = mul i32 11, %1445
4176  %1447 = add i32 3, %1446
4177  %1448 = mul i32 %1444, %1447
4178  %1449 = add i32 %1443, %1448
4179  %1450 = getelementptr inbounds %struct.cmplx, ptr %1442, i32 %1449
4180  %1451 = getelementptr inbounds %struct.cmplx, ptr %1450, i32 0, i32 1
4181  %1452 = load double, ptr %1451, align 8
4182  %1453 = load ptr, ptr %9, align 4
4183  %1454 = load i32, ptr %44, align 4
4184  %1455 = load i32, ptr %7, align 4
4185  %1456 = load i32, ptr %24, align 4
4186  %1457 = mul i32 11, %1456
4187  %1458 = add i32 8, %1457
4188  %1459 = mul i32 %1455, %1458
4189  %1460 = add i32 %1454, %1459
4190  %1461 = getelementptr inbounds %struct.cmplx, ptr %1453, i32 %1460
4191  %1462 = getelementptr inbounds %struct.cmplx, ptr %1461, i32 0, i32 1
4192  %1463 = load double, ptr %1462, align 8
4193  %1464 = fsub double %1452, %1463
4194  %1465 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 1
4195  store double %1464, ptr %1465, align 8
4196  %1466 = load ptr, ptr %9, align 4
4197  %1467 = load i32, ptr %44, align 4
4198  %1468 = load i32, ptr %7, align 4
4199  %1469 = load i32, ptr %24, align 4
4200  %1470 = mul i32 11, %1469
4201  %1471 = add i32 4, %1470
4202  %1472 = mul i32 %1468, %1471
4203  %1473 = add i32 %1467, %1472
4204  %1474 = getelementptr inbounds %struct.cmplx, ptr %1466, i32 %1473
4205  %1475 = getelementptr inbounds %struct.cmplx, ptr %1474, i32 0, i32 0
4206  %1476 = load double, ptr %1475, align 8
4207  %1477 = load ptr, ptr %9, align 4
4208  %1478 = load i32, ptr %44, align 4
4209  %1479 = load i32, ptr %7, align 4
4210  %1480 = load i32, ptr %24, align 4
4211  %1481 = mul i32 11, %1480
4212  %1482 = add i32 7, %1481
4213  %1483 = mul i32 %1479, %1482
4214  %1484 = add i32 %1478, %1483
4215  %1485 = getelementptr inbounds %struct.cmplx, ptr %1477, i32 %1484
4216  %1486 = getelementptr inbounds %struct.cmplx, ptr %1485, i32 0, i32 0
4217  %1487 = load double, ptr %1486, align 8
4218  %1488 = fadd double %1476, %1487
4219  %1489 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 0
4220  store double %1488, ptr %1489, align 8
4221  %1490 = load ptr, ptr %9, align 4
4222  %1491 = load i32, ptr %44, align 4
4223  %1492 = load i32, ptr %7, align 4
4224  %1493 = load i32, ptr %24, align 4
4225  %1494 = mul i32 11, %1493
4226  %1495 = add i32 4, %1494
4227  %1496 = mul i32 %1492, %1495
4228  %1497 = add i32 %1491, %1496
4229  %1498 = getelementptr inbounds %struct.cmplx, ptr %1490, i32 %1497
4230  %1499 = getelementptr inbounds %struct.cmplx, ptr %1498, i32 0, i32 1
4231  %1500 = load double, ptr %1499, align 8
4232  %1501 = load ptr, ptr %9, align 4
4233  %1502 = load i32, ptr %44, align 4
4234  %1503 = load i32, ptr %7, align 4
4235  %1504 = load i32, ptr %24, align 4
4236  %1505 = mul i32 11, %1504
4237  %1506 = add i32 7, %1505
4238  %1507 = mul i32 %1503, %1506
4239  %1508 = add i32 %1502, %1507
4240  %1509 = getelementptr inbounds %struct.cmplx, ptr %1501, i32 %1508
4241  %1510 = getelementptr inbounds %struct.cmplx, ptr %1509, i32 0, i32 1
4242  %1511 = load double, ptr %1510, align 8
4243  %1512 = fadd double %1500, %1511
4244  %1513 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 1
4245  store double %1512, ptr %1513, align 8
4246  %1514 = load ptr, ptr %9, align 4
4247  %1515 = load i32, ptr %44, align 4
4248  %1516 = load i32, ptr %7, align 4
4249  %1517 = load i32, ptr %24, align 4
4250  %1518 = mul i32 11, %1517
4251  %1519 = add i32 4, %1518
4252  %1520 = mul i32 %1516, %1519
4253  %1521 = add i32 %1515, %1520
4254  %1522 = getelementptr inbounds %struct.cmplx, ptr %1514, i32 %1521
4255  %1523 = getelementptr inbounds %struct.cmplx, ptr %1522, i32 0, i32 0
4256  %1524 = load double, ptr %1523, align 8
4257  %1525 = load ptr, ptr %9, align 4
4258  %1526 = load i32, ptr %44, align 4
4259  %1527 = load i32, ptr %7, align 4
4260  %1528 = load i32, ptr %24, align 4
4261  %1529 = mul i32 11, %1528
4262  %1530 = add i32 7, %1529
4263  %1531 = mul i32 %1527, %1530
4264  %1532 = add i32 %1526, %1531
4265  %1533 = getelementptr inbounds %struct.cmplx, ptr %1525, i32 %1532
4266  %1534 = getelementptr inbounds %struct.cmplx, ptr %1533, i32 0, i32 0
4267  %1535 = load double, ptr %1534, align 8
4268  %1536 = fsub double %1524, %1535
4269  %1537 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 0
4270  store double %1536, ptr %1537, align 8
4271  %1538 = load ptr, ptr %9, align 4
4272  %1539 = load i32, ptr %44, align 4
4273  %1540 = load i32, ptr %7, align 4
4274  %1541 = load i32, ptr %24, align 4
4275  %1542 = mul i32 11, %1541
4276  %1543 = add i32 4, %1542
4277  %1544 = mul i32 %1540, %1543
4278  %1545 = add i32 %1539, %1544
4279  %1546 = getelementptr inbounds %struct.cmplx, ptr %1538, i32 %1545
4280  %1547 = getelementptr inbounds %struct.cmplx, ptr %1546, i32 0, i32 1
4281  %1548 = load double, ptr %1547, align 8
4282  %1549 = load ptr, ptr %9, align 4
4283  %1550 = load i32, ptr %44, align 4
4284  %1551 = load i32, ptr %7, align 4
4285  %1552 = load i32, ptr %24, align 4
4286  %1553 = mul i32 11, %1552
4287  %1554 = add i32 7, %1553
4288  %1555 = mul i32 %1551, %1554
4289  %1556 = add i32 %1550, %1555
4290  %1557 = getelementptr inbounds %struct.cmplx, ptr %1549, i32 %1556
4291  %1558 = getelementptr inbounds %struct.cmplx, ptr %1557, i32 0, i32 1
4292  %1559 = load double, ptr %1558, align 8
4293  %1560 = fsub double %1548, %1559
4294  %1561 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 1
4295  store double %1560, ptr %1561, align 8
4296  %1562 = load ptr, ptr %9, align 4
4297  %1563 = load i32, ptr %44, align 4
4298  %1564 = load i32, ptr %7, align 4
4299  %1565 = load i32, ptr %24, align 4
4300  %1566 = mul i32 11, %1565
4301  %1567 = add i32 5, %1566
4302  %1568 = mul i32 %1564, %1567
4303  %1569 = add i32 %1563, %1568
4304  %1570 = getelementptr inbounds %struct.cmplx, ptr %1562, i32 %1569
4305  %1571 = getelementptr inbounds %struct.cmplx, ptr %1570, i32 0, i32 0
4306  %1572 = load double, ptr %1571, align 8
4307  %1573 = load ptr, ptr %9, align 4
4308  %1574 = load i32, ptr %44, align 4
4309  %1575 = load i32, ptr %7, align 4
4310  %1576 = load i32, ptr %24, align 4
4311  %1577 = mul i32 11, %1576
4312  %1578 = add i32 6, %1577
4313  %1579 = mul i32 %1575, %1578
4314  %1580 = add i32 %1574, %1579
4315  %1581 = getelementptr inbounds %struct.cmplx, ptr %1573, i32 %1580
4316  %1582 = getelementptr inbounds %struct.cmplx, ptr %1581, i32 0, i32 0
4317  %1583 = load double, ptr %1582, align 8
4318  %1584 = fadd double %1572, %1583
4319  %1585 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 0
4320  store double %1584, ptr %1585, align 8
4321  %1586 = load ptr, ptr %9, align 4
4322  %1587 = load i32, ptr %44, align 4
4323  %1588 = load i32, ptr %7, align 4
4324  %1589 = load i32, ptr %24, align 4
4325  %1590 = mul i32 11, %1589
4326  %1591 = add i32 5, %1590
4327  %1592 = mul i32 %1588, %1591
4328  %1593 = add i32 %1587, %1592
4329  %1594 = getelementptr inbounds %struct.cmplx, ptr %1586, i32 %1593
4330  %1595 = getelementptr inbounds %struct.cmplx, ptr %1594, i32 0, i32 1
4331  %1596 = load double, ptr %1595, align 8
4332  %1597 = load ptr, ptr %9, align 4
4333  %1598 = load i32, ptr %44, align 4
4334  %1599 = load i32, ptr %7, align 4
4335  %1600 = load i32, ptr %24, align 4
4336  %1601 = mul i32 11, %1600
4337  %1602 = add i32 6, %1601
4338  %1603 = mul i32 %1599, %1602
4339  %1604 = add i32 %1598, %1603
4340  %1605 = getelementptr inbounds %struct.cmplx, ptr %1597, i32 %1604
4341  %1606 = getelementptr inbounds %struct.cmplx, ptr %1605, i32 0, i32 1
4342  %1607 = load double, ptr %1606, align 8
4343  %1608 = fadd double %1596, %1607
4344  %1609 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 1
4345  store double %1608, ptr %1609, align 8
4346  %1610 = load ptr, ptr %9, align 4
4347  %1611 = load i32, ptr %44, align 4
4348  %1612 = load i32, ptr %7, align 4
4349  %1613 = load i32, ptr %24, align 4
4350  %1614 = mul i32 11, %1613
4351  %1615 = add i32 5, %1614
4352  %1616 = mul i32 %1612, %1615
4353  %1617 = add i32 %1611, %1616
4354  %1618 = getelementptr inbounds %struct.cmplx, ptr %1610, i32 %1617
4355  %1619 = getelementptr inbounds %struct.cmplx, ptr %1618, i32 0, i32 0
4356  %1620 = load double, ptr %1619, align 8
4357  %1621 = load ptr, ptr %9, align 4
4358  %1622 = load i32, ptr %44, align 4
4359  %1623 = load i32, ptr %7, align 4
4360  %1624 = load i32, ptr %24, align 4
4361  %1625 = mul i32 11, %1624
4362  %1626 = add i32 6, %1625
4363  %1627 = mul i32 %1623, %1626
4364  %1628 = add i32 %1622, %1627
4365  %1629 = getelementptr inbounds %struct.cmplx, ptr %1621, i32 %1628
4366  %1630 = getelementptr inbounds %struct.cmplx, ptr %1629, i32 0, i32 0
4367  %1631 = load double, ptr %1630, align 8
4368  %1632 = fsub double %1620, %1631
4369  %1633 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 0
4370  store double %1632, ptr %1633, align 8
4371  %1634 = load ptr, ptr %9, align 4
4372  %1635 = load i32, ptr %44, align 4
4373  %1636 = load i32, ptr %7, align 4
4374  %1637 = load i32, ptr %24, align 4
4375  %1638 = mul i32 11, %1637
4376  %1639 = add i32 5, %1638
4377  %1640 = mul i32 %1636, %1639
4378  %1641 = add i32 %1635, %1640
4379  %1642 = getelementptr inbounds %struct.cmplx, ptr %1634, i32 %1641
4380  %1643 = getelementptr inbounds %struct.cmplx, ptr %1642, i32 0, i32 1
4381  %1644 = load double, ptr %1643, align 8
4382  %1645 = load ptr, ptr %9, align 4
4383  %1646 = load i32, ptr %44, align 4
4384  %1647 = load i32, ptr %7, align 4
4385  %1648 = load i32, ptr %24, align 4
4386  %1649 = mul i32 11, %1648
4387  %1650 = add i32 6, %1649
4388  %1651 = mul i32 %1647, %1650
4389  %1652 = add i32 %1646, %1651
4390  %1653 = getelementptr inbounds %struct.cmplx, ptr %1645, i32 %1652
4391  %1654 = getelementptr inbounds %struct.cmplx, ptr %1653, i32 0, i32 1
4392  %1655 = load double, ptr %1654, align 8
4393  %1656 = fsub double %1644, %1655
4394  %1657 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 1
4395  store double %1656, ptr %1657, align 8
4396  %1658 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 0
4397  %1659 = load double, ptr %1658, align 8
4398  %1660 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 0
4399  %1661 = load double, ptr %1660, align 8
4400  %1662 = fadd double %1659, %1661
4401  %1663 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 0
4402  %1664 = load double, ptr %1663, align 8
4403  %1665 = fadd double %1662, %1664
4404  %1666 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 0
4405  %1667 = load double, ptr %1666, align 8
4406  %1668 = fadd double %1665, %1667
4407  %1669 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 0
4408  %1670 = load double, ptr %1669, align 8
4409  %1671 = fadd double %1668, %1670
4410  %1672 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 0
4411  %1673 = load double, ptr %1672, align 8
4412  %1674 = fadd double %1671, %1673
4413  %1675 = load ptr, ptr %10, align 4
4414  %1676 = load i32, ptr %44, align 4
4415  %1677 = load i32, ptr %7, align 4
4416  %1678 = load i32, ptr %24, align 4
4417  %1679 = load i32, ptr %8, align 4
4418  %1680 = mul i32 %1679, 0
4419  %1681 = add i32 %1678, %1680
4420  %1682 = mul i32 %1677, %1681
4421  %1683 = add i32 %1676, %1682
4422  %1684 = getelementptr inbounds %struct.cmplx, ptr %1675, i32 %1683
4423  %1685 = getelementptr inbounds %struct.cmplx, ptr %1684, i32 0, i32 0
4424  store double %1674, ptr %1685, align 8
4425  %1686 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 1
4426  %1687 = load double, ptr %1686, align 8
4427  %1688 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 1
4428  %1689 = load double, ptr %1688, align 8
4429  %1690 = fadd double %1687, %1689
4430  %1691 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 1
4431  %1692 = load double, ptr %1691, align 8
4432  %1693 = fadd double %1690, %1692
4433  %1694 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 1
4434  %1695 = load double, ptr %1694, align 8
4435  %1696 = fadd double %1693, %1695
4436  %1697 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 1
4437  %1698 = load double, ptr %1697, align 8
4438  %1699 = fadd double %1696, %1698
4439  %1700 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 1
4440  %1701 = load double, ptr %1700, align 8
4441  %1702 = fadd double %1699, %1701
4442  %1703 = load ptr, ptr %10, align 4
4443  %1704 = load i32, ptr %44, align 4
4444  %1705 = load i32, ptr %7, align 4
4445  %1706 = load i32, ptr %24, align 4
4446  %1707 = load i32, ptr %8, align 4
4447  %1708 = mul i32 %1707, 0
4448  %1709 = add i32 %1706, %1708
4449  %1710 = mul i32 %1705, %1709
4450  %1711 = add i32 %1704, %1710
4451  %1712 = getelementptr inbounds %struct.cmplx, ptr %1703, i32 %1711
4452  %1713 = getelementptr inbounds %struct.cmplx, ptr %1712, i32 0, i32 1
4453  store double %1702, ptr %1713, align 8
4454  %1714 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 0
4455  %1715 = load double, ptr %1714, align 8
4456  %1716 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 0
4457  %1717 = load double, ptr %1716, align 8
4458  %1718 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %1717, double %1715)
4459  %1719 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 0
4460  %1720 = load double, ptr %1719, align 8
4461  %1721 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %1720, double %1718)
4462  %1722 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 0
4463  %1723 = load double, ptr %1722, align 8
4464  %1724 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %1723, double %1721)
4465  %1725 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 0
4466  %1726 = load double, ptr %1725, align 8
4467  %1727 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %1726, double %1724)
4468  %1728 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 0
4469  %1729 = load double, ptr %1728, align 8
4470  %1730 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %1729, double %1727)
4471  %1731 = getelementptr inbounds %struct.cmplx, ptr %58, i32 0, i32 0
4472  store double %1730, ptr %1731, align 8
4473  %1732 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 1
4474  %1733 = load double, ptr %1732, align 8
4475  %1734 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 1
4476  %1735 = load double, ptr %1734, align 8
4477  %1736 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %1735, double %1733)
4478  %1737 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 1
4479  %1738 = load double, ptr %1737, align 8
4480  %1739 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %1738, double %1736)
4481  %1740 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 1
4482  %1741 = load double, ptr %1740, align 8
4483  %1742 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %1741, double %1739)
4484  %1743 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 1
4485  %1744 = load double, ptr %1743, align 8
4486  %1745 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %1744, double %1742)
4487  %1746 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 1
4488  %1747 = load double, ptr %1746, align 8
4489  %1748 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %1747, double %1745)
4490  %1749 = getelementptr inbounds %struct.cmplx, ptr %58, i32 0, i32 1
4491  store double %1748, ptr %1749, align 8
4492  %1750 = load double, ptr %15, align 8
4493  %1751 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 0
4494  %1752 = load double, ptr %1751, align 8
4495  %1753 = load double, ptr %17, align 8
4496  %1754 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 0
4497  %1755 = load double, ptr %1754, align 8
4498  %1756 = fmul double %1753, %1755
4499  %1757 = call double @llvm.fmuladd.f64(double %1750, double %1752, double %1756)
4500  %1758 = load double, ptr %19, align 8
4501  %1759 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 0
4502  %1760 = load double, ptr %1759, align 8
4503  %1761 = call double @llvm.fmuladd.f64(double %1758, double %1760, double %1757)
4504  %1762 = load double, ptr %21, align 8
4505  %1763 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 0
4506  %1764 = load double, ptr %1763, align 8
4507  %1765 = call double @llvm.fmuladd.f64(double %1762, double %1764, double %1761)
4508  %1766 = load double, ptr %23, align 8
4509  %1767 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 0
4510  %1768 = load double, ptr %1767, align 8
4511  %1769 = call double @llvm.fmuladd.f64(double %1766, double %1768, double %1765)
4512  %1770 = getelementptr inbounds %struct.cmplx, ptr %59, i32 0, i32 1
4513  store double %1769, ptr %1770, align 8
4514  %1771 = load double, ptr %15, align 8
4515  %1772 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 1
4516  %1773 = load double, ptr %1772, align 8
4517  %1774 = load double, ptr %17, align 8
4518  %1775 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 1
4519  %1776 = load double, ptr %1775, align 8
4520  %1777 = fmul double %1774, %1776
4521  %1778 = call double @llvm.fmuladd.f64(double %1771, double %1773, double %1777)
4522  %1779 = load double, ptr %19, align 8
4523  %1780 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 1
4524  %1781 = load double, ptr %1780, align 8
4525  %1782 = call double @llvm.fmuladd.f64(double %1779, double %1781, double %1778)
4526  %1783 = load double, ptr %21, align 8
4527  %1784 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 1
4528  %1785 = load double, ptr %1784, align 8
4529  %1786 = call double @llvm.fmuladd.f64(double %1783, double %1785, double %1782)
4530  %1787 = load double, ptr %23, align 8
4531  %1788 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 1
4532  %1789 = load double, ptr %1788, align 8
4533  %1790 = call double @llvm.fmuladd.f64(double %1787, double %1789, double %1786)
4534  %1791 = fneg double %1790
4535  %1792 = getelementptr inbounds %struct.cmplx, ptr %59, i32 0, i32 0
4536  store double %1791, ptr %1792, align 8
4537  %1793 = getelementptr inbounds %struct.cmplx, ptr %58, i32 0, i32 0
4538  %1794 = load double, ptr %1793, align 8
4539  %1795 = getelementptr inbounds %struct.cmplx, ptr %59, i32 0, i32 0
4540  %1796 = load double, ptr %1795, align 8
4541  %1797 = fadd double %1794, %1796
4542  %1798 = getelementptr inbounds %struct.cmplx, ptr %56, i32 0, i32 0
4543  store double %1797, ptr %1798, align 8
4544  %1799 = getelementptr inbounds %struct.cmplx, ptr %58, i32 0, i32 1
4545  %1800 = load double, ptr %1799, align 8
4546  %1801 = getelementptr inbounds %struct.cmplx, ptr %59, i32 0, i32 1
4547  %1802 = load double, ptr %1801, align 8
4548  %1803 = fadd double %1800, %1802
4549  %1804 = getelementptr inbounds %struct.cmplx, ptr %56, i32 0, i32 1
4550  store double %1803, ptr %1804, align 8
4551  %1805 = getelementptr inbounds %struct.cmplx, ptr %58, i32 0, i32 0
4552  %1806 = load double, ptr %1805, align 8
4553  %1807 = getelementptr inbounds %struct.cmplx, ptr %59, i32 0, i32 0
4554  %1808 = load double, ptr %1807, align 8
4555  %1809 = fsub double %1806, %1808
4556  %1810 = getelementptr inbounds %struct.cmplx, ptr %57, i32 0, i32 0
4557  store double %1809, ptr %1810, align 8
4558  %1811 = getelementptr inbounds %struct.cmplx, ptr %58, i32 0, i32 1
4559  %1812 = load double, ptr %1811, align 8
4560  %1813 = getelementptr inbounds %struct.cmplx, ptr %59, i32 0, i32 1
4561  %1814 = load double, ptr %1813, align 8
4562  %1815 = fsub double %1812, %1814
4563  %1816 = getelementptr inbounds %struct.cmplx, ptr %57, i32 0, i32 1
4564  store double %1815, ptr %1816, align 8
4565  %1817 = load ptr, ptr %11, align 4
4566  %1818 = load i32, ptr %44, align 4
4567  %1819 = sub i32 %1818, 1
4568  %1820 = load i32, ptr %7, align 4
4569  %1821 = sub i32 %1820, 1
4570  %1822 = mul i32 0, %1821
4571  %1823 = add i32 %1819, %1822
4572  %1824 = getelementptr inbounds %struct.cmplx, ptr %1817, i32 %1823
4573  %1825 = getelementptr inbounds %struct.cmplx, ptr %1824, i32 0, i32 0
4574  %1826 = load double, ptr %1825, align 8
4575  %1827 = getelementptr inbounds %struct.cmplx, ptr %56, i32 0, i32 0
4576  %1828 = load double, ptr %1827, align 8
4577  %1829 = load i32, ptr %12, align 4
4578  %1830 = sitofp i32 %1829 to double
4579  %1831 = load ptr, ptr %11, align 4
4580  %1832 = load i32, ptr %44, align 4
4581  %1833 = sub i32 %1832, 1
4582  %1834 = load i32, ptr %7, align 4
4583  %1835 = sub i32 %1834, 1
4584  %1836 = mul i32 0, %1835
4585  %1837 = add i32 %1833, %1836
4586  %1838 = getelementptr inbounds %struct.cmplx, ptr %1831, i32 %1837
4587  %1839 = getelementptr inbounds %struct.cmplx, ptr %1838, i32 0, i32 1
4588  %1840 = load double, ptr %1839, align 8
4589  %1841 = fmul double %1830, %1840
4590  %1842 = getelementptr inbounds %struct.cmplx, ptr %56, i32 0, i32 1
4591  %1843 = load double, ptr %1842, align 8
4592  %1844 = fmul double %1841, %1843
4593  %1845 = fneg double %1844
4594  %1846 = call double @llvm.fmuladd.f64(double %1826, double %1828, double %1845)
4595  %1847 = load ptr, ptr %10, align 4
4596  %1848 = load i32, ptr %44, align 4
4597  %1849 = load i32, ptr %7, align 4
4598  %1850 = load i32, ptr %24, align 4
4599  %1851 = load i32, ptr %8, align 4
4600  %1852 = mul i32 %1851, 1
4601  %1853 = add i32 %1850, %1852
4602  %1854 = mul i32 %1849, %1853
4603  %1855 = add i32 %1848, %1854
4604  %1856 = getelementptr inbounds %struct.cmplx, ptr %1847, i32 %1855
4605  %1857 = getelementptr inbounds %struct.cmplx, ptr %1856, i32 0, i32 0
4606  store double %1846, ptr %1857, align 8
4607  %1858 = load ptr, ptr %11, align 4
4608  %1859 = load i32, ptr %44, align 4
4609  %1860 = sub i32 %1859, 1
4610  %1861 = load i32, ptr %7, align 4
4611  %1862 = sub i32 %1861, 1
4612  %1863 = mul i32 0, %1862
4613  %1864 = add i32 %1860, %1863
4614  %1865 = getelementptr inbounds %struct.cmplx, ptr %1858, i32 %1864
4615  %1866 = getelementptr inbounds %struct.cmplx, ptr %1865, i32 0, i32 0
4616  %1867 = load double, ptr %1866, align 8
4617  %1868 = getelementptr inbounds %struct.cmplx, ptr %56, i32 0, i32 1
4618  %1869 = load double, ptr %1868, align 8
4619  %1870 = load i32, ptr %12, align 4
4620  %1871 = sitofp i32 %1870 to double
4621  %1872 = load ptr, ptr %11, align 4
4622  %1873 = load i32, ptr %44, align 4
4623  %1874 = sub i32 %1873, 1
4624  %1875 = load i32, ptr %7, align 4
4625  %1876 = sub i32 %1875, 1
4626  %1877 = mul i32 0, %1876
4627  %1878 = add i32 %1874, %1877
4628  %1879 = getelementptr inbounds %struct.cmplx, ptr %1872, i32 %1878
4629  %1880 = getelementptr inbounds %struct.cmplx, ptr %1879, i32 0, i32 1
4630  %1881 = load double, ptr %1880, align 8
4631  %1882 = fmul double %1871, %1881
4632  %1883 = getelementptr inbounds %struct.cmplx, ptr %56, i32 0, i32 0
4633  %1884 = load double, ptr %1883, align 8
4634  %1885 = fmul double %1882, %1884
4635  %1886 = call double @llvm.fmuladd.f64(double %1867, double %1869, double %1885)
4636  %1887 = load ptr, ptr %10, align 4
4637  %1888 = load i32, ptr %44, align 4
4638  %1889 = load i32, ptr %7, align 4
4639  %1890 = load i32, ptr %24, align 4
4640  %1891 = load i32, ptr %8, align 4
4641  %1892 = mul i32 %1891, 1
4642  %1893 = add i32 %1890, %1892
4643  %1894 = mul i32 %1889, %1893
4644  %1895 = add i32 %1888, %1894
4645  %1896 = getelementptr inbounds %struct.cmplx, ptr %1887, i32 %1895
4646  %1897 = getelementptr inbounds %struct.cmplx, ptr %1896, i32 0, i32 1
4647  store double %1886, ptr %1897, align 8
4648  %1898 = load ptr, ptr %11, align 4
4649  %1899 = load i32, ptr %44, align 4
4650  %1900 = sub i32 %1899, 1
4651  %1901 = load i32, ptr %7, align 4
4652  %1902 = sub i32 %1901, 1
4653  %1903 = mul i32 9, %1902
4654  %1904 = add i32 %1900, %1903
4655  %1905 = getelementptr inbounds %struct.cmplx, ptr %1898, i32 %1904
4656  %1906 = getelementptr inbounds %struct.cmplx, ptr %1905, i32 0, i32 0
4657  %1907 = load double, ptr %1906, align 8
4658  %1908 = getelementptr inbounds %struct.cmplx, ptr %57, i32 0, i32 0
4659  %1909 = load double, ptr %1908, align 8
4660  %1910 = load i32, ptr %12, align 4
4661  %1911 = sitofp i32 %1910 to double
4662  %1912 = load ptr, ptr %11, align 4
4663  %1913 = load i32, ptr %44, align 4
4664  %1914 = sub i32 %1913, 1
4665  %1915 = load i32, ptr %7, align 4
4666  %1916 = sub i32 %1915, 1
4667  %1917 = mul i32 9, %1916
4668  %1918 = add i32 %1914, %1917
4669  %1919 = getelementptr inbounds %struct.cmplx, ptr %1912, i32 %1918
4670  %1920 = getelementptr inbounds %struct.cmplx, ptr %1919, i32 0, i32 1
4671  %1921 = load double, ptr %1920, align 8
4672  %1922 = fmul double %1911, %1921
4673  %1923 = getelementptr inbounds %struct.cmplx, ptr %57, i32 0, i32 1
4674  %1924 = load double, ptr %1923, align 8
4675  %1925 = fmul double %1922, %1924
4676  %1926 = fneg double %1925
4677  %1927 = call double @llvm.fmuladd.f64(double %1907, double %1909, double %1926)
4678  %1928 = load ptr, ptr %10, align 4
4679  %1929 = load i32, ptr %44, align 4
4680  %1930 = load i32, ptr %7, align 4
4681  %1931 = load i32, ptr %24, align 4
4682  %1932 = load i32, ptr %8, align 4
4683  %1933 = mul i32 %1932, 10
4684  %1934 = add i32 %1931, %1933
4685  %1935 = mul i32 %1930, %1934
4686  %1936 = add i32 %1929, %1935
4687  %1937 = getelementptr inbounds %struct.cmplx, ptr %1928, i32 %1936
4688  %1938 = getelementptr inbounds %struct.cmplx, ptr %1937, i32 0, i32 0
4689  store double %1927, ptr %1938, align 8
4690  %1939 = load ptr, ptr %11, align 4
4691  %1940 = load i32, ptr %44, align 4
4692  %1941 = sub i32 %1940, 1
4693  %1942 = load i32, ptr %7, align 4
4694  %1943 = sub i32 %1942, 1
4695  %1944 = mul i32 9, %1943
4696  %1945 = add i32 %1941, %1944
4697  %1946 = getelementptr inbounds %struct.cmplx, ptr %1939, i32 %1945
4698  %1947 = getelementptr inbounds %struct.cmplx, ptr %1946, i32 0, i32 0
4699  %1948 = load double, ptr %1947, align 8
4700  %1949 = getelementptr inbounds %struct.cmplx, ptr %57, i32 0, i32 1
4701  %1950 = load double, ptr %1949, align 8
4702  %1951 = load i32, ptr %12, align 4
4703  %1952 = sitofp i32 %1951 to double
4704  %1953 = load ptr, ptr %11, align 4
4705  %1954 = load i32, ptr %44, align 4
4706  %1955 = sub i32 %1954, 1
4707  %1956 = load i32, ptr %7, align 4
4708  %1957 = sub i32 %1956, 1
4709  %1958 = mul i32 9, %1957
4710  %1959 = add i32 %1955, %1958
4711  %1960 = getelementptr inbounds %struct.cmplx, ptr %1953, i32 %1959
4712  %1961 = getelementptr inbounds %struct.cmplx, ptr %1960, i32 0, i32 1
4713  %1962 = load double, ptr %1961, align 8
4714  %1963 = fmul double %1952, %1962
4715  %1964 = getelementptr inbounds %struct.cmplx, ptr %57, i32 0, i32 0
4716  %1965 = load double, ptr %1964, align 8
4717  %1966 = fmul double %1963, %1965
4718  %1967 = call double @llvm.fmuladd.f64(double %1948, double %1950, double %1966)
4719  %1968 = load ptr, ptr %10, align 4
4720  %1969 = load i32, ptr %44, align 4
4721  %1970 = load i32, ptr %7, align 4
4722  %1971 = load i32, ptr %24, align 4
4723  %1972 = load i32, ptr %8, align 4
4724  %1973 = mul i32 %1972, 10
4725  %1974 = add i32 %1971, %1973
4726  %1975 = mul i32 %1970, %1974
4727  %1976 = add i32 %1969, %1975
4728  %1977 = getelementptr inbounds %struct.cmplx, ptr %1968, i32 %1976
4729  %1978 = getelementptr inbounds %struct.cmplx, ptr %1977, i32 0, i32 1
4730  store double %1967, ptr %1978, align 8
4731  %1979 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 0
4732  %1980 = load double, ptr %1979, align 8
4733  %1981 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 0
4734  %1982 = load double, ptr %1981, align 8
4735  %1983 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %1982, double %1980)
4736  %1984 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 0
4737  %1985 = load double, ptr %1984, align 8
4738  %1986 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %1985, double %1983)
4739  %1987 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 0
4740  %1988 = load double, ptr %1987, align 8
4741  %1989 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %1988, double %1986)
4742  %1990 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 0
4743  %1991 = load double, ptr %1990, align 8
4744  %1992 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %1991, double %1989)
4745  %1993 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 0
4746  %1994 = load double, ptr %1993, align 8
4747  %1995 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %1994, double %1992)
4748  %1996 = getelementptr inbounds %struct.cmplx, ptr %62, i32 0, i32 0
4749  store double %1995, ptr %1996, align 8
4750  %1997 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 1
4751  %1998 = load double, ptr %1997, align 8
4752  %1999 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 1
4753  %2000 = load double, ptr %1999, align 8
4754  %2001 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %2000, double %1998)
4755  %2002 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 1
4756  %2003 = load double, ptr %2002, align 8
4757  %2004 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %2003, double %2001)
4758  %2005 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 1
4759  %2006 = load double, ptr %2005, align 8
4760  %2007 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %2006, double %2004)
4761  %2008 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 1
4762  %2009 = load double, ptr %2008, align 8
4763  %2010 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %2009, double %2007)
4764  %2011 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 1
4765  %2012 = load double, ptr %2011, align 8
4766  %2013 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %2012, double %2010)
4767  %2014 = getelementptr inbounds %struct.cmplx, ptr %62, i32 0, i32 1
4768  store double %2013, ptr %2014, align 8
4769  %2015 = load double, ptr %17, align 8
4770  %2016 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 0
4771  %2017 = load double, ptr %2016, align 8
4772  %2018 = load double, ptr %21, align 8
4773  %2019 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 0
4774  %2020 = load double, ptr %2019, align 8
4775  %2021 = fmul double %2018, %2020
4776  %2022 = call double @llvm.fmuladd.f64(double %2015, double %2017, double %2021)
4777  %2023 = load double, ptr %23, align 8
4778  %2024 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 0
4779  %2025 = load double, ptr %2024, align 8
4780  %2026 = fneg double %2023
4781  %2027 = call double @llvm.fmuladd.f64(double %2026, double %2025, double %2022)
4782  %2028 = load double, ptr %19, align 8
4783  %2029 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 0
4784  %2030 = load double, ptr %2029, align 8
4785  %2031 = fneg double %2028
4786  %2032 = call double @llvm.fmuladd.f64(double %2031, double %2030, double %2027)
4787  %2033 = load double, ptr %15, align 8
4788  %2034 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 0
4789  %2035 = load double, ptr %2034, align 8
4790  %2036 = fneg double %2033
4791  %2037 = call double @llvm.fmuladd.f64(double %2036, double %2035, double %2032)
4792  %2038 = getelementptr inbounds %struct.cmplx, ptr %63, i32 0, i32 1
4793  store double %2037, ptr %2038, align 8
4794  %2039 = load double, ptr %17, align 8
4795  %2040 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 1
4796  %2041 = load double, ptr %2040, align 8
4797  %2042 = load double, ptr %21, align 8
4798  %2043 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 1
4799  %2044 = load double, ptr %2043, align 8
4800  %2045 = fmul double %2042, %2044
4801  %2046 = call double @llvm.fmuladd.f64(double %2039, double %2041, double %2045)
4802  %2047 = load double, ptr %23, align 8
4803  %2048 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 1
4804  %2049 = load double, ptr %2048, align 8
4805  %2050 = fneg double %2047
4806  %2051 = call double @llvm.fmuladd.f64(double %2050, double %2049, double %2046)
4807  %2052 = load double, ptr %19, align 8
4808  %2053 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 1
4809  %2054 = load double, ptr %2053, align 8
4810  %2055 = fneg double %2052
4811  %2056 = call double @llvm.fmuladd.f64(double %2055, double %2054, double %2051)
4812  %2057 = load double, ptr %15, align 8
4813  %2058 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 1
4814  %2059 = load double, ptr %2058, align 8
4815  %2060 = fneg double %2057
4816  %2061 = call double @llvm.fmuladd.f64(double %2060, double %2059, double %2056)
4817  %2062 = fneg double %2061
4818  %2063 = getelementptr inbounds %struct.cmplx, ptr %63, i32 0, i32 0
4819  store double %2062, ptr %2063, align 8
4820  %2064 = getelementptr inbounds %struct.cmplx, ptr %62, i32 0, i32 0
4821  %2065 = load double, ptr %2064, align 8
4822  %2066 = getelementptr inbounds %struct.cmplx, ptr %63, i32 0, i32 0
4823  %2067 = load double, ptr %2066, align 8
4824  %2068 = fadd double %2065, %2067
4825  %2069 = getelementptr inbounds %struct.cmplx, ptr %60, i32 0, i32 0
4826  store double %2068, ptr %2069, align 8
4827  %2070 = getelementptr inbounds %struct.cmplx, ptr %62, i32 0, i32 1
4828  %2071 = load double, ptr %2070, align 8
4829  %2072 = getelementptr inbounds %struct.cmplx, ptr %63, i32 0, i32 1
4830  %2073 = load double, ptr %2072, align 8
4831  %2074 = fadd double %2071, %2073
4832  %2075 = getelementptr inbounds %struct.cmplx, ptr %60, i32 0, i32 1
4833  store double %2074, ptr %2075, align 8
4834  %2076 = getelementptr inbounds %struct.cmplx, ptr %62, i32 0, i32 0
4835  %2077 = load double, ptr %2076, align 8
4836  %2078 = getelementptr inbounds %struct.cmplx, ptr %63, i32 0, i32 0
4837  %2079 = load double, ptr %2078, align 8
4838  %2080 = fsub double %2077, %2079
4839  %2081 = getelementptr inbounds %struct.cmplx, ptr %61, i32 0, i32 0
4840  store double %2080, ptr %2081, align 8
4841  %2082 = getelementptr inbounds %struct.cmplx, ptr %62, i32 0, i32 1
4842  %2083 = load double, ptr %2082, align 8
4843  %2084 = getelementptr inbounds %struct.cmplx, ptr %63, i32 0, i32 1
4844  %2085 = load double, ptr %2084, align 8
4845  %2086 = fsub double %2083, %2085
4846  %2087 = getelementptr inbounds %struct.cmplx, ptr %61, i32 0, i32 1
4847  store double %2086, ptr %2087, align 8
4848  %2088 = load ptr, ptr %11, align 4
4849  %2089 = load i32, ptr %44, align 4
4850  %2090 = sub i32 %2089, 1
4851  %2091 = load i32, ptr %7, align 4
4852  %2092 = sub i32 %2091, 1
4853  %2093 = mul i32 1, %2092
4854  %2094 = add i32 %2090, %2093
4855  %2095 = getelementptr inbounds %struct.cmplx, ptr %2088, i32 %2094
4856  %2096 = getelementptr inbounds %struct.cmplx, ptr %2095, i32 0, i32 0
4857  %2097 = load double, ptr %2096, align 8
4858  %2098 = getelementptr inbounds %struct.cmplx, ptr %60, i32 0, i32 0
4859  %2099 = load double, ptr %2098, align 8
4860  %2100 = load i32, ptr %12, align 4
4861  %2101 = sitofp i32 %2100 to double
4862  %2102 = load ptr, ptr %11, align 4
4863  %2103 = load i32, ptr %44, align 4
4864  %2104 = sub i32 %2103, 1
4865  %2105 = load i32, ptr %7, align 4
4866  %2106 = sub i32 %2105, 1
4867  %2107 = mul i32 1, %2106
4868  %2108 = add i32 %2104, %2107
4869  %2109 = getelementptr inbounds %struct.cmplx, ptr %2102, i32 %2108
4870  %2110 = getelementptr inbounds %struct.cmplx, ptr %2109, i32 0, i32 1
4871  %2111 = load double, ptr %2110, align 8
4872  %2112 = fmul double %2101, %2111
4873  %2113 = getelementptr inbounds %struct.cmplx, ptr %60, i32 0, i32 1
4874  %2114 = load double, ptr %2113, align 8
4875  %2115 = fmul double %2112, %2114
4876  %2116 = fneg double %2115
4877  %2117 = call double @llvm.fmuladd.f64(double %2097, double %2099, double %2116)
4878  %2118 = load ptr, ptr %10, align 4
4879  %2119 = load i32, ptr %44, align 4
4880  %2120 = load i32, ptr %7, align 4
4881  %2121 = load i32, ptr %24, align 4
4882  %2122 = load i32, ptr %8, align 4
4883  %2123 = mul i32 %2122, 2
4884  %2124 = add i32 %2121, %2123
4885  %2125 = mul i32 %2120, %2124
4886  %2126 = add i32 %2119, %2125
4887  %2127 = getelementptr inbounds %struct.cmplx, ptr %2118, i32 %2126
4888  %2128 = getelementptr inbounds %struct.cmplx, ptr %2127, i32 0, i32 0
4889  store double %2117, ptr %2128, align 8
4890  %2129 = load ptr, ptr %11, align 4
4891  %2130 = load i32, ptr %44, align 4
4892  %2131 = sub i32 %2130, 1
4893  %2132 = load i32, ptr %7, align 4
4894  %2133 = sub i32 %2132, 1
4895  %2134 = mul i32 1, %2133
4896  %2135 = add i32 %2131, %2134
4897  %2136 = getelementptr inbounds %struct.cmplx, ptr %2129, i32 %2135
4898  %2137 = getelementptr inbounds %struct.cmplx, ptr %2136, i32 0, i32 0
4899  %2138 = load double, ptr %2137, align 8
4900  %2139 = getelementptr inbounds %struct.cmplx, ptr %60, i32 0, i32 1
4901  %2140 = load double, ptr %2139, align 8
4902  %2141 = load i32, ptr %12, align 4
4903  %2142 = sitofp i32 %2141 to double
4904  %2143 = load ptr, ptr %11, align 4
4905  %2144 = load i32, ptr %44, align 4
4906  %2145 = sub i32 %2144, 1
4907  %2146 = load i32, ptr %7, align 4
4908  %2147 = sub i32 %2146, 1
4909  %2148 = mul i32 1, %2147
4910  %2149 = add i32 %2145, %2148
4911  %2150 = getelementptr inbounds %struct.cmplx, ptr %2143, i32 %2149
4912  %2151 = getelementptr inbounds %struct.cmplx, ptr %2150, i32 0, i32 1
4913  %2152 = load double, ptr %2151, align 8
4914  %2153 = fmul double %2142, %2152
4915  %2154 = getelementptr inbounds %struct.cmplx, ptr %60, i32 0, i32 0
4916  %2155 = load double, ptr %2154, align 8
4917  %2156 = fmul double %2153, %2155
4918  %2157 = call double @llvm.fmuladd.f64(double %2138, double %2140, double %2156)
4919  %2158 = load ptr, ptr %10, align 4
4920  %2159 = load i32, ptr %44, align 4
4921  %2160 = load i32, ptr %7, align 4
4922  %2161 = load i32, ptr %24, align 4
4923  %2162 = load i32, ptr %8, align 4
4924  %2163 = mul i32 %2162, 2
4925  %2164 = add i32 %2161, %2163
4926  %2165 = mul i32 %2160, %2164
4927  %2166 = add i32 %2159, %2165
4928  %2167 = getelementptr inbounds %struct.cmplx, ptr %2158, i32 %2166
4929  %2168 = getelementptr inbounds %struct.cmplx, ptr %2167, i32 0, i32 1
4930  store double %2157, ptr %2168, align 8
4931  %2169 = load ptr, ptr %11, align 4
4932  %2170 = load i32, ptr %44, align 4
4933  %2171 = sub i32 %2170, 1
4934  %2172 = load i32, ptr %7, align 4
4935  %2173 = sub i32 %2172, 1
4936  %2174 = mul i32 8, %2173
4937  %2175 = add i32 %2171, %2174
4938  %2176 = getelementptr inbounds %struct.cmplx, ptr %2169, i32 %2175
4939  %2177 = getelementptr inbounds %struct.cmplx, ptr %2176, i32 0, i32 0
4940  %2178 = load double, ptr %2177, align 8
4941  %2179 = getelementptr inbounds %struct.cmplx, ptr %61, i32 0, i32 0
4942  %2180 = load double, ptr %2179, align 8
4943  %2181 = load i32, ptr %12, align 4
4944  %2182 = sitofp i32 %2181 to double
4945  %2183 = load ptr, ptr %11, align 4
4946  %2184 = load i32, ptr %44, align 4
4947  %2185 = sub i32 %2184, 1
4948  %2186 = load i32, ptr %7, align 4
4949  %2187 = sub i32 %2186, 1
4950  %2188 = mul i32 8, %2187
4951  %2189 = add i32 %2185, %2188
4952  %2190 = getelementptr inbounds %struct.cmplx, ptr %2183, i32 %2189
4953  %2191 = getelementptr inbounds %struct.cmplx, ptr %2190, i32 0, i32 1
4954  %2192 = load double, ptr %2191, align 8
4955  %2193 = fmul double %2182, %2192
4956  %2194 = getelementptr inbounds %struct.cmplx, ptr %61, i32 0, i32 1
4957  %2195 = load double, ptr %2194, align 8
4958  %2196 = fmul double %2193, %2195
4959  %2197 = fneg double %2196
4960  %2198 = call double @llvm.fmuladd.f64(double %2178, double %2180, double %2197)
4961  %2199 = load ptr, ptr %10, align 4
4962  %2200 = load i32, ptr %44, align 4
4963  %2201 = load i32, ptr %7, align 4
4964  %2202 = load i32, ptr %24, align 4
4965  %2203 = load i32, ptr %8, align 4
4966  %2204 = mul i32 %2203, 9
4967  %2205 = add i32 %2202, %2204
4968  %2206 = mul i32 %2201, %2205
4969  %2207 = add i32 %2200, %2206
4970  %2208 = getelementptr inbounds %struct.cmplx, ptr %2199, i32 %2207
4971  %2209 = getelementptr inbounds %struct.cmplx, ptr %2208, i32 0, i32 0
4972  store double %2198, ptr %2209, align 8
4973  %2210 = load ptr, ptr %11, align 4
4974  %2211 = load i32, ptr %44, align 4
4975  %2212 = sub i32 %2211, 1
4976  %2213 = load i32, ptr %7, align 4
4977  %2214 = sub i32 %2213, 1
4978  %2215 = mul i32 8, %2214
4979  %2216 = add i32 %2212, %2215
4980  %2217 = getelementptr inbounds %struct.cmplx, ptr %2210, i32 %2216
4981  %2218 = getelementptr inbounds %struct.cmplx, ptr %2217, i32 0, i32 0
4982  %2219 = load double, ptr %2218, align 8
4983  %2220 = getelementptr inbounds %struct.cmplx, ptr %61, i32 0, i32 1
4984  %2221 = load double, ptr %2220, align 8
4985  %2222 = load i32, ptr %12, align 4
4986  %2223 = sitofp i32 %2222 to double
4987  %2224 = load ptr, ptr %11, align 4
4988  %2225 = load i32, ptr %44, align 4
4989  %2226 = sub i32 %2225, 1
4990  %2227 = load i32, ptr %7, align 4
4991  %2228 = sub i32 %2227, 1
4992  %2229 = mul i32 8, %2228
4993  %2230 = add i32 %2226, %2229
4994  %2231 = getelementptr inbounds %struct.cmplx, ptr %2224, i32 %2230
4995  %2232 = getelementptr inbounds %struct.cmplx, ptr %2231, i32 0, i32 1
4996  %2233 = load double, ptr %2232, align 8
4997  %2234 = fmul double %2223, %2233
4998  %2235 = getelementptr inbounds %struct.cmplx, ptr %61, i32 0, i32 0
4999  %2236 = load double, ptr %2235, align 8
5000  %2237 = fmul double %2234, %2236
5001  %2238 = call double @llvm.fmuladd.f64(double %2219, double %2221, double %2237)
5002  %2239 = load ptr, ptr %10, align 4
5003  %2240 = load i32, ptr %44, align 4
5004  %2241 = load i32, ptr %7, align 4
5005  %2242 = load i32, ptr %24, align 4
5006  %2243 = load i32, ptr %8, align 4
5007  %2244 = mul i32 %2243, 9
5008  %2245 = add i32 %2242, %2244
5009  %2246 = mul i32 %2241, %2245
5010  %2247 = add i32 %2240, %2246
5011  %2248 = getelementptr inbounds %struct.cmplx, ptr %2239, i32 %2247
5012  %2249 = getelementptr inbounds %struct.cmplx, ptr %2248, i32 0, i32 1
5013  store double %2238, ptr %2249, align 8
5014  %2250 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 0
5015  %2251 = load double, ptr %2250, align 8
5016  %2252 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 0
5017  %2253 = load double, ptr %2252, align 8
5018  %2254 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %2253, double %2251)
5019  %2255 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 0
5020  %2256 = load double, ptr %2255, align 8
5021  %2257 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %2256, double %2254)
5022  %2258 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 0
5023  %2259 = load double, ptr %2258, align 8
5024  %2260 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %2259, double %2257)
5025  %2261 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 0
5026  %2262 = load double, ptr %2261, align 8
5027  %2263 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %2262, double %2260)
5028  %2264 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 0
5029  %2265 = load double, ptr %2264, align 8
5030  %2266 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %2265, double %2263)
5031  %2267 = getelementptr inbounds %struct.cmplx, ptr %66, i32 0, i32 0
5032  store double %2266, ptr %2267, align 8
5033  %2268 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 1
5034  %2269 = load double, ptr %2268, align 8
5035  %2270 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 1
5036  %2271 = load double, ptr %2270, align 8
5037  %2272 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %2271, double %2269)
5038  %2273 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 1
5039  %2274 = load double, ptr %2273, align 8
5040  %2275 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %2274, double %2272)
5041  %2276 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 1
5042  %2277 = load double, ptr %2276, align 8
5043  %2278 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %2277, double %2275)
5044  %2279 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 1
5045  %2280 = load double, ptr %2279, align 8
5046  %2281 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %2280, double %2278)
5047  %2282 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 1
5048  %2283 = load double, ptr %2282, align 8
5049  %2284 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %2283, double %2281)
5050  %2285 = getelementptr inbounds %struct.cmplx, ptr %66, i32 0, i32 1
5051  store double %2284, ptr %2285, align 8
5052  %2286 = load double, ptr %19, align 8
5053  %2287 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 0
5054  %2288 = load double, ptr %2287, align 8
5055  %2289 = load double, ptr %23, align 8
5056  %2290 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 0
5057  %2291 = load double, ptr %2290, align 8
5058  %2292 = fmul double %2289, %2291
5059  %2293 = fneg double %2292
5060  %2294 = call double @llvm.fmuladd.f64(double %2286, double %2288, double %2293)
5061  %2295 = load double, ptr %17, align 8
5062  %2296 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 0
5063  %2297 = load double, ptr %2296, align 8
5064  %2298 = fneg double %2295
5065  %2299 = call double @llvm.fmuladd.f64(double %2298, double %2297, double %2294)
5066  %2300 = load double, ptr %15, align 8
5067  %2301 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 0
5068  %2302 = load double, ptr %2301, align 8
5069  %2303 = call double @llvm.fmuladd.f64(double %2300, double %2302, double %2299)
5070  %2304 = load double, ptr %21, align 8
5071  %2305 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 0
5072  %2306 = load double, ptr %2305, align 8
5073  %2307 = call double @llvm.fmuladd.f64(double %2304, double %2306, double %2303)
5074  %2308 = getelementptr inbounds %struct.cmplx, ptr %67, i32 0, i32 1
5075  store double %2307, ptr %2308, align 8
5076  %2309 = load double, ptr %19, align 8
5077  %2310 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 1
5078  %2311 = load double, ptr %2310, align 8
5079  %2312 = load double, ptr %23, align 8
5080  %2313 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 1
5081  %2314 = load double, ptr %2313, align 8
5082  %2315 = fmul double %2312, %2314
5083  %2316 = fneg double %2315
5084  %2317 = call double @llvm.fmuladd.f64(double %2309, double %2311, double %2316)
5085  %2318 = load double, ptr %17, align 8
5086  %2319 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 1
5087  %2320 = load double, ptr %2319, align 8
5088  %2321 = fneg double %2318
5089  %2322 = call double @llvm.fmuladd.f64(double %2321, double %2320, double %2317)
5090  %2323 = load double, ptr %15, align 8
5091  %2324 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 1
5092  %2325 = load double, ptr %2324, align 8
5093  %2326 = call double @llvm.fmuladd.f64(double %2323, double %2325, double %2322)
5094  %2327 = load double, ptr %21, align 8
5095  %2328 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 1
5096  %2329 = load double, ptr %2328, align 8
5097  %2330 = call double @llvm.fmuladd.f64(double %2327, double %2329, double %2326)
5098  %2331 = fneg double %2330
5099  %2332 = getelementptr inbounds %struct.cmplx, ptr %67, i32 0, i32 0
5100  store double %2331, ptr %2332, align 8
5101  %2333 = getelementptr inbounds %struct.cmplx, ptr %66, i32 0, i32 0
5102  %2334 = load double, ptr %2333, align 8
5103  %2335 = getelementptr inbounds %struct.cmplx, ptr %67, i32 0, i32 0
5104  %2336 = load double, ptr %2335, align 8
5105  %2337 = fadd double %2334, %2336
5106  %2338 = getelementptr inbounds %struct.cmplx, ptr %64, i32 0, i32 0
5107  store double %2337, ptr %2338, align 8
5108  %2339 = getelementptr inbounds %struct.cmplx, ptr %66, i32 0, i32 1
5109  %2340 = load double, ptr %2339, align 8
5110  %2341 = getelementptr inbounds %struct.cmplx, ptr %67, i32 0, i32 1
5111  %2342 = load double, ptr %2341, align 8
5112  %2343 = fadd double %2340, %2342
5113  %2344 = getelementptr inbounds %struct.cmplx, ptr %64, i32 0, i32 1
5114  store double %2343, ptr %2344, align 8
5115  %2345 = getelementptr inbounds %struct.cmplx, ptr %66, i32 0, i32 0
5116  %2346 = load double, ptr %2345, align 8
5117  %2347 = getelementptr inbounds %struct.cmplx, ptr %67, i32 0, i32 0
5118  %2348 = load double, ptr %2347, align 8
5119  %2349 = fsub double %2346, %2348
5120  %2350 = getelementptr inbounds %struct.cmplx, ptr %65, i32 0, i32 0
5121  store double %2349, ptr %2350, align 8
5122  %2351 = getelementptr inbounds %struct.cmplx, ptr %66, i32 0, i32 1
5123  %2352 = load double, ptr %2351, align 8
5124  %2353 = getelementptr inbounds %struct.cmplx, ptr %67, i32 0, i32 1
5125  %2354 = load double, ptr %2353, align 8
5126  %2355 = fsub double %2352, %2354
5127  %2356 = getelementptr inbounds %struct.cmplx, ptr %65, i32 0, i32 1
5128  store double %2355, ptr %2356, align 8
5129  %2357 = load ptr, ptr %11, align 4
5130  %2358 = load i32, ptr %44, align 4
5131  %2359 = sub i32 %2358, 1
5132  %2360 = load i32, ptr %7, align 4
5133  %2361 = sub i32 %2360, 1
5134  %2362 = mul i32 2, %2361
5135  %2363 = add i32 %2359, %2362
5136  %2364 = getelementptr inbounds %struct.cmplx, ptr %2357, i32 %2363
5137  %2365 = getelementptr inbounds %struct.cmplx, ptr %2364, i32 0, i32 0
5138  %2366 = load double, ptr %2365, align 8
5139  %2367 = getelementptr inbounds %struct.cmplx, ptr %64, i32 0, i32 0
5140  %2368 = load double, ptr %2367, align 8
5141  %2369 = load i32, ptr %12, align 4
5142  %2370 = sitofp i32 %2369 to double
5143  %2371 = load ptr, ptr %11, align 4
5144  %2372 = load i32, ptr %44, align 4
5145  %2373 = sub i32 %2372, 1
5146  %2374 = load i32, ptr %7, align 4
5147  %2375 = sub i32 %2374, 1
5148  %2376 = mul i32 2, %2375
5149  %2377 = add i32 %2373, %2376
5150  %2378 = getelementptr inbounds %struct.cmplx, ptr %2371, i32 %2377
5151  %2379 = getelementptr inbounds %struct.cmplx, ptr %2378, i32 0, i32 1
5152  %2380 = load double, ptr %2379, align 8
5153  %2381 = fmul double %2370, %2380
5154  %2382 = getelementptr inbounds %struct.cmplx, ptr %64, i32 0, i32 1
5155  %2383 = load double, ptr %2382, align 8
5156  %2384 = fmul double %2381, %2383
5157  %2385 = fneg double %2384
5158  %2386 = call double @llvm.fmuladd.f64(double %2366, double %2368, double %2385)
5159  %2387 = load ptr, ptr %10, align 4
5160  %2388 = load i32, ptr %44, align 4
5161  %2389 = load i32, ptr %7, align 4
5162  %2390 = load i32, ptr %24, align 4
5163  %2391 = load i32, ptr %8, align 4
5164  %2392 = mul i32 %2391, 3
5165  %2393 = add i32 %2390, %2392
5166  %2394 = mul i32 %2389, %2393
5167  %2395 = add i32 %2388, %2394
5168  %2396 = getelementptr inbounds %struct.cmplx, ptr %2387, i32 %2395
5169  %2397 = getelementptr inbounds %struct.cmplx, ptr %2396, i32 0, i32 0
5170  store double %2386, ptr %2397, align 8
5171  %2398 = load ptr, ptr %11, align 4
5172  %2399 = load i32, ptr %44, align 4
5173  %2400 = sub i32 %2399, 1
5174  %2401 = load i32, ptr %7, align 4
5175  %2402 = sub i32 %2401, 1
5176  %2403 = mul i32 2, %2402
5177  %2404 = add i32 %2400, %2403
5178  %2405 = getelementptr inbounds %struct.cmplx, ptr %2398, i32 %2404
5179  %2406 = getelementptr inbounds %struct.cmplx, ptr %2405, i32 0, i32 0
5180  %2407 = load double, ptr %2406, align 8
5181  %2408 = getelementptr inbounds %struct.cmplx, ptr %64, i32 0, i32 1
5182  %2409 = load double, ptr %2408, align 8
5183  %2410 = load i32, ptr %12, align 4
5184  %2411 = sitofp i32 %2410 to double
5185  %2412 = load ptr, ptr %11, align 4
5186  %2413 = load i32, ptr %44, align 4
5187  %2414 = sub i32 %2413, 1
5188  %2415 = load i32, ptr %7, align 4
5189  %2416 = sub i32 %2415, 1
5190  %2417 = mul i32 2, %2416
5191  %2418 = add i32 %2414, %2417
5192  %2419 = getelementptr inbounds %struct.cmplx, ptr %2412, i32 %2418
5193  %2420 = getelementptr inbounds %struct.cmplx, ptr %2419, i32 0, i32 1
5194  %2421 = load double, ptr %2420, align 8
5195  %2422 = fmul double %2411, %2421
5196  %2423 = getelementptr inbounds %struct.cmplx, ptr %64, i32 0, i32 0
5197  %2424 = load double, ptr %2423, align 8
5198  %2425 = fmul double %2422, %2424
5199  %2426 = call double @llvm.fmuladd.f64(double %2407, double %2409, double %2425)
5200  %2427 = load ptr, ptr %10, align 4
5201  %2428 = load i32, ptr %44, align 4
5202  %2429 = load i32, ptr %7, align 4
5203  %2430 = load i32, ptr %24, align 4
5204  %2431 = load i32, ptr %8, align 4
5205  %2432 = mul i32 %2431, 3
5206  %2433 = add i32 %2430, %2432
5207  %2434 = mul i32 %2429, %2433
5208  %2435 = add i32 %2428, %2434
5209  %2436 = getelementptr inbounds %struct.cmplx, ptr %2427, i32 %2435
5210  %2437 = getelementptr inbounds %struct.cmplx, ptr %2436, i32 0, i32 1
5211  store double %2426, ptr %2437, align 8
5212  %2438 = load ptr, ptr %11, align 4
5213  %2439 = load i32, ptr %44, align 4
5214  %2440 = sub i32 %2439, 1
5215  %2441 = load i32, ptr %7, align 4
5216  %2442 = sub i32 %2441, 1
5217  %2443 = mul i32 7, %2442
5218  %2444 = add i32 %2440, %2443
5219  %2445 = getelementptr inbounds %struct.cmplx, ptr %2438, i32 %2444
5220  %2446 = getelementptr inbounds %struct.cmplx, ptr %2445, i32 0, i32 0
5221  %2447 = load double, ptr %2446, align 8
5222  %2448 = getelementptr inbounds %struct.cmplx, ptr %65, i32 0, i32 0
5223  %2449 = load double, ptr %2448, align 8
5224  %2450 = load i32, ptr %12, align 4
5225  %2451 = sitofp i32 %2450 to double
5226  %2452 = load ptr, ptr %11, align 4
5227  %2453 = load i32, ptr %44, align 4
5228  %2454 = sub i32 %2453, 1
5229  %2455 = load i32, ptr %7, align 4
5230  %2456 = sub i32 %2455, 1
5231  %2457 = mul i32 7, %2456
5232  %2458 = add i32 %2454, %2457
5233  %2459 = getelementptr inbounds %struct.cmplx, ptr %2452, i32 %2458
5234  %2460 = getelementptr inbounds %struct.cmplx, ptr %2459, i32 0, i32 1
5235  %2461 = load double, ptr %2460, align 8
5236  %2462 = fmul double %2451, %2461
5237  %2463 = getelementptr inbounds %struct.cmplx, ptr %65, i32 0, i32 1
5238  %2464 = load double, ptr %2463, align 8
5239  %2465 = fmul double %2462, %2464
5240  %2466 = fneg double %2465
5241  %2467 = call double @llvm.fmuladd.f64(double %2447, double %2449, double %2466)
5242  %2468 = load ptr, ptr %10, align 4
5243  %2469 = load i32, ptr %44, align 4
5244  %2470 = load i32, ptr %7, align 4
5245  %2471 = load i32, ptr %24, align 4
5246  %2472 = load i32, ptr %8, align 4
5247  %2473 = mul i32 %2472, 8
5248  %2474 = add i32 %2471, %2473
5249  %2475 = mul i32 %2470, %2474
5250  %2476 = add i32 %2469, %2475
5251  %2477 = getelementptr inbounds %struct.cmplx, ptr %2468, i32 %2476
5252  %2478 = getelementptr inbounds %struct.cmplx, ptr %2477, i32 0, i32 0
5253  store double %2467, ptr %2478, align 8
5254  %2479 = load ptr, ptr %11, align 4
5255  %2480 = load i32, ptr %44, align 4
5256  %2481 = sub i32 %2480, 1
5257  %2482 = load i32, ptr %7, align 4
5258  %2483 = sub i32 %2482, 1
5259  %2484 = mul i32 7, %2483
5260  %2485 = add i32 %2481, %2484
5261  %2486 = getelementptr inbounds %struct.cmplx, ptr %2479, i32 %2485
5262  %2487 = getelementptr inbounds %struct.cmplx, ptr %2486, i32 0, i32 0
5263  %2488 = load double, ptr %2487, align 8
5264  %2489 = getelementptr inbounds %struct.cmplx, ptr %65, i32 0, i32 1
5265  %2490 = load double, ptr %2489, align 8
5266  %2491 = load i32, ptr %12, align 4
5267  %2492 = sitofp i32 %2491 to double
5268  %2493 = load ptr, ptr %11, align 4
5269  %2494 = load i32, ptr %44, align 4
5270  %2495 = sub i32 %2494, 1
5271  %2496 = load i32, ptr %7, align 4
5272  %2497 = sub i32 %2496, 1
5273  %2498 = mul i32 7, %2497
5274  %2499 = add i32 %2495, %2498
5275  %2500 = getelementptr inbounds %struct.cmplx, ptr %2493, i32 %2499
5276  %2501 = getelementptr inbounds %struct.cmplx, ptr %2500, i32 0, i32 1
5277  %2502 = load double, ptr %2501, align 8
5278  %2503 = fmul double %2492, %2502
5279  %2504 = getelementptr inbounds %struct.cmplx, ptr %65, i32 0, i32 0
5280  %2505 = load double, ptr %2504, align 8
5281  %2506 = fmul double %2503, %2505
5282  %2507 = call double @llvm.fmuladd.f64(double %2488, double %2490, double %2506)
5283  %2508 = load ptr, ptr %10, align 4
5284  %2509 = load i32, ptr %44, align 4
5285  %2510 = load i32, ptr %7, align 4
5286  %2511 = load i32, ptr %24, align 4
5287  %2512 = load i32, ptr %8, align 4
5288  %2513 = mul i32 %2512, 8
5289  %2514 = add i32 %2511, %2513
5290  %2515 = mul i32 %2510, %2514
5291  %2516 = add i32 %2509, %2515
5292  %2517 = getelementptr inbounds %struct.cmplx, ptr %2508, i32 %2516
5293  %2518 = getelementptr inbounds %struct.cmplx, ptr %2517, i32 0, i32 1
5294  store double %2507, ptr %2518, align 8
5295  %2519 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 0
5296  %2520 = load double, ptr %2519, align 8
5297  %2521 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 0
5298  %2522 = load double, ptr %2521, align 8
5299  %2523 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %2522, double %2520)
5300  %2524 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 0
5301  %2525 = load double, ptr %2524, align 8
5302  %2526 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %2525, double %2523)
5303  %2527 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 0
5304  %2528 = load double, ptr %2527, align 8
5305  %2529 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %2528, double %2526)
5306  %2530 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 0
5307  %2531 = load double, ptr %2530, align 8
5308  %2532 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %2531, double %2529)
5309  %2533 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 0
5310  %2534 = load double, ptr %2533, align 8
5311  %2535 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %2534, double %2532)
5312  %2536 = getelementptr inbounds %struct.cmplx, ptr %70, i32 0, i32 0
5313  store double %2535, ptr %2536, align 8
5314  %2537 = getelementptr inbounds %struct.cmplx, ptr %45, i32 0, i32 1
5315  %2538 = load double, ptr %2537, align 8
5316  %2539 = getelementptr inbounds %struct.cmplx, ptr %46, i32 0, i32 1
5317  %2540 = load double, ptr %2539, align 8
5318  %2541 = call double @llvm.fmuladd.f64(double 0xBFE4F49E7F775887, double %2540, double %2538)
5319  %2542 = getelementptr inbounds %struct.cmplx, ptr %47, i32 0, i32 1
5320  %2543 = load double, ptr %2542, align 8
5321  %2544 = call double @llvm.fmuladd.f64(double 0xBFC2375F640F44DB, double %2543, double %2541)
5322  %2545 = getelementptr inbounds %struct.cmplx, ptr %48, i32 0, i32 1
5323  %2546 = load double, ptr %2545, align 8
5324  %2547 = call double @llvm.fmuladd.f64(double 0x3FEAEB8C8764F0BA, double %2546, double %2544)
5325  %2548 = getelementptr inbounds %struct.cmplx, ptr %49, i32 0, i32 1
5326  %2549 = load double, ptr %2548, align 8
5327  %2550 = call double @llvm.fmuladd.f64(double 0xBFEEB42A9BCD5057, double %2549, double %2547)
5328  %2551 = getelementptr inbounds %struct.cmplx, ptr %50, i32 0, i32 1
5329  %2552 = load double, ptr %2551, align 8
5330  %2553 = call double @llvm.fmuladd.f64(double 0x3FDA9628D9C712B6, double %2552, double %2550)
5331  %2554 = getelementptr inbounds %struct.cmplx, ptr %70, i32 0, i32 1
5332  store double %2553, ptr %2554, align 8
5333  %2555 = load double, ptr %21, align 8
5334  %2556 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 0
5335  %2557 = load double, ptr %2556, align 8
5336  %2558 = load double, ptr %19, align 8
5337  %2559 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 0
5338  %2560 = load double, ptr %2559, align 8
5339  %2561 = fmul double %2558, %2560
5340  %2562 = fneg double %2561
5341  %2563 = call double @llvm.fmuladd.f64(double %2555, double %2557, double %2562)
5342  %2564 = load double, ptr %15, align 8
5343  %2565 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 0
5344  %2566 = load double, ptr %2565, align 8
5345  %2567 = call double @llvm.fmuladd.f64(double %2564, double %2566, double %2563)
5346  %2568 = load double, ptr %23, align 8
5347  %2569 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 0
5348  %2570 = load double, ptr %2569, align 8
5349  %2571 = call double @llvm.fmuladd.f64(double %2568, double %2570, double %2567)
5350  %2572 = load double, ptr %17, align 8
5351  %2573 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 0
5352  %2574 = load double, ptr %2573, align 8
5353  %2575 = fneg double %2572
5354  %2576 = call double @llvm.fmuladd.f64(double %2575, double %2574, double %2571)
5355  %2577 = getelementptr inbounds %struct.cmplx, ptr %71, i32 0, i32 1
5356  store double %2576, ptr %2577, align 8
5357  %2578 = load double, ptr %21, align 8
5358  %2579 = getelementptr inbounds %struct.cmplx, ptr %55, i32 0, i32 1
5359  %2580 = load double, ptr %2579, align 8
5360  %2581 = load double, ptr %19, align 8
5361  %2582 = getelementptr inbounds %struct.cmplx, ptr %54, i32 0, i32 1
5362  %2583 = load double, ptr %2582, align 8
5363  %2584 = fmul double %2581, %2583
5364  %2585 = fneg double %2584
5365  %2586 = call double @llvm.fmuladd.f64(double %2578, double %2580, double %2585)
5366  %2587 = load double, ptr %15, align 8
5367  %2588 = getelementptr inbounds %struct.cmplx, ptr %53, i32 0, i32 1
5368  %2589 = load double, ptr %2588, align 8
5369  %2590 = call double @llvm.fmuladd.f64(double %2587, double %2589, double %2586)
5370  %2591 = load double, ptr %23, align 8
5371  %2592 = getelementptr inbounds %struct.cmplx, ptr %52, i32 0, i32 1
5372  %2593 = load double, ptr %2592, align 8
5373  %2594 = call double @llvm.fmuladd.f64(double %2591, double %2593, double %2590)
5374  %2595 = load double, ptr %17, align 8
5375  %2596 = getelementptr inbounds %struct.cmplx, ptr %51, i32 0, i32 1
5376  %2597 = load double, ptr %2596, align 8
5377  %2598 = fneg double %2595
5378  %2599 = call double @llvm.fmuladd.f64(double %2598, double %2597, double %2594)
5379  %2600 = fneg double %2599
5380  %2601 = getelementptr inbounds %struct.cmplx, ptr %71, i32 0, i32 0
5381  store double %2600, ptr %2601, align 8
5382  %2602 = getelementptr inbounds %struct.cmplx, ptr %70, i32 0, i32 0
5383  %2603 = load double, ptr %2602, align 8
5384  %2604 = getelementptr inbounds %struct.cmplx, ptr %71, i32 0, i32 0
5385  %2605 = load double, ptr %2604, align 8
5386  %2606 = fadd double %2603, %2605
5387  %2607 = getelementptr inbounds %struct.cmplx, ptr %68, i32 0, i32 0
5388  store double %2606, ptr %2607, align 8
5389  %2608 = getelementptr inbounds %struct.cmplx, ptr %70, i32 0, i32 1
5390  %2609 = load double, ptr %2608, align 8
5391  %2610 = getelementptr inbounds %struct.cmplx, ptr %71, i32 0, i32 1
5392  %2611 = load double, ptr %2610, align 8
5393  %2612 = fadd double %2609, %2611
5394  %2613 = getelementptr inbounds %struct.cmplx, ptr %68, i32 0, i32 1
5395  store double %2612, ptr %2613, align 8
5396  %2614 = getelementptr inbounds %struct.cmplx, ptr %70, i32 0, i32 0
5397  %2615 = load double, ptr %2614, align 8
5398  %2616 = getelementptr inbounds %struct.cmplx, ptr %71, i32 0, i32 0
5399  %2617 = load double, ptr %2616, align 8
5400  %2618 = fsub double %2615, %2617
5401  %2619 = getelementptr inbounds %struct.cmplx, ptr %69, i32 0, i32 0
5402  store double %2618, ptr %2619, align 8
5403  %2620 = getelementptr inbounds %struct.cmplx, ptr %70, i32 0, i32 1
5404  %2621 = load double, ptr %2620, align 8
5405  %2622 = getelementptr inbounds %struct.cmplx, ptr %71, i32 0, i32 1
5406  %2623 = load double, ptr %2622, align 8
5407  %2624 = fsub double %2621, %2623
5408  %2625 = getelementptr inbounds %struct.cmplx, ptr %69, i32 0, i32 1
5409  store double %2624, ptr %2625, align 8
5410  %2626 = load ptr, ptr %11, align 4
5411  %2627 = load i32, ptr %44, align 4
5412  %2628 = sub i32 %2627, 1
5413  %2629 = load i32, ptr %7, align 4
5414  %2630 = sub i32 %2629, 1
5415  %2631 = mul i32 3, %2630
5416  %2632 = add i32 %2628, %2631
5417  %2633 = getelementptr inbounds %struct.cmplx, ptr %2626, i32 %2632
5418  %2634 = getelementptr inbounds %struct.cmplx, ptr %2633, i32 0, i32 0
5419  %2635 = load double, ptr %2634, align 8
5420  %2636 = getelementptr inbounds %struct.cmplx, ptr %68, i32 0, i32 0
5421  %2637 = load double, ptr %2636, align 8
5422  %2638 = load i32, ptr %12, align 4
5423  %2639 = sitofp i32 %2638 to double
5424  %2640 = load ptr, ptr %11, align 4
5425  %2641 = load i32, ptr %44, align 4
5426  %2642 = sub i32 %2641, 1
5427  %2643 = load i32, ptr %7, align 4
5428  %2644 = sub i32 %2643, 1
5429  %2645 = mul i32 3, %2644
5430  %2646 = add i32 %2642, %2645
5431  %2647 = getelementptr inbounds %struct.cmplx, ptr %2640, i32 %2646
5432  %2648 = getelementptr inbounds %struct.cmplx, ptr %2647, i32 0, i32 1
5433  %2649 = load double, ptr %2648, align 8
5434  %2650 = fmul double %2639, %2649
5435  %2651 = getelementptr inbounds %struct.cmplx, ptr %68, i32 0, i32 1
5436  %2652 = load double, ptr %2651, align 8
5437  %2653 = fmul double %2650, %2652
5438  %2654 = fneg double %2653
5439  %2655 = call double @llvm.fmuladd.f64(double %2635, double %2637, double %2654)
5440  %2656 = load ptr, ptr %10, align 4
5441  %2657 = load i32, ptr %44, align 4
5442  %2658 = load i32, ptr %7, align 4
5443  %2659 = load i32, ptr %24, align 4
5444  %2660 = load i32, ptr %8, align 4
5445  %2661 = mul i32 %2660, 4
5446  %2662 = add i32 %2659, %2661
5447  %2663 = mul i32 %2658, %2662
5448  %2664 = add i32 %2657, %2663
5449  %2665 = getelementptr inbounds %struct.cmplx, ptr %2656, i32 %2664
5450  %2666 = getelementptr inbounds %struct.cmplx, ptr %2665, i32 0, i32 0
5451  store double %2655, ptr %2666, align 8
5452  %2667 = load ptr, ptr %11, align 4
5453  %2668 = load i32, ptr %44, align 4
5454  %2669 = sub i32 %2668, 1
5455  %2670 = load i32, ptr %7, align 4
5456  %2671 = sub i32 %2670, 1
5457  %2672 = mul i32 3, %2671
5458  %2673 = add i32 %2669, %2672
5459  %2674 = getelementptr inbounds %struct.cmplx, ptr %2667, i32 %2673
5460  %2675 = getelementptr inbounds %struct.cmplx, ptr %2674, i32 0, i32 0
5461  %2676 = load double, ptr %2675, align 8
5462  %2677 = getelementptr inbounds %struct.cmplx, ptr %68, i32 0, i32 1
5463  %2678 = load double, ptr %2677, align 8
5464  %2679 = load i32, ptr %12, align 4
5465  %2680 = sitofp i32 %2679 to double
5466  %2681 = load ptr, ptr %11, align 4
5467  %2682 = load i32, ptr %44, align 4
5468  %2683 = sub i32 %2682, 1
5469  %2684 = load i32, ptr %7, align 4
5470  %2685 = sub i32 %2684, 1
5471  %2686 = mul i32 3, %2685
5472  %2687 = add i32 %2683, %2686
5473  %2688 = getelementptr inbounds %struct.cmplx, ptr %2681, i32 %2687
5474  %2689 = getelementptr inbounds %struct.cmplx, ptr %2688, i32 0, i32 1
5475  %2690 = load double, ptr %2689, align 8
5476  %2691 = fmul double %2680, %2690
5477  %2692 = getelementptr inbounds %struct.cmplx, ptr %68, i32 0, i32 0
5478  %2693 = load double, ptr %2692, align 8
5479  %2694 = fmul double %2691, %2693
5480  %2695 = call double @llvm.fmuladd.f64(double %2676, double %2678, double %2694)
5481  %2696 = load ptr, ptr %10, align 4
5482  %2697 = load i32, ptr %44, align 4
5483  %2698 = load i32, ptr %7, align 4
5484  %2699 = load i32, ptr %24, align 4
5485  %2700 = load i32, ptr %8, align 4
5486  %2701 = mul i32 %2700, 4
5487  %2702 = add i32 %2699, %2701
5488  %2703 = mul i32 %2698, %2702
5489  %2704 = add i32 %2697, %2703
5490  %2705 = getelementptr inbounds %struct.cmplx, ptr %2696, i32 %2704
5491  %2706 = getelementptr inbounds %struct.cmplx, ptr %2705, i32 0, i32 1
5492  store double %2695, ptr %2706, align 8
5493  %2707 = load ptr, ptr %11, align 4
5494  %2708 = load i32, ptr %44, align 4
5495  %2709 = sub i32 %2708, 1
5496  %2710 = load i32, ptr %7, align 4
5497  %2711 = sub i32 %2710, 1
5498  %2712 = mul i32 6, %2711
5499  %2713 = add i32 %2709, %2712
5500  %2714 = getelementptr inbounds %struct.cmplx, ptr %2707, i32 %2713
5501  %2715 = getelementptr inbounds %struct.cmplx, ptr %2714, i32 0, i32 0
5502  %2716 = load double, ptr %2715, align 8
5503  %2717 = getelementptr inbounds %struct.cmplx, ptr %69, i32 0, i32 0
5504  %2718 = load double, ptr %2717, align 8
5505  %2719 = load i32, ptr %12, align 4
5506  %2720 = sitofp i32 %2719 to double
5507  %2721 = load ptr, ptr %11, align 4
5508  %2722 = load i32, ptr %44, align 4
5509  %2723 = sub i32 %2722, 1
5510  %2724 = load i32, ptr %7, align 4
5511  %2725 = sub i32 %2724, 1
5512  %2726 = mul i32 6, %2725
5513  %2727 = add i32 %2723, %2726
5514  %2728 = getelementptr inbounds %struct.cmplx, ptr %2721, i32 %2727
5515  %2729 = getelementptr inbounds %struct.cmplx, ptr %2728, i32 0, i32 1
5516  %2730 = load double, ptr %2729, align 8
5517  %2731 = fmul double %2720, %2730
5518  %2732 = getelementptr inbounds %struct.cmplx, ptr %69, i32 0, i32 1
5519  %2733 = load double, ptr %2732, align 8
5520  %2734 = fmul double %2731, %2733
5521  %2735 = fneg double %2734
5522  %2736 = call double @llvm.fmuladd.f64(double %2716, double %2718, double %2735)
5523  %2737 = load ptr, ptr %10, align 4
5524  %2738 = load i32, ptr %44, align 4
5525  %2739 = load i32, ptr %7, align 4
5526  %2740 = load i32, ptr %24, align 4
5527  %2741 = load i32, ptr %8, align 4
5528  %2742 = mul i32 %2741, 7
5529  %2743 = add i32 %2740, %2742
5530  %2744 = mul i32 %2739, %2743
5531  %2745 = add i32 %2738, %2744
5532  %2746 = getelementptr inbounds %struct.cmplx, ptr %2737, i32 %2745
5533  %2747 = getelementptr inbounds %struct.cmplx, ptr %2746, i32 0, i32 0
5534  store double %2736, ptr %2747, align 8
5535  %2748 = load ptr, ptr %11, align 4
5536  %2749 = load i32, ptr %44, align 4
5537  %2750 = sub i32 %2749, 1
5538  %2751 = load i32, ptr %7, align 4
5539  %2752 = sub i32 %2751, 1
5540  %2753 = mul i32 6, %2752
5541  %2754 = add i32 %2750, %2753
5542  %2755 = getelementptr inbounds %struct.cmplx, ptr %2748, i32 %2754
5543  %2756 = getelementptr inbounds %struct.cmplx, ptr %2755, i32 0, i32 0
5544  %2757 = load double, ptr %2756, align 8
5545  %2758 = getelementptr inbounds %struct.cmplx, ptr %69, i32 0, i32 1
5546  %2759 = load double, ptr %2758, align 8
5547  %2760 = load i32, ptr %12, align 4
5548  %2761 = sitofp i32 %2760 to double
5549  %2762 = load ptr, ptr %11, align 4
5550  %2763 = load i32, ptr %44, align 4
5551  %2764 = sub i32 %2763, 1
5552  %2765 = load i32, ptr %7, align 4
5553  %2766 = sub i32 %2765, 1
5554  %2767 = mul i32 6, %2766
5555  %2768 = add i32 %2764, %2767
5556  %2769 = getelementptr inbounds %struct.cmplx, ptr %2762, i32 %2768
5557  %2770 = getelementptr inbounds %struct.cmplx, ptr %2769, i32 0, i32 1
5558  %2771 = load double, ptr %2770, align 8
5559  %2772 = fmul double %2761, %2771
5560  %2773 = getelementptr inbounds %struct.cmplx, ptr %69, i32 0, i32 0
5561  %2774 = load double, ptr %2773, align 8
5562  %2775 = fmul double %2772, %2774
5563  %2776 = call double @llvm.fmuladd.f64(double %2757, double %2759, double %2775)
5564  %2777 = load ptr, ptr %10, align 4
5565  %2778 = load i32, ptr %44, align 4
5566  %2779 = load i32, ptr %7, align 4
5567  %2780 = load i32, ptr %24, align 4
5568  %2781 = load i32, ptr %8, align 4
5569  %2782 = mul i32 %2781, 7
5570  %2783 = add i32 %2780, %2782
5571  %2784 = mul i32 %2779, %2783
5572  %2785 = add i32 %2778, %2784
5573  %2786 = getelementptr inbounds %struct.cmplx, ptr %2777, i32 %2785
5574  %2787 = getelementptr inbounds %struct.cmplx, ptr %2786, i32 0, i32 1
5575  store double %2776, ptr %2787, align 8
5576  br label %2788
5577
55782788:                                             ; preds = %1168
5579  %2789 = load i32, ptr %44, align 4
5580  %2790 = add i32 %2789, 1
5581  store i32 %2790, ptr %44, align 4
5582  br label %1164, !llvm.loop !4
5583
55842791:                                             ; preds = %1164
5585  br label %2792
5586
55872792:                                             ; preds = %2791
5588  %2793 = load i32, ptr %24, align 4
5589  %2794 = add i32 %2793, 1
5590  store i32 %2794, ptr %24, align 4
5591  br label %87, !llvm.loop !6
5592
55932795:                                             ; preds = %87
5594  ret void
5595}
5596
5597; Function Attrs: nocallback nofree nounwind willreturn memory(argmem: readwrite)
5598declare void @llvm.memcpy.p0.p0.i32(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i32, i1 immarg) #2
5599
5600; Function Attrs: nocallback nofree nosync nounwind speculatable willreturn memory(none)
5601declare double @llvm.fmuladd.f64(double, double, double) #3
5602
5603attributes #0 = { noinline nounwind optnone uwtable "frame-pointer"="all" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="e500" "target-features"="+spe,-altivec,-bpermd,-crbits,-crypto,-direct-move,-extdiv,-htm,-isa-v206-instructions,-isa-v207-instructions,-isa-v30-instructions,-power8-vector,-power9-vector,-privileged,-quadword-atomics,-rop-protect,-vsx" }
5604attributes #1 = { "frame-pointer"="all" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="e500" "target-features"="+spe,-altivec,-bpermd,-crbits,-crypto,-direct-move,-extdiv,-htm,-isa-v206-instructions,-isa-v207-instructions,-isa-v30-instructions,-power8-vector,-power9-vector,-privileged,-quadword-atomics,-rop-protect,-vsx" }
5605attributes #2 = { nocallback nofree nounwind willreturn memory(argmem: readwrite) }
5606attributes #3 = { nocallback nofree nosync nounwind speculatable willreturn memory(none) }
5607
5608!llvm.module.flags = !{!0, !1, !2}
5609!llvm.ident = !{!3}
5610
5611!0 = !{i32 1, !"wchar_size", i32 4}
5612!1 = !{i32 7, !"uwtable", i32 2}
5613!2 = !{i32 7, !"frame-pointer", i32 2}
5614!3 = !{!"clang version 17.0.0 (https://github.com/llvm/llvm-project.git 69db592f762ade86508826a7b3c9d5434c4837e2)"}
5615!4 = distinct !{!4, !5}
5616!5 = !{!"llvm.loop.mustprogress"}
5617!6 = distinct !{!6, !5}
5618;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
5619; SPE: {{.*}}
5620