================ @@ -57,31 +75,90 @@ class OpenACCClauseCIREmitter final } } + mlir::acc::DeviceType decodeDeviceType(const IdentifierInfo *II) { + + // '*' case leaves no identifier-info, just a nullptr. + if (!II) + return mlir::acc::DeviceType::Star; + return llvm::StringSwitch<mlir::acc::DeviceType>(II->getName()) + .CaseLower("default", mlir::acc::DeviceType::Default) + .CaseLower("host", mlir::acc::DeviceType::Host) + .CaseLower("multicore", mlir::acc::DeviceType::Multicore) + .CasesLower("nvidia", "acc_device_nvidia", + mlir::acc::DeviceType::Nvidia) + .CaseLower("radeon", mlir::acc::DeviceType::Radeon); + } + + void VisitDeviceTypeClause(const OpenACCDeviceTypeClause &clause) { + + switch (dirKind) { + case OpenACCDirectiveKind::Init: + case OpenACCDirectiveKind::Shutdown: { + // Device type has a list that is either a 'star' (emitted as 'star'), + // or an identifer list, all of which get added for attributes. + + for (const DeviceTypeArgument &Arg : clause.getArchitectures()) + attrData.deviceTypeArchs.push_back(decodeDeviceType(Arg.first)); + break; + } + default: + return clauseNotImplemented(clause); + } + } + // Apply any of the clauses that resulted in an 'attribute'. - template <typename Op> void applyAttributes(Op &op) { - if (attrData.defaultVal.has_value()) - op.setDefaultAttr(*attrData.defaultVal); + template <typename Op> + void applyAttributes(CIRGenBuilderTy &builder, Op &op) { + + if (attrData.defaultVal.has_value()) { + // FIXME: OpenACC: as we implement this for other directive kinds, we have + // to expand this list. + if constexpr (isOneOfTypes<Op, ParallelOp, SerialOp, KernelsOp, DataOp>) ---------------- andykaylor wrote:
Am I right that `ParallelOp` is `acc::ParallelOp`? I was confused about what was happening here because I didn't read the comment where `isOneOfType` was defined. A brief comment here explaining what you're looking for ('Is Op one of the expected types?") would be helpful. https://github.com/llvm/llvm-project/pull/135102 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits