// RUN: fir-opt --split-input-file --fir-add-alias-tags %s | FileCheck %s // subroutine oneArg(a) // integer :: a(:) // a(1) = a(2) // end subroutine func.func @_QPonearg(%arg0: !fir.box> {fir.bindc_name = "a"}) { %c1 = arith.constant 1 : index %c2 = arith.constant 2 : index %0 = fir.declare %arg0 {uniq_name = "_QFoneargEa"} : (!fir.box>) -> !fir.box> %1 = fir.rebox %0 : (!fir.box>) -> !fir.box> %2 = fir.array_coor %1 %c2 : (!fir.box>, index) -> !fir.ref %3 = fir.load %2 : !fir.ref %4 = fir.array_coor %1 %c1 : (!fir.box>, index) -> !fir.ref fir.store %3 to %4 : !fir.ref return } // CHECK: #[[ONE_ARG_ROOT:.+]] = #llvm.tbaa_root // CHECK: #[[ONE_ARG_ANY_ACCESS:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[ONE_ARG_ANY_DATA:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[ONE_ARG_ANY_ARG:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[ONE_ARG_A:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[ONE_ARG_A_TAG:.+]] = #llvm.tbaa_tag // CHECK-LABEL: func.func @_QPonearg( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box> {fir.bindc_name = "a"}) { // CHECK: %[[VAL_1:.*]] = arith.constant 1 : index // CHECK: %[[VAL_2:.*]] = arith.constant 2 : index // CHECK: %[[VAL_3:.*]] = fir.declare %[[VAL_0]] {uniq_name = "_QFoneargEa"} : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_4:.*]] = fir.rebox %[[VAL_3]] : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_5:.*]] = fir.array_coor %[[VAL_4]] %[[VAL_2]] : (!fir.box>, index) -> !fir.ref // CHECK: %[[VAL_6:.*]] = fir.load %[[VAL_5]] {tbaa = [#[[ONE_ARG_A_TAG]]]} : !fir.ref // CHECK: %[[VAL_7:.*]] = fir.array_coor %[[VAL_4]] %[[VAL_1]] : (!fir.box>, index) -> !fir.ref // CHECK: fir.store %[[VAL_6]] to %[[VAL_7]] {tbaa = [#[[ONE_ARG_A_TAG]]]} : !fir.ref // CHECK: return // CHECK: } // ----- // subroutine twoArg(a, b) // integer :: a(:), b(:) // a(1) = b(1) // end subroutine func.func @_QPtwoarg(%arg0: !fir.box> {fir.bindc_name = "a"}, %arg1: !fir.box> {fir.bindc_name = "b"}) { %c1 = arith.constant 1 : index %0 = fir.declare %arg0 {uniq_name = "_QFtwoargEa"} : (!fir.box>) -> !fir.box> %1 = fir.rebox %0 : (!fir.box>) -> !fir.box> %2 = fir.declare %arg1 {uniq_name = "_QFtwoargEb"} : (!fir.box>) -> !fir.box> %3 = fir.rebox %2 : (!fir.box>) -> !fir.box> %4 = fir.array_coor %3 %c1 : (!fir.box>, index) -> !fir.ref %5 = fir.load %4 : !fir.ref %6 = fir.array_coor %1 %c1 : (!fir.box>, index) -> !fir.ref fir.store %5 to %6 : !fir.ref return } // CHECK: #[[TWO_ARG_ROOT:.+]] = #llvm.tbaa_root // CHECK: #[[TWO_ARG_ANY_ACCESS:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TWO_ARG_ANY_DATA:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TWO_ARG_ANY_ARG:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TWO_ARG_B:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TWO_ARG_A:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TWO_ARG_B_TAG:.+]] = #llvm.tbaa_tag // CHECK: #[[TWO_ARG_A_TAG:.+]] = #llvm.tbaa_tag // CHECK-LABEL: func.func @_QPtwoarg( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box> {fir.bindc_name = "a"}, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box> {fir.bindc_name = "b"}) { // CHECK: %[[VAL_2:.*]] = arith.constant 1 : index // CHECK: %[[VAL_3:.*]] = fir.declare %[[VAL_0]] {uniq_name = "_QFtwoargEa"} : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_4:.*]] = fir.rebox %[[VAL_3]] : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_5:.*]] = fir.declare %[[VAL_1]] {uniq_name = "_QFtwoargEb"} : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_6:.*]] = fir.rebox %[[VAL_5]] : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_7:.*]] = fir.array_coor %[[VAL_6]] %[[VAL_2]] : (!fir.box>, index) -> !fir.ref // CHECK: %[[VAL_8:.*]] = fir.load %[[VAL_7]] {tbaa = [#[[TWO_ARG_B_TAG]]]} : !fir.ref // CHECK: %[[VAL_9:.*]] = fir.array_coor %[[VAL_4]] %[[VAL_2]] : (!fir.box>, index) -> !fir.ref // CHECK: fir.store %[[VAL_8]] to %[[VAL_9]] {tbaa = [#[[TWO_ARG_A_TAG]]]} : !fir.ref // CHECK: return // CHECK: } // ----- // subroutine targetArg(a, b) // integer, target :: a(:) // integer :: b(:) // a(1) = b(1) // end subroutine func.func @_QPtargetarg(%arg0: !fir.box> {fir.bindc_name = "a", fir.target}, %arg1: !fir.box> {fir.bindc_name = "b"}) { %c1 = arith.constant 1 : index %0 = fir.declare %arg0 {fortran_attrs = #fir.var_attrs, uniq_name = "_QFtargetargEa"} : (!fir.box>) -> !fir.box> %1 = fir.rebox %0 : (!fir.box>) -> !fir.box> %2 = fir.declare %arg1 {uniq_name = "_QFtargetargEb"} : (!fir.box>) -> !fir.box> %3 = fir.rebox %2 : (!fir.box>) -> !fir.box> %4 = fir.array_coor %3 %c1 : (!fir.box>, index) -> !fir.ref %5 = fir.load %4 : !fir.ref %6 = fir.array_coor %1 %c1 : (!fir.box>, index) -> !fir.ref fir.store %5 to %6 : !fir.ref return } // CHECK: #[[TARGET_ROOT:.+]] = #llvm.tbaa_root // CHECK: #[[TARGET_ANY_ACCESS:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TARGET_ANY_DATA:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TARGET_ANY_ARG:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TARGET_B:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[TARGET_B_TAG:.+]] = #llvm.tbaa_tag // No entry for "dummy arg data/a" because that pointer should get "any data access" becase it has the TARGET attribute // CHECK-LABEL: func.func @_QPtargetarg( // CHECK-SAME: %[[VAL_0:.*]]: !fir.box> {fir.bindc_name = "a", fir.target}, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box> {fir.bindc_name = "b"}) { // CHECK: %[[VAL_2:.*]] = arith.constant 1 : index // CHECK: %[[VAL_3:.*]] = fir.declare %[[VAL_0]] {fortran_attrs = #{{.*}}, uniq_name = "_QFtargetargEa"} : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_4:.*]] = fir.rebox %[[VAL_3]] : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_5:.*]] = fir.declare %[[VAL_1]] {uniq_name = "_QFtargetargEb"} : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_6:.*]] = fir.rebox %[[VAL_5]] : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_7:.*]] = fir.array_coor %[[VAL_6]] %[[VAL_2]] : (!fir.box>, index) -> !fir.ref // CHECK: %[[VAL_8:.*]] = fir.load %[[VAL_7]] {tbaa = [#[[TARGET_B_TAG]]]} : !fir.ref // CHECK: %[[VAL_9:.*]] = fir.array_coor %[[VAL_4]] %[[VAL_2]] : (!fir.box>, index) -> !fir.ref // "any data access" tag is added by TBAABuilder during CodeGen // CHECK: fir.store %[[VAL_8]] to %[[VAL_9]] : !fir.ref // CHECK: return // CHECK: } // ----- // subroutine pointerArg(a, b) // integer, pointer :: a(:) // integer :: b(:) // a(1) = b(1) // end subroutine func.func @_QPpointerarg(%arg0: !fir.ref>>> {fir.bindc_name = "a"}, %arg1: !fir.box> {fir.bindc_name = "b"}) { %c0 = arith.constant 0 : index %c1 = arith.constant 1 : index %0 = fir.declare %arg0 {fortran_attrs = #fir.var_attrs, uniq_name = "_QFpointerargEa"} : (!fir.ref>>>) -> !fir.ref>>> %1 = fir.declare %arg1 {uniq_name = "_QFpointerargEb"} : (!fir.box>) -> !fir.box> %2 = fir.rebox %1 : (!fir.box>) -> !fir.box> %3 = fir.array_coor %2 %c1 : (!fir.box>, index) -> !fir.ref %4 = fir.load %3 : !fir.ref %5 = fir.load %0 : !fir.ref>>> %6:3 = fir.box_dims %5, %c0 : (!fir.box>>, index) -> (index, index, index) %7 = fir.shift %6#0 : (index) -> !fir.shift<1> %8 = fir.array_coor %5(%7) %c1 : (!fir.box>>, !fir.shift<1>, index) -> !fir.ref fir.store %4 to %8 : !fir.ref return } // CHECK: #[[POINTER_ROOT:.+]] = #llvm.tbaa_root // CHECK: #[[POINTER_ANY_ACCESS:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[POINTER_ANY_DATA:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[POINTER_ANY_ARG:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[POINTER_B:.+]] = #llvm.tbaa_type_desc}> // CHECK: #[[POINTER_B_TAG:.+]] = #llvm.tbaa_tag // No entry for "dummy arg data/a" because that pointer should get "any data access" becase it has the POINTER attribute // CHECK-LABEL: func.func @_QPpointerarg( // CHECK-SAME: %[[VAL_0:.*]]: !fir.ref>>> {fir.bindc_name = "a"}, // CHECK-SAME: %[[VAL_1:.*]]: !fir.box> {fir.bindc_name = "b"}) { // CHECK: %[[VAL_2:.*]] = arith.constant 0 : index // CHECK: %[[VAL_3:.*]] = arith.constant 1 : index // CHECK: %[[VAL_4:.*]] = fir.declare %[[VAL_0]] {fortran_attrs = #{{.*}}, uniq_name = "_QFpointerargEa"} : (!fir.ref>>>) -> !fir.ref>>> // CHECK: %[[VAL_5:.*]] = fir.declare %[[VAL_1]] {uniq_name = "_QFpointerargEb"} : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_6:.*]] = fir.rebox %[[VAL_5]] : (!fir.box>) -> !fir.box> // CHECK: %[[VAL_7:.*]] = fir.array_coor %[[VAL_6]] %[[VAL_3]] : (!fir.box>, index) -> !fir.ref // CHECK: %[[VAL_8:.*]] = fir.load %[[VAL_7]] {tbaa = [#[[POINTER_B_TAG]]]} : !fir.ref // "any descriptor access" tag is added by TBAABuilder during CodeGen // CHECK: %[[VAL_9:.*]] = fir.load %[[VAL_4]] : !fir.ref>>> // CHECK: %[[VAL_10:.*]]:3 = fir.box_dims %[[VAL_9]], %[[VAL_2]] : (!fir.box>>, index) -> (index, index, index) // CHECK: %[[VAL_11:.*]] = fir.shift %[[VAL_10]]#0 : (index) -> !fir.shift<1> // CHECK: %[[VAL_12:.*]] = fir.array_coor %[[VAL_9]](%[[VAL_11]]) %[[VAL_3]] : (!fir.box>>, !fir.shift<1>, index) -> !fir.ref // "any data access" tag is added by TBAABuilder during CodeGen // CHECK: fir.store %[[VAL_8]] to %[[VAL_12]] : !fir.ref // CHECK: return // CHECK: }