X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=ld%2Ftestsuite%2Fld-i386%2Fi386.exp;h=8fe047bba0c0da572552f26b0ffef31ee12b295a;hb=8493b6651af3d2130d5f5f050905cd3d6e8a9c27;hp=d30f9fb53b4528cbaf7d2f0aeab6fa805e3e6aa3;hpb=b1058ce98878654d8c19b7b6741d84615795b9a1;p=deliverable%2Fbinutils-gdb.git diff --git a/ld/testsuite/ld-i386/i386.exp b/ld/testsuite/ld-i386/i386.exp index d30f9fb53b..8fe047bba0 100644 --- a/ld/testsuite/ld-i386/i386.exp +++ b/ld/testsuite/ld-i386/i386.exp @@ -1,5 +1,5 @@ # Expect script for ld-i386 tests -# Copyright (C) 2002-2016 Free Software Foundation, Inc. +# Copyright (C) 2002-2019 Free Software Foundation, Inc. # # This file is part of the GNU Binutils. # @@ -19,28 +19,36 @@ # MA 02110-1301, USA. # +global ASFLAGS +set saved_ASFLAGS "$ASFLAGS" +if { [is_elf_format] \ + && ([istarget "i?86-*-*"] || [istarget "x86_64-*-*"]) } { + set ASFLAGS "$ASFLAGS -mx86-used-note=no" +} + # Test i386 linking; all types of relocs. This tests the assembler and # tools like objdump as well as the linker. if {[istarget "i?86-*-vxworks"]} { set i386tests { - {"VxWorks shared library test 1" "-shared -Tvxworks1.ld" "" + {"VxWorks shared library test 1" + "-shared -Tvxworks1.ld --hash-style=sysv" "" "" {vxworks1-lib.s} {{readelf --relocs vxworks1-lib.rd} {objdump -dr vxworks1-lib.dd} {readelf --symbols vxworks1-lib.nd} {readelf -d vxworks1-lib.td}} "libvxworks1.so"} {"VxWorks executable test 1 (dynamic)" \ - "tmpdir/libvxworks1.so -Tvxworks1.ld -q --force-dynamic" "" + "tmpdir/libvxworks1.so -Tvxworks1.ld --hash-style=sysv -q --force-dynamic" "" "" {vxworks1.s} {{readelf --relocs vxworks1.rd} {objdump -dr vxworks1.dd}} "vxworks1"} {"VxWorks executable test 2 (dynamic)" \ - "-Tvxworks1.ld -q --force-dynamic" "" + "-Tvxworks1.ld --hash-style=sysv -q --force-dynamic" "" "" {vxworks2.s} {{readelf --segments vxworks2.sd}} "vxworks2"} {"VxWorks executable test 2 (static)" - "-Tvxworks1.ld" "" + "-Tvxworks1.ld --hash-style=sysv" "" "" {vxworks2.s} {{readelf --segments vxworks2-static.sd}} "vxworks2"} @@ -98,11 +106,10 @@ if [istarget "*-*-go32*"] { } if { !([istarget "i?86-*-elf*"] - || (([istarget "i?86-*-linux*"] - || [istarget "i?86-*-gnu*"]) - && ![istarget "*-*-*aout*"] - && ![istarget "*-*-*oldld*"]) + || [istarget "i?86-*-linux*"] + || [istarget "i?86-*-gnu*"] || [istarget "i?86-*-nacl*"] + || [istarget "x86_64-*-elf*"] || [istarget "x86_64-*-nacl*"] || [istarget "x86_64-*-linux*"] || [istarget "amd64-*-linux*"]) } { @@ -128,13 +135,23 @@ set i386tests { "-shared -melf_i386 tmpdir/libpltlib.so" "" "--32" {plt-pic.s} {{objdump -drj.plt plt-pic.pd}} "libplt-pic.so"} {"TLS -fpic -shared transitions" - "-shared -melf_i386 --no-ld-generated-unwind-info" "" + "-shared -melf_i386 --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" "--32" {tlspic1.s tlspic2.s} {{readelf -Ssrl tlspic.rd} {objdump -drj.text tlspic.dd} {objdump -sj.got tlspic.sd} {objdump -sj.tdata tlspic.td}} "libtlspic.so"} + {"TLS -fpic -shared transitions without PLT" + "-shared -melf_i386 --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" + "-mrelax-relocations=yes --32" + {tlspic3.s tlspic2.s} + {{readelf -Ssrl tlspic2.rd} {objdump -drj.text tlspic2.dd} + {objdump -sj.got tlspic2.sd} {objdump -sj.tdata tlspic2.td}} + "libtlspic2.so"} {"TLS descriptor -fpic -shared transitions" - "-shared -melf_i386 --no-ld-generated-unwind-info" "" + "-shared -melf_i386 --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" "--32" {tlsdesc.s tlspic2.s} {{readelf -Ssrl tlsdesc.rd} {objdump -drj.text tlsdesc.dd} {objdump "-s -j.got -j.got.plt" tlsdesc.sd} {objdump -sj.tdata tlsdesc.td}} @@ -142,24 +159,36 @@ set i386tests { {"Helper shared library" "-shared -melf_i386" "" "--32" {tlslib.s} {} "libtlslib.so"} {"TLS -fpic and -fno-pic exec transitions" - "-melf_i386 tmpdir/libtlslib.so --no-ld-generated-unwind-info" "" + "-melf_i386 tmpdir/libtlslib.so --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" "--32" {tlsbinpic.s tlsbin.s} {{readelf -Ssrl tlsbin.rd} {objdump -drj.text tlsbin.dd} {objdump -sj.got tlsbin.sd} {objdump -sj.tdata tlsbin.td}} "tlsbin"} + {"TLS -fpic and -fno-pic exec transitions without PLT" + "-melf_i386 tmpdir/libtlslib.so --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" + "-mrelax-relocations=yes --32" + {tlsbinpic2.s tlsbin.s} + {{readelf -Ssrl tlsbin2.rd} {objdump -drj.text tlsbin2.dd} + {objdump -sj.got tlsbin2.sd} {objdump -sj.tdata tlsbin2.td}} + "tlsbin2"} {"TLS descriptor -fpic and -fno-pic exec transitions" - "-melf_i386 tmpdir/libtlslib.so --no-ld-generated-unwind-info" "" + "-melf_i386 tmpdir/libtlslib.so --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" "--32" {tlsbindesc.s tlsbin.s} {{readelf -Ssrl tlsbindesc.rd} {objdump -drj.text tlsbindesc.dd} {objdump -sj.got tlsbindesc.sd} {objdump -sj.tdata tlsbindesc.td}} "tlsbindesc"} {"TLS -fno-pic -shared" - "-shared -melf_i386 --no-ld-generated-unwind-info" "" + "-shared -melf_i386 --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" "--32" {tlsnopic1.s tlsnopic2.s} {{readelf -Ssrl tlsnopic.rd} {objdump -drj.text tlsnopic.dd} {objdump -sj.got tlsnopic.sd}} "libtlsnopic.so"} {"TLS with global dynamic and descriptors" - "-shared -melf_i386 --no-ld-generated-unwind-info" "" + "-shared -melf_i386 --no-ld-generated-unwind-info \ + -z noseparate-code --hash-style=sysv" "" "--32" {tlsgdesc.s} {{readelf -Ssrl tlsgdesc.rd} {objdump -drj.text tlsgdesc.dd}} "libtlsgdesc.so"} @@ -177,32 +206,44 @@ set i386tests { {"TLS GD->LE transition" "-melf_i386" "" "--32" {tlsgd1.s} {{objdump -dwr tlsgd1.dd}} "tlsgd1"} + {"TLS GD->LE transition without PLT" "-melf_i386" "" + "-mrelax-relocations=yes --32" + {tlsgd3.s} + {{objdump -dwr tlsgd3.dd}} "tlsgd3"} {"TLS LD->LE transition" "-melf_i386" "" "--32" {tlsld1.s} {{objdump -dwr tlsld1.dd}} "tlsld1"} + {"TLS LD->LE transition without PLT" "-melf_i386" "" + "-mrelax-relocations=yes --32" + {tlsld2.s} + {{objdump -dwr tlsld2.dd}} "tlsld2"} {"TLS IE->LE transition" "-melf_i386" "" "--32" {tlsie1.s} {{objdump -dwr tlsie1.dd}} "tlsie1"} {"PR ld/17313 (1)" "-melf_i386" "" - "--32" {zero.s} {} ""} + "--32 -mx86-used-note=yes" {zero.s} {} ""} {"PR ld/17313 (2)" "-melf_i386 -shared --just-symbols=tmpdir/zero.o" "" - "--32" {lea1.s} {} "libpr17313.so"} + "--32 -mx86-used-note=yes" {lea1.s} {} "libpr17313.so"} {"PR ld/17306 (1)" "-melf_i386" "" - "--32" {pr17306b.s} {} ""} + "--32 -mx86-used-note=yes" {pr17306b.s} {} ""} {"PR ld/17306 (2)" "-melf_i386 -shared -Bsymbolic --just-symbols=tmpdir/pr17306b.o" "" - "--32" {pr17306a.s} {} "libpr17306.so"} + "--32 -mx86-used-note=yes" {pr17306a.s} {} "libpr17306.so"} {"PR ld/17709 (1)" "-melf_i386 -shared" "" - "--32" {pr17709a.s} {} "libpr17709.so"} + "--32 -mx86-used-note=yes" {pr17709a.s} {} "libpr17709.so"} {"PR ld/17709 (2)" "-melf_i386 tmpdir/libpr17709.so" "" - "--32" {pr17709b.s} {{readelf -r pr17709.rd}} "pr17709"} + "--32 -mx86-used-note=yes" + {pr17709b.s} {{readelf -r pr17709.rd}} "pr17709"} {"Build pr19827a.o" "" "" - "--32" { pr19827a.S }} + "--32 -mx86-used-note=yes" { pr19827a.S }} {"Build pr19827b.so" "-melf_i386 -shared" "" - "--32" { pr19827b.S } {} "pr19827b.so"} + "--32 -mx86-used-note=yes" + { pr19827b.S } {} "pr19827b.so"} {"Build pr19827" "-melf_i386 -pie tmpdir/pr19827a.o tmpdir/pr19827b.so" "" - "--32" { dummy.s } {{readelf {-rW} pr19827.rd}} "pr19827"} + "--32 -mx86-used-note=yes" + { dummy.s } {{readelf {-rW} pr19827.rd}} "pr19827"} {"Build pr19827.so" "-melf_i386 -shared -Bsymbolic" "" - "--32" { pr19827a.S } {{readelf {-rW} pr19827.rd}} "pr19827.so"} + "--32 -mx86-used-note=yes" + { pr19827a.S } {{readelf {-rW} pr19827.rd}} "pr19827.so"} } # So as to avoid rewriting every last test case here in a nacl variant, @@ -270,6 +311,7 @@ run_dump_test "pcrel16abs" run_dump_test "alloc" run_dump_test "warn1" run_dump_test "tlsgd2" +run_dump_test "tlsgd4" run_dump_test "tlsie2" run_dump_test "tlsie3" run_dump_test "tlsie4" @@ -284,8 +326,12 @@ run_dump_test "protected4" run_dump_test "protected5" run_dump_test "protected6a" run_dump_test "protected6b" +run_dump_test "protected7" run_dump_test "tlspie1" run_dump_test "tlspie2" +run_dump_test "tlspie3a" +run_dump_test "tlspie3b" +run_dump_test "tlspie3c" run_dump_test "nogot1" run_dump_test "nogot2" run_dump_test "discarded1" @@ -339,6 +385,9 @@ run_dump_test "pr19636-1f" run_dump_test "pr19636-1g" run_dump_test "pr19636-1h" run_dump_test "pr19636-1i" +run_dump_test "pr19636-1j" +run_dump_test "pr19636-1k" +run_dump_test "pr19636-1l" run_dump_test "pr19636-2a" run_dump_test "pr19636-2b" run_dump_test "pr19636-2c" @@ -346,6 +395,7 @@ run_dump_test "pr19636-2c-nacl" run_dump_test "pr19636-2d" run_dump_test "pr19636-2d-nacl" run_dump_test "pr19636-2e" +run_dump_test "pr19636-2e-nacl" run_dump_test "pr19636-3a" run_dump_test "pr19636-3b" run_dump_test "pr19636-3c" @@ -353,6 +403,8 @@ run_dump_test "pr19636-3d" run_dump_test "pr19636-3e" run_dump_test "pr19636-3f" run_dump_test "pr19636-3g" +run_dump_test "pr19636-3h" +run_dump_test "pr19636-3i" run_dump_test "pr19636-4a" run_dump_test "pr19636-4b" run_dump_test "pr19636-4c" @@ -374,12 +426,83 @@ run_dump_test "undefweaka" run_dump_test "undefweakb" run_dump_test "pr19539" run_dump_test "pr20117" +run_dump_test "pr20244-1a" +run_dump_test "pr20244-1b" +run_dump_test "pr20244-1c" +run_dump_test "pr20244-2a" +run_dump_test "pr20244-2b" +run_dump_test "pr20244-2c" +run_dump_test "pr20244-2d" +run_dump_test "pr20244-4a" +run_dump_test "pr20244-4b" +run_dump_test "pr20244-4c" +run_dump_test "pr20253-3" +run_dump_test "pr20253-4a" +run_dump_test "pr20253-4b" +run_dump_test "pr20253-4c" +run_dump_test "pr20253-5" +run_dump_test "pr20515" +run_dump_test "property-x86-3" +run_dump_test "property-x86-4a" +run_dump_test "property-x86-4b" +run_dump_test "property-x86-5" +run_dump_test "property-x86-ibt1a" +run_dump_test "property-x86-ibt1b" +run_dump_test "property-x86-ibt2" +run_dump_test "property-x86-ibt3a" +run_dump_test "property-x86-ibt3b" +run_dump_test "property-x86-ibt4" +run_dump_test "property-x86-ibt5" +run_dump_test "property-x86-shstk1a" +run_dump_test "property-x86-shstk1b" +run_dump_test "property-x86-shstk2" +run_dump_test "property-x86-shstk3a" +run_dump_test "property-x86-shstk3b" +run_dump_test "property-x86-shstk4" +run_dump_test "property-x86-shstk5" +run_dump_test "property-x86-cet1" +run_dump_test "property-x86-cet2a" +run_dump_test "property-x86-cet2b" +run_dump_test "property-x86-cet3a" +run_dump_test "property-x86-cet3b" +run_dump_test "property-x86-cet4a" +run_dump_test "property-x86-cet4b" +run_dump_test "property-x86-cet5a" +run_dump_test "property-x86-cet5b" +run_dump_test "property-x86-cet6" +run_dump_test "pie1" +run_dump_test "pie1-nacl" +run_dump_test "pr21884" +run_dump_test "pr21884-nacl" +run_dump_test "pr22115-1a" +run_dump_test "pr22115-1b" +run_dump_test "pr22115-1c" +run_dump_test "pr22115-1d" +run_dump_test "pr22135" +run_dump_test "pr22782" +run_dump_test "pr22929" +run_dump_test "pr23189" +run_dump_test "pr23194" +run_dump_test "pr23372a" +run_dump_test "pr23372b" +run_dump_test "pr23372c" +run_dump_test "pr23372d" +run_dump_test "pr23486a" +run_dump_test "pr23486b" +run_dump_test "pr23486c" +run_dump_test "pr23486d" +run_dump_test "pr23854" +run_dump_test "pr23930" +run_dump_test "pr24322a" +run_dump_test "pr24322b" +run_dump_test "align-branch-1" if { !([istarget "i?86-*-linux*"] || [istarget "i?86-*-gnu*"] || [istarget "i?86-*-nacl*"] || [istarget "x86_64-*-nacl*"] || [istarget "x86_64-*-linux*"]) } { + set ASFLAGS "$saved_ASFLAGS" return } @@ -390,10 +513,12 @@ run_dump_test "pr14215" run_dump_test "pr17057" run_dump_test "pr17935-1" run_dump_test "pr17935-2" -run_dump_test "pr18801" +run_dump_test "pr18801a" +run_dump_test "pr18801b" run_dump_test "pr18815" run_dump_test "pr19939a" run_dump_test "pr19939b" +run_dump_test "tlsdesc2" proc undefined_weak {cflags ldflags} { set testname "Undefined weak symbol" @@ -401,8 +526,8 @@ proc undefined_weak {cflags ldflags} { set testname "$testname ($cflags $ldflags)" } - if { [ regexp "\-fPIE" $cflags] - && ![ regexp "\-z nodynamic-undefined-weak" $ldflags] } { + if { [string match "*-fPIE*" $cflags] + && ![string match "*-z nodynamic-undefined-weak*" $ldflags] } { set weak_symbol "Weak defined" } else { set weak_symbol "Weak undefined" @@ -412,7 +537,7 @@ proc undefined_weak {cflags ldflags} { [list \ "Build libpr19704a.so" \ "-shared -Wl,-soname,libpr19704.so" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.s } \ {} \ "libpr19704a.so" \ @@ -420,7 +545,7 @@ proc undefined_weak {cflags ldflags} { [list \ "Build libpr19704b.so" \ "-shared -Wl,-soname,libpr19704.so" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { pr19704b.c } \ {} \ "libpr19704b.so" \ @@ -429,11 +554,11 @@ proc undefined_weak {cflags ldflags} { exec cp tmpdir/libpr19704a.so tmpdir/libpr19704.so - run_ld_link_exec_tests [] [list \ + run_ld_link_exec_tests [list \ [list \ "Run pr19704" \ - "$ldflags tmpdir/libpr19704.so -R tmpdir" \ - "" \ + "$ldflags tmpdir/libpr19704.so -Wl,-R,tmpdir" \ + "-Wa,-mrelax-relocations=yes" \ { pr19704a.c } \ "pr19704" \ "pr19704.out" \ @@ -457,12 +582,12 @@ global PLT_CFLAGS # Must be Linux native with the C compiler if { [isnative] && [istarget "i?86-*-linux*"] - && [which $CC] != 0 } { + && [check_compiler_available] } { run_cc_link_tests [list \ [list \ "Build plt-lib.so" \ "-shared" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { plt-lib.c } \ {} \ "libplt-lib.so" \ @@ -470,7 +595,7 @@ if { [isnative] [list \ "Build libplt-main1.a" \ "" \ - "-fPIC -Wa,-mrelax-relocations=yes" \ + "-fPIC -Wa,-mrelax-relocations=yes,-mrelax-relocations=yes" \ { plt-main1.c } \ {{readelf {-Wr} plt-main1.rd}} \ "libplt-main1.a" \ @@ -478,7 +603,7 @@ if { [isnative] [list \ "Build libplt-main2.a" \ "" \ - "-fPIC -Wa,-mrelax-relocations=yes" \ + "-fPIC -Wa,-mrelax-relocations=yes,-mrelax-relocations=yes" \ { plt-main2.c } \ {{readelf {-Wr} plt-main2.rd}} \ "libplt-main2.a" \ @@ -486,7 +611,7 @@ if { [isnative] [list \ "Build libplt-main3.a" \ "" \ - "-fPIC -Wa,-mrelax-relocations=yes $PLT_CFLAGS" \ + "-fPIC -Wa,-mrelax-relocations=yes,-mrelax-relocations=yes $PLT_CFLAGS" \ { plt-main3.c } \ {{readelf {-Wr} plt-main3.rd}} \ "libplt-main3.a" \ @@ -494,7 +619,7 @@ if { [isnative] [list \ "Build libplt-main4.a" \ "" \ - "-fPIC -Wa,-mrelax-relocations=yes $PLT_CFLAGS" \ + "-fPIC -Wa,-mrelax-relocations=yes,-mrelax-relocations=yes $PLT_CFLAGS" \ { plt-main4.c } \ {{readelf {-Wr} plt-main4.rd}} \ "libplt-main4.a" \ @@ -503,7 +628,7 @@ if { [isnative] "Build plt-main" \ "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { plt-main5.c } \ {{readelf {-Wr} plt-main.rd}} \ "plt-main" \ @@ -512,7 +637,7 @@ if { [isnative] "Build plt-main with PIE" \ "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so -pie" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { plt-main5.c } \ {{readelf {-Wr} plt-main.rd}} \ "plt-main" \ @@ -520,7 +645,7 @@ if { [isnative] [list \ "Build copyreloc-lib.so" \ "-shared" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { copyreloc-lib.c } \ {} \ "copyreloc-lib.so" \ @@ -528,7 +653,7 @@ if { [isnative] [list \ "Build libcopyreloc-main.a" \ "" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { copyreloc-main.S } \ {} \ "libcopyreloc-main.a" \ @@ -536,7 +661,7 @@ if { [isnative] [list \ "Build copyreloc-main with PIE and GOTOFF (1)" \ "tmpdir/copyreloc-main.o tmpdir/copyreloc-lib.so -pie" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.s } \ {{readelf {-Wr} copyreloc-main1.rd}} \ "copyreloc-main" \ @@ -544,7 +669,7 @@ if { [isnative] [list \ "Build copyreloc-main with PIE and GOTOFF (2)" \ "tmpdir/copyreloc-main.o tmpdir/copyreloc-lib.so -pie" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.s } \ {{readelf {-Wr} copyreloc-main2.rd}} \ "copyreloc-main" \ @@ -552,7 +677,7 @@ if { [isnative] [list \ "Build pr17689.so" \ "-shared" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { pr17689a.c } \ {} \ "pr17689.so" \ @@ -560,7 +685,7 @@ if { [isnative] [list \ "Build pr17689.so with -z now" \ "-shared -Wl,-z,now" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { pr17689a.c } \ {{readelf {-Wr} pr17689now.rd}} \ "pr17689now.so" \ @@ -568,7 +693,7 @@ if { [isnative] [list \ "Build pr17689ver.so" \ "-shared -Wl,--version-script,pr17689a.t" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { pr17689a.c } \ {} \ "pr17689ver.so" \ @@ -576,7 +701,7 @@ if { [isnative] [list \ "Build pr17689.a" \ "" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { pr17689b.S } \ {} \ "pr17689.a" \ @@ -584,7 +709,7 @@ if { [isnative] [list \ "Build pr17689 with PIE and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689.so -pie" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.c } \ {{readelf {-Wr} pr17689.rd}} \ "pr17689" \ @@ -592,7 +717,7 @@ if { [isnative] [list \ "Build pr17689 with PIE, -z now and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689.so -pie -Wl,-z,now" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.c } \ {{readelf {-Wr} pr17689now.rd}} \ "pr17689now" \ @@ -600,7 +725,7 @@ if { [isnative] [list \ "Build pr17689ver with PIE and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689ver.so -pie" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.c } \ {{readelf {-Wr} pr17689ver.rd}} \ "pr17689ver" \ @@ -608,7 +733,7 @@ if { [isnative] [list \ "Build pr17827 with PIE and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689.so -pie" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.c } \ {{readelf {-Wr} pr17827.rd}} \ "pr17827" \ @@ -616,7 +741,7 @@ if { [isnative] [list \ "Build pr18900.so" \ "-shared" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { pr18900a.c } \ "" \ "pr18900.so" \ @@ -624,7 +749,7 @@ if { [isnative] [list \ "Build pr18900.o" \ "-r -nostdlib" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { pr18900b.c pr18900c.c } \ "" \ "pr18900.o" \ @@ -632,7 +757,7 @@ if { [isnative] [list \ "Build pr18900a" \ "tmpdir/pr18900.o tmpdir/pr18900.so" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.s } \ {{readelf {-Wrd} pr18900a.rd}} \ "pr18900a" \ @@ -640,7 +765,7 @@ if { [isnative] [list \ "Build pr18900b" \ "-Wl,--as-needed tmpdir/pr18900.o tmpdir/pr18900.so" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { dummy.s } \ {{readelf {-Wrd} pr18900b.rd}} \ "pr18900b" \ @@ -648,7 +773,7 @@ if { [isnative] [list \ "Build pr19031.so" \ "-shared" \ - "-fPIC" \ + "-fPIC -Wa,-mrelax-relocations=yes" \ { pr19031a.c } \ "" \ "pr19031.so" \ @@ -656,7 +781,7 @@ if { [isnative] [list \ "Build got1d.so" \ "-shared" \ - "" \ + "-Wa,-mrelax-relocations=yes" \ { got1d.S } \ "" \ "got1d.so" \ @@ -671,8 +796,8 @@ if { [isnative] ] \ [list \ "Build gotpc1" \ - "-Wl,--as-needed tmpdir/gotpc1.o tmpdir/got1d.so" \ - "" \ + "$NOPIE_LDFLAGS -Wl,--as-needed tmpdir/gotpc1.o tmpdir/got1d.so" \ + "-Wa,-mx86-used-note=no" \ { dummy.s } \ {{objdump {-dw} got1.dd}} \ "got1" \ @@ -680,7 +805,7 @@ if { [isnative] [list \ "Build pr19319.so" \ "-shared" \ - "" \ + "-Wa,-mx86-used-note=no" \ { pr19319a.S } \ "" \ "pr19319.so" \ @@ -693,14 +818,191 @@ if { [isnative] {{objdump {-dw} pr19319.dd}} \ "pr19319" \ ] \ + [list \ + "Build pr24276.so" \ + "-shared -nostdlib -nostartfiles \ + -Ltmpdir $srcdir/$subdir/pr24276.dso" \ + "-Wa,-mx86-used-note=yes" \ + { pr19319b.S } \ + {{warning_output pr24276.warn}} \ + "pr24276.so" \ + ] \ + [list \ + "Build property 1" \ + "" \ + "-Wa,-mx86-used-note=no" \ + {pass.c property-no-copy.S} \ + {{readelf {-n} property-1.r}} \ + "property-1" \ + ] \ + [list \ + "Build property 1 (.o)" \ + "-r -nostdlib" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-no-copy.S} \ + {{readelf {-n} property-1a.r}} \ + "property-1.o" \ + ] \ + [list \ + "Build property 1 (.so)" \ + "-shared" \ + "-fPIC -Wa,-mx86-used-note=no" \ + {pass.c property-no-copy.S} \ + {{readelf {-n} property-1.r}} \ + "property-1.so" \ + ] \ + [list \ + "Build property 2" \ + "" \ + "-Wa,-mx86-used-note=no" \ + {pass.c property-stack.S} \ + {{readelf {-n} property-2.r}} \ + "property-2" \ + ] \ + [list \ + "Build property 2 (.o)" \ + "-r -nostdlib" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-stack.S} \ + {{readelf {-n} property-2a.r}} \ + "property-2.o" \ + ] \ + [list \ + "Build property 2 (.so)" \ + "-shared" \ + "-fPIC -Wa,-mx86-used-note=no" \ + {pass.c property-stack.S} \ + {{readelf {-n} property-2.r}} \ + "property-2.so" \ + ] \ + [list \ + "Build property 3" \ + "" \ + "-Wa,-mx86-used-note=no" \ + {pass.c property-stack.S property-x86-1.S} \ + {{readelf {-n} property-3.r}} \ + "property-3" \ + ] \ + [list \ + "Build property 3 (.o)" \ + "-r -nostdlib" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-x86-1.S property-stack.S} \ + {{readelf {-n} property-3a.r}} \ + "property-3.o" \ + ] \ + [list \ + "Build property 3 (.so)" \ + "-shared" \ + "-fPIC -Wa,-mx86-used-note=no" \ + {property-x86-1.S pass.c property-stack.S} \ + {{readelf {-n} property-3.r}} \ + "property-3.so" \ + ] \ + [list \ + "Build property 4" \ + "" \ + "-Wa,-mx86-used-note=no" \ + {pass.c property-stack.S property-x86-1.S property-x86-2.S} \ + {{readelf {-n} property-4.r}} \ + "property-4" \ + ] \ + [list \ + "Build property 4 (.o)" \ + "-r -nostdlib" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-x86-2.S property-x86-1.S property-stack.S} \ + {{readelf {-n} property-4a.r}} \ + "property-4.o" \ + ] \ + [list \ + "Build property 4 (.so)" \ + "-shared" \ + "-fPIC -Wa,-mx86-used-note=no" \ + {property-x86-2.S property-x86-1.S pass.c property-stack.S} \ + {{readelf {-n} property-4.r}} \ + "property-4.so" \ + ] \ + [list \ + "Build property 4 (-Wl,-z,stack-size=0)" \ + "-Wl,-z,stack-size=0" \ + "-Wa,-mx86-used-note=no" \ + {pass.c property-stack.S property-x86-1.S property-x86-2.S} \ + {{readelf {-n} property-4.r}} \ + "property-4" \ + ] \ + [list \ + "Build property 5" \ + "-Wl,-z,stack-size=0x900000" \ + "-Wa,-mx86-used-note=no" \ + {pass.c property-stack.S property-x86-1.S property-x86-2.S} \ + {{readelf {-n} property-5.r}} \ + "property-5" \ + ] \ + [list \ + "Build property 5 (.o)" \ + "-r -nostdlib -Wl,-z,stack-size=0x900000" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-x86-2.S property-x86-1.S property-stack.S} \ + {{readelf {-n} property-5a.r}} \ + "property-5.o" \ + ] \ + [list \ + "Build property 5 (.so)" \ + "-shared -Wl,-z,stack-size=0x900000" \ + "-fPIC -Wa,-mx86-used-note=no" \ + {property-x86-2.S property-x86-1.S pass.c property-stack.S} \ + {{readelf {-n} property-5.r}} \ + "property-5.so" \ + ] \ + [list \ + "Build property-6.so" \ + "-shared" \ + "-fPIC -Wa,-mx86-used-note=no" \ + {property-6a.c property-6c.S} \ + {{readelf {-n} property-6.r}} \ + "property-6.so" \ + ] \ + [list \ + "Build property-6.o" \ + "-r -nostdlib" \ + "-Wa,-mx86-used-note=yes" \ + {property-6b.c property-stack.S} \ + {{readelf {-n} property-2a.r}} \ + "property-6.o" \ + ] \ + [list \ + "Build property-6" \ + "-Wl,--as-needed tmpdir/property-6.o tmpdir/property-6.so" \ + "-Wa,-mx86-used-note=no" \ + { dummy.s } \ + {{readelf {-n} property-2.r}} \ + "property-6" \ + ] \ + [list \ + "Build property 7a (.o)" \ + "-r -nostdlib" \ + "-Wa,-mx86-used-note=yes" \ + {property-unsorted-1.S} \ + {{readelf {-n} property-7a.r}} \ + "property-7a.o" \ + ] \ + [list \ + "Build property 7b (.o)" \ + "-r -nostdlib" \ + "-Wa,-mx86-used-note=yes" \ + {property-unsorted-2.S} \ + {{readelf {-n} property-7a.r}} \ + "property-7b.o" \ + ] \ ] - run_ld_link_exec_tests [] [list \ + run_ld_link_exec_tests [list \ [list \ "Run plt-main" \ "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so" \ - "" \ + "-Wa,-mx86-used-note=yes" \ { plt-main5.c } \ "plt-main" \ "plt-main.out" \ @@ -709,7 +1011,7 @@ if { [isnative] "Run plt-main with PIE" \ "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so -pie" \ - "" \ + "-Wa,-mx86-used-note=yes" \ { plt-main5.c } \ "plt-main-pie" \ "plt-main.out" \ @@ -717,8 +1019,8 @@ if { [isnative] ] \ [list \ "Run copyreloc-main with PIE and GOTOFF" \ - "--as-needed tmpdir/copyreloc-main.o tmpdir/copyreloc-lib.so -pie" \ - "" \ + "-Wl,--as-needed tmpdir/copyreloc-main.o tmpdir/copyreloc-lib.so -pie" \ + "-Wa,-mx86-used-note=yes" \ { dummy.s } \ "copyreloc-main" \ "copyreloc-main.out" \ @@ -726,7 +1028,7 @@ if { [isnative] [list \ "Run pr17689 with PIE and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689.so -pie" \ - "" \ + "-Wa,-mx86-used-note=yes" \ { dummy.c } \ "pr17689" \ "pr17689.out" \ @@ -734,7 +1036,7 @@ if { [isnative] [list \ "Run pr17689 with PIE, -z now and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689.so -pie -z now" \ - "" \ + "-Wa,-mx86-used-note=yes" \ { dummy.c } \ "pr17689now" \ "pr17689.out" \ @@ -742,7 +1044,7 @@ if { [isnative] [list \ "Run pr17689ver with PIE and GOTOFF" \ "tmpdir/pr17689b.o tmpdir/pr17689ver.so -pie" \ - "" \ + "-Wa,-mx86-used-note=yes" \ { dummy.c } \ "pr17689ver" \ "pr17689.out" \ @@ -750,41 +1052,481 @@ if { [isnative] [list \ "Run pr18900" \ "tmpdir/pr18900.o tmpdir/pr18900.so" \ - "" \ + "-Wa,-mx86-used-note=yes" \ { dummy.s } \ "pr18900" \ "pr18900.out" \ ] \ [list \ "Run pr19031" \ - "tmpdir/pr19031.so" \ - "" \ + "$NOPIE_LDFLAGS tmpdir/pr19031.so" \ + "-Wa,-mx86-used-note=yes" \ { pr19031b.S pr19031c.c } \ "pr19031" \ "pr19031.out" \ + "$NOPIE_CFLAGS" \ ] \ [list \ "Run got1" \ - "tmpdir/got1d.so" \ - "" \ + "$NOPIE_LDFLAGS tmpdir/got1d.so" \ + "-Wa,-mx86-used-note=yes" \ { got1a.S got1b.c got1c.c } \ "got1" \ "got1.out" \ ] \ + [list \ + "Run property 1" \ + "" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-no-copy.S} \ + "property-1" "pass.out" \ + ] \ + [list \ + "Run property 1 (PIE)" \ + "-pie" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-no-copy.S} \ + "property-1-pie" "pass.out" "-fPIE" \ + ] \ + [list \ + "Run property 1 (static)" \ + "-static" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-no-copy.S} \ + "property-1-static" "pass.out" \ + ] \ + [list \ + "Run property 2" \ + "" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-stack.S} \ + "property-2" "pass.out" \ + ] \ + [list \ + "Run property 2 (PIE)" \ + "-pie" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-stack.S} \ + "property-2-pie" "pass.out" "-fPIE" \ + ] \ + [list \ + "Run property 2 (static)" \ + "-static" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-stack.S} \ + "property-3-static" "pass.out" \ + ] \ + [list \ + "Run property 3" \ + "" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-stack.S property-x86-1.S} \ + "property-3" "pass.out" \ + ] \ + [list \ + "Run property 3 (PIE)" \ + "-pie" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-x86-1.S property-stack.S} \ + "property-3-pie" "pass.out" "-fPIE" \ + ] \ + [list \ + "Run property 3 (static)" \ + "-static" \ + "-Wa,-mx86-used-note=yes" \ + {property-x86-1.S pass.c property-stack.S} \ + "property-3-static" "pass.out" \ + ] \ + [list \ + "Run property 4" \ + "" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-stack.S property-x86-1.S property-x86-2.S} \ + "property-4" "pass.out" \ + ] \ + [list \ + "Run property 4 (PIE)" \ + "-pie" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-x86-2.S property-x86-1.S property-stack.S} \ + "property-4-pie" "pass.out" "-fPIE" \ + ] \ + [list \ + "Run property 4 (static)" \ + "-static" \ + "-Wa,-mx86-used-note=yes" \ + {property-x86-2.S property-x86-1.S pass.c property-stack.S} \ + "property-4-static" "pass.out" \ + ] \ + [list \ + "Run property 5" \ + "-Wl,-z,stack-size=0x900000" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-stack.S property-x86-1.S property-x86-2.S} \ + "property-5" "pass.out" \ + ] \ + [list \ + "Run property 5 (PIE)" \ + "-pie -Wl,-z,stack-size=0x900000" \ + "-Wa,-mx86-used-note=yes" \ + {pass.c property-x86-2.S property-x86-1.S property-stack.S} \ + "property-5-pie" "pass.out" "-fPIE" \ + ] \ + [list \ + "Run property 5 (static)" \ + "-static -Wl,-z,stack-size=0x900000" \ + "-Wa,-mx86-used-note=yes" \ + {property-x86-2.S property-x86-1.S pass.c property-stack.S} \ + "property-5-static" "pass.out" \ + ] \ ] - undefined_weak "" "" - undefined_weak "-fPIE" "" + undefined_weak "$NOPIE_CFLAGS" "$NOPIE_LDFLAGS" + undefined_weak "-fPIE" "$NOPIE_LDFLAGS" undefined_weak "-fPIE" "-pie" - undefined_weak "-fPIE" "-z nodynamic-undefined-weak" + undefined_weak "-fPIE" "-z nodynamic-undefined-weak $NOPIE_LDFLAGS" undefined_weak "-fPIE" "-pie -z nodynamic-undefined-weak" } +global NOPIE_CFLAGS NOPIE_LDFLAGS + +# Must be native with the C compiler and working IFUNC support, +if { [isnative] + && [check_ifunc_available] + && [istarget "i?86-*-*"] + && [check_compiler_available] } { + run_cc_link_tests [list \ + [list \ + "Build ifunc-1a.o ifunc-1b.o ifunc-1c.o ifunc-1d.o" \ + "" \ + "-fPIC -O2 -g -Wa,-mx86-used-note=yes" \ + { ifunc-1a.c ifunc-1b.S ifunc-1c.S ifunc-1d.S } \ + ] \ + [list \ + "Build pr21168a.o" \ + "" \ + "-Wa,-mx86-used-note=yes" \ + { pr21168a.c } \ + ] \ + [list \ + "Build pr21168.so" \ + "-shared" \ + "-Wa,-mx86-used-note=yes" \ + { pr21168b.S } \ + "" \ + "pr21168.so" \ + ] \ + ] + + run_ld_link_exec_tests [list \ + [list \ + "Run ifunc-1a" \ + "tmpdir/ifunc-1a.o tmpdir/ifunc-1b.o \ + tmpdir/ifunc-1c.o tmpdir/ifunc-1d.o" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + "ifunc-1a" \ + "pass.out" \ + ] \ + [list \ + "Run ifunc-1b" \ + "--static tmpdir/ifunc-1a.o tmpdir/ifunc-1b.o \ + tmpdir/ifunc-1c.o tmpdir/ifunc-1d.o" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + "ifunc-1b" \ + "pass.out" \ + ] \ + [list \ + "Run pr21168" \ + "tmpdir/pr21168a.o tmpdir/pr21168.so" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + "pr21168" \ + "pass.out" \ + ] \ + ] + + if { [istarget "i?86-*-linux*"] } { + run_cc_link_tests [list \ + [list \ + "Build pr21168.so with -z ibtplt" \ + "-shared -Wl,-z,ibtplt" \ + "-Wa,-mx86-used-note=yes" \ + { pr21168b.S } \ + "" \ + "pr21168-ibt.so" \ + ] \ + [list \ + "Build ifunc-1a with -z ibtplt" \ + "-Wl,-z,ibtplt $NOPIE_LDFLAGS tmpdir/ifunc-1a.o \ + tmpdir/ifunc-1b.o tmpdir/ifunc-1c.o tmpdir/ifunc-1d.o" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + {{objdump {-dw} plt-main-ibt.dd}} \ + "ifunc-1a-ibt" \ + ] \ + [list \ + "Build ifunc-1a with PIE -z ibtplt" \ + "-Wl,-z,ibtplt -pie tmpdir/ifunc-1a.o \ + tmpdir/ifunc-1b.o tmpdir/ifunc-1c.o tmpdir/ifunc-1d.o" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + {{objdump {-dw} plt-pie-ibt.dd}} \ + "ifunc-1a-pie-ibt" \ + ] \ + ] + + run_ld_link_exec_tests [list \ + [list \ + "Run ifunc-1a with -z ibtplt" \ + "-Wl,-z,ibtplt $NOPIE_LDFLAGS tmpdir/ifunc-1a.o \ + tmpdir/ifunc-1b.o tmpdir/ifunc-1c.o tmpdir/ifunc-1d.o" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + "ifunc-1a-ibt" \ + "pass.out" \ + ] \ + [list \ + "Run ifunc-1a with PIE -z ibtplt" \ + "-Wl,-z,ibtplt -pie tmpdir/ifunc-1a.o \ + tmpdir/ifunc-1b.o tmpdir/ifunc-1c.o tmpdir/ifunc-1d.o" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + "ifunc-1a-pie-ibt" \ + "pass.out" \ + ] \ + [list \ + "Run pr21168 with -z ibtplt" \ + "tmpdir/pr21168a.o tmpdir/pr21168-ibt.so" \ + "-Wa,-mx86-used-note=yes" \ + { dummy.c } \ + "pr21168-ibt" \ + "pass.out" \ + ] \ + ] + } +} + +# Must be native with the C compiler. +if { [isnative] + && [istarget "i?86-*-*"] + && [check_compiler_available] } { + run_cc_link_tests [list \ + [list \ + "Build pr22001-1.so" \ + "-shared" \ + "-Wa,-mx86-used-note=yes" \ + { pr22001-1a.c } \ + {} \ + "pr22001-1.so" \ + ] \ + [list \ + "Build pr21997-1.so" \ + "-shared" \ + "-Wa,-mx86-used-note=yes" \ + { property-stack.S property-no-copy.S pr21997-1a.S } \ + {} \ + "pr21997-1.so" \ + ] \ + [list \ + "Build pr22842.so" \ + "-shared" \ + "-fPIC -Wa,-mx86-used-note=yes" \ + { pr22842a.c } \ + {} \ + "pr22842.so" \ + ] \ + ] + + run_ld_link_exec_tests [list \ + [list \ + "Run weakundef1 without PIE" \ + "$NOPIE_LDFLAGS" \ + "-Wa,-mx86-used-note=yes" \ + { weakundef1.c } \ + "weakundef1pie" \ + "pass.out" \ + "$NOPIE_CFLAGS" \ + ] \ + [list \ + "Run pr22001-1" \ + "$NOPIE_LDFLAGS -Wl,-z,nocopyreloc,--no-as-needed tmpdir/pr22001-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr22001-1b.c } \ + "pr22001-1" \ + "pass.out" \ + "$NOPIE_CFLAGS" \ + ] \ + [list \ + "Run pr22001-1 (PIE 1)" \ + "$NOPIE_LDFLAGS -Wl,-z,nocopyreloc,--no-as-needed tmpdir/pr22001-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr22001-1c.S } \ + "pr22001-1-pie-1" \ + "pass.out" \ + ] \ + [list \ + "Run pr22001-1 (PIE 2)" \ + "-pie -Wl,-z,nocopyreloc,--no-as-needed tmpdir/pr22001-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr22001-1c.S } \ + "pr22001-1-pie-2" \ + "pass.out" \ + ] \ + [list \ + "Run pr22001-1 (PIC 1)" \ + "$NOPIE_LDFLAGS -Wl,-z,nocopyreloc,--no-as-needed tmpdir/pr22001-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr22001-1b.c } \ + "pr22001-1-pic-1" \ + "pass.out" \ + "-fPIC" \ + ] \ + [list \ + "Run pr22001-1 (PIC 2)" \ + "-pie -Wl,-z,nocopyreloc,--no-as-needed tmpdir/pr22001-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr22001-1b.c } \ + "pr22001-1-pic-2" \ + "pass.out" \ + "-fPIC" \ + ] \ + [list \ + "Run pr21997-1" \ + "$NOPIE_LDFLAGS -Wl,--no-as-needed tmpdir/pr21997-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr21997-1b.c } \ + "pr21997-1" \ + "pass.out" \ + "$NOPIE_CFLAGS" \ + ] \ + [list \ + "Run pr21997-1 (PIC 1)" \ + "$NOPIE_LDFLAGS -Wl,--no-as-needed tmpdir/pr21997-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr21997-1b.c } \ + "pr21997-1-pic-1" \ + "pass.out" \ + "-fPIC" \ + ] \ + [list \ + "Run pr21997-1 (PIC 2)" \ + "-pie -Wl,--no-as-needed tmpdir/pr21997-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr21997-1b.c } \ + "pr21997-1-pic-2" \ + "pass.out" \ + "-fPIC" \ + ] \ + [list \ + "Run pr21997-1 (PIE 1)" \ + "$NOPIE_LDFLAGS -Wl,--no-as-needed tmpdir/pr21997-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr21997-1c.S } \ + "pr21997-1-pie-1" \ + "pass.out" \ + ] \ + [list \ + "Run pr21997-1 (PIE 2)" \ + "-pie -Wl,--no-as-needed tmpdir/pr21997-1.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr21997-1c.S } \ + "pr21997-1-pie-2" \ + "pass.out" \ + ] \ + [list \ + "Build pr22842" \ + "-pie -Wl,--no-as-needed tmpdir/pr22842.so" \ + "-Wa,-mx86-used-note=yes" \ + { pr22842b.S } \ + "pr22842" \ + "pass.out" \ + ] \ + [list \ + "Run pr23997" \ + "" \ + "" \ + { ../ld-x86-64/pr23997a.s ../ld-x86-64/pr23997b.c \ + ../ld-x86-64/pr23997c.c } \ + "pr23997" \ + "pass.out" \ + ] \ + ] + + if { [at_least_gcc_version 5 0] } { + run_ld_link_exec_tests [list \ + [list \ + "Run weakundef1 with PIE" \ + "-pie" \ + "-Wa,-mx86-used-note=yes" \ + { weakundef1.c } \ + "weakundef1pie" \ + "pass.out" \ + "-fPIE" \ + ] \ + ] + } +} + if { !([istarget "i?86-*-linux*"] || [istarget "x86_64-*-linux*"]) } { + set ASFLAGS "$saved_ASFLAGS" return } +run_ld_link_tests [list \ + [list \ + "basic PLT generation (non-PIC, -z now)" \ + "-z now -melf_i386 --hash-style=sysv \ + -z noseparate-code tmpdir/libpltlib.so" \ + "" \ + "--32" \ + {plt2.s} \ + {{readelf -SW plt2.rd} {objdump -dwr plt2.dd}} \ + "plt2" \ + ] \ + [list \ + "basic PLT generation (PIC, -z now)" \ + "-z now -shared -melf_i386 tmpdir/libpltlib.so" \ + "" \ + "--32 -mx86-used-note=yes" \ + {plt-pic.s} \ + {{objdump -dwr plt-pic2.dd}} \ + "plt-pic2.so" \ + ] \ + [list \ + "Build pr21626.so" \ + "-shared -melf_i386" \ + "" \ + "--32 -mx86-used-note=yes" \ + {property-x86-3.s} \ + "" \ + "pr21626.so" \ + ] \ + [list \ + "Build pr21626" \ + "-melf_i386 tmpdir/pr21626.so" \ + "" \ + "--32 -mx86-used-note=yes" \ + {start.s foo.s} \ + "" \ + "pr21626" \ + ] \ +] + # Linux only tests run_dump_test "pltgot-1" run_dump_test "pltgot-2" +run_dump_test "pr20830" +run_dump_test "ibt-plt-1" +run_dump_test "ibt-plt-2a" +run_dump_test "ibt-plt-2b" +run_dump_test "ibt-plt-2c" +run_dump_test "ibt-plt-2d" +run_dump_test "ibt-plt-3a" +run_dump_test "ibt-plt-3b" +run_dump_test "ibt-plt-3c" +run_dump_test "ibt-plt-3d" + +set ASFLAGS "$saved_ASFLAGS"