blob: a53bdf3bf5ef114b8d59692ff1651d4e3e6829d3 [file] [log] [blame] [edit]
// Test conversions to index
// Test dynamically legal array coor ops, we should both keep a fir.array_coor
// and generate a memref.store
// example fortran code:
// subroutine func(a)
// integer :: a(4)
// end
//
// subroutine slice(a)
// integer :: a(8)
// call func(a(1:4))
// a(5) = 1
// a(1) = 2
// end
// RUN: fir-opt %s --fir-to-memref --allow-unregistered-dialect | FileCheck %s
// CHECK-LABEL: func.func @slice
// CHECK: [[C5:%.+]] = arith.constant 5 : index
// CHECK: [[C1_I32:%.+]] = arith.constant 1 : i32
// CHECK: [[C1:%.+]] = arith.constant 1 : index
// CHECK: [[C8:%.+]] = arith.constant 8 : index
// CHECK: [[DUMMY:%.+]] = fir.dummy_scope : !fir.dscope
// CHECK: [[SHAPE:%.+]] = fir.shape [[C8]] : (index) -> !fir.shape<1>
// CHECK: [[DECLARE:%.+]] = fir.declare %arg0([[SHAPE]]) dummy_scope [[DUMMY]]
// CHECK: [[COOR1:%.+]] = fir.array_coor [[DECLARE]]([[SHAPE]]) [[C1]] : (!fir.ref<!fir.array<8xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
// CHECK: [[SLICE:%.+]] = fir.convert [[COOR1]] : (!fir.ref<i32>) -> !fir.ref<!fir.array<4xi32>>
// CHECK: [[CONVERT:%.+]] = fir.convert [[DECLARE]] : (!fir.ref<!fir.array<8xi32>>) -> memref<8xi32>
// CHECK: [[C1B:%.+]] = arith.constant 1 : index
// CHECK: [[SUB:%.+]] = arith.subi [[C5]], [[C1B]] : index
// CHECK: [[MUL:%.+]] = arith.muli [[SUB]], [[C1B]] : index
// CHECK: [[SUB2:%.+]] = arith.subi [[C1B]], [[C1B]] : index
// CHECK: [[IDX:%.+]] = arith.addi [[MUL]], [[SUB2]] : index
// CHECK: memref.store [[C1_I32]], [[CONVERT]][[[IDX]]] : memref<8xi32>
func.func @slice(%arg0: !fir.ref<!fir.array<8xi32>>){
%c5 = arith.constant 5 : index
%c1_i32 = arith.constant 1 : i32
%c1 = arith.constant 1 : index
%c8 = arith.constant 8 : index
%0 = fir.dummy_scope : !fir.dscope
%1 = fir.shape %c8 : (index) -> !fir.shape<1>
%2 = fir.declare %arg0(%1) dummy_scope %0 {uniq_name = "_QFsliceEa"} : (!fir.ref<!fir.array<8xi32>>, !fir.shape<1>, !fir.dscope) -> !fir.ref<!fir.array<8xi32>>
%3 = fir.array_coor %2(%1) %c1 : (!fir.ref<!fir.array<8xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
%4 = fir.convert %3 : (!fir.ref<i32>) -> !fir.ref<!fir.array<4xi32>>
%5 = fir.array_coor %2(%1) %c5 : (!fir.ref<!fir.array<8xi32>>, !fir.shape<1>, index) -> !fir.ref<i32>
fir.store %c1_i32 to %5 : !fir.ref<i32>
return
}