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