38 enum class IntegerExtension { None, Zero, Sign };
40 Attributes(
unsigned short alignment = 0,
bool byval =
false,
41 bool sret =
false,
bool append =
false,
42 IntegerExtension intExt = IntegerExtension::None)
43 : alignment{alignment}, byval{byval}, sret{sret}, append{append},
46 unsigned getAlignment()
const {
return alignment; }
47 bool hasAlignment()
const {
return alignment != 0; }
48 bool isByVal()
const {
return byval; }
49 bool isSRet()
const {
return sret; }
50 bool isAppend()
const {
return append; }
51 bool isZeroExt()
const {
return intExt == IntegerExtension::Zero; }
52 bool isSignExt()
const {
return intExt == IntegerExtension::Sign; }
53 llvm::StringRef getIntExtensionAttrName()
const;
56 unsigned short alignment{};
60 IntegerExtension intExt;
68class CodeGenSpecifics {
71 using TypeAndAttr = std::tuple<mlir::Type, Attributes>;
72 using Marshalling = std::vector<TypeAndAttr>;
74 static std::unique_ptr<CodeGenSpecifics>
75 get(mlir::MLIRContext *ctx, llvm::Triple &&trp,
KindMapping &&kindMap,
76 llvm::StringRef targetCPU, mlir::LLVM::TargetFeaturesAttr targetFeatures,
77 llvm::StringRef targetABI,
const mlir::DataLayout &dl);
79 static std::unique_ptr<CodeGenSpecifics>
80 get(mlir::MLIRContext *ctx, llvm::Triple &&trp,
KindMapping &&kindMap,
81 llvm::StringRef targetCPU, mlir::LLVM::TargetFeaturesAttr targetFeatures,
82 llvm::StringRef targetABI,
const mlir::DataLayout &dl,
83 llvm::StringRef tuneCPU);
85 static TypeAndAttr getTypeAndAttr(mlir::Type t) {
return TypeAndAttr{t, {}}; }
87 CodeGenSpecifics(mlir::MLIRContext *ctx, llvm::Triple &&trp,
89 mlir::LLVM::TargetFeaturesAttr targetFeatures,
90 llvm::StringRef targetABI,
const mlir::DataLayout &dl)
91 : context{*ctx}, triple{std::move(trp)}, kindMap{std::move(kindMap)},
92 targetCPU{targetCPU}, targetFeatures{targetFeatures},
93 targetABI{targetABI}, dataLayout{&dl}, tuneCPU{
""} {}
95 CodeGenSpecifics(mlir::MLIRContext *ctx, llvm::Triple &&trp,
97 mlir::LLVM::TargetFeaturesAttr targetFeatures,
98 llvm::StringRef targetABI,
const mlir::DataLayout &dl,
99 llvm::StringRef tuneCPU)
100 : context{*ctx}, triple{std::move(trp)}, kindMap{std::move(kindMap)},
101 targetCPU{targetCPU}, targetFeatures{targetFeatures},
102 targetABI{targetABI}, dataLayout{&dl}, tuneCPU{tuneCPU} {}
104 CodeGenSpecifics() =
delete;
105 virtual ~CodeGenSpecifics() {}
114 mlir::Type eleTy)
const = 0;
119 mlir::Type eleTy)
const = 0;
129 const Marshalling &previousArguments)
const = 0;
134 fir::RecordType eleTy)
const = 0;
170 virtual Marshalling integerArgumentType(mlir::Location loc,
171 mlir::IntegerType argTy)
const = 0;
175 virtual Marshalling integerReturnType(mlir::Location loc,
176 mlir::IntegerType argTy)
const = 0;
179 virtual unsigned char getCIntTypeWidth()
const = 0;
181 llvm::StringRef getTargetCPU()
const {
return targetCPU; }
182 llvm::StringRef
getTuneCPU()
const {
return tuneCPU; }
184 mlir::LLVM::TargetFeaturesAttr getTargetFeatures()
const {
185 return targetFeatures;
188 llvm::StringRef getTargetABI()
const {
return targetABI; }
190 const mlir::DataLayout &getDataLayout()
const {
191 assert(dataLayout &&
"dataLayout must be set");
196 mlir::MLIRContext &context;
199 llvm::StringRef targetCPU;
200 mlir::LLVM::TargetFeaturesAttr targetFeatures;
201 llvm::StringRef targetABI;
202 const mlir::DataLayout *dataLayout =
nullptr;
203 llvm::StringRef tuneCPU;