diff --git a/flang/lib/Lower/OpenMP.cpp b/flang/lib/Lower/OpenMP.cpp --- a/flang/lib/Lower/OpenMP.cpp +++ b/flang/lib/Lower/OpenMP.cpp @@ -2328,16 +2328,16 @@ std::get<2>(atomicWrite.t); const Fortran::parser::OmpAtomicClauseList &leftHandClauseList = std::get<0>(atomicWrite.t); - const auto &assignmentStmtExpr = - std::get(std::get<3>(atomicWrite.t).statement.t); - const auto &assignmentStmtVariable = std::get( - std::get<3>(atomicWrite.t).statement.t); + const Fortran::parser::AssignmentStmt &stmt = + std::get<3>(atomicWrite.t).statement; + const Fortran::evaluate::Assignment &assign = *stmt.typedAssignment->v; Fortran::lower::StatementContext stmtCtx; // Get the value and address of atomic write operands. - mlir::Value rhs_expr = fir::getBase(converter.genExprValue( - *Fortran::semantics::GetExpr(assignmentStmtExpr), stmtCtx)); - mlir::Value lhs_addr = fir::getBase(converter.genExprAddr( - *Fortran::semantics::GetExpr(assignmentStmtVariable), stmtCtx)); + mlir::Value rhs_expr = + fir::getBase(converter.genExprValue(assign.rhs, stmtCtx)); + + mlir::Value lhs_addr = + fir::getBase(converter.genExprAddr(assign.lhs, stmtCtx)); genOmpAtomicWriteStatement(converter, eval, lhs_addr, rhs_expr, &leftHandClauseList, &rightHandClauseList); } diff --git a/flang/test/Lower/OpenMP/atomic-write.f90 b/flang/test/Lower/OpenMP/atomic-write.f90 --- a/flang/test/Lower/OpenMP/atomic-write.f90 +++ b/flang/test/Lower/OpenMP/atomic-write.f90 @@ -63,3 +63,13 @@ x = 2 end +!CHECK-LABEL: func.func @_QPatomic_write_typed_assign +!CHECK: %[[VAR:.*]] = fir.alloca f32 {bindc_name = "r2", uniq_name = "{{.*}}r2"} +!CHECK: %[[CST:.*]] = arith.constant 0.000000e+00 : f32 +!CHECK: omp.atomic.write %[[VAR]] = %[[CST]] : !fir.ref, f32 + +subroutine atomic_write_typed_assign + real :: r2 + !$omp atomic write + r2 = 0 +end subroutine