1*179ea355SValentin Clement! RUN: bbc -emit-fir %s -o - | FileCheck %s 2*179ea355SValentin Clement! RUN: bbc -emit-fir -use-alloc-runtime %s -o - | FileCheck %s 3*179ea355SValentin Clement 4*179ea355SValentin Clement! Test global allocatable definition lowering 5*179ea355SValentin Clement 6*179ea355SValentin Clement! CHECK-LABEL: fir.global @_QMmod_allocatablesEc : !fir.box<!fir.heap<!fir.array<?x!fir.char<1,10>>>> { 7*179ea355SValentin Clement ! CHECK-DAG: %[[modcNullAddr:.*]] = fir.zero_bits !fir.heap<!fir.array<?x!fir.char<1,10>>> 8*179ea355SValentin Clement ! CHECK-DAG: %[[modcShape:.*]] = fir.shape %c0{{.*}} : (index) -> !fir.shape<1> 9*179ea355SValentin Clement ! CHECK: %[[modcInitBox:.*]] = fir.embox %[[modcNullAddr]](%[[modcShape]]) : (!fir.heap<!fir.array<?x!fir.char<1,10>>>, !fir.shape<1>) -> !fir.box<!fir.heap<!fir.array<?x!fir.char<1,10>>>> 10*179ea355SValentin Clement ! CHECK: fir.has_value %[[modcInitBox]] : !fir.box<!fir.heap<!fir.array<?x!fir.char<1,10>>>> 11*179ea355SValentin Clement 12*179ea355SValentin Clementmodule mod_allocatables 13*179ea355SValentin Clement character(10), allocatable :: c(:) 14*179ea355SValentin Clementend module 15*179ea355SValentin Clement 16*179ea355SValentin Clement! CHECK-LABEL: func @_QPtest_mod_allocatables() 17*179ea355SValentin Clementsubroutine test_mod_allocatables() 18*179ea355SValentin Clement use mod_allocatables, only: c 19*179ea355SValentin Clement ! CHECK: fir.address_of(@_QMmod_allocatablesEc) : !fir.ref<!fir.box<!fir.heap<!fir.array<?x!fir.char<1,10>>>>> 20*179ea355SValentin Clement call bar(c(1)) 21*179ea355SValentin Clementend subroutine 22*179ea355SValentin Clement 23*179ea355SValentin Clement 24*179ea355SValentin Clement! CHECK-LABEL: func @_QPtest_globals() 25*179ea355SValentin Clementsubroutine test_globals() 26*179ea355SValentin Clement integer, allocatable :: gx, gy(:, :) 27*179ea355SValentin Clement save :: gx, gy 28*179ea355SValentin Clement ! CHECK-DAG: fir.address_of(@_QFtest_globalsEgx) : !fir.ref<!fir.box<!fir.heap<i32>>> 29*179ea355SValentin Clement ! CHECK-DAG: fir.address_of(@_QFtest_globalsEgy) : !fir.ref<!fir.box<!fir.heap<!fir.array<?x?xi32>>>> 30*179ea355SValentin Clement character(:), allocatable :: gc1, gc2(:, :) 31*179ea355SValentin Clement character(10), allocatable :: gc3, gc4(:, :) 32*179ea355SValentin Clement save :: gc1, gc2, gc3, gc4 33*179ea355SValentin Clement ! CHECK-DAG: fir.address_of(@_QFtest_globalsEgc1) : !fir.ref<!fir.box<!fir.heap<!fir.char<1,?>>>> 34*179ea355SValentin Clement ! CHECK-DAG: fir.address_of(@_QFtest_globalsEgc2) : !fir.ref<!fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,?>>>>> 35*179ea355SValentin Clement ! CHECK-DAG: fir.address_of(@_QFtest_globalsEgc3) : !fir.ref<!fir.box<!fir.heap<!fir.char<1,10>>>> 36*179ea355SValentin Clement ! CHECK-DAG: fir.address_of(@_QFtest_globalsEgc4) : !fir.ref<!fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,10>>>>> 37*179ea355SValentin Clement allocate(gx, gy(20, 30), gc3, gc4(40, 50)) 38*179ea355SValentin Clement allocate(character(15):: gc1, gc2(60, 70)) 39*179ea355SValentin Clementend subroutine 40*179ea355SValentin Clement 41*179ea355SValentin Clement! CHECK-LABEL: fir.global internal @_QFtest_globalsEgc1 : !fir.box<!fir.heap<!fir.char<1,?>>> 42*179ea355SValentin Clement ! CHECK-DAG: %[[gc1NullAddr:.*]] = fir.zero_bits !fir.heap<!fir.char<1,?>> 43*179ea355SValentin Clement ! CHECK: %[[gc1InitBox:.*]] = fir.embox %[[gc1NullAddr]] typeparams %c0{{.*}} : (!fir.heap<!fir.char<1,?>>, index) -> !fir.box<!fir.heap<!fir.char<1,?>>> 44*179ea355SValentin Clement ! CHECK: fir.has_value %[[gc1InitBox]] : !fir.box<!fir.heap<!fir.char<1,?>>> 45*179ea355SValentin Clement 46*179ea355SValentin Clement! CHECK-LABEL: fir.global internal @_QFtest_globalsEgc2 : !fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,?>>>> 47*179ea355SValentin Clement ! CHECK-DAG: %[[gc2NullAddr:.*]] = fir.zero_bits !fir.heap<!fir.array<?x?x!fir.char<1,?>>> 48*179ea355SValentin Clement ! CHECK-DAG: %[[gc2NullShape:.*]] = fir.shape %c0{{.*}}, %c0{{.*}} : (index, index) -> !fir.shape<2> 49*179ea355SValentin Clement ! CHECK: %[[gc2InitBox:.*]] = fir.embox %[[gc2NullAddr]](%[[gc2NullShape]]) typeparams %c0{{.*}} : (!fir.heap<!fir.array<?x?x!fir.char<1,?>>>, !fir.shape<2>, index) -> !fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,?>>>> 50*179ea355SValentin Clement ! CHECK: fir.has_value %[[gc2InitBox]] : !fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,?>>>> 51*179ea355SValentin Clement 52*179ea355SValentin Clement! CHECK-LABEL: fir.global internal @_QFtest_globalsEgc3 : !fir.box<!fir.heap<!fir.char<1,10>>> 53*179ea355SValentin Clement ! CHECK-DAG: %[[gc3NullAddr:.*]] = fir.zero_bits !fir.heap<!fir.char<1,10>> 54*179ea355SValentin Clement ! CHECK: %[[gc3InitBox:.*]] = fir.embox %[[gc3NullAddr]] : (!fir.heap<!fir.char<1,10>>) -> !fir.box<!fir.heap<!fir.char<1,10>>> 55*179ea355SValentin Clement ! CHECK: fir.has_value %[[gc3InitBox]] : !fir.box<!fir.heap<!fir.char<1,10>>> 56*179ea355SValentin Clement 57*179ea355SValentin Clement! CHECK-LABEL: fir.global internal @_QFtest_globalsEgc4 : !fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,10>>>> 58*179ea355SValentin Clement ! CHECK-DAG: %[[gc4NullAddr:.*]] = fir.zero_bits !fir.heap<!fir.array<?x?x!fir.char<1,10>>> 59*179ea355SValentin Clement ! CHECK-DAG: %[[gc4NullShape:.*]] = fir.shape %c0{{.*}}, %c0{{.*}} : (index, index) -> !fir.shape<2> 60*179ea355SValentin Clement ! CHECK: %[[gc4InitBox:.*]] = fir.embox %[[gc4NullAddr]](%[[gc4NullShape]]) : (!fir.heap<!fir.array<?x?x!fir.char<1,10>>>, !fir.shape<2>) -> !fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,10>>>> 61*179ea355SValentin Clement ! CHECK: fir.has_value %[[gc4InitBox]] : !fir.box<!fir.heap<!fir.array<?x?x!fir.char<1,10>>>> 62*179ea355SValentin Clement 63*179ea355SValentin Clement! CHECK-LABEL: fir.global internal @_QFtest_globalsEgx : !fir.box<!fir.heap<i32>> 64*179ea355SValentin Clement ! CHECK: %[[gxNullAddr:.*]] = fir.zero_bits !fir.heap<i32> 65*179ea355SValentin Clement ! CHECK: %[[gxInitBox:.*]] = fir.embox %0 : (!fir.heap<i32>) -> !fir.box<!fir.heap<i32>> 66*179ea355SValentin Clement ! CHECK: fir.has_value %[[gxInitBox]] : !fir.box<!fir.heap<i32>> 67*179ea355SValentin Clement 68*179ea355SValentin Clement! CHECK-LABEL: fir.global internal @_QFtest_globalsEgy : !fir.box<!fir.heap<!fir.array<?x?xi32>>> { 69*179ea355SValentin Clement ! CHECK-DAG: %[[gyNullAddr:.*]] = fir.zero_bits !fir.heap<!fir.array<?x?xi32>> 70*179ea355SValentin Clement ! CHECK-DAG: %[[gyShape:.*]] = fir.shape %c0{{.*}}, %c0{{.*}} : (index, index) -> !fir.shape<2> 71*179ea355SValentin Clement ! CHECK: %[[gyInitBox:.*]] = fir.embox %[[gyNullAddr]](%[[gyShape]]) : (!fir.heap<!fir.array<?x?xi32>>, !fir.shape<2>) -> !fir.box<!fir.heap<!fir.array<?x?xi32>>> 72*179ea355SValentin Clement ! CHECK: fir.has_value %[[gyInitBox]] : !fir.box<!fir.heap<!fir.array<?x?xi32>>> 73