OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [gdb-7.2/] [gdb-7.2-or32-1.0rc1/] [gdb/] [testsuite/] [gdb.hp/] [gdb.base-hp/] [reg.exp] - Blame information for rev 779

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 330 jeremybenn
# This test script is part of GDB, the GNU debugger.
2
 
3
# Copyright 1998, 1999, 2001, 2004,
4
# Free Software Foundation, Inc.
5
 
6
# This program is free software; you can redistribute it and/or modify
7
# it under the terms of the GNU General Public License as published by
8
# the Free Software Foundation; either version 3 of the License, or
9
# (at your option) any later version.
10
#
11
# This program is distributed in the hope that it will be useful,
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
# GNU General Public License for more details.
15
#
16
# You should have received a copy of the GNU General Public License
17
# along with this program.  If not, see .  */
18
 
19
# Tests of wide register displays for GDB on HPPA 2.0 machines
20
 
21
# use this to debug:
22
#log_user 1
23
 
24
if $tracelevel then {
25
        strace $tracelevel
26
        }
27
 
28
if { [skip_hp_tests] } then { continue }
29
 
30
set testfile "reg"
31
 
32
if [istarget "hppa64-hp-hpux*"] {
33
    verbose "reg.exp is not for PA2.0W."
34
    return 0
35
}
36
set srcfile ${testfile}.s
37
set binfile ${objdir}/${subdir}/${testfile}
38
 
39
# To build a pa 2.0 executable
40
#
41
#     as -o reg reg.s
42
# or
43
#     cc -g -o reg reg.s
44
#
45
# The +DA2.0N flag doesn't seem to be needed.
46
#
47
# Don't reject if there are warnings, as we expect this warning:
48
#
49
#    (Warning) At least one PA 2.0 object file (pa2.0_test2.o) was detected.
50
#    The linked output may not run on a PA 1.x system.
51
#
52
 
53
if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
54
     untested reg.exp
55
     return -1
56
}
57
 
58
gdb_exit
59
gdb_start
60
gdb_reinitialize_dir $srcdir/$subdir
61
gdb_load ${binfile}
62
 
63
# test machine--there's no 2.0n architecture, so we have
64
# to try to run the app.
65
#
66
send_gdb "break main\n"
67
    gdb_expect {
68
        -re "Breakpoint.*$gdb_prompt $" {
69
            pass "initial set-up"
70
        }
71
        -re ".*$gdb_prompt $" {
72
            fail "initial set-up"
73
        }
74
        timeout {
75
            fail "initial set-up (timeout)"
76
        }
77
    }
78
 
79
send_gdb "run\n"
80
    gdb_expect {
81
        -re ".*Executable file incompatible with hardware.*$gdb_prompt $" {
82
            # Not hppa2.0 machine
83
            #
84
            return 0
85
        }
86
        -re "Cannot exec.*$gdb_prompt $" {
87
            # Not hppa2.0 machine
88
            #
89
            return 0
90
        }
91
        -re ".*Starting program:.*$gdb_prompt $" {
92
            pass "Ready to start test"
93
        }
94
        timeout {
95
            fail "initial set-up, part 2 (timeout)"
96
            return 0
97
        }
98
    }
99
 
100
# Let the program set known values.  This secretly deletes
101
# the breakpoint at main and re-runs to mainend.
102
#
103
runto mainend
104
 
105
# Look for known values
106
#
107
# The output format changed between gdb 6.1.1 and gdb HEAD 2004-06-01.
108
#
109
#   gdb 6.1.1:
110
#   (gdb) info reg r1
111
#   r1 1
112
#
113
#   gdb HEAD 2004-06-01:
114
#   (gdb) info reg r1
115
#   r1             0x1     1
116
#
117
# For now, I accept both formats.  In the future, you can remove
118
# the old gdb 6.1.1 format.
119
#
120
# -- chastain 2004-06-26
121
 
122
set ws "\[\r\n\t \]+"
123
 
124
proc hp_integer_reg {regname vhex vdec} {
125
  global ws
126
  set value_611 "$regname${ws}$vhex"
127
  set value_new "$regname${ws}0x$vhex${ws}$vdec"
128
  gdb_test "info reg $regname" "$value_611|$value_new"
129
}
130
 
