summaryrefslogtreecommitdiffstats
path: root/lld/test
diff options
context:
space:
mode:
authorGeorge Rimar <grimar@accesssoftek.com>2015-11-25 22:15:01 +0000
committerGeorge Rimar <grimar@accesssoftek.com>2015-11-25 22:15:01 +0000
commit77b7779b4841fc7ae23c99c98e76e14d49242bc4 (patch)
tree7936f266216ae9f1304b6114684a5db4324f7dce /lld/test
parentd9b42188314df597558baf719218d2d0cd332905 (diff)
downloadbcm5719-llvm-77b7779b4841fc7ae23c99c98e76e14d49242bc4.tar.gz
bcm5719-llvm-77b7779b4841fc7ae23c99c98e76e14d49242bc4.zip
Reapply r254098.
Fix is (OutputSections.cpp): for (std::pair<const SymbolBody *, size_t> &I : Entries) { => for (std::pair<const SymbolBody *, unsigned> &I : Entries) { llvm-svn: 254105
Diffstat (limited to 'lld/test')
-rw-r--r--lld/test/ELF/plt-i686.s127
-rw-r--r--lld/test/ELF/relocation-i686.s8
2 files changed, 111 insertions, 24 deletions
diff --git a/lld/test/ELF/plt-i686.s b/lld/test/ELF/plt-i686.s
index 3c001d4f313..27ff8d5ce24 100644
--- a/lld/test/ELF/plt-i686.s
+++ b/lld/test/ELF/plt-i686.s
@@ -2,8 +2,12 @@
// RUN: llvm-mc -filetype=obj -triple=i686-unknown-linux %p/Inputs/shared.s -o %t2.o
// RUN: ld.lld -shared %t2.o -o %t2.so
// RUN: ld.lld %t.o %t2.so -o %t
-// RUN: llvm-readobj -s -r %t | FileCheck %s
+// RUN: llvm-readobj -s -r %t | FileCheck --check-prefix=CHECK %s
// RUN: llvm-objdump -d %t | FileCheck --check-prefix=DISASM %s
+// RUN: ld.lld -shared %t.o %t2.so -o %t
+// RUN: llvm-readobj -s -r %t | FileCheck --check-prefix=CHECKSHARED %s
+// RUN: llvm-objdump -d %t | FileCheck --check-prefix=DISASMSHARED %s
+
// REQUIRES: x86
// CHECK: Name: .plt
@@ -14,41 +18,124 @@
// CHECK-NEXT: ]
// CHECK-NEXT: Address: 0x11010
// CHECK-NEXT: Offset:
-// CHECK-NEXT: Size: 16
+// CHECK-NEXT: Size: 48
// CHECK-NEXT: Link: 0
// CHECK-NEXT: Info: 0
// CHECK-NEXT: AddressAlignment: 16
+// CHECK: Name: .got.plt
+// CHECK-NEXT: Type: SHT_PROGBITS
+// CHECK-NEXT: Flags [
+// CHECK-NEXT: SHF_ALLOC
+// CHECK-NEXT: SHF_WRITE
+// CHECK-NEXT: ]
+// CHECK-NEXT: Address: 0x12058
+// CHECK-NEXT: Offset: 0x2058
+// CHECK-NEXT: Size: 20
+// CHECK-NEXT: Link: 0
+// CHECK-NEXT: Info: 0
+// CHECK-NEXT: AddressAlignment: 4
+// CHECK-NEXT: EntrySize: 0
+
+// 0x12058 + got.plt.reserved(12) = 0x12064
+// 0x12058 + got.plt.reserved(12) + 4 = 0x12068
// CHECK: Relocations [
-// CHECK-NEXT: Section ({{.*}}) .rel.dyn {
-// CHECK-NEXT: 0x12050 R_386_GLOB_DAT bar 0x0
-// CHECK-NEXT: 0x12054 R_386_GLOB_DAT zed 0x0
+// CHECK-NEXT: Section ({{.*}}) .rel.plt {
+// CHECK-NEXT: 0x12064 R_386_JUMP_SLOT bar 0x0
+// CHECK-NEXT: 0x12068 R_386_JUMP_SLOT zed 0x0
// CHECK-NEXT: }
// CHECK-NEXT: ]
// Unfortunately FileCheck can't do math, so we have to check for explicit
// values:
-// 0x11010 - (0x11000 + 1) - 4 = 11
-// 0x11010 - (0x11005 + 1) - 4 = 2
-// 0x11018 - (0x1100a + 1) - 4 = 9
+// 16 is the size of PLT[0]
+// (0x11010 + 16) - (0x11000 + 1) - 4 = 27
+// (0x11010 + 16) - (0x11005 + 1) - 4 = 22
+// (0x11020 + 16) - (0x1100a + 1) - 4 = 33
// DISASM: _start:
-// DISASM-NEXT: 11000: e9 0b 00 00 00 jmp 11
-// DISASM-NEXT: 11005: e9 06 00 00 00 jmp 6
-// DISASM-NEXT: 1100a: e9 09 00 00 00 jmp 9
-
-// 0x12050 = 73808
-// 0x12054 = 73812
+// DISASM-NEXT: 11000: e9 1b 00 00 00 jmp 27
+// DISASM-NEXT: 11005: e9 16 00 00 00 jmp 22
+// DISASM-NEXT: 1100a: e9 21 00 00 00 jmp 33
+// 0x11010 - 0x1102b - 5 = -32
+// 0x11010 - 0x1103b - 5 = -48
+// 73820 = 0x1205C = .got.plt (0x12058) + 4
+// 73824 = 0x12060 = .got.plt (0x12058) + 8
+// 73828 = 0x12064 = .got.plt (0x12058) + got.plt.reserved(12)
+// 73832 = 0x12068 = .got.plt (0x12058) + got.plt.reserved(12) + 4
// DISASM: Disassembly of section .plt:
// DISASM-NEXT: .plt:
-// DISASM-NEXT: 11010: ff 25 {{.*}} jmpl *73808
-// DISASM-NEXT: 11016: 90 nop
-// DISASM-NEXT: 11017: 90 nop
-// DISASM-NEXT: 11018: ff 25 {{.*}} jmpl *73812
-// DISASM-NEXT: 1101e: 90 nop
-// DISASM-NEXT: 1101f: 90 nop
+// DISASM-NEXT: 11010: ff 35 5c 20 01 00 pushl 73820
+// DISASM-NEXT: 11016: ff 25 60 20 01 00 jmpl *73824
+// DISASM-NEXT: 1101c: 90 nop
+// DISASM-NEXT: 1101d: 90 nop
+// DISASM-NEXT: 1101e: 90 nop
+// DISASM-NEXT: 1101f: 90 nop
+// DISASM-NEXT: 11020: ff 25 64 20 01 00 jmpl *73828
+// DISASM-NEXT: 11026: 68 00 00 00 00 pushl $0
+// DISASM-NEXT: 1102b: e9 e0 ff ff ff jmp -32 <.plt>
+// DISASM-NEXT: 11030: ff 25 68 20 01 00 jmpl *73832
+// DISASM-NEXT: 11036: 68 08 00 00 00 pushl $8
+// DISASM-NEXT: 1103b: e9 d0 ff ff ff jmp -48 <.plt>
+
+// CHECKSHARED: Name: .plt
+// CHECKSHARED-NEXT: Type: SHT_PROGBITS
+// CHECKSHARED-NEXT: Flags [
+// CHECKSHARED-NEXT: SHF_ALLOC
+// CHECKSHARED-NEXT: SHF_EXECINSTR
+// CHECKSHARED-NEXT: ]
+// CHECKSHARED-NEXT: Address: 0x1010
+// CHECKSHARED-NEXT: Offset: 0x1010
+// CHECKSHARED-NEXT: Size: 48
+// CHECKSHARED-NEXT: Link: 0
+// CHECKSHARED-NEXT: Info: 0
+// CHECKSHARED-NEXT: AddressAlignment: 16
+// CHECKSHARED-NEXT: EntrySize: 0
+// CHECKSHARED-NEXT: }
+// CHECKSHARED: Name: .got.plt
+// CHECKSHARED-NEXT: Type: SHT_PROGBITS
+// CHECKSHARED-NEXT: Flags [
+// CHECKSHARED-NEXT: SHF_ALLOC
+// CHECKSHARED-NEXT: SHF_WRITE
+// CHECKSHARED-NEXT: ]
+// CHECKSHARED-NEXT: Address: 0x2058
+// CHECKSHARED-NEXT: Offset: 0x2058
+// CHECKSHARED-NEXT: Size: 20
+// CHECKSHARED-NEXT: Link: 0
+// CHECKSHARED-NEXT: Info: 0
+// CHECKSHARED-NEXT: AddressAlignment: 4
+// CHECKSHARED-NEXT: EntrySize: 0
+// CHECKSHARED-NEXT: }
+
+// 0x2058 + got.plt.reserved(12) = 0x2064
+// 0x2058 + got.plt.reserved(12) + 4 = 0x2068
+// CHECKSHARED: Relocations [
+// CHECKSHARED-NEXT: Section ({{.*}}) .rel.plt {
+// CHECKSHARED-NEXT: 0x2064 R_386_JUMP_SLOT bar 0x0
+// CHECKSHARED-NEXT: 0x2068 R_386_JUMP_SLOT zed 0x0
+// CHECKSHARED-NEXT: }
+// CHECKSHARED-NEXT: ]
+
+// DISASMSHARED: _start:
+// DISASMSHARED-NEXT: 1000: e9 1b 00 00 00 jmp 27
+// DISASMSHARED-NEXT: 1005: e9 16 00 00 00 jmp 22
+// DISASMSHARED-NEXT: 100a: e9 21 00 00 00 jmp 33
+// DISASMSHARED-NEXT: Disassembly of section .plt:
+// DISASMSHARED-NEXT: .plt:
+// DISASMSHARED-NEXT: 1010: ff b3 04 00 00 00 pushl 4(%ebx)
+// DISASMSHARED-NEXT: 1016: ff a3 08 00 00 00 jmpl *8(%ebx)
+// DISASMSHARED-NEXT: 101c: 90 nop
+// DISASMSHARED-NEXT: 101d: 90 nop
+// DISASMSHARED-NEXT: 101e: 90 nop
+// DISASMSHARED-NEXT: 101f: 90 nop
+// DISASMSHARED-NEXT: 1020: ff a3 0c 00 00 00 jmpl *12(%ebx)
+// DISASMSHARED-NEXT: 1026: 68 00 00 00 00 pushl $0
+// DISASMSHARED-NEXT: 102b: e9 e0 ff ff ff jmp -32 <.plt>
+// DISASMSHARED-NEXT: 1030: ff a3 10 00 00 00 jmpl *16(%ebx)
+// DISASMSHARED: 1036: 68 08 00 00 00 pushl $8
+// DISASMSHARED: 103b: e9 d0 ff ff ff jmp -48 <.plt>
.global _start
_start:
diff --git a/lld/test/ELF/relocation-i686.s b/lld/test/ELF/relocation-i686.s
index d4f6d8cd4f6..f66cad20a07 100644
--- a/lld/test/ELF/relocation-i686.s
+++ b/lld/test/ELF/relocation-i686.s
@@ -47,7 +47,7 @@ movl bar@GOT, %eax
// ADDR-NEXT: ]
// ADDR-NEXT: Address: 0x11030
// ADDR-NEXT: Offset: 0x1030
-// ADDR-NEXT: Size: 8
+// ADDR-NEXT: Size: 32
// ADDR: Name: .got
// ADDR-NEXT: Type: SHT_PROGBITS
@@ -55,7 +55,7 @@ movl bar@GOT, %eax
// ADDR-NEXT: SHF_ALLOC
// ADDR-NEXT: SHF_WRITE
// ADDR-NEXT: ]
-// ADDR-NEXT: Address: 0x12050
+// ADDR-NEXT: Address: 0x12070
.section .R_386_GOTPC,"ax",@progbits
R_386_GOTPC:
@@ -65,14 +65,14 @@ R_386_GOTPC:
// CHECK: Disassembly of section .R_386_GOTPC:
// CHECK-NEXT: R_386_GOTPC:
-// CHECK-NEXT: 11014: {{.*}} movl $4156, %eax
+// CHECK-NEXT: 11014: {{.*}} movl $4188, %eax
.section .dynamic_reloc, "ax",@progbits
call bar
// 0x11030 - (0x11019 + 5) = 18
// CHECK: Disassembly of section .dynamic_reloc:
// CHECK-NEXT: .dynamic_reloc:
-// CHECK-NEXT: 11019: e8 12 00 00 00 calll 18
+// CHECK-NEXT: 11019: e8 22 00 00 00 calll 34
.section .R_386_GOT32,"ax",@progbits
.global R_386_GOT32
OpenPOWER on IntegriCloud