]> granicus.if.org Git - clang/log
clang
8 years agoImplement post-commit review feedback on r252662
Jonathan Roelofs [Tue, 10 Nov 2015 22:48:11 +0000 (22:48 +0000)]
Implement post-commit review feedback on r252662

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252664 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoImplement the fix that r252641 should have been
Jonathan Roelofs [Tue, 10 Nov 2015 22:38:59 +0000 (22:38 +0000)]
Implement the fix that r252641 should have been

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252662 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[COFF] Don't try to emit weak aliases on COFF
Reid Kleckner [Tue, 10 Nov 2015 22:23:58 +0000 (22:23 +0000)]
[COFF] Don't try to emit weak aliases on COFF

This comes up when a derived class destructor is equivalent to a base
class destructor defined in the same TU, and we try to alias them.

A COFF weak alias cannot satisfy a normal undefined symbol reference
from another TU. The other TU must also mark the referenced symbol as
weak, and we can't rely on that.

Clang already has a special case here for dllexport, but we failed to
realize that the problem also applies to other non-discardable symbols
such as those from explicit template instantiations.

Fixes PR25477.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252659 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoImplement __attribute__((internal_linkage)).
Evgeniy Stepanov [Tue, 10 Nov 2015 21:28:44 +0000 (21:28 +0000)]
Implement __attribute__((internal_linkage)).

The attrubite is applicable to functions and variables and changes
the linkage of the subject to internal.

This is the same functionality as C-style "static", but applicable to
class methods; and the same as anonymouns namespaces, but can apply
to individual methods of a class.

Following the proposal in
http://lists.llvm.org/pipermail/cfe-dev/2015-October/045580.html

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252648 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[WebAssembly] Change long double to be quadruple-precision floating point.
Dan Gohman [Tue, 10 Nov 2015 21:01:46 +0000 (21:01 +0000)]
[WebAssembly] Change long double to be quadruple-precision floating point.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252646 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix missing CMake dependency introduced in r252474
Jonathan Roelofs [Tue, 10 Nov 2015 20:01:22 +0000 (20:01 +0000)]
Fix missing CMake dependency introduced in r252474

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252641 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoAdd the variant of __sparc_v9__ with five underscores, not just four.
Joerg Sonnenberger [Tue, 10 Nov 2015 19:28:17 +0000 (19:28 +0000)]
Add the variant of __sparc_v9__ with five underscores, not just four.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252640 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoNo longer creating the install-clang target for IDEs, as it was never meant for those.
Aaron Ballman [Tue, 10 Nov 2015 12:51:25 +0000 (12:51 +0000)]
No longer creating the install-clang target for IDEs, as it was never meant for those.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252601 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[Analyzer] Fix comments and formatting. NFC.
Sean Eveson [Tue, 10 Nov 2015 11:48:55 +0000 (11:48 +0000)]
[Analyzer] Fix comments and formatting. NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252599 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[X86] Use setzero instead of set1(0) in a few places in intrinsic headers.
Craig Topper [Tue, 10 Nov 2015 05:08:08 +0000 (05:08 +0000)]
[X86] Use setzero instead of set1(0) in a few places in intrinsic headers.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252587 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[X86] Remove temporary variables from macros in x86 intrinsic headers. Prevents dupli...
Craig Topper [Tue, 10 Nov 2015 05:08:05 +0000 (05:08 +0000)]
[X86] Remove temporary variables from macros in x86 intrinsic headers. Prevents duplicate names appearing from multiple macro expansions. NFC

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252586 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[X86] Fix bad intrinsic header comment. NFC.
Craig Topper [Tue, 10 Nov 2015 05:08:00 +0000 (05:08 +0000)]
[X86] Fix bad intrinsic header comment. NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252585 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoUse the generic Sparc CPU handling for Linux, FreeBSD and OpenBSD, too.
Joerg Sonnenberger [Tue, 10 Nov 2015 00:40:29 +0000 (00:40 +0000)]
Use the generic Sparc CPU handling for Linux, FreeBSD and OpenBSD, too.
This currently changes the default toward the more historic -Av8/-Av9,
but as discussed with James Y Knight, consistency is for now more
important than figuring out which default CPU each OS should be using.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252571 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoUse the normal switch over getArch() approach and not a long if chain.
Joerg Sonnenberger [Tue, 10 Nov 2015 00:23:12 +0000 (00:23 +0000)]
Use the normal switch over getArch() approach and not a long if chain.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252562 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[Driver] Use platform-appropriate profiling libraries for WatchOS, TVOS
Vedant Kumar [Tue, 10 Nov 2015 00:20:34 +0000 (00:20 +0000)]
[Driver] Use platform-appropriate profiling libraries for WatchOS, TVOS

