diff --git a/flang/lib/Lower/OpenACC.cpp b/flang/lib/Lower/OpenACC.cpp --- a/flang/lib/Lower/OpenACC.cpp +++ b/flang/lib/Lower/OpenACC.cpp @@ -2416,7 +2416,6 @@ } else if (moduleOp) { mlir::OpBuilder modBuilder(moduleOp.getBodyRegion()); for (const Fortran::parser::AccClause &clause : accClauseList.v) { - mlir::Location clauseLocation = converter.genLocation(clause.source); if (const auto *createClause = std::get_if(&clause.u)) { genGlobalCtorsWithModifier( converter, modBuilder, deviceResidentClause->v, mlir::acc::DataClause::acc_declare_device_resident); + } else if (const auto *linkClause = + std::get_if( + &clause.u)) { + genGlobalCtors( + converter, modBuilder, linkClause->v, + mlir::acc::DataClause::acc_declare_link); } else { - TODO(clauseLocation, "OpenACC declare clause"); + llvm::report_fatal_error("unsupported clause on DECLARE directive"); } } } diff --git a/flang/test/Lower/OpenACC/acc-declare.f90 b/flang/test/Lower/OpenACC/acc-declare.f90 --- a/flang/test/Lower/OpenACC/acc-declare.f90 +++ b/flang/test/Lower/OpenACC/acc-declare.f90 @@ -70,3 +70,18 @@ ! CHECK: acc.declare_enter dataOperands(%[[DEVICERESIDENT]] : !fir.ref>) ! CHECK: acc.terminator ! CHECK: } + +module acc_declare_device_link_test + integer, parameter :: n = 5000 + integer, dimension(n) :: data1 + !$acc declare link(data1) +end module + +! CHECK-LABEL: fir.global @_QMacc_declare_device_link_testEdata1 {acc.declare = #acc.declare} : !fir.array<5000xi32> { + +! CHECK-LABEL: acc.global_ctor @_QMacc_declare_device_link_testEdata1_acc_ctor { +! CHECK: %[[GLOBAL_ADDR:.*]] = fir.address_of(@_QMacc_declare_device_link_testEdata1) {acc.declare = #acc.declare} : !fir.ref> +! CHECK: %[[LINK:.*]] = acc.declare_link varPtr(%[[GLOBAL_ADDR]] : !fir.ref>) -> !fir.ref> {name = "data1"} +! CHECK: acc.declare_enter dataOperands(%[[LINK]] : !fir.ref>) +! CHECK: acc.terminator +! CHECK: }