URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Subversion Repositories openrisc_2011-10-31
Compare Revisions
- This comparison shows the changes necessary to convert path
/openrisc/trunk/gnu-src/binutils-2.18.50/ld/testsuite/ld-d10v
- from Rev 38 to Rev 156
- ↔ Reverse comparison
Rev 38 → Rev 156
/regression-001.s
0,0 → 1,14
.section .data |
;; |
;; The next line caused an earlier ld to core dump. |
.global .data |
foo: |
.space 0x0064 |
|
.section .text |
.global _test |
.global _start |
_test: |
ldi r0,foo |
_start: |
nop |
/reloc-001.d
0,0 → 1,12
#source: reloc-001.s |
#ld: -T $srcdir/$subdir/reloc-001.ld |
#objdump: -D |
|
# Test 10 bit pc rel reloc normal case |
|
.*: file format elf32-d10v |
|
Disassembly of section .text: |
|
01014000 <_start>: |
1014000: 65 20 cc 1a brf0f.s 1014104 <foo> -> jmp r13 |
/reloc-002.d
0,0 → 1,12
#source: reloc-001.s |
#ld: -T $srcdir/$subdir/reloc-002.ld |
#objdump: -D |
|
# Test 10 bit pc rel reloc good boundary. |
|
.*: file format elf32-d10v |
|
Disassembly of section .text: |
|
01014000 <_start>: |
1014000: 65 3f cc 1a brf0f.s 10141fc <foo> -> jmp r13 |
/reloc-003.d
0,0 → 1,5
#source: reloc-001.s |
#ld: -T $srcdir/$subdir/reloc-003.ld |
#error: relocation truncated to fit: R_D10V_10_PCREL_L |
|
# Test 10 bit pc rel reloc bad boundary. |
/reloc-004.d
0,0 → 1,5
#source: reloc-001.s |
#ld: -T $srcdir/$subdir/reloc-004.ld |
#error: relocation truncated to fit: R_D10V_10_PCREL_L |
|
# Test 10 bit pc rel reloc normal bad. |
/reloc-005.d
0,0 → 1,13
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-005.ld |
#objdump: -D |
|
# Test 18 bit pc rel reloc normal case |
|
.*: file format elf32-d10v |
|
Disassembly of section .text: |
|
01014000 <_start>: |
1014000: e4 00 10 02 bra.l 1018008 <foo> |
1014004: 26 0d 5e 00 jmp r13 || nop |
/reloc-006.d
0,0 → 1,13
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-006.ld |
#objdump: -D |
|
# Test 18 bit pc rel reloc good boundary |
|
.*: file format elf32-d10v |
|
Disassembly of section .text: |
|
01014000 <_start>: |
1014000: e4 00 7f ff bra.l 1033ffc <foo> |
1014004: 26 0d 5e 00 jmp r13 || nop |
/reloc-007.d
0,0 → 1,7
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-007.ld |
#objdump: -D |
#error: relocation truncated to fit: R_D10V_18_PCREL |
|
# Test 18 bit pc rel reloc bad boundary |
|
/reloc-008.d
0,0 → 1,7
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-008.ld |
#objdump: -D |
#error: relocation truncated to fit: R_D10V_18_PCREL |
|
# Test 18 bit pc rel reloc normal bad |
|
/reloc-009.d
0,0 → 1,15
#source: reloc-009.s |
#ld: -T $srcdir/$subdir/reloc-009.ld |
#objdump: -D |
|
# Test 10 bit pc rel reloc negative normal case |
|
.*: file format elf32-d10v |
Disassembly of section .text: |
|
01014000 <foo>: |
... |
|
01014100 <_start>: |
1014100: 6f 00 4a c0 nop -> brf0f.s 1014000 <foo> |
1014104: 26 0d 5e 00 jmp r13 || nop |
/linktest-001.s
0,0 → 1,4
.section .data |
.global bar |
bar: |
.space 64 |
/regression-001.lt
0,0 → 1,3
#source: regression-001.s |
#as: -W |
|
/linktest-002.s
0,0 → 1,4
.section .text |
.global _start |
_start: |
ldi r0,bar |
/reloc-001.ld
0,0 → 1,10
SECTIONS |
{ |
.text 0x01014000 : |
{ |
*(.text) |
foo = (. + 0x100); |
} |
} |
|
|
/reloc-011.ld
0,0 → 1,11
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x204); |
*(.text) |
} |
} |
|
|
/reloc-003.ld
0,0 → 1,10
SECTIONS |
{ |
.text 0x01014000 : |
{ |
*(.text) |
foo = (. + 0x1FC); |
} |
} |
|
|
/reloc-013.ld
0,0 → 1,12
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x400); |
*(.text) |
} |
} |
|
|
|
/reloc-001.s
0,0 → 1,11
;; Test pc relative relocation |
|
.text |
.global _start |
_start: |
brf0f.s foo |
jmp r13 |
|
|
|
|
/default_layout.d
0,0 → 1,10
#source: simple.s |
#ld: |
#objdump: -h |
|
.*: file format elf32-d10v |
|
Sections: |
Idx Name Size VMA LMA File off Algn |
0 \.text 00000004 01014000 01014000 00001000 2\*\*0 |
CONTENTS, ALLOC, LOAD, READONLY, CODE |
/reloc-005.ld
0,0 → 1,10
SECTIONS |
{ |
.text 0x01014000 : |
{ |
*(.text) |
foo = (. + 0x4000); |
} |
} |
|
|
/reloc-015.ld
0,0 → 1,12
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x20004); |
*(.text) |
} |
} |
|
|
|
/reloc-007.ld
0,0 → 1,8
SECTIONS |
{ |
.text 0x01014000 : |
{ |
*(.text) |
foo = (. + 0x1fff8); |
} |
} |
/reloc-005.s
0,0 → 1,11
;; Test 18 bit pc rel relocation |
|
.text |
.global _start |
_start: |
bra.l foo |
jmp r13 |
|
|
|
|
/reloc-009.ld
0,0 → 1,11
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x100); |
*(.text) |
} |
} |
|
|
/linktest-002.lt
0,0 → 1,2
#source: linktest-001.s |
#source: linktest-002.s |
/reloc-009.s
0,0 → 1,12
;; Test pc relative relocation |
|
.text |
.global _start |
_start: |
nop |
brf0f.s foo |
jmp r13 |
|
|
|
|
/reloc-010.d
0,0 → 1,16
#source: reloc-009.s |
#ld: -T $srcdir/$subdir/reloc-010.ld |
#objdump: -D |
|
# Test 10 bit pc rel reloc negative good boundary case |
|
.*: file format elf32-d10v |
|
Disassembly of section .text: |
|
01014000 <foo>: |
... |
|
01014200 <_start>: |
1014200: 6f 00 4a 80 nop -> brf0f.s 1014000 <foo> |
1014204: 26 0d 5e 00 jmp r13 || nop |
/reloc-011.d
0,0 → 1,6
#source: reloc-009.s |
#ld: -T $srcdir/$subdir/reloc-011.ld |
#error: relocation truncated to fit: R_D10V_10_PCREL_R |
|
# Test 10 bit pc rel reloc negative bad boundary. |
|
/reloc-012.d
0,0 → 1,6
#source: reloc-009.s |
#ld: -T $srcdir/$subdir/reloc-012.ld |
#error: relocation truncated to fit: R_D10V_10_PCREL_R |
|
# Test 10 bit pc rel reloc negative normal bad. |
|
/reloc-013.d
0,0 → 1,16
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-013.ld |
#objdump: -D |
|
# Test 18 bit pc rel reloc negative normal case |
|
.*: file format elf32-d10v |
|
Disassembly of section .text: |
|
01014000 <foo>: |
... |
|
01014400 <_start>: |
1014400: e4 00 ff 00 bra.l 1014000 <foo> |
1014404: 26 0d 5e 00 jmp r13 || nop |
/reloc-014.d
0,0 → 1,16
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-014.ld |
#objdump: -D |
|
# Test 18 bit pc rel reloc negative good boundary case |
|
.*: file format elf32-d10v |
|
Disassembly of section .text: |
|
01014000 <foo>: |
... |
|
01034000 <_start>: |
1034000: e4 00 80 00 bra.l 1014000 <foo> |
1034004: 26 0d 5e 00 jmp r13 || nop |
/reloc-015.d
0,0 → 1,7
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-015.ld |
#objdump: -D |
#error: relocation truncated to fit: R_D10V_18_PCREL |
|
# Test 18 bit pc rel negative reloc bad boundary |
|
/reloc-016.d
0,0 → 1,7
#source: reloc-005.s |
#ld: -T $srcdir/$subdir/reloc-016.ld |
#objdump: -D |
#error: relocation truncated to fit: R_D10V_18_PCREL |
|
# Test 18 bit pc rel negative reloc normal bad |
|
/simple.s
0,0 → 1,5
.text |
.global _start |
_start: |
jmp r13 |
|
/reloc-010.ld
0,0 → 1,11
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x200); |
*(.text) |
} |
} |
|
|
/reloc-002.ld
0,0 → 1,10
SECTIONS |
{ |
.text 0x01014000 : |
{ |
*(.text) |
foo = (. + 0x1F8); |
} |
} |
|
|
/reloc-012.ld
0,0 → 1,11
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x80004); |
*(.text) |
} |
} |
|
|
/reloc-004.ld
0,0 → 1,10
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x400); |
} |
} |
|
|
/reloc-014.ld
0,0 → 1,12
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x20000); |
*(.text) |
} |
} |
|
|
|
/reloc-006.ld
0,0 → 1,8
SECTIONS |
{ |
.text 0x01014000 : |
{ |
*(.text) |
foo = (. + 0x1fff4); |
} |
} |
/d10v.exp
0,0 → 1,253
# Expect script for ld-d10v tests |
# Copyright 2002, 2007 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 Tom Rix, trix@redhat.com |
# |
|
# Test d10v |
|
if ![istarget d10v-*-*] { |
return |
} |
|
# run_link_test FILE |
# Copied from run_dump_test, with the dumping part removed. |
# |
# Assemble a .s file, then run some utility on it and check the output. |
# |
# There should be an assembly language file named FILE.s in the test |
# suite directory. `run_link_test' will assemble and link FILE.s |
# |
# The FILE.lt file begins with zero or more option lines, which specify |
# flags to pass to the assembler, the program to run to dump the |
# assembler's output, and the options it wants. The option lines have |
# the syntax: |
# |
# # OPTION: VALUE |
# |
# OPTION is the name of some option, like "name" or "ld", and |
# VALUE is OPTION's value. The valid options are described below. |
# Whitespace is ignored everywhere, except within VALUE. The option |
# list ends with the first line that doesn't match the above syntax |
# (hmm, not great for error detection). |
# |
# The interesting options are: |
# |
# name: TEST-NAME |
# The name of this test, passed to DejaGNU's `pass' and `fail' |
# commands. If omitted, this defaults to FILE, the root of the |
# .s and .d files' names. |
# |
# as: FLAGS |
# When assembling, pass FLAGS to the assembler. |
# If assembling several files, you can pass different assembler |
# options in the "source" directives. See below. |
# |
# ld: FLAGS |
# Link assembled files using FLAGS, in the order of the "source" |
# directives, when using multiple files. |
# |
# source: SOURCE [FLAGS] |
# Assemble the file SOURCE.s using the flags in the "as" directive |
# and the (optional) FLAGS. If omitted, the source defaults to |
# FILE.s. |
# This is useful if several .x files want to share a .s file. |
# More than one "source" directive can be given, which is useful |
# when testing linking. |
# |
# xfail: TARGET |
# The test is expected to fail on TARGET. This may occur more than |
# once. |
# |
# target: TARGET |
# Only run the test for TARGET. This may occur more than once; the |
# target being tested must match at least one. |
# |
# notarget: TARGET |
# Do not run the test for TARGET. This may occur more than once; |
# the target being tested must not match any of them. |
# |
# Each option may occur at most once unless otherwise mentioned. |
# |
|
proc run_link_test { name } { |
global subdir srcdir |
global AS LD |
global ASFLAGS LDFLAGS |
global host_triplet runtests |
|
if [string match "*/*" $name] { |
set file $name |
set name [file tail $name] |
} else { |
set file "$srcdir/$subdir/$name" |
} |
|
if ![runtest_file_p $runtests $name] then { |
return |
} |
|
set opt_array [slurp_options "${file}.lt"] |
if { $opt_array == -1 } { |
perror "error reading options from $file.lt" |
unresolved $subdir/$name |
return |
} |
set dumpfile tmpdir/dump.out |
set run_ld 0 |
set opts(as) {} |
set opts(ld) {} |
set opts(xfail) {} |
set opts(target) {} |
set opts(notarget) {} |
set opts(name) {} |
set opts(source) {} |
set asflags(${file}.s) {} |
|
foreach i $opt_array { |
set opt_name [lindex $i 0] |
set opt_val [lindex $i 1] |
if ![info exists opts($opt_name)] { |
perror "unknown option $opt_name in file $file.lt" |
unresolved $subdir/$name |
return |
} |
|
switch -- $opt_name { |
xfail {} |
target {} |
notarget {} |
source { |
# Move any source-specific as-flags to a separate array to |
# simplify processing. |
if { [llength $opt_val] > 1 } { |
set asflags([lindex $opt_val 0]) [lrange $opt_val 1 end] |
set opt_val [lindex $opt_val 0] |
} else { |
set asflags($opt_val) {} |
} |
} |
default { |
if [string length $opts($opt_name)] { |
perror "option $opt_name multiply set in $file.lt" |
unresolved $subdir/$name |
return |
} |
} |
} |
set opts($opt_name) [concat $opts($opt_name) $opt_val] |
} |
|
# Decide early whether we should run the test for this target. |
if { [llength $opts(target)] > 0 } { |
set targmatch 0 |
foreach targ $opts(target) { |
if [istarget $targ] { |
set targmatch 1 |
break |
} |
} |
if { $targmatch == 0 } { |
return |
} |
} |
foreach targ $opts(notarget) { |
if [istarget $targ] { |
return |
} |
} |
|
if { $opts(name) == "" } { |
set testname "$subdir/$name" |
} else { |
set testname $opts(name) |
} |
|
if { $opts(source) == "" } { |
set sourcefiles [list ${file}.s] |
} else { |
set sourcefiles {} |
foreach sf $opts(source) { |
lappend sourcefiles "$srcdir/$subdir/$sf" |
# Must have asflags indexed on source name. |
set asflags($srcdir/$subdir/$sf) $asflags($sf) |
} |
} |
|
# Time to setup xfailures. |
foreach targ $opts(xfail) { |
setup_xfail $targ |
} |
|
# Assemble each file. |
set objfiles {} |
for { set i 0 } { $i < [llength $sourcefiles] } { incr i } { |
set sourcefile [lindex $sourcefiles $i] |
|
set objfile "tmpdir/dump$i.o" |
lappend objfiles $objfile |
set cmd "$AS $ASFLAGS $opts(as) $asflags($sourcefile) -o $objfile $sourcefile" |
|
send_log "$cmd\n" |
set cmdret [catch "exec $cmd" comp_output] |
set comp_output [prune_warnings $comp_output] |
|
# We accept errors at assembly stage too, unless we're supposed to |
# link something. |
if { $cmdret != 0 || ![string match "" $comp_output] } then { |
send_log "$comp_output\n" |
verbose "$comp_output" 3 |
fail $testname |
return |
} |
} |
|
# Link the file(s). |
set objfile "tmpdir/dump" |
set cmd "$LD $LDFLAGS $opts(ld) -o $objfile $objfiles" |
|
send_log "$cmd\n" |
set cmdret [catch "exec $cmd" comp_output] |
set comp_output [prune_warnings $comp_output] |
|
if { $cmdret != 0 || ![string match "" $comp_output] } then { |
|
send_log "$comp_output\n" |
verbose "$comp_output" 3 |
fail $testname |
return |
} |
pass $testname |
} |
|
|
set test_list [lsort [glob -nocomplain $srcdir/$subdir/*.d]] |
foreach test $test_list { |
# We need to strip the ".d", but can leave the dirname. |
verbose [file rootname $test] |
run_dump_test [file rootname $test] |
} |
|
set test_list [lsort [glob -nocomplain $srcdir/$subdir/*.lt]] |
foreach test $test_list { |
# We need to strip the ".lt", but can leave the dirname. |
verbose [file rootname $test] |
run_link_test [file rootname $test] |
} |
/reloc-016.ld
0,0 → 1,12
SECTIONS |
{ |
.text 0x01014000 : |
{ |
foo = .; |
. = (. + 0x800004); |
*(.text) |
} |
} |
|
|
|
/reloc-008.ld
0,0 → 1,8
SECTIONS |
{ |
.text 0x01014000 : |
{ |
*(.text) |
foo = (. + 0x41fff8); |
} |
} |