2015-11-26 04:41:53 +08:00
|
|
|
// REQUIRES: x86
|
|
|
|
// RUN: llvm-mc -filetype=obj -triple=i686-pc-linux %s -o %t
|
|
|
|
// RUN: ld.lld %t -o %tout
|
2017-10-06 17:37:44 +08:00
|
|
|
// RUN: ld.lld --hash-style=sysv %t -shared -o %tsharedout
|
2015-11-26 04:41:53 +08:00
|
|
|
// RUN: llvm-objdump -d %tout | FileCheck %s --check-prefix=DIS
|
|
|
|
// RUN: llvm-readobj -r %tout | FileCheck %s --check-prefix=RELOC
|
|
|
|
// RUN: llvm-objdump -d %tsharedout | FileCheck %s --check-prefix=DISSHARED
|
|
|
|
// RUN: llvm-readobj -r %tsharedout | FileCheck %s --check-prefix=RELOCSHARED
|
|
|
|
|
|
|
|
.section ".tdata", "awT", @progbits
|
|
|
|
.globl var
|
|
|
|
.globl var1
|
|
|
|
var:
|
|
|
|
.long 0
|
|
|
|
var1:
|
|
|
|
.long 1
|
|
|
|
|
2016-04-30 08:49:10 +08:00
|
|
|
.section test, "awx"
|
2015-11-26 04:41:53 +08:00
|
|
|
.global _start
|
|
|
|
_start:
|
|
|
|
movl $var@tpoff, %edx
|
|
|
|
movl %gs:0, %ecx
|
|
|
|
subl %edx, %eax
|
|
|
|
movl $var1@tpoff, %edx
|
|
|
|
movl %gs:0, %ecx
|
|
|
|
subl %edx, %eax
|
|
|
|
|
|
|
|
movl %gs:0, %ecx
|
|
|
|
leal var@ntpoff(%ecx), %eax
|
|
|
|
movl %gs:0, %ecx
|
2016-08-20 18:54:51 +08:00
|
|
|
leal var1@ntpoff+123(%ecx), %eax
|
2015-11-26 04:41:53 +08:00
|
|
|
|
2016-04-30 08:49:10 +08:00
|
|
|
// DIS: Disassembly of section test:
|
2015-11-26 04:41:53 +08:00
|
|
|
// DIS-NEXT: _start:
|
Align AArch64 and i386 image base to superpage
Summary:
As for x86_64, the default image base for AArch64 and i386 should be
aligned to a superpage appropriate for the architecture.
On AArch64, this is 2 MiB, on i386 it is 4 MiB.
Reviewers: emaste, grimar, javed.absar, espindola, ruiu, peter.smith, srhines, rprichard
Reviewed By: ruiu, peter.smith
Subscribers: jfb, markj, arichardson, krytarowski, kristof.beyls, llvm-commits
Differential Revision: https://reviews.llvm.org/D50297
llvm-svn: 342746
2018-09-22 00:58:13 +08:00
|
|
|
// DIS-NEXT: 401000: ba 08 00 00 00 movl $8, %edx
|
|
|
|
// DIS-NEXT: 401005: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DIS-NEXT: 40100c: 29 d0 subl %edx, %eax
|
|
|
|
// DIS-NEXT: 40100e: ba 04 00 00 00 movl $4, %edx
|
|
|
|
// DIS-NEXT: 401013: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DIS-NEXT: 40101a: 29 d0 subl %edx, %eax
|
|
|
|
// DIS-NEXT: 40101c: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DIS-NEXT: 401023: 8d 81 f8 ff ff ff leal -8(%ecx), %eax
|
|
|
|
// DIS-NEXT: 401029: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DIS-NEXT: 401030: 8d 81 77 00 00 00 leal 119(%ecx), %eax
|
2015-11-26 04:41:53 +08:00
|
|
|
|
|
|
|
// RELOC: Relocations [
|
|
|
|
// RELOC-NEXT: ]
|
|
|
|
|
2016-04-30 08:49:10 +08:00
|
|
|
// DISSHARED: Disassembly of section test:
|
2015-11-26 04:41:53 +08:00
|
|
|
// DISSHARED-NEXT: _start:
|
2017-05-27 01:23:25 +08:00
|
|
|
// DISSHARED-NEXT: 1000: ba 00 00 00 00 movl $0, %edx
|
|
|
|
// DISSHARED-NEXT: 1005: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DISSHARED-NEXT: 100c: 29 d0 subl %edx, %eax
|
|
|
|
// DISSHARED-NEXT: 100e: ba 00 00 00 00 movl $0, %edx
|
|
|
|
// DISSHARED-NEXT: 1013: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DISSHARED-NEXT: 101a: 29 d0 subl %edx, %eax
|
|
|
|
// DISSHARED-NEXT: 101c: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DISSHARED-NEXT: 1023: 8d 81 00 00 00 00 leal (%ecx), %eax
|
|
|
|
// DISSHARED-NEXT: 1029: 65 8b 0d 00 00 00 00 movl %gs:0, %ecx
|
|
|
|
// DISSHARED-NEXT: 1030: 8d 81 7b 00 00 00 leal 123(%ecx), %eax
|
2015-11-26 04:41:53 +08:00
|
|
|
|
|
|
|
// RELOCSHARED: Relocations [
|
|
|
|
// RELOCSHARED-NEXT: Section (4) .rel.dyn {
|
2017-05-27 01:23:25 +08:00
|
|
|
// RELOCSHARED-NEXT: 0x1001 R_386_TLS_TPOFF32 var 0x0
|
|
|
|
// RELOCSHARED-NEXT: 0x1025 R_386_TLS_TPOFF var 0x0
|
|
|
|
// RELOCSHARED-NEXT: 0x100F R_386_TLS_TPOFF32 var1 0x0
|
|
|
|
// RELOCSHARED-NEXT: 0x1032 R_386_TLS_TPOFF var1 0x0
|
2015-11-26 04:41:53 +08:00
|
|
|
// RELOCSHARED-NEXT: }
|
|
|
|
// RELOCSHARED-NEXT: ]
|