aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom de Vries <tdevries@suse.de>2022-11-28 13:57:17 +0100
committerTom de Vries <tdevries@suse.de>2022-11-28 13:57:17 +0100
commit85819864f7cbf813cde00cf3bed30a38414e1bd8 (patch)
tree2a0299083b933addf6d099726b8c1cf16dece7d0
parent2650ea9730e31fc5c9111afc1a689dbca76707f5 (diff)
downloadgdb-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.c2
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));