diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2020-04-02 07:03:08 -0700 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2020-04-02 07:12:45 -0700 |
commit | 8be5def63b0f2036312483dac8dd5a4fa2e91009 (patch) | |
tree | e9944941e51e9b0c3f781b0bdd91ffb12d16706a /ld | |
parent | 4d095f5b5e57584133f85df42da2123e20834aec (diff) | |
download | gdb-8be5def63b0f2036312483dac8dd5a4fa2e91009.zip gdb-8be5def63b0f2036312483dac8dd5a4fa2e91009.tar.gz gdb-8be5def63b0f2036312483dac8dd5a4fa2e91009.tar.bz2 |
ld: Add NOCF_PROTECTION_CFLAGS to turn off -fcf-protection
GCC in Ubuntu 20.04 enables -fcf-protection by default, which leads to
FAIL: S-records
FAIL: S-records with constructors
FAIL: Build plt-main with -z bndplt
FAIL: Build plt-main with PIE and -z bndplt
FAIL: Build plt-main with -z bndplt -z now
FAIL: Build plt-main with PIE and -z bndplt -z now
on x86-64. Add NOCF_PROTECTION_CFLAGS to pass -fcf-protection=none on
these tests.
* testsuite/config/default.exp (NOCF_PROTECTION_CFLAGS): New.
Set to "-fcf-protection=none" if target compiler supports it.
* testsuite/ld-srec/srec.exp: Add $NOCF_PROTECTION_CFLAGS to
CC and CXX.
* testsuite/ld-x86-64/x86-64.exp: Add $NOCF_PROTECTION_CFLAGS
to PLT BND tests.
Diffstat (limited to 'ld')
-rw-r--r-- | ld/ChangeLog | 9 | ||||
-rw-r--r-- | ld/testsuite/config/default.exp | 38 | ||||
-rw-r--r-- | ld/testsuite/ld-srec/srec.exp | 8 | ||||
-rw-r--r-- | ld/testsuite/ld-x86-64/x86-64.exp | 10 |
4 files changed, 57 insertions, 8 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index ec43c89..2720a54 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,5 +1,14 @@ 2020-04-02 H.J. Lu <hongjiu.lu@intel.com> + * testsuite/config/default.exp (NOCF_PROTECTION_CFLAGS): New. + Set to "-fcf-protection=none" if target compiler supports it. + * testsuite/ld-srec/srec.exp: Add $NOCF_PROTECTION_CFLAGS to + CC and CXX. + * testsuite/ld-x86-64/x86-64.exp: Add $NOCF_PROTECTION_CFLAGS + to PLT BND tests. + +2020-04-02 H.J. Lu <hongjiu.lu@intel.com> + * testsuite/ld-elf/linux-x86.exp (check_pr25749a): Compile with -I../bfd. (check_pr25749b): Likewise. diff --git a/ld/testsuite/config/default.exp b/ld/testsuite/config/default.exp index 7fa7911..7998f4e 100644 --- a/ld/testsuite/config/default.exp +++ b/ld/testsuite/config/default.exp @@ -344,6 +344,44 @@ if { ![info exists NOPIE_CFLAGS] || ![info exists NOPIE_LDFLAGS] } then { } } +# Set NOCF_PROTECTION_CFLAGS to "-fcf-protection=none" if target compiler +# supports it. + +if { ![info exists NOCF_PROTECTION_CFLAGS] } then { + if { [check_compiler_available] } { + # Check if gcc supports -fcf-protection=none. + set flags "" + if [board_info [target_info name] exists cflags] { + append flags " [board_info [target_info name] cflags]" + } + if [board_info [target_info name] exists ldflags] { + append flags " [board_info [target_info name] ldflags]" + } + + set basename "tmpdir/nopie[pid]" + set src ${basename}.c + set output ${basename} + set f [open $src "w"] + puts $f "int main (void) { return 0; }" + close $f + if [is_remote host] { + set src [remote_download host $src] + } + set nopie_available [run_host_cmd_yesno "$CC" "$flags -fcf-protection=none $src -o $output"] + remote_file host delete $src + remote_file host delete $output + file delete $src + + if { $nopie_available == 1 } then { + set NOCF_PROTECTION_CFLAGS "-fcf-protection=none" + } else { + set NOCF_PROTECTION_CFLAGS "" + } + } else { + set NOCF_PROTECTION_CFLAGS "" + } +} + # Set GNU2_CFLAGS to "-mtls-dialect=gnu2" if target compiler supports it. if { ![info exists GNU2_CFLAGS] } then { diff --git a/ld/testsuite/ld-srec/srec.exp b/ld/testsuite/ld-srec/srec.exp index 742b997..da230fb 100644 --- a/ld/testsuite/ld-srec/srec.exp +++ b/ld/testsuite/ld-srec/srec.exp @@ -350,12 +350,12 @@ if { ![check_compiler_available] } { # Pass -fplt to CC and CXX since -fno-plt doesn't work with S-records # tests. Also add $NOPIE_CFLAGS and $NOPIE_LDFLAGS if PIE doesn't work -# with S-records. -global PLT_CFLAGS NOPIE_CFLAGS NOPIE_LDFLAGS +# with S-records. Also add $NOCF_PROTECTION_CFLAGS for S-records. +global PLT_CFLAGS NOPIE_CFLAGS NOPIE_LDFLAGS NOCF_PROTECTION_CFLAGS set old_CC "$CC" -set CC "$CC $PLT_CFLAGS $NOPIE_CFLAGS $NOPIE_LDFLAGS" +set CC "$CC $PLT_CFLAGS $NOPIE_CFLAGS $NOPIE_LDFLAGS $NOCF_PROTECTION_CFLAGS" set old_CXX "$CXX" -set CXX "$CXX $PLT_CFLAGS $NOPIE_CFLAGS $NOPIE_LDFLAGS" +set CXX "$CXX $PLT_CFLAGS $NOPIE_CFLAGS $NOPIE_LDFLAGS $NOCF_PROTECTION_CFLAGS" # S-records can't handle .note.gnu.property sections. if { [is_elf_format] \ diff --git a/ld/testsuite/ld-x86-64/x86-64.exp b/ld/testsuite/ld-x86-64/x86-64.exp index c78b0fd..d2e5ac7 100644 --- a/ld/testsuite/ld-x86-64/x86-64.exp +++ b/ld/testsuite/ld-x86-64/x86-64.exp @@ -740,6 +740,8 @@ proc undefined_weak {cflags ldflags} { global PLT_CFLAGS # Add $NOPIE_CFLAGS and $NOPIE_LDFLAGS if non-PIE is required. global NOPIE_CFLAGS NOPIE_LDFLAGS +# Add $NOCF_PROTECTION_CFLAGS if -fcf-protection=none is required. +global NOCF_PROTECTION_CFLAGS # Must be native with the C compiler if { [isnative] && [check_compiler_available] } { @@ -1819,7 +1821,7 @@ if { [isnative] && [check_compiler_available] } { "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so -z bndplt \ -z noseparate-code -z max-page-size=0x200000" \ - "-Wa,-mx86-used-note=yes" \ + "-Wa,-mx86-used-note=yes $NOCF_PROTECTION_CFLAGS" \ { plt-main5.c } \ {{objdump {-drw} plt-main-bnd.dd}} \ "plt-main-bnd" \ @@ -1829,7 +1831,7 @@ if { [isnative] && [check_compiler_available] } { "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so -z bndplt -pie \ -z noseparate-code -z max-page-size=0x200000" \ - "-fPIC -Wa,-mx86-used-note=yes" \ + "-fPIC -Wa,-mx86-used-note=yes $NOCF_PROTECTION_CFLAGS" \ { plt-main5.c } \ {{objdump {-drw} plt-main-bnd.dd}} \ "plt-main-pie-bnd" \ @@ -1839,7 +1841,7 @@ if { [isnative] && [check_compiler_available] } { "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so -z bndplt -z now \ -z noseparate-code -z max-page-size=0x200000" \ - "-Wa,-mx86-used-note=yes" \ + "-Wa,-mx86-used-note=yes $NOCF_PROTECTION_CFLAGS" \ { plt-main5.c } \ {{readelf {-SW} plt-main-bnd-now.rd} {objdump {-drw} plt-main-bnd.dd}} \ "plt-main-bnd-now" \ @@ -1849,7 +1851,7 @@ if { [isnative] && [check_compiler_available] } { "tmpdir/plt-main1.o tmpdir/plt-main2.o tmpdir/plt-main3.o \ tmpdir/plt-main4.o tmpdir/libplt-lib.so -z bndplt -z now -pie \ -z noseparate-code -z max-page-size=0x200000" \ - "-fPIC -Wa,-mx86-used-note=yes" \ + "-fPIC -Wa,-mx86-used-note=yes $NOCF_PROTECTION_CFLAGS" \ { plt-main5.c } \ {{readelf {-SW} plt-main-bnd-now.rd} {objdump {-drw} plt-main-bnd.dd}} \ "plt-main-pie-bnd-now" \ |