diff options
-rw-r--r-- | lld/ELF/Writer.cpp | 2 | ||||
-rw-r--r-- | lld/test/ELF/relro.s | 7 |
2 files changed, 6 insertions, 3 deletions
diff --git a/lld/ELF/Writer.cpp b/lld/ELF/Writer.cpp index c7ed590dfe7..f0563c43bcd 100644 --- a/lld/ELF/Writer.cpp +++ b/lld/ELF/Writer.cpp @@ -500,7 +500,7 @@ template <class ELFT> bool elf::isRelroSection(const OutputSectionBase *Sec) { return true; StringRef S = Sec->getName(); return S == ".data.rel.ro" || S == ".ctors" || S == ".dtors" || S == ".jcr" || - S == ".eh_frame"; + S == ".eh_frame" || S == ".openbsd.randomdata"; } template <class ELFT> diff --git a/lld/test/ELF/relro.s b/lld/test/ELF/relro.s index 5dbf8975d6e..b21e514303a 100644 --- a/lld/test/ELF/relro.s +++ b/lld/test/ELF/relro.s @@ -19,8 +19,8 @@ // CHECK-NEXT: GNU_RELRO // CHECK: Section to Segment mapping: -// FULLRELRO: 05 .dynamic .got .got.plt {{$}} -// PARTRELRO: 05 .dynamic .got {{$}} +// FULLRELRO: 05 .openbsd.randomdata .dynamic .got .got.plt {{$}} +// PARTRELRO: 05 .openbsd.randomdata .dynamic .got {{$}} // NORELRO-NOT: GNU_RELRO @@ -36,3 +36,6 @@ _start: .zero 4 .section .foo,"aw" .section .bss,"",@nobits + +.section .openbsd.randomdata, "aw" +.quad 0 |