clang  19.0.0git
ABIInfo.h
Go to the documentation of this file.
1 //===----- ABIInfo.h - ABI information access & encapsulation ---*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLVM_CLANG_LIB_CODEGEN_ABIINFO_H
10 #define LLVM_CLANG_LIB_CODEGEN_ABIINFO_H
11 
12 #include "clang/AST/Attr.h"
13 #include "clang/AST/CharUnits.h"
14 #include "clang/AST/Type.h"
15 #include "llvm/IR/CallingConv.h"
16 #include "llvm/IR/Type.h"
17 
18 namespace llvm {
19 class Value;
20 class LLVMContext;
21 class DataLayout;
22 class Type;
23 } // namespace llvm
24 
25 namespace clang {
26 class ASTContext;
27 class CodeGenOptions;
28 class TargetInfo;
29 
30 namespace CodeGen {
31 class ABIArgInfo;
32 class Address;
33 class CGCXXABI;
34 class CGFunctionInfo;
35 class CodeGenFunction;
36 class CodeGenTypes;
37 
38 // FIXME: All of this stuff should be part of the target interface
39 // somehow. It is currently here because it is not clear how to factor
40 // the targets to support this, since the Targets currently live in a
41 // layer below types n'stuff.
42 
43 /// ABIInfo - Target specific hooks for defining how a type should be
44 /// passed or returned from functions.
45 class ABIInfo {
46 protected:
49 
50 public:
52  : CGT(cgt), RuntimeCC(llvm::CallingConv::C) {}
53 
54  virtual ~ABIInfo();
55 
56  virtual bool allowBFloatArgsAndRet() const { return false; }
57 
59  ASTContext &getContext() const;
60  llvm::LLVMContext &getVMContext() const;
61  const llvm::DataLayout &getDataLayout() const;
62  const TargetInfo &getTarget() const;
63  const CodeGenOptions &getCodeGenOpts() const;
64 
65  /// Return the calling convention to use for system runtime
66  /// functions.
68 
69  virtual void computeInfo(CodeGen::CGFunctionInfo &FI) const = 0;
70 
71  /// EmitVAArg - Emit the target dependent code to load a value of
72  /// \arg Ty from the va_list pointed to by \arg VAListAddr.
73 
74  // FIXME: This is a gaping layering violation if we wanted to drop
75  // the ABI information any lower than CodeGen. Of course, for
76  // VAArg handling it has to be at this level; there is no way to
77  // abstract this out.
79  CodeGen::Address VAListAddr,
80  QualType Ty) const = 0;
81 
82  bool isAndroid() const;
83  bool isOHOSFamily() const;
84 
85  /// Emit the target dependent code to load a value of
86  /// \arg Ty from the \c __builtin_ms_va_list pointed to by \arg VAListAddr.
88  CodeGen::Address VAListAddr,
89  QualType Ty) const;
90 
91  virtual bool isHomogeneousAggregateBaseType(QualType Ty) const;
92 
93  virtual bool isHomogeneousAggregateSmallEnough(const Type *Base,
94  uint64_t Members) const;
96 
97  /// isHomogeneousAggregate - Return true if a type is an ELFv2 homogeneous
98  /// aggregate. Base is set to the base element type, and Members is set
99  /// to the number of base elements.
100  bool isHomogeneousAggregate(QualType Ty, const Type *&Base,
101  uint64_t &Members) const;
102 
103  // Implement the Type::IsPromotableIntegerType for ABI specific needs. The
104  // only difference is that this considers bit-precise integer types as well.
106 
107  /// A convenience method to return an indirect ABIArgInfo with an
108  /// expected alignment equal to the ABI alignment of the given type.
110  getNaturalAlignIndirect(QualType Ty, bool ByVal = true, bool Realign = false,
111  llvm::Type *Padding = nullptr) const;
112 
114  bool Realign = false) const;
115 
116  virtual void appendAttributeMangling(TargetAttr *Attr,
117  raw_ostream &Out) const;
118  virtual void appendAttributeMangling(TargetVersionAttr *Attr,
119  raw_ostream &Out) const;
120  virtual void appendAttributeMangling(TargetClonesAttr *Attr, unsigned Index,
121  raw_ostream &Out) const;
122  virtual void appendAttributeMangling(StringRef AttrStr,
123  raw_ostream &Out) const;
124 };
125 
126 /// Target specific hooks for defining how a type should be passed or returned
127 /// from functions with one of the Swift calling conventions.
129 protected:
132 
133  bool occupiesMoreThan(ArrayRef<llvm::Type *> scalarTypes,
134  unsigned maxAllRegisters) const;
135 
136 public:
139 
140  virtual ~SwiftABIInfo();
141 
142  /// Returns true if an aggregate which expands to the given type sequence
143  /// should be passed / returned indirectly.
144  virtual bool shouldPassIndirectly(ArrayRef<llvm::Type *> ComponentTys,
145  bool AsReturnValue) const;
146 
147  /// Returns true if the given vector type is legal from Swift's calling
148  /// convention perspective.
149  virtual bool isLegalVectorType(CharUnits VectorSize, llvm::Type *EltTy,
150  unsigned NumElts) const;
151 
152  /// Returns true if swifterror is lowered to a register by the target ABI.
154 };
155 } // end namespace CodeGen
156 } // end namespace clang
157 
158 #endif
MatchType Type
static char ID
Definition: Arena.cpp:183
C Language Family Type Representation.
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
Definition: ASTContext.h:185
Attr - This represents one attribute.
Definition: Attr.h:46
CharUnits - This is an opaque type for sizes expressed in character units.
Definition: CharUnits.h:38
CodeGenOptions - Track various options which control how the code is optimized and passed to the back...
ABIArgInfo - Helper class to encapsulate information about how a specific C type should be passed to ...
ABIInfo - Target specific hooks for defining how a type should be passed or returned from functions.
Definition: ABIInfo.h:45
const llvm::DataLayout & getDataLayout() const
Definition: ABIInfo.cpp:26
virtual bool allowBFloatArgsAndRet() const
Definition: ABIInfo.h:56
const CodeGenOptions & getCodeGenOpts() const
Definition: ABIInfo.cpp:32
ABIInfo(CodeGen::CodeGenTypes &cgt)
Definition: ABIInfo.h:51
CodeGen::CodeGenTypes & CGT
Definition: ABIInfo.h:47
virtual CodeGen::Address EmitMSVAArg(CodeGen::CodeGenFunction &CGF, CodeGen::Address VAListAddr, QualType Ty) const
Emit the target dependent code to load a value of.
Definition: ABIInfo.cpp:42
bool isHomogeneousAggregate(QualType Ty, const Type *&Base, uint64_t &Members) const
isHomogeneousAggregate - Return true if a type is an ELFv2 homogeneous aggregate.
Definition: ABIInfo.cpp:61
CodeGen::CGCXXABI & getCXXABI() const
Definition: ABIInfo.cpp:18
ASTContext & getContext() const
Definition: ABIInfo.cpp:20
virtual bool isHomogeneousAggregateBaseType(QualType Ty) const
Definition: ABIInfo.cpp:47
bool isPromotableIntegerTypeForABI(QualType Ty) const
Definition: ABIInfo.cpp:163
virtual void appendAttributeMangling(TargetAttr *Attr, raw_ostream &Out) const
Definition: ABIInfo.cpp:187
bool isOHOSFamily() const
Definition: ABIInfo.cpp:38
virtual CodeGen::Address EmitVAArg(CodeGen::CodeGenFunction &CGF, CodeGen::Address VAListAddr, QualType Ty) const =0
EmitVAArg - Emit the target dependent code to load a value of.
CodeGen::ABIArgInfo getNaturalAlignIndirect(QualType Ty, bool ByVal=true, bool Realign=false, llvm::Type *Padding=nullptr) const
A convenience method to return an indirect ABIArgInfo with an expected alignment equal to the ABI ali...
Definition: ABIInfo.cpp:174
virtual bool isHomogeneousAggregateSmallEnough(const Type *Base, uint64_t Members) const
Definition: ABIInfo.cpp:51
const TargetInfo & getTarget() const
Definition: ABIInfo.cpp:30
virtual bool isZeroLengthBitfieldPermittedInHomogeneousAggregate() const
Definition: ABIInfo.cpp:56
llvm::CallingConv::ID getRuntimeCC() const
Return the calling convention to use for system runtime functions.
Definition: ABIInfo.h:67
CodeGen::ABIArgInfo getNaturalAlignIndirectInReg(QualType Ty, bool Realign=false) const
Definition: ABIInfo.cpp:181
virtual void computeInfo(CodeGen::CGFunctionInfo &FI) const =0
llvm::CallingConv::ID RuntimeCC
Definition: ABIInfo.h:48
bool isAndroid() const
Definition: ABIInfo.cpp:36
llvm::LLVMContext & getVMContext() const
Definition: ABIInfo.cpp:22
Like RawAddress, an abstract representation of an aligned address, but the pointer contained in this ...
Definition: Address.h:111
Implements C++ ABI-specific code generation functions.
Definition: CGCXXABI.h:43
CGFunctionInfo - Class to encapsulate the information about a function definition.
CodeGenFunction - This class organizes the per-function state that is used while generating LLVM code...
This class organizes the cross-module state that is used while lowering AST types to LLVM types.
Definition: CodeGenTypes.h:54
Target specific hooks for defining how a type should be passed or returned from functions with one of...
Definition: ABIInfo.h:128
virtual bool isLegalVectorType(CharUnits VectorSize, llvm::Type *EltTy, unsigned NumElts) const
Returns true if the given vector type is legal from Swift's calling convention perspective.
Definition: ABIInfo.cpp:278
bool occupiesMoreThan(ArrayRef< llvm::Type * > scalarTypes, unsigned maxAllRegisters) const
Does the given lowering require more than the given number of registers when expanded?
Definition: ABIInfo.cpp:255
bool isSwiftErrorInRegister() const
Returns true if swifterror is lowered to a register by the target ABI.
Definition: ABIInfo.h:153
virtual bool shouldPassIndirectly(ArrayRef< llvm::Type * > ComponentTys, bool AsReturnValue) const
Returns true if an aggregate which expands to the given type sequence should be passed / returned ind...
Definition: ABIInfo.cpp:273
SwiftABIInfo(CodeGen::CodeGenTypes &CGT, bool SwiftErrorInRegister)
Definition: ABIInfo.h:137
A (possibly-)qualified type.
Definition: Type.h:940
Exposes information about the current target.
Definition: TargetInfo.h:218
The base class of the type hierarchy.
Definition: Type.h:1813
The JSON file list parser is used to communicate input to InstallAPI.
CallingConv
CallingConv - Specifies the calling convention that a function uses.
Definition: Specifiers.h:275
unsigned long uint64_t
Diagnostic wrappers for TextAPI types for error reporting.
Definition: Dominators.h:30