|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | Previously it was uninitialized and thus always defaulted to "<stdin>".
This is mostly a cosmetic change that helps making the debug info more readable.
llvm-svn: 308397 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Change ASTFileSignature from a random 32-bit number to the hash of the
PCM content.
  - Move definition ASTFileSignature to Basic/Module.h so Module and
    ASTSourceDescriptor can use it.
  - Change the signature from uint64_t to std::array<uint32_t,5>.
  - Stop using (saving/reading) the size and modification time of PCM
    files when there is a valid SIGNATURE.
  - Add UNHASHED_CONTROL_BLOCK, and use it to store the SIGNATURE record
    and other records that shouldn't affect the hash.  Because implicit
    modules reuses the same file for multiple levels of -Werror, this
    includes DIAGNOSTIC_OPTIONS and DIAG_PRAGMA_MAPPINGS.
This helps to solve a PCH + implicit Modules dependency issue: PCH files
are handled by the external build system, whereas implicit modules are
handled by internal compiler build system.  This prevents invalidating a
PCH when the compiler overwrites a PCM file with the same content
(modulo the diagnostic differences).
Design and original patch by Manman Ren!
llvm-svn: 297655 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | inline assembly may use the `.include` directive to include other
content into the file.  Without the integrated assembler, the `-I` group
gets passed to the assembler.  Emulate this by collecting the header
search paths and passing them to the IAS.
Resolves PR24811!
llvm-svn: 291123 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | As proposed on llvm-dev:
http://lists.llvm.org/pipermail/llvm-dev/2016-October/106630.html
Move block info block state to a new class, BitstreamBlockInfo.
Clients may set the block info for a particular cursor with the
BitstreamCursor::setBlockInfo() method.
At this point BitstreamReader is not much more than a container for an
ArrayRef<uint8_t>, so remove it and replace all uses with direct uses
of memory buffers.
Differential Revision: https://reviews.llvm.org/D26259
llvm-svn: 286207 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | As proposed on llvm-dev:
http://lists.llvm.org/pipermail/llvm-dev/2016-October/106595.html
This change also fixes an API oddity where BitstreamCursor::Read() would
return zero for the first read past the end of the bitstream, but would
report_fatal_error for subsequent reads. Now we always report_fatal_error
for all reads past the end. Updated clients to check for the end of the
bitstream before reading from it.
I also needed to add padding to the invalid bitcode tests in
test/Bitcode/. This is because the streaming interface was not checking that
the file size is a multiple of 4.
Differential Revision: https://reviews.llvm.org/D26219
llvm-svn: 285773 | 
| | 
| 
| 
| 
| 
| | rdar://problem/24504815
llvm-svn: 279004 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This changes the CompilerInstance::createOutputFile function to return
a std::unique_ptr<llvm::raw_ostream>, rather than an llvm::raw_ostream
implicitly owned by the CompilerInstance. This in most cases required that
I move ownership of the output stream to the relevant ASTConsumer.
The motivation for this change is to allow BackendConsumer to be a client
of interfaces such as D20268 which take ownership of the output stream.
Differential Revision: http://reviews.llvm.org/D21537
llvm-svn: 275507 | 
| | 
| 
| 
| 
| 
| | No functional change is intended, just a small refactoring.
llvm-svn: 273647 | 
| | 
| 
| 
| 
| 
| | No functionality change intended, maybe a tiny performance improvement.
llvm-svn: 270996 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | These constructs are only applicable to a debugger capable of loading a
Clang AST, so omit them for brevity when not doing so.
We could potentially propagate more of CodeGenOptions through the
ObjectFilePCGContainerOperations for consistency (so the next person who
adds some CodeGenOpts feature that tweaks debug info output doesn't get
caught by this), so I'm open to objections/alternatives there, but went
with this for now.
Tested just a couple of basic cases (one direct, one indirect (through
the ObjectFilePCHContainerOperations) & fixed up other cases to pass the
-debugger-tuning flag as appropriate.
llvm-svn: 268460 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Revert the two changes to thread CodeGenOptions into the TargetInfo allocation
and to fix the layering violation by moving CodeGenOptions into Basic.
Code Generation is arguably not particularly "basic".  This addresses Richard's
post-commit review comments.  This change purely does the mechanical revert and
will be followed up with an alternate approach to thread the desired information
into TargetInfo.
llvm-svn: 265806 | 
| | 
| 
| 
| 
| 
| 
| 
| | This is a mechanical move of CodeGenOptions from libFrontend to libBasic.  This
fixes the layering violation introduced earlier by threading CodeGenOptions into
TargetInfo.  It should also fix the modules based self-hosting builds.  NFC.
llvm-svn: 265702 | 
| | 
| 
| 
| 
| 
| 
| 
| | whose DeclContext is not yet complete by deferring their emission.
rdar://problem/24918680
llvm-svn: 262851 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Use it to calculate UserLabelPrefix, instead of specifying it (often
incorrectly).
Note that the *actual* user label prefix has always come from the
DataLayout, and is handled within LLVM. The main thing clang's
TargetInfo::UserLabelPrefix did was to set the #define value. Having
these be different from each-other is just silly.
Differential Revision: http://reviews.llvm.org/D17183
llvm-svn: 262737 | 
| | 
| 
| 
| 
| 
| | from Driver to Frontend.
llvm-svn: 259489 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | by stripping the path. Follow-up to r258555.
This is safe because only one PCH per CU is currently supported for
module debugging.
rdar://problem/24301262
llvm-svn: 258582 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | emitted into a precompiled header to mirror the debug info emitted for
object files importing the PCH.
rdar://problem/24290667
llvm-svn: 258555 | 
| | 
| 
| 
| | llvm-svn: 258531 | 
| | 
| 
| 
| 
| 
| | rdar://problem/24290667
llvm-svn: 258519 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | PCH files don't have a module signature and LLVM uses a nonzero DWO id as
an indicator for skeleton / module CUs. This change pins the DWO id for PCH
files to a known constant value.
The correct long-term solution here is to implement a module signature
that is an actual dterministic hash (at the moment module signatures are
just random nonzero numbers) and then enable this for PCH files as well.
<rdar://problem/24290667>
llvm-svn: 258507 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | variables are visited.
This shouldn't encourage anyone to put global variables into clang modules.
rdar://problem/24199640
llvm-svn: 258250 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | until we are visiting their declcontext.
This fixes a regression introduced in r256962:
When building debug info for a typdef'd anonymous tag type, we would be
visiting the inner anonymous type first thus creating a "typedef changes
linkage of anonymous type, but linkage was already computed" error.
rdar://problem/24199640
llvm-svn: 258152 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | was visited and all decls have been merged.
We only get a single chance to emit the types for virtual classes because
CGDebugInfo::completeRequiredType() categorically doesn't complete them.
llvm-svn: 256962 | 
| | 
| 
| 
| 
| 
| 
| 
| | containers.
rdar://problem/23196170
llvm-svn: 251120 | 
| | 
| 
| 
| | llvm-svn: 251116 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | when building a module. Clang already records the module signature when
building a skeleton CU to reference a clang module.
Matching the id in the skeleton with the one in the module allows a DWARF
consumer to verify that they found the correct version of the module
without them needing to know about the clang module format.
llvm-svn: 248345 | 
| | 
| 
| 
| | llvm-svn: 248184 | 
| | 
| 
| 
| | llvm-svn: 248127 | 
| | 
| 
| 
| 
| 
| 
| 
| | by dropping the const qualifier on the CI.
NFC
llvm-svn: 248101 | 
| | 
| 
| 
| | llvm-svn: 248068 | 
| | 
| 
| 
| 
| 
| 
| 
| | by passing in a CompilerInstance instead of all its individual members.
NFC.
llvm-svn: 248053 | 
| | 
| 
| 
| 
| 
| | Thanks to dblaikie for spotting this.
llvm-svn: 247303 | 
| | 
| 
| 
| 
| 
| 
| 
| | fixes"
This never broke the build; it was the LLVM side, r247216, that caused problems.
llvm-svn: 247302 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Seems it broke the Polly build.
From http://lab.llvm.org:8011/builders/perf-x86_64-penryn-O3-polly-fast/builds/11687/steps/compile/logs/stdio:
In file included from /home/grosser/buildslave/perf-x86_64-penryn-O3-polly-fast/llvm.src/lib/TableGen/Record.cpp:14:0:
/home/grosser/buildslave/perf-x86_64-penryn-O3-polly-fast/llvm.src/include/llvm/TableGen/Record.h:369:3: error: looser throw specifier for 'virtual llvm::TypedInit::~TypedInit()'
/home/grosser/buildslave/perf-x86_64-penryn-O3-polly-fast/llvm.src/include/llvm/TableGen/Record.h:270:11: error:   overriding 'virtual llvm::Init::~Init() noexcept (true)'
llvm-svn: 247222 | 
| | 
| 
| 
| 
| 
| 
| 
| | Patch by Eugene Zelenko!
Differential Revision: http://reviews.llvm.org/D12741
llvm-svn: 247218 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | When -fmodule-format is set to "obj", emit debug info for all types
declared in a module or referenced by a declaration into the module's
object file container.
This patch adds support for Objective-C types and methods.
llvm-svn: 247068 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | When -fmodule-format is set to "obj", emit debug info for all types
declared in a module or referenced by a declaration into the module's
object file container.
This patch adds support for C and C++ types.
llvm-svn: 247049 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | to enable the use of external type references in the debug info
(a.k.a. module debugging).
The driver expands -gmodules to "-g -fmodule-format=obj -dwarf-ext-refs"
and passes that to cc1. All this does at the moment is set a flag
codegenopts.
http://reviews.llvm.org/D11958
llvm-svn: 246192 | 
| | 
| 
| 
| 
| 
| 
| | ASTContext. Fixes some cases where we could previously initialize the AST
consumer more than once.
llvm-svn: 245346 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | After r244870 flush() will only compare two null pointers and return,
doing nothing but wasting run time. The call is not required any more
as the stream and its SmallString are always in sync.
Thanks to David Blaikie for reviewing.
llvm-svn: 244928 | 
| | 
| 
| 
| 
| 
| | particular, this avoids the need to re-parse module map files when using such a module.
llvm-svn: 244416 | 
| | 
| 
| 
| 
| 
| | use of the string.
llvm-svn: 244178 | 
| | 
| 
| 
| 
| | From: Mehdi Amini <mehdi.amini@apple.com>
llvm-svn: 243115 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - introduces a new cc1 option -fmodule-format=[raw,obj]
  with 'raw' being the default
- supports arbitrary module container formats that libclang is agnostic to
- adds the format to the module hash to avoid collisions
- splits the old PCHContainerOperations into PCHContainerWriter and
  a PCHContainerReader.
Thanks to Richard Smith for reviewing this patch!
llvm-svn: 242499 | 
| | 
| 
| 
| 
| 
| | and re-clang-format (NFC).
llvm-svn: 241841 | 
| | 
| 
| 
| 
| 
| | of the llvm targets from clang/CodeGen into ClangCheck.cpp and CIndex.cpp.
llvm-svn: 241653 | 
| | 
| 
| 
| 
| 
| | failures.
llvm-svn: 241642 | 
| | 
| 
| 
| | llvm-svn: 241635 | 
|  | This patch adds ObjectFilePCHContainerOperations uses the LLVM backend
to put the contents of a PCH into a __clangast section inside a COFF, ELF,
or Mach-O object file container.
This is done to facilitate module debugging by makeing it possible to
store the debug info for the types defined by a module alongside the AST.
rdar://problem/20091852
llvm-svn: 241620 |