Home | History | Annotate | Line # | Download | only in gdb.arch
      1  1.1.1.6  christos # Copyright (C) 2016-2024 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.1.6  christos require {istarget "mips*-*-*"}
     21      1.1  christos 
     22      1.1  christos standard_testfile
     23      1.1  christos 
     24  1.1.1.2  christos if { [prepare_for_testing "failed to prepare" ${testfile}] } {
     25      1.1  christos     return
     26      1.1  christos }
     27      1.1  christos 
     28      1.1  christos if ![runto_main] {
     29      1.1  christos     return
     30      1.1  christos }
     31      1.1  christos 
     32      1.1  christos # First check if we have an FPU available in the first place.
     33      1.1  christos gdb_test_multiple "show mipsfpu" "check for MIPS floating-point coprocessor" {
     34      1.1  christos     -re "The MIPS floating-point coprocessor .*\(absent\|unknown\).*$gdb_prompt $" {
     35      1.1  christos 	unsupported "no MIPS floating-point coprocessor in the processor"
     36      1.1  christos 	return
     37      1.1  christos     }
     38      1.1  christos     -re "The MIPS floating-point coprocessor .*$gdb_prompt $" {
     39      1.1  christos 	verbose "MIPS floating-point coprocessor check successful."
     40      1.1  christos     }
     41      1.1  christos     default {
     42      1.1  christos 	fail
     43      1.1  christos 	return
     44      1.1  christos     }
     45      1.1  christos }
     46      1.1  christos 
     47      1.1  christos # Now check that FCRs are accessible and 32-bit wide.
     48      1.1  christos gdb_test "info registers \$fcsr" "fcsr: $hex"
     49      1.1  christos gdb_test "print sizeof \$fcsr" "\\\$$decimal = 4"
     50      1.1  christos gdb_test "info registers \$fir" "fir: $hex"
     51      1.1  christos gdb_test "print sizeof \$fir" "\\\$$decimal = 4"
     52