Home | History | Annotate | Line # | Download | only in gdb.arch
mips-fcr.exp revision 1.1
      1  1.1  christos # Copyright (C) 2016 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  christos if { [prepare_for_testing ${testfile}.exp ${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