aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/MC/MCObjectStreamer.cpp
AgeCommit message (Collapse)AuthorFilesLines
2016-02-05[MC] Add support for encoding CodeView variable definition rangesDavid Majnemer1-0/+7
CodeView, like most other debug formats, represents the live range of a variable so that debuggers might print them out. They use a variety of records to represent how a particular variable might be available (in a register, in a frame pointer, etc.) along with a set of ranges where this debug information is relevant. However, the format only allows us to use ranges which are limited to a maximum of 0xF000 in size. This means that we need to split our debug information into chunks of 0xF000. Because the layout of code is not known until *very* late, we must use a new fragment to record the information we need until we can know *exactly* what the range is. llvm-svn: 259868
2016-02-02[codeview] Correctly handle inlining functions post-dominated by unreachableDavid Majnemer1-3/+4
CodeView requires us to accurately describe the extent of the inlined code. We did this by grabbing the next debug location in source order and using *that* to denote where we stopped inlining. However, this is not sufficient or correct in instances where there is no next debug location or the next debug location belongs to the start of another function. To get this correct, use the end symbol of the function to denote the last possible place the inlining could have stopped at. llvm-svn: 259548
2016-02-02[codeview] Wire up the .cv_inline_linetable directiveReid Kleckner1-3/+4
This directive emits the binary annotations that describe line and code deltas in inlined call sites. Single-stepping through inlined frames in windbg now works. llvm-svn: 259535
2016-01-29[CodeView] Implement .cv_inline_linetableDavid Majnemer1-0/+10
This support is _very_ rudimentary, just enough to get some basic data into the CodeView debug section. Left to do is: - Use the combined opcodes to save space. - Do something about code offsets. llvm-svn: 259230
2016-01-29Reland "[CodeView] Use assembler directives for line tables"Reid Kleckner1-0/+31
This reverts commit r259126 and relands r259117. This time with updated library dependencies. llvm-svn: 259130
2016-01-29Revert "[CodeView] Use assembler directives for line tables"Reid Kleckner1-31/+0
This reverts commit r259117. The LineInfo constructor is defined in the codeview library and we have to link against it now. Doing that isn't trivial, so reverting for now. llvm-svn: 259126
2016-01-28[CodeView] Use assembler directives for line tablesReid Kleckner1-0/+31
Adds a new family of .cv_* directives to LLVM's variant of GAS syntax: - .cv_file: Similar to DWARF .file directives - .cv_loc: Similar to the DWARF .loc directive, but starts with a function id. CodeView line tables are emitted by function instead of by compilation unit, so we needed an extra field to communicate this. Rather than overloading the .loc direction further, we decided it was better to have our own directive. - .cv_stringtable: Emits the codeview string table at the current position. Currently this just contains the filenames as null-terminated strings. - .cv_filechecksums: Emits the file checksum table for all files used with .cv_file so far. There is currently no support for emitting actual checksums, just filenames. This moves the line table emission code down into the assembler. This is in preparation for implementing the inlined call site line table format. The inline line table format encoding algorithm requires knowing the absolute code offsets, so it must run after the assembler has laid out the code. David Majnemer collaborated on this patch. llvm-svn: 259117
2016-01-21Rename MCLineEntry to MCDwarfLineEntryDavid Majnemer1-4/+4
MCLineEntry gives the impression that it is generic MC machinery. However, it is specific to DWARF. llvm-svn: 258381
2016-01-19[MC, COFF] Add .reloc support for WinCOFFDavid Majnemer1-2/+7
This adds rudimentary support for a few relocations that we will use for the CodeView debug format. llvm-svn: 258216
2016-01-19Simplify MCFillFragment.Rafael Espindola1-2/+2
The value size was always 1 or 0, so we don't need to store it. In a no asserts build this takes the testcase of pr26208 from 11 to 10 seconds. llvm-svn: 258141
2016-01-11Remove a bugs assert.Rafael Espindola1-2/+0
There is no reason the value being printed has to be positive. Fixes pr25802. llvm-svn: 257412
2015-11-12Implement .reloc (constant offset only) with support for R_MIPS_NONE and ↵Daniel Sanders1-0/+20
R_MIPS_32. Summary: Support for R_MIPS_NONE allows us to parse MIPS16's usage of .reloc. R_MIPS_32 was included to be able to better test the directive. Targets can add their relocations by overriding MCAsmBackend::getFixupKind(). Subscribers: grosbach, rafael, majnemer, dsanders, llvm-commits Differential Revision: http://reviews.llvm.org/D13659 llvm-svn: 252888
2015-11-05Fix pr24832.Rafael Espindola1-9/+1
It is pretty simple now that the yak is shaved. llvm-svn: 252105
2015-11-04Simplify now that emitValueToOffset always returns false.Rafael Espindola1-2/+1
llvm-svn: 252102
2015-11-04Simplify .org processing and make it a bit more powerful.Rafael Espindola1-17/+1
We now always create the fragment, which lets us handle things like .org after a .align. llvm-svn: 252101
2015-10-10MC: Remove implicit ilist iterator conversions, NFCDuncan P. N. Exon Smith1-1/+1
llvm-svn: 249922
2015-10-05Fix pr24486.Rafael Espindola1-2/+2
This extends the work done in r233995 so that now getFragment (in addition to getSection) also works for variable symbols. With that the existing logic to decide if a-b can be computed works even if a or b are variables. Given that, the expression evaluation can avoid expanding variables as aggressively and that in turn lets the relocation code see the original variable. In order for this to work with the asm streamer, there is now a dummy fragment per section. It is used to assign a section to a symbol when no other fragment exists. This patch is a joint work by Maxim Ostapenko andy myself. llvm-svn: 249303
2015-10-03Use early return. NFC.Rafael Espindola1-12/+12
llvm-svn: 249224
2015-09-20Cleanup places that passed SMLoc by const reference to pass it by value ↵Craig Topper1-1/+1
instead. NFC llvm-svn: 248135
2015-09-01[MC] Remove MCAssembler's copy of OSDavid Majnemer1-1/+1
We can just ask the ObjectWriter for it's stream instead of caching around our own reference to it. No functionality change is intended. llvm-svn: 246604
2015-08-13Remove and forbid raw_svector_ostream::flush() calls.Yaron Keren1-1/+0
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
2015-08-07[MC/Dwarf] Allow to specify custom parameters for linetable emission.Frederic Riss1-6/+10
NFC patch for current users, but llvm-dsymutil will use the new functionality to adapt to the input linetable. Based on a patch by Adrian Prantl. llvm-svn: 244318
2015-06-27[MC] Ensure that pending labels are flushed when -mc-relax-all flag is usedPetr Hosek1-2/+9
Summary: The current implementation doesn't always flush all pending labels beforeemitting data which can result in an incorrectly placed labels in case when when instruction bundling is enabled and -mc-relax-all flag is being used. To address this issue, we always flush pending labels before emitting data. The change was tested by running PNaCl toolchain trybots with -mc-relax-all flag set. Fixes https://code.google.com/p/nativeclient/issues/detail?id=4063 Test Plan: Regression test attached Reviewers: mseaborn Subscribers: jfb, llvm-commits Differential Revision: http://reviews.llvm.org/D10325 llvm-svn: 240870
2015-06-11Generalize emitAbsoluteSymbolDiff.Rafael Espindola1-9/+6
This makes emitAbsoluteSymbolDiff always succeed and moves logic from the asm printer to it. The object one now also works on ELF. If two symbols are in the same fragment, we will never move them apart. llvm-svn: 239552
2015-06-01Rename HasData to IsRegistered.Rafael Espindola1-4/+0
There is no MCSectionData, so the old name is now meaningless. Also remove some asserts/checks that were there just because the information they used was in MCSectionData. llvm-svn: 238708
2015-06-01Remove trivial forwarding function.Rafael Espindola1-1/+1
llvm-svn: 238707
2015-05-30MC: Clean up MCExpr naming. NFC.Jim Grosbach1-13/+13
llvm-svn: 238634
2015-05-29Remove getData.Rafael Espindola1-9/+5
This completes the mechanical part of merging MCSymbol and MCSymbolData. llvm-svn: 238617
2015-05-29Remove the MCSymbolData typedef.Rafael Espindola1-2/+2
The getData member function is next. llvm-svn: 238611
2015-05-29Rename getOrCreateSymbolData to registerSymbol and return void.Rafael Espindola1-3/+4
Another step in merging MCSymbol and MCSymbolData. llvm-svn: 238607
2015-05-29Move common symbol related information from MCSectionData to MCSymbol.Rafael Espindola1-4/+4
llvm-svn: 238583
2015-05-29Store MCSymbols in PendingLabels.Rafael Espindola1-2/+3
llvm-svn: 238582
2015-05-28Remove a trivial forwarding function. NFC.Rafael Espindola1-2/+2
llvm-svn: 238506
2015-05-27Rename and move getCurrentSectionData.Rafael Espindola1-4/+4
I think this concludes the merge of MCSectionData and MCSection. llvm-svn: 238358
2015-05-27There is only one current section.Rafael Espindola1-6/+5
Both MCStreamer and MCObjectStreamer were maintaining a current section variable and they were slightly out of sync. I don't think this was observable, but was inefficient and error prone. Changing this requires a few cascading changes: * SwitchSection has to call ChangeSection earlier for ChangeSection to see the old section. * With that change, ChangeSection cannot call EmitLabel, since during ChangeSection we are still in the old section. * When the object streamer requires a begin label, just reused the existing generic support for begin labels instead of calling EmitLabel directly. llvm-svn: 238357
2015-05-27Delete MCSectionData.Rafael Espindola1-1/+1
llvm-svn: 238331
2015-05-27Move getSubsectionInsertionPoint to MCSection.Rafael Espindola1-2/+1
llvm-svn: 238320
2015-05-26Replace getOrCreateSectionData with registerSection.Rafael Espindola1-2/+1
There is now no SectionData to be created. llvm-svn: 238208
2015-05-26Have getCurrentSectionData return a MCSection.Rafael Espindola1-6/+8
I will fix the name shortly. llvm-svn: 238204
2015-05-25Store a MCSection in MCFragment.Rafael Espindola1-1/+1
Part of the work to merge MCSectionData into MCSection. llvm-svn: 238160
2015-05-25Move HasInstructions to MCSection.Rafael Espindola1-1/+5
llvm-svn: 238150
2015-05-25Move bundle info from MCSectionData to MCSection.Rafael Espindola1-1/+1
llvm-svn: 238143
2015-05-21Stop forwarding (get|set)Aligment from MCSectionData to MCSection.Rafael Espindola1-2/+3
llvm-svn: 237956
2015-05-21Move alignment from MCSectionData to MCSection.Rafael Espindola1-2/+2
This starts merging MCSection and MCSectionData. There are a few issues with the current split between MCSection and MCSectionData. * It optimizes the the not as important case. We want the production of .o files to be really fast, but the split puts the information used for .o emission in a separate data structure. * The ELF/COFF/MachO hierarchy is not represented in MCSectionData, leading to some ad-hoc ways to represent the various flags. * It makes it harder to remember where each item is. The attached patch starts merging the two by moving the alignment from MCSectionData to MCSection. Most of the patch is actually just dropping 'const', since MCSectionData is mutable, but MCSection was not. llvm-svn: 237936
2015-05-21AsmPrinter: Compute absolute label difference directlyDuncan P. N. Exon Smith1-0/+23
Create a low-overhead path for `EmitLabelDifference()` that emits a emits an absolute number when (1) the output is an object stream and (2) the two symbols are in the same data fragment. This drops memory usage on Mach-O from 975 MB down to 919 MB (5.8%). The only call is when `!doesDwarfUseRelocationsAcrossSections()` -- i.e., on Mach-O -- since otherwise an absolute offset from the start of the section needs a relocation. (`EmitLabelDifference()` is cheaper on ELF anyway, since it creates 1 fewer temp symbol, and it gets called far less often. It's not clear to me if this is even a bottleneck there.) (I'm looking at `llc` memory usage on `verify-uselistorder.lto.opt.bc`; see r236629 for details.) llvm-svn: 237876
2015-05-18MC: Clean up method names in MCContext.Jim Grosbach1-3/+3
The naming was a mish-mash of old and new style. Update to be consistent with the new. NFC. llvm-svn: 237594
2015-05-15MC: Update MCCodeEmitter naming. NFC.Jim Grosbach1-1/+1
s/EncodeInstruction/encodeInstruction/ llvm-svn: 237469
2015-05-15MC: Update MCFixup naming. NFC.Jim Grosbach1-3/+3
s/MCFixup::Create/MCFixup::create/ llvm-svn: 237468
2015-04-14Use raw_pwrite_stream in the object writer/streamer.Rafael Espindola1-1/+2
The ELF object writer will take advantage of that in the next commit. llvm-svn: 234950
2015-04-12[MC] Write padding into fragments when -mc-relax-all flag is usedPetr Hosek1-4/+10
Summary: When instruction bundling is enabled and the -mc-relax-all flag is set, we can write bundle padding directly into fragments and avoid creating large number of fragments significantly reducing LLVM MC memory usage. Test Plan: Regression test attached Reviewers: eliben Subscribers: jfb, mseaborn Differential Revision: http://reviews.llvm.org/D8072 llvm-svn: 234714