|
|
b94e32 |
From FEDORA_PATCHES Mon Sep 17 00:00:00 2001
|
|
|
b94e32 |
From: Fedora GDB patches <invalid@email.com>
|
|
|
b94e32 |
Date: Fri, 27 Oct 2017 21:07:50 +0200
|
|
|
b94e32 |
Subject: gdb-rhbz1261564-aarch64-hw-watchpoint-test.patch
|
|
|
b94e32 |
|
|
|
b94e32 |
;; [aarch64] Fix hardware watchpoints (RH BZ 1261564).
|
|
|
b94e32 |
;;=fedoratest
|
|
|
b94e32 |
|
|
|
b94e32 |
diff --git a/gdb/testsuite/gdb.base/rhbz1261564-aarch64-watchpoint.c b/gdb/testsuite/gdb.base/rhbz1261564-aarch64-watchpoint.c
|
|
|
b94e32 |
new file mode 100644
|
|
|
b94e32 |
--- /dev/null
|
|
|
b94e32 |
+++ b/gdb/testsuite/gdb.base/rhbz1261564-aarch64-watchpoint.c
|
|
|
b94e32 |
@@ -0,0 +1,33 @@
|
|
|
b94e32 |
+/* This testcase is part of GDB, the GNU debugger.
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+ Copyright 2016 Free Software Foundation, Inc.
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+ This program is free software; you can redistribute it and/or modify
|
|
|
b94e32 |
+ it under the terms of the GNU General Public License as published by
|
|
|
b94e32 |
+ the Free Software Foundation; either version 3 of the License, or
|
|
|
b94e32 |
+ (at your option) any later version.
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+ This program is distributed in the hope that it will be useful,
|
|
|
b94e32 |
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
b94e32 |
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
b94e32 |
+ GNU General Public License for more details.
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+ You should have received a copy of the GNU General Public License
|
|
|
b94e32 |
+ along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+__attribute__((aligned(16))) struct
|
|
|
b94e32 |
+{
|
|
|
b94e32 |
+ int var0, var4, var8;
|
|
|
b94e32 |
+} aligned;
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+int
|
|
|
b94e32 |
+main (void)
|
|
|
b94e32 |
+{
|
|
|
b94e32 |
+ aligned.var0 = 1;
|
|
|
b94e32 |
+ aligned.var4 = 2;
|
|
|
b94e32 |
+ aligned.var8 = 3;
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+ aligned.var4 = aligned.var0;
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+ return 0;
|
|
|
b94e32 |
+}
|
|
|
b94e32 |
diff --git a/gdb/testsuite/gdb.base/rhbz1261564-aarch64-watchpoint.exp b/gdb/testsuite/gdb.base/rhbz1261564-aarch64-watchpoint.exp
|
|
|
b94e32 |
new file mode 100644
|
|
|
b94e32 |
--- /dev/null
|
|
|
b94e32 |
+++ b/gdb/testsuite/gdb.base/rhbz1261564-aarch64-watchpoint.exp
|
|
|
b94e32 |
@@ -0,0 +1,53 @@
|
|
|
b94e32 |
+# Copyright (C) 2016 Free Software Foundation, Inc.
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+# This program is free software; you can redistribute it and/or modify
|
|
|
b94e32 |
+# it under the terms of the GNU General Public License as published by
|
|
|
b94e32 |
+# the Free Software Foundation; either version 3 of the License, or
|
|
|
b94e32 |
+# (at your option) any later version.
|
|
|
b94e32 |
+#
|
|
|
b94e32 |
+# This program is distributed in the hope that it will be useful,
|
|
|
b94e32 |
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
b94e32 |
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
b94e32 |
+# GNU General Public License for more details.
|
|
|
b94e32 |
+#
|
|
|
b94e32 |
+# You should have received a copy of the GNU General Public License
|
|
|
b94e32 |
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+if { [prepare_for_testing rhbz1261564-aarch64-watchpoint.exp "rhbz1261564-aarch64-watchpoint"] } {
|
|
|
b94e32 |
+ return -1
|
|
|
b94e32 |
+}
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+if { ! [ runto main ] } then { return 0 }
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+set test "rwatch aligned.var4"
|
|
|
b94e32 |
+if [istarget "s390*-*-*"] {
|
|
|
b94e32 |
+ gdb_test $test {Target does not support this type of hardware watchpoint\.}
|
|
|
b94e32 |
+ untested "s390* does not support hw read watchpoint"
|
|
|
b94e32 |
+ return
|
|
|
b94e32 |
+}
|
|
|
b94e32 |
+gdb_test $test "Hardware read watchpoint \[0-9\]+: aligned.var4"
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+proc checkvar { address } {
|
|
|
b94e32 |
+ global gdb_prompt
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+ set test "p &aligned.var$address"
|
|
|
b94e32 |
+ gdb_test_multiple $test $test {
|
|
|
b94e32 |
+ -re " = \\(int \\*\\) 0x\[0-9a-f\]+$address <aligned(\\+\[0-9\]+)?>\r\n$gdb_prompt $" {
|
|
|
b94e32 |
+ pass $test
|
|
|
b94e32 |
+ }
|
|
|
b94e32 |
+ -re "\r\n$gdb_prompt $" {
|
|
|
b94e32 |
+ untested "$test (unexpected ELF layout)"
|
|
|
b94e32 |
+ return 0
|
|
|
b94e32 |
+ }
|
|
|
b94e32 |
+ }
|
|
|
b94e32 |
+ return 1
|
|
|
b94e32 |
+}
|
|
|
b94e32 |
+if ![checkvar "0"] { return }
|
|
|
b94e32 |
+if ![checkvar "4"] { return }
|
|
|
b94e32 |
+if ![checkvar "8"] { return }
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+# Assumes: PPC_PTRACE_GETHWDBGINFO::data_bp_alignment == 8
|
|
|
b94e32 |
+# 'lwz' does read only 4 bytes but the hw watchpoint is 8 bytes wide.
|
|
|
b94e32 |
+setup_xfail "powerpc*-*-*"
|
|
|
b94e32 |
+
|
|
|
b94e32 |
+gdb_continue_to_end
|