|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | subsequent changes are easier to review. About to fix some layering
issues, and wanted to separate out the necessary churn.
Also comment and sink the include of "Windows.h" in three .inc files to
match the usage in Memory.inc.
llvm-svn: 198685 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | MCJIT needs to be able to run in hostile environments, even when PWD
is invalid. There's no need to crash MCJIT in this case.
The obvious fix is to simply leave MCContext's CompilationDir empty
when PWD can't be determined. This way, MCJIT clients,
and other clients that link with LLVM don’t need a valid working directory.
If we do want to guarantee valid CompilationDir, that should be done
only for clients of getCompilationDir(). This is as simple as checking
for an empty string.
The only current use of getCompilationDir is EmitGenDwarfInfo, which
won’t conceivably run with an invalid working dir. However, in the
purely hypothetically and untestable case that this happens, the
AT_comp_dir will be omitted from the compilation_unit DIE.
llvm-svn: 196874 | 
| | 
| 
| 
| | llvm-svn: 196873 | 
| | 
| 
| 
| 
| 
| 
| | This patch tries to avoid unrelated changes other than fixing a few
hyphen-related ambiguities and contractions in nearby lines.
llvm-svn: 196471 | 
| | 
| 
| 
| | llvm-svn: 196301 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is the first step to fix pr17918.
It extends the .section directive a bit, inspired by what the ELF one looks
like. The problem with using linkonce is that given
.section foo
.linkonce....
.section foo
.linkonce
we would already have switched sections when getting to .linkonce. The cleanest
solution seems to be to add the comdat information in the .section itself.
llvm-svn: 195148 | 
| | 
| 
| 
| 
| 
| | Code review by Eric Christopher and Rafael Espindola.
llvm-svn: 193209 | 
| | 
| 
| 
| | llvm-svn: 185753 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Someone may want to do something crazy, like replace these objects if they
change or something.
No functionality change intended.
llvm-svn: 184175 | 
| | 
| 
| 
| | llvm-svn: 184059 | 
| | 
| 
| 
| 
| 
| | GetCurrentDirectory is now unused. Remove it.
llvm-svn: 184003 | 
| | 
| 
| 
| | llvm-svn: 183947 | 
| | 
| 
| 
| 
| 
| | MCDwarfFilesCUMap
llvm-svn: 176893 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | We now emit a line table for each compile unit. To reduce the prologue size
of each line table, the files and directories used by each compile unit are
stored in std::map<unsigned, std::vector< > > instead of std::vector< >.
The prologue for a lto'ed image can be as big as 93K. Duplicating 93K for each
compile unit causes a huge increase of debug info. With this patch, each
prologue will only emit the files required by the compile unit.
rdar://problem/13342023
llvm-svn: 176605 | 
| | 
| 
| 
| | llvm-svn: 175578 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | We generate one line table for each compilation unit in the object file.
Reviewed by Eric and Kevin.
rdar://problem/13067005
llvm-svn: 174445 | 
| | 
| 
| 
| | llvm-svn: 170394 | 
| | 
| 
| 
| 
| 
| 
| 
| | the assembler.
Part of PR14624
llvm-svn: 170390 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | compilation directory.
This defaults to the current working directory, just as it always has,
but now an assembler can choose to override it with a custom directory.
I've taught llvm-mc about this option and added a test case.
llvm-svn: 170371 | 
| | 
| 
| 
| 
| 
| 
| 
| | the asm printer,
also changed MCContext to a single reset only method for simplicity as requested on the list
llvm-svn: 170041 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | back to the tree with fixes. on darwin no valgrind issues exist in the tests that used to fail.
original change description:
change MCContext to work on the doInitialization/doFinalization model
reviewed by Evan Cheng <evan.cheng@apple.com>
llvm-svn: 169553 | 
| | 
| 
| 
| 
| 
| 
| 
| | doInitialization/doFinalization model"
It broke many builders.
llvm-svn: 169462 | 
| | 
| 
| 
| 
| 
| | reviewed by Evan Cheng <evan.cheng@apple.com>
llvm-svn: 169456 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Sooooo many of these had incorrect or strange main module includes.
I have manually inspected all of these, and fixed the main module
include to be the nearest plausible thing I could find. If you own or
care about any of these source files, I encourage you to take some time
and check that these edits were sensible. I can't have broken anything
(I strictly added headers, and reordered them, never removed), but they
may not be the headers you'd really like to identify as containing the
API being implemented.
Many forward declarations and missing includes were added to a header
files to allow them to parse cleanly when included first. The main
module rule does in fact have its merits. =]
llvm-svn: 169131 | 
| | 
| 
| 
| 
| 
| | Patch by Adhemerval Zanella.
llvm-svn: 164141 | 
| | 
| 
| 
| | llvm-svn: 159645 | 
| | 
| 
| 
| 
| 
| 
| 
| | with PathV2.
It fixes failure in test/MC/MachO/gen-dwarf.s on Win32 w/o bash.
llvm-svn: 159640 | 
| | 
| 
| 
| 
| 
| 
| | Can be used to issue more user friendly diagnostics for faulty
relocation constructs and such.
llvm-svn: 149092 | 
| | 
| 
| 
| | llvm-svn: 149090 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | it is separating the directory part from the basename of the FileName.  Noticed 
that this:
  .file 1 "dir/foo"
