Skip to content

Commit

Permalink
Merge pull request #3814 from yebblies/crazyelf
Browse files Browse the repository at this point in the history
[cleanup] Normalize backend's elf structures with system headers.
  • Loading branch information
MartinNowak committed Oct 8, 2014
2 parents 1ea5d59 + 96705e4 commit 040515b
Show file tree
Hide file tree
Showing 5 changed files with 308 additions and 294 deletions.
2 changes: 1 addition & 1 deletion src/backend/cod3.c
Expand Up @@ -517,7 +517,7 @@ void cod3_buildmodulector(Outbuffer* buf, int codeOffset, int refOffset)
/* movl ModuleReference*, %eax */
buf->writeByte(0xB8);
codeOffset += 1;
const unsigned reltype = I64 ? R_X86_64_32 : RI_TYPE_SYM32;
const unsigned reltype = I64 ? R_X86_64_32 : R_386_32;
codeOffset += ElfObj::writerel(seg, codeOffset, reltype, 3 /*STI_DATA*/, refOffset);

/* movl _Dmodule_ref, %ecx */
Expand Down
4 changes: 2 additions & 2 deletions src/backend/dwarf.c
Expand Up @@ -73,7 +73,7 @@ static char __file__[] = __FILE__; // for tassert.h
int dwarf_getsegment(const char *name, int align)
{
#if ELFOBJ
return ElfObj::getsegment(name, NULL, SHT_PROGDEF, 0, align * 4);
return ElfObj::getsegment(name, NULL, SHT_PROGBITS, 0, align * 4);
#elif MACHOBJ
return MachObj::getsegment(name, "__DWARF", align * 2, S_ATTR_DEBUG);
#else
Expand All @@ -89,7 +89,7 @@ int dwarf_getsegment(const char *name, int align)
void dwarf_addrel(int seg, targ_size_t offset, int targseg, targ_size_t val = 0)
{
#if ELFOBJ
ElfObj::addrel(seg, offset, I64 ? R_X86_64_32 : RI_TYPE_SYM32, MAP_SEG2SYMIDX(targseg), val);
ElfObj::addrel(seg, offset, I64 ? R_X86_64_32 : R_386_32, MAP_SEG2SYMIDX(targseg), val);
#elif MACHOBJ
MachObj::addrel(seg, offset, NULL, targseg, RELaddr, val);
#else
Expand Down

0 comments on commit 040515b

Please sign in to comment.