forked from OSchip/llvm-project
Disallow a cleanup attribute from appertaining to a parameter (the attribute only appertains to local variables and is silently a noop on parameters). This repurposes the unused (and syntactically incorrect) NormalVar attribute subject.
llvm-svn: 319555
This commit is contained in:
parent
54c6083fb1
commit
3b70e75780
|
@ -77,13 +77,8 @@ class SubsetSubject<AttrSubject base, code check, string diag> : AttrSubject {
|
||||||
string DiagSpelling = diag;
|
string DiagSpelling = diag;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This is the type of a variable which C++11 allows alignas(...) to appertain
|
def LocalVar : SubsetSubject<Var,
|
||||||
// to.
|
[{S->hasLocalStorage() && !isa<ParmVarDecl>(S)}],
|
||||||
def NormalVar : SubsetSubject<Var,
|
|
||||||
[{S->getStorageClass() != VarDecl::Register &&
|
|
||||||
S->getKind() != Decl::ImplicitParam &&
|
|
||||||
S->getKind() != Decl::ParmVar &&
|
|
||||||
S->getKind() != Decl::NonTypeTemplateParm}],
|
|
||||||
"local variables">;
|
"local variables">;
|
||||||
def NonParmVar : SubsetSubject<Var,
|
def NonParmVar : SubsetSubject<Var,
|
||||||
[{S->getKind() != Decl::ParmVar}],
|
[{S->getKind() != Decl::ParmVar}],
|
||||||
|
@ -533,7 +528,6 @@ def Alias : Attr {
|
||||||
def Aligned : InheritableAttr {
|
def Aligned : InheritableAttr {
|
||||||
let Spellings = [GCC<"aligned">, Declspec<"align">, Keyword<"alignas">,
|
let Spellings = [GCC<"aligned">, Declspec<"align">, Keyword<"alignas">,
|
||||||
Keyword<"_Alignas">];
|
Keyword<"_Alignas">];
|
||||||
// let Subjects = SubjectList<[NonBitField, NormalVar, Tag]>;
|
|
||||||
let Args = [AlignedArgument<"Alignment", 1>];
|
let Args = [AlignedArgument<"Alignment", 1>];
|
||||||
let Accessors = [Accessor<"isGNU", [GCC<"aligned">]>,
|
let Accessors = [Accessor<"isGNU", [GCC<"aligned">]>,
|
||||||
Accessor<"isC11", [Keyword<"_Alignas">]>,
|
Accessor<"isC11", [Keyword<"_Alignas">]>,
|
||||||
|
@ -768,7 +762,7 @@ def CFConsumed : InheritableParamAttr {
|
||||||
def Cleanup : InheritableAttr {
|
def Cleanup : InheritableAttr {
|
||||||
let Spellings = [GCC<"cleanup">];
|
let Spellings = [GCC<"cleanup">];
|
||||||
let Args = [FunctionArgument<"FunctionDecl">];
|
let Args = [FunctionArgument<"FunctionDecl">];
|
||||||
let Subjects = SubjectList<[Var]>;
|
let Subjects = SubjectList<[LocalVar]>;
|
||||||
let Documentation = [Undocumented];
|
let Documentation = [Undocumented];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3067,12 +3067,6 @@ static void handleTargetAttr(Sema &S, Decl *D, const AttributeList &Attr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void handleCleanupAttr(Sema &S, Decl *D, const AttributeList &Attr) {
|
static void handleCleanupAttr(Sema &S, Decl *D, const AttributeList &Attr) {
|
||||||
VarDecl *VD = cast<VarDecl>(D);
|
|
||||||
if (!VD->hasLocalStorage()) {
|
|
||||||
S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Expr *E = Attr.getArgAsExpr(0);
|
Expr *E = Attr.getArgAsExpr(0);
|
||||||
SourceLocation Loc = E->getExprLoc();
|
SourceLocation Loc = E->getExprLoc();
|
||||||
FunctionDecl *FD = nullptr;
|
FunctionDecl *FD = nullptr;
|
||||||
|
@ -3115,7 +3109,7 @@ static void handleCleanupAttr(Sema &S, Decl *D, const AttributeList &Attr) {
|
||||||
|
|
||||||
// We're currently more strict than GCC about what function types we accept.
|
// We're currently more strict than GCC about what function types we accept.
|
||||||
// If this ever proves to be a problem it should be easy to fix.
|
// If this ever proves to be a problem it should be easy to fix.
|
||||||
QualType Ty = S.Context.getPointerType(VD->getType());
|
QualType Ty = S.Context.getPointerType(cast<VarDecl>(D)->getType());
|
||||||
QualType ParamTy = FD->getParamDecl(0)->getType();
|
QualType ParamTy = FD->getParamDecl(0)->getType();
|
||||||
if (S.CheckAssignmentConstraints(FD->getParamDecl(0)->getLocation(),
|
if (S.CheckAssignmentConstraints(FD->getParamDecl(0)->getLocation(),
|
||||||
ParamTy, Ty) != Sema::Compatible) {
|
ParamTy, Ty) != Sema::Compatible) {
|
||||||
|
|
|
@ -2,16 +2,16 @@
|
||||||
|
|
||||||
void c1(int *a);
|
void c1(int *a);
|
||||||
|
|
||||||
extern int g1 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute ignored}}
|
extern int g1 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute only applies to local variables}}
|
||||||
int g2 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute ignored}}
|
int g2 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute only applies to local variables}}
|
||||||
static int g3 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute ignored}}
|
static int g3 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute only applies to local variables}}
|
||||||
|
|
||||||
void t1()
|
void t1()
|
||||||
{
|
{
|
||||||
int v1 __attribute((cleanup)); // expected-error {{'cleanup' attribute takes one argument}}
|
int v1 __attribute((cleanup)); // expected-error {{'cleanup' attribute takes one argument}}
|
||||||
int v2 __attribute((cleanup(1, 2))); // expected-error {{'cleanup' attribute takes one argument}}
|
int v2 __attribute((cleanup(1, 2))); // expected-error {{'cleanup' attribute takes one argument}}
|
||||||
|
|
||||||
static int v3 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute ignored}}
|
static int v3 __attribute((cleanup(c1))); // expected-warning {{'cleanup' attribute only applies to local variables}}
|
||||||
|
|
||||||
int v4 __attribute((cleanup(h))); // expected-error {{use of undeclared identifier 'h'}}
|
int v4 __attribute((cleanup(h))); // expected-error {{use of undeclared identifier 'h'}}
|
||||||
|
|
||||||
|
@ -46,3 +46,5 @@ void t5() {
|
||||||
void t6(void) {
|
void t6(void) {
|
||||||
int i __attribute__((cleanup((void *)0))); // expected-error {{'cleanup' argument is not a function}}
|
int i __attribute__((cleanup((void *)0))); // expected-error {{'cleanup' argument is not a function}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void t7(__attribute__((cleanup(c4))) int a) {} // expected-warning {{'cleanup' attribute only applies to local variables}}
|
||||||
|
|
Loading…
Reference in New Issue