зеркало из https://github.com/microsoft/clang.git
Add support for attribute((naked)), patch by Zoxc on cfe-commits!
- Minor style tweaks by me. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@115056 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
1b39820526
Коммит
dd0cb22bd6
|
@ -245,6 +245,10 @@ def MSP430Interrupt : Attr {
|
|||
let Args = [UnsignedArgument<"Number">];
|
||||
}
|
||||
|
||||
def Naked : Attr {
|
||||
let Spellings = ["naked"];
|
||||
}
|
||||
|
||||
def NoDebug : Attr {
|
||||
let Spellings = ["nodebug"];
|
||||
}
|
||||
|
|
|
@ -83,6 +83,7 @@ public:
|
|||
AT_hiding,
|
||||
AT_malloc,
|
||||
AT_mode,
|
||||
AT_naked,
|
||||
AT_nodebug,
|
||||
AT_noinline,
|
||||
AT_no_instrument_function,
|
||||
|
|
|
@ -457,6 +457,9 @@ void CodeGenModule::SetLLVMFunctionAttributesForDefinition(const Decl *D,
|
|||
if (D->hasAttr<AlwaysInlineAttr>())
|
||||
F->addFnAttr(llvm::Attribute::AlwaysInline);
|
||||
|
||||
if (D->hasAttr<NakedAttr>())
|
||||
F->addFnAttr(llvm::Attribute::Naked);
|
||||
|
||||
if (D->hasAttr<NoInlineAttr>())
|
||||
F->addFnAttr(llvm::Attribute::NoInline);
|
||||
|
||||
|
|
|
@ -73,6 +73,7 @@ AttributeList::Kind AttributeList::getKind(const IdentifierInfo *Name) {
|
|||
.Case("unused", AT_unused)
|
||||
.Case("aligned", AT_aligned)
|
||||
.Case("cleanup", AT_cleanup)
|
||||
.Case("naked", AT_naked)
|
||||
.Case("nodebug", AT_nodebug)
|
||||
.Case("nonnull", AT_nonnull)
|
||||
.Case("nothrow", AT_nothrow)
|
||||
|
|
|
@ -650,9 +650,9 @@ static void HandleAliasAttr(Decl *d, const AttributeList &Attr, Sema &S) {
|
|||
d->addAttr(::new (S.Context) AliasAttr(Attr.getLoc(), S.Context, Str->getString()));
|
||||
}
|
||||
|
||||
static void HandleAlwaysInlineAttr(Decl *d, const AttributeList &Attr,
|
||||
static void HandleNakedAttr(Decl *d, const AttributeList &Attr,
|
||||
Sema &S) {
|
||||
// check the attribute arguments.
|
||||
// Check the attribute arguments.
|
||||
if (Attr.getNumArgs() != 0) {
|
||||
S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0;
|
||||
return;
|
||||
|
@ -660,7 +660,24 @@ static void HandleAlwaysInlineAttr(Decl *d, const AttributeList &Attr,
|
|||
|
||||
if (!isa<FunctionDecl>(d)) {
|
||||
S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
|
||||
<< Attr.getName() << 0 /*function*/;
|
||||
<< Attr.getName() << 0 /*function*/;
|
||||
return;
|
||||
}
|
||||
|
||||
d->addAttr(::new (S.Context) NakedAttr(Attr.getLoc(), S.Context));
|
||||
}
|
||||
|
||||
static void HandleAlwaysInlineAttr(Decl *d, const AttributeList &Attr,
|
||||
Sema &S) {
|
||||
// Check the attribute arguments.
|
||||
if (Attr.getNumArgs() != 0) {
|
||||
S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0;
|
||||
return;
|
||||
}
|
||||
|
||||
if (!isa<FunctionDecl>(d)) {
|
||||
S.Diag(Attr.getLoc(), diag::warn_attribute_wrong_decl_type)
|
||||
<< Attr.getName() << 0 /*function*/;
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -668,7 +685,7 @@ static void HandleAlwaysInlineAttr(Decl *d, const AttributeList &Attr,
|
|||
}
|
||||
|
||||
static void HandleMallocAttr(Decl *d, const AttributeList &Attr, Sema &S) {
|
||||
// check the attribute arguments.
|
||||
// Check the attribute arguments.
|
||||
if (Attr.getNumArgs() != 0) {
|
||||
S.Diag(Attr.getLoc(), diag::err_attribute_wrong_number_arguments) << 0;
|
||||
return;
|
||||
|
@ -2281,6 +2298,7 @@ static void ProcessDeclAttribute(Scope *scope, Decl *D,
|
|||
case AttributeList::AT_ownership_takes:
|
||||
case AttributeList::AT_ownership_holds:
|
||||
HandleOwnershipAttr (D, Attr, S); break;
|
||||
case AttributeList::AT_naked: HandleNakedAttr (D, Attr, S); break;
|
||||
case AttributeList::AT_noreturn: HandleNoReturnAttr (D, Attr, S); break;
|
||||
case AttributeList::AT_nothrow: HandleNothrowAttr (D, Attr, S); break;
|
||||
case AttributeList::AT_override: HandleOverrideAttr (D, Attr, S); break;
|
||||
|
|
|
@ -0,0 +1,9 @@
|
|||
// RUN: %clang_cc1 -g -emit-llvm -o %t %s
|
||||
// RUN: grep 'naked' %t
|
||||
|
||||
void t1() __attribute__((naked));
|
||||
|
||||
void t1()
|
||||
{
|
||||
}
|
||||
|
|
@ -0,0 +1,8 @@
|
|||
// RUN: %clang_cc1 %s -verify -fsyntax-only
|
||||
|
||||
int a __attribute__((naked)); // expected-warning {{'naked' attribute only applies to function types}}
|
||||
|
||||
void t1() __attribute__((naked));
|
||||
|
||||
void t2() __attribute__((naked(2))); // expected-error {{attribute requires 0 argument(s)}}
|
||||
|
Загрузка…
Ссылка в новой задаче