From: Alan Hayward Date: Wed, 22 May 2019 13:02:17 +0000 (+0100) Subject: AArch64: Treat pauth ops as nops on non-pauth systems X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=8fca4da0759df376bcb646bc4b79a92ba27e2362;p=binutils-gdb.git AArch64: Treat pauth ops as nops on non-pauth systems Running an address signed binary through GDB on a non pauth system gives the following error: Call Frame Instruction op 45 in vendor extension space is not handled on this architecture. Instead GDB should ignore the op, treating it as a nop. Add test case for pauth binaries, regardless of whether the target supports it. gdb/ChangeLog: * aarch64-tdep.c (aarch64_execute_dwarf_cfa_vendor_op): Treat DW_CFA_AARCH64_negate_ra_state as nop on non pauth targets. gdb/testsuite/ChangeLog: * gdb.arch/aarch64-pauth.c: New test. * gdb.arch/aarch64-pauth.exp: New file. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 52fc11d8f49..34d97c82665 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2019-05-22 Alan Hayward + + * aarch64-tdep.c (aarch64_execute_dwarf_cfa_vendor_op): Treat + DW_CFA_AARCH64_negate_ra_state as nop on non pauth targets. + 2019-05-22 Alan Hayward * NEWS: Add debugredirect and testsuite sections. diff --git a/gdb/aarch64-tdep.c b/gdb/aarch64-tdep.c index bbb2a25f956..96ebce4c352 100644 --- a/gdb/aarch64-tdep.c +++ b/gdb/aarch64-tdep.c @@ -1180,8 +1180,12 @@ aarch64_execute_dwarf_cfa_vendor_op (struct gdbarch *gdbarch, gdb_byte op, struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch); struct dwarf2_frame_state_reg *ra_state; - if (tdep->has_pauth () && op == DW_CFA_AARCH64_negate_ra_state) + if (op == DW_CFA_AARCH64_negate_ra_state) { + /* On systems without pauth, treat as a nop. */ + if (!tdep->has_pauth ()) + return true; + /* Allocate RA_STATE column if it's not allocated yet. */ fs->regs.alloc_regs (AARCH64_DWARF_PAUTH_RA_STATE + 1); diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 867455f7a58..62adbd7f2ca 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2019-05-22 Alan Hayward + + * gdb.arch/aarch64-pauth.c: New test. + * gdb.arch/aarch64-pauth.exp: New file. + 2019-05-22 Alan Hayward * README (Re-running Tests Outside The Testsuite): New section. diff --git a/gdb/testsuite/gdb.arch/aarch64-pauth.c b/gdb/testsuite/gdb.arch/aarch64-pauth.c new file mode 100644 index 00000000000..af9bbe4a935 --- /dev/null +++ b/gdb/testsuite/gdb.arch/aarch64-pauth.c @@ -0,0 +1,36 @@ +/* This test program is part of GDB, the GNU debugger. + + Copyright 2019 Free Software Foundation, Inc. + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . */ + +int +bar (int b) +{ + int x = 1; /* break here. */ + return b - x; +} + +int +foo (int a) +{ + int y = bar (9); + return a + y; +} + +int +main () +{ + foo (5); +} diff --git a/gdb/testsuite/gdb.arch/aarch64-pauth.exp b/gdb/testsuite/gdb.arch/aarch64-pauth.exp new file mode 100644 index 00000000000..ff1bf26ab4d --- /dev/null +++ b/gdb/testsuite/gdb.arch/aarch64-pauth.exp @@ -0,0 +1,43 @@ +# Copyright (C) 2019 Free Software Foundation, Inc. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# Test a binary with address signing works regardless of whether the target +# supports pauth instructions. On non pauth systems, all pauth instructions +# are treated as nops. + +if {![is_aarch64_target]} { + verbose "Skipping ${gdb_test_file_name}." + return +} + +# Build program with address signing forced on. +standard_testfile +set compile_flags {debug} +lappend compile_flags "additional_flags=-msign-return-address=all" +lappend compile_flags "additional_flags=-fno-inline" +if { [prepare_for_testing "failed to prepare" ${testfile} ${srcfile} ${compile_flags}] } { + return -1 +} + +if ![runto_main] { + untested "could not run to main" + return -1 +} + +gdb_breakpoint [ gdb_get_line_number "break here" ] +gdb_continue_to_breakpoint "break here" ".*break here.*" + +# Ensure we can get a full backtrace, despite the address signing. +gdb_test "bt" "^bt\r\n#0 +bar *\\(b=9\\) +at.*\r\n#1 +0x\[0-9a-f\]* +in +foo \\(a=5\\).*\r\n#2 +0x\[0-9a-f\]* +in +main \\(\\).*" "backtrace"