forked from OSchip/llvm-project
parent
71af9db0e8
commit
fba9f74932
|
@ -706,6 +706,9 @@ void ELFObjectWriterImpl::RecordRelocation(const MCAssembler &Asm,
|
||||||
switch (Modifier) {
|
switch (Modifier) {
|
||||||
default:
|
default:
|
||||||
llvm_unreachable("Unimplemented");
|
llvm_unreachable("Unimplemented");
|
||||||
|
case MCSymbolRefExpr::VK_GOT:
|
||||||
|
Type = ELF::R_386_GOT32;
|
||||||
|
break;
|
||||||
case MCSymbolRefExpr::VK_GOTOFF:
|
case MCSymbolRefExpr::VK_GOTOFF:
|
||||||
Type = ELF::R_386_GOTOFF;
|
Type = ELF::R_386_GOTOFF;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -36,11 +36,18 @@
|
||||||
// CHECK-NEXT: ('r_type', 10)
|
// CHECK-NEXT: ('r_type', 10)
|
||||||
// CHECK-NEXT: ),
|
// CHECK-NEXT: ),
|
||||||
|
|
||||||
// Relocation 3 (bar3@GOTOFF) is done symbol 6 (bss)
|
// Relocation 3 (bar3@GOTOFF) is done with symbol 6 (bss)
|
||||||
// CHECK-NEXT: # Relocation 3
|
// CHECK-NEXT: # Relocation 3
|
||||||
// CHECK-NEXT: (('r_offset',
|
// CHECK-NEXT: (('r_offset',
|
||||||
// CHECK-NEXT: ('r_sym', 6
|
// CHECK-NEXT: ('r_sym', 6
|
||||||
// CHECK-NEXT: ('r_type',
|
// CHECK-NEXT: ('r_type',
|
||||||
|
// CHECK-NEXT: ),
|
||||||
|
|
||||||
|
// Relocation 4 (bar2@GOT) is of type R_386_GOT32
|
||||||
|
// CHECK-NEXT: # Relocation 4
|
||||||
|
// CHECK-NEXT: (('r_offset',
|
||||||
|
// CHECK-NEXT: ('r_sym',
|
||||||
|
// CHECK-NEXT: ('r_type', 3
|
||||||
// CHECK-NEXT: ),
|
// CHECK-NEXT: ),
|
||||||
|
|
||||||
.text
|
.text
|
||||||
|
@ -57,6 +64,8 @@ bar2:
|
||||||
.local bar3
|
.local bar3
|
||||||
.comm bar3,1,1
|
.comm bar3,1,1
|
||||||
|
|
||||||
|
movl bar2j@GOT(%eax), %eax
|
||||||
|
|
||||||
.section .rodata.str1.16,"aMS",@progbits,1
|
.section .rodata.str1.16,"aMS",@progbits,1
|
||||||
.Lfoo:
|
.Lfoo:
|
||||||
.asciz "bool llvm::llvm_start_multithreaded()"
|
.asciz "bool llvm::llvm_start_multithreaded()"
|
||||||
|
|
Loading…
Reference in New Issue