|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The IR
@foo = private constant i32 42
is valid, but before this patch we would produce an invalid MachO from it. It
was invalid because it would use an L label in a section where the liker needs
the labels in order to atomize it.
One way of fixing it would be to just reject this IR in the backend, but that
would not be very front end friendly.
What this patch does is use an 'l' prefix in sections that we know the linker
requires symbols for atomizing them. This allows frontends to just use
private and not worry about which sections they go to or how the linker handles
them.
One small issue with this strategy is that now a symbol name depends on the
section, which is not available before codegen. This is not a problem in
practice. The reason is that it only happens with private linkage, which will
be ignored by the non codegen users (llvm-nm and llvm-ar).
llvm-svn: 201608 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | These methods normally call each other and it is really annoying if the
arguments are in different order. The more common rule was that the arguments
specific to call are first (GV, Encoding, Suffix) and the auxiliary objects
(Mang, TM) come after. This patch changes the exceptions.
llvm-svn: 201044 | 
| | 
| 
| 
| 
| 
| 
| | It is never null and it is not used in casts, so there is no reason to use a
pointer. This matches how we pass TM.
llvm-svn: 201025 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | code to see if we're emitting a function into a non-default
text section. This is still a less-than-ideal solution, but more
contained than r199871 to determine whether or not we're emitting
code into an array of comdat sections.
llvm-svn: 200269 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | e.g. linkonce, to TargetMachine and set it when we've done so
for ELF targets currently. This involved making TargetMachine
non-const in a TLOF use and propagating that change around - I'm
open to other ideas.
This will be used in a future commit to handle emitting debug
information with ranges.
llvm-svn: 199871 | 
| | 
| 
| 
| 
| 
| | This makes it available to tools that don't link with target (like llvm-ar).
llvm-svn: 198708 | 
| | 
| 
| 
| 
| 
| 
| | With the gnu objc runtime private strings are used. Since we only need to
produce a unique label, the fix is to just drop the asserts.
llvm-svn: 198701 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Before this patch any program that wanted to know the final symbol name of a
GlobalValue had to link with Target.
This patch implements a compromise solution where the mangler uses DataLayout.
This way, any tool that already links with Target (llc, clang) gets the exact
behavior as before and new IR files can be mangled without linking with Target.
With this patch the mangler is constructed with just a DataLayout and DataLayout
is extended to include the information the Mangler needs.
llvm-svn: 198438 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | getSymbolWithGlobalValueBase use is to create a name of a new symbol based
on the name of an existing GV. Assert that and then remove the last call
to pass true to isImplicitlyPrivate.
This gives the mangler API a 1:1 mapping from GV to names, which is what we
need to drop the mangler dependency on the target (and use an extended
datalayout instead).
llvm-svn: 196472 | 
| | 
| 
| 
| 
| 
| | This allows it to be used in TargetLoweringObjectFileImpl.cpp.
llvm-svn: 196117 | 
| | 
| 
| 
| 
| 
| | This allows constructing a Mangler with just a TargetMachine.
llvm-svn: 193630 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This allows getDebugThreadLocalSymbol to return a generic MCExpr
instead of just a MCSymbolRefExpr.
This is in preparation for supporting debug info for TLS variables
on PowerPC, where we need to describe the variable location using
a more complex expression than just MCSymbolRefExpr.
llvm-svn: 185460 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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: 165402 | 
| | 
| 
| 
| | llvm-svn: 156226 | 
| | 
| 
| 
| | llvm-svn: 153502 | 
| | 
| 
| 
| 
| 
| | instead of always using ConstantVector.
llvm-svn: 149912 | 
| | 
| 
| 
| | llvm-svn: 148805 | 
| | 
| 
| 
| 
| 
| 
| 
| | of several newly un-defaulted switches. This also helps optimizers
(including LLVM's) recognize that every case is covered, and we should
assume as much.
llvm-svn: 147861 | 
| | 
| 
| 
| | llvm-svn: 147855 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | change, now you need a TargetOptions object to create a TargetMachine. Clang
patch to follow.
One small functionality change in PTX. PTX had commented out the machine
verifier parts in their copy of printAndVerify. That now calls the version in
LLVMTargetMachine. Users of PTX who need verification disabled should rely on
not passing the command-line flag to enable it.
llvm-svn: 145714 | 
| | 
| 
| 
| 
| 
| 
| | 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: 135375 | 
| | 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| | const Constant *.
llvm-svn: 133400 | 
| | 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | give it a bit more responsibility. Also implement it for MachO.
If hacked to use cfi, 32 bit MachO will produce
.cfi_personality 155, L___gxx_personality_v0$non_lazy_ptr
and 64 bit will produce
.cfi_presonality ___gxx_personality_v0
The general idea is that .cfi_personality gets passed the final symbol. It is
up to codegen to produce it if using indirect representation (like 32 bit
MachO), but it is up to MC to decide which relocations to create.
llvm-svn: 130341 | 
| | 
| 
| 
| | llvm-svn: 129844 | 
| | 
| 
| 
| | llvm-svn: 129640 | 
| | 
| 
| 
| 
| 
| | error in foo.o; no .eh_frame_hdr table will be created.
llvm-svn: 129635 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | debug info.
Change ELF systems to use CFI for producing the EH tables. This reduces the
size of the clang binary in Debug builds from 690MB to 679MB.
llvm-svn: 129571 | 
| | 
| 
| 
| 
| 
| 
| 
| | This reduces the"
It broke several builds.
llvm-svn: 129557 | 
| | 
| 
| 
| 
| 
| | size of the clang binary in Debug builds from 690MB to 679MB.
llvm-svn: 129518 | 
| | 
| 
| 
| 
| 
| | Add support for SHT_X86_64_UNWIND.
llvm-svn: 124059 | 
| | 
| 
| 
| 
| 
| 
| | constant but requires a unique address, we can still put it in a
readonly section, just not a mergable one.
llvm-svn: 123711 | 
| | 
| 
| 
| | llvm-svn: 123585 | 
| | 
| 
| 
| 
| 
| 
| | support aligned comm.  Detect when compiling for 10.4 and don't
emit an alignment for comm.  THis will hopefully fix PR8198.
llvm-svn: 114817 | 
| | 
| 
| 
| | llvm-svn: 106279 | 
| | 
| 
| 
| | llvm-svn: 100709 | 
| | 
| 
| 
| 
| 
| 
| | should use CreateTempSymbol() if they don't care about the
name.
llvm-svn: 98712 | 
| | 
| 
| 
| 
| 
| | for a global instead of messing around with string buffers.
llvm-svn: 98366 |