131
hp_integer_reg "r1"      "1"     "1"
132
hp_integer_reg "r4"      "2"     "2"
133
hp_integer_reg "r5"      "4"     "4"
134
hp_integer_reg "r6"      "8"     "8"
135
hp_integer_reg "r7"     "10"    "16"
136
hp_integer_reg "r8"     "20"    "32"
137
hp_integer_reg "r9"     "40"    "64"
138
hp_integer_reg "r10"    "80"   "128"
139
hp_integer_reg "r11"   "100"   "256"
140
hp_integer_reg "r12"   "200"   "512"
141
hp_integer_reg "r13"   "400"  "1024"
142
hp_integer_reg "r14"   "800"  "2048"
143
hp_integer_reg "r15"  "1000"  "4096"
144
hp_integer_reg "r16"  "2000"  "8192"
145
 
146
# Two odd variants that GDB supports are:
147
#   "1" means "r1", and
148
#   "$1" means "r1"
149
 
150
hp_integer_reg "1" "1" "1"
151
hp_integer_reg "4" "2" "2"
152
 
153
set name "info reg \$1"
154
gdb_test_multiple "info reg \$1" "$name" {
155
    -re "r1${ws}1\r\n$gdb_prompt $" {
156
        pass "$name"
157
    }
158
    -re "r1${ws}0x1${ws}1\r\n$gdb_prompt $" {
159
        pass "$name"
160
    }
161
}
162
 
163
# Verify that GDB responds gracefully to a register ID number that
164
# is out of range.
165
 
166
gdb_test "info reg 999" "Invalid register.*999.*"
167
 
168
# Make sure the floating point status and error registers
169
# don't show up as floating point numbers!
170
 
171
hp_integer_reg "fpsr" "0" "0"
172
hp_integer_reg "fpe1" "0" "0"
173
hp_integer_reg "fpe2" "0" "0"
174
hp_integer_reg "fpe3" "0" "0"
175
hp_integer_reg "fpe4" "0" "0"
176
hp_integer_reg "fpe5" "0" "0"
177
hp_integer_reg "fpe6" "0" "0"
178
hp_integer_reg "fpe7" "0" "0"
179
 
180
# Floating point registers.
181
# TODO: these are old format only.
182
 
183
gdb_test "info reg fr4"  ".*fr4.*(double precision).* 1"
184
gdb_test "info reg fr5"  ".*fr5.*(double precision).* 2"
185
gdb_test "info reg fr6"  ".*fr6.*(double precision).* 2"
186
gdb_test "info reg fr7"  ".*fr7.*(double precision).* 4"
187
gdb_test "info reg fr8"  ".*fr8.*(double precision).* 8"
188
gdb_test "info reg fr9"  ".*fr9.*(double precision).* 32"
189
gdb_test "info reg fr10" ".*fr10.*(double precision).* 256"
190
 
191
# An integer register with a 64-bit value.
192
 
193
set name "info reg r19"
194
gdb_test_multiple "info reg r19" "$name" {
195
    -re "r19${ws}deadbeefbadcadee\r\n$gdb_prompt $" {
196
        # old gdb 6.1.1 format, good result
197
        pass "$name"
198
    }
199
    -re "r19${ws}badcadee\r\n$gdb_prompt $" {
200
        # old gdb 6.1.1 format, bad result
201
        fail "$name (32-bit truncation)"
202
    }
203
    -re "r19${ws}0xdeadbeefbadcadee${ws}16045690984232431086\r\n$gdb_prompt $" {
204
        # new gdb HEAD 2004-06-01 format, good result
205
        pass "$name"
206
    }
207
    -re "r19${ws}0xbadcadee${ws}3135024622\r\n$gdb_prompt $" {
208
        # new gdb HEAD 2004-06-01 format, 32 bit truncation
209
        fail "$name (32-bit truncation)"
210
    }
211
}
212
 
213
set name "print /x \$r19"
214
gdb_test_multiple "print /x \$r19" "$name" {
215
    -re "= 0xdeadbeefbadcadee\r\n$gdb_prompt $" {
216
        pass "$name"
217
    }
218
    -re "= 0xbadcadee\r\n$gdb_prompt $" {
219
        # this was a PASS in the last version so keep it PASS for now
220
        # -- chastain 2004-06-26
221
        pass "$name (32-bit truncation)"
222
    }
223
}
224
 
225
# Need to add tests of setting wide regs too.  E.g.
226
#
227
# set $r4 = 0x1234567890123456
228
# p/x $r4
229
#
230
 
231
# done
232
#
233
gdb_exit
234
 
235
return 0

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.