|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| | We were marking the symbol as absolute instead of computing b's offset + the
expression value.
This fixes pr19126.
llvm-svn: 203962 | 
| | 
| 
| 
| 
| 
| | class.
llvm-svn: 203340 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | This compiles with no changes to clang/lld/lldb with MSVC and includes
overloads to various functions which are used by those projects and llvm
which have OwningPtr's as parameters. This should allow out of tree
projects some time to move. There are also no changes to libs/Target,
which should help out of tree targets have time to move, if necessary.
llvm-svn: 203083 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This is a nop. doesSectionRequireSymbols is only used from
isSymbolLinkerVisible. isSymbolLinkerVisible only use from ELF was in
if (!Asm.isSymbolLinkerVisible(Symbol) && !Symbol.isUndefined())
  return false;
if (Symbol.isTemporary())
  return false;
If the symbol is a temporary this code returns false and it is irrelevant if
we take the first if or not. If the symbol is not a temporary,
Asm.isSymbolLinkerVisible returns true without ever calling
doesSectionRequireSymbols.
This was an horrible leftover from when support for ELF was first added.
llvm-svn: 200894 | 
| | 
| 
| 
| 
| 
| | resolution works.
llvm-svn: 198780 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | take type from the new symbol but merge them so that the type
is never "downgraded".
This is probably quite rare, except for IFUNC symbols which
we used to misassemble, losing the IFUNC type.
Fixes #18372.
llvm-svn: 198706 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | Instead of crashing, raise an error when a subtraction expression
involves an undefined symbol.
This fixes PR18375.
llvm-svn: 198590 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | ELF_Other_Weakref and ELF_Other_ThumbFunc seems to be LLVM
internal ELF symbol flags.  These should not be emitted to
object file.
This commit defines ELF_STO_Shift for the target-defined
flags for st_other, and increase the value of
ELF_Other_Shift to 16.
llvm-svn: 196440 | 
| | 
| 
| 
| 
| 
| 
| | ELF. They can overlap with the other symbols, e.g. if a source file
"foo.c" contains a function "foo" with a static variable "c".
llvm-svn: 193569 | 
| | 
| 
| 
| 
| 
| | Code review by Eric Christopher and Rafael Espindola.
llvm-svn: 193209 | 
| | 
| 
| 
| | llvm-svn: 193194 | 
| | 
| 
| 
| 
| 
| 
| 
| | This makes using array_pod_sort significantly safer. The implementation relies
on function pointer casting but that should be safe as we're dealing with void*
here.
llvm-svn: 191175 | 
| | 
| 
| 
| 
| 
| 
| 
| | Patch from Игорь Пашев  (I do hope we support utf-8 commit messages; I
also hope he'll forgive me for transliterating it as Igor Pashev in
case things go horribly wrong).
llvm-svn: 186034 | 
| | 
| 
| 
| 
| 
| 
| 
| | Now that PowerPC no longer uses adjustFixupOffset, and no other
back-end (ever?) did, we can remove the infrastructure itself
(incidentally addressing a FIXME to that effect).
llvm-svn: 181895 | 
| | 
| 
| 
| | llvm-svn: 176763 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | excluding visibility bits.
Generic STO handling at the Target level.
The st_other field of the ELF symbol table is one
byte in size. The first 2 bytes are used for generic
visibility and are currently handled by llvm.
The other six bits are processor specific and need 
to be set at the target level.
A couple of notes:
The new static methods for accessing and setting the "other"
flags in include/llvm/MC/MCELF.h match the style guide
and not the other methods in the file. I don't like the
inconsistency, but feel I should follow the prescribed 
lowerUpper() convention.
STO_ value definitions are not specified in gnu land as 
consistently as the STT_ and STB_ fields. Probably because
the latter were defined in a standards doc and the former
defined partially in code. I have stuck with the full byte
definition of the flags.
Contributer: Zoran Jovanovic
llvm-svn: 175561 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | violations such as tabs, blanks at eol and long 
lines.
 
llvm-svn: 175007 | 
| | 
| 
| 
| 
| 
| 
| 
| | The sh_link in the ELF section header of .ARM.exidx should
be filled with the section index of the corresponding text
section.
llvm-svn: 174372 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and update ELF header e_flags.
Currently gathering information such as symbol, 
section and data is done by collecting it in an 
MCAssembler object. From MCAssembler and MCAsmLayout 
objects ELFObjectWriter::WriteObject() forms and 
streams out the ELF object file.
This patch just adds a few members to the MCAssember 
class to store and access the e_flag settings. It 
allows for runtime additions to the e_flag by 
assembler directives. The standalone assembler can 
get to MCAssembler from getParser().getStreamer().getAssembler().
This patch is the generic infrastructure and will be
followed by patches for ARM and Mips for their target 
specific use.
Contributer: Jack Carter
 
llvm-svn: 173882 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | but I cannot reproduce the problem and have scrubed my sources and
even tested with llvm-lit -v --vg.
Support for Mips register information sections.
Mips ELF object files have a section that is dedicated
to register use info. Some of this information such as
the assumed Global Pointer value is used by the linker
in relocation resolution.
The register info file is .reginfo in o32 and .MIPS.options
in 64 and n32 abi files.
This patch contains the changes needed to create the sections,
but leaves the actual register accounting for a future patch.
Contributer: Jack Carter
 
