Home | History | Annotate | Line # | Download | only in gdb.arch
mips-fcr.exp revision 1.1.1.2
      1  1.1.1.2  christos # Copyright (C) 2016-2017 Free Software Foundation, Inc.
      2      1.1  christos 
      3      1.1  christos # This program is free software; you can redistribute it and/or modify
      4      1.1  christos # it under the terms of the GNU General Public License as published by
      5      1.1  christos # the Free Software Foundation; either version 3 of the License, or
      6      1.1  christos # (at your option) any later version.
      7      1.1  christos #
      8      1.1  christos # This program is distributed in the hope that it will be useful,
      9      1.1  christos # but WITHOUT ANY WARRANTY; without even the implied warranty of
     10      1.1  christos # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     11      1.1  christos # GNU General Public License for more details.
     12      1.1  christos #
     13      1.1  christos # You should have received a copy of the GNU General Public License
     14      1.1  christos # along with this program.  If not, see <http://www.gnu.org/licenses/>.
     15      1.1  christos 
     16      1.1  christos # Contributed by Imagination Technologies, written by Maciej W. Rozycki.
     17      1.1  christos 
     18      1.1  christos # Test MIPS Floating Point Control Register handling.
     19      1.1  christos 
     20      1.1  christos if { ![istarget "mips*-*-*"] } then {
     21      1.1  christos     verbose "Skipping MIPS Floating Point Control Register tests."
     22      1.1  christos     return
     23      1.1  christos }
     24      1.1  christos 
     25      1.1  christos standard_testfile
     26      1.1  christos 
     27  1.1.1.2  christos if { [prepare_for_testing "failed to prepare" ${testfile}] } {
     28      1.1  christos     return
     29      1.1  christos }
     30      1.1  christos 
     31      1.1  christos if ![runto_main] {
     32      1.1  christos     return
     33      1.1  christos }
     34      1.1  christos 
     35      1.1  christos # First check if we have an FPU available in the first place.
     36      1.1  christos gdb_test_multiple "show mipsfpu" "check for MIPS floating-point coprocessor" {
     37      1.1  christos     -re "The MIPS floating-point coprocessor .*\(absent\|unknown\).*$gdb_prompt $" {
     38      1.1  christos 	unsupported "no MIPS floating-point coprocessor in the processor"
     39      1.1  christos 	return
     40      1.1  christos     }
     41      1.1  christos     -re "The MIPS floating-point coprocessor .*$gdb_prompt $" {
     42      1.1  christos 	verbose "MIPS floating-point coprocessor check successful."
     43      1.1  christos     }
     44      1.1  christos     default {
     45      1.1  christos 	fail
     46      1.1  christos 	return
     47      1.1  christos     }
     48      1.1  christos }
     49      1.1  christos 
     50      1.1  christos # Now check that FCRs are accessible and 32-bit wide.
     51      1.1  christos gdb_test "info registers \$fcsr" "fcsr: $hex"
     52      1.1  christos gdb_test "print sizeof \$fcsr" "\\\$$decimal = 4"
     53      1.1  christos gdb_test "info registers \$fir" "fir: $hex"
     54      1.1  christos gdb_test "print sizeof \$fir" "\\\$$decimal = 4"
     55