Commit | Line | Data |
---|---|---|
0fb0cc75 | 1 | # Copyright 2003, 2007, 2008, 2009 Free Software Foundation, Inc. |
dabf8a35 MK |
2 | |
3 | # This program is free software; you can redistribute it and/or modify | |
4 | # it under the terms of the GNU General Public License as published by | |
e22f8b7c | 5 | # the Free Software Foundation; either version 3 of the License, or |
dabf8a35 MK |
6 | # (at your option) any later version. |
7 | # | |
8 | # This program is distributed in the hope that it will be useful, | |
9 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
10 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
11 | # GNU General Public License for more details. | |
12 | # | |
13 | # You should have received a copy of the GNU General Public License | |
e22f8b7c | 14 | # along with this program. If not, see <http://www.gnu.org/licenses/>. |
dabf8a35 MK |
15 | |
16 | # Please email any bugs, comments, and/or additions to this file to: | |
17 | # bug-gdb@gnu.org | |
18 | ||
19 | # This file is part of the gdb testsuite. | |
20 | ||
21 | if $tracelevel { | |
22 | strace $tracelevel | |
23 | } | |
24 | ||
25 | # | |
26 | # Test floating-point related functionality. | |
27 | # | |
28 | ||
29 | set prms_id 0 | |
30 | set bug_id 0 | |
31 | ||
aa81e255 | 32 | if { [prepare_for_testing float.exp float run.c] } { |
b60f0898 | 33 | return -1 |
dabf8a35 MK |
34 | } |
35 | ||
dabf8a35 MK |
36 | # Set it up at a breakpoint so we have its registers. |
37 | ||
38 | if ![runto_main] then { | |
39 | perror "couldn't run to breakpoint" | |
40 | continue | |
41 | } | |
42 | ||
43 | # Test "info float". | |
44 | ||
d80dbb52 RH |
45 | if { [istarget "alpha*-*-*"] } then { |
46 | gdb_test "info float" "f0.*" "info float" | |
47 | } elseif { [istarget "arm*-*-*"] || \ | |
dabf8a35 MK |
48 | [istarget "xscale*-*-*"] || \ |
49 | [istarget "strongarm*-*-*"] } then { | |
bd5ddfe8 DJ |
50 | gdb_test_multiple "info float" "info float" { |
51 | -re "Software FPU type.*mask:.*flags:.*$gdb_prompt $" { | |
52 | pass "info float (FPA)" | |
53 | } | |
58d6951d DJ |
54 | -re "fpscr.*s0.*s1.*s31.*$gdb_prompt $" { |
55 | # Only check for single precision; d0 might be a vector register | |
56 | # if we have NEON. | |
57 | pass "info float (VFP)" | |
58 | } | |
bd5ddfe8 DJ |
59 | -re "No floating.point info available for this processor.*" { |
60 | pass "info float (without FPU)" | |
61 | } | |
62 | } | |
7b34ad4e | 63 | } elseif { [istarget "i?86-*-*"] || [istarget "x86_64-*-*"] } then { |
dabf8a35 | 64 | gdb_test "info float" "R7:.*Status Word:.*Opcode:.*" "info float" |
21c38304 JJ |
65 | } elseif [istarget "ia64-*-*"] then { |
66 | gdb_test "info float" "f0.*f1.*f127.*" "info float" | |
83876b3b | 67 | } elseif [istarget "m68k-*-*"] then { |
d8f82aba DJ |
68 | gdb_test_multiple "info float" "info_float" { |
69 | -re "fp0.*fp1.*fp7.*$gdb_prompt $" { | |
70 | pass "info float (with FPU)" | |
71 | } | |
72 | -re "No floating.point info available for this processor.*" { | |
73 | pass "info float (without FPU)" | |
74 | } | |
75 | } | |
caeb605f MH |
76 | } elseif [istarget "mips*-*-*"] then { |
77 | gdb_test "info float" "f0:.*flt:.*dbl:.*" "info float" | |
384e1a61 | 78 | } elseif [istarget "powerpc*-*-*"] then { |
d8f82aba DJ |
79 | gdb_test_multiple "info float" "info_float" { |
80 | -re "f0.*f1.*f31.*fpscr.*$gdb_prompt $" { | |
81 | pass "info float (with FPU)" | |
82 | } | |
83 | -re "No floating.point info available for this processor.*" { | |
84 | pass "info float (without FPU)" | |
85 | } | |
86 | } | |
d0f54f9d JB |
87 | } elseif [istarget "s390*-*-*"] then { |
88 | gdb_test "info float" "fpc.*f0.*f1.*f15.*" "info float" | |
c99c59c3 MS |
89 | } elseif [istarget "sh*-*"] then { |
90 | # SH may or may not have an FPU | |
91 | gdb_test_multiple "info float" "info float" { | |
92 | -re "fpul.*fr0.*fr1.*fr15.*$gdb_prompt $" { | |
93 | pass "info float (with FPU)" | |
94 | } | |
95 | -re "No floating.point info available for this processor.*" { | |
96 | pass "info float (without FPU)" | |
97 | } | |
98 | } | |
c892bb64 RC |
99 | } elseif [istarget "hppa*-*"] then { |
100 | gdb_test "info float" "fr4.*fr4R.*fr31R.*" "info float" | |
880da185 DM |
101 | } elseif [istarget "sparc*-*-*"] then { |
102 | gdb_test "info float" "f0.*f1.*f31.*d0.*d30.*" "info float" | |
dabf8a35 | 103 | } else { |
c892bb64 | 104 | gdb_test "info float" "No floating.point info available for this processor." "info float (unknown target)" |
dabf8a35 | 105 | } |