# Expect script for common symbol tests
-# Copyright 2003, 2005, 2006, 2007 Free Software Foundation, Inc.
+# Copyright (C) 2003-2021 Free Software Foundation, Inc.
#
# This file is part of the GNU Binutils.
#
return
}
+# hpux assembly is weird
+if [istarget "hppa*-*-hpux*"] {
+ return
+}
+
proc test_sort_common {} {
global exec_output
global objdump
return 0
}
- if { ![ld_simple_link $ld tmpdir/sort-common.dx "--sort-common=descending tmpdir/sort-common.o"] } {
- fail "$test"
+ if { ![ld_link $ld tmpdir/sort-common.dx "--sort-common=descending tmpdir/sort-common.o"] } {
+ fail "$test (could not link)"
return 0
}
# section and large commons in a .bss section.
if { ![regexp ".*var_16.*var_8.*var_4.*var_2.*var_1.*" $exec_output]
&& ![regexp ".*sbss.*var_8.*var_4.*var_2.*var_1.*bss.*var_16.*" $exec_output] } {
- fail $test
+ fail "$test (variables in wrong order)"
} else {
pass $test
}
verbose "Check to see that --sort-common=ascending sorts in ascending alignment"
- if { ![ld_simple_link $ld tmpdir/sort-common.ax "--sort-common=ascending tmpdir/sort-common.o"] } {
- fail "$test"
+ if { ![ld_link $ld tmpdir/sort-common.ax "--sort-common=ascending tmpdir/sort-common.o"] } {
+ fail "$test (could not link)"
return 0
}
set exec_output [run_host_cmd "$objdump" "--syms tmpdir/sort-common.ax | grep var | sort"]
if {![regexp ".*var_1.*var_2.*var_4.*var_8.*var_16.*" $exec_output]} {
- fail $test
+ fail "$test (variables in wrong order)"
return 0
}
test_sort_common
-set test1 "size/aligment change of common symbols"
+set test1 "size/alignment change of common symbols"
set test1w1 "$test1 (warning 1)"
set test1w2 "$test1 (warning 2)"
set test1c1 "$test1 (change 1)"
set test1c2 "$test1 (change 2)"
-if { ![is_remote host] && [which $CC] == 0 } {
+if { ![check_compiler_available] } {
untested $test1w1
untested $test1w2
untested $test1c1
global READELF
global ld
- set options "$options tmpdir/common1a.o"
+ set options "$options tmpdir/common1c.o"
- if { ! [ld_simple_link $ld tmpdir/common.exe $options] } {
+ if { ! [ld_link $ld tmpdir/common.exe $options] } {
unresolved $testname
return 0
}
send_log "$READELF --syms tmpdir/common.exe | grep foo\n"
set exec_output [run_host_cmd "$READELF" "--syms tmpdir/common.exe | grep foo"]
- if {![regexp "(\[ \]*)(\[0-9\]+):(\[ \]*)(\[0-9\]+)(\[ \]+)(\[0-9\]+)(\[ \]+)COMMON(\[ \]+)GLOBAL(\[ \]+)DEFAULT(\[ \]+)(\[0-9\]+)(\[ \]+)_?foo2" $exec_output] } {
+ if {![regexp { +[0-9a-f]+. +[0-9a-f]+ OBJECT + GLOBAL +DEFAULT +[0-9]+ _?foo2} $exec_output] } {
fail $testname
return 0
}
return 1
}
-# Check to see if the assembler is generating symbols with the STT_COMMON type.
-proc assembler_generates_commons {} {
- global exec_output
- global READELF
-
- verbose "Check to see if STT_COMMON symbols are being generated:"
- set exec_output [run_host_cmd "$READELF" "--syms tmpdir/common1a.o | grep foo"]
-
- if { ![regexp "(\[ \]*)(\[0-9\]+):(\[ \]*)(\[0\]*)80(\[ \]+).(\[ \]+)COMMON(\[ \]+)GLOBAL(\[ \]+)DEFAULT(\[ \]+)(PRC\\\[0xff03\\\]|COM|SCOM)(\[ \]+)_?foo2" $exec_output] } {
- verbose "STT_COMMON not generated"
- return 0
- }
-
- verbose "STT_COMMON's are generated"
- return 1
+if [istarget nios2*-*-*] {
+ set CFLAGS "$CFLAGS -G0"
}
-
-if { ![ld_compile "$CC $CFLAGS" $srcdir/$subdir/common1a.c tmpdir/common1a.o]
- || ![ld_compile "$CC $CFLAGS" $srcdir/$subdir/common1b.c tmpdir/common1b.o] } {
+# Explicitly use "-fcommon" so that even if $CFLAGS includes
+# "-fno-common", these tests are compiled as expected.
+if { ![ld_compile "$CC $CFLAGS -fcommon $NOSANITIZE_CFLAGS $NOLTO_CFLAGS" $srcdir/$subdir/common1a.c tmpdir/common1a.o]
+ || ![ld_compile "$CC $CFLAGS -fcommon $NOSANITIZE_CFLAGS $NOLTO_CFLAGS" $srcdir/$subdir/common1b.c tmpdir/common1b.o]
+ || ![ld_compile "$CC $CFLAGS $NOSANITIZE_CFLAGS $NOLTO_CFLAGS -Wa,--elf-stt-common=yes -fcommon" $srcdir/$subdir/common1b.c tmpdir/common1c.o] } {
+ unresolved $test1
unresolved $test1
return
}
-global ld
-global link_output
+set options "-r tmpdir/common1a.o tmpdir/common1b.o"
-if { [ld_simple_link $ld tmpdir/common1.o "-r tmpdir/common1a.o tmpdir/common1b.o"] } {
+if { [ld_link $ld tmpdir/common1.o $options] } {
unresolved $test1w1
return
}
# This test fails on MIPS because the backend sets type_change_ok.
-# The size change warning is suppressed.
-if {[istarget mips*-*-*]} {
- if { ![regexp "Warning: alignment (\[0-9\]+) of symbol \`_?foo1\' in tmpdir/common1b.o is smaller than 64 in tmpdir/common1a.o" $link_output] } {
+# The size change warning is suppressed. Same on hppa64.
+if {[istarget mips*-*-*] || [istarget hppa*64*-*-*]} {
+ if { ![regexp "warning: alignment (\[0-9\]+) of symbol \`_?foo1\' in tmpdir/common1b.o is smaller than 64 in tmpdir/common1a.o" $link_output] } {
fail $test1w1
} else {
pass $test1w1
}
} else {
- if { ![regexp "Warning: alignment (\[0-9\]+) of symbol \`_?foo1\' in tmpdir/common1b.o is smaller than 64 in tmpdir/common1a.o" $link_output]
- || ![regexp "Warning: size of symbol \`_?foo1\' changed from 2 in tmpdir/common1a.o to 21 in tmpdir/common1b.o" $link_output] } {
+ if { ![regexp "warning: alignment (\[0-9\]+) of symbol \`_?foo1\' in tmpdir/common1b.o is smaller than 64 in tmpdir/common1a.o" $link_output]
+ || ![regexp "warning: size of symbol \`_?foo1\' changed from 2 in tmpdir/common1a.o to 21 in tmpdir/common1b.o" $link_output] } {
fail $test1w1
} else {
pass $test1w1
pass $test1c1
}
-if { [ld_simple_link $ld tmpdir/common1.o "-r tmpdir/common1b.o tmpdir/common1a.o"] } {
+set options "-r tmpdir/common1b.o tmpdir/common1a.o"
+
+if { [ld_link $ld tmpdir/common1.o $options] } {
unresolved $test1w2
return
}
-if { ![regexp "Warning: alignment (\[0-9\]+) of symbol \`_?foo1\' in tmpdir/common1b.o is smaller than 64 in tmpdir/common1a.o" $link_output] } {
+if { ![regexp "warning: alignment (\[0-9\]+) of symbol \`_?foo1\' in tmpdir/common1b.o is smaller than 64 in tmpdir/common1a.o" $link_output] } {
fail $test1w2
} else {
pass $test1w2
#
# The following tests are for when we are generating STT_COMMON symbols only.
#
+# Handling of -z common and -z nocommon flags is enabled only if
+# $GENERATE_SHLIB_SCRIPT is turned on in emulparams i.e. shared
+# libraries are supported.
-if { ![assembler_generates_commons] } {
+if ![check_shared_lib_support] {
return
}
stt_common_test "-shared" "shared link of common symbols"
stt_common_test "-pie" "position independent link of common symbols"
+run_ld_link_tests [list \
+ [list \
+ "Build common-3x.o" \
+ "-r" "" "--elf-stt-common=no" \
+ {common-1.s} {} "common-3x.o" \
+ ] \
+ [list \
+ "Build common-3y.o" \
+ "-r" "" "--elf-stt-common=yes" \
+ {common-1.s} {} "common-3y.o" \
+ ] \
+ [list \
+ "Build common-3a.o" \
+ "-r tmpdir/common-3x.o tmpdir/common-3y.o" "" "" \
+ {dummy.s} {{readelf {-s -W} common-3a.rd}} "common-3a.o" \
+ ] \
+ [list \
+ "Build common-3b.o" \
+ "-r tmpdir/common-3y.o tmpdir/common-3x.o" "" "" \
+ {dummy.s} {{readelf {-s -W} common-3b.rd}} "common-3b.o" \
+ ] \
+ [list \
+ "Build common-3c.o" \
+ "-r -z nocommon tmpdir/common-3x.o tmpdir/common-3y.o" "" "" \
+ {dummy.s} {{readelf {-s -W} common-3a.rd}} "common-3c.o" \
+ ] \
+ [list \
+ "Build common-3d.o" \
+ "-r -z common tmpdir/common-3x.o tmpdir/common-3y.o" "" "" \
+ {dummy.s} {{readelf {-s -W} common-3b.rd}} "common-3b.o" \
+ ] \
+ [list \
+ "Build common-3e.o" \
+ "-r -z common tmpdir/common-3y.o tmpdir/common-3x.o" "" "" \
+ {dummy.s} {{readelf {-s -W} common-3b.rd}} "common-3e.o" \
+ ] \
+ [list \
+ "Build common-3f.o" \
+ "-r -z nocommon tmpdir/common-3y.o tmpdir/common-3x.o" "" "" \
+ {dummy.s} {{readelf {-s -W} common-3a.rd}} "common-3f.o" \
+ ] \
+]
+
+set test_list [lsort [glob -nocomplain $srcdir/$subdir/*.d]]
+foreach t $test_list {
+ # We need to strip the ".d", but can leave the dirname.
+ verbose [file rootname $t]
+ run_dump_test [file rootname $t]
+}