|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| | Restrict the current TLS support to X86 ELF for now. Test that we don't
produce it on PPC & we can flesh that test case out with the right thing
once someone implements it.
llvm-svn: 185389 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Based on GCC's output for TLS variables (OP_constNu, x@dtpoff,
OP_lo_user), this implements debug info support for TLS in ELF. Verified
that this output is correct/sufficient on Linux (using gold - if you're
using binutils-ld, you'll need something with the fix for
http://sourceware.org/bugzilla/show_bug.cgi?id=15685 in it).
Support on non-ELF is sort of "arbitrary" at the moment - if Apple folks
want to discuss (or just go ahead & implement) how this should work in
MachO, etc, I'm open.
llvm-svn: 185203 | 
| | 
| 
| 
| 
| 
| 
| | TLVs probably won't be as common as the other types of variables. Check for them
last before defaulting to "DATA".
llvm-svn: 180631 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Summary:
This is modelled on the Mach-O linker options implementation and should
support a Clang implementation of #pragma comment(lib/linker).
Reviewers: rafael
CC: llvm-commits
Differential Revision: http://llvm-reviews.chandlerc.com/D724
llvm-svn: 180569 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The linker sorts the .tls$<xyz> sections by name, and we need
to make sure any extra sections we produce (e.g. for weak globals) 
always end up between .tls$AAA and .tls$ZZZ, even if the name 
starts with e.g. an underscore.
Patch by David Nadlinger!
llvm-svn: 177256 | 
| | 
| 
| 
| | llvm-svn: 176467 | 
| | 
| 
| 
| 
| 
| | - Also, fixup syntax errors in LangRef and missing newline in the MCAsmStreamer.
llvm-svn: 172837 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | into their new header subdirectory: include/llvm/IR. This matches the
directory structure of lib, and begins to correct a long standing point
of file layout clutter in LLVM.
There are still more header files to move here, but I wanted to handle
them in separate commits to make tracking what files make sense at each
layer easier.
The only really questionable files here are the target intrinsic
tablegen files. But that's a battle I'd rather not fight today.
I've updated both CMake and Makefile build systems (I think, and my
tests think, but I may have missed something).
I've also re-sorted the includes throughout the project. I'll be
committing updates to Clang, DragonEgg, and Polly momentarily.
llvm-svn: 171366 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| | Do some cleanup of the code while here.
Inspired by patch by Logan Chien!
llvm-svn: 167904 | 
| | 
| 
| 
| | llvm-svn: 167877 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | r165941: Resubmit the changes to llvm core to update the functions to
         support different pointer sizes on a per address space basis.
