[lld] 4007756 - [ELF][test] Improve data-segment-relro.test
Fangrui Song via llvm-commits
llvm-commits at lists.llvm.org
Thu Apr 28 22:29:43 PDT 2022
Author: Fangrui Song
Date: 2022-04-28T22:29:39-07:00
New Revision: 400775649969b9baf3bc2a510266e7912bb16ae9
URL: https://github.com/llvm/llvm-project/commit/400775649969b9baf3bc2a510266e7912bb16ae9
DIFF: https://github.com/llvm/llvm-project/commit/400775649969b9baf3bc2a510266e7912bb16ae9.diff
LOG: [ELF][test] Improve data-segment-relro.test
Added:
Modified:
lld/test/ELF/linkerscript/data-segment-relro.test
Removed:
lld/test/ELF/linkerscript/Inputs/data-segment-relro.s
################################################################################
diff --git a/lld/test/ELF/linkerscript/Inputs/data-segment-relro.s b/lld/test/ELF/linkerscript/Inputs/data-segment-relro.s
deleted file mode 100644
index 668a2e2ca2a4a..0000000000000
--- a/lld/test/ELF/linkerscript/Inputs/data-segment-relro.s
+++ /dev/null
@@ -1,11 +0,0 @@
-.global _start
-_start:
- .long bar
- jmp *bar2 at GOTPCREL(%rip)
-
-.section .data,"aw"
-.quad 0
-
-.zero 4
-.section .foo,"aw"
-.section .bss,"", at nobits
diff --git a/lld/test/ELF/linkerscript/data-segment-relro.test b/lld/test/ELF/linkerscript/data-segment-relro.test
index a74cb4ae49a21..bc24ad48d932e 100644
--- a/lld/test/ELF/linkerscript/data-segment-relro.test
+++ b/lld/test/ELF/linkerscript/data-segment-relro.test
@@ -1,17 +1,62 @@
# REQUIRES: x86
-# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %p/Inputs/data-segment-relro.s -o %t1.o
-# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %p/Inputs/shared.s -o %t2.o
-# RUN: ld.lld -shared %t2.o -o %t2.so
+# RUN: rm -rf %t && split-file %s %t
+# RUN: llvm-mc -filetype=obj -triple=x86_64 %t/a.s -o %t/a.o
+# RUN: llvm-mc -filetype=obj -triple=x86_64 %p/Inputs/shared.s -o %t/b.o
+# RUN: ld.lld -shared -soname=b %t/b.o -o %t/b.so
## With relro or without DATA_SEGMENT_RELRO_END just aligns to
## page boundary.
-# RUN: ld.lld --hash-style=sysv -z norelro %t1.o %t2.so --script %s -o %t
-# RUN: llvm-readobj -S %t | FileCheck %s
+# RUN: ld.lld --hash-style=sysv -z norelro %t/a.o %t/b.so -T %t/1.t -o %t/a1
+# RUN: llvm-readelf -S -l %t/a1 | FileCheck %s --check-prefixes=CHECK,CHECK1
-# RUN: ld.lld --hash-style=sysv -z relro %t1.o %t2.so --script %s -o %t2
-# RUN: llvm-readobj -S %t2 | FileCheck %s
+# RUN: ld.lld --hash-style=sysv -z relro %t/a.o %t/b.so -T %t/1.t -o %t/a2
+# RUN: llvm-readelf -S -l %t/a2 | FileCheck %s --check-prefixes=CHECK,CHECK2
+# CHECK: Name Type Address Off Size ES Flg
+# CHECK-NEXT: NULL {{.*}}
+# CHECK: .dynamic DYNAMIC 0000000000001000 001000 0000f0 10 WA
+# CHECK-NEXT: .got PROGBITS 00000000000010f0 0010f0 000008 00 WA
+# CHECK-NEXT: __libc_atexit PROGBITS 0000000000002000 002000 000008 00 WA
+# CHECK-NEXT: .got.plt PROGBITS 0000000000002008 002008 000020 00 WA
+
+# CHECK1: Program Headers:
+# CHECK1-NOT: GNU_RELRO
+
+# CHECK2: Program Headers:
+# CHECK2-NEXT: Type
+# CHECK2-NEXT: PHDR
+# CHECK2-NEXT: LOAD
+# CHECK2-NEXT: LOAD
+# CHECK2-NEXT: LOAD
+# CHECK2-NEXT: LOAD
+# CHECK2-NEXT: DYNAMIC
+# CHECK2-NEXT: GNU_RELRO
+# CHECK2-NEXT: GNU_STACK
+
+# CHECK2: Section to Segment mapping:
+# CHECK2: 06 .dynamic .got {{$}}
+
+# RUN: sed '/DATA_SEGMENT_RELRO_END/d' %t/1.t > %t/2.t
+# RUN: ld.lld %t/a.o %t/b.so -T %t/2.t -o /dev/null
+
+#--- a.s
+.global _start
+_start:
+ .long bar
+ jmp *bar2 at GOTPCREL(%rip)
+
+.section .data,"aw"
+.quad 0
+
+.zero 4
+.section .foo,"aw"
+.section .bss,"", at nobits
+
+.section __libc_atexit,"aw", at progbits
+.dc.a __libc_atexit
+
+#--- 1.t
SECTIONS {
. = SIZEOF_HEADERS;
@@ -25,42 +70,12 @@ SECTIONS {
. = DATA_SEGMENT_RELRO_END (1 ? 24 : 0, .);
+ __libc_atexit : { *(__libc_atexit) }
.got.plt : { *(.got.plt) }
.data : { *(.data) }
.bss : { *(.bss) }
. = DATA_SEGMENT_END (.);
-}
-# CHECK: Section {
-# CHECK: Index:
-# CHECK: Name: .got
-# CHECK-NEXT: Type: SHT_PROGBITS
-# CHECK-NEXT: Flags [
-# CHECK-NEXT: SHF_ALLOC
-# CHECK-NEXT: SHF_WRITE
-# CHECK-NEXT: ]
-# CHECK-NEXT: Address: 0x10F0
-# CHECK-NEXT: Offset: 0x10F0
-# CHECK-NEXT: Size:
-# CHECK-NEXT: Link:
-# CHECK-NEXT: Info:
-# CHECK-NEXT: AddressAlignment:
-# CHECK-NEXT: EntrySize:
-# CHECK-NEXT: }
-# CHECK-NEXT: Section {
-# CHECK-NEXT: Index:
-# CHECK-NEXT: Name: .got.plt
-# CHECK-NEXT: Type: SHT_PROGBITS
-# CHECK-NEXT: Flags [
-# CHECK-NEXT: SHF_ALLOC
-# CHECK-NEXT: SHF_WRITE
-# CHECK-NEXT: ]
-# CHECK-NEXT: Address: 0x2000
-# CHECK-NEXT: Offset: 0x2000
-# CHECK-NEXT: Size:
-# CHECK-NEXT: Link:
-# CHECK-NEXT: Info:
-# CHECK-NEXT: AddressAlignment:
-# CHECK-NEXT: EntrySize:
-# CHECK-NEXT: }
+ .comment 0 : { *(.comment) }
+}
More information about the llvm-commits
mailing list