When adding profiling instrumentation, use libclang_rt.profile_tvos.a
for TVOS targets and libclang_rt.profile_watchos.a for WatchOS targets.

I've also fixed up a comment and added an assert() that prevents us from
defaulting to an incorrect platform.

Differential Revision: http://reviews.llvm.org/D14521

Reviewed-by: t.p.northover
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252558 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoReorganise CPU handling for Sparc. When using -mcpu=v9 and co, __sparcv8
Joerg Sonnenberger [Mon, 9 Nov 2015 23:39:45 +0000 (23:39 +0000)]
Reorganise CPU handling for Sparc. When using -mcpu=v9 and co, __sparcv8
is not defined for 32bit mode, but __sparcv9 is. Pass down the correct
-target-cpu flags to the backend, so that instruction restrictions are
applied correctly. Pass down the correct -A flag when not using IAS.
The latter is limited to NetBSD targets in this commit.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252545 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[CMake] Support passing CMAKE_VERBOSE_MAKEFILE through to bootstrap builds.
Chris Bieneman [Mon, 9 Nov 2015 22:43:10 +0000 (22:43 +0000)]
[CMake] Support passing CMAKE_VERBOSE_MAKEFILE through to bootstrap builds.

This option enables full verbosity in recursive CMake builds.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252523 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoExtend linux header search to find libc++ headers in c++/vN for any N.
Evgeniy Stepanov [Mon, 9 Nov 2015 21:10:54 +0000 (21:10 +0000)]
Extend linux header search to find libc++ headers in c++/vN for any N.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252514 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoAtomics: support __c11_* calls on _Atomic struct types.
Tim Northover [Mon, 9 Nov 2015 19:56:35 +0000 (19:56 +0000)]
Atomics: support __c11_* calls on _Atomic struct types.

When a struct's size is not a power of 2, the corresponding _Atomic() type is
promoted to the nearest. We already correctly handled normal C++ expressions of
this form, but direct calls to the __c11_atomic_whatever builtins ended up
performing dodgy operations on the smaller non-atomic types (e.g. memcpy too
much). Later optimisations removed this as undefined behaviour.

This patch converts EmitAtomicExpr to allocate its temporaries at the full
atomic width, sidestepping the issue.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252507 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[analyzer] Fix assertion failure invalidating on const member function calls (PR25392).
Devin Coughlin [Mon, 9 Nov 2015 19:50:29 +0000 (19:50 +0000)]
[analyzer] Fix assertion failure invalidating on const member function calls (PR25392).

We now return early when the 'this' value cannot be converted to a MemRegion.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252506 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoMoving FileManager::removeDotPaths to llvm::sys::path::remove_dots
Mike Aizatsky [Mon, 9 Nov 2015 19:12:18 +0000 (19:12 +0000)]
Moving FileManager::removeDotPaths to llvm::sys::path::remove_dots

Differential Revision: http://reviews.llvm.org/D14394

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252501 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoUse "auto" when the type name is redundant
Alexander Kornienko [Mon, 9 Nov 2015 17:53:06 +0000 (17:53 +0000)]
Use "auto" when the type name is redundant

Summary: Use "auto" when the type name is redundant

Reviewers: aaron.ballman

Subscribers: cfe-commits

Differential Revision: http://reviews.llvm.org/D14501

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252494 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix the cmake build after r252474 broke it
Jonathan Roelofs [Mon, 9 Nov 2015 16:47:09 +0000 (16:47 +0000)]
Fix the cmake build after r252474 broke it

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252489 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoAdjust printQualifiedName to handle unscoped enums in a way similar to anonymous...
Alexander Kornienko [Mon, 9 Nov 2015 16:45:17 +0000 (16:45 +0000)]
Adjust printQualifiedName to handle unscoped enums in a way similar to anonymous namespaces.

Patch by Sterling Augustine!

Differential revision: http://reviews.llvm.org/D14459

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252488 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoCreate install targets for scan-build and scan-view
Jonathan Roelofs [Mon, 9 Nov 2015 16:12:56 +0000 (16:12 +0000)]
Create install targets for scan-build and scan-view

http://reviews.llvm.org/D14403

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252474 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFixing SPHINX warnings with incorrect indentations.
Aaron Ballman [Mon, 9 Nov 2015 15:24:09 +0000 (15:24 +0000)]
Fixing SPHINX warnings with incorrect indentations.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252470 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[EABI] Add Clang support for -meabi flag
Renato Golin [Mon, 9 Nov 2015 12:40:41 +0000 (12:40 +0000)]
[EABI] Add Clang support for -meabi flag

The -meabi flag to control LLVM EABI version.

