36591ba149
Andrew Jenner <andrew@codesourcery.com> Based on patches from Altera Corporation. bfd/ * Makefile.am (ALL_MACHINES): Add cpu-nios2.lo. (ALL_MACHINES_CFILES): Add cpu-nios2.c. (BFD_BACKENDS): Add elf32-nios2.lo. (BFD32_BACKENDS_CFILES): Add elf32-nios2.c. * Makefile.in: Regenerated. * configure.in: Add entries for bfd_elf32_bignios2_vec and bfd_elf32_littlenios2_vec. * configure: Regenerated. * config.bfd: Add cases for nios2. * archures.c (enum bfd_architecture): Add bfd_arch_nios2. (bfd_mach_nios2): Define. (bfd_nios2_arch): Declare. (bfd_archures_list): Add bfd_nios2_arch. * targets.c (bfd_elf32_bignios2_vec): Declare. (bfd_elf32_littlenios2_vec): Declare. (_bfd_target_vector): Add entries for bfd_elf32_bignios2_vec and bfd_elf32_littlenios2_vec. * elf-bfd.h (enum elf_target_id): Add NIOS2_ELF_DATA. * reloc.c (enum bfd_reloc_code_real): Add Nios II relocations. * bfd-in2.h: Regenerated. * libbfd.h: Regenerated. * cpu-nios2.c: New file. * elf32-nios2.c: New file. opcodes/ * Makefile.am (TARGET_LIBOPCODES_CFILES): Add nios2-dis.c and nios2-opc.c. * Makefile.in: Regenerated. * configure.in: Add case for bfd_nios2_arch. * configure: Regenerated. * disassemble.c (ARCH_nios2): Define. (disassembler): Add case for bfd_arch_nios2. * nios2-dis.c: New file. * nios2-opc.c: New file. include/ * dis-asm.h (print_insn_big_nios2): Declare. (print_insn_little_nios2): Declare. include/elf * nios2.h: New file. include/opcode/ * nios2.h: New file. gas/ * Makefile.am (TARGET_CPU_CFILES): Add config/tc-nios2.c. (TARGET_CPU_HFILES): Add config/tc-nios2.h. * Makefile.in: Regenerated. * configure.tgt: Add case for nios2*-linux*. * config/obj-elf.c: Conditionally include elf/nios2.h. * config/tc-nios2.c: New file. * config/tc-nios2.h: New file. * doc/Makefile.am (CPU_DOCS): Add c-nios2.texi. * doc/Makefile.in: Regenerated. * doc/all.texi: Set NIOSII. * doc/as.texinfo (Overview): Add Nios II options. (Machine Dependencies): Include c-nios2.texi. * doc/c-nios2.texi: New file. * NEWS: Note Altera Nios II support. gas/testsuite/ * gas/nios2/add.d: New. * gas/nios2/add.s: New. * gas/nios2/align_fill.d: New. * gas/nios2/align_fill.s: New. * gas/nios2/align_text.d: New. * gas/nios2/align_text.s: New. * gas/nios2/and.d: New. * gas/nios2/and.s: New. * gas/nios2/branch.d: New. * gas/nios2/branch.s: New. * gas/nios2/break.d: New. * gas/nios2/break.s: New. * gas/nios2/bret.d: New. * gas/nios2/bret.s: New. * gas/nios2/cache.d: New. * gas/nios2/cache.s: New. * gas/nios2/call26.d: New. * gas/nios2/call26.s: New. * gas/nios2/call.d: New. * gas/nios2/call.s: New. * gas/nios2/cmp.d: New. * gas/nios2/cmp.s: New. * gas/nios2/comments.d: New. * gas/nios2/comments.s: New. * gas/nios2/complex.d: New. * gas/nios2/complex.s: New. * gas/nios2/ctl.d: New. * gas/nios2/ctl.s: New. * gas/nios2/custom.d: New. * gas/nios2/custom.s: New. * gas/nios2/etbt.d: New. * gas/nios2/etbt.s: New. * gas/nios2/flushda.d: New. * gas/nios2/flushda.s: New. * gas/nios2/illegal.l: New. * gas/nios2/illegal.s: New. * gas/nios2/jmp.d: New. * gas/nios2/jmp.s: New. * gas/nios2/ldb.d: New. * gas/nios2/ldb.s: New. * gas/nios2/ldh.d: New. * gas/nios2/ldh.s: New. * gas/nios2/ldw.d: New. * gas/nios2/ldw.s: New. * gas/nios2/lineseparator.d: New. * gas/nios2/lineseparator.s: New. * gas/nios2/mov.d: New. * gas/nios2/movia.d: New. * gas/nios2/movia.s: New. * gas/nios2/movi.d: New. * gas/nios2/movi.s: New. * gas/nios2/mov.s: New. * gas/nios2/mul.d: New. * gas/nios2/mul.s: New. * gas/nios2/nios2.exp: New. * gas/nios2/nor.d: New. * gas/nios2/nor.s: New. * gas/nios2/or.d: New. * gas/nios2/or.s: New. * gas/nios2/ret.d: New. * gas/nios2/ret.s: New. * gas/nios2/rol.d: New. * gas/nios2/rol.s: New. * gas/nios2/rotate.d: New. * gas/nios2/rotate.s: New. * gas/nios2/stb.d: New. * gas/nios2/stb.s: New. * gas/nios2/sth.d: New. * gas/nios2/sth.s: New. * gas/nios2/stw.d: New. * gas/nios2/stw.s: New. * gas/nios2/sub.d: New. * gas/nios2/sub.s: New. * gas/nios2/sync.d: New. * gas/nios2/sync.s: New. * gas/nios2/trap.d: New. * gas/nios2/trap.s: New. * gas/nios2/tret.d: New. * gas/nios2/tret.s: New. * gas/nios2/warn_noat.l: New. * gas/nios2/warn_noat.s: New. * gas/nios2/warn_nobreak.l: New. * gas/nios2/warn_nobreak.s: New. * gas/nios2/xor.d: New. * gas/nios2/xor.s: New. ld/ * Makefile.am (enios2elf.c): New rule. * Makefile.in: Regenerated. * configure.tgt: Add case for nios2*-*-*. * emulparams/nios2elf.sh: New file. * NEWS: Note Altera Nios II support. ld/testsuite/ * ld-nios2/emit-relocs-1a.s: New. * ld-nios2/emit-relocs-1b.s: New. * ld-nios2/emit-relocs-1.d: New. * ld-nios2/emit-relocs-1.ld: New. * ld-nios2/gprel.d: New. * ld-nios2/gprel.s: New. * ld-nios2/hilo16.d: New. * ld-nios2/hilo16.s: New. * ld-nios2/hilo16_symbol.s: New. * ld-nios2/imm5.d: New. * ld-nios2/imm5.s: New. * ld-nios2/imm5_symbol.s: New. * ld-nios2/nios2.exp: New. * ld-nios2/pcrel16.d: New. * ld-nios2/pcrel16_label.s: New. * ld-nios2/pcrel16.s: New. * ld-nios2/relax_callr.d: New. * ld-nios2/relax_callr.ld: New. * ld-nios2/relax_callr.s: New. * ld-nios2/relax_cjmp.d: New. * ld-nios2/relax_cjmp.s: New. * ld-nios2/relax_jmp.ld: New. * ld-nios2/relax_section.d: New. * ld-nios2/relax_section.s: New. * ld-nios2/relax_ujmp.d: New. * ld-nios2/relax_ujmp.s: New. * ld-nios2/reloc.d: New. * ld-nios2/reloc.s: New. * ld-nios2/reloc_symbol.s: New. * ld-nios2/s16.d: New. * ld-nios2/s16.s: New. * ld-nios2/s16_symbol.s: New. * ld-nios2/u16.d: New. * ld-nios2/u16.s: New. * ld-nios2/u16_symbol.s: New. * ld-elf/indirect.exp: Skip on targets that don't support -shared -fPIC. * ld-elfcomm/elfcomm.exp: Build with -G0 for nios2. * ld-plugin/lto.exp: Skip shared library tests on targets that don't support them. Skip execution tests on non-native targets. binutils/ * readelf.c: Include elf/nios2.h. (dump_relocations): Add case for EM_ALTERA_NIOS2. (get_nios2_dynamic_type): New. (get_dynamic_type): Add case for EM_ALTERA_NIOS2. (is_32bit_abs_reloc): Fix EM_ALTERA_NIOS2 case. (is_16bit_abs_reloc): Likewise. (is_none_reloc): Add EM_ALTERA_NIOS2 and EM_NIOS32 cases. * NEWS: Note Altera Nios II support. * MAINTAINERS: Add Nios II maintainers.
273 lines
7.9 KiB
Text
273 lines
7.9 KiB
Text
# Expect script for common symbol tests
|
|
# Copyright 2003, 2005, 2006, 2007, 2008, 2009
|
|
# Free Software Foundation, Inc.
|
|
#
|
|
# This file is part of the GNU Binutils.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
|
|
# MA 02110-1301, USA.
|
|
#
|
|
# Written by H.J. Lu (hjl@gnu.org)
|
|
#
|
|
|
|
# Make sure that ld correctly handles common symbols in ELF.
|
|
|
|
# This test can only be run on ELF platforms.
|
|
if ![is_elf_format] {
|
|
return
|
|
}
|
|
|
|
# hpux assembly is weird
|
|
if [istarget "hppa*-*-hpux*"] {
|
|
return
|
|
}
|
|
|
|
proc test_sort_common {} {
|
|
global exec_output
|
|
global objdump
|
|
global srcdir
|
|
global subdir
|
|
global as
|
|
global ld
|
|
|
|
set test "--sort-common (descending)"
|
|
|
|
verbose "Check to see that --sort-common sorts in descending alignment"
|
|
|
|
# We do not run the sort common tests for the DLX target because we know that the linker
|
|
# will seg-fault. The built-in DLX linker script requires that there be something in the
|
|
# .text section and our sort-common.s file does not provide anything.
|
|
if [istarget dlx-*-*] {
|
|
untested "$test"
|
|
return 0
|
|
}
|
|
|
|
if { ![ld_assemble $as $srcdir/$subdir/sort-common.s tmpdir/sort-common.o] } {
|
|
unresolved "$test"
|
|
return 0
|
|
}
|
|
|
|
if { ![ld_simple_link $ld tmpdir/sort-common.dx "--sort-common=descending tmpdir/sort-common.o"] } {
|
|
fail "$test"
|
|
return 0
|
|
}
|
|
|
|
send_log "$objdump --syms tmpdir/sort-common.dx | grep var | sort\n"
|
|
set exec_output [run_host_cmd "$objdump" "--syms tmpdir/sort-common.dx | grep var | sort"]
|
|
|
|
# Don't know why, but the CR ports fail this test.
|
|
setup_xfail "cr16-*-*" "crx-*-*"
|
|
|
|
# Note: The second regexp is for targets which put small commons in a .sbss
|
|
# 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
|
|
} else {
|
|
pass $test
|
|
}
|
|
|
|
set test "--sort-common (ascending)"
|
|
|
|
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"
|
|
return 0
|
|
}
|
|
|
|
send_log "$objdump --syms tmpdir/sort-common.ax | grep var | sort\n"
|
|
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
|
|
return 0
|
|
}
|
|
|
|
pass $test
|
|
return 1
|
|
}
|
|
|
|
test_sort_common
|
|
|
|
set test1 "size/aligment 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 } {
|
|
untested $test1w1
|
|
untested $test1w2
|
|
untested $test1c1
|
|
untested $test1c2
|
|
return
|
|
}
|
|
if { [istarget score-*-*] } {
|
|
untested $test1w1
|
|
untested $test1w2
|
|
untested $test1c1
|
|
untested $test1c2
|
|
return
|
|
}
|
|
|
|
proc dump_common1 { testname } {
|
|
global exec_output
|
|
global READELF
|
|
|
|
send_log "$READELF --syms tmpdir/common1.o | grep foo\n"
|
|
set exec_output [run_host_cmd "$READELF" "--syms tmpdir/common1.o | grep foo"]
|
|
|
|
if { ![regexp "(\[ \]*)(\[0-9\]+):(\[ \]*)(\[0\]*)80(\[ \]+)4(\[ \]+)(COMMON|OBJECT)(\[ \]+)GLOBAL(\[ \]+)DEFAULT(\[ \]+)(PRC\\\[0xff03\\\]|COM|SCOM)(\[ \]+)_?foo2" $exec_output]
|
|
|| ![regexp "(\[ \]*)(\[0-9\]+):(\[ \]*)(\[0-9\]+)(\[ \]+)21(\[ \]+)OBJECT(\[ \]+)GLOBAL(\[ \]+)DEFAULT(\[ \]+)(\[0-9\]+)(\[ \]+)_?foo1" $exec_output] } {
|
|
verbose $exec_output
|
|
fail $testname
|
|
return 0
|
|
}
|
|
|
|
return 1
|
|
}
|
|
|
|
proc stt_common_test { options testname } {
|
|
global exec_output
|
|
global READELF
|
|
global ld
|
|
|
|
set options "$options tmpdir/common1a.o"
|
|
|
|
if { ! [ld_simple_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] } {
|
|
fail $testname
|
|
return 0
|
|
}
|
|
|
|
pass $testname
|
|
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"
|
|
}
|
|
|
|
# Explicitly use "-fcommon" so that even if $CFLAGS includes
|
|
# "-fno-common", these tests are compiled as expected.
|
|
if { ![ld_compile "$CC $CFLAGS -fcommon" $srcdir/$subdir/common1a.c tmpdir/common1a.o]
|
|
|| ![ld_compile "$CC $CFLAGS -fcommon" $srcdir/$subdir/common1b.c tmpdir/common1b.o] } {
|
|
unresolved $test1
|
|
return
|
|
}
|
|
|
|
global ld
|
|
global link_output
|
|
|
|
set options "-r tmpdir/common1a.o tmpdir/common1b.o"
|
|
|
|
# SH64 targets needs an extra ld option for this test.
|
|
if [istarget sh64*-*-*] {
|
|
if [istarget sh64*l*-*-*] {
|
|
set options "-mshlelf32 $options"
|
|
} else {
|
|
set options "-mshelf32 $options"
|
|
}
|
|
}
|
|
|
|
if { [ld_simple_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. 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] } {
|
|
fail $test1w1
|
|
} else {
|
|
pass $test1w1
|
|
}
|
|
}
|
|
|
|
if { [dump_common1 $test1c1] } {
|
|
pass $test1c1
|
|
}
|
|
|
|
set options "-r tmpdir/common1b.o tmpdir/common1a.o"
|
|
|
|
# SH64 targets needs an extra ld option for this test.
|
|
if [istarget sh64*-*-*] {
|
|
if [istarget sh64*l*-*-*] {
|
|
set options "-mshlelf32 $options"
|
|
} else {
|
|
set options "-mshelf32 $options"
|
|
}
|
|
}
|
|
|
|
if { [ld_simple_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] } {
|
|
fail $test1w2
|
|
} else {
|
|
pass $test1w2
|
|
}
|
|
|
|
if { [dump_common1 $test1c2] } {
|
|
pass $test1c2
|
|
}
|
|
|
|
#
|
|
# The following tests are for when we are generating STT_COMMON symbols only.
|
|
#
|
|
|
|
if { ![assembler_generates_commons] } {
|
|
return
|
|
}
|
|
|
|
stt_common_test "-static -e 0" "static link of common symbols"
|
|
stt_common_test "-shared" "shared link of common symbols"
|
|
stt_common_test "-pie" "position independent link of common symbols"
|
|
|