Despite this commit log, this change primarily changed stuff outside of
VMCore, and those changes do not carry any tests for correctness (or
even plausibility), and we have consistently found questionable or flat
out incorrect cases in these changes. Most of them are probably correct,
but we need to devise a system that makes it more clear when we have
handled the address space concerns correctly, and ideally each pass that
gets updated would receive an accompanying test case that exercises that
pass specificaly w.r.t. alternate address spaces.
However, from this commit, I have retained the new C API entry points.
Those were an orthogonal change that probably should have been split
apart, but they seem entirely good.
In several places the changes were very obvious cleanups with no actual
multiple address space code added; these I have not reverted when
I spotted them.
In a few other places there were merge conflicts due to a cleaner
solution being implemented later, often not using address spaces at all.
In those cases, I've preserved the new code which isn't address space
dependent.
This is part of my ongoing effort to clean out the partial address space
code which carries high risk and low test coverage, and not likely to be
finished before the 3.2 release looms closer. Duncan and I would both
like to see the above issues addressed before we return to these
changes.
llvm-svn: 167222 | 
| | 
| 
| 
| 
| 
| | different pointer sizes on a per address space basis.
llvm-svn: 165941 | 
| | 
| 
| 
| | llvm-svn: 165747 | 
| | 
| 
| 
| 
| 
| | per address space pointer sizes to be optimized correctly.
llvm-svn: 165726 | 
| | 
| 
| 
| | llvm-svn: 165402 | 
| | 
| 
| 
| | llvm-svn: 160475 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | TargetLoweringObjectFileELF. Use this to support it on X86. Unlike ARM,
on X86 it is not easy to find out if .init_array should be used or not, so
the decision is made via TargetOptions and defaults to off.
Add a command line option to llc that enables it.
llvm-svn: 158692 | 
| | 
| 
| 
| 
| 
| | compiled to run on a simulator.
llvm-svn: 155435 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | member
of instantiated C++ templates.
Patch by Kristof Beyls!
llvm-svn: 151250 | 
| | 
| 
| 
| 
| 
| | guessing that it's the same as the size.
llvm-svn: 150813 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | ld sulk.  GNU ld is perfectly happy with it, which is worrying for a whole other set of reasons...
Thanks to Anton, Duncan and Rafael for helping me track this down.
Pointy hat to Rafael for introducing the bug in the first place.
llvm-svn: 150811 | 
| | 
| 
| 
| | llvm-svn: 150628 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | method. This allows the target lowering code to not have to deal with MDNodes.
Also, avoid leaking memory like a sieve by not creating a global variable for
the image info section, but just emitting the code directly.
llvm-svn: 150624 | 
| | 
| 
| 
| 
| 
| 
| 
| | The MachO back-end needs to emit the garbage collection flags specified in the
module flags. This is a WIP, so the front-end hasn't been modified to emit these
flags just yet. Documentation and front-end switching to occur soon.
llvm-svn: 150507 | 
| | 
| 
| 
| 
| 
| | Patch by Kai Nacke!
llvm-svn: 150307 | 
| | 
| 
| 
| 
| 
| 
| 
| | and let linker handle the rest.
This finally fixes PR5329
llvm-svn: 148990 | 
| | 
| 
| 
| | llvm-svn: 148578 | 
| | 
| 
| 
| 
| 
| 
| 
| | non_lazy_symbol_pointers section (__IMPORT,__pointers). Ignore the 'hidden' part
since that will place it in the wrong section.
<rdar://problem/10443720>
llvm-svn: 145356 | 
| | 
| 
| 
| | llvm-svn: 144648 | 
| | 
| 
| 
| 
| 
| 
| | table. A hidden variable could potentially end up in both lists.
<rdar://problem/10336715>
llvm-svn: 142869 | 
| | 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 135535 | 
| | 
| 
| 
| | llvm-svn: 135068 | 
| | 
| 
| 
| 
| 
| | supports compact unwind info instead of having a separate flag indicating this.
llvm-svn: 133685 | 
| | 
| 
| 
| | llvm-svn: 133662 | 
| | 
| 
| 
| 
| 
| 
| 
| | If the linker supports it, this will hold the CIE and FDE information in a
compact format. The implementation of the compact unwinding emission is coming
soon.
llvm-svn: 133658 | 
| | 
| 
| 
| 
| 
| | having.
llvm-svn: 132898 | 
| | 
| 
| 
| 
| 
| | Fixes PR10095.
llvm-svn: 132735 | 
| | 
| 
| 
| 
| 
| | this. XFAIL'd, because the COFF AsmParser can't handle .section yet.
llvm-svn: 132220 | 
| | 
| 
| 
| 
| 
| | assert that prevented setting alignment on section creation.
llvm-svn: 132113 | 
| | 
| 
| 
| | llvm-svn: 132111 | 
| | 
| 
| 
| | llvm-svn: 131952 | 
| | 
| 
| 
| | llvm-svn: 131951 | 
| | 
| 
| 
| | llvm-svn: 131765 | 
| | 
| 
| 
| | llvm-svn: 131763 | 
| | 
| 
| 
| 
| 
| 
| 
| | who used this flag, and it now emits CFI and doesn't emit this anymore. All
other targets left this flag "false".
<rdar://problem/8486371>
llvm-svn: 130918 | 
| | 
| 
| 
| 
| 
| | -fno-dwarf2-cfi-asm. Implement the same behavior.
llvm-svn: 130637 | 
| | 
| 
| 
| | llvm-svn: 130343 |