llvm-svn: 172847 | 
| | 
| 
| 
| | llvm-svn: 172358 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | SmallString. This makes it possible to use the length-erased SmallVectorImpl
in the interface without imposing buffer size. Thus, the size of MCInstFragment
is back down since a preallocated 8-byte contents buffer is enough.
It would be generally a good idea to rid all the fragments of SmallString as
contents, because a vector just makes more sense.
llvm-svn: 169644 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Before this patch, when you objdump an LLVM-compiled file, objdump tried to
decode data-in-code sections as if they were code.  This patch adds the missing
Mapping Symbols, as defined by "ELF for the ARM Architecture" (ARM IHI 0044D).
Patch based on work by Greg Fitzgerald.
llvm-svn: 169609 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This patch adds initial PPC64 TOC MC object creation using the small mcmodel
(a single 64K TOC) adding the some TOC relocations (R_PPC64_TOC,
R_PPC64_TOC16, and R_PPC64_TOC16DS).
The addition of 'undefinedExplicitRelSym' hook on 'MCELFObjectTargetWriter'
is meant to avoid the creation of an unreferenced ".TOC." symbol (used in
the .odp creation) as well to set the R_PPC64_TOC relocation target as the
temporary ".TOC." symbol. On PPC64 ABI, the R_PPC64_TOC relocation should
not point to any symbol.
llvm-svn: 166677 | 
| | 
| 
| 
| | llvm-svn: 166051 | 
| | 
| 
| 
| | llvm-svn: 162678 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | which many Mips 64 ABIs use than for O64 which many 
if not all other target ABIs use.
Most architectures have the following 64 bit relocation record format:
  typedef struct
  {
    Elf64_Addr   r_offset; /* Address of reference */
    Elf64_Xword  r_info;   /* Symbol index and type of relocation */
  } Elf64_Rel;
  typedef struct
  {
    Elf64_Addr    r_offset;
    Elf64_Xword   r_info;
    Elf64_Sxword  r_addend;
  } Elf64_Rela;
Whereas N64 has the following format:
  typedef struct
  {
    Elf64_Addr    r_offset;/* Address of reference */
    Elf64_Word  r_sym;     /* Symbol index */
    Elf64_Byte  r_ssym;    /* Special symbol */
    Elf64_Byte  r_type3;   /* Relocation type */
    Elf64_Byte  r_type2;   /* Relocation type */
    Elf64_Byte  r_type;    /* Relocation type */
  } Elf64_Rel;
  typedef struct
  {
    Elf64_Addr    r_offset;/* Address of reference */
    Elf64_Word  r_sym;     /* Symbol index */
    Elf64_Byte  r_ssym;    /* Special symbol */
    Elf64_Byte  r_type3;   /* Relocation type */
    Elf64_Byte  r_type2;   /* Relocation type */
    Elf64_Byte  r_type;    /* Relocation type */
    Elf64_Sxword  r_addend;
  } Elf64_Rela;
The structure is the same size, but the r_info data element 
is now 5 separate elements. Besides the content aspects, 
endian byte reordering will be different for the area with 
each element being endianized separately.
I treat this as generic and continue to pass r_type as 
an integer masking and unmasking the byte sized N64 
values for N64 mode. I've implemented this and it causes no 
affect on other current targets.
This passes make check.
Jack
llvm-svn: 159299 | 
| | 
| 
| 
| | llvm-svn: 156602 | 
| | 
| 
| 
| | llvm-svn: 153429 | 
| | 
| 
| 
| 
| 
| | entries in the relocation table before they are written out to the file. 
llvm-svn: 153345 | 
| | 
| 
| 
| 
| 
| | Found by the clang static analyzer.
llvm-svn: 148541 | 
| | 
| 
| 
| | llvm-svn: 147136 | 
| | 
| 
| 
| | llvm-svn: 147135 | 
| | 
| 
| 
| | llvm-svn: 147133 | 
| | 
| 
| 
| | llvm-svn: 147129 | 
| | 
| 
| 
| | llvm-svn: 147124 | 
| | 
| 
| 
| 
| 
| 
| 
| | ELF relocations.
Patch by Jack Carter.
llvm-svn: 147118 | 
| | 
| 
| 
| | llvm-svn: 147115 | 
| | 
| 
| 
| | llvm-svn: 147114 | 
| | 
| 
| 
| 
| 
| | to Target/.
llvm-svn: 147087 | 
| | 
| 
| 
| 
| 
| | Other targets will follow shortly.
llvm-svn: 147060 | 
| | 
| 
| 
| 
| 
| 
| | avoid including ADT/Triple.h in many places when the target specific bits are
moved.
llvm-svn: 147059 | 
| | 
| 
| 
| 
| 
| | side when the target specific bits are moved to the Target directory.
llvm-svn: 147053 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | test cases where there were a lot of relocations applied relative to a large
rodata section. Gas would create a symbol for each of these whereas we would
be relative to the beginning of the rodata section. This change mimics what
gas does.
Patch by Jack Carter.
llvm-svn: 146468 | 
| | 
| 
| 
| 
| 
| 
| | previous commit. It is strange that we see it in 32 bits. We already
have a fixme about it.
llvm-svn: 146273 | 
| | 
| 
| 
| 
| 
| 
| 
| | symbol difference. This matches gas behavior and fixes PR11513.
We still don't handle _GLOBAL_OFFSET_TABLE_ in data sections.
llvm-svn: 146238 | 
| | 
| 
| 
| 
| 
| 
| 
| | make the addend fixup code a bit more generic
Patch by Jack Carter.
llvm-svn: 145998 | 
| | 
| 
| 
| | llvm-svn: 145911 | 
| | 
| 
| 
| | llvm-svn: 145878 |