|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 122134 | 
| | 
| 
| 
| | llvm-svn: 122070 | 
| | 
| 
| 
| | llvm-svn: 122067 | 
| | 
| 
| 
| | llvm-svn: 122064 | 
| | 
| 
| 
| | llvm-svn: 122050 | 
| | 
| 
| 
| 
| 
| 
| 
| | specific hook.
 - Currently just has stub implementations for Mach-O, ELF, and COFF.
llvm-svn: 122037 | 
| | 
| 
| 
| 
| 
| | -- and remove FIXME asking for the same!
llvm-svn: 122032 | 
| | 
| 
| 
| 
| 
| 
| | 2. Fixed EmitLocalCommonSymbol for ELF (Yes, they exist. :)
   Test added.
llvm-svn: 121951 | 
| | 
| 
| 
| 
| 
| | Test has fixme, to move to .s -> .o test when AsmParser works better.
llvm-svn: 121732 | 
| | 
| 
| 
| | llvm-svn: 121496 | 
| | 
| 
| 
| | llvm-svn: 121404 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Added test to check bl __aeabi_read_tp gets emitted properly for ELF/ASM
as well as ELF/OBJ (including fixup)
Also added support for ELF::R_ARM_TLS_IE32
llvm-svn: 121312 | 
| | 
| 
| 
| | llvm-svn: 121308 | 
| | 
| 
| 
| | llvm-svn: 121226 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 121072 | 
| | 
| 
| 
| 
| 
| 
| | + ARM/X86/MBlaze now share a common RecordRelocation
+ ARM/X86/MBlaze arch specific routines are limited to GetRelocType()
llvm-svn: 121043 | 
| | 
| 
| 
| 
| 
| | that on the ELF writer to detect a section we created.
llvm-svn: 120981 | 
| | 
| 
| 
| | llvm-svn: 120977 | 
| | 
| 
| 
| 
| 
| 
| 
| | contain only data. Handle them specially instead of using AddSectionToTheEnd.
This moves a hack from the generic assembler to the elf writer. It is also
a bit faster and should make other improvements easier.
llvm-svn: 120683 | 
| | 
| 
| 
| 
| 
| | pool entries (LEApcrel pseudo). Ongoing saga of rdar://8542291.
llvm-svn: 120635 | 
| | 
| 
| 
| 
| 
| | Additionally, update these to unified syntax.
llvm-svn: 120589 | 
| | 
| 
| 
| | llvm-svn: 120585 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Lifted adjustFixupValue() from Darwin for sharing w ELF.
Test added
TODO:
  refactor ELFObjectWriter::RecordRelocation more.
  Possibly share more code with Darwin?
  Lots more relocations...
llvm-svn: 120534 | 
| | 
| 
| 
| 
| 
| | and at least the 4 byte one will be needed to implement the .cfi_* directives.
llvm-svn: 120240 | 
| | 
| 
| 
| 
| 
| | for any relocation to a symbol defined in a tls section.
llvm-svn: 120121 | 
| | 
| 
| 
| 
| 
| | Patch by David Meyer, I added the test.
llvm-svn: 120104 | 
| | 
| 
| 
| | llvm-svn: 119986 | 
| | 
| 
| 
| | llvm-svn: 119982 | 
| | 
| 
| 
| | llvm-svn: 119981 | 
| | 
| 
| 
| | llvm-svn: 119979 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | to inside the class where it belongs.
Next step is to rationally break apart the RecordRelocation()
Probably the step will be to have 1 member function for ech slot of the ELFRelocationEntry()
llvm-svn: 119978 | 
| | 
| 
| 
| 
| 
| | perfect yet, but it works for many tests.
llvm-svn: 119952 | 
| | 
| 
| 
| | llvm-svn: 119917 | 
| | 
| 
| 
| | llvm-svn: 119328 | 
| | 
| 
| 
| | llvm-svn: 119175 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| | Added 2 new subclasses - X86ELFObjectWriter and ARMELFObectWriter.
ARM and X86 require different code for RecordRelocation(), possibly others.
llvm-svn: 119149 | 
| | 
| 
| 
| 
| 
| | a central location. This also makes us a bit more compatible with gas.
llvm-svn: 119094 | 
| | 
| 
| 
| 
| 
| 
| | signature symbol causes a local symbol to be created unless there is
some other use of the symbol.
llvm-svn: 119026 | 
| | 
| 
| 
| 
| 
| | the symbols.
llvm-svn: 119022 | 
| | 
| 
| 
| 
| 
| | - What was I thinking?????
llvm-svn: 118992 | 
| | 
| 
| 
| | llvm-svn: 118920 | 
| | 
| 
| 
| | llvm-svn: 118805 | 
| | 
| 
| 
| 
| 
| | a weakref is used with a VariantKind.
llvm-svn: 118798 | 
| | 
| 
| 
| 
| 
| 
| | easier to read by having const references to the symbol, aliased symbol and
renamed symbol.
llvm-svn: 118793 | 
| | 
| 
| 
| 
| 
| | a leftover from the removal of isExplicit.
llvm-svn: 118774 | 
| | 
| 
| 
| | llvm-svn: 118733 | 
| | 
| 
| 
| | llvm-svn: 118728 | 
| | 
| 
| 
| | llvm-svn: 118725 |