Without '-meabi' or with '-meabi default' imply LLVM triple default.
With '-meabi gnu' sets EABI GNU.
With '-meabi 4' or '-meabi 5' set EABI version 4 and 5 respectively.

A similar patch was introduced in LLVM.

Patch by Vinicius Tinti.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252463 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[PGO] Code cleanup [NFC]
Xinliang David Li [Mon, 9 Nov 2015 00:04:16 +0000 (00:04 +0000)]
[PGO] Code cleanup [NFC]

Use interfaces defined in LLVM to create FuncName
and FuncNameVar.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252434 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoReplace tab with 8 spaces, NFC.
Yaron Keren [Sun, 8 Nov 2015 22:01:45 +0000 (22:01 +0000)]
Replace tab with 8 spaces, NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252426 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[analyzer] Update SATestBuild.py to enable a 'download and patch' model for projects.
Devin Coughlin [Sat, 7 Nov 2015 18:27:35 +0000 (18:27 +0000)]
[analyzer] Update SATestBuild.py to enable a 'download and patch' model for projects.

Currently the SATestBuild.py and SATestAdd.py buildbot scripts expect project
sources to be checked into the project repository. This commit changes these
scripts to additionally support a model where project sources are downloaded
rather than checked into the repository. Sometimes projects may need to be
modified (for example, to support a newer versions of clang), so the updated scripts
also allow for an optional patch file that will be applied to the downloaded
project source before analysis.

To support this workflow, this commit changes the expected layout of
a project in the repository. The project-specific helper scripts will stay
in the root of each project directory, but the benchmark source itself (if
checked into the repo) should now be stored in a subdirectory named
'CachedSource':

  project_name/
    cleanup_run_static_analyzer.sh [optional]
    run_static_analyzer.cmd [required]
    download_project.sh [optional]
    CachedSource/ [optional]
    changes_for_analyzer.patch [optional]

If the 'CachedSource' source directory is not present, the download script will
be executed. This script should download the project source into 'CachedSource'.
Then, if 'changes_for_analyzer.patch' is present its changes will
be applied to a copy of 'CachedSource' before analysis.

Differential Revision: http://reviews.llvm.org/D14345

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252410 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoRemove spaces in empty line, NFC.
Yaron Keren [Sat, 7 Nov 2015 16:35:07 +0000 (16:35 +0000)]
Remove spaces in empty line, NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252405 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoRemove spaces at start of line, NFC.
Yaron Keren [Sat, 7 Nov 2015 16:24:52 +0000 (16:24 +0000)]
Remove spaces at start of line, NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252404 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoMake a couple methods static.
Craig Topper [Sat, 7 Nov 2015 08:08:34 +0000 (08:08 +0000)]
Make a couple methods static.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252400 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoMake SemaBuiltinCpuSupports a static function. NFC.
Craig Topper [Sat, 7 Nov 2015 08:08:31 +0000 (08:08 +0000)]
Make SemaBuiltinCpuSupports a static function. NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252399 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoUse makeArrayRef instead of explicitly mentioning the type. NFC
Craig Topper [Sat, 7 Nov 2015 06:16:16 +0000 (06:16 +0000)]
Use makeArrayRef instead of explicitly mentioning the type. NFC

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252398 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix indentation. NFC
Craig Topper [Sat, 7 Nov 2015 06:16:14 +0000 (06:16 +0000)]
Fix indentation. NFC

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252397 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoUse regex in test case.
Akira Hatanaka [Sat, 7 Nov 2015 00:48:18 +0000 (00:48 +0000)]
Use regex in test case.

This is a follow-up to r252369.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252376 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoAdd support for function attribute 'not_tail_called'.
Akira Hatanaka [Fri, 6 Nov 2015 23:56:15 +0000 (23:56 +0000)]
Add support for function attribute 'not_tail_called'.

This attribute is used to prevent tail-call optimizations to the marked
function. For example, in the following piece of code, foo1 will not be
tail-call optimized:

int __attribute__((not_tail_called)) foo1(int);

int foo2(int a) {
  return foo1(a); // Tail-call optimization is not performed.
}

The attribute has effect only on statically bound calls. It has no
effect on indirect calls. Also, virtual functions and objective-c
methods cannot be marked as 'not_tail_called'.

rdar://problem/22667622

Differential Revision: http://reviews.llvm.org/D12922

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252369 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoStaticAnalyzer: Remove implicit ilist iterator conversions, NFC
Duncan P. N. Exon Smith [Fri, 6 Nov 2015 23:04:58 +0000 (23:04 +0000)]
StaticAnalyzer: Remove implicit ilist iterator conversions, NFC

