From: Rafael Espindola Date: Wed, 18 Mar 2015 17:33:40 +0000 (+0000) Subject: Handle X86::reloc_riprel_4byte in 32 bits mode. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=df600f804907d478abc9968b1aa49dad3f21ce75;p=oota-llvm.git Handle X86::reloc_riprel_4byte in 32 bits mode. We can get there with .code64. Fixes pr22349. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@232651 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp b/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp index 569b811e5f4..172887a48ec 100644 --- a/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp +++ b/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp @@ -191,6 +191,7 @@ unsigned X86ELFObjectWriter::GetRelocType(const MCValue &Target, } break; + case X86::reloc_riprel_4byte: case X86::reloc_signed_4byte: case FK_PCRel_4: case FK_Data_4: diff --git a/test/MC/ELF/relocation-386.s b/test/MC/ELF/relocation-386.s index 83c524b9d07..39abcedba5e 100644 --- a/test/MC/ELF/relocation-386.s +++ b/test/MC/ELF/relocation-386.s @@ -65,6 +65,7 @@ // CHECK-NEXT: 0xA3 R_386_GOTOFF und_symbol 0x0 // Relocation 29 (zed@PLT) is of type R_386_PLT32 and uses the symbol // CHECK-NEXT: 0xA9 R_386_PLT32 zed 0x0 +// CHECK-NEXT: 0xAF R_386_PC32 tr_start 0x0 // CHECK-NEXT: } // CHECK-NEXT: ] @@ -133,6 +134,9 @@ bar2: leal 1 + und_symbol@GOTOFF, %edi movl zed@PLT(%eax), %eax + .code64 + jmpq *tr_start(%rip) + .section zedsec,"awT",@progbits zed: .long 0