blob: 4236fe63267417083514a2757d6ab91b89330fc7 [file] [log] [blame] [edit]
! RUN: flang -fc1 -emit-fir -fwrapv %s -o - | FileCheck %s
module cs
type r
integer n, d
end type r
type t2
integer :: f1(5)
type(r) :: f2
end type t2
type t3
type(t2) :: f(3,3)
end type t3
contains
! CHECK-LABEL: func.func @_QMcsPc1(
! CHECK-SAME: %[[arg0:[^:]+]]: !fir.box<!fir.array<?x!fir.type<_QMcsTr{n:i32,d:i32}>>>{{.*}}, %[[arg1:[^:]+]]: !fir.box<!fir.array<?x!fir.type<_QMcsTr{n:i32,d:i32}>>>{{.*}}) -> !fir.logical<1> {
function c1(e, c)
type(r), intent(in) :: e(:), c(:)
logical*1 :: c1
! CHECK-DAG: %[[c1_ref:.*]] = fir.alloca !fir.logical<1>
! CHECK-DAG: %[[c_decl:.*]] = fir.declare %[[arg1]] {{.*}}
! CHECK-DAG: %[[c_rebox:.*]] = fir.rebox %[[c_decl]] : {{.*}}
! CHECK-DAG: %[[e_decl:.*]] = fir.declare %[[arg0]] {{.*}}
! CHECK-DAG: %[[e_rebox:.*]] = fir.rebox %[[e_decl]] : {{.*}}
! CHECK-DAG: %[[fldn_c:.*]] = fir.field_index n, !fir.type<_QMcsTr{n:i32,d:i32}>
! CHECK: %[[slice_c:.*]] = fir.slice {{.*}} path %[[fldn_c]] : (index, index, index, !fir.field) -> !fir.slice<1>
! CHECK: %[[c_n_rebox:.*]] = fir.rebox %[[c_rebox]] [%[[slice_c]]]
! CHECK-DAG: %[[fldn_e:.*]] = fir.field_index n, !fir.type<_QMcsTr{n:i32,d:i32}>
! CHECK: %[[slice_e:.*]] = fir.slice {{.*}} path %[[fldn_e]] : (index, index, index, !fir.field) -> !fir.slice<1>
! CHECK: %[[e_n_rebox:.*]] = fir.rebox %[[e_rebox]] [%[[slice_e]]]
! CHECK: fir.do_loop {{.*}} {
! CHECK: %[[c_addr:.*]] = fir.array_coor %[[c_n_rebox]]
! CHECK: %[[e_addr:.*]] = fir.array_coor %[[e_n_rebox]]
! CHECK: %[[c_val:.*]] = fir.load %[[c_addr]]
! CHECK: %[[e_val:.*]] = fir.load %[[e_addr]]
! CHECK: %[[cmp:.*]] = arith.cmpi eq, %[[c_val]], %[[e_val]]
! CHECK: {{.*}} = fir.convert %[[cmp]] : (i1) -> !fir.logical<4>
! CHECK: fir.store {{.*}}
! CHECK: }
c1 = all(c%n == e%n)
end function c1
! CHECK-LABEL: func.func @_QMcsPtest2(
! CHECK-SAME: %[[arg0:[^:]+]]: !fir.box<!fir.array<?x!fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>>>{{.*}}, %[[arg1:[^:]+]]: !fir.box<!fir.array<?x!fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>>>{{.*}}) {
subroutine test2(a1, a2)
type(t2) :: a1(:), a2(:)
! CHECK-DAG: %[[a1_decl:.*]] = fir.declare %[[arg0]] {{.*}}
! CHECK-DAG: %[[a1_rebox:.*]] = fir.rebox %[[a1_decl]] : {{.*}}
! CHECK-DAG: %[[a2_decl:.*]] = fir.declare %[[arg1]] {{.*}}
! CHECK-DAG: %[[a2_rebox:.*]] = fir.rebox %[[a2_decl]] : {{.*}}
! slice for a2%f1(1)
! CHECK-DAG: %[[fld_f1_1:.*]] = fir.field_index f1, !fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>
! CHECK: %[[slice_a2_f1_1:.*]] = fir.slice {{.*}} path %[[fld_f1_1]], {{.*}}
! CHECK: %[[a2_f1_1_rebox:.*]] = fir.rebox %[[a2_rebox]] [%[[slice_a2_f1_1]]]
! slice for a2%f1(5)
! CHECK-DAG: %[[fld_f1_5:.*]] = fir.field_index f1, !fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>
! CHECK: %[[slice_a2_f1_5:.*]] = fir.slice {{.*}} path %[[fld_f1_5]], {{.*}}
! CHECK: %[[a2_f1_5_rebox:.*]] = fir.rebox %[[a2_rebox]] [%[[slice_a2_f1_5]]]
! slice for a2%f1(3)
! CHECK-DAG: %[[fld_f1_3:.*]] = fir.field_index f1, !fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>
! CHECK: %[[slice_a2_f1_3:.*]] = fir.slice {{.*}} path %[[fld_f1_3]], {{.*}}
! CHECK: %[[a2_f1_3_rebox:.*]] = fir.rebox %[[a2_rebox]] [%[[slice_a2_f1_3]]]
! RHS computation
! CHECK: %[[temp:.*]] = fir.allocmem !fir.array<?xi32>
! CHECK: fir.do_loop {{.*}} {
! CHECK: %[[val_f1_5:.*]] = fir.load {{.*}}
! CHECK: %[[val_f1_3:.*]] = fir.load {{.*}}
! CHECK: %[[div:.*]] = arith.divsi %[[val_f1_5]], %[[val_f1_3]]
! CHECK: %[[val_f1_1:.*]] = fir.load {{.*}}
! CHECK: %[[sum:.*]] = arith.addi %[[val_f1_1]], %[[div]]
! CHECK: fir.store %[[sum]] to {{.*}}
! CHECK: }
! slice for a1%f2%d
! CHECK-DAG: %[[fld_f2:.*]] = fir.field_index f2, !fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>
! CHECK: %[[slice_a1_f2:.*]] = fir.slice {{.*}} path %[[fld_f2]] : (index, index, index, !fir.field) -> !fir.slice<1>
! CHECK: %[[a1_f2_rebox:.*]] = fir.rebox %[[a1_rebox]] [%[[slice_a1_f2]]]
! CHECK-DAG: %[[fld_d:.*]] = fir.field_index d, !fir.type<_QMcsTr{n:i32,d:i32}>
! CHECK: %[[slice_d:.*]] = fir.slice {{.*}} path %[[fld_d]] : (index, index, index, !fir.field) -> !fir.slice<1>
! CHECK: %[[a1_f2_d_rebox:.*]] = fir.rebox %[[a1_f2_rebox]] [%[[slice_d]]]
! Assignment
! CHECK: fir.call @_FortranAAssign
a1%f2%d = a2%f1(1) + a2%f1(5) / a2%f1(3)
end subroutine test2
! CHECK-LABEL: func.func @_QMcsPtest3(
! CHECK-SAME: %[[arg0:[^:]+]]: !fir.box<!fir.array<?x!fir.type<_QMcsTt3{f:!fir.array<3x3x!fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>>}>>>{{.*}}, %[[arg1:[^:]+]]: !fir.box<!fir.array<?x!fir.type<_QMcsTt3{f:!fir.array<3x3x!fir.type<_QMcsTt2{f1:!fir.array<5xi32>,f2:!fir.type<_QMcsTr{n:i32,d:i32}>}>>}>>>{{.*}}) {
subroutine test3(a3, a4)
type(t3) :: a3(:), a4(:)
! CHECK-DAG: %[[a3_decl:.*]] = fir.declare %[[arg0]] {{.*}}
! CHECK-DAG: %[[a3_rebox:.*]] = fir.rebox %[[a3_decl]] : {{.*}}
! CHECK-DAG: %[[a4_decl:.*]] = fir.declare %[[arg1]] {{.*}}
! CHECK-DAG: %[[a4_rebox:.*]] = fir.rebox %[[a4_decl]] : {{.*}}
! Assignment 1
! a3%f(1,1)%f2%n = a4%f(2,2)%f1(4) - 4
! RHS: a4%f(2,2)%f1(4)
! CHECK: %[[slice_a4_f:.*]] = fir.slice {{.*}} path %{{.*}}, {{.*}}, {{.*}}
! CHECK: %[[a4_f_rebox:.*]] = fir.rebox %[[a4_rebox]] [%[[slice_a4_f]]]
! CHECK: %[[slice_a4_f1:.*]] = fir.slice {{.*}} path %{{.*}}, {{.*}}
! CHECK: %[[a4_f1_rebox:.*]] = fir.rebox %[[a4_f_rebox]] [%[[slice_a4_f1]]]
! CHECK: %[[temp1:.*]] = fir.allocmem !fir.array<?xi32>
! CHECK: fir.do_loop {{.*}} {
! CHECK: fir.load
! CHECK: arith.subi
! CHECK: fir.store
! CHECK: }
! LHS: a3%f(1,1)%f2%n
! CHECK: %[[slice_a3_f:.*]] = fir.slice {{.*}} path %{{.*}}, {{.*}}, {{.*}}
! CHECK: %[[a3_f_rebox:.*]] = fir.rebox %[[a3_rebox]] [%[[slice_a3_f]]]
! CHECK: %[[slice_a3_f2:.*]] = fir.slice {{.*}} path %{{.*}}
! CHECK: %[[a3_f2_rebox:.*]] = fir.rebox %[[a3_f_rebox]] [%[[slice_a3_f2]]]
! CHECK: %[[slice_a3_n:.*]] = fir.slice {{.*}} path %{{.*}}
! CHECK: %[[a3_n_rebox:.*]] = fir.rebox %[[a3_f2_rebox]] [%[[slice_a3_n]]]
! CHECK: fir.call @_FortranAAssign
a3%f(1,1)%f2%n = a4%f(2,2)%f1(4) - 4
! Assignment 2
! a4%f(3,3)%f1(2) = a3%f(1,2)%f2%d + 4
! CHECK: %[[temp2:.*]] = fir.allocmem !fir.array<?xi32>
! CHECK: fir.do_loop {{.*}} {
! CHECK: fir.load
! CHECK: arith.addi
! CHECK: fir.store
! CHECK: }
! CHECK: fir.call @_FortranAAssign
a4%f(3,3)%f1(2) = a3%f(1,2)%f2%d + 4
end subroutine test3
end module cs