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