From 3b9fce9660539584e869ea2d77610434e6baa2a2 Mon Sep 17 00:00:00 2001 From: Andrew Burgess Date: Tue, 16 Jun 2020 10:02:09 +0100 Subject: gdb/riscv: Improve support for matching against target descriptions For the RISC-V target it is desirable if the three floating pointer status CSRs fflags, frm, and fcsr can be placed into either the FPU feature or the CSR feature. This allows different targets to build the features in a way that better reflects their target. The change to support this within GDB is fairly simple, so this is done in this commit, and some tests added to check this new functionality. gdb/ChangeLog: * riscv-tdep.c (value_of_riscv_user_reg): Moved to here from later in the file. (class riscv_pending_register_alias): Likewise. (riscv_register_feature::register_info): Change 'required_p' field to 'required', and change its type. Add 'check' member function. (riscv_register_feature::register_info::check): Define new member function. (riscv_xreg_feature): Change initialisation of 'required' field. (riscv_freg_feature): Likewise. (riscv_virtual_feature): Likewise. (riscv_csr_feature): Likewise. (riscv_check_tdesc_feature): Take extra parameter, the csr tdesc_feature, rewrite the function to use the new riscv_register_feature::register_info::check function. (riscv_gdbarch_init): Pass the csr tdesc_feature where needed. gdb/testsuite/ChangeLog: * gdb.arch/riscv-tdesc-loading-01.xml: New file. * gdb.arch/riscv-tdesc-loading-02.xml: New file. * gdb.arch/riscv-tdesc-loading-03.xml: New file. * gdb.arch/riscv-tdesc-loading-04.xml: New file. * gdb.arch/riscv-tdesc-loading.exp: New file. --- gdb/testsuite/gdb.arch/riscv-tdesc-loading-01.xml | 83 +++++++++++++++++++++++ gdb/testsuite/gdb.arch/riscv-tdesc-loading-02.xml | 81 ++++++++++++++++++++++ gdb/testsuite/gdb.arch/riscv-tdesc-loading-03.xml | 79 +++++++++++++++++++++ gdb/testsuite/gdb.arch/riscv-tdesc-loading-04.xml | 77 +++++++++++++++++++++ gdb/testsuite/gdb.arch/riscv-tdesc-loading.exp | 39 +++++++++++ 5 files changed, 359 insertions(+) create mode 100644 gdb/testsuite/gdb.arch/riscv-tdesc-loading-01.xml create mode 100644 gdb/testsuite/gdb.arch/riscv-tdesc-loading-02.xml create mode 100644 gdb/testsuite/gdb.arch/riscv-tdesc-loading-03.xml create mode 100644 gdb/testsuite/gdb.arch/riscv-tdesc-loading-04.xml create mode 100644 gdb/testsuite/gdb.arch/riscv-tdesc-loading.exp (limited to 'gdb/testsuite/gdb.arch') diff --git a/gdb/testsuite/gdb.arch/riscv-tdesc-loading-01.xml b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-01.xml new file mode 100644 index 0000000..39bde20 --- /dev/null +++ b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-01.xml @@ -0,0 +1,83 @@ + + + + riscv + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gdb/testsuite/gdb.arch/riscv-tdesc-loading-02.xml b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-02.xml new file mode 100644 index 0000000..db0771b --- /dev/null +++ b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-02.xml @@ -0,0 +1,81 @@ + + + + riscv + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gdb/testsuite/gdb.arch/riscv-tdesc-loading-03.xml b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-03.xml new file mode 100644 index 0000000..b4af362 --- /dev/null +++ b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-03.xml @@ -0,0 +1,79 @@ + + + + riscv + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gdb/testsuite/gdb.arch/riscv-tdesc-loading-04.xml b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-04.xml new file mode 100644 index 0000000..d44d7e2 --- /dev/null +++ b/gdb/testsuite/gdb.arch/riscv-tdesc-loading-04.xml @@ -0,0 +1,77 @@ + + + + riscv + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/gdb/testsuite/gdb.arch/riscv-tdesc-loading.exp b/gdb/testsuite/gdb.arch/riscv-tdesc-loading.exp new file mode 100644 index 0000000..e111172 --- /dev/null +++ b/gdb/testsuite/gdb.arch/riscv-tdesc-loading.exp @@ -0,0 +1,39 @@ +# Copyright 2020 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 . + +# Check that we can load different RISC-V target descriptions. + +if {![istarget "riscv*-*-*"]} { + verbose "Skipping ${gdb_test_file_name}." + return +} + +clean_restart + +# Run over every test XML file and check the target description can be +# loaded. +foreach filename [lsort [glob $srcdir/$subdir/riscv-tdesc-loading-*.xml]] { + if {[is_remote host]} { + set test_path [remote_download host $filename] + } else { + set test_path $filename + } + + # Currently it is expected that all of the target descriptions in + # this test will load successfully, so we expect no additonal + # output from GDB. + gdb_test_no_output "set tdesc filename $test_path" \ + "check [file tail $filename]" +} -- cgit v1.1