URL
https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk
Subversion Repositories openrisc_me
[/] [openrisc/] [trunk/] [gnu-src/] [gdb-7.1/] [gdb/] [testsuite/] [gdb.cell/] [f-regs.exp] - Rev 227
Compare with Previous | Blame | View Log
# Copyright 2009 Free Software Foundation, Inc.## 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, see <http://www.gnu.org/licenses/>.## Contributed by Markus Deuling <deuling@de.ibm.com>.## Testsuite for Cell Broadband Engine combined debugger# This testcase tests access to SPU vector registers while language is fortran.load_lib cell.expset ppu_file "break"set ppu_src ${srcdir}/${subdir}/${ppu_file}.cset ppu_bin ${objdir}/${subdir}/${ppu_file}set spu_file "break-spu"set spu_src ${srcdir}/${subdir}/${spu_file}.cset spu_bin ${objdir}/${subdir}/${spu_file}if {[skip_cell_tests]} {return 0}# Compile SPU binary.if { [gdb_compile_cell_spu $spu_src $spu_bin executable {debug}] != "" } {unsupported "Compiling spu binary failed."return -1}# Compile PPU binary.if { [gdb_cell_embedspu $spu_bin $spu_bin-embed.o {debug}] != "" } {unsupported "Embedding spu binary failed."return -1}if { [gdb_compile_cell_ppu [list $ppu_src $spu_bin-embed.o] $ppu_bin executable {debug}] != "" } {unsupported "Compiling ppu binary failed."return -1}if [get_compiler_info ${ppu_bin}] {return -1}proc check_vector_regs {} {for {set check_reg 0} {$check_reg < 128} {incr check_reg} {gdb_test "p \$r$check_reg" \"r$check_reg.*=.*\(.*\).*" \"p \$r$check_reg"gdb_test "ptype \$r$check_reg" \"type = Type,.*C_Union :: __spu_builtin_type_vec128.*int128_t :: uint128.*int64_t :: v2_int64.*int32_t :: v4_int32\(.*\).*int16_t :: v8_int16\(.*\).*int8_t :: v16_int8\(.*\).*double :: v2_double\(.*\).*float :: v4_float\(.*\).*End Type __spu_builtin_type_vec128.*" \"ptype \$r$check_reg"}}gdb_exitgdb_startgdb_reinitialize_dir $srcdir/$subdirgdb_load ${ppu_bin}# No programm running, no registers should be available.gdb_test "info all-registers" \"The program has no registers now." \"info all-registers"if ![runto_main] then {fail "Can't run to main"return 0}cont_spu_maingdb_test "set language fortran" \"Warning: the current language does not match this frame.*" \"set language fortran"check_vector_regsgdb_exitreturn 0
