diff options
author | Tom de Vries <tdevries@suse.de> | 2022-11-28 13:57:17 +0100 |
---|---|---|
committer | Tom de Vries <tdevries@suse.de> | 2022-11-28 13:57:17 +0100 |
commit | 85819864f7cbf813cde00cf3bed30a38414e1bd8 (patch) | |
tree | 2a0299083b933addf6d099726b8c1cf16dece7d0 | |
parent | 2650ea9730e31fc5c9111afc1a689dbca76707f5 (diff) | |
download | gdb-85819864f7cbf813cde00cf3bed30a38414e1bd8.zip gdb-85819864f7cbf813cde00cf3bed30a38414e1bd8.tar.gz gdb-85819864f7cbf813cde00cf3bed30a38414e1bd8.tar.bz2 |
[gdb/testsuite] Fix gdb.arch/altivec-regs.exp with gcc 4.8.5
On powerpc64le-linux, using gcc 4.8.5, I run into:
...
(gdb) PASS: gdb.arch/altivec-regs.exp: next (1)
next^M
11 c = vec_add (a, b);^M
(gdb) PASS: gdb.arch/altivec-regs.exp: next (2)
print/x a^M
$67 = {0xfefefefe, 0xfefefefe, 0xfefefefe, 0xfefefefe}^M
(gdb) FAIL: gdb.arch/altivec-regs.exp: print vector parameter a
...
Looking at the disassembly and the debug info, it's clear why there's
a FAIL.
The debug info says that the variable can be found at some stack location, but
the instructions don't seem to be writing there.
We can work around this by marking variable a volatile. Likewise for b.
Note that marking the variables as volatile doesn't change the location
information.
Tested on power64le-linux.
-rw-r--r-- | gdb/testsuite/gdb.arch/altivec-regs.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/gdb/testsuite/gdb.arch/altivec-regs.c b/gdb/testsuite/gdb.arch/altivec-regs.c index 4d4fe3f..8f3b729 100644 --- a/gdb/testsuite/gdb.arch/altivec-regs.c +++ b/gdb/testsuite/gdb.arch/altivec-regs.c @@ -2,7 +2,7 @@ #include <stdio.h> vector unsigned int -vector_fun (vector unsigned int a, vector unsigned int b) +vector_fun (volatile vector unsigned int a, volatile vector unsigned int b) { vector unsigned int c; a = ((vector unsigned int) vec_splat_u8(2)); |