[clang] [clang] Merge some delarations which currently have different attributes (PR #79349)
Nikolas Klauser via cfe-commits
cfe-commits at lists.llvm.org
Wed Jan 24 11:13:38 PST 2024
https://github.com/philnik777 created https://github.com/llvm/llvm-project/pull/79349
None
>From f65bd5f45cf24369a56a4cf4c556c57791d0bf3b Mon Sep 17 00:00:00 2001
From: Nikolas Klauser <nikolasklauser at berlin.de>
Date: Wed, 11 Oct 2023 13:02:30 +0200
Subject: [PATCH] [clang] Merge some delarations which currently have different
attributes
---
clang/include/clang/Basic/Builtins.td | 76 ++++++---------------------
1 file changed, 17 insertions(+), 59 deletions(-)
diff --git a/clang/include/clang/Basic/Builtins.td b/clang/include/clang/Basic/Builtins.td
index 22e616e6cde599..127236bb0d57da 100644
--- a/clang/include/clang/Basic/Builtins.td
+++ b/clang/include/clang/Basic/Builtins.td
@@ -727,12 +727,6 @@ def RotateRight : BitInt8_16_32_64BuiltinsTemplate, Builtin {
// FIXME: The builtins marked FunctionWithBuiltinPrefix below should be
// merged with the library definitions. They are currently not because
// the attributes are different.
-def BuiltinCalloc : Builtin {
- let Spellings = ["__builtin_calloc"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow];
- let Prototype = "void*(size_t, size_t)";
-}
-
def BuiltinConstantP : Builtin {
let Spellings = ["__builtin_constant_p"];
let Attributes = [NoThrow, Const, CustomTypeChecking, UnevaluatedArguments, Constexpr];
@@ -775,48 +769,18 @@ def BuiltinAssumeAligned : Builtin {
let Prototype = "void*(void const*, size_t, ...)";
}
-def BuiltinFree : Builtin {
- let Spellings = ["__builtin_free"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow];
- let Prototype = "void(void*)";
-}
-
-def BuiltinMalloc : Builtin {
- let Spellings = ["__builtin_malloc"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow];
- let Prototype = "void*(size_t)";
-}
-
def BuiltinMemcpyInline : Builtin {
let Spellings = ["__builtin_memcpy_inline"];
let Attributes = [NoThrow];
let Prototype = "void(void*, void const*, _Constant size_t)";
}
-def BuiltinMempcpy : Builtin {
- let Spellings = ["__builtin_mempcpy"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow];
- let Prototype = "void*(void*, void const*, size_t)";
-}
-
def BuiltinMemsetInline : Builtin {
let Spellings = ["__builtin_memset_inline"];
let Attributes = [NoThrow];
let Prototype = "void(void*, int, _Constant size_t)";
}
-def BuiltinStrcspn : Builtin {
- let Spellings = ["__builtin_strcspn"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow];
- let Prototype = "size_t(char const*, char const*)";
-}
-
-def BuiltinRealloc : Builtin {
- let Spellings = ["__builtin_realloc"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow];
- let Prototype = "void*(void*, size_t)";
-}
-
def BuiltinReturnAddress : Builtin {
let Spellings = ["__builtin_return_address"];
let Attributes = [NoThrow];
@@ -2539,7 +2503,9 @@ def Abort : LibBuiltin<"stdlib.h"> {
def Calloc : LibBuiltin<"stdlib.h"> {
let Spellings = ["calloc"];
+ let Attributes = [NoThrow];
let Prototype = "void*(size_t, size_t)";
+ let AddBuiltinPrefixedAlias = 1;
}
def Exit : LibBuiltin<"stdlib.h"> {
@@ -2550,17 +2516,23 @@ def Exit : LibBuiltin<"stdlib.h"> {
def Malloc : LibBuiltin<"stdlib.h"> {
let Spellings = ["malloc"];
+ let Attributes = [NoThrow];
let Prototype = "void*(size_t)";
+ let AddBuiltinPrefixedAlias = 1;
}
def Realloc : LibBuiltin<"stdlib.h"> {
let Spellings = ["realloc"];
+ let Attributes = [NoThrow];
let Prototype = "void*(void*, size_t)";
+ let AddBuiltinPrefixedAlias = 1;
}
def Free : LibBuiltin<"stdlib.h"> {
let Spellings = ["free"];
+ let Attributes = [NoThrow];
let Prototype = "void(void*)";
+ let AddBuiltinPrefixedAlias = 1;
}
def StrToD : LibBuiltin<"stdlib.h"> {
@@ -2612,16 +2584,11 @@ def MemCpy : LibBuiltin<"string.h"> {
let AddBuiltinPrefixedAlias = 1;
}
-def BuiltinMemCmp : Builtin {
- let Spellings = ["__builtin_memcmp"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow, Constexpr];
- let Prototype = "int(void const*, void const*, size_t)";
-}
-
def MemCmp : LibBuiltin<"string.h"> {
let Spellings = ["memcmp"];
- let Attributes = [Constexpr];
+ let Attributes = [NoThrow, Constexpr];
let Prototype = "int(void const*, void const*, size_t)";
+ let AddBuiltinPrefixedAlias = 1;
}
def MemMove : LibBuiltin<"string.h"> {
@@ -2694,7 +2661,9 @@ def StrChr : LibBuiltin<"string.h"> {
def StrcSpn : LibBuiltin<"string.h"> {
let Spellings = ["strcspn"];
+ let Attributes = [NoThrow];
let Prototype = "size_t(char const*, char const*)";
+ let AddBuiltinPrefixedAlias = 1;
}
def StrpBrk : LibBuiltin<"string.h"> {
@@ -2753,14 +2722,7 @@ def StrLen : LibBuiltin<"string.h"> {
// FIXME: This list is incomplete.
def Printf : LibBuiltin<"stdio.h"> {
let Spellings = ["printf"];
- let Attributes = [PrintfFormat<0>];
- let Prototype = "int(char const*, ...)";
-}
-
-// FIXME: The builtin and library function should have the same signature.
-def BuiltinPrintf : Builtin {
- let Spellings = ["__builtin_printf"];
- let Attributes = [NoThrow, PrintfFormat<0>, FunctionWithBuiltinPrefix];
+ let Attributes = [NoThrow, PrintfFormat<0>];
let Prototype = "int(char const* restrict, ...)";
}
@@ -3060,7 +3022,9 @@ def MemcCpy : GNULibBuiltin<"stdlib.h"> {
def MempCpy : GNULibBuiltin<"stdlib.h"> {
let Spellings = ["mempcpy"];
+ let Attributes = [NoThrow]
let Prototype = "void*(void*, void const*, size_t)";
+ let AddBuiltinPrefixedAlias = 1;
}
def StpCpy : GNULibBuiltin<"stdlib.h"> {
@@ -3121,17 +3085,11 @@ def Bcopy : GNULibBuiltin<"strings.h"> {
let AddBuiltinPrefixedAlias = 1;
}
-// FIXME: This should be part of BCmp.
-def BuiltinBCmp : Builtin {
- let Spellings = ["__builtin_bcmp"];
- let Attributes = [FunctionWithBuiltinPrefix, NoThrow, Constexpr];
- let Prototype = "int(void const*, void const*, size_t)";
-}
-
def BCmp : GNULibBuiltin<"strings.h"> {
let Spellings = ["bcmp"];
- let Attributes = [Constexpr];
+ let Attributes = [NoThrow, Constexpr];
let Prototype = "int(void const*, void const*, size_t)";
+ let AddBuiltinPrefixedAlias = 1;
}
def StrCaseCmp : GNULibBuiltin<"strings.h"> {
More information about the cfe-commits
mailing list