-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgen01236030773695640064-onnx.mlir
652 lines (651 loc) · 42.3 KB
/
gen01236030773695640064-onnx.mlir
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
module attributes {llvm.data_layout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128", llvm.target_triple = "x86_64-unknown-linux-gnu"} {
llvm.func @strncmp(!llvm.ptr<i8>, !llvm.ptr<i8>, i64) -> i32
llvm.mlir.global external constant @_entry_point_0("run_main_graph\00") {addr_space = 0 : i32}
llvm.mlir.global external constant @_entry_point_0_in_sig("[ { \22type\22 : \22i32\22 , \22dims\22 : [] , \22name\22 : \22v7_0\22 }\0A , { \22type\22 : \22i32\22 , \22dims\22 : [1] , \22name\22 : \22v2_0\22 }\0A\0A]\00") {addr_space = 0 : i32}
llvm.mlir.global external constant @_entry_point_0_out_sig("[ { \22type\22 : \22i32\22 , \22dims\22 : [1 , 1 , 1 , 2] , \22name\22 : \22v1_0\22 }\0A , { \22type\22 : \22i32\22 , \22dims\22 : [] , \22name\22 : \22v0_0\22 }\0A , { \22type\22 : \22i32\22 , \22dims\22 : [1 , 1 , 1 , 2] , \22name\22 : \22v3_0\22 }\0A\0A]\00") {addr_space = 0 : i32}
llvm.func @omTensorListGetSize(!llvm.ptr<i8>) -> i64
llvm.func @omTensorPrint(!llvm.ptr<i8>, !llvm.ptr<i8>)
llvm.func @omTensorListGetOmtArray(!llvm.ptr<i8>) -> !llvm.ptr<ptr<i8>>
llvm.func @omTensorSetDataType(!llvm.ptr<i8>, i64)
llvm.func @omTensorGetDataType(!llvm.ptr<i8>) -> i64
llvm.func @omTensorGetStrides(!llvm.ptr<i8>) -> !llvm.ptr<i64>
llvm.func @omTensorGetShape(!llvm.ptr<i8>) -> !llvm.ptr<i64>
llvm.func @omTensorGetRank(!llvm.ptr<i8>) -> i64
llvm.func @omTensorSetDataPtr(!llvm.ptr<i8>, i64, !llvm.ptr<i8>, !llvm.ptr<i8>)
llvm.func @omTensorGetDataPtr(!llvm.ptr<i8>) -> !llvm.ptr<i8>
llvm.func @omTensorCreateUntyped(i64) -> !llvm.ptr<i8>
llvm.func @omTensorListCreate(!llvm.ptr<ptr<i8>>, i64, i64) -> !llvm.ptr<i8>
llvm.func @malloc(i64) -> !llvm.ptr<i8>
llvm.mlir.global internal constant @constant_5(dense<[[[[3, 7]]]]> : tensor<1x1x1x2xi32>) {addr_space = 0 : i32, alignment = 16 : i64} : !llvm.array<1 x array<1 x array<1 x array<2 x i32>>>>
llvm.func @main_graph(%arg0: !llvm.ptr<i32>, %arg1: !llvm.ptr<i32>, %arg2: i64, %arg3: !llvm.ptr<i32>, %arg4: !llvm.ptr<i32>, %arg5: i64, %arg6: i64, %arg7: i64) -> !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)> attributes {input_names = ["v7_0", "v2_0"], llvm.emit_c_interface, output_names = ["v1_0", "v0_0", "v3_0"]} {
%0 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%1 = llvm.insertvalue %arg0, %0[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%2 = llvm.insertvalue %arg1, %1[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%3 = llvm.insertvalue %arg2, %2[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%4 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%5 = llvm.insertvalue %arg3, %4[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%6 = llvm.insertvalue %arg4, %5[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%7 = llvm.insertvalue %arg5, %6[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%8 = llvm.insertvalue %arg6, %7[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%9 = llvm.insertvalue %arg7, %8[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%10 = llvm.mlir.constant(-2147483648 : i32) : i32
%11 = llvm.mlir.constant(0 : index) : i64
%12 = llvm.mlir.addressof @constant_5 : !llvm.ptr<array<1 x array<1 x array<1 x array<2 x i32>>>>>
%13 = llvm.bitcast %12 : !llvm.ptr<array<1 x array<1 x array<1 x array<2 x i32>>>>> to !llvm.ptr<i32>
%14 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%15 = llvm.insertvalue %13, %14[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%16 = llvm.insertvalue %13, %15[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%17 = llvm.mlir.constant(0 : index) : i64
%18 = llvm.insertvalue %17, %16[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%19 = llvm.mlir.constant(1 : index) : i64
%20 = llvm.insertvalue %19, %18[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%21 = llvm.mlir.constant(2 : index) : i64
%22 = llvm.insertvalue %21, %20[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%23 = llvm.mlir.constant(1 : index) : i64
%24 = llvm.insertvalue %23, %22[3, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%25 = llvm.mlir.constant(2 : index) : i64
%26 = llvm.insertvalue %25, %24[4, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%27 = llvm.mlir.constant(1 : index) : i64
%28 = llvm.insertvalue %27, %26[3, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%29 = llvm.mlir.constant(2 : index) : i64
%30 = llvm.insertvalue %29, %28[4, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%31 = llvm.mlir.constant(2 : index) : i64
%32 = llvm.insertvalue %31, %30[3, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%33 = llvm.mlir.constant(1 : index) : i64
%34 = llvm.insertvalue %33, %32[4, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%35 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%36 = llvm.extractvalue %3[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%37 = llvm.extractvalue %3[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%38 = llvm.insertvalue %36, %35[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%39 = llvm.insertvalue %37, %38[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%40 = llvm.mlir.constant(0 : index) : i64
%41 = llvm.insertvalue %40, %39[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%42 = llvm.mlir.constant(1 : index) : i64
%43 = llvm.insertvalue %42, %41[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%44 = llvm.mlir.constant(1 : index) : i64
%45 = llvm.insertvalue %44, %43[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%46 = llvm.mlir.constant(1 : index) : i64
%47 = llvm.mlir.constant(1 : index) : i64
%48 = llvm.mlir.constant(1 : index) : i64
%49 = llvm.mlir.constant(2 : index) : i64
%50 = llvm.mlir.constant(1 : index) : i64
%51 = llvm.mlir.constant(2 : index) : i64
%52 = llvm.mlir.constant(2 : index) : i64
%53 = llvm.mlir.constant(2 : index) : i64
%54 = llvm.mlir.null : !llvm.ptr<i32>
%55 = llvm.getelementptr %54[%53] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%56 = llvm.ptrtoint %55 : !llvm.ptr<i32> to i64
%57 = llvm.mlir.constant(16 : index) : i64
%58 = llvm.add %56, %57 : i64
%59 = llvm.call @malloc(%58) : (i64) -> !llvm.ptr<i8>
%60 = llvm.bitcast %59 : !llvm.ptr<i8> to !llvm.ptr<i32>
%61 = llvm.ptrtoint %60 : !llvm.ptr<i32> to i64
%62 = llvm.mlir.constant(1 : index) : i64
%63 = llvm.sub %57, %62 : i64
%64 = llvm.add %61, %63 : i64
%65 = llvm.urem %64, %57 : i64
%66 = llvm.sub %64, %65 : i64
%67 = llvm.inttoptr %66 : i64 to !llvm.ptr<i32>
%68 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%69 = llvm.insertvalue %60, %68[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%70 = llvm.insertvalue %67, %69[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%71 = llvm.mlir.constant(0 : index) : i64
%72 = llvm.insertvalue %71, %70[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%73 = llvm.insertvalue %46, %72[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%74 = llvm.insertvalue %47, %73[3, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%75 = llvm.insertvalue %48, %74[3, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%76 = llvm.insertvalue %49, %75[3, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%77 = llvm.insertvalue %52, %76[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%78 = llvm.insertvalue %51, %77[4, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%79 = llvm.insertvalue %49, %78[4, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%80 = llvm.insertvalue %50, %79[4, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%81 = llvm.mlir.constant(0 : index) : i64
%82 = llvm.mlir.constant(1 : index) : i64
%83 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb1(%81 : i64)
^bb1(%84: i64): // 2 preds: ^bb0, ^bb11
%85 = llvm.icmp "slt" %84, %82 : i64
llvm.cond_br %85, ^bb2, ^bb12
^bb2: // pred: ^bb1
%86 = llvm.mlir.constant(0 : index) : i64
%87 = llvm.mlir.constant(1 : index) : i64
%88 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb3(%86 : i64)
^bb3(%89: i64): // 2 preds: ^bb2, ^bb10
%90 = llvm.icmp "slt" %89, %87 : i64
llvm.cond_br %90, ^bb4, ^bb11
^bb4: // pred: ^bb3
%91 = llvm.mlir.constant(0 : index) : i64
%92 = llvm.mlir.constant(1 : index) : i64
%93 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb5(%91 : i64)
^bb5(%94: i64): // 2 preds: ^bb4, ^bb9
%95 = llvm.icmp "slt" %94, %92 : i64
llvm.cond_br %95, ^bb6, ^bb10
^bb6: // pred: ^bb5
%96 = llvm.mlir.constant(0 : index) : i64
%97 = llvm.mlir.constant(2 : index) : i64
%98 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb7(%96 : i64)
^bb7(%99: i64): // 2 preds: ^bb6, ^bb8
%100 = llvm.icmp "slt" %99, %97 : i64
llvm.cond_br %100, ^bb8, ^bb9
^bb8: // pred: ^bb7
%101 = llvm.extractvalue %34[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%102 = llvm.mlir.constant(2 : index) : i64
%103 = llvm.mul %84, %102 : i64
%104 = llvm.mlir.constant(2 : index) : i64
%105 = llvm.mul %89, %104 : i64
%106 = llvm.add %103, %105 : i64
%107 = llvm.mlir.constant(2 : index) : i64
%108 = llvm.mul %94, %107 : i64
%109 = llvm.add %106, %108 : i64
%110 = llvm.add %109, %99 : i64
%111 = llvm.getelementptr %101[%110] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%112 = llvm.load %111 : !llvm.ptr<i32>
%113 = llvm.extractvalue %45[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%114 = llvm.getelementptr %113[%11] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%115 = llvm.load %114 : !llvm.ptr<i32>
%116 = llvm.icmp "slt" %112, %115 : i32
%117 = llvm.select %116, %112, %115 : i1, i32
%118 = llvm.extractvalue %80[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%119 = llvm.mlir.constant(2 : index) : i64
%120 = llvm.mul %84, %119 : i64
%121 = llvm.mlir.constant(2 : index) : i64
%122 = llvm.mul %89, %121 : i64
%123 = llvm.add %120, %122 : i64
%124 = llvm.mlir.constant(2 : index) : i64
%125 = llvm.mul %94, %124 : i64
%126 = llvm.add %123, %125 : i64
%127 = llvm.add %126, %99 : i64
%128 = llvm.getelementptr %118[%127] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
llvm.store %117, %128 : !llvm.ptr<i32>
%129 = llvm.add %99, %98 : i64
llvm.br ^bb7(%129 : i64)
^bb9: // pred: ^bb7
%130 = llvm.add %94, %93 : i64
llvm.br ^bb5(%130 : i64)
^bb10: // pred: ^bb5
%131 = llvm.add %89, %88 : i64
llvm.br ^bb3(%131 : i64)
^bb11: // pred: ^bb3
%132 = llvm.add %84, %83 : i64
llvm.br ^bb1(%132 : i64)
^bb12: // pred: ^bb1
%133 = llvm.mlir.constant(1 : index) : i64
%134 = llvm.mlir.constant(1 : index) : i64
%135 = llvm.mlir.constant(1 : index) : i64
%136 = llvm.mlir.constant(2 : index) : i64
%137 = llvm.mlir.constant(1 : index) : i64
%138 = llvm.mlir.constant(2 : index) : i64
%139 = llvm.mlir.constant(2 : index) : i64
%140 = llvm.mlir.constant(2 : index) : i64
%141 = llvm.mlir.null : !llvm.ptr<i32>
%142 = llvm.getelementptr %141[%140] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%143 = llvm.ptrtoint %142 : !llvm.ptr<i32> to i64
%144 = llvm.mlir.constant(16 : index) : i64
%145 = llvm.add %143, %144 : i64
%146 = llvm.call @malloc(%145) : (i64) -> !llvm.ptr<i8>
%147 = llvm.bitcast %146 : !llvm.ptr<i8> to !llvm.ptr<i32>
%148 = llvm.ptrtoint %147 : !llvm.ptr<i32> to i64
%149 = llvm.mlir.constant(1 : index) : i64
%150 = llvm.sub %144, %149 : i64
%151 = llvm.add %148, %150 : i64
%152 = llvm.urem %151, %144 : i64
%153 = llvm.sub %151, %152 : i64
%154 = llvm.inttoptr %153 : i64 to !llvm.ptr<i32>
%155 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%156 = llvm.insertvalue %147, %155[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%157 = llvm.insertvalue %154, %156[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%158 = llvm.mlir.constant(0 : index) : i64
%159 = llvm.insertvalue %158, %157[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%160 = llvm.insertvalue %133, %159[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%161 = llvm.insertvalue %134, %160[3, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%162 = llvm.insertvalue %135, %161[3, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%163 = llvm.insertvalue %136, %162[3, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%164 = llvm.insertvalue %139, %163[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%165 = llvm.insertvalue %138, %164[4, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%166 = llvm.insertvalue %136, %165[4, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%167 = llvm.insertvalue %137, %166[4, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%168 = llvm.mlir.constant(0 : index) : i64
%169 = llvm.mlir.constant(1 : index) : i64
%170 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb13(%168 : i64)
^bb13(%171: i64): // 2 preds: ^bb12, ^bb23
%172 = llvm.icmp "slt" %171, %169 : i64
llvm.cond_br %172, ^bb14, ^bb24
^bb14: // pred: ^bb13
%173 = llvm.mlir.constant(0 : index) : i64
%174 = llvm.mlir.constant(1 : index) : i64
%175 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb15(%173 : i64)
^bb15(%176: i64): // 2 preds: ^bb14, ^bb22
%177 = llvm.icmp "slt" %176, %174 : i64
llvm.cond_br %177, ^bb16, ^bb23
^bb16: // pred: ^bb15
%178 = llvm.mlir.constant(0 : index) : i64
%179 = llvm.mlir.constant(1 : index) : i64
%180 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb17(%178 : i64)
^bb17(%181: i64): // 2 preds: ^bb16, ^bb21
%182 = llvm.icmp "slt" %181, %179 : i64
llvm.cond_br %182, ^bb18, ^bb22
^bb18: // pred: ^bb17
%183 = llvm.mlir.constant(0 : index) : i64
%184 = llvm.mlir.constant(2 : index) : i64
%185 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb19(%183 : i64)
^bb19(%186: i64): // 2 preds: ^bb18, ^bb20
%187 = llvm.icmp "slt" %186, %184 : i64
llvm.cond_br %187, ^bb20, ^bb21
^bb20: // pred: ^bb19
%188 = llvm.extractvalue %80[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%189 = llvm.mlir.constant(2 : index) : i64
%190 = llvm.mul %171, %189 : i64
%191 = llvm.mlir.constant(2 : index) : i64
%192 = llvm.mul %176, %191 : i64
%193 = llvm.add %190, %192 : i64
%194 = llvm.mlir.constant(2 : index) : i64
%195 = llvm.mul %181, %194 : i64
%196 = llvm.add %193, %195 : i64
%197 = llvm.add %196, %186 : i64
%198 = llvm.getelementptr %188[%197] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%199 = llvm.load %198 : !llvm.ptr<i32>
%200 = llvm.extractvalue %167[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%201 = llvm.mlir.constant(2 : index) : i64
%202 = llvm.mul %171, %201 : i64
%203 = llvm.mlir.constant(2 : index) : i64
%204 = llvm.mul %176, %203 : i64
%205 = llvm.add %202, %204 : i64
%206 = llvm.mlir.constant(2 : index) : i64
%207 = llvm.mul %181, %206 : i64
%208 = llvm.add %205, %207 : i64
%209 = llvm.add %208, %186 : i64
%210 = llvm.getelementptr %200[%209] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
llvm.store %199, %210 : !llvm.ptr<i32>
%211 = llvm.add %186, %185 : i64
llvm.br ^bb19(%211 : i64)
^bb21: // pred: ^bb19
%212 = llvm.add %181, %180 : i64
llvm.br ^bb17(%212 : i64)
^bb22: // pred: ^bb17
%213 = llvm.add %176, %175 : i64
llvm.br ^bb15(%213 : i64)
^bb23: // pred: ^bb15
%214 = llvm.add %171, %170 : i64
llvm.br ^bb13(%214 : i64)
^bb24: // pred: ^bb13
%215 = llvm.mlir.constant(1 : index) : i64
%216 = llvm.mlir.null : !llvm.ptr<i32>
%217 = llvm.getelementptr %216[%215] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%218 = llvm.ptrtoint %217 : !llvm.ptr<i32> to i64
%219 = llvm.call @malloc(%218) : (i64) -> !llvm.ptr<i8>
%220 = llvm.bitcast %219 : !llvm.ptr<i8> to !llvm.ptr<i32>
%221 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%222 = llvm.insertvalue %220, %221[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%223 = llvm.insertvalue %220, %222[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%224 = llvm.mlir.constant(0 : index) : i64
%225 = llvm.insertvalue %224, %223[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%226 = llvm.extractvalue %225[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
llvm.store %10, %226 : !llvm.ptr<i32>
%227 = llvm.mlir.constant(0 : index) : i64
%228 = llvm.mlir.constant(1 : index) : i64
%229 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb25(%227 : i64)
^bb25(%230: i64): // 2 preds: ^bb24, ^bb26
%231 = llvm.icmp "slt" %230, %228 : i64
llvm.cond_br %231, ^bb26, ^bb27
^bb26: // pred: ^bb25
%232 = llvm.extractvalue %9[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%233 = llvm.getelementptr %232[%230] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%234 = llvm.load %233 : !llvm.ptr<i32>
%235 = llvm.extractvalue %225[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%236 = llvm.load %235 : !llvm.ptr<i32>
%237 = llvm.icmp "sgt" %236, %234 : i32
%238 = llvm.select %237, %236, %234 : i1, i32
%239 = llvm.extractvalue %225[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
llvm.store %238, %239 : !llvm.ptr<i32>
%240 = llvm.add %230, %229 : i64
llvm.br ^bb25(%240 : i64)
^bb27: // pred: ^bb25
%241 = llvm.mlir.constant(1 : index) : i64
%242 = llvm.mlir.constant(1 : index) : i64
%243 = llvm.mlir.constant(1 : index) : i64
%244 = llvm.mlir.constant(2 : index) : i64
%245 = llvm.mlir.constant(1 : index) : i64
%246 = llvm.mlir.constant(2 : index) : i64
%247 = llvm.mlir.constant(2 : index) : i64
%248 = llvm.mlir.constant(2 : index) : i64
%249 = llvm.mlir.null : !llvm.ptr<i32>
%250 = llvm.getelementptr %249[%248] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%251 = llvm.ptrtoint %250 : !llvm.ptr<i32> to i64
%252 = llvm.mlir.constant(16 : index) : i64
%253 = llvm.add %251, %252 : i64
%254 = llvm.call @malloc(%253) : (i64) -> !llvm.ptr<i8>
%255 = llvm.bitcast %254 : !llvm.ptr<i8> to !llvm.ptr<i32>
%256 = llvm.ptrtoint %255 : !llvm.ptr<i32> to i64
%257 = llvm.mlir.constant(1 : index) : i64
%258 = llvm.sub %252, %257 : i64
%259 = llvm.add %256, %258 : i64
%260 = llvm.urem %259, %252 : i64
%261 = llvm.sub %259, %260 : i64
%262 = llvm.inttoptr %261 : i64 to !llvm.ptr<i32>
%263 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%264 = llvm.insertvalue %255, %263[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%265 = llvm.insertvalue %262, %264[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%266 = llvm.mlir.constant(0 : index) : i64
%267 = llvm.insertvalue %266, %265[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%268 = llvm.insertvalue %241, %267[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%269 = llvm.insertvalue %242, %268[3, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%270 = llvm.insertvalue %243, %269[3, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%271 = llvm.insertvalue %244, %270[3, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%272 = llvm.insertvalue %247, %271[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%273 = llvm.insertvalue %246, %272[4, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%274 = llvm.insertvalue %244, %273[4, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%275 = llvm.insertvalue %245, %274[4, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%276 = llvm.mlir.constant(0 : index) : i64
%277 = llvm.mlir.constant(1 : index) : i64
%278 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb28(%276 : i64)
^bb28(%279: i64): // 2 preds: ^bb27, ^bb38
%280 = llvm.icmp "slt" %279, %277 : i64
llvm.cond_br %280, ^bb29, ^bb39
^bb29: // pred: ^bb28
%281 = llvm.mlir.constant(0 : index) : i64
%282 = llvm.mlir.constant(1 : index) : i64
%283 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb30(%281 : i64)
^bb30(%284: i64): // 2 preds: ^bb29, ^bb37
%285 = llvm.icmp "slt" %284, %282 : i64
llvm.cond_br %285, ^bb31, ^bb38
^bb31: // pred: ^bb30
%286 = llvm.mlir.constant(0 : index) : i64
%287 = llvm.mlir.constant(1 : index) : i64
%288 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb32(%286 : i64)
^bb32(%289: i64): // 2 preds: ^bb31, ^bb36
%290 = llvm.icmp "slt" %289, %287 : i64
llvm.cond_br %290, ^bb33, ^bb37
^bb33: // pred: ^bb32
%291 = llvm.mlir.constant(0 : index) : i64
%292 = llvm.mlir.constant(2 : index) : i64
%293 = llvm.mlir.constant(1 : index) : i64
llvm.br ^bb34(%291 : i64)
^bb34(%294: i64): // 2 preds: ^bb33, ^bb35
%295 = llvm.icmp "slt" %294, %292 : i64
llvm.cond_br %295, ^bb35, ^bb36
^bb35: // pred: ^bb34
%296 = llvm.extractvalue %80[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%297 = llvm.mlir.constant(2 : index) : i64
%298 = llvm.mul %279, %297 : i64
%299 = llvm.mlir.constant(2 : index) : i64
%300 = llvm.mul %284, %299 : i64
%301 = llvm.add %298, %300 : i64
%302 = llvm.mlir.constant(2 : index) : i64
%303 = llvm.mul %289, %302 : i64
%304 = llvm.add %301, %303 : i64
%305 = llvm.add %304, %294 : i64
%306 = llvm.getelementptr %296[%305] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%307 = llvm.load %306 : !llvm.ptr<i32>
%308 = llvm.extractvalue %9[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%309 = llvm.getelementptr %308[%11] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
%310 = llvm.load %309 : !llvm.ptr<i32>
%311 = llvm.icmp "sgt" %307, %310 : i32
%312 = llvm.select %311, %307, %310 : i1, i32
%313 = llvm.extractvalue %275[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%314 = llvm.mlir.constant(2 : index) : i64
%315 = llvm.mul %279, %314 : i64
%316 = llvm.mlir.constant(2 : index) : i64
%317 = llvm.mul %284, %316 : i64
%318 = llvm.add %315, %317 : i64
%319 = llvm.mlir.constant(2 : index) : i64
%320 = llvm.mul %289, %319 : i64
%321 = llvm.add %318, %320 : i64
%322 = llvm.add %321, %294 : i64
%323 = llvm.getelementptr %313[%322] : (!llvm.ptr<i32>, i64) -> !llvm.ptr<i32>
llvm.store %312, %323 : !llvm.ptr<i32>
%324 = llvm.add %294, %293 : i64
llvm.br ^bb34(%324 : i64)
^bb36: // pred: ^bb34
%325 = llvm.add %289, %288 : i64
llvm.br ^bb32(%325 : i64)
^bb37: // pred: ^bb32
%326 = llvm.add %284, %283 : i64
llvm.br ^bb30(%326 : i64)
^bb38: // pred: ^bb30
%327 = llvm.add %279, %278 : i64
llvm.br ^bb28(%327 : i64)
^bb39: // pred: ^bb28
%328 = llvm.mlir.undef : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
%329 = llvm.insertvalue %167, %328[0] : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
%330 = llvm.insertvalue %225, %329[1] : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
%331 = llvm.insertvalue %275, %330[2] : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
llvm.return %331 : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
}
llvm.func @_mlir_ciface_main_graph(%arg0: !llvm.ptr<struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>>, %arg1: !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64)>>, %arg2: !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>>) attributes {input_names = ["v7_0", "v2_0"], llvm.emit_c_interface, output_names = ["v1_0", "v0_0", "v3_0"]} {
%0 = llvm.load %arg1 : !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64)>>
%1 = llvm.extractvalue %0[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%2 = llvm.extractvalue %0[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%3 = llvm.extractvalue %0[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%4 = llvm.load %arg2 : !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>>
%5 = llvm.extractvalue %4[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%6 = llvm.extractvalue %4[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%7 = llvm.extractvalue %4[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%8 = llvm.extractvalue %4[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%9 = llvm.extractvalue %4[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%10 = llvm.call @main_graph(%1, %2, %3, %5, %6, %7, %8, %9) : (!llvm.ptr<i32>, !llvm.ptr<i32>, i64, !llvm.ptr<i32>, !llvm.ptr<i32>, i64, i64, i64) -> !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
llvm.store %10, %arg0 : !llvm.ptr<struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>>
llvm.return
}
llvm.func @run_main_graph(%arg0: !llvm.ptr<i8>) -> !llvm.ptr<i8> {
%0 = llvm.call @omTensorListGetOmtArray(%arg0) : (!llvm.ptr<i8>) -> !llvm.ptr<ptr<i8>>
%1 = llvm.mlir.constant(1 : i64) : i64
%2 = llvm.alloca %1 x !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)> : (i64) -> !llvm.ptr<struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>>
%3 = llvm.mlir.constant(0 : i64) : i64
%4 = llvm.getelementptr %0[%3] : (!llvm.ptr<ptr<i8>>, i64) -> !llvm.ptr<ptr<i8>>
%5 = llvm.load %4 : !llvm.ptr<ptr<i8>>
%6 = llvm.alloca %1 x !llvm.struct<(ptr<i32>, ptr<i32>, i64)> : (i64) -> !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64)>>
%7 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%8 = llvm.call @omTensorGetDataPtr(%5) : (!llvm.ptr<i8>) -> !llvm.ptr<i8>
%9 = llvm.bitcast %8 : !llvm.ptr<i8> to !llvm.ptr<i32>
%10 = llvm.insertvalue %9, %7[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%11 = llvm.insertvalue %9, %10[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%12 = llvm.mlir.constant(0 : i64) : i64
%13 = llvm.insertvalue %12, %11[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%14 = llvm.call @omTensorGetShape(%5) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%15 = llvm.call @omTensorGetStrides(%5) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
llvm.store %13, %6 : !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64)>>
%16 = llvm.mlir.constant(1 : i64) : i64
%17 = llvm.getelementptr %0[%16] : (!llvm.ptr<ptr<i8>>, i64) -> !llvm.ptr<ptr<i8>>
%18 = llvm.load %17 : !llvm.ptr<ptr<i8>>
%19 = llvm.alloca %1 x !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)> : (i64) -> !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>>
%20 = llvm.mlir.undef : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%21 = llvm.call @omTensorGetDataPtr(%18) : (!llvm.ptr<i8>) -> !llvm.ptr<i8>
%22 = llvm.bitcast %21 : !llvm.ptr<i8> to !llvm.ptr<i32>
%23 = llvm.insertvalue %22, %20[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%24 = llvm.insertvalue %22, %23[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%25 = llvm.mlir.constant(0 : i64) : i64
%26 = llvm.insertvalue %25, %24[2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%27 = llvm.call @omTensorGetShape(%18) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%28 = llvm.call @omTensorGetStrides(%18) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%29 = llvm.mlir.constant(0 : i64) : i64
%30 = llvm.getelementptr %27[%29] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
%31 = llvm.load %30 : !llvm.ptr<i64>
%32 = llvm.insertvalue %31, %26[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
%33 = llvm.getelementptr %28[%29] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
%34 = llvm.load %33 : !llvm.ptr<i64>
%35 = llvm.insertvalue %34, %32[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>
llvm.store %35, %19 : !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>>
llvm.call @_mlir_ciface_main_graph(%2, %6, %19) : (!llvm.ptr<struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>>, !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64)>>, !llvm.ptr<struct<(ptr<i32>, ptr<i32>, i64, array<1 x i64>, array<1 x i64>)>>) -> ()
%36 = llvm.load %2 : !llvm.ptr<struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>>
%37 = llvm.extractvalue %36[0] : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
%38 = llvm.extractvalue %36[1] : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
%39 = llvm.extractvalue %36[2] : !llvm.struct<(struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>, struct<(ptr<i32>, ptr<i32>, i64)>, struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>)>
%40 = llvm.mlir.constant(3 : i64) : i64
%41 = llvm.mlir.constant(24 : i64) : i64
%42 = llvm.call @malloc(%41) : (i64) -> !llvm.ptr<i8>
%43 = llvm.bitcast %42 : !llvm.ptr<i8> to !llvm.ptr<ptr<i8>>
%44 = llvm.mlir.constant(4 : i64) : i64
%45 = llvm.call @omTensorCreateUntyped(%44) : (i64) -> !llvm.ptr<i8>
%46 = llvm.mlir.constant(1 : i64) : i64
%47 = llvm.extractvalue %37[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%48 = llvm.bitcast %47 : !llvm.ptr<i32> to !llvm.ptr<i8>
%49 = llvm.extractvalue %37[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%50 = llvm.bitcast %49 : !llvm.ptr<i32> to !llvm.ptr<i8>
llvm.call @omTensorSetDataPtr(%45, %46, %48, %50) : (!llvm.ptr<i8>, i64, !llvm.ptr<i8>, !llvm.ptr<i8>) -> ()
%51 = llvm.mlir.constant(6 : i64) : i64
llvm.call @omTensorSetDataType(%45, %51) : (!llvm.ptr<i8>, i64) -> ()
%52 = llvm.call @omTensorGetShape(%45) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%53 = llvm.call @omTensorGetStrides(%45) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%54 = llvm.mlir.constant(0 : i64) : i64
%55 = llvm.extractvalue %37[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%56 = llvm.getelementptr %52[%54] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %55, %56 : !llvm.ptr<i64>
%57 = llvm.extractvalue %37[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%58 = llvm.getelementptr %53[%54] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %57, %58 : !llvm.ptr<i64>
%59 = llvm.mlir.constant(1 : i64) : i64
%60 = llvm.extractvalue %37[3, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%61 = llvm.getelementptr %52[%59] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %60, %61 : !llvm.ptr<i64>
%62 = llvm.extractvalue %37[4, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%63 = llvm.getelementptr %53[%59] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %62, %63 : !llvm.ptr<i64>
%64 = llvm.mlir.constant(2 : i64) : i64
%65 = llvm.extractvalue %37[3, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%66 = llvm.getelementptr %52[%64] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %65, %66 : !llvm.ptr<i64>
%67 = llvm.extractvalue %37[4, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%68 = llvm.getelementptr %53[%64] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %67, %68 : !llvm.ptr<i64>
%69 = llvm.mlir.constant(3 : i64) : i64
%70 = llvm.extractvalue %37[3, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%71 = llvm.getelementptr %52[%69] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %70, %71 : !llvm.ptr<i64>
%72 = llvm.extractvalue %37[4, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%73 = llvm.getelementptr %53[%69] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %72, %73 : !llvm.ptr<i64>
%74 = llvm.mlir.constant(0 : i64) : i64
%75 = llvm.getelementptr %43[%74] : (!llvm.ptr<ptr<i8>>, i64) -> !llvm.ptr<ptr<i8>>
llvm.store %45, %75 : !llvm.ptr<ptr<i8>>
%76 = llvm.mlir.constant(0 : i64) : i64
%77 = llvm.call @omTensorCreateUntyped(%76) : (i64) -> !llvm.ptr<i8>
%78 = llvm.mlir.constant(1 : i64) : i64
%79 = llvm.extractvalue %38[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%80 = llvm.bitcast %79 : !llvm.ptr<i32> to !llvm.ptr<i8>
%81 = llvm.extractvalue %38[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64)>
%82 = llvm.bitcast %81 : !llvm.ptr<i32> to !llvm.ptr<i8>
llvm.call @omTensorSetDataPtr(%77, %78, %80, %82) : (!llvm.ptr<i8>, i64, !llvm.ptr<i8>, !llvm.ptr<i8>) -> ()
%83 = llvm.mlir.constant(6 : i64) : i64
llvm.call @omTensorSetDataType(%77, %83) : (!llvm.ptr<i8>, i64) -> ()
%84 = llvm.call @omTensorGetShape(%77) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%85 = llvm.call @omTensorGetStrides(%77) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%86 = llvm.mlir.constant(1 : i64) : i64
%87 = llvm.getelementptr %43[%86] : (!llvm.ptr<ptr<i8>>, i64) -> !llvm.ptr<ptr<i8>>
llvm.store %77, %87 : !llvm.ptr<ptr<i8>>
%88 = llvm.mlir.constant(4 : i64) : i64
%89 = llvm.call @omTensorCreateUntyped(%88) : (i64) -> !llvm.ptr<i8>
%90 = llvm.mlir.constant(1 : i64) : i64
%91 = llvm.extractvalue %39[0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%92 = llvm.bitcast %91 : !llvm.ptr<i32> to !llvm.ptr<i8>
%93 = llvm.extractvalue %39[1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%94 = llvm.bitcast %93 : !llvm.ptr<i32> to !llvm.ptr<i8>
llvm.call @omTensorSetDataPtr(%89, %90, %92, %94) : (!llvm.ptr<i8>, i64, !llvm.ptr<i8>, !llvm.ptr<i8>) -> ()
%95 = llvm.mlir.constant(6 : i64) : i64
llvm.call @omTensorSetDataType(%89, %95) : (!llvm.ptr<i8>, i64) -> ()
%96 = llvm.call @omTensorGetShape(%89) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%97 = llvm.call @omTensorGetStrides(%89) : (!llvm.ptr<i8>) -> !llvm.ptr<i64>
%98 = llvm.mlir.constant(0 : i64) : i64
%99 = llvm.extractvalue %39[3, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%100 = llvm.getelementptr %96[%98] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %99, %100 : !llvm.ptr<i64>
%101 = llvm.extractvalue %39[4, 0] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%102 = llvm.getelementptr %97[%98] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %101, %102 : !llvm.ptr<i64>
%103 = llvm.mlir.constant(1 : i64) : i64
%104 = llvm.extractvalue %39[3, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%105 = llvm.getelementptr %96[%103] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %104, %105 : !llvm.ptr<i64>
%106 = llvm.extractvalue %39[4, 1] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%107 = llvm.getelementptr %97[%103] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %106, %107 : !llvm.ptr<i64>
%108 = llvm.mlir.constant(2 : i64) : i64
%109 = llvm.extractvalue %39[3, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%110 = llvm.getelementptr %96[%108] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %109, %110 : !llvm.ptr<i64>
%111 = llvm.extractvalue %39[4, 2] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%112 = llvm.getelementptr %97[%108] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %111, %112 : !llvm.ptr<i64>
%113 = llvm.mlir.constant(3 : i64) : i64
%114 = llvm.extractvalue %39[3, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%115 = llvm.getelementptr %96[%113] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %114, %115 : !llvm.ptr<i64>
%116 = llvm.extractvalue %39[4, 3] : !llvm.struct<(ptr<i32>, ptr<i32>, i64, array<4 x i64>, array<4 x i64>)>
%117 = llvm.getelementptr %97[%113] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
llvm.store %116, %117 : !llvm.ptr<i64>
%118 = llvm.mlir.constant(2 : i64) : i64
%119 = llvm.getelementptr %43[%118] : (!llvm.ptr<ptr<i8>>, i64) -> !llvm.ptr<ptr<i8>>
llvm.store %89, %119 : !llvm.ptr<ptr<i8>>
%120 = llvm.call @omTensorListCreate(%43, %40, %1) : (!llvm.ptr<ptr<i8>>, i64, i64) -> !llvm.ptr<i8>
llvm.return %120 : !llvm.ptr<i8>
}
llvm.mlir.global internal constant @_entry_point_arrays() {addr_space = 0 : i32} : !llvm.array<2 x ptr<i8>> {
%0 = llvm.mlir.undef : !llvm.array<2 x ptr<i8>>
%1 = llvm.mlir.addressof @_entry_point_0 : !llvm.ptr<array<15 x i8>>
%2 = llvm.mlir.constant(0 : i64) : i64
%3 = llvm.getelementptr %1[%2, %2] : (!llvm.ptr<array<15 x i8>>, i64, i64) -> !llvm.ptr<i8>
%4 = llvm.insertvalue %3, %0[0] : !llvm.array<2 x ptr<i8>>
%5 = llvm.mlir.null : !llvm.ptr<i8>
%6 = llvm.insertvalue %5, %4[1] : !llvm.array<2 x ptr<i8>>
llvm.return %6 : !llvm.array<2 x ptr<i8>>
}
llvm.func @omQueryEntryPoints(%arg0: !llvm.ptr<i64>) -> !llvm.ptr<ptr<i8>> {
%0 = llvm.mlir.null : !llvm.ptr<i64>
%1 = llvm.icmp "ne" %arg0, %0 : !llvm.ptr<i64>
llvm.cond_br %1, ^bb1, ^bb2
^bb1: // pred: ^bb0
%2 = llvm.mlir.constant(0 : i64) : i64
%3 = llvm.getelementptr %arg0[%2] : (!llvm.ptr<i64>, i64) -> !llvm.ptr<i64>
%4 = llvm.mlir.constant(1 : i64) : i64
llvm.store %4, %3 : !llvm.ptr<i64>
llvm.br ^bb2
^bb2: // 2 preds: ^bb0, ^bb1
%5 = llvm.mlir.addressof @_entry_point_arrays : !llvm.ptr<array<2 x ptr<i8>>>
%6 = llvm.bitcast %5 : !llvm.ptr<array<2 x ptr<i8>>> to !llvm.ptr<ptr<i8>>
llvm.return %6 : !llvm.ptr<ptr<i8>>
}
llvm.func @omInputSignature(%arg0: !llvm.ptr<i8>) -> !llvm.ptr<i8> {
%0 = llvm.mlir.constant(0 : i32) : i32
%1 = llvm.mlir.addressof @_entry_point_0 : !llvm.ptr<array<15 x i8>>
%2 = llvm.mlir.constant(0 : i64) : i64
%3 = llvm.getelementptr %1[%2, %2] : (!llvm.ptr<array<15 x i8>>, i64, i64) -> !llvm.ptr<i8>
%4 = llvm.mlir.constant(15 : i64) : i64
%5 = llvm.call @strncmp(%arg0, %3, %4) : (!llvm.ptr<i8>, !llvm.ptr<i8>, i64) -> i32
%6 = llvm.icmp "eq" %5, %0 : i32
llvm.cond_br %6, ^bb1, ^bb2
^bb1: // pred: ^bb0
%7 = llvm.mlir.addressof @_entry_point_0_in_sig : !llvm.ptr<array<117 x i8>>
%8 = llvm.bitcast %7 : !llvm.ptr<array<117 x i8>> to !llvm.ptr<i8>
llvm.return %8 : !llvm.ptr<i8>
^bb2: // pred: ^bb0
%9 = llvm.mlir.null : !llvm.ptr<i8>
llvm.return %9 : !llvm.ptr<i8>
}
llvm.func @omOutputSignature(%arg0: !llvm.ptr<i8>) -> !llvm.ptr<i8> {
%0 = llvm.mlir.constant(0 : i32) : i32
%1 = llvm.mlir.addressof @_entry_point_0 : !llvm.ptr<array<15 x i8>>
%2 = llvm.mlir.constant(0 : i64) : i64
%3 = llvm.getelementptr %1[%2, %2] : (!llvm.ptr<array<15 x i8>>, i64, i64) -> !llvm.ptr<i8>
%4 = llvm.mlir.constant(15 : i64) : i64
%5 = llvm.call @strncmp(%arg0, %3, %4) : (!llvm.ptr<i8>, !llvm.ptr<i8>, i64) -> i32
%6 = llvm.icmp "eq" %5, %0 : i32
llvm.cond_br %6, ^bb1, ^bb2
^bb1: // pred: ^bb0
%7 = llvm.mlir.addressof @_entry_point_0_out_sig : !llvm.ptr<array<198 x i8>>
%8 = llvm.bitcast %7 : !llvm.ptr<array<198 x i8>> to !llvm.ptr<i8>
llvm.return %8 : !llvm.ptr<i8>
^bb2: // pred: ^bb0
%9 = llvm.mlir.null : !llvm.ptr<i8>
llvm.return %9 : !llvm.ptr<i8>
}
}