[flang] Accept polymorphic component element in storage_size
[llvm-project.git] / flang / test / Fir / convert-to-llvm-target.fir
blobc580056e2e17f8566523bf8a5aedc10cd215c325
1 // RUN: fir-opt --split-input-file --fir-to-llvm-ir="target=x86_64-unknown-linux-gnu" %s | FileCheck %s --check-prefix INT64
2 // RUN: fir-opt --split-input-file --fir-to-llvm-ir="target=aarch64-unknown-linux-gnu" %s | FileCheck %s --check-prefixes INT64
3 // RUN: fir-opt --split-input-file --fir-to-llvm-ir="target=i386-unknown-linux-gnu" %s | FileCheck %s --check-prefixes INT32
4 // RUN: fir-opt --split-input-file --fir-to-llvm-ir="target=powerpc64le-unknown-linux-gn" %s | FileCheck %s --check-prefixes INT64
6 //=============================================================================
7 // SUMMARY: Tests for FIR --> LLVM MLIR conversion that *depend* on the target
8 //=============================================================================
10 // Test fir.emboxchar
12 func.func @test_embox(%char_array : !fir.ref<!fir.char<1,?>>) -> () {
13   %c10 = arith.constant 10 : i64
14   %box_char = fir.emboxchar %char_array, %c10 : (!fir.ref<!fir.char<1,?>>, i64) -> !fir.boxchar<1>
15   return
18 // INT64-LABEL: test_embox
19 // INT64-SAME: (%[[char_array:.*]]: !llvm.ptr<i8>)
20 // INT64:    %[[c10:.*]] = llvm.mlir.constant(10 : i64) : i64
21 // INT64:    %[[empty_struct:.*]] = llvm.mlir.undef : !llvm.struct<(ptr<i8>, i{{.*}})>
22 // INT64:    %[[struct_with_buffer:.*]] = llvm.insertvalue %[[char_array]], %[[empty_struct]][0] : !llvm.struct<(ptr<i8>, i{{.*}})>
23 // INT64:    %{{.*}} = llvm.insertvalue %[[c10]], %[[struct_with_buffer]][1] : !llvm.struct<(ptr<i8>, i{{.*}})>
24 // INT64-NEXT:    llvm.return
26 // INT32-LABEL:  llvm.func @test_embox
27 // INT32-SAME: %[[char_array:.*]]: !llvm.ptr<i8>)
28 // INT32:    %[[c10:.*]] = llvm.mlir.constant(10 : i64) : i64
29 // INT32:    %[[empty_struct:.*]] = llvm.mlir.undef : !llvm.struct<(ptr<i8>, i32)>
30 // INT32:    %[[c10_truncated:.*]] = llvm.trunc %[[c10]] : i64 to i32
31 // INT32:    %[[struct_with_buffer:.*]] = llvm.insertvalue %[[char_array]], %[[empty_struct]][0] : !llvm.struct<(ptr<i8>, i32)>
32 // INT32:    %{{.*}} = llvm.insertvalue %[[c10_truncated:.*]], %[[struct_with_buffer]][1] : !llvm.struct<(ptr<i8>, i32)>
33 // INT32-NEXT:    llvm.return
35 // -----
37 // Test fir.unboxchar
39 func.func @unboxchar_i8(%arg0 : !fir.boxchar<1>) -> () {
40   %0:2 = fir.unboxchar %arg0 : (!fir.boxchar<1>) -> (!fir.ref<!fir.char<1>>, i64)
41   return
44 // INT64-LABEL: llvm.func @unboxchar_i8
45 // INT64-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i8>, i64)>
46 // INT64:  %{{.*}} = llvm.extractvalue %[[box_char]][0] : !llvm.struct<(ptr<i8>, i64)>
47 // INT64:  %{{.*}} = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i8>, i64)>
48 // INT64-NEXT:  llvm.return
50 // INT32-LABEL: llvm.func @unboxchar_i8
51 // INT32-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i8>, i32)>
52 // INT32:  %{{.*}} = llvm.extractvalue %[[box_char]][0] : !llvm.struct<(ptr<i8>, i32)>
53 // INT32:  %[[len_unextended:.*]] = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i8>, i32)>
54 // INT32:  %{{.*}} = llvm.sext %[[len_unextended]] : i32 to i64
55 // INT32-NEXT:  llvm.return
57 func.func @unboxchar_i32(%arg0 : !fir.boxchar<4>) -> () {
58   fir.unboxchar %arg0 : (!fir.boxchar<4>) -> (!fir.ref<!fir.char<4>>, i64)
59   return
62 // INT64-LABEL: llvm.func @unboxchar_i32
63 // INT64-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i32>, i64)>
64 // INT64:  %{{.*}} = llvm.extractvalue %[[box_char]][0] : !llvm.struct<(ptr<i32>, i64)>
65 // INT64:  %{{.*}} = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i32>, i64)>
66 // INT64-NEXT:  llvm.return
68 // INT32-LABEL: llvm.func @unboxchar_i32
69 // INT32-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i32>, i32)>
70 // INT32:  %{{.*}} = llvm.extractvalue %[[box_char]][0] : !llvm.struct<(ptr<i32>, i32)>
71 // INT32:  %[[len_unextended:.*]] = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i32>, i32)>
72 // INT32:  %{{.*}} = llvm.sext %[[len_unextended]] : i32 to i64
73 // INT32-NEXT:  llvm.return
75 // -----
77 // Test fir.boxchar_len
79 func.func @boxchar_len_i8_i32(%arg0 : !fir.boxchar<1>) -> () {
80   fir.boxchar_len %arg0 : (!fir.boxchar<1>) -> i32
81   return
84 // INT64-LABEL: llvm.func @boxchar_len_i8_i32
85 // INT64-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i8>, i64)>
86 // INT64:  %[[len:.*]] = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i8>, i64)>
87 // INT64: %{{.*}} = llvm.trunc %[[len]] : i64 to i32
88 // INT64-NEXT:  llvm.return
90 // INT32-LABEL: llvm.func @boxchar_len_i8_i32
91 // INT32-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i8>, i32)>
92 // INT32:  %{{.*}} = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i8>, i32)>
93 // INT32-NOT:  llvm.trunc
94 // INT32-NOT:  llvm.sext
95 // INT32-NEXT:  llvm.return
97 func.func @boxchar_len_i8_i64(%arg0 : !fir.boxchar<1>) -> () {
98   fir.boxchar_len %arg0 : (!fir.boxchar<1>) -> i64
99   return
102 // INT64-LABEL: llvm.func @boxchar_len_i8_i64
103 // INT64-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i8>, i64)>
104 // INT64:  %{{.*}} = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i8>, i64)>
105 // INT64-NOT:  llvm.trunc
106 // INT64-NOT:  llvm.sext
107 // INT64-NEXT:  llvm.return
109 // INT32-LABEL: llvm.func @boxchar_len_i8_i64
110 // INT32-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i8>, i32)>
111 // INT32:  %[[len:.*]] = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i8>, i32)>
112 // INT32:  %{{.*}} = llvm.sext %0 : i32 to i64
113 // INT32-NEXT:  llvm.return
115 func.func @boxchar_len_i32_i32(%arg0 : !fir.boxchar<4>) -> () {
116   fir.boxchar_len %arg0 : (!fir.boxchar<4>) -> i32
117   return
120 // INT64-LABEL: llvm.func @boxchar_len_i32_i32
121 // INT64-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i32>, i64)>
122 // INT64:  %[[len:.*]] = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i32>, i64)>
123 // INT64: %{{.*}} = llvm.trunc %[[len]] : i64 to i32
124 // INT64-NEXT:  llvm.return
126 // INT32-LABEL: llvm.func @boxchar_len_i32_i32
127 // INT32-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i32>, i32)>
128 // INT32:  %{{.*}} = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i32>, i32)>
129 // INT32-NOT:  llvm.trunc
130 // INT32-NOT:  llvm.sext
131 // INT32-NEXT:  llvm.return
133 func.func @boxchar_len_i32_i64(%arg0 : !fir.boxchar<4>) -> (i64) {
134   %0 = fir.boxchar_len %arg0 : (!fir.boxchar<4>) -> i64
135   return %0 : i64
138 // INT64-LABEL: llvm.func @boxchar_len_i32_i64
139 // INT64-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i32>, i64)>
140 // INT64:  %{{.*}} = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i32>, i64)>
141 // INT64-NOT:  llvm.trunc
142 // INT64-NOT:  llvm.sext
143 // INT64-NEXT:  llvm.return
145 // INT32-LABEL: llvm.func @boxchar_len_i32_i64
146 // INT32-SAME: %[[box_char:.*]]: !llvm.struct<(ptr<i32>, i32)>
147 // INT32:  %[[len:.*]] = llvm.extractvalue %[[box_char]][1] : !llvm.struct<(ptr<i32>, i32)>
148 // INT32:  %{{.*}} = llvm.sext %0 : i32 to i64
149 // INT32-NEXT:  llvm.return