|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| | This first patch is for expression variable kinds.
Patch by Jack Carter!
llvm-svn: 142934 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - On COFF the .lcomm directive has an alignment argument.
- On ELF we fall back to .local + .comm
Based on a patch by NAKAMURA Takumi.
Fixes PR9337, PR9483 and PR10128.
llvm-svn: 138976 | 
| | 
| 
| 
| | llvm-svn: 136197 | 
| | 
| 
| 
| 
| 
| | createMCAsmBackend.
llvm-svn: 136010 | 
| | 
| 
| 
| 
| 
| | they belong.
llvm-svn: 135833 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | TargetAsmInfo, which in turn pulls in TargetRegisterInfo, etc. :-( There are
other cases of violations, but this is probably the worst.
This patch is but one small step towards fixing this. 500 more steps to go. :-(
llvm-svn: 135131 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | ("T is 1 if the target symbol S has type STT_FUNC and the
symbol addresses a Thumb instruction ;it is 0 otherwise."
from "ELF for the ARM Architecture" 4.7.1.2)
Patch by Koan-Sin Tan!
llvm-svn: 131406 | 
| | 
| 
| 
| | llvm-svn: 131119 | 
| | 
| 
| 
| 
| 
| | -fno-dwarf2-cfi-asm. Implement the same behavior.
llvm-svn: 130637 | 
| | 
| 
| 
| 
| 
| | While here, add VK_ARM_TPOFF and VK_ARM_GOTTPOFF, too.
llvm-svn: 127780 | 
| | 
| 
| 
| 
| 
| | other components can use them.
llvm-svn: 126942 | 
| | 
| 
| 
| 
| 
| | (duplicated) functions to new MCELF class.
llvm-svn: 126686 | 
| | 
| 
| 
| | llvm-svn: 126488 | 
| | 
| 
| 
| 
| 
| | Patch by Nathan Jeffords!
llvm-svn: 126425 | 
| | 
| 
| 
| | llvm-svn: 125629 | 
| | 
| 
| 
| | llvm-svn: 124077 | 
| | 
| 
| 
| | llvm-svn: 124056 | 
| | 
| 
| 
| | llvm-svn: 124054 | 
| | 
| 
| 
| | llvm-svn: 122566 | 
| | 
| 
| 
| 
| 
| 
| | 2. Fixed EmitLocalCommonSymbol for ELF (Yes, they exist. :)
   Test added.
llvm-svn: 121951 | 
| | 
| 
| 
| | llvm-svn: 121471 | 
| | 
| 
| 
| | llvm-svn: 121461 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | f:
        .cfi_startproc
        nop
        .cfi_endproc
assembled (on ELF).
llvm-svn: 121434 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | actuall addresses in a .o file, so it is better to let the MachO writer compute
it.
This is good for two reasons. First, areas that shouldn't care about
addresses now don't have access to it. Second, the layout of each section
is independent. I should use this in a subsequent commit to speed it up.
Most of the patch is just removing the section address computation. The two
interesting parts are the change on how we handle padding in the end
of sections and how MachO can get the address of a-b when a and b are in
different sections.
Since now the expression evaluation normally doesn't know the section address,
it will think that a-b needs relocation and let the MachO writer know. Once
it has computed the section addresses, it calls back the expression evaluation
with the section addresses to resolve these expressions.
The remaining problem is the handling of padding. Currently it will create
a special alignment fragment at the end. Since that fragment doesn't update
the alignment of the section, it needs the real address to be computed.
Since now the layout will not compute a-b with a and b in different sections,
the only effect that the special alignment fragment has is update the
address size of the section. This can also be done by the MachO writer.
llvm-svn: 121076 | 
| | 
| 
| 
| 
| 
| 
| | data fragment. This reduces the time to assemble the test in 8711 from 60s to
54s.
llvm-svn: 120767 | 
| | 
| 
| 
| | llvm-svn: 120691 | 
| | 
| 
| 
| | llvm-svn: 120690 | 
| | 
| 
| 
| | llvm-svn: 120269 | 
| | 
| 
| 
| 
| 
| | Factor some duplicated code into MCObjectStreamer::EmitLabel.
llvm-svn: 120248 | 
| | 
| 
| 
| | llvm-svn: 120246 | 
| | 
| 
| 
| | llvm-svn: 120245 | 
| | 
| 
| 
| | llvm-svn: 120243 | 
| | 
| 
| 
| 
| 
| | and at least the 4 byte one will be needed to implement the .cfi_* directives.
llvm-svn: 120240 | 
| | 
| 
| 
| 
| 
| | sets the type of a symbol to STT_TLS.
llvm-svn: 120100 | 
| | 
| 
| 
| 
| 
| | fixes PR8659.
llvm-svn: 120076 | 
| | 
| 
| 
| | llvm-svn: 119816 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | MCStreamer instead of just MCObjectStreamer. Address changes cannot
be as efficient as we have to use DW_LNE_set_addres, but at least
most of the logic is shared.
This will be used so that, with CodeGen still using EmitDwarfLocDirective,
llvm-gcc is able to produce debug_line sections without needing an
assembler that supports .loc.
llvm-svn: 119777 | 
| | 
| 
| 
| 
| 
| 
| | Next: Add support for the !HasDotLocAndDotFile case to the MCAsmStreamer
and then switch codegen to use it.
llvm-svn: 119384 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | variable if recursing fails to simplify it.
Factor AliasedSymbol to be a method of MCSymbol.
Update MCAssembler::EvaluateFixup to match the change in
EvaluateAsRelocatableImpl.
Remove the WeakRefExpr hack, as the object writer now sees the weakref with
no extra effort needed.
Nothing else is using MCTargetExpr, but keep it for now.
Now that the ELF writer sees relocations with aliases, handle
    .weak    foo2
foo2:
    .weak    bar2
    .set    bar2,foo2
    .quad    bar2
the same way gas does and produce a relocation with bar2.
llvm-svn: 119152 | 
| | 
| 
| 
| 
| 
| | directive.
llvm-svn: 119073 | 
| | 
| 
| 
| | llvm-svn: 119060 | 
| | 
| 
| 
| 
| 
| 
| | signature symbol causes a local symbol to be created unless there is
some other use of the symbol.
llvm-svn: 119026 | 
| | 
| 
| 
| | llvm-svn: 119021 | 
| | 
| 
| 
| 
| 
| | gas.
llvm-svn: 118818 | 
| | 
| 
| 
| | llvm-svn: 118309 | 
| | 
| 
| 
| | llvm-svn: 118301 | 
| | 
| 
| 
| | llvm-svn: 118294 | 
| | 
| 
| 
| | llvm-svn: 117930 | 
| | 
| 
| 
| | llvm-svn: 117925 | 
| | 
| 
| 
| | llvm-svn: 117911 |