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