xref: /llvm-project/flang/test/HLFIR/order_assignments/forall-codegen-fuse-assignments.fir (revision c9e3840c832d4c3fbbf57f0a8c90ae3d80af8913)
1*c9e3840cSJean Perier// Test code generation of hlfir.forall when assignment fusing is enabled
2*c9e3840cSJean Perier// and possible.
3*c9e3840cSJean Perier// RUN: fir-opt %s --lower-hlfir-ordered-assignments=fuse-assignments=true | FileCheck %s --check-prefix=FUSE
4*c9e3840cSJean Perier// RUN: fir-opt %s --lower-hlfir-ordered-assignments=fuse-assignments=false | FileCheck %s --check-prefix=NOFUSE
5*c9e3840cSJean Perier
6*c9e3840cSJean Perierfunc.func @test_assignment_fusing(%x: !fir.ref<!fir.array<10xi32>>, %y : !fir.box<!fir.array<?xi32>>) {
7*c9e3840cSJean Perier  %c42 = arith.constant 42 : i32
8*c9e3840cSJean Perier  hlfir.forall lb {
9*c9e3840cSJean Perier    %c1 = arith.constant 1 : index
10*c9e3840cSJean Perier    hlfir.yield %c1 : index
11*c9e3840cSJean Perier  } ub {
12*c9e3840cSJean Perier    %c10 = arith.constant 10 : index
13*c9e3840cSJean Perier    hlfir.yield %c10 : index
14*c9e3840cSJean Perier  }  (%i: index) {
15*c9e3840cSJean Perier    hlfir.region_assign {
16*c9e3840cSJean Perier      hlfir.yield %c42 : i32
17*c9e3840cSJean Perier    } to {
18*c9e3840cSJean Perier      %2 = hlfir.designate %x (%i)  : (!fir.ref<!fir.array<10xi32>>, index) -> !fir.ref<i32>
19*c9e3840cSJean Perier      hlfir.yield %2 : !fir.ref<i32>
20*c9e3840cSJean Perier    }
21*c9e3840cSJean Perier    hlfir.region_assign {
22*c9e3840cSJean Perier      hlfir.yield %c42 : i32
23*c9e3840cSJean Perier    } to {
24*c9e3840cSJean Perier      %2 = hlfir.designate %y (%i)  : (!fir.box<!fir.array<?xi32>>, index) -> !fir.ref<i32>
25*c9e3840cSJean Perier      hlfir.yield %2 : !fir.ref<i32>
26*c9e3840cSJean Perier    }
27*c9e3840cSJean Perier  }
28*c9e3840cSJean Perier  return
29*c9e3840cSJean Perier}
30*c9e3840cSJean Perier// FUSE-LABEL:   func.func @test_assignment_fusing(
31*c9e3840cSJean Perier// FUSE-SAME:                                      %[[VAL_0:.*]]: !fir.ref<!fir.array<10xi32>>,
32*c9e3840cSJean Perier// FUSE-SAME:                                      %[[VAL_1:.*]]: !fir.box<!fir.array<?xi32>>) {
33*c9e3840cSJean Perier// FUSE:           %[[VAL_2:.*]] = arith.constant 42 : i32
34*c9e3840cSJean Perier// FUSE:           %[[VAL_3:.*]] = arith.constant 1 : index
35*c9e3840cSJean Perier// FUSE:           %[[VAL_4:.*]] = arith.constant 10 : index
36*c9e3840cSJean Perier// FUSE:           %[[VAL_5:.*]] = arith.constant 1 : index
37*c9e3840cSJean Perier// FUSE:           fir.do_loop %[[VAL_6:.*]] = %[[VAL_3]] to %[[VAL_4]] step %[[VAL_5]] {
38*c9e3840cSJean Perier// FUSE-NEXT:         %[[VAL_7:.*]] = hlfir.designate %[[VAL_0]] (%[[VAL_6]])  : (!fir.ref<!fir.array<10xi32>>, index) -> !fir.ref<i32>
39*c9e3840cSJean Perier// FUSE-NEXT:         hlfir.assign %[[VAL_2]] to %[[VAL_7]] : i32, !fir.ref<i32>
40*c9e3840cSJean Perier// FUSE-NEXT:         %[[VAL_8:.*]] = hlfir.designate %[[VAL_1]] (%[[VAL_6]])  : (!fir.box<!fir.array<?xi32>>, index) -> !fir.ref<i32>
41*c9e3840cSJean Perier// FUSE-NEXT:         hlfir.assign %[[VAL_2]] to %[[VAL_8]] : i32, !fir.ref<i32>
42*c9e3840cSJean Perier// FUSE-NEXT:      }
43*c9e3840cSJean Perier// FUSE-NEXT:      return
44*c9e3840cSJean Perier
45*c9e3840cSJean Perier// NOFUSE-LABEL: func.func @test_assignment_fusing(
46*c9e3840cSJean Perier// NOFUSE:         fir.do_loop
47*c9e3840cSJean Perier// NOFUSE:           hlfir.assign
48*c9e3840cSJean Perier// NOFUSE:         }
49*c9e3840cSJean Perier// NOFUSE:         fir.do_loop
50*c9e3840cSJean Perier// NOFUSE:           hlfir.assign
51*c9e3840cSJean Perier// NOFUSE:         }
52