when assembled got the two parts switched.  Using the Mac OS X dwarfdump tool
it can be seen easily:
% dwarfdump -a a.out
include_directories[  1] = 'foo'
                Dir  Mod Time   File Len   File Name
                ---- ---------- ---------- ---------------------------
file_names[  1]    1 0x00000000 0x00000000 dir
...
Which should be:
...
include_directories[  1] = 'dir'
                Dir  Mod Time   File Len   File Name
                ---- ---------- ---------- ---------------------------
file_names[  1]    1 0x00000000 0x00000000 foo
llvm-svn: 143521 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | -g flag.  In this part we generate the .file for the source being assembled and
the .loc's for the assembled instructions.
The next part will be to generate the dwarf Compile Unit DIE and a dwarf
subprogram DIE for each non-temporary label.
Once the next part is done test cases will be added.  rdar://9275556
llvm-svn: 143509 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | .file filenumber "directory" "filename"
This removes one join+split of the directory+filename in MC internals. Because
bitcode files have independent fields for directory and filenames in debug info,
this patch may change the .o files written by existing .bc files.
llvm-svn: 142300 | 
| | 
| 
| 
| | llvm-svn: 141807 | 
| | 
| 
| 
| 
| 
| 
| | There is still a bit more refactoring left to do in Targets. But we are now very
close to fixing all the layering issues in MC.
llvm-svn: 135611 | 
| | 
| 
| 
| 
| 
| 
| 
| | TargetLoweringObjectFileImpl down to MCObjectFileInfo.
TargetAsmInfo is done to one last method. It's *almost* gone!
llvm-svn: 135569 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | to MCRegisterInfo. Also initialize the mapping at construction time.
This patch eliminate TargetRegisterInfo from TargetAsmInfo. It's another step
towards fixing the layering violation.
llvm-svn: 135424 | 
| | 
| 
| 
| 
| 
| | reduces the number of calls to malloc().
llvm-svn: 129687 | 
| | 
| 
| 
| 
| 
| | And don't append the name over and over again in the loop.
llvm-svn: 129210 | 
| | 
| 
| 
| 
| 
| | on Darwin.
llvm-svn: 128430 | 
| | 
| 
| 
| | llvm-svn: 124054 | 
| | 
| 
| 
| | llvm-svn: 121471 | 
| | 
| 
| 
| | llvm-svn: 121461 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | f:
        .cfi_startproc
        nop
        .cfi_endproc
assembled (on ELF).
llvm-svn: 121434 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | by the assembler. This was blocking parsing any large .s produced by clang for
example.
Fixes PR8596.
llvm-svn: 120603 | 
| | 
| 
| 
| | llvm-svn: 120166 | 
| | 
| 
| 
| 
| 
| 
| | Next: Add support for the !HasDotLocAndDotFile case to the MCAsmStreamer
and then switch codegen to use it.
llvm-svn: 119384 | 
| | 
| 
| 
| 
| 
| 
| | another patch.
This lets us parse a bit more of the gcc 4.5 output.
llvm-svn: 118975 | 
| | 
| 
| 
| | llvm-svn: 118805 | 
| | 
| 
| 
| | llvm-svn: 118699 | 
| | 
| 
| 
| 
| 
| | earlier. Implicit bool -> int conversions are evil!
llvm-svn: 118651 |