diff options
author | Aaron Ballman <aaron@aaronballman.com> | 2012-10-02 14:26:08 +0000 |
---|---|---|
committer | Aaron Ballman <aaron@aaronballman.com> | 2012-10-02 14:26:08 +0000 |
commit | 82bfa19fe3be324b13fdbcda46304b52c500f0d4 (patch) | |
tree | 0daccd9f1baf85595defd27fbac108073d2d56df /lib/Sema/SemaType.cpp | |
parent | 2ec1d13063fe11730f4a0005ee39299a1145a98a (diff) |
Allowing individual targets to determine whether a given calling convention is allowed or ignored with warning. This allows for correct name mangling for x64 targets on Windows, which in turn allows for linking against the Win32 APIs.
Fixes PR13782
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@165015 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaType.cpp')
-rw-r--r-- | lib/Sema/SemaType.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/lib/Sema/SemaType.cpp b/lib/Sema/SemaType.cpp index 243ae12d2a..a3af981c37 100644 --- a/lib/Sema/SemaType.cpp +++ b/lib/Sema/SemaType.cpp @@ -3886,14 +3886,14 @@ static bool handleFunctionTypeAttr(TypeProcessingState &state, return true; } + // Delay if the type didn't work out to a function. + if (!unwrapped.isFunctionType()) return false; + // Otherwise, a calling convention. CallingConv CC; if (S.CheckCallingConvAttr(attr, CC)) return true; - // Delay if the type didn't work out to a function. - if (!unwrapped.isFunctionType()) return false; - const FunctionType *fn = unwrapped.get(); CallingConv CCOld = fn->getCallConv(); if (S.Context.getCanonicalCallConv(CC) == |