1 # Copyright
2003-2019 Free Software Foundation
, Inc.
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
5 # the Free Software Foundation
; either version
3 of the License
, or
6 #
(at your option
) any later version.
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.
13 # You should have received a copy of the GNU General Public License
14 # along with this
program.
If not
, see
<http
://www.gnu.org
/licenses
/>.
17 # Tests
for Powerpc e500 ABI
21 # This file uses e500
-abi.c
for input.
25 if ![istarget
"powerpc-*eabispe"] then {
26 verbose
"Skipping e500 abi tests."
30 set testfile
"e500-abi"
31 set binfile $
{objdir
}/$
{subdir
}/$
{testfile
}
33 set src1 $
{srcdir
}/$
{subdir
}/$
{testfile
}.c
35 if { [gdb_compile $
{src1
} $
{binfile
} executable
{debug nowarnings
}] != "" } {
36 untested
"failed to compile"
41 gdb_reinitialize_dir $srcdir
/$subdir
45 # Run to `main
' where we begin our tests.
48 if ![runto_main] then {
49 fail "can't run to main
"
53 gdb_test
"b marker" "Breakpoint 2 at.*file.*e500-abi.c, line \[0-9\]+." "break marker"
54 gdb_test
"continue" "Breakpoint 2.*marker.*e500-abi.c.*" "continue to marker"
55 gdb_test
"finish" "Run till exit from .0.*marker.*at.*e500-abi.c.*main \\(\\) at.*e500-abi.c.*res_vec = vec_func \\(a_vec,.*goes in r3.*" "back to main (1)"
57 # now all the arguments of vec_func are initialized
59 set pattern
"vec_func .a_vec_f=.0, 55., b_vec_f=.0, 66., c_vec_f=.3.14.*2.18.*, d_vec_f=.5, 4., e_vec_f=.5, 6., f_vec_f=.6, 6, 7, 1., g_vec_f=.6, 6, 7, 9., h_vec_f=.3, 2., i_vec_f=.3, 2., l_vec_f=.3, 5., m_vec_f=.6, 9.."
62 append pattern1
" at.*e500-abi.c.*x = 2;"
64 # Now let
's call the function. This function has > 8 args,
65 # the last ones will go on the stack.
66 gdb_test "p vec_func(a_vec,b_vec,c_vec,d_vec,e_vec,f_vec,g_vec,h_vec,i_vec,l_vec,m_vec)" \
67 ".\[0-9\]+ = .6, 63." "call inferior function with vectors (1) "
69 # Let's
call the function again with dummy arguments. This is to clean
70 # up the contents of the ev registers before the next
call.
71 gdb_test
"p vec_func(a_vec_d,b_vec_d,c_vec_d,d_vec_d,e_vec_d,f_vec_d,g_vec_d,h_vec_d,i_vec_d,l_vec_d,m_vec_d)" \
72 ".\[0-9\]+ = .1, 1." "call inferior function with vectors (2) "
74 # Let
's step into the function, to see if the args are printed correctly.
79 # Let's see
if the result is returned correctly.
81 "Run till exit from .0.* at.*e500-abi.c.*main.*res_vec = vec_func .a_vec,.*goes in r3.*Value returned is.*= .6, 63." \
82 "vector value returned correctly"