* NEWS: Mention new PRU target. * Makefile.am: Add PRU target. * configure.tgt: Ditto. * emulparams/pruelf.sh: New file. * emultempl/pruelf.em: New file. * scripttempl/pru.sc: New file. * Makefile.in: Regenerate. * testsuite/ld-pru/emit-relocs-1.d: New PRU testcase file. * testsuite/ld-pru/emit-relocs-1.ld: Ditto. * testsuite/ld-pru/emit-relocs-1a.s: Ditto. * testsuite/ld-pru/emit-relocs-1b.s * testsuite/ld-pru/ldi32.d: Ditto. * testsuite/ld-pru/ldi32.s: Ditto. * testsuite/ld-pru/ldi32_symbol.s: Ditto. * testsuite/ld-pru/norelax_ldi32-data.d: Ditto. * testsuite/ld-pru/norelax_ldi32-dis.d: Ditto. * testsuite/ld-pru/pcrel_s10.d: Ditto. * testsuite/ld-pru/pcrel_s10.s: Ditto. * testsuite/ld-pru/pcrel_s10_label.s: Ditto. * testsuite/ld-pru/pcrel_u8-illegal.d: Ditto. * testsuite/ld-pru/pcrel_u8-illegal.s: Ditto. * testsuite/ld-pru/pcrel_u8-illegal2.d: Ditto. * testsuite/ld-pru/pcrel_u8-illegal2.s: Ditto. * testsuite/ld-pru/pcrel_u8-illegal3.d: Ditto. * testsuite/ld-pru/pcrel_u8-illegal3.s: Ditto. * testsuite/ld-pru/pcrel_u8.d: Ditto. * testsuite/ld-pru/pcrel_u8.s: Ditto. * testsuite/ld-pru/pcrel_u8_label.s: Ditto. * testsuite/ld-pru/pmem.d: Ditto. * testsuite/ld-pru/pmem.s: Ditto. * testsuite/ld-pru/pmem_symbol.s: Ditto. * testsuite/ld-pru/pru.exp: Ditto. * testsuite/ld-pru/relax_ldi32-data.d: Ditto. * testsuite/ld-pru/relax_ldi32-dis.d: Ditto. * testsuite/ld-pru/relax_ldi32.s: Ditto. * testsuite/ld-pru/relax_ldi32_symbol.s: Ditto. * testsuite/ld-pru/reloc.d: Ditto. * testsuite/ld-pru/reloc.s: Ditto. * testsuite/ld-pru/reloc_symbol.s: Ditto. * testsuite/ld-pru/u16.d: Ditto. * testsuite/ld-pru/u16.s: Ditto. * testsuite/ld-pru/u16_symbol.s: Ditto. PRU does not export __end symbol because it is ambiguous for it. Users are expected to use instead the section markers __text_end, __data_end, __bss_end or __noinit_end. * testsuite/lib/ld-lib.exp (check_shared_lib_support): No shared libraries are supported for PRU. (check_gc_sections_available): Mark PRU as not supported. * testsuite/ld-elf/eh-frame-hdr.d: Disable for PRU. * testsuite/ld-elf/endsym.d: Likewise. * testsuite/ld-elf/group8a.d: Likewise. * testsuite/ld-elf/group8b.d: Likewise. * testsuite/ld-elf/group9a.d: Likewise. * testsuite/ld-elf/group9b.d: Likewise. * testsuite/ld-elf/merge.d: Likewise. * testsuite/ld-elf/pr12851.d: Likewise. * testsuite/ld-elf/pr14926.d: Likewise. * testsuite/ld-elf/sec-to-seg.exp: Likewise. * testsuite/ld-elf/sec64k.exp: Mark sec64k case as too big for PRU. * testsuite/ld-srec/srec.exp (run_srec_test): Add setup for PRU. Signed-off-by: Dimitar Dimitrov <dimitar@dinux.eu>
104 lines
3.3 KiB
Plaintext
104 lines
3.3 KiB
Plaintext
# Test the assigment of sections to segments.
|
|
#
|
|
# Copyright (C) 2008-2016 Free Software Foundation, Inc.
|
|
# Contributed by Red Hat.
|
|
#
|
|
# 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.
|
|
|
|
set testname "assignment of ELF sections to segments"
|
|
|
|
if {! [is_elf_format] } {
|
|
unsupported $testname
|
|
return
|
|
}
|
|
|
|
if { ! [ld_assemble $as $srcdir/$subdir/sec-to-seg1.s tmpdir/sec-to-seg1.o]
|
|
|| ! [ld_assemble $as $srcdir/$subdir/sec-to-seg2.s tmpdir/sec-to-seg2.o]} then {
|
|
unresolved $testname
|
|
return
|
|
}
|
|
|
|
proc sec_to_seg_test { testname scriptname same_seg } {
|
|
global srcdir
|
|
global subdir
|
|
global ld
|
|
global exec_output
|
|
global READELF
|
|
|
|
if {! [ld_simple_link $ld tmpdir/sec-to-seg "-T $srcdir/$subdir/$scriptname tmpdir/sec-to-seg1.o tmpdir/sec-to-seg2.o"] } then {
|
|
fail $testname
|
|
return 0
|
|
}
|
|
|
|
send_log "$READELF --program-headers --section-headers tmpdir/sec-to-seg\n"
|
|
set exec_output [run_host_cmd "$READELF" "--program-headers --section-headers tmpdir/sec-to-seg"]
|
|
|
|
if { $same_seg == 1 } {
|
|
if {! [regexp ".*.sec1 .sec2" $exec_output] } {
|
|
fail $testname
|
|
return 0
|
|
}
|
|
} else {
|
|
if { [regexp ".*.sec1 .sec2" $exec_output] } {
|
|
fail $testname
|
|
return 0
|
|
}
|
|
}
|
|
|
|
pass $testname
|
|
return 1
|
|
}
|
|
|
|
# Assuming a pagesize of 0x1000 then:
|
|
#
|
|
# Test Sec1 End Sec 2 Start Expected Result
|
|
# ---- -------- ----------- ---------------
|
|
# A 00001042 00001043 Both sections on same page: assign to same segment.
|
|
# B 00001042 00002044 Sections on adjacent pages: assign to same segment.
|
|
# C 00001042 00003044 Sections on disjoint pages: assign to separate segments.
|
|
|
|
# These targets have a pagesize of 1, so they will always end up
|
|
# placing the two sections in separate segments in the B test.
|
|
if { [istarget avr-*-*]
|
|
|| [istarget cr16-*-*]
|
|
|| [istarget crx-*-*]
|
|
|| [istarget dlx-*-*]
|
|
|| [istarget ft32-*-*]
|
|
|| [istarget h8300-*-*]
|
|
|| [istarget i960-*-*]
|
|
|| [istarget ip2k-*-*]
|
|
|| [istarget m32r-*-*]
|
|
|| [istarget m88k-*-*]
|
|
|| [istarget moxie-*-*]
|
|
|| [istarget msp430-*-*]
|
|
|| [istarget mt-*-*]
|
|
|| [istarget pru-*-*]
|
|
|| [istarget visium-*-*]
|
|
} {
|
|
set B_test_same_seg 0
|
|
} else {
|
|
set B_test_same_seg 1
|
|
}
|
|
|
|
sec_to_seg_test "assignment of ELF sections to segments (same page)" "sec-to-seg-script-same-page.t" 1
|
|
sec_to_seg_test "assignment of ELF sections to segments (adjacent pages)" "sec-to-seg-script-adjoining-pages.t" $B_test_same_seg
|
|
sec_to_seg_test "assignment of ELF sections to segments (disjoint pages)" "sec-to-seg-script-disjoint-pages.t" 0
|
|
|
|
|
|
# FIXME: Add more tests to check other rules of section to segment assignment.
|