|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| | llvm-svn: 130522 | 
| | 
| 
| 
| | llvm-svn: 130520 | 
| | 
| 
| 
| 
| 
| | assuming they are present in a fragment.
llvm-svn: 130519 | 
| | 
| 
| 
| 
| 
| | Luis Felipe Strano Moraes!
llvm-svn: 129558 | 
| | 
| 
| 
| 
| 
| | BLX, rather than a 2-byte instruction like B.
llvm-svn: 128169 | 
| | 
| 
| 
| 
| 
| 
| | This fixes kimwitu++, bullet, and tramp3dv4 with the ARM integrated assembler.
Fixes <rdar://problem/9165738>.
llvm-svn: 128117 | 
| | 
| 
| 
| 
| 
| | MCFixupKind.  This is the same technique that is used elsewhere in MC.
llvm-svn: 127676 | 
| | 
| 
| 
| 
| 
| | Patch by Erik Olofsson!
llvm-svn: 126796 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | (yes, this is different from R_ARM_CALL)
- Adds a new method getARMBranchTargetOpValue() which handles the
  necessary distinction between the conditional and unconditional br/bl
  needed for ARM/ELF
At least for ARM mode, the needed fixup for conditional versus unconditional
br/bl is identical, but the ARM docs and existing ARM tools expect this
reloc type...
Added a few FIXME's for future naming fixups in ARMInstrInfo.td
llvm-svn: 124895 | 
| | 
| 
| 
| | llvm-svn: 124645 | 
| | 
| 
| 
| 
| 
| 
| 
| | - Fixed :upper16: fix up routine. It should be shifting down the top 16 bits first.
- Added support for Thumb2 :lower16: and :upper16: fix up.
- Added :upper16: and :lower16: relocation support to mach-o object writer.
llvm-svn: 123424 | 
| | 
| 
| 
| | llvm-svn: 122583 | 
| | 
| 
| 
| 
| 
| | have a single point where targets test if a relocation is needed.
llvm-svn: 122549 | 
| | 
| 
| 
| | llvm-svn: 122547 | 
| | 
| 
| 
| | llvm-svn: 122441 | 
| | 
| 
| 
| | llvm-svn: 122419 | 
| | 
| 
| 
| 
| 
| | esp. important given that the LOCAL_SECTDIFF enumeration got redefined.
llvm-svn: 122412 | 
| | 
| 
| 
| 
| 
| | figure out how it is supposed to work.
llvm-svn: 122410 | 
| | 
| 
| 
| | llvm-svn: 122409 | 
| | 
| 
| 
| | llvm-svn: 122408 | 
| | 
| 
| 
| | llvm-svn: 122407 | 
| | 
| 
| 
| | llvm-svn: 122406 | 
| | 
| 
| 
| 
| 
| | RecordRelocation with lots of FIXMEs.
llvm-svn: 122402 | 
| | 
| 
| 
| | llvm-svn: 122401 | 
| | 
| 
| 
| 
| 
| 
| | clear how to keep in the generic path (yet).
 - Will revisit when it actually works.
llvm-svn: 122400 | 
| | 
| 
| 
| 
| 
| 
| | types, but they're just getting converted to unsigned anyway, so cast first
(and ask questions later).
llvm-svn: 122377 | 
| | 
| 
| 
| 
| 
| | type.
llvm-svn: 122334 | 
| | 
| 
| 
| | llvm-svn: 122148 | 
| | 
| 
| 
| | llvm-svn: 122147 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | IsSymbolRefDifferenceFullyResolved, it turns out this does change behavior on
enough cases for x86-32 that I would rather wait a bit on it.
 - In practice, we will want to change this eventually because it only means we
   generate less relocations (it also eliminates the need for the horrible
   '.set' hack that Darwin requires in some places).
llvm-svn: 122042 | 
| | 
| 
| 
| 
| 
| 
| 
| | - Unlike for fixups, we always do the "reliable" thing (not just for x86_64).
 - Since Darwin 'as' would typically reject things that using this will allow,
   we don't need to worry about compatibility.
llvm-svn: 122038 | 
| | 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| | superceded and was effectively dead.
llvm-svn: 122024 | 
| | 
| 
| 
| 
| 
| | interface.
llvm-svn: 121981 | 
| | 
| 
| 
| | llvm-svn: 121973 | 
| | 
| 
| 
| | llvm-svn: 121971 | 
| | 
| 
| 
| | llvm-svn: 121970 | 
| | 
| 
| 
| 
| 
| | from ctor_dtor_count-2.cpp.
llvm-svn: 121152 | 
| | 
| 
| 
| | llvm-svn: 121114 | 
| | 
| 
| 
| | llvm-svn: 121107 | 
| | 
| 
| 
| | llvm-svn: 121085 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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: 121041 | 
| | 
| 
| 
| | llvm-svn: 121034 | 
| | 
| 
| 
| 
| 
| | pool entries (LEApcrel pseudo). Ongoing saga of rdar://8542291.
llvm-svn: 120635 | 
| | 
| 
| 
| 
| 
| | and at least the 4 byte one will be needed to implement the .cfi_* directives.
llvm-svn: 120240 | 
| | 
| 
| 
| | llvm-svn: 120216 | 
| | 
| 
| 
| | llvm-svn: 120199 | 
| | 
| 
| 
| | llvm-svn: 120189 |