Skip to content

Commit 0984407

Browse files
committed
[flang][omp] Emit omp.workshare in frontend
Fix lower test for workshare
1 parent 45a5069 commit 0984407

File tree

2 files changed

+29
-7
lines changed

2 files changed

+29
-7
lines changed

flang/lib/Lower/OpenMP/OpenMP.cpp

Lines changed: 26 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1272,6 +1272,15 @@ static void genTaskwaitClauses(lower::AbstractConverter &converter,
12721272
loc, llvm::omp::Directive::OMPD_taskwait);
12731273
}
12741274

1275+
static void genWorkshareClauses(lower::AbstractConverter &converter,
1276+
semantics::SemanticsContext &semaCtx,
1277+
lower::StatementContext &stmtCtx,
1278+
const List<Clause> &clauses, mlir::Location loc,
1279+
mlir::omp::WorkshareOperands &clauseOps) {
1280+
ClauseProcessor cp(converter, semaCtx, clauses);
1281+
cp.processNowait(clauseOps);
1282+
}
1283+
12751284
static void genTeamsClauses(lower::AbstractConverter &converter,
12761285
semantics::SemanticsContext &semaCtx,
12771286
lower::StatementContext &stmtCtx,
@@ -1897,6 +1906,22 @@ genTaskyieldOp(lower::AbstractConverter &converter, lower::SymMap &symTable,
18971906
return converter.getFirOpBuilder().create<mlir::omp::TaskyieldOp>(loc);
18981907
}
18991908

1909+
static mlir::omp::WorkshareOp
1910+
genWorkshareOp(lower::AbstractConverter &converter, lower::SymMap &symTable,
1911+
semantics::SemanticsContext &semaCtx, lower::pft::Evaluation &eval,
1912+
mlir::Location loc, const ConstructQueue &queue,
1913+
ConstructQueue::iterator item) {
1914+
lower::StatementContext stmtCtx;
1915+
mlir::omp::WorkshareOperands clauseOps;
1916+
genWorkshareClauses(converter, semaCtx, stmtCtx, item->clauses, loc, clauseOps);
1917+
1918+
return genOpWithBody<mlir::omp::WorkshareOp>(
1919+
OpWithBodyGenInfo(converter, symTable, semaCtx, loc, eval,
1920+
llvm::omp::Directive::OMPD_workshare)
1921+
.setClauses(&item->clauses),
1922+
queue, item, clauseOps);
1923+
}
1924+
19001925
static mlir::omp::TeamsOp
19011926
genTeamsOp(lower::AbstractConverter &converter, lower::SymMap &symTable,
19021927
semantics::SemanticsContext &semaCtx, lower::pft::Evaluation &eval,
@@ -2309,10 +2334,7 @@ static void genOMPDispatch(lower::AbstractConverter &converter,
23092334
llvm::omp::getOpenMPDirectiveName(dir) + ")");
23102335
// case llvm::omp::Directive::OMPD_workdistribute:
23112336
case llvm::omp::Directive::OMPD_workshare:
2312-
// FIXME: Workshare is not a commonly used OpenMP construct, an
2313-
// implementation for this feature will come later. For the codes
2314-
// that use this construct, add a single construct for now.
2315-
genSingleOp(converter, symTable, semaCtx, eval, loc, queue, item);
2337+
genWorkshareOp(converter, symTable, semaCtx, eval, loc, queue, item);
23162338
break;
23172339
default:
23182340
// Combined and composite constructs should have been split into a sequence

flang/test/Lower/OpenMP/workshare.f90

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ subroutine sb1(arr)
66
integer :: arr(:)
77
!CHECK: omp.parallel {
88
!$omp parallel
9-
!CHECK: omp.single {
9+
!CHECK: omp.workshare {
1010
!$omp workshare
1111
arr = 0
1212
!$omp end workshare
@@ -20,7 +20,7 @@ subroutine sb2(arr)
2020
integer :: arr(:)
2121
!CHECK: omp.parallel {
2222
!$omp parallel
23-
!CHECK: omp.single nowait {
23+
!CHECK: omp.workshare nowait {
2424
!$omp workshare
2525
arr = 0
2626
!$omp end workshare nowait
@@ -33,7 +33,7 @@ subroutine sb2(arr)
3333
subroutine sb3(arr)
3434
integer :: arr(:)
3535
!CHECK: omp.parallel {
36-
!CHECK: omp.single {
36+
!CHECK: omp.workshare {
3737
!$omp parallel workshare
3838
arr = 0
3939
!$omp end parallel workshare

0 commit comments

Comments
 (0)