1e5dd7070Spatrick //===--- InitPreprocessor.cpp - PP initialization code. ---------*- C++ -*-===//
2e5dd7070Spatrick //
3e5dd7070Spatrick // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4e5dd7070Spatrick // See https://llvm.org/LICENSE.txt for license information.
5e5dd7070Spatrick // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6e5dd7070Spatrick //
7e5dd7070Spatrick //===----------------------------------------------------------------------===//
8e5dd7070Spatrick //
9e5dd7070Spatrick // This file implements the clang::InitializePreprocessor function.
10e5dd7070Spatrick //
11e5dd7070Spatrick //===----------------------------------------------------------------------===//
12e5dd7070Spatrick
13e5dd7070Spatrick #include "clang/Basic/FileManager.h"
14*12c85518Srobert #include "clang/Basic/HLSLRuntime.h"
15e5dd7070Spatrick #include "clang/Basic/MacroBuilder.h"
16e5dd7070Spatrick #include "clang/Basic/SourceManager.h"
17e5dd7070Spatrick #include "clang/Basic/SyncScope.h"
18e5dd7070Spatrick #include "clang/Basic/TargetInfo.h"
19e5dd7070Spatrick #include "clang/Basic/Version.h"
20e5dd7070Spatrick #include "clang/Frontend/FrontendDiagnostic.h"
21e5dd7070Spatrick #include "clang/Frontend/FrontendOptions.h"
22e5dd7070Spatrick #include "clang/Frontend/Utils.h"
23e5dd7070Spatrick #include "clang/Lex/HeaderSearch.h"
24e5dd7070Spatrick #include "clang/Lex/Preprocessor.h"
25e5dd7070Spatrick #include "clang/Lex/PreprocessorOptions.h"
26e5dd7070Spatrick #include "clang/Serialization/ASTReader.h"
27e5dd7070Spatrick #include "llvm/ADT/APFloat.h"
28e5dd7070Spatrick #include "llvm/IR/DataLayout.h"
29*12c85518Srobert #include "llvm/IR/DerivedTypes.h"
30e5dd7070Spatrick using namespace clang;
31e5dd7070Spatrick
MacroBodyEndsInBackslash(StringRef MacroBody)32e5dd7070Spatrick static bool MacroBodyEndsInBackslash(StringRef MacroBody) {
33e5dd7070Spatrick while (!MacroBody.empty() && isWhitespace(MacroBody.back()))
34e5dd7070Spatrick MacroBody = MacroBody.drop_back();
35e5dd7070Spatrick return !MacroBody.empty() && MacroBody.back() == '\\';
36e5dd7070Spatrick }
37e5dd7070Spatrick
38e5dd7070Spatrick // Append a #define line to Buf for Macro. Macro should be of the form XXX,
39e5dd7070Spatrick // in which case we emit "#define XXX 1" or "XXX=Y z W" in which case we emit
40e5dd7070Spatrick // "#define XXX Y z W". To get a #define with no value, use "XXX=".
DefineBuiltinMacro(MacroBuilder & Builder,StringRef Macro,DiagnosticsEngine & Diags)41e5dd7070Spatrick static void DefineBuiltinMacro(MacroBuilder &Builder, StringRef Macro,
42e5dd7070Spatrick DiagnosticsEngine &Diags) {
43e5dd7070Spatrick std::pair<StringRef, StringRef> MacroPair = Macro.split('=');
44e5dd7070Spatrick StringRef MacroName = MacroPair.first;
45e5dd7070Spatrick StringRef MacroBody = MacroPair.second;
46e5dd7070Spatrick if (MacroName.size() != Macro.size()) {
47e5dd7070Spatrick // Per GCC -D semantics, the macro ends at \n if it exists.
48e5dd7070Spatrick StringRef::size_type End = MacroBody.find_first_of("\n\r");
49e5dd7070Spatrick if (End != StringRef::npos)
50e5dd7070Spatrick Diags.Report(diag::warn_fe_macro_contains_embedded_newline)
51e5dd7070Spatrick << MacroName;
52e5dd7070Spatrick MacroBody = MacroBody.substr(0, End);
53e5dd7070Spatrick // We handle macro bodies which end in a backslash by appending an extra
54e5dd7070Spatrick // backslash+newline. This makes sure we don't accidentally treat the
55e5dd7070Spatrick // backslash as a line continuation marker.
56e5dd7070Spatrick if (MacroBodyEndsInBackslash(MacroBody))
57e5dd7070Spatrick Builder.defineMacro(MacroName, Twine(MacroBody) + "\\\n");
58e5dd7070Spatrick else
59e5dd7070Spatrick Builder.defineMacro(MacroName, MacroBody);
60e5dd7070Spatrick } else {
61e5dd7070Spatrick // Push "macroname 1".
62e5dd7070Spatrick Builder.defineMacro(Macro);
63e5dd7070Spatrick }
64e5dd7070Spatrick }
65e5dd7070Spatrick
66e5dd7070Spatrick /// AddImplicitInclude - Add an implicit \#include of the specified file to the
67e5dd7070Spatrick /// predefines buffer.
68e5dd7070Spatrick /// As these includes are generated by -include arguments the header search
69e5dd7070Spatrick /// logic is going to search relatively to the current working directory.
AddImplicitInclude(MacroBuilder & Builder,StringRef File)70e5dd7070Spatrick static void AddImplicitInclude(MacroBuilder &Builder, StringRef File) {
71e5dd7070Spatrick Builder.append(Twine("#include \"") + File + "\"");
72e5dd7070Spatrick }
73e5dd7070Spatrick
AddImplicitIncludeMacros(MacroBuilder & Builder,StringRef File)74e5dd7070Spatrick static void AddImplicitIncludeMacros(MacroBuilder &Builder, StringRef File) {
75e5dd7070Spatrick Builder.append(Twine("#__include_macros \"") + File + "\"");
76e5dd7070Spatrick // Marker token to stop the __include_macros fetch loop.
77e5dd7070Spatrick Builder.append("##"); // ##?
78e5dd7070Spatrick }
79e5dd7070Spatrick
80e5dd7070Spatrick /// Add an implicit \#include using the original file used to generate
81e5dd7070Spatrick /// a PCH file.
AddImplicitIncludePCH(MacroBuilder & Builder,Preprocessor & PP,const PCHContainerReader & PCHContainerRdr,StringRef ImplicitIncludePCH)82e5dd7070Spatrick static void AddImplicitIncludePCH(MacroBuilder &Builder, Preprocessor &PP,
83e5dd7070Spatrick const PCHContainerReader &PCHContainerRdr,
84e5dd7070Spatrick StringRef ImplicitIncludePCH) {
85ec727ea7Spatrick std::string OriginalFile = ASTReader::getOriginalSourceFile(
86ec727ea7Spatrick std::string(ImplicitIncludePCH), PP.getFileManager(), PCHContainerRdr,
87ec727ea7Spatrick PP.getDiagnostics());
88e5dd7070Spatrick if (OriginalFile.empty())
89e5dd7070Spatrick return;
90e5dd7070Spatrick
91e5dd7070Spatrick AddImplicitInclude(Builder, OriginalFile);
92e5dd7070Spatrick }
93e5dd7070Spatrick
94e5dd7070Spatrick /// PickFP - This is used to pick a value based on the FP semantics of the
95e5dd7070Spatrick /// specified FP model.
96e5dd7070Spatrick template <typename T>
PickFP(const llvm::fltSemantics * Sem,T IEEEHalfVal,T IEEESingleVal,T IEEEDoubleVal,T X87DoubleExtendedVal,T PPCDoubleDoubleVal,T IEEEQuadVal)97e5dd7070Spatrick static T PickFP(const llvm::fltSemantics *Sem, T IEEEHalfVal, T IEEESingleVal,
98e5dd7070Spatrick T IEEEDoubleVal, T X87DoubleExtendedVal, T PPCDoubleDoubleVal,
99e5dd7070Spatrick T IEEEQuadVal) {
100e5dd7070Spatrick if (Sem == (const llvm::fltSemantics*)&llvm::APFloat::IEEEhalf())
101e5dd7070Spatrick return IEEEHalfVal;
102e5dd7070Spatrick if (Sem == (const llvm::fltSemantics*)&llvm::APFloat::IEEEsingle())
103e5dd7070Spatrick return IEEESingleVal;
104e5dd7070Spatrick if (Sem == (const llvm::fltSemantics*)&llvm::APFloat::IEEEdouble())
105e5dd7070Spatrick return IEEEDoubleVal;
106e5dd7070Spatrick if (Sem == (const llvm::fltSemantics*)&llvm::APFloat::x87DoubleExtended())
107e5dd7070Spatrick return X87DoubleExtendedVal;
108e5dd7070Spatrick if (Sem == (const llvm::fltSemantics*)&llvm::APFloat::PPCDoubleDouble())
109e5dd7070Spatrick return PPCDoubleDoubleVal;
110e5dd7070Spatrick assert(Sem == (const llvm::fltSemantics*)&llvm::APFloat::IEEEquad());
111e5dd7070Spatrick return IEEEQuadVal;
112e5dd7070Spatrick }
113e5dd7070Spatrick
DefineFloatMacros(MacroBuilder & Builder,StringRef Prefix,const llvm::fltSemantics * Sem,StringRef Ext)114e5dd7070Spatrick static void DefineFloatMacros(MacroBuilder &Builder, StringRef Prefix,
115e5dd7070Spatrick const llvm::fltSemantics *Sem, StringRef Ext) {
116e5dd7070Spatrick const char *DenormMin, *Epsilon, *Max, *Min;
117e5dd7070Spatrick DenormMin = PickFP(Sem, "5.9604644775390625e-8", "1.40129846e-45",
118e5dd7070Spatrick "4.9406564584124654e-324", "3.64519953188247460253e-4951",
119e5dd7070Spatrick "4.94065645841246544176568792868221e-324",
120e5dd7070Spatrick "6.47517511943802511092443895822764655e-4966");
121e5dd7070Spatrick int Digits = PickFP(Sem, 3, 6, 15, 18, 31, 33);
122e5dd7070Spatrick int DecimalDigits = PickFP(Sem, 5, 9, 17, 21, 33, 36);
123e5dd7070Spatrick Epsilon = PickFP(Sem, "9.765625e-4", "1.19209290e-7",
124e5dd7070Spatrick "2.2204460492503131e-16", "1.08420217248550443401e-19",
125e5dd7070Spatrick "4.94065645841246544176568792868221e-324",
126e5dd7070Spatrick "1.92592994438723585305597794258492732e-34");
127e5dd7070Spatrick int MantissaDigits = PickFP(Sem, 11, 24, 53, 64, 106, 113);
128e5dd7070Spatrick int Min10Exp = PickFP(Sem, -4, -37, -307, -4931, -291, -4931);
129e5dd7070Spatrick int Max10Exp = PickFP(Sem, 4, 38, 308, 4932, 308, 4932);
130e5dd7070Spatrick int MinExp = PickFP(Sem, -13, -125, -1021, -16381, -968, -16381);
131e5dd7070Spatrick int MaxExp = PickFP(Sem, 16, 128, 1024, 16384, 1024, 16384);
132e5dd7070Spatrick Min = PickFP(Sem, "6.103515625e-5", "1.17549435e-38", "2.2250738585072014e-308",
133e5dd7070Spatrick "3.36210314311209350626e-4932",
134e5dd7070Spatrick "2.00416836000897277799610805135016e-292",
135e5dd7070Spatrick "3.36210314311209350626267781732175260e-4932");
136e5dd7070Spatrick Max = PickFP(Sem, "6.5504e+4", "3.40282347e+38", "1.7976931348623157e+308",
137e5dd7070Spatrick "1.18973149535723176502e+4932",
138e5dd7070Spatrick "1.79769313486231580793728971405301e+308",
139e5dd7070Spatrick "1.18973149535723176508575932662800702e+4932");
140e5dd7070Spatrick
141e5dd7070Spatrick SmallString<32> DefPrefix;
142e5dd7070Spatrick DefPrefix = "__";
143e5dd7070Spatrick DefPrefix += Prefix;
144e5dd7070Spatrick DefPrefix += "_";
145e5dd7070Spatrick
146e5dd7070Spatrick Builder.defineMacro(DefPrefix + "DENORM_MIN__", Twine(DenormMin)+Ext);
147e5dd7070Spatrick Builder.defineMacro(DefPrefix + "HAS_DENORM__");
148e5dd7070Spatrick Builder.defineMacro(DefPrefix + "DIG__", Twine(Digits));
149e5dd7070Spatrick Builder.defineMacro(DefPrefix + "DECIMAL_DIG__", Twine(DecimalDigits));
150e5dd7070Spatrick Builder.defineMacro(DefPrefix + "EPSILON__", Twine(Epsilon)+Ext);
151e5dd7070Spatrick Builder.defineMacro(DefPrefix + "HAS_INFINITY__");
152e5dd7070Spatrick Builder.defineMacro(DefPrefix + "HAS_QUIET_NAN__");
153e5dd7070Spatrick Builder.defineMacro(DefPrefix + "MANT_DIG__", Twine(MantissaDigits));
154e5dd7070Spatrick
155e5dd7070Spatrick Builder.defineMacro(DefPrefix + "MAX_10_EXP__", Twine(Max10Exp));
156e5dd7070Spatrick Builder.defineMacro(DefPrefix + "MAX_EXP__", Twine(MaxExp));
157e5dd7070Spatrick Builder.defineMacro(DefPrefix + "MAX__", Twine(Max)+Ext);
158e5dd7070Spatrick
159e5dd7070Spatrick Builder.defineMacro(DefPrefix + "MIN_10_EXP__","("+Twine(Min10Exp)+")");
160e5dd7070Spatrick Builder.defineMacro(DefPrefix + "MIN_EXP__", "("+Twine(MinExp)+")");
161e5dd7070Spatrick Builder.defineMacro(DefPrefix + "MIN__", Twine(Min)+Ext);
162e5dd7070Spatrick }
163e5dd7070Spatrick
164e5dd7070Spatrick
165e5dd7070Spatrick /// DefineTypeSize - Emit a macro to the predefines buffer that declares a macro
166e5dd7070Spatrick /// named MacroName with the max value for a type with width 'TypeWidth' a
167e5dd7070Spatrick /// signedness of 'isSigned' and with a value suffix of 'ValSuffix' (e.g. LL).
DefineTypeSize(const Twine & MacroName,unsigned TypeWidth,StringRef ValSuffix,bool isSigned,MacroBuilder & Builder)168e5dd7070Spatrick static void DefineTypeSize(const Twine &MacroName, unsigned TypeWidth,
169e5dd7070Spatrick StringRef ValSuffix, bool isSigned,
170e5dd7070Spatrick MacroBuilder &Builder) {
171e5dd7070Spatrick llvm::APInt MaxVal = isSigned ? llvm::APInt::getSignedMaxValue(TypeWidth)
172e5dd7070Spatrick : llvm::APInt::getMaxValue(TypeWidth);
173a9ac8606Spatrick Builder.defineMacro(MacroName, toString(MaxVal, 10, isSigned) + ValSuffix);
174e5dd7070Spatrick }
175e5dd7070Spatrick
176e5dd7070Spatrick /// DefineTypeSize - An overloaded helper that uses TargetInfo to determine
177e5dd7070Spatrick /// the width, suffix, and signedness of the given type
DefineTypeSize(const Twine & MacroName,TargetInfo::IntType Ty,const TargetInfo & TI,MacroBuilder & Builder)178e5dd7070Spatrick static void DefineTypeSize(const Twine &MacroName, TargetInfo::IntType Ty,
179e5dd7070Spatrick const TargetInfo &TI, MacroBuilder &Builder) {
180e5dd7070Spatrick DefineTypeSize(MacroName, TI.getTypeWidth(Ty), TI.getTypeConstantSuffix(Ty),
181e5dd7070Spatrick TI.isTypeSigned(Ty), Builder);
182e5dd7070Spatrick }
183e5dd7070Spatrick
DefineFmt(const Twine & Prefix,TargetInfo::IntType Ty,const TargetInfo & TI,MacroBuilder & Builder)184e5dd7070Spatrick static void DefineFmt(const Twine &Prefix, TargetInfo::IntType Ty,
185e5dd7070Spatrick const TargetInfo &TI, MacroBuilder &Builder) {
186e5dd7070Spatrick bool IsSigned = TI.isTypeSigned(Ty);
187e5dd7070Spatrick StringRef FmtModifier = TI.getTypeFormatModifier(Ty);
188e5dd7070Spatrick for (const char *Fmt = IsSigned ? "di" : "ouxX"; *Fmt; ++Fmt) {
189e5dd7070Spatrick Builder.defineMacro(Prefix + "_FMT" + Twine(*Fmt) + "__",
190e5dd7070Spatrick Twine("\"") + FmtModifier + Twine(*Fmt) + "\"");
191e5dd7070Spatrick }
192e5dd7070Spatrick }
193e5dd7070Spatrick
DefineType(const Twine & MacroName,TargetInfo::IntType Ty,MacroBuilder & Builder)194e5dd7070Spatrick static void DefineType(const Twine &MacroName, TargetInfo::IntType Ty,
195e5dd7070Spatrick MacroBuilder &Builder) {
196e5dd7070Spatrick Builder.defineMacro(MacroName, TargetInfo::getTypeName(Ty));
197e5dd7070Spatrick }
198e5dd7070Spatrick
DefineTypeWidth(const Twine & MacroName,TargetInfo::IntType Ty,const TargetInfo & TI,MacroBuilder & Builder)199*12c85518Srobert static void DefineTypeWidth(const Twine &MacroName, TargetInfo::IntType Ty,
200e5dd7070Spatrick const TargetInfo &TI, MacroBuilder &Builder) {
201e5dd7070Spatrick Builder.defineMacro(MacroName, Twine(TI.getTypeWidth(Ty)));
202e5dd7070Spatrick }
203e5dd7070Spatrick
DefineTypeSizeof(StringRef MacroName,unsigned BitWidth,const TargetInfo & TI,MacroBuilder & Builder)204e5dd7070Spatrick static void DefineTypeSizeof(StringRef MacroName, unsigned BitWidth,
205e5dd7070Spatrick const TargetInfo &TI, MacroBuilder &Builder) {
206e5dd7070Spatrick Builder.defineMacro(MacroName,
207e5dd7070Spatrick Twine(BitWidth / TI.getCharWidth()));
208e5dd7070Spatrick }
209e5dd7070Spatrick
210*12c85518Srobert // This will generate a macro based on the prefix with `_MAX__` as the suffix
211*12c85518Srobert // for the max value representable for the type, and a macro with a `_WIDTH__`
212*12c85518Srobert // suffix for the width of the type.
DefineTypeSizeAndWidth(const Twine & Prefix,TargetInfo::IntType Ty,const TargetInfo & TI,MacroBuilder & Builder)213*12c85518Srobert static void DefineTypeSizeAndWidth(const Twine &Prefix, TargetInfo::IntType Ty,
214*12c85518Srobert const TargetInfo &TI,
215*12c85518Srobert MacroBuilder &Builder) {
216*12c85518Srobert DefineTypeSize(Prefix + "_MAX__", Ty, TI, Builder);
217*12c85518Srobert DefineTypeWidth(Prefix + "_WIDTH__", Ty, TI, Builder);
218*12c85518Srobert }
219*12c85518Srobert
DefineExactWidthIntType(TargetInfo::IntType Ty,const TargetInfo & TI,MacroBuilder & Builder)220e5dd7070Spatrick static void DefineExactWidthIntType(TargetInfo::IntType Ty,
221e5dd7070Spatrick const TargetInfo &TI,
222e5dd7070Spatrick MacroBuilder &Builder) {
223e5dd7070Spatrick int TypeWidth = TI.getTypeWidth(Ty);
224e5dd7070Spatrick bool IsSigned = TI.isTypeSigned(Ty);
225e5dd7070Spatrick
226e5dd7070Spatrick // Use the target specified int64 type, when appropriate, so that [u]int64_t
227e5dd7070Spatrick // ends up being defined in terms of the correct type.
228e5dd7070Spatrick if (TypeWidth == 64)
229e5dd7070Spatrick Ty = IsSigned ? TI.getInt64Type() : TI.getUInt64Type();
230e5dd7070Spatrick
231a9ac8606Spatrick // Use the target specified int16 type when appropriate. Some MCU targets
232a9ac8606Spatrick // (such as AVR) have definition of [u]int16_t to [un]signed int.
233a9ac8606Spatrick if (TypeWidth == 16)
234a9ac8606Spatrick Ty = IsSigned ? TI.getInt16Type() : TI.getUInt16Type();
235a9ac8606Spatrick
236e5dd7070Spatrick const char *Prefix = IsSigned ? "__INT" : "__UINT";
237e5dd7070Spatrick
238e5dd7070Spatrick DefineType(Prefix + Twine(TypeWidth) + "_TYPE__", Ty, Builder);
239e5dd7070Spatrick DefineFmt(Prefix + Twine(TypeWidth), Ty, TI, Builder);
240e5dd7070Spatrick
241e5dd7070Spatrick StringRef ConstSuffix(TI.getTypeConstantSuffix(Ty));
242e5dd7070Spatrick Builder.defineMacro(Prefix + Twine(TypeWidth) + "_C_SUFFIX__", ConstSuffix);
243e5dd7070Spatrick }
244e5dd7070Spatrick
DefineExactWidthIntTypeSize(TargetInfo::IntType Ty,const TargetInfo & TI,MacroBuilder & Builder)245e5dd7070Spatrick static void DefineExactWidthIntTypeSize(TargetInfo::IntType Ty,
246e5dd7070Spatrick const TargetInfo &TI,
247e5dd7070Spatrick MacroBuilder &Builder) {
248e5dd7070Spatrick int TypeWidth = TI.getTypeWidth(Ty);
249e5dd7070Spatrick bool IsSigned = TI.isTypeSigned(Ty);
250e5dd7070Spatrick
251e5dd7070Spatrick // Use the target specified int64 type, when appropriate, so that [u]int64_t
252e5dd7070Spatrick // ends up being defined in terms of the correct type.
253e5dd7070Spatrick if (TypeWidth == 64)
254e5dd7070Spatrick Ty = IsSigned ? TI.getInt64Type() : TI.getUInt64Type();
255e5dd7070Spatrick
256*12c85518Srobert // We don't need to define a _WIDTH macro for the exact-width types because
257*12c85518Srobert // we already know the width.
258e5dd7070Spatrick const char *Prefix = IsSigned ? "__INT" : "__UINT";
259e5dd7070Spatrick DefineTypeSize(Prefix + Twine(TypeWidth) + "_MAX__", Ty, TI, Builder);
260e5dd7070Spatrick }
261e5dd7070Spatrick
DefineLeastWidthIntType(unsigned TypeWidth,bool IsSigned,const TargetInfo & TI,MacroBuilder & Builder)262e5dd7070Spatrick static void DefineLeastWidthIntType(unsigned TypeWidth, bool IsSigned,
263e5dd7070Spatrick const TargetInfo &TI,
264e5dd7070Spatrick MacroBuilder &Builder) {
265e5dd7070Spatrick TargetInfo::IntType Ty = TI.getLeastIntTypeByWidth(TypeWidth, IsSigned);
266e5dd7070Spatrick if (Ty == TargetInfo::NoInt)
267e5dd7070Spatrick return;
268e5dd7070Spatrick
269e5dd7070Spatrick const char *Prefix = IsSigned ? "__INT_LEAST" : "__UINT_LEAST";
270e5dd7070Spatrick DefineType(Prefix + Twine(TypeWidth) + "_TYPE__", Ty, Builder);
271*12c85518Srobert // We only want the *_WIDTH macro for the signed types to avoid too many
272*12c85518Srobert // predefined macros (the unsigned width and the signed width are identical.)
273*12c85518Srobert if (IsSigned)
274*12c85518Srobert DefineTypeSizeAndWidth(Prefix + Twine(TypeWidth), Ty, TI, Builder);
275*12c85518Srobert else
276e5dd7070Spatrick DefineTypeSize(Prefix + Twine(TypeWidth) + "_MAX__", Ty, TI, Builder);
277e5dd7070Spatrick DefineFmt(Prefix + Twine(TypeWidth), Ty, TI, Builder);
278e5dd7070Spatrick }
279e5dd7070Spatrick
DefineFastIntType(unsigned TypeWidth,bool IsSigned,const TargetInfo & TI,MacroBuilder & Builder)280e5dd7070Spatrick static void DefineFastIntType(unsigned TypeWidth, bool IsSigned,
281e5dd7070Spatrick const TargetInfo &TI, MacroBuilder &Builder) {
282e5dd7070Spatrick // stdint.h currently defines the fast int types as equivalent to the least
283e5dd7070Spatrick // types.
284e5dd7070Spatrick TargetInfo::IntType Ty = TI.getLeastIntTypeByWidth(TypeWidth, IsSigned);
285e5dd7070Spatrick if (Ty == TargetInfo::NoInt)
286e5dd7070Spatrick return;
287e5dd7070Spatrick
288e5dd7070Spatrick const char *Prefix = IsSigned ? "__INT_FAST" : "__UINT_FAST";
289e5dd7070Spatrick DefineType(Prefix + Twine(TypeWidth) + "_TYPE__", Ty, Builder);
290*12c85518Srobert // We only want the *_WIDTH macro for the signed types to avoid too many
291*12c85518Srobert // predefined macros (the unsigned width and the signed width are identical.)
292*12c85518Srobert if (IsSigned)
293*12c85518Srobert DefineTypeSizeAndWidth(Prefix + Twine(TypeWidth), Ty, TI, Builder);
294*12c85518Srobert else
295e5dd7070Spatrick DefineTypeSize(Prefix + Twine(TypeWidth) + "_MAX__", Ty, TI, Builder);
296e5dd7070Spatrick DefineFmt(Prefix + Twine(TypeWidth), Ty, TI, Builder);
297e5dd7070Spatrick }
298e5dd7070Spatrick
299e5dd7070Spatrick
300e5dd7070Spatrick /// Get the value the ATOMIC_*_LOCK_FREE macro should have for a type with
301e5dd7070Spatrick /// the specified properties.
getLockFreeValue(unsigned TypeWidth,const TargetInfo & TI)302*12c85518Srobert static const char *getLockFreeValue(unsigned TypeWidth, const TargetInfo &TI) {
303e5dd7070Spatrick // Fully-aligned, power-of-2 sizes no larger than the inline
304e5dd7070Spatrick // width will be inlined as lock-free operations.
305*12c85518Srobert // Note: we do not need to check alignment since _Atomic(T) is always
306*12c85518Srobert // appropriately-aligned in clang.
307*12c85518Srobert if (TI.hasBuiltinAtomic(TypeWidth, TypeWidth))
308e5dd7070Spatrick return "2"; // "always lock free"
309e5dd7070Spatrick // We cannot be certain what operations the lib calls might be
310e5dd7070Spatrick // able to implement as lock-free on future processors.
311e5dd7070Spatrick return "1"; // "sometimes lock free"
312e5dd7070Spatrick }
313e5dd7070Spatrick
314e5dd7070Spatrick /// Add definitions required for a smooth interaction between
315e5dd7070Spatrick /// Objective-C++ automated reference counting and libstdc++ (4.2).
AddObjCXXARCLibstdcxxDefines(const LangOptions & LangOpts,MacroBuilder & Builder)316e5dd7070Spatrick static void AddObjCXXARCLibstdcxxDefines(const LangOptions &LangOpts,
317e5dd7070Spatrick MacroBuilder &Builder) {
318e5dd7070Spatrick Builder.defineMacro("_GLIBCXX_PREDEFINED_OBJC_ARC_IS_SCALAR");
319e5dd7070Spatrick
320e5dd7070Spatrick std::string Result;
321e5dd7070Spatrick {
322e5dd7070Spatrick // Provide specializations for the __is_scalar type trait so that
323e5dd7070Spatrick // lifetime-qualified objects are not considered "scalar" types, which
324e5dd7070Spatrick // libstdc++ uses as an indicator of the presence of trivial copy, assign,
325e5dd7070Spatrick // default-construct, and destruct semantics (none of which hold for
326e5dd7070Spatrick // lifetime-qualified objects in ARC).
327e5dd7070Spatrick llvm::raw_string_ostream Out(Result);
328e5dd7070Spatrick
329e5dd7070Spatrick Out << "namespace std {\n"
330e5dd7070Spatrick << "\n"
331e5dd7070Spatrick << "struct __true_type;\n"
332e5dd7070Spatrick << "struct __false_type;\n"
333e5dd7070Spatrick << "\n";
334e5dd7070Spatrick
335e5dd7070Spatrick Out << "template<typename _Tp> struct __is_scalar;\n"
336e5dd7070Spatrick << "\n";
337e5dd7070Spatrick
338e5dd7070Spatrick if (LangOpts.ObjCAutoRefCount) {
339e5dd7070Spatrick Out << "template<typename _Tp>\n"
340e5dd7070Spatrick << "struct __is_scalar<__attribute__((objc_ownership(strong))) _Tp> {\n"
341e5dd7070Spatrick << " enum { __value = 0 };\n"
342e5dd7070Spatrick << " typedef __false_type __type;\n"
343e5dd7070Spatrick << "};\n"
344e5dd7070Spatrick << "\n";
345e5dd7070Spatrick }
346e5dd7070Spatrick
347e5dd7070Spatrick if (LangOpts.ObjCWeak) {
348e5dd7070Spatrick Out << "template<typename _Tp>\n"
349e5dd7070Spatrick << "struct __is_scalar<__attribute__((objc_ownership(weak))) _Tp> {\n"
350e5dd7070Spatrick << " enum { __value = 0 };\n"
351e5dd7070Spatrick << " typedef __false_type __type;\n"
352e5dd7070Spatrick << "};\n"
353e5dd7070Spatrick << "\n";
354e5dd7070Spatrick }
355e5dd7070Spatrick
356e5dd7070Spatrick if (LangOpts.ObjCAutoRefCount) {
357e5dd7070Spatrick Out << "template<typename _Tp>\n"
358e5dd7070Spatrick << "struct __is_scalar<__attribute__((objc_ownership(autoreleasing)))"
359e5dd7070Spatrick << " _Tp> {\n"
360e5dd7070Spatrick << " enum { __value = 0 };\n"
361e5dd7070Spatrick << " typedef __false_type __type;\n"
362e5dd7070Spatrick << "};\n"
363e5dd7070Spatrick << "\n";
364e5dd7070Spatrick }
365e5dd7070Spatrick
366e5dd7070Spatrick Out << "}\n";
367e5dd7070Spatrick }
368e5dd7070Spatrick Builder.append(Result);
369e5dd7070Spatrick }
370e5dd7070Spatrick
InitializeStandardPredefinedMacros(const TargetInfo & TI,const LangOptions & LangOpts,const FrontendOptions & FEOpts,MacroBuilder & Builder)371e5dd7070Spatrick static void InitializeStandardPredefinedMacros(const TargetInfo &TI,
372e5dd7070Spatrick const LangOptions &LangOpts,
373e5dd7070Spatrick const FrontendOptions &FEOpts,
374e5dd7070Spatrick MacroBuilder &Builder) {
375*12c85518Srobert if (LangOpts.HLSL) {
376*12c85518Srobert Builder.defineMacro("__hlsl_clang");
377*12c85518Srobert // HLSL Version
378*12c85518Srobert Builder.defineMacro("__HLSL_VERSION",
379*12c85518Srobert Twine((unsigned)LangOpts.getHLSLVersion()));
380*12c85518Srobert
381*12c85518Srobert if (LangOpts.NativeHalfType)
382*12c85518Srobert Builder.defineMacro("__HLSL_ENABLE_16_BIT",
383*12c85518Srobert Twine((unsigned)LangOpts.getHLSLVersion()));
384*12c85518Srobert
385*12c85518Srobert // Shader target information
386*12c85518Srobert // "enums" for shader stages
387*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_VERTEX",
388*12c85518Srobert Twine((uint32_t)ShaderStage::Vertex));
389*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_PIXEL",
390*12c85518Srobert Twine((uint32_t)ShaderStage::Pixel));
391*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_GEOMETRY",
392*12c85518Srobert Twine((uint32_t)ShaderStage::Geometry));
393*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_HULL",
394*12c85518Srobert Twine((uint32_t)ShaderStage::Hull));
395*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_DOMAIN",
396*12c85518Srobert Twine((uint32_t)ShaderStage::Domain));
397*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_COMPUTE",
398*12c85518Srobert Twine((uint32_t)ShaderStage::Compute));
399*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_AMPLIFICATION",
400*12c85518Srobert Twine((uint32_t)ShaderStage::Amplification));
401*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_MESH",
402*12c85518Srobert Twine((uint32_t)ShaderStage::Mesh));
403*12c85518Srobert Builder.defineMacro("__SHADER_STAGE_LIBRARY",
404*12c85518Srobert Twine((uint32_t)ShaderStage::Library));
405*12c85518Srobert // The current shader stage itself
406*12c85518Srobert uint32_t StageInteger = static_cast<uint32_t>(
407*12c85518Srobert hlsl::getStageFromEnvironment(TI.getTriple().getEnvironment()));
408*12c85518Srobert
409*12c85518Srobert Builder.defineMacro("__SHADER_TARGET_STAGE", Twine(StageInteger));
410*12c85518Srobert // Add target versions
411*12c85518Srobert if (TI.getTriple().getOS() == llvm::Triple::ShaderModel) {
412*12c85518Srobert VersionTuple Version = TI.getTriple().getOSVersion();
413*12c85518Srobert Builder.defineMacro("__SHADER_TARGET_MAJOR", Twine(Version.getMajor()));
414*12c85518Srobert unsigned Minor = Version.getMinor().value_or(0);
415*12c85518Srobert Builder.defineMacro("__SHADER_TARGET_MINOR", Twine(Minor));
416*12c85518Srobert }
417*12c85518Srobert return;
418*12c85518Srobert }
419e5dd7070Spatrick // C++ [cpp.predefined]p1:
420e5dd7070Spatrick // The following macro names shall be defined by the implementation:
421e5dd7070Spatrick
422e5dd7070Spatrick // -- __STDC__
423e5dd7070Spatrick // [C++] Whether __STDC__ is predefined and if so, what its value is,
424e5dd7070Spatrick // are implementation-defined.
425e5dd7070Spatrick // (Removed in C++20.)
426e5dd7070Spatrick if (!LangOpts.MSVCCompat && !LangOpts.TraditionalCPP)
427e5dd7070Spatrick Builder.defineMacro("__STDC__");
428e5dd7070Spatrick // -- __STDC_HOSTED__
429e5dd7070Spatrick // The integer literal 1 if the implementation is a hosted
430e5dd7070Spatrick // implementation or the integer literal 0 if it is not.
431e5dd7070Spatrick if (LangOpts.Freestanding)
432e5dd7070Spatrick Builder.defineMacro("__STDC_HOSTED__", "0");
433e5dd7070Spatrick else
434e5dd7070Spatrick Builder.defineMacro("__STDC_HOSTED__");
435e5dd7070Spatrick
436e5dd7070Spatrick // -- __STDC_VERSION__
437e5dd7070Spatrick // [C++] Whether __STDC_VERSION__ is predefined and if so, what its
438e5dd7070Spatrick // value is, are implementation-defined.
439e5dd7070Spatrick // (Removed in C++20.)
440e5dd7070Spatrick if (!LangOpts.CPlusPlus) {
441*12c85518Srobert // FIXME: Use correct value for C23.
442*12c85518Srobert if (LangOpts.C2x)
443*12c85518Srobert Builder.defineMacro("__STDC_VERSION__", "202000L");
444*12c85518Srobert else if (LangOpts.C17)
445e5dd7070Spatrick Builder.defineMacro("__STDC_VERSION__", "201710L");
446e5dd7070Spatrick else if (LangOpts.C11)
447e5dd7070Spatrick Builder.defineMacro("__STDC_VERSION__", "201112L");
448e5dd7070Spatrick else if (LangOpts.C99)
449e5dd7070Spatrick Builder.defineMacro("__STDC_VERSION__", "199901L");
450e5dd7070Spatrick else if (!LangOpts.GNUMode && LangOpts.Digraphs)
451e5dd7070Spatrick Builder.defineMacro("__STDC_VERSION__", "199409L");
452e5dd7070Spatrick } else {
453e5dd7070Spatrick // -- __cplusplus
454a9ac8606Spatrick // FIXME: Use correct value for C++23.
455a9ac8606Spatrick if (LangOpts.CPlusPlus2b)
456a9ac8606Spatrick Builder.defineMacro("__cplusplus", "202101L");
457e5dd7070Spatrick // [C++20] The integer literal 202002L.
458a9ac8606Spatrick else if (LangOpts.CPlusPlus20)
459e5dd7070Spatrick Builder.defineMacro("__cplusplus", "202002L");
460e5dd7070Spatrick // [C++17] The integer literal 201703L.
461e5dd7070Spatrick else if (LangOpts.CPlusPlus17)
462e5dd7070Spatrick Builder.defineMacro("__cplusplus", "201703L");
463e5dd7070Spatrick // [C++14] The name __cplusplus is defined to the value 201402L when
464e5dd7070Spatrick // compiling a C++ translation unit.
465e5dd7070Spatrick else if (LangOpts.CPlusPlus14)
466e5dd7070Spatrick Builder.defineMacro("__cplusplus", "201402L");
467e5dd7070Spatrick // [C++11] The name __cplusplus is defined to the value 201103L when
468e5dd7070Spatrick // compiling a C++ translation unit.
469e5dd7070Spatrick else if (LangOpts.CPlusPlus11)
470e5dd7070Spatrick Builder.defineMacro("__cplusplus", "201103L");
471e5dd7070Spatrick // [C++03] The name __cplusplus is defined to the value 199711L when
472e5dd7070Spatrick // compiling a C++ translation unit.
473e5dd7070Spatrick else
474e5dd7070Spatrick Builder.defineMacro("__cplusplus", "199711L");
475e5dd7070Spatrick
476e5dd7070Spatrick // -- __STDCPP_DEFAULT_NEW_ALIGNMENT__
477e5dd7070Spatrick // [C++17] An integer literal of type std::size_t whose value is the
478e5dd7070Spatrick // alignment guaranteed by a call to operator new(std::size_t)
479e5dd7070Spatrick //
480e5dd7070Spatrick // We provide this in all language modes, since it seems generally useful.
481e5dd7070Spatrick Builder.defineMacro("__STDCPP_DEFAULT_NEW_ALIGNMENT__",
482e5dd7070Spatrick Twine(TI.getNewAlign() / TI.getCharWidth()) +
483e5dd7070Spatrick TI.getTypeConstantSuffix(TI.getSizeType()));
484a9ac8606Spatrick
485a9ac8606Spatrick // -- __STDCPP_THREADS__
486a9ac8606Spatrick // Defined, and has the value integer literal 1, if and only if a
487a9ac8606Spatrick // program can have more than one thread of execution.
488a9ac8606Spatrick if (LangOpts.getThreadModel() == LangOptions::ThreadModelKind::POSIX)
489a9ac8606Spatrick Builder.defineMacro("__STDCPP_THREADS__", "1");
490e5dd7070Spatrick }
491e5dd7070Spatrick
492e5dd7070Spatrick // In C11 these are environment macros. In C++11 they are only defined
493e5dd7070Spatrick // as part of <cuchar>. To prevent breakage when mixing C and C++
494e5dd7070Spatrick // code, define these macros unconditionally. We can define them
495e5dd7070Spatrick // unconditionally, as Clang always uses UTF-16 and UTF-32 for 16-bit
496e5dd7070Spatrick // and 32-bit character literals.
497e5dd7070Spatrick Builder.defineMacro("__STDC_UTF_16__", "1");
498e5dd7070Spatrick Builder.defineMacro("__STDC_UTF_32__", "1");
499e5dd7070Spatrick
500e5dd7070Spatrick if (LangOpts.ObjC)
501e5dd7070Spatrick Builder.defineMacro("__OBJC__");
502e5dd7070Spatrick
503e5dd7070Spatrick // OpenCL v1.0/1.1 s6.9, v1.2/2.0 s6.10: Preprocessor Directives and Macros.
504e5dd7070Spatrick if (LangOpts.OpenCL) {
505e5dd7070Spatrick if (LangOpts.CPlusPlus) {
506*12c85518Srobert switch (LangOpts.OpenCLCPlusPlusVersion) {
507*12c85518Srobert case 100:
508e5dd7070Spatrick Builder.defineMacro("__OPENCL_CPP_VERSION__", "100");
509*12c85518Srobert break;
510*12c85518Srobert case 202100:
511*12c85518Srobert Builder.defineMacro("__OPENCL_CPP_VERSION__", "202100");
512*12c85518Srobert break;
513*12c85518Srobert default:
514e5dd7070Spatrick llvm_unreachable("Unsupported C++ version for OpenCL");
515*12c85518Srobert }
516e5dd7070Spatrick Builder.defineMacro("__CL_CPP_VERSION_1_0__", "100");
517*12c85518Srobert Builder.defineMacro("__CL_CPP_VERSION_2021__", "202100");
518e5dd7070Spatrick } else {
519e5dd7070Spatrick // OpenCL v1.0 and v1.1 do not have a predefined macro to indicate the
520e5dd7070Spatrick // language standard with which the program is compiled. __OPENCL_VERSION__
521e5dd7070Spatrick // is for the OpenCL version supported by the OpenCL device, which is not
522e5dd7070Spatrick // necessarily the language standard with which the program is compiled.
523e5dd7070Spatrick // A shared OpenCL header file requires a macro to indicate the language
524e5dd7070Spatrick // standard. As a workaround, __OPENCL_C_VERSION__ is defined for
525e5dd7070Spatrick // OpenCL v1.0 and v1.1.
526e5dd7070Spatrick switch (LangOpts.OpenCLVersion) {
527e5dd7070Spatrick case 100:
528e5dd7070Spatrick Builder.defineMacro("__OPENCL_C_VERSION__", "100");
529e5dd7070Spatrick break;
530e5dd7070Spatrick case 110:
531e5dd7070Spatrick Builder.defineMacro("__OPENCL_C_VERSION__", "110");
532e5dd7070Spatrick break;
533e5dd7070Spatrick case 120:
534e5dd7070Spatrick Builder.defineMacro("__OPENCL_C_VERSION__", "120");
535e5dd7070Spatrick break;
536e5dd7070Spatrick case 200:
537e5dd7070Spatrick Builder.defineMacro("__OPENCL_C_VERSION__", "200");
538e5dd7070Spatrick break;
539a9ac8606Spatrick case 300:
540a9ac8606Spatrick Builder.defineMacro("__OPENCL_C_VERSION__", "300");
541a9ac8606Spatrick break;
542e5dd7070Spatrick default:
543e5dd7070Spatrick llvm_unreachable("Unsupported OpenCL version");
544e5dd7070Spatrick }
545e5dd7070Spatrick }
546e5dd7070Spatrick Builder.defineMacro("CL_VERSION_1_0", "100");
547e5dd7070Spatrick Builder.defineMacro("CL_VERSION_1_1", "110");
548e5dd7070Spatrick Builder.defineMacro("CL_VERSION_1_2", "120");
549e5dd7070Spatrick Builder.defineMacro("CL_VERSION_2_0", "200");
550a9ac8606Spatrick Builder.defineMacro("CL_VERSION_3_0", "300");
551e5dd7070Spatrick
552e5dd7070Spatrick if (TI.isLittleEndian())
553e5dd7070Spatrick Builder.defineMacro("__ENDIAN_LITTLE__");
554e5dd7070Spatrick
555e5dd7070Spatrick if (LangOpts.FastRelaxedMath)
556e5dd7070Spatrick Builder.defineMacro("__FAST_RELAXED_MATH__");
557e5dd7070Spatrick }
558ec727ea7Spatrick
559a9ac8606Spatrick if (LangOpts.SYCLIsDevice || LangOpts.SYCLIsHost) {
560ec727ea7Spatrick // SYCL Version is set to a value when building SYCL applications
561a9ac8606Spatrick if (LangOpts.getSYCLVersion() == LangOptions::SYCL_2017)
562ec727ea7Spatrick Builder.defineMacro("CL_SYCL_LANGUAGE_VERSION", "121");
563a9ac8606Spatrick else if (LangOpts.getSYCLVersion() == LangOptions::SYCL_2020)
564a9ac8606Spatrick Builder.defineMacro("SYCL_LANGUAGE_VERSION", "202001");
565ec727ea7Spatrick }
566ec727ea7Spatrick
567e5dd7070Spatrick // Not "standard" per se, but available even with the -undef flag.
568e5dd7070Spatrick if (LangOpts.AsmPreprocessor)
569e5dd7070Spatrick Builder.defineMacro("__ASSEMBLER__");
570*12c85518Srobert if (LangOpts.CUDA) {
571*12c85518Srobert if (LangOpts.GPURelocatableDeviceCode)
572*12c85518Srobert Builder.defineMacro("__CLANG_RDC__");
573*12c85518Srobert if (!LangOpts.HIP)
574e5dd7070Spatrick Builder.defineMacro("__CUDA__");
575*12c85518Srobert }
576e5dd7070Spatrick if (LangOpts.HIP) {
577e5dd7070Spatrick Builder.defineMacro("__HIP__");
578e5dd7070Spatrick Builder.defineMacro("__HIPCC__");
579*12c85518Srobert Builder.defineMacro("__HIP_MEMORY_SCOPE_SINGLETHREAD", "1");
580*12c85518Srobert Builder.defineMacro("__HIP_MEMORY_SCOPE_WAVEFRONT", "2");
581*12c85518Srobert Builder.defineMacro("__HIP_MEMORY_SCOPE_WORKGROUP", "3");
582*12c85518Srobert Builder.defineMacro("__HIP_MEMORY_SCOPE_AGENT", "4");
583*12c85518Srobert Builder.defineMacro("__HIP_MEMORY_SCOPE_SYSTEM", "5");
584e5dd7070Spatrick if (LangOpts.CUDAIsDevice)
585e5dd7070Spatrick Builder.defineMacro("__HIP_DEVICE_COMPILE__");
586*12c85518Srobert if (LangOpts.GPUDefaultStream ==
587*12c85518Srobert LangOptions::GPUDefaultStreamKind::PerThread)
588*12c85518Srobert Builder.defineMacro("HIP_API_PER_THREAD_DEFAULT_STREAM");
589e5dd7070Spatrick }
590e5dd7070Spatrick }
591e5dd7070Spatrick
592e5dd7070Spatrick /// Initialize the predefined C++ language feature test macros defined in
593e5dd7070Spatrick /// ISO/IEC JTC1/SC22/WG21 (C++) SD-6: "SG10 Feature Test Recommendations".
InitializeCPlusPlusFeatureTestMacros(const LangOptions & LangOpts,MacroBuilder & Builder)594e5dd7070Spatrick static void InitializeCPlusPlusFeatureTestMacros(const LangOptions &LangOpts,
595e5dd7070Spatrick MacroBuilder &Builder) {
596e5dd7070Spatrick // C++98 features.
597e5dd7070Spatrick if (LangOpts.RTTI)
598e5dd7070Spatrick Builder.defineMacro("__cpp_rtti", "199711L");
599e5dd7070Spatrick if (LangOpts.CXXExceptions)
600e5dd7070Spatrick Builder.defineMacro("__cpp_exceptions", "199711L");
601e5dd7070Spatrick
602e5dd7070Spatrick // C++11 features.
603e5dd7070Spatrick if (LangOpts.CPlusPlus11) {
604e5dd7070Spatrick Builder.defineMacro("__cpp_unicode_characters", "200704L");
605e5dd7070Spatrick Builder.defineMacro("__cpp_raw_strings", "200710L");
606e5dd7070Spatrick Builder.defineMacro("__cpp_unicode_literals", "200710L");
607e5dd7070Spatrick Builder.defineMacro("__cpp_user_defined_literals", "200809L");
608e5dd7070Spatrick Builder.defineMacro("__cpp_lambdas", "200907L");
609*12c85518Srobert Builder.defineMacro("__cpp_constexpr", LangOpts.CPlusPlus2b ? "202211L"
610*12c85518Srobert : LangOpts.CPlusPlus20 ? "201907L"
611*12c85518Srobert : LangOpts.CPlusPlus17 ? "201603L"
612*12c85518Srobert : LangOpts.CPlusPlus14 ? "201304L"
613*12c85518Srobert : "200704");
614e5dd7070Spatrick Builder.defineMacro("__cpp_constexpr_in_decltype", "201711L");
615e5dd7070Spatrick Builder.defineMacro("__cpp_range_based_for",
616e5dd7070Spatrick LangOpts.CPlusPlus17 ? "201603L" : "200907");
617e5dd7070Spatrick Builder.defineMacro("__cpp_static_assert",
618e5dd7070Spatrick LangOpts.CPlusPlus17 ? "201411L" : "200410");
619e5dd7070Spatrick Builder.defineMacro("__cpp_decltype", "200707L");
620e5dd7070Spatrick Builder.defineMacro("__cpp_attributes", "200809L");
621e5dd7070Spatrick Builder.defineMacro("__cpp_rvalue_references", "200610L");
622e5dd7070Spatrick Builder.defineMacro("__cpp_variadic_templates", "200704L");
623e5dd7070Spatrick Builder.defineMacro("__cpp_initializer_lists", "200806L");
624e5dd7070Spatrick Builder.defineMacro("__cpp_delegating_constructors", "200604L");
625e5dd7070Spatrick Builder.defineMacro("__cpp_nsdmi", "200809L");
626e5dd7070Spatrick Builder.defineMacro("__cpp_inheriting_constructors", "201511L");
627e5dd7070Spatrick Builder.defineMacro("__cpp_ref_qualifiers", "200710L");
628e5dd7070Spatrick Builder.defineMacro("__cpp_alias_templates", "200704L");
629e5dd7070Spatrick }
630e5dd7070Spatrick if (LangOpts.ThreadsafeStatics)
631e5dd7070Spatrick Builder.defineMacro("__cpp_threadsafe_static_init", "200806L");
632e5dd7070Spatrick
633e5dd7070Spatrick // C++14 features.
634e5dd7070Spatrick if (LangOpts.CPlusPlus14) {
635e5dd7070Spatrick Builder.defineMacro("__cpp_binary_literals", "201304L");
636e5dd7070Spatrick Builder.defineMacro("__cpp_digit_separators", "201309L");
637e5dd7070Spatrick Builder.defineMacro("__cpp_init_captures",
638ec727ea7Spatrick LangOpts.CPlusPlus20 ? "201803L" : "201304L");
639e5dd7070Spatrick Builder.defineMacro("__cpp_generic_lambdas",
640ec727ea7Spatrick LangOpts.CPlusPlus20 ? "201707L" : "201304L");
641e5dd7070Spatrick Builder.defineMacro("__cpp_decltype_auto", "201304L");
642e5dd7070Spatrick Builder.defineMacro("__cpp_return_type_deduction", "201304L");
643e5dd7070Spatrick Builder.defineMacro("__cpp_aggregate_nsdmi", "201304L");
644e5dd7070Spatrick Builder.defineMacro("__cpp_variable_templates", "201304L");
645e5dd7070Spatrick }
646e5dd7070Spatrick if (LangOpts.SizedDeallocation)
647e5dd7070Spatrick Builder.defineMacro("__cpp_sized_deallocation", "201309L");
648e5dd7070Spatrick
649e5dd7070Spatrick // C++17 features.
650e5dd7070Spatrick if (LangOpts.CPlusPlus17) {
651e5dd7070Spatrick Builder.defineMacro("__cpp_hex_float", "201603L");
652e5dd7070Spatrick Builder.defineMacro("__cpp_inline_variables", "201606L");
653e5dd7070Spatrick Builder.defineMacro("__cpp_noexcept_function_type", "201510L");
654e5dd7070Spatrick Builder.defineMacro("__cpp_capture_star_this", "201603L");
655e5dd7070Spatrick Builder.defineMacro("__cpp_if_constexpr", "201606L");
656e5dd7070Spatrick Builder.defineMacro("__cpp_deduction_guides", "201703L"); // (not latest)
657e5dd7070Spatrick Builder.defineMacro("__cpp_template_auto", "201606L"); // (old name)
658e5dd7070Spatrick Builder.defineMacro("__cpp_namespace_attributes", "201411L");
659e5dd7070Spatrick Builder.defineMacro("__cpp_enumerator_attributes", "201411L");
660e5dd7070Spatrick Builder.defineMacro("__cpp_nested_namespace_definitions", "201411L");
661e5dd7070Spatrick Builder.defineMacro("__cpp_variadic_using", "201611L");
662e5dd7070Spatrick Builder.defineMacro("__cpp_aggregate_bases", "201603L");
663e5dd7070Spatrick Builder.defineMacro("__cpp_structured_bindings", "201606L");
664e5dd7070Spatrick Builder.defineMacro("__cpp_nontype_template_args",
665e5dd7070Spatrick "201411L"); // (not latest)
666e5dd7070Spatrick Builder.defineMacro("__cpp_fold_expressions", "201603L");
667e5dd7070Spatrick Builder.defineMacro("__cpp_guaranteed_copy_elision", "201606L");
668e5dd7070Spatrick Builder.defineMacro("__cpp_nontype_template_parameter_auto", "201606L");
669e5dd7070Spatrick }
670e5dd7070Spatrick if (LangOpts.AlignedAllocation && !LangOpts.AlignedAllocationUnavailable)
671e5dd7070Spatrick Builder.defineMacro("__cpp_aligned_new", "201606L");
672e5dd7070Spatrick if (LangOpts.RelaxedTemplateTemplateArgs)
673e5dd7070Spatrick Builder.defineMacro("__cpp_template_template_args", "201611L");
674e5dd7070Spatrick
675e5dd7070Spatrick // C++20 features.
676ec727ea7Spatrick if (LangOpts.CPlusPlus20) {
677*12c85518Srobert Builder.defineMacro("__cpp_aggregate_paren_init", "201902L");
678*12c85518Srobert
679*12c85518Srobert // P0848 is implemented, but we're still waiting for other concepts
680*12c85518Srobert // issues to be addressed before bumping __cpp_concepts up to 202002L.
681*12c85518Srobert // Refer to the discussion of this at https://reviews.llvm.org/D128619.
682e5dd7070Spatrick Builder.defineMacro("__cpp_concepts", "201907L");
683e5dd7070Spatrick Builder.defineMacro("__cpp_conditional_explicit", "201806L");
684e5dd7070Spatrick //Builder.defineMacro("__cpp_consteval", "201811L");
685e5dd7070Spatrick Builder.defineMacro("__cpp_constexpr_dynamic_alloc", "201907L");
686e5dd7070Spatrick Builder.defineMacro("__cpp_constinit", "201907L");
687*12c85518Srobert Builder.defineMacro("__cpp_impl_coroutine", "201902L");
688e5dd7070Spatrick Builder.defineMacro("__cpp_designated_initializers", "201707L");
689e5dd7070Spatrick Builder.defineMacro("__cpp_impl_three_way_comparison", "201907L");
690e5dd7070Spatrick //Builder.defineMacro("__cpp_modules", "201907L");
691a9ac8606Spatrick Builder.defineMacro("__cpp_using_enum", "201907L");
692a9ac8606Spatrick }
693a9ac8606Spatrick // C++2b features.
694a9ac8606Spatrick if (LangOpts.CPlusPlus2b) {
695a9ac8606Spatrick Builder.defineMacro("__cpp_implicit_move", "202011L");
696a9ac8606Spatrick Builder.defineMacro("__cpp_size_t_suffix", "202011L");
697*12c85518Srobert Builder.defineMacro("__cpp_if_consteval", "202106L");
698*12c85518Srobert Builder.defineMacro("__cpp_multidimensional_subscript", "202211L");
699e5dd7070Spatrick }
700*12c85518Srobert
701*12c85518Srobert // We provide those C++2b features as extensions in earlier language modes, so
702*12c85518Srobert // we also define their feature test macros.
703*12c85518Srobert if (LangOpts.CPlusPlus11)
704*12c85518Srobert Builder.defineMacro("__cpp_static_call_operator", "202207L");
705*12c85518Srobert Builder.defineMacro("__cpp_named_character_escapes", "202207L");
706*12c85518Srobert
707e5dd7070Spatrick if (LangOpts.Char8)
708*12c85518Srobert Builder.defineMacro("__cpp_char8_t", "202207L");
709e5dd7070Spatrick Builder.defineMacro("__cpp_impl_destroying_delete", "201806L");
710e5dd7070Spatrick
711e5dd7070Spatrick // TS features.
712e5dd7070Spatrick if (LangOpts.Coroutines)
713e5dd7070Spatrick Builder.defineMacro("__cpp_coroutines", "201703L");
714e5dd7070Spatrick }
715e5dd7070Spatrick
716a9ac8606Spatrick /// InitializeOpenCLFeatureTestMacros - Define OpenCL macros based on target
717a9ac8606Spatrick /// settings and language version
InitializeOpenCLFeatureTestMacros(const TargetInfo & TI,const LangOptions & Opts,MacroBuilder & Builder)718a9ac8606Spatrick void InitializeOpenCLFeatureTestMacros(const TargetInfo &TI,
719a9ac8606Spatrick const LangOptions &Opts,
720a9ac8606Spatrick MacroBuilder &Builder) {
721a9ac8606Spatrick const llvm::StringMap<bool> &OpenCLFeaturesMap = TI.getSupportedOpenCLOpts();
722a9ac8606Spatrick // FIXME: OpenCL options which affect language semantics/syntax
723a9ac8606Spatrick // should be moved into LangOptions.
724a9ac8606Spatrick auto defineOpenCLExtMacro = [&](llvm::StringRef Name, auto... OptArgs) {
725a9ac8606Spatrick // Check if extension is supported by target and is available in this
726a9ac8606Spatrick // OpenCL version
727a9ac8606Spatrick if (TI.hasFeatureEnabled(OpenCLFeaturesMap, Name) &&
728a9ac8606Spatrick OpenCLOptions::isOpenCLOptionAvailableIn(Opts, OptArgs...))
729a9ac8606Spatrick Builder.defineMacro(Name);
730a9ac8606Spatrick };
731a9ac8606Spatrick #define OPENCL_GENERIC_EXTENSION(Ext, ...) \
732a9ac8606Spatrick defineOpenCLExtMacro(#Ext, __VA_ARGS__);
733a9ac8606Spatrick #include "clang/Basic/OpenCLExtensions.def"
734a9ac8606Spatrick
735a9ac8606Spatrick // Assume compiling for FULL profile
736a9ac8606Spatrick Builder.defineMacro("__opencl_c_int64");
737a9ac8606Spatrick }
738a9ac8606Spatrick
InitializePredefinedMacros(const TargetInfo & TI,const LangOptions & LangOpts,const FrontendOptions & FEOpts,const PreprocessorOptions & PPOpts,MacroBuilder & Builder)739e5dd7070Spatrick static void InitializePredefinedMacros(const TargetInfo &TI,
740e5dd7070Spatrick const LangOptions &LangOpts,
741e5dd7070Spatrick const FrontendOptions &FEOpts,
742e5dd7070Spatrick const PreprocessorOptions &PPOpts,
743e5dd7070Spatrick MacroBuilder &Builder) {
744e5dd7070Spatrick // Compiler version introspection macros.
745e5dd7070Spatrick Builder.defineMacro("__llvm__"); // LLVM Backend
746e5dd7070Spatrick Builder.defineMacro("__clang__"); // Clang Frontend
747e5dd7070Spatrick #define TOSTR2(X) #X
748e5dd7070Spatrick #define TOSTR(X) TOSTR2(X)
749e5dd7070Spatrick Builder.defineMacro("__clang_major__", TOSTR(CLANG_VERSION_MAJOR));
750e5dd7070Spatrick Builder.defineMacro("__clang_minor__", TOSTR(CLANG_VERSION_MINOR));
751e5dd7070Spatrick Builder.defineMacro("__clang_patchlevel__", TOSTR(CLANG_VERSION_PATCHLEVEL));
752e5dd7070Spatrick #undef TOSTR
753e5dd7070Spatrick #undef TOSTR2
754e5dd7070Spatrick Builder.defineMacro("__clang_version__",
755e5dd7070Spatrick "\"" CLANG_VERSION_STRING " "
756e5dd7070Spatrick + getClangFullRepositoryVersion() + "\"");
757e5dd7070Spatrick
758e5dd7070Spatrick if (LangOpts.GNUCVersion != 0) {
759e5dd7070Spatrick // Major, minor, patch, are given two decimal places each, so 4.2.1 becomes
760e5dd7070Spatrick // 40201.
761e5dd7070Spatrick unsigned GNUCMajor = LangOpts.GNUCVersion / 100 / 100;
762e5dd7070Spatrick unsigned GNUCMinor = LangOpts.GNUCVersion / 100 % 100;
763e5dd7070Spatrick unsigned GNUCPatch = LangOpts.GNUCVersion % 100;
764e5dd7070Spatrick Builder.defineMacro("__GNUC__", Twine(GNUCMajor));
765e5dd7070Spatrick Builder.defineMacro("__GNUC_MINOR__", Twine(GNUCMinor));
766e5dd7070Spatrick Builder.defineMacro("__GNUC_PATCHLEVEL__", Twine(GNUCPatch));
767e5dd7070Spatrick Builder.defineMacro("__GXX_ABI_VERSION", "1002");
768e5dd7070Spatrick
769e5dd7070Spatrick if (LangOpts.CPlusPlus) {
770e5dd7070Spatrick Builder.defineMacro("__GNUG__", Twine(GNUCMajor));
771e5dd7070Spatrick Builder.defineMacro("__GXX_WEAK__");
772e5dd7070Spatrick }
773e5dd7070Spatrick }
774e5dd7070Spatrick
775e5dd7070Spatrick // Define macros for the C11 / C++11 memory orderings
776e5dd7070Spatrick Builder.defineMacro("__ATOMIC_RELAXED", "0");
777e5dd7070Spatrick Builder.defineMacro("__ATOMIC_CONSUME", "1");
778e5dd7070Spatrick Builder.defineMacro("__ATOMIC_ACQUIRE", "2");
779e5dd7070Spatrick Builder.defineMacro("__ATOMIC_RELEASE", "3");
780e5dd7070Spatrick Builder.defineMacro("__ATOMIC_ACQ_REL", "4");
781e5dd7070Spatrick Builder.defineMacro("__ATOMIC_SEQ_CST", "5");
782e5dd7070Spatrick
783e5dd7070Spatrick // Define macros for the OpenCL memory scope.
784e5dd7070Spatrick // The values should match AtomicScopeOpenCLModel::ID enum.
785e5dd7070Spatrick static_assert(
786e5dd7070Spatrick static_cast<unsigned>(AtomicScopeOpenCLModel::WorkGroup) == 1 &&
787e5dd7070Spatrick static_cast<unsigned>(AtomicScopeOpenCLModel::Device) == 2 &&
788e5dd7070Spatrick static_cast<unsigned>(AtomicScopeOpenCLModel::AllSVMDevices) == 3 &&
789e5dd7070Spatrick static_cast<unsigned>(AtomicScopeOpenCLModel::SubGroup) == 4,
790e5dd7070Spatrick "Invalid OpenCL memory scope enum definition");
791e5dd7070Spatrick Builder.defineMacro("__OPENCL_MEMORY_SCOPE_WORK_ITEM", "0");
792e5dd7070Spatrick Builder.defineMacro("__OPENCL_MEMORY_SCOPE_WORK_GROUP", "1");
793e5dd7070Spatrick Builder.defineMacro("__OPENCL_MEMORY_SCOPE_DEVICE", "2");
794e5dd7070Spatrick Builder.defineMacro("__OPENCL_MEMORY_SCOPE_ALL_SVM_DEVICES", "3");
795e5dd7070Spatrick Builder.defineMacro("__OPENCL_MEMORY_SCOPE_SUB_GROUP", "4");
796e5dd7070Spatrick
797e5dd7070Spatrick // Support for #pragma redefine_extname (Sun compatibility)
798e5dd7070Spatrick Builder.defineMacro("__PRAGMA_REDEFINE_EXTNAME", "1");
799e5dd7070Spatrick
800e5dd7070Spatrick // Previously this macro was set to a string aiming to achieve compatibility
801e5dd7070Spatrick // with GCC 4.2.1. Now, just return the full Clang version
802e5dd7070Spatrick Builder.defineMacro("__VERSION__", "\"" +
803e5dd7070Spatrick Twine(getClangFullCPPVersion()) + "\"");
804e5dd7070Spatrick
805e5dd7070Spatrick // Initialize language-specific preprocessor defines.
806e5dd7070Spatrick
807e5dd7070Spatrick // Standard conforming mode?
808e5dd7070Spatrick if (!LangOpts.GNUMode && !LangOpts.MSVCCompat)
809e5dd7070Spatrick Builder.defineMacro("__STRICT_ANSI__");
810e5dd7070Spatrick
811e5dd7070Spatrick if (LangOpts.GNUCVersion && LangOpts.CPlusPlus11)
812e5dd7070Spatrick Builder.defineMacro("__GXX_EXPERIMENTAL_CXX0X__");
813e5dd7070Spatrick
814e5dd7070Spatrick if (LangOpts.ObjC) {
815e5dd7070Spatrick if (LangOpts.ObjCRuntime.isNonFragile()) {
816e5dd7070Spatrick Builder.defineMacro("__OBJC2__");
817e5dd7070Spatrick
818e5dd7070Spatrick if (LangOpts.ObjCExceptions)
819e5dd7070Spatrick Builder.defineMacro("OBJC_ZEROCOST_EXCEPTIONS");
820e5dd7070Spatrick }
821e5dd7070Spatrick
822e5dd7070Spatrick if (LangOpts.getGC() != LangOptions::NonGC)
823e5dd7070Spatrick Builder.defineMacro("__OBJC_GC__");
824e5dd7070Spatrick
825e5dd7070Spatrick if (LangOpts.ObjCRuntime.isNeXTFamily())
826e5dd7070Spatrick Builder.defineMacro("__NEXT_RUNTIME__");
827e5dd7070Spatrick
828e5dd7070Spatrick if (LangOpts.ObjCRuntime.getKind() == ObjCRuntime::GNUstep) {
829e5dd7070Spatrick auto version = LangOpts.ObjCRuntime.getVersion();
830e5dd7070Spatrick std::string versionString = "1";
831e5dd7070Spatrick // Don't rely on the tuple argument, because we can be asked to target
832e5dd7070Spatrick // later ABIs than we actually support, so clamp these values to those
833e5dd7070Spatrick // currently supported
834e5dd7070Spatrick if (version >= VersionTuple(2, 0))
835e5dd7070Spatrick Builder.defineMacro("__OBJC_GNUSTEP_RUNTIME_ABI__", "20");
836e5dd7070Spatrick else
837*12c85518Srobert Builder.defineMacro(
838*12c85518Srobert "__OBJC_GNUSTEP_RUNTIME_ABI__",
839*12c85518Srobert "1" + Twine(std::min(8U, version.getMinor().value_or(0))));
840e5dd7070Spatrick }
841e5dd7070Spatrick
842e5dd7070Spatrick if (LangOpts.ObjCRuntime.getKind() == ObjCRuntime::ObjFW) {
843e5dd7070Spatrick VersionTuple tuple = LangOpts.ObjCRuntime.getVersion();
844*12c85518Srobert unsigned minor = tuple.getMinor().value_or(0);
845*12c85518Srobert unsigned subminor = tuple.getSubminor().value_or(0);
846e5dd7070Spatrick Builder.defineMacro("__OBJFW_RUNTIME_ABI__",
847e5dd7070Spatrick Twine(tuple.getMajor() * 10000 + minor * 100 +
848e5dd7070Spatrick subminor));
849e5dd7070Spatrick }
850e5dd7070Spatrick
851e5dd7070Spatrick Builder.defineMacro("IBOutlet", "__attribute__((iboutlet))");
852e5dd7070Spatrick Builder.defineMacro("IBOutletCollection(ClassName)",
853e5dd7070Spatrick "__attribute__((iboutletcollection(ClassName)))");
854e5dd7070Spatrick Builder.defineMacro("IBAction", "void)__attribute__((ibaction)");
855e5dd7070Spatrick Builder.defineMacro("IBInspectable", "");
856e5dd7070Spatrick Builder.defineMacro("IB_DESIGNABLE", "");
857e5dd7070Spatrick }
858e5dd7070Spatrick
859e5dd7070Spatrick // Define a macro that describes the Objective-C boolean type even for C
860e5dd7070Spatrick // and C++ since BOOL can be used from non Objective-C code.
861e5dd7070Spatrick Builder.defineMacro("__OBJC_BOOL_IS_BOOL",
862e5dd7070Spatrick Twine(TI.useSignedCharForObjCBool() ? "0" : "1"));
863e5dd7070Spatrick
864e5dd7070Spatrick if (LangOpts.CPlusPlus)
865e5dd7070Spatrick InitializeCPlusPlusFeatureTestMacros(LangOpts, Builder);
866e5dd7070Spatrick
867e5dd7070Spatrick // darwin_constant_cfstrings controls this. This is also dependent
868e5dd7070Spatrick // on other things like the runtime I believe. This is set even for C code.
869e5dd7070Spatrick if (!LangOpts.NoConstantCFStrings)
870e5dd7070Spatrick Builder.defineMacro("__CONSTANT_CFSTRINGS__");
871e5dd7070Spatrick
872e5dd7070Spatrick if (LangOpts.ObjC)
873e5dd7070Spatrick Builder.defineMacro("OBJC_NEW_PROPERTIES");
874e5dd7070Spatrick
875e5dd7070Spatrick if (LangOpts.PascalStrings)
876e5dd7070Spatrick Builder.defineMacro("__PASCAL_STRINGS__");
877e5dd7070Spatrick
878e5dd7070Spatrick if (LangOpts.Blocks) {
879e5dd7070Spatrick Builder.defineMacro("__block", "__attribute__((__blocks__(byref)))");
880e5dd7070Spatrick Builder.defineMacro("__BLOCKS__");
881e5dd7070Spatrick }
882e5dd7070Spatrick
883e5dd7070Spatrick if (!LangOpts.MSVCCompat && LangOpts.Exceptions)
884e5dd7070Spatrick Builder.defineMacro("__EXCEPTIONS");
885e5dd7070Spatrick if (LangOpts.GNUCVersion && LangOpts.RTTI)
886e5dd7070Spatrick Builder.defineMacro("__GXX_RTTI");
887e5dd7070Spatrick
888a9ac8606Spatrick if (LangOpts.hasSjLjExceptions())
889e5dd7070Spatrick Builder.defineMacro("__USING_SJLJ_EXCEPTIONS__");
890a9ac8606Spatrick else if (LangOpts.hasSEHExceptions())
891e5dd7070Spatrick Builder.defineMacro("__SEH__");
892a9ac8606Spatrick else if (LangOpts.hasDWARFExceptions() &&
893e5dd7070Spatrick (TI.getTriple().isThumb() || TI.getTriple().isARM()))
894e5dd7070Spatrick Builder.defineMacro("__ARM_DWARF_EH__");
895e5dd7070Spatrick
896e5dd7070Spatrick if (LangOpts.Deprecated)
897e5dd7070Spatrick Builder.defineMacro("__DEPRECATED");
898e5dd7070Spatrick
899e5dd7070Spatrick if (!LangOpts.MSVCCompat && LangOpts.CPlusPlus)
900e5dd7070Spatrick Builder.defineMacro("__private_extern__", "extern");
901e5dd7070Spatrick
902e5dd7070Spatrick if (LangOpts.MicrosoftExt) {
903e5dd7070Spatrick if (LangOpts.WChar) {
904e5dd7070Spatrick // wchar_t supported as a keyword.
905e5dd7070Spatrick Builder.defineMacro("_WCHAR_T_DEFINED");
906e5dd7070Spatrick Builder.defineMacro("_NATIVE_WCHAR_T_DEFINED");
907e5dd7070Spatrick }
908e5dd7070Spatrick }
909e5dd7070Spatrick
910a9ac8606Spatrick // Macros to help identify the narrow and wide character sets
911a9ac8606Spatrick // FIXME: clang currently ignores -fexec-charset=. If this changes,
912a9ac8606Spatrick // then this may need to be updated.
913a9ac8606Spatrick Builder.defineMacro("__clang_literal_encoding__", "\"UTF-8\"");
914a9ac8606Spatrick if (TI.getTypeWidth(TI.getWCharType()) >= 32) {
915a9ac8606Spatrick // FIXME: 32-bit wchar_t signals UTF-32. This may change
916a9ac8606Spatrick // if -fwide-exec-charset= is ever supported.
917a9ac8606Spatrick Builder.defineMacro("__clang_wide_literal_encoding__", "\"UTF-32\"");
918a9ac8606Spatrick } else {
919a9ac8606Spatrick // FIXME: Less-than 32-bit wchar_t generally means UTF-16
920a9ac8606Spatrick // (e.g., Windows, 32-bit IBM). This may need to be
921a9ac8606Spatrick // updated if -fwide-exec-charset= is ever supported.
922a9ac8606Spatrick Builder.defineMacro("__clang_wide_literal_encoding__", "\"UTF-16\"");
923a9ac8606Spatrick }
924a9ac8606Spatrick
925e5dd7070Spatrick if (LangOpts.Optimize)
926e5dd7070Spatrick Builder.defineMacro("__OPTIMIZE__");
927e5dd7070Spatrick if (LangOpts.OptimizeSize)
928e5dd7070Spatrick Builder.defineMacro("__OPTIMIZE_SIZE__");
929e5dd7070Spatrick
930e5dd7070Spatrick if (LangOpts.FastMath)
931e5dd7070Spatrick Builder.defineMacro("__FAST_MATH__");
932e5dd7070Spatrick
933e5dd7070Spatrick // Initialize target-specific preprocessor defines.
934e5dd7070Spatrick
935e5dd7070Spatrick // __BYTE_ORDER__ was added in GCC 4.6. It's analogous
936e5dd7070Spatrick // to the macro __BYTE_ORDER (no trailing underscores)
937e5dd7070Spatrick // from glibc's <endian.h> header.
938e5dd7070Spatrick // We don't support the PDP-11 as a target, but include
939e5dd7070Spatrick // the define so it can still be compared against.
940e5dd7070Spatrick Builder.defineMacro("__ORDER_LITTLE_ENDIAN__", "1234");
941e5dd7070Spatrick Builder.defineMacro("__ORDER_BIG_ENDIAN__", "4321");
942e5dd7070Spatrick Builder.defineMacro("__ORDER_PDP_ENDIAN__", "3412");
943e5dd7070Spatrick if (TI.isBigEndian()) {
944e5dd7070Spatrick Builder.defineMacro("__BYTE_ORDER__", "__ORDER_BIG_ENDIAN__");
945e5dd7070Spatrick Builder.defineMacro("__BIG_ENDIAN__");
946e5dd7070Spatrick } else {
947e5dd7070Spatrick Builder.defineMacro("__BYTE_ORDER__", "__ORDER_LITTLE_ENDIAN__");
948e5dd7070Spatrick Builder.defineMacro("__LITTLE_ENDIAN__");
949e5dd7070Spatrick }
950e5dd7070Spatrick
951*12c85518Srobert if (TI.getPointerWidth(LangAS::Default) == 64 && TI.getLongWidth() == 64 &&
952*12c85518Srobert TI.getIntWidth() == 32) {
953e5dd7070Spatrick Builder.defineMacro("_LP64");
954e5dd7070Spatrick Builder.defineMacro("__LP64__");
955e5dd7070Spatrick }
956e5dd7070Spatrick
957*12c85518Srobert if (TI.getPointerWidth(LangAS::Default) == 32 && TI.getLongWidth() == 32 &&
958*12c85518Srobert TI.getIntWidth() == 32) {
959e5dd7070Spatrick Builder.defineMacro("_ILP32");
960e5dd7070Spatrick Builder.defineMacro("__ILP32__");
961e5dd7070Spatrick }
962e5dd7070Spatrick
963e5dd7070Spatrick // Define type sizing macros based on the target properties.
964e5dd7070Spatrick assert(TI.getCharWidth() == 8 && "Only support 8-bit char so far");
965e5dd7070Spatrick Builder.defineMacro("__CHAR_BIT__", Twine(TI.getCharWidth()));
966e5dd7070Spatrick
967*12c85518Srobert Builder.defineMacro("__BOOL_WIDTH__", Twine(TI.getBoolWidth()));
968*12c85518Srobert Builder.defineMacro("__SHRT_WIDTH__", Twine(TI.getShortWidth()));
969*12c85518Srobert Builder.defineMacro("__INT_WIDTH__", Twine(TI.getIntWidth()));
970*12c85518Srobert Builder.defineMacro("__LONG_WIDTH__", Twine(TI.getLongWidth()));
971*12c85518Srobert Builder.defineMacro("__LLONG_WIDTH__", Twine(TI.getLongLongWidth()));
972*12c85518Srobert
973*12c85518Srobert size_t BitIntMaxWidth = TI.getMaxBitIntWidth();
974*12c85518Srobert assert(BitIntMaxWidth <= llvm::IntegerType::MAX_INT_BITS &&
975*12c85518Srobert "Target defined a max bit width larger than LLVM can support!");
976*12c85518Srobert assert(BitIntMaxWidth >= TI.getLongLongWidth() &&
977*12c85518Srobert "Target defined a max bit width smaller than the C standard allows!");
978*12c85518Srobert Builder.defineMacro("__BITINT_MAXWIDTH__", Twine(BitIntMaxWidth));
979*12c85518Srobert
980e5dd7070Spatrick DefineTypeSize("__SCHAR_MAX__", TargetInfo::SignedChar, TI, Builder);
981e5dd7070Spatrick DefineTypeSize("__SHRT_MAX__", TargetInfo::SignedShort, TI, Builder);
982e5dd7070Spatrick DefineTypeSize("__INT_MAX__", TargetInfo::SignedInt, TI, Builder);
983e5dd7070Spatrick DefineTypeSize("__LONG_MAX__", TargetInfo::SignedLong, TI, Builder);
984e5dd7070Spatrick DefineTypeSize("__LONG_LONG_MAX__", TargetInfo::SignedLongLong, TI, Builder);
985*12c85518Srobert DefineTypeSizeAndWidth("__WCHAR", TI.getWCharType(), TI, Builder);
986*12c85518Srobert DefineTypeSizeAndWidth("__WINT", TI.getWIntType(), TI, Builder);
987*12c85518Srobert DefineTypeSizeAndWidth("__INTMAX", TI.getIntMaxType(), TI, Builder);
988*12c85518Srobert DefineTypeSizeAndWidth("__SIZE", TI.getSizeType(), TI, Builder);
989e5dd7070Spatrick
990*12c85518Srobert DefineTypeSizeAndWidth("__UINTMAX", TI.getUIntMaxType(), TI, Builder);
991*12c85518Srobert DefineTypeSizeAndWidth("__PTRDIFF", TI.getPtrDiffType(LangAS::Default), TI,
992*12c85518Srobert Builder);
993*12c85518Srobert DefineTypeSizeAndWidth("__INTPTR", TI.getIntPtrType(), TI, Builder);
994*12c85518Srobert DefineTypeSizeAndWidth("__UINTPTR", TI.getUIntPtrType(), TI, Builder);
995e5dd7070Spatrick
996e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_DOUBLE__", TI.getDoubleWidth(), TI, Builder);
997e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_FLOAT__", TI.getFloatWidth(), TI, Builder);
998e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_INT__", TI.getIntWidth(), TI, Builder);
999e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_LONG__", TI.getLongWidth(), TI, Builder);
1000e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_LONG_DOUBLE__",TI.getLongDoubleWidth(),TI,Builder);
1001e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_LONG_LONG__", TI.getLongLongWidth(), TI, Builder);
1002*12c85518Srobert DefineTypeSizeof("__SIZEOF_POINTER__", TI.getPointerWidth(LangAS::Default),
1003*12c85518Srobert TI, Builder);
1004e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_SHORT__", TI.getShortWidth(), TI, Builder);
1005e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_PTRDIFF_T__",
1006*12c85518Srobert TI.getTypeWidth(TI.getPtrDiffType(LangAS::Default)), TI,
1007*12c85518Srobert Builder);
1008e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_SIZE_T__",
1009e5dd7070Spatrick TI.getTypeWidth(TI.getSizeType()), TI, Builder);
1010e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_WCHAR_T__",
1011e5dd7070Spatrick TI.getTypeWidth(TI.getWCharType()), TI, Builder);
1012e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_WINT_T__",
1013e5dd7070Spatrick TI.getTypeWidth(TI.getWIntType()), TI, Builder);
1014e5dd7070Spatrick if (TI.hasInt128Type())
1015e5dd7070Spatrick DefineTypeSizeof("__SIZEOF_INT128__", 128, TI, Builder);
1016e5dd7070Spatrick
1017e5dd7070Spatrick DefineType("__INTMAX_TYPE__", TI.getIntMaxType(), Builder);
1018e5dd7070Spatrick DefineFmt("__INTMAX", TI.getIntMaxType(), TI, Builder);
1019e5dd7070Spatrick Builder.defineMacro("__INTMAX_C_SUFFIX__",
1020e5dd7070Spatrick TI.getTypeConstantSuffix(TI.getIntMaxType()));
1021e5dd7070Spatrick DefineType("__UINTMAX_TYPE__", TI.getUIntMaxType(), Builder);
1022e5dd7070Spatrick DefineFmt("__UINTMAX", TI.getUIntMaxType(), TI, Builder);
1023e5dd7070Spatrick Builder.defineMacro("__UINTMAX_C_SUFFIX__",
1024e5dd7070Spatrick TI.getTypeConstantSuffix(TI.getUIntMaxType()));
1025*12c85518Srobert DefineType("__PTRDIFF_TYPE__", TI.getPtrDiffType(LangAS::Default), Builder);
1026*12c85518Srobert DefineFmt("__PTRDIFF", TI.getPtrDiffType(LangAS::Default), TI, Builder);
1027e5dd7070Spatrick DefineType("__INTPTR_TYPE__", TI.getIntPtrType(), Builder);
1028e5dd7070Spatrick DefineFmt("__INTPTR", TI.getIntPtrType(), TI, Builder);
1029e5dd7070Spatrick DefineType("__SIZE_TYPE__", TI.getSizeType(), Builder);
1030e5dd7070Spatrick DefineFmt("__SIZE", TI.getSizeType(), TI, Builder);
1031e5dd7070Spatrick DefineType("__WCHAR_TYPE__", TI.getWCharType(), Builder);
1032e5dd7070Spatrick DefineType("__WINT_TYPE__", TI.getWIntType(), Builder);
1033*12c85518Srobert DefineTypeSizeAndWidth("__SIG_ATOMIC", TI.getSigAtomicType(), TI, Builder);
1034e5dd7070Spatrick DefineType("__CHAR16_TYPE__", TI.getChar16Type(), Builder);
1035e5dd7070Spatrick DefineType("__CHAR32_TYPE__", TI.getChar32Type(), Builder);
1036e5dd7070Spatrick
1037e5dd7070Spatrick DefineType("__UINTPTR_TYPE__", TI.getUIntPtrType(), Builder);
1038e5dd7070Spatrick DefineFmt("__UINTPTR", TI.getUIntPtrType(), TI, Builder);
1039*12c85518Srobert
1040*12c85518Srobert // The C standard requires the width of uintptr_t and intptr_t to be the same,
1041*12c85518Srobert // per 7.20.2.4p1. Same for intmax_t and uintmax_t, per 7.20.2.5p1.
1042*12c85518Srobert assert(TI.getTypeWidth(TI.getUIntPtrType()) ==
1043*12c85518Srobert TI.getTypeWidth(TI.getIntPtrType()) &&
1044*12c85518Srobert "uintptr_t and intptr_t have different widths?");
1045*12c85518Srobert assert(TI.getTypeWidth(TI.getUIntMaxType()) ==
1046*12c85518Srobert TI.getTypeWidth(TI.getIntMaxType()) &&
1047*12c85518Srobert "uintmax_t and intmax_t have different widths?");
1048e5dd7070Spatrick
1049e5dd7070Spatrick if (TI.hasFloat16Type())
1050e5dd7070Spatrick DefineFloatMacros(Builder, "FLT16", &TI.getHalfFormat(), "F16");
1051e5dd7070Spatrick DefineFloatMacros(Builder, "FLT", &TI.getFloatFormat(), "F");
1052e5dd7070Spatrick DefineFloatMacros(Builder, "DBL", &TI.getDoubleFormat(), "");
1053e5dd7070Spatrick DefineFloatMacros(Builder, "LDBL", &TI.getLongDoubleFormat(), "L");
1054e5dd7070Spatrick
1055e5dd7070Spatrick // Define a __POINTER_WIDTH__ macro for stdint.h.
1056e5dd7070Spatrick Builder.defineMacro("__POINTER_WIDTH__",
1057*12c85518Srobert Twine((int)TI.getPointerWidth(LangAS::Default)));
1058e5dd7070Spatrick
1059e5dd7070Spatrick // Define __BIGGEST_ALIGNMENT__ to be compatible with gcc.
1060e5dd7070Spatrick Builder.defineMacro("__BIGGEST_ALIGNMENT__",
1061e5dd7070Spatrick Twine(TI.getSuitableAlign() / TI.getCharWidth()) );
1062e5dd7070Spatrick
1063e5dd7070Spatrick if (!LangOpts.CharIsSigned)
1064e5dd7070Spatrick Builder.defineMacro("__CHAR_UNSIGNED__");
1065e5dd7070Spatrick
1066e5dd7070Spatrick if (!TargetInfo::isTypeSigned(TI.getWCharType()))
1067e5dd7070Spatrick Builder.defineMacro("__WCHAR_UNSIGNED__");
1068e5dd7070Spatrick
1069e5dd7070Spatrick if (!TargetInfo::isTypeSigned(TI.getWIntType()))
1070e5dd7070Spatrick Builder.defineMacro("__WINT_UNSIGNED__");
1071e5dd7070Spatrick
1072e5dd7070Spatrick // Define exact-width integer types for stdint.h
1073e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::SignedChar, TI, Builder);
1074e5dd7070Spatrick
1075e5dd7070Spatrick if (TI.getShortWidth() > TI.getCharWidth())
1076e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::SignedShort, TI, Builder);
1077e5dd7070Spatrick
1078e5dd7070Spatrick if (TI.getIntWidth() > TI.getShortWidth())
1079e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::SignedInt, TI, Builder);
1080e5dd7070Spatrick
1081e5dd7070Spatrick if (TI.getLongWidth() > TI.getIntWidth())
1082e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::SignedLong, TI, Builder);
1083e5dd7070Spatrick
1084e5dd7070Spatrick if (TI.getLongLongWidth() > TI.getLongWidth())
1085e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::SignedLongLong, TI, Builder);
1086e5dd7070Spatrick
1087e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::UnsignedChar, TI, Builder);
1088e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::UnsignedChar, TI, Builder);
1089e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::SignedChar, TI, Builder);
1090e5dd7070Spatrick
1091e5dd7070Spatrick if (TI.getShortWidth() > TI.getCharWidth()) {
1092e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::UnsignedShort, TI, Builder);
1093e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::UnsignedShort, TI, Builder);
1094e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::SignedShort, TI, Builder);
1095e5dd7070Spatrick }
1096e5dd7070Spatrick
1097e5dd7070Spatrick if (TI.getIntWidth() > TI.getShortWidth()) {
1098e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::UnsignedInt, TI, Builder);
1099e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::UnsignedInt, TI, Builder);
1100e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::SignedInt, TI, Builder);
1101e5dd7070Spatrick }
1102e5dd7070Spatrick
1103e5dd7070Spatrick if (TI.getLongWidth() > TI.getIntWidth()) {
1104e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::UnsignedLong, TI, Builder);
1105e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::UnsignedLong, TI, Builder);
1106e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::SignedLong, TI, Builder);
1107e5dd7070Spatrick }
1108e5dd7070Spatrick
1109e5dd7070Spatrick if (TI.getLongLongWidth() > TI.getLongWidth()) {
1110e5dd7070Spatrick DefineExactWidthIntType(TargetInfo::UnsignedLongLong, TI, Builder);
1111e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::UnsignedLongLong, TI, Builder);
1112e5dd7070Spatrick DefineExactWidthIntTypeSize(TargetInfo::SignedLongLong, TI, Builder);
1113e5dd7070Spatrick }
1114e5dd7070Spatrick
1115e5dd7070Spatrick DefineLeastWidthIntType(8, true, TI, Builder);
1116e5dd7070Spatrick DefineLeastWidthIntType(8, false, TI, Builder);
1117e5dd7070Spatrick DefineLeastWidthIntType(16, true, TI, Builder);
1118e5dd7070Spatrick DefineLeastWidthIntType(16, false, TI, Builder);
1119e5dd7070Spatrick DefineLeastWidthIntType(32, true, TI, Builder);
1120e5dd7070Spatrick DefineLeastWidthIntType(32, false, TI, Builder);
1121e5dd7070Spatrick DefineLeastWidthIntType(64, true, TI, Builder);
1122e5dd7070Spatrick DefineLeastWidthIntType(64, false, TI, Builder);
1123e5dd7070Spatrick
1124e5dd7070Spatrick DefineFastIntType(8, true, TI, Builder);
1125e5dd7070Spatrick DefineFastIntType(8, false, TI, Builder);
1126e5dd7070Spatrick DefineFastIntType(16, true, TI, Builder);
1127e5dd7070Spatrick DefineFastIntType(16, false, TI, Builder);
1128e5dd7070Spatrick DefineFastIntType(32, true, TI, Builder);
1129e5dd7070Spatrick DefineFastIntType(32, false, TI, Builder);
1130e5dd7070Spatrick DefineFastIntType(64, true, TI, Builder);
1131e5dd7070Spatrick DefineFastIntType(64, false, TI, Builder);
1132e5dd7070Spatrick
1133a9ac8606Spatrick Builder.defineMacro("__USER_LABEL_PREFIX__", TI.getUserLabelPrefix());
1134e5dd7070Spatrick
1135*12c85518Srobert if (!LangOpts.MathErrno)
1136*12c85518Srobert Builder.defineMacro("__NO_MATH_ERRNO__");
1137*12c85518Srobert
1138e5dd7070Spatrick if (LangOpts.FastMath || LangOpts.FiniteMathOnly)
1139e5dd7070Spatrick Builder.defineMacro("__FINITE_MATH_ONLY__", "1");
1140e5dd7070Spatrick else
1141e5dd7070Spatrick Builder.defineMacro("__FINITE_MATH_ONLY__", "0");
1142e5dd7070Spatrick
1143e5dd7070Spatrick if (LangOpts.GNUCVersion) {
1144e5dd7070Spatrick if (LangOpts.GNUInline || LangOpts.CPlusPlus)
1145e5dd7070Spatrick Builder.defineMacro("__GNUC_GNU_INLINE__");
1146e5dd7070Spatrick else
1147e5dd7070Spatrick Builder.defineMacro("__GNUC_STDC_INLINE__");
1148e5dd7070Spatrick
1149e5dd7070Spatrick // The value written by __atomic_test_and_set.
1150e5dd7070Spatrick // FIXME: This is target-dependent.
1151e5dd7070Spatrick Builder.defineMacro("__GCC_ATOMIC_TEST_AND_SET_TRUEVAL", "1");
1152e5dd7070Spatrick }
1153e5dd7070Spatrick
1154e5dd7070Spatrick auto addLockFreeMacros = [&](const llvm::Twine &Prefix) {
1155e5dd7070Spatrick // Used by libc++ and libstdc++ to implement ATOMIC_<foo>_LOCK_FREE.
1156e5dd7070Spatrick #define DEFINE_LOCK_FREE_MACRO(TYPE, Type) \
1157e5dd7070Spatrick Builder.defineMacro(Prefix + #TYPE "_LOCK_FREE", \
1158*12c85518Srobert getLockFreeValue(TI.get##Type##Width(), TI));
1159e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(BOOL, Bool);
1160e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(CHAR, Char);
1161e5dd7070Spatrick if (LangOpts.Char8)
1162e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(CHAR8_T, Char); // Treat char8_t like char.
1163e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(CHAR16_T, Char16);
1164e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(CHAR32_T, Char32);
1165e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(WCHAR_T, WChar);
1166e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(SHORT, Short);
1167e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(INT, Int);
1168e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(LONG, Long);
1169e5dd7070Spatrick DEFINE_LOCK_FREE_MACRO(LLONG, LongLong);
1170*12c85518Srobert Builder.defineMacro(
1171*12c85518Srobert Prefix + "POINTER_LOCK_FREE",
1172*12c85518Srobert getLockFreeValue(TI.getPointerWidth(LangAS::Default), TI));
1173e5dd7070Spatrick #undef DEFINE_LOCK_FREE_MACRO
1174e5dd7070Spatrick };
1175e5dd7070Spatrick addLockFreeMacros("__CLANG_ATOMIC_");
1176e5dd7070Spatrick if (LangOpts.GNUCVersion)
1177e5dd7070Spatrick addLockFreeMacros("__GCC_ATOMIC_");
1178e5dd7070Spatrick
1179e5dd7070Spatrick if (LangOpts.NoInlineDefine)
1180e5dd7070Spatrick Builder.defineMacro("__NO_INLINE__");
1181e5dd7070Spatrick
1182e5dd7070Spatrick if (unsigned PICLevel = LangOpts.PICLevel) {
1183e5dd7070Spatrick Builder.defineMacro("__PIC__", Twine(PICLevel));
1184e5dd7070Spatrick Builder.defineMacro("__pic__", Twine(PICLevel));
1185e5dd7070Spatrick if (LangOpts.PIE) {
1186e5dd7070Spatrick Builder.defineMacro("__PIE__", Twine(PICLevel));
1187e5dd7070Spatrick Builder.defineMacro("__pie__", Twine(PICLevel));
1188e5dd7070Spatrick }
1189e5dd7070Spatrick }
1190e5dd7070Spatrick
1191e5dd7070Spatrick // Macros to control C99 numerics and <float.h>
1192e5dd7070Spatrick Builder.defineMacro("__FLT_RADIX__", "2");
1193e5dd7070Spatrick Builder.defineMacro("__DECIMAL_DIG__", "__LDBL_DECIMAL_DIG__");
1194e5dd7070Spatrick
1195e5dd7070Spatrick if (LangOpts.getStackProtector() == LangOptions::SSPOn)
1196e5dd7070Spatrick Builder.defineMacro("__SSP__");
1197e5dd7070Spatrick else if (LangOpts.getStackProtector() == LangOptions::SSPStrong)
1198e5dd7070Spatrick Builder.defineMacro("__SSP_STRONG__", "2");
1199e5dd7070Spatrick else if (LangOpts.getStackProtector() == LangOptions::SSPReq)
1200e5dd7070Spatrick Builder.defineMacro("__SSP_ALL__", "3");
1201e5dd7070Spatrick
1202e5dd7070Spatrick if (PPOpts.SetUpStaticAnalyzer)
1203e5dd7070Spatrick Builder.defineMacro("__clang_analyzer__");
1204e5dd7070Spatrick
1205e5dd7070Spatrick if (LangOpts.FastRelaxedMath)
1206e5dd7070Spatrick Builder.defineMacro("__FAST_RELAXED_MATH__");
1207e5dd7070Spatrick
1208e5dd7070Spatrick if (FEOpts.ProgramAction == frontend::RewriteObjC ||
1209e5dd7070Spatrick LangOpts.getGC() != LangOptions::NonGC) {
1210e5dd7070Spatrick Builder.defineMacro("__weak", "__attribute__((objc_gc(weak)))");
1211e5dd7070Spatrick Builder.defineMacro("__strong", "__attribute__((objc_gc(strong)))");
1212e5dd7070Spatrick Builder.defineMacro("__autoreleasing", "");
1213e5dd7070Spatrick Builder.defineMacro("__unsafe_unretained", "");
1214e5dd7070Spatrick } else if (LangOpts.ObjC) {
1215e5dd7070Spatrick Builder.defineMacro("__weak", "__attribute__((objc_ownership(weak)))");
1216e5dd7070Spatrick Builder.defineMacro("__strong", "__attribute__((objc_ownership(strong)))");
1217e5dd7070Spatrick Builder.defineMacro("__autoreleasing",
1218e5dd7070Spatrick "__attribute__((objc_ownership(autoreleasing)))");
1219e5dd7070Spatrick Builder.defineMacro("__unsafe_unretained",
1220e5dd7070Spatrick "__attribute__((objc_ownership(none)))");
1221e5dd7070Spatrick }
1222e5dd7070Spatrick
1223e5dd7070Spatrick // On Darwin, there are __double_underscored variants of the type
1224e5dd7070Spatrick // nullability qualifiers.
1225e5dd7070Spatrick if (TI.getTriple().isOSDarwin()) {
1226e5dd7070Spatrick Builder.defineMacro("__nonnull", "_Nonnull");
1227e5dd7070Spatrick Builder.defineMacro("__null_unspecified", "_Null_unspecified");
1228e5dd7070Spatrick Builder.defineMacro("__nullable", "_Nullable");
1229e5dd7070Spatrick }
1230e5dd7070Spatrick
1231e5dd7070Spatrick // Add a macro to differentiate between regular iOS/tvOS/watchOS targets and
1232e5dd7070Spatrick // the corresponding simulator targets.
1233e5dd7070Spatrick if (TI.getTriple().isOSDarwin() && TI.getTriple().isSimulatorEnvironment())
1234e5dd7070Spatrick Builder.defineMacro("__APPLE_EMBEDDED_SIMULATOR__", "1");
1235e5dd7070Spatrick
1236e5dd7070Spatrick // OpenMP definition
1237e5dd7070Spatrick // OpenMP 2.2:
1238e5dd7070Spatrick // In implementations that support a preprocessor, the _OPENMP
1239e5dd7070Spatrick // macro name is defined to have the decimal value yyyymm where
1240e5dd7070Spatrick // yyyy and mm are the year and the month designations of the
1241e5dd7070Spatrick // version of the OpenMP API that the implementation support.
1242e5dd7070Spatrick if (!LangOpts.OpenMPSimd) {
1243e5dd7070Spatrick switch (LangOpts.OpenMP) {
1244e5dd7070Spatrick case 0:
1245e5dd7070Spatrick break;
1246e5dd7070Spatrick case 31:
1247e5dd7070Spatrick Builder.defineMacro("_OPENMP", "201107");
1248e5dd7070Spatrick break;
1249e5dd7070Spatrick case 40:
1250e5dd7070Spatrick Builder.defineMacro("_OPENMP", "201307");
1251e5dd7070Spatrick break;
1252ec727ea7Spatrick case 45:
1253ec727ea7Spatrick Builder.defineMacro("_OPENMP", "201511");
1254e5dd7070Spatrick break;
1255*12c85518Srobert case 51:
1256*12c85518Srobert Builder.defineMacro("_OPENMP", "202011");
1257*12c85518Srobert break;
1258*12c85518Srobert case 52:
1259*12c85518Srobert Builder.defineMacro("_OPENMP", "202111");
1260*12c85518Srobert break;
1261*12c85518Srobert case 50:
1262e5dd7070Spatrick default:
1263ec727ea7Spatrick // Default version is OpenMP 5.0
1264ec727ea7Spatrick Builder.defineMacro("_OPENMP", "201811");
1265e5dd7070Spatrick break;
1266e5dd7070Spatrick }
1267e5dd7070Spatrick }
1268e5dd7070Spatrick
1269e5dd7070Spatrick // CUDA device path compilaton
1270e5dd7070Spatrick if (LangOpts.CUDAIsDevice && !LangOpts.HIP) {
1271e5dd7070Spatrick // The CUDA_ARCH value is set for the GPU target specified in the NVPTX
1272e5dd7070Spatrick // backend's target defines.
1273e5dd7070Spatrick Builder.defineMacro("__CUDA_ARCH__");
1274e5dd7070Spatrick }
1275e5dd7070Spatrick
1276e5dd7070Spatrick // We need to communicate this to our CUDA header wrapper, which in turn
1277e5dd7070Spatrick // informs the proper CUDA headers of this choice.
1278e5dd7070Spatrick if (LangOpts.CUDADeviceApproxTranscendentals || LangOpts.FastMath) {
1279e5dd7070Spatrick Builder.defineMacro("__CLANG_CUDA_APPROX_TRANSCENDENTALS__");
1280e5dd7070Spatrick }
1281e5dd7070Spatrick
1282e5dd7070Spatrick // Define a macro indicating that the source file is being compiled with a
1283e5dd7070Spatrick // SYCL device compiler which doesn't produce host binary.
1284e5dd7070Spatrick if (LangOpts.SYCLIsDevice) {
1285e5dd7070Spatrick Builder.defineMacro("__SYCL_DEVICE_ONLY__", "1");
1286e5dd7070Spatrick }
1287e5dd7070Spatrick
1288e5dd7070Spatrick // OpenCL definitions.
1289e5dd7070Spatrick if (LangOpts.OpenCL) {
1290a9ac8606Spatrick InitializeOpenCLFeatureTestMacros(TI, LangOpts, Builder);
1291e5dd7070Spatrick
1292*12c85518Srobert if (TI.getTriple().isSPIR() || TI.getTriple().isSPIRV())
1293e5dd7070Spatrick Builder.defineMacro("__IMAGE_SUPPORT__");
1294e5dd7070Spatrick }
1295e5dd7070Spatrick
1296e5dd7070Spatrick if (TI.hasInt128Type() && LangOpts.CPlusPlus && LangOpts.GNUMode) {
1297e5dd7070Spatrick // For each extended integer type, g++ defines a macro mapping the
1298e5dd7070Spatrick // index of the type (0 in this case) in some list of extended types
1299e5dd7070Spatrick // to the type.
1300e5dd7070Spatrick Builder.defineMacro("__GLIBCXX_TYPE_INT_N_0", "__int128");
1301e5dd7070Spatrick Builder.defineMacro("__GLIBCXX_BITSIZE_INT_N_0", "128");
1302e5dd7070Spatrick }
1303e5dd7070Spatrick
1304e5dd7070Spatrick // Get other target #defines.
1305e5dd7070Spatrick TI.getTargetDefines(LangOpts, Builder);
1306e5dd7070Spatrick }
1307e5dd7070Spatrick
1308e5dd7070Spatrick /// InitializePreprocessor - Initialize the preprocessor getting it and the
1309*12c85518Srobert /// environment ready to process a single file.
InitializePreprocessor(Preprocessor & PP,const PreprocessorOptions & InitOpts,const PCHContainerReader & PCHContainerRdr,const FrontendOptions & FEOpts)1310e5dd7070Spatrick void clang::InitializePreprocessor(
1311e5dd7070Spatrick Preprocessor &PP, const PreprocessorOptions &InitOpts,
1312e5dd7070Spatrick const PCHContainerReader &PCHContainerRdr,
1313e5dd7070Spatrick const FrontendOptions &FEOpts) {
1314e5dd7070Spatrick const LangOptions &LangOpts = PP.getLangOpts();
1315e5dd7070Spatrick std::string PredefineBuffer;
1316e5dd7070Spatrick PredefineBuffer.reserve(4080);
1317e5dd7070Spatrick llvm::raw_string_ostream Predefines(PredefineBuffer);
1318e5dd7070Spatrick MacroBuilder Builder(Predefines);
1319e5dd7070Spatrick
1320e5dd7070Spatrick // Emit line markers for various builtin sections of the file. We don't do
1321e5dd7070Spatrick // this in asm preprocessor mode, because "# 4" is not a line marker directive
1322e5dd7070Spatrick // in this mode.
1323e5dd7070Spatrick if (!PP.getLangOpts().AsmPreprocessor)
1324e5dd7070Spatrick Builder.append("# 1 \"<built-in>\" 3");
1325e5dd7070Spatrick
1326e5dd7070Spatrick // Install things like __POWERPC__, __GNUC__, etc into the macro table.
1327e5dd7070Spatrick if (InitOpts.UsePredefines) {
1328e5dd7070Spatrick // FIXME: This will create multiple definitions for most of the predefined
1329e5dd7070Spatrick // macros. This is not the right way to handle this.
1330e5dd7070Spatrick if ((LangOpts.CUDA || LangOpts.OpenMPIsDevice || LangOpts.SYCLIsDevice) &&
1331e5dd7070Spatrick PP.getAuxTargetInfo())
1332e5dd7070Spatrick InitializePredefinedMacros(*PP.getAuxTargetInfo(), LangOpts, FEOpts,
1333e5dd7070Spatrick PP.getPreprocessorOpts(), Builder);
1334e5dd7070Spatrick
1335e5dd7070Spatrick InitializePredefinedMacros(PP.getTargetInfo(), LangOpts, FEOpts,
1336e5dd7070Spatrick PP.getPreprocessorOpts(), Builder);
1337e5dd7070Spatrick
1338e5dd7070Spatrick // Install definitions to make Objective-C++ ARC work well with various
1339e5dd7070Spatrick // C++ Standard Library implementations.
1340e5dd7070Spatrick if (LangOpts.ObjC && LangOpts.CPlusPlus &&
1341e5dd7070Spatrick (LangOpts.ObjCAutoRefCount || LangOpts.ObjCWeak)) {
1342e5dd7070Spatrick switch (InitOpts.ObjCXXARCStandardLibrary) {
1343e5dd7070Spatrick case ARCXX_nolib:
1344e5dd7070Spatrick case ARCXX_libcxx:
1345e5dd7070Spatrick break;
1346e5dd7070Spatrick
1347e5dd7070Spatrick case ARCXX_libstdcxx:
1348e5dd7070Spatrick AddObjCXXARCLibstdcxxDefines(LangOpts, Builder);
1349e5dd7070Spatrick break;
1350e5dd7070Spatrick }
1351e5dd7070Spatrick }
1352e5dd7070Spatrick }
1353e5dd7070Spatrick
1354e5dd7070Spatrick // Even with predefines off, some macros are still predefined.
1355e5dd7070Spatrick // These should all be defined in the preprocessor according to the
1356e5dd7070Spatrick // current language configuration.
1357e5dd7070Spatrick InitializeStandardPredefinedMacros(PP.getTargetInfo(), PP.getLangOpts(),
1358e5dd7070Spatrick FEOpts, Builder);
1359e5dd7070Spatrick
1360e5dd7070Spatrick // Add on the predefines from the driver. Wrap in a #line directive to report
1361e5dd7070Spatrick // that they come from the command line.
1362e5dd7070Spatrick if (!PP.getLangOpts().AsmPreprocessor)
1363e5dd7070Spatrick Builder.append("# 1 \"<command line>\" 1");
1364e5dd7070Spatrick
1365e5dd7070Spatrick // Process #define's and #undef's in the order they are given.
1366e5dd7070Spatrick for (unsigned i = 0, e = InitOpts.Macros.size(); i != e; ++i) {
1367e5dd7070Spatrick if (InitOpts.Macros[i].second) // isUndef
1368e5dd7070Spatrick Builder.undefineMacro(InitOpts.Macros[i].first);
1369e5dd7070Spatrick else
1370e5dd7070Spatrick DefineBuiltinMacro(Builder, InitOpts.Macros[i].first,
1371e5dd7070Spatrick PP.getDiagnostics());
1372e5dd7070Spatrick }
1373e5dd7070Spatrick
1374e5dd7070Spatrick // Exit the command line and go back to <built-in> (2 is LC_LEAVE).
1375e5dd7070Spatrick if (!PP.getLangOpts().AsmPreprocessor)
1376e5dd7070Spatrick Builder.append("# 1 \"<built-in>\" 2");
1377e5dd7070Spatrick
1378e5dd7070Spatrick // If -imacros are specified, include them now. These are processed before
1379e5dd7070Spatrick // any -include directives.
1380e5dd7070Spatrick for (unsigned i = 0, e = InitOpts.MacroIncludes.size(); i != e; ++i)
1381e5dd7070Spatrick AddImplicitIncludeMacros(Builder, InitOpts.MacroIncludes[i]);
1382e5dd7070Spatrick
1383e5dd7070Spatrick // Process -include-pch/-include-pth directives.
1384e5dd7070Spatrick if (!InitOpts.ImplicitPCHInclude.empty())
1385e5dd7070Spatrick AddImplicitIncludePCH(Builder, PP, PCHContainerRdr,
1386e5dd7070Spatrick InitOpts.ImplicitPCHInclude);
1387e5dd7070Spatrick
1388e5dd7070Spatrick // Process -include directives.
1389e5dd7070Spatrick for (unsigned i = 0, e = InitOpts.Includes.size(); i != e; ++i) {
1390e5dd7070Spatrick const std::string &Path = InitOpts.Includes[i];
1391e5dd7070Spatrick AddImplicitInclude(Builder, Path);
1392e5dd7070Spatrick }
1393e5dd7070Spatrick
1394e5dd7070Spatrick // Instruct the preprocessor to skip the preamble.
1395e5dd7070Spatrick PP.setSkipMainFilePreamble(InitOpts.PrecompiledPreambleBytes.first,
1396e5dd7070Spatrick InitOpts.PrecompiledPreambleBytes.second);
1397e5dd7070Spatrick
1398e5dd7070Spatrick // Copy PredefinedBuffer into the Preprocessor.
1399*12c85518Srobert PP.setPredefines(std::move(PredefineBuffer));
1400e5dd7070Spatrick }
1401