|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| | llvm-svn: 120188 | 
| | 
| 
| 
| 
| 
| 
| | independent information on the Mach object format, and move some stuff from
MachObjectWriter.cpp there.
llvm-svn: 120186 | 
| | 
| 
| 
| | llvm-svn: 119547 | 
| | 
| 
| 
| 
| 
| | - What was I thinking?????
llvm-svn: 118992 | 
| | 
| 
| 
| | llvm-svn: 118831 | 
| | 
| 
| 
| | llvm-svn: 118288 | 
| | 
| 
| 
| 
| 
| 
| | they should be in the symbol table or not. Instead of "guessing", just compute
the symbol table after the relocations are known.
llvm-svn: 115619 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | where both symbols are "local", that is non-external symbols, and there is
no "base" for the symbols used in the expression, that is the section has
no non-temporary symbols.  This case looks like this:
% cat local_reloc_A-B.s
	.long 0
LB:	.long 1
	.long LA - LB - 4
	.long 2
LA:	.long 3
which llvm-mc will not encode without this patch, generates a "unsupported
local relocations in difference" error, but the Darwin assembler will
encode with relocation entries like this:
% otool -rv a.out l.out 
a.out:
Relocation information (__TEXT,__text) 2 entries
address  pcrel length extern type    scattered symbolnum/value
00000008 False long   False  SUB     False     1 (__TEXT,__text)
00000008 False long   False  UNSIGND False     1 (__TEXT,__text)
which is very similar to what is encoded when the symbols don't have the
leading 'L' and they are not temporary symbols.  Which llvm-mc and the
Darwin assembler will encoded like this:
Relocation information (__TEXT,__text) 2 entries
address  pcrel length extern type    scattered symbolnum/value
00000008 False long   True   SUB     False     B
00000008 False long   True   UNSIGND False     A
This is the missing relocation encoding needed to allow the Mach-O x86
Dwarf file and line table to be emitted.  So this patch also removes the
TODO from the if() statement in MCMachOStreamer::Finish() that didn't 
call MCDwarfFileTable::Emit() for 64-bit targets.
llvm-svn: 115389 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | With this patch in
movq    $foo, foo(%rip)
foo:
.long   foo
We produce a R_X86_64_32S for the first relocation and R_X86_64_32 for the
second one.
llvm-svn: 115134 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | resolved or not. Different object files have different restrictions and
different native assemblers have different idiosyncrasies we want to emulate
for now.
Move the existing MachO logic to the new place and implement an ELF one that
gets fixups to globals right.
llvm-svn: 115131 | 
| | 
| 
| 
| | llvm-svn: 114852 | 
| | 
| 
| 
| | llvm-svn: 114176 | 
| | 
| 
| 
| 
| 
| | 64 bits (was 64-bit shift intended?)", pointed out by 'nobled' on llvmdev
llvm-svn: 111148 | 
| | 
| 
| 
| 
| 
| 
| 
| | This reverts commit 110575.
Target.isAbsolute() is true if SD would be null.
llvm-svn: 110683 | 
| | 
| 
| 
| 
| 
| | Discovered by Microsoft Visual Studio 2010 Code Analysis.
llvm-svn: 110575 | 
| | 
| 
| 
| | llvm-svn: 107826 | 
| | 
| 
| 
| 
| 
| | but then not actually used - maybe a bug?  Remove the variable.
llvm-svn: 107137 | 
| | 
| 
| 
| 
| 
| | Thanks Daniel!
llvm-svn: 106608 | 
| | 
| 
| 
| | llvm-svn: 106191 | 
| | 
| 
| 
| | llvm-svn: 106154 | 
| | 
| 
| 
| | llvm-svn: 106142 | 
| | 
| 
| 
| | llvm-svn: 106072 | 
| | 
| 
| 
| | llvm-svn: 106062 | 
| | 
| 
| 
| | llvm-svn: 104793 | 
| | 
| 
| 
| | llvm-svn: 104699 | 
| | 
| 
| 
| | llvm-svn: 104697 | 
| | 
| 
| 
| | llvm-svn: 104651 | 
| | 
| 
| 
| | llvm-svn: 104223 | 
| | 
| 
| 
| 
| 
| 
| 
| | section header.
Also, create symbol data for LHS of assignment, to match 'as' symbol ordering better.
llvm-svn: 104033 | 
| | 
| 
| 
| | llvm-svn: 104032 | 
| | 
| 
| 
| 
| 
| | used to replace a normal relocation, not a reference to a GOT entry.
llvm-svn: 103789 | 
| | 
| 
| 
| 
| 
| | offset instead of the fixup address as intended.
llvm-svn: 103527 | 
| | 
| 
| 
| 
| 
| | clarify.
llvm-svn: 103526 | 
| | 
| 
| 
| | llvm-svn: 103525 | 
| | 
| 
| 
| 
| 
| | scattered relocation entry with a .weak_definition.
llvm-svn: 103443 | 
| | 
| 
| 
| | llvm-svn: 103442 | 
| | 
| 
| 
| 
| 
| 
| | external and the item to be relocated should not have the address of the
symbol added in.
llvm-svn: 103302 | 
| | 
| 
| 
| 
| 
| 
| | writing them.
 - <rdar://problem/7885351> integrated assembler broken for i386 objc code
llvm-svn: 103112 |