Remove implicit ilist iterator conversions from clangStaticAnalyzer.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252360 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoCodeGen: Remove implicit ilist iterator conversions, NFC
Duncan P. N. Exon Smith [Fri, 6 Nov 2015 23:00:41 +0000 (23:00 +0000)]
CodeGen: Remove implicit ilist iterator conversions, NFC

Make ilist iterator conversions explicit in clangCodeGen.  Eventually
I'll remove them everywhere.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252358 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFixing line endings; NFC.
Aaron Ballman [Fri, 6 Nov 2015 15:34:03 +0000 (15:34 +0000)]
Fixing line endings; NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252314 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFollowup test failure fix for r252310 ("[tsan] Add Clang frontend support for TSan...
Kuba Brecka [Fri, 6 Nov 2015 15:20:30 +0000 (15:20 +0000)]
Followup test failure fix for r252310 ("[tsan] Add Clang frontend support for TSan on OS X").

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252311 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[tsan] Add Clang frontend support for TSan on OS X
Kuba Brecka [Fri, 6 Nov 2015 15:09:20 +0000 (15:09 +0000)]
[tsan] Add Clang frontend support for TSan on OS X

We're currently in process of porting TSan to OS X, and quite a few of the initial support in the runtime library has already landed in trunk. This patch actually enables "-fsanitize=thread" in the frontend.

Differential Revision: http://reviews.llvm.org/D14440

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252310 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix __builtin_signbit for ppcf128 type
Petar Jovanovic [Fri, 6 Nov 2015 14:52:46 +0000 (14:52 +0000)]
Fix __builtin_signbit for ppcf128 type

Function__builtin_signbit returns wrong value for type ppcf128 on big endian
machines. This patch fixes how value is generated in that case.

Patch by Aleksandar Beserminji.

Differential Revision: http://reviews.llvm.org/D14149

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252307 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[analyzer] Add VforkChecker to find unsafe code in vforked process.
Yury Gribov [Fri, 6 Nov 2015 11:16:31 +0000 (11:16 +0000)]
[analyzer] Add VforkChecker to find unsafe code in vforked process.

This checker looks for unsafe constructs in vforked process:
function calls (excluding whitelist), memory write and returns.
This was originally motivated by a vfork-related bug in xtables package.

Patch by Yury Gribov.

Differential revision: http://reviews.llvm.org/D14014

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252285 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoRefactor: Simplify boolean conditional return statements in lib/ARCMigrate
Alexander Kornienko [Fri, 6 Nov 2015 01:26:37 +0000 (01:26 +0000)]
Refactor: Simplify boolean conditional return statements in lib/ARCMigrate

Patch by Richard Thomson! (+a couple of modifications to address comments)

Differential revision: http://reviews.llvm.org/D10009

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252261 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoRefactor: simplify boolean conditional return statements in lib/Analysis
Alexander Kornienko [Fri, 6 Nov 2015 01:08:38 +0000 (01:08 +0000)]
Refactor: simplify boolean conditional return statements in lib/Analysis

Patch by Richard Thomson!

Differential revision: http://reviews.llvm.org/D10008

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252256 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix crash in EmitDeclMetadata mode
Keno Fischer [Thu, 5 Nov 2015 23:18:44 +0000 (23:18 +0000)]
Fix crash in EmitDeclMetadata mode

Summary: This fixes a bug that's easily encountered in LLDB
(https://llvm.org/bugs/show_bug.cgi?id=22875). The problem here is that we
mangle a name during debug info emission, but never actually emit the actual
Decl, so we run into problems in EmitDeclMetadata (which assumes such a Decl
exists). Fix that by just skipping metadata emissions for mangled names that
don't have associated Decls.

Reviewers: rjmccall

Subscribers: labath, cfe-commits

Differential Revision: http://reviews.llvm.org/D13959

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252229 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoBetter link for Library Fundamentals TS.
Richard Smith [Thu, 5 Nov 2015 22:21:52 +0000 (22:21 +0000)]
Better link for Library Fundamentals TS.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252223 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoCodeGen: Update for debug info API change.
Peter Collingbourne [Thu, 5 Nov 2015 22:04:14 +0000 (22:04 +0000)]
CodeGen: Update for debug info API change.

Differential Revision: http://reviews.llvm.org/D14266

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252220 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix incorrect status for P0012R1.
Richard Smith [Thu, 5 Nov 2015 21:42:32 +0000 (21:42 +0000)]
Fix incorrect status for P0012R1.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252216 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix CSS style name.
Richard Smith [Thu, 5 Nov 2015 21:42:07 +0000 (21:42 +0000)]
Fix CSS style name.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252215 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoUpdate C++ status page to match motions from Kona.
Richard Smith [Thu, 5 Nov 2015 21:41:06 +0000 (21:41 +0000)]
Update C++ status page to match motions from Kona.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252214 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoPR25368: Replace workaround for build failure with modules enabled with a fix
Richard Smith [Thu, 5 Nov 2015 21:16:22 +0000 (21:16 +0000)]
PR25368: Replace workaround for build failure with modules enabled with a fix
for the root cause. The 'using llvm::isa;' declaration in Basic/LLVM.h only
pulls the declarations of llvm::isa that were declared prior to it into
namespace clang. In a modules build, this is a hermetic set of just the
declarations from LLVM. In a non-modules build, we happened to also pull the
declaration from lib/CodeGen/Address.h into namespace clang, which made the
code in question accidentally compile.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252211 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoImprove macro dumping to preserve semantically-relevant spelling information.
Richard Smith [Thu, 5 Nov 2015 20:55:14 +0000 (20:55 +0000)]
Improve macro dumping to preserve semantically-relevant spelling information.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252206 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[WebAssembly] Update wasm builtin functions to match spec changes.
Dan Gohman [Thu, 5 Nov 2015 20:16:37 +0000 (20:16 +0000)]
[WebAssembly] Update wasm builtin functions to match spec changes.

The page_size operator has been removed from the spec, and the resize_memory
operator has been changed to grow_memory.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252201 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoAfter some discussion, promote -fobjc-weak to a driver option.
John McCall [Thu, 5 Nov 2015 19:19:56 +0000 (19:19 +0000)]
After some discussion, promote -fobjc-weak to a driver option.

rdar://problem/23415863

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252187 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[analyzer] Update RegionStoreManager::getBinding to handle BlockDataRegions
Devin Coughlin [Thu, 5 Nov 2015 18:56:42 +0000 (18:56 +0000)]
[analyzer] Update RegionStoreManager::getBinding to handle BlockDataRegions

Update RegionStoreManager::getBinding() to return UnknownVal when trying to get
the binding for a BlockDataRegion. Previously, getBinding() would try to cast the
BlockDataRegion to a TypedValueRegion and crash. This happened when a block
was passed as a parameter to an inlined function for which
StackHintGeneratorForSymbol::getMessage() tried to generate a stack hint message.

rdar://problem/21291971

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252185 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[ARM] Clang gives unintended warning message for 'mthumb' + M-profiles:
Alexandros Lamprineas [Thu, 5 Nov 2015 17:11:55 +0000 (17:11 +0000)]
[ARM] Clang gives unintended warning message for 'mthumb' + M-profiles:

$ clang --target=armv7m-none-eabi -mthumb -march=armv7-m -c test.c
clang-3.8: warning: argument unused during compilation: '-mthumb'

Differential Revision: http://reviews.llvm.org/D14384

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252175 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoAllow use of private headers in different sub-modules.
Manuel Klimek [Thu, 5 Nov 2015 15:24:47 +0000 (15:24 +0000)]
Allow use of private headers in different sub-modules.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252170 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[x86] Additional small fix for MCU psABI support
Andrey Bokhanko [Thu, 5 Nov 2015 12:43:09 +0000 (12:43 +0000)]
[x86] Additional small fix for MCU psABI support

This patch fixes one more thing in MCU psABI support: LongDoubleWidth should be set to 64.

Differential Revision: http://reviews.llvm.org/D14285

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252156 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoUse profile data template file for covmap func record (NFC)
Xinliang David Li [Thu, 5 Nov 2015 05:46:39 +0000 (05:46 +0000)]
Use profile data template file for covmap func record (NFC)

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252147 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoMake ArgumentAdjuster aware of the current file being processed.
Alexander Kornienko [Thu, 5 Nov 2015 02:19:53 +0000 (02:19 +0000)]
Make ArgumentAdjuster aware of the current file being processed.

Summary:
This is needed to handle per-project configurations when adding extra
arguments in clang-tidy for example.

Reviewers: klimek, djasper

Subscribers: djasper, cfe-commits, klimek

Differential Revision: http://reviews.llvm.org/D14191

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252134 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoTestModuleFileExtension.cpp: Include <cstdio> explicitly for fprintf(3).
NAKAMURA Takumi [Thu, 5 Nov 2015 01:34:19 +0000 (01:34 +0000)]
TestModuleFileExtension.cpp: Include <cstdio> explicitly for fprintf(3).

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252128 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[modules] Don't merge an anonymous enum definition into a named enum definition.
Richard Smith [Thu, 5 Nov 2015 01:30:19 +0000 (01:30 +0000)]
[modules] Don't merge an anonymous enum definition into a named enum definition.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252125 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix build break
David Majnemer [Thu, 5 Nov 2015 01:10:42 +0000 (01:10 +0000)]
Fix build break

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252120 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[Lex] Add __has_builtin support for __make_integer_seq
David Majnemer [Thu, 5 Nov 2015 01:01:47 +0000 (01:01 +0000)]
[Lex] Add __has_builtin support for __make_integer_seq

Differential Revision: http://reviews.llvm.org/D14349

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252115 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[modules] If we're given a module file, via -fmodule-file=, for a module, but
Richard Smith [Thu, 5 Nov 2015 00:54:55 +0000 (00:54 +0000)]
[modules] If we're given a module file, via -fmodule-file=, for a module, but
we can't load that file due to a configuration mismatch, and implicit module
building is disabled, and the user turns off the error-by-default warning for
that situation, then fall back to textual inclusion for the module rather than
giving an error if any of its headers are included.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252114 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix nullptr crash in -Wthread-safety-beta
Reid Kleckner [Thu, 5 Nov 2015 00:24:01 +0000 (00:24 +0000)]
Fix nullptr crash in -Wthread-safety-beta

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252107 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoThe control expression for a _Generic selection expression should have
Aaron Ballman [Thu, 5 Nov 2015 00:06:05 +0000 (00:06 +0000)]
The control expression for a _Generic selection expression should have
its type decayed and qualifiers stripped when determining which
selection it matches. Fixes PR16340.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252104 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoclang-format: Turn on wrapping before "else" for WebKit style.
Daniel Jasper [Wed, 4 Nov 2015 22:49:32 +0000 (22:49 +0000)]
clang-format: Turn on wrapping before "else" for WebKit style.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252089 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFix some Clang-tidy modernize warnings, other minor fixes.
Eugene Zelenko [Wed, 4 Nov 2015 21:37:17 +0000 (21:37 +0000)]
Fix some Clang-tidy modernize warnings, other minor fixes.

Differential revision: http://reviews.llvm.org/D14311

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252081 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[analyzer] Add 'optin' checker package and move localizability checkers into it.
Devin Coughlin [Wed, 4 Nov 2015 21:33:41 +0000 (21:33 +0000)]
[analyzer] Add 'optin' checker package and move localizability checkers into it.

This commit creates a new 'optin' top-level checker package and moves several of
the localizability checkers into it.

This package is for checkers that are not alpha and that would normally be on by
default but where the driver does not have enough information to determine when
they are applicable. The localizability checkers fit this criterion because the
driver cannot determine whether a project is localized or not -- this is best
determined at the IDE or build-system level.

This new package is *not* intended for checkers that are too noisy to be on by
default.

The hierarchy under 'optin' mirrors that in 'alpha': checkers under 'optin'
should be organized in the hierarchy they would have had if they were truly top
level (e.g., optin.osx.cocoa.MyOptInChecker).

Differential Revision: http://reviews.llvm.org/D14303

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252080 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFixed a link.
Alexander Kornienko [Wed, 4 Nov 2015 19:42:17 +0000 (19:42 +0000)]
Fixed a link.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252069 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoFixed header levels.
Alexander Kornienko [Wed, 4 Nov 2015 19:40:05 +0000 (19:40 +0000)]
Fixed header levels.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252068 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoRemoved mentions of clang-modernize, added a short description of clang-tidy.
Alexander Kornienko [Wed, 4 Nov 2015 19:34:55 +0000 (19:34 +0000)]
Removed mentions of clang-modernize, added a short description of clang-tidy.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252066 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[modules] Generalize the workaround for multiple ambiguous definitions of
Richard Smith [Wed, 4 Nov 2015 19:26:32 +0000 (19:26 +0000)]
[modules] Generalize the workaround for multiple ambiguous definitions of
internal linkage entities in different modules from r250884 to apply to all
names, not just function names.

This is really awkward: we don't want to merge internal-linkage symbols from
separate modules, because they might not actually be defining the same entity.
But we don't want to reject programs that use such an ambiguous symbol if those
internal-linkage symbols are in fact equivalent. For now, we're resolving the
ambiguity by picking one of the equivalent definitions as an extension.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252063 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[Concepts] Add diagnostics which fall under [dcl.spec.concept]p1
Nathan Wilson [Wed, 4 Nov 2015 18:18:35 +0000 (18:18 +0000)]
[Concepts] Add diagnostics which fall under [dcl.spec.concept]p1

Summary: Diagnose when the 'concept' specifier is used on a typedef or function parameter.

Reviewers: rsmith, hubert.reinterpretcast, aaron.ballman, faisalv

Subscribers: cfe-commits

Differential Revision: http://reviews.llvm.org/D14316

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252061 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoclang-cl: Parse the /guard:cf[-] flag (PR25400)
Hans Wennborg [Wed, 4 Nov 2015 16:11:56 +0000 (16:11 +0000)]
clang-cl: Parse the /guard:cf[-] flag (PR25400)

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252056 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoImproving the diagnostic for cases where the attribute only appertains to a function...
Aaron Ballman [Wed, 4 Nov 2015 16:09:04 +0000 (16:09 +0000)]
Improving the diagnostic for cases where the attribute only appertains to a function with a prototype.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252055 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoAllow compound assignment expressions to be contracted when licensed by the language...
Stephen Canon [Wed, 4 Nov 2015 15:25:38 +0000 (15:25 +0000)]
Allow compound assignment expressions to be contracted when licensed by the language or pragma.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252050 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoSilence "enumeral and non-enumeral type in conditional expression" warning; NFC.
Aaron Ballman [Wed, 4 Nov 2015 14:43:43 +0000 (14:43 +0000)]
Silence "enumeral and non-enumeral type in conditional expression" warning; NFC.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252047 91177308-0d34-0410-b5e6-96231b3b80d8

8 years agoInitialize member field.
Erik Verbruggen [Wed, 4 Nov 2015 14:34:43 +0000 (14:34 +0000)]
Initialize member field.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252045 91177308-0d34-0410-b5e6-96231b3b80d8

8 years ago[Sema] Implement __make_integer_seq
David Majnemer [Wed, 4 Nov 2015 03:40:30 +0000 (03:40 +0000)]
[Sema] Implement __make_integer_seq

This new builtin template allows for incredibly fast instantiations of
templates like std::integer_sequence.

Performance numbers follow:
My work station has 64 GB of ram + 20 Xeon Cores at 2.8 GHz.

__make_integer_seq<std::integer_sequence, int, 90000> takes 0.25
seconds.

std::make_integer_sequence<int, 90000> takes unbound time, it is still
running.  Clang is consuming gigabytes of memory.

Differential Revision: http://reviews.llvm.org/D13786

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@252036 91177308-0d34-0410-b5e6-96231b3b80d8

9 years ago[analyzer] Move the ObjCGenericsChecker out of the alpha package.
Devin Coughlin [Tue, 3 Nov 2015 19:38:03 +0000 (19:38 +0000)]
[analyzer] Move the ObjCGenericsChecker out of the alpha package.

It is now in the osx.cocoa package and so will be on by default for Apple
toolchains.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251966 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoIntroduce module file extensions to piggy-back data onto module files.
Douglas Gregor [Tue, 3 Nov 2015 18:33:07 +0000 (18:33 +0000)]
Introduce module file extensions to piggy-back data onto module files.

Introduce the notion of a module file extension, which introduces
additional information into a module file at the time it is built that
can then be queried when the module file is read. Module file
extensions are identified by a block name (which must be unique to the
extension) and can write any bitstream records into their own
extension block within the module file. When a module file is loaded,
any extension blocks are matched up with module file extension
readers, that are per-module-file and are given access to the input
bitstream.

Note that module file extensions can only be introduced by
programmatic clients that have access to the CompilerInvocation. There
is only one such extension at the moment, which is used for testing
the module file extension harness. As a future direction, one could
imagine allowing the plugin mechanism to introduce new module file
extensions.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251955 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoRevert "Support watchOS and tvOS in compiler-rt builds"
Tim Northover [Tue, 3 Nov 2015 18:14:42 +0000 (18:14 +0000)]
Revert "Support watchOS and tvOS in compiler-rt builds"

The required compiler-rt changes aren't present yet so attempting to
build with compiler-rt breaks. And since we're trying to deprecate
autotools we actually want to fix this in CMake primarily anyway.

This reverts r251712.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251953 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoSimplify Sema::ProcessPropertyDecl. NFC
Douglas Gregor [Tue, 3 Nov 2015 17:02:34 +0000 (17:02 +0000)]
Simplify Sema::ProcessPropertyDecl. NFC

Now that the properties created within Objective-C class extensions go
into the extension themselves, we don't need any of the extra
complexity here.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251949 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoRemove unused #include
David Majnemer [Tue, 3 Nov 2015 16:32:15 +0000 (16:32 +0000)]
Remove unused #include

No functionality change is intended.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251941 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoRemove some legacy mingw-w64 gcc struct info
Martell Malone [Tue, 3 Nov 2015 15:57:45 +0000 (15:57 +0000)]
Remove some legacy mingw-w64 gcc struct info

As of gcc 4.7 mingw-w64 no longer emits 128-bit structs as i128

Differential Revision: http://reviews.llvm.org/D14179

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251930 91177308-0d34-0410-b5e6-96231b3b80d8

9 years ago[X86] Rounding mode for roundps/pd/ss/sd builtins should be an ICE.
Craig Topper [Tue, 3 Nov 2015 07:20:07 +0000 (07:20 +0000)]
[X86] Rounding mode for roundps/pd/ss/sd builtins should be an ICE.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251902 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoFix a couple intrinsic header comments. NFC
Craig Topper [Tue, 3 Nov 2015 06:16:31 +0000 (06:16 +0000)]
Fix a couple intrinsic header comments. NFC

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251900 91177308-0d34-0410-b5e6-96231b3b80d8

9 years ago[modules] Rationalize the behavior of Decl::declarationReplaces, and in
Richard Smith [Tue, 3 Nov 2015 03:13:11 +0000 (03:13 +0000)]
[modules] Rationalize the behavior of Decl::declarationReplaces, and in
particular don't assume that two declarations of the same kind in the same
context are declaring the same entity. That's not true when the same name is
declared multiple times as internal-linkage symbols within a module.
(getCanonicalDecl is cheap now, so we can just use it here.)

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251898 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoEliminate "rewritten decls" from the AST writer. NFC
Douglas Gregor [Tue, 3 Nov 2015 01:20:54 +0000 (01:20 +0000)]
Eliminate "rewritten decls" from the AST writer. NFC

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251877 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoSwitch to using an explicit scope object to ensure we don't forget to pop ObjC
Richard Smith [Tue, 3 Nov 2015 01:19:56 +0000 (01:19 +0000)]
Switch to using an explicit scope object to ensure we don't forget to pop ObjC
type parameters off the scope, and fix the cases where we failed to do so.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251875 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoStop back-patching 'readonly' Objective-C properties with 'readwrite' ones.
Douglas Gregor [Tue, 3 Nov 2015 01:15:46 +0000 (01:15 +0000)]
Stop back-patching 'readonly' Objective-C properties with 'readwrite' ones.

A 'readonly' Objective-C property declared in the primary class can
effectively be shadowed by a 'readwrite' property declared within an
extension of that class, so long as the types and attributes of the
two property declarations are compatible.

Previously, this functionality was implemented by back-patching the
original 'readonly' property to make it 'readwrite', destroying source
information and causing some hideously redundant, incorrect
code. Simplify the implementation to express how this should actually
be modeled: as a separate property declaration in the extension that
shadows (via the name lookup rules) the declaration in the primary
class. While here, correct some broken Fix-Its, eliminate a pile of
redundant code, clean up the ARC migrator's handling of properties
declared in extensions, and fix debug info's naming of methods that
come from categories.

A wonderous side effect of doing this write is that it eliminates the
"AddedObjCPropertyInClassExtension" method from the AST mutation
listener, which in turn eliminates the last place where we rewrite
entire declarations in a chained PCH file or a module file. This
change (which fixes rdar://problem/18475765) will allow us to
eliminate the rewritten-decls logic from the serialization library,
and fixes a crash (rdar://problem/23247794) illustrated by the
test/PCH/chain-categories.m example.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251874 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoRemove empty directories.
Alexander Kornienko [Mon, 2 Nov 2015 22:24:28 +0000 (22:24 +0000)]
Remove empty directories.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251843 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agoMake hasLHS and hasRHS matchers available for ArraySubscriptExpr
Alexander Kornienko [Mon, 2 Nov 2015 22:23:21 +0000 (22:23 +0000)]
Make hasLHS and hasRHS matchers available for ArraySubscriptExpr

Summary:
The hasBase and hasIndex don't tell anything about the position of the
base and the index in the code, so we need hasLHS and hasRHS in some cases.

Reviewers: klimek

Subscribers: klimek, cfe-commits

Differential Revision: http://reviews.llvm.org/D14212

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251842 91177308-0d34-0410-b5e6-96231b3b80d8

9 years agowatchOS & tvOS: add a few more tests.
Tim Northover [Mon, 2 Nov 2015 21:14:48 +0000 (21:14 +0000)]
watchOS & tvOS: add a few more tests.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251832 91177308-0d34-0410-b5e6-96231b3b80d8

9 years ago[PTH] Fix data length used for stat cache entries
Reid Kleckner [Mon, 2 Nov 2015 20:47:31 +0000 (20:47 +0000)]
[PTH] Fix data length used for stat cache entries

This came up in a boost build, which apparently uses PTH. This was
broken in r187619 when we migrated it to uses llvm::fs instead of raw
stat calls.

Constructing a test case with a hash table collision in-tree is tough.
Instead, I have a pending change to OnDiskChainedHashTable that asserts
that the reported length of the data agrees with the data actually
written. All of the existing in-tree tests find the bug with this
assert.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@251828 91177308-0d34-0410-b5e6-96231b3b80d8