aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom de Vries <tdevries@suse.de>2021-09-21 00:41:26 +0200
committerTom de Vries <tdevries@suse.de>2021-09-21 00:41:26 +0200
commitff1c1bb9be3ed77fdabe594d977a9ccc67870fd0 (patch)
treeb993c2cd39176c63aab5b78c2a0f742125860533
parentc45a683f8f9195bf7cc53bc645a20092c7155629 (diff)
downloadbinutils-ff1c1bb9be3ed77fdabe594d977a9ccc67870fd0.zip
binutils-ff1c1bb9be3ed77fdabe594d977a9ccc67870fd0.tar.gz
binutils-ff1c1bb9be3ed77fdabe594d977a9ccc67870fd0.tar.bz2
[gdb/testsuite] Register test for each arch separately in register_test_foreach_arch
In gdb/disasm-selftests.c we have: ... selftests::register_test_foreach_arch ("print_one_insn", selftests::print_one_insn_test); ... and we get: ... $ gdb -q -batch -ex "maint selftest print_one_insn" 2>&1 \ | grep ^Running Running selftest print_one_insn. $ ... Change the semantics register_test_foreach_arch such that a version of print_one_insn is registered for each architecture, such that we have: ... $ gdb -q -batch -ex "maint selftest print_one_insn" 2>&1 \ | grep ^Running Running selftest print_one_insn::A6. Running selftest print_one_insn::A7. Running selftest print_one_insn::ARC600. ... $ ... This makes it f.i. possible to do: ... $ gdb -q -batch a.out -ex "maint selftest print_one_insn::armv8.1-m.main" Running selftest print_one_insn::armv8.1-m.main. Self test failed: self-test failed at src/gdb/disasm-selftests.c:165 Ran 1 unit tests, 1 failed ... Tested on x86_64-linux with an --enable-targets=all build.
-rw-r--r--gdb/selftest-arch.c105
1 files changed, 45 insertions, 60 deletions
diff --git a/gdb/selftest-arch.c b/gdb/selftest-arch.c
index 052daed..935459d 100644
--- a/gdb/selftest-arch.c
+++ b/gdb/selftest-arch.c
@@ -17,6 +17,7 @@
along with this program. If not, see <http://www.gnu.org/licenses/>. */
#include "defs.h"
+#include <functional>
#if GDB_SELF_TEST
#include "gdbsupport/selftest.h"
@@ -25,73 +26,57 @@
namespace selftests {
-/* A kind of selftest that calls the test function once for each gdbarch known
- to GDB. */
-
-struct gdbarch_selftest : public selftest
+static bool skip_arch (const char *arch)
{
- gdbarch_selftest (self_test_foreach_arch_function *function_)
- : function (function_)
- {}
-
- void operator() () const override
- {
- std::vector<const char *> arches = gdbarch_printable_names ();
- bool pass = true;
-
- for (const char *arch : arches)
- {
- if (strcmp ("fr300", arch) == 0)
- {
- /* PR 20946 */
- continue;
- }
- else if (strcmp ("powerpc:EC603e", arch) == 0
- || strcmp ("powerpc:e500mc", arch) == 0
- || strcmp ("powerpc:e500mc64", arch) == 0
- || strcmp ("powerpc:titan", arch) == 0
- || strcmp ("powerpc:vle", arch) == 0
- || strcmp ("powerpc:e5500", arch) == 0
- || strcmp ("powerpc:e6500", arch) == 0)
- {
- /* PR 19797 */
- continue;
- }
-
- QUIT;
-
- try
- {
- struct gdbarch_info info;
-
- info.bfd_arch_info = bfd_scan_arch (arch);
-
- struct gdbarch *gdbarch = gdbarch_find_by_info (info);
- SELF_CHECK (gdbarch != NULL);
-
- function (gdbarch);
- }
- catch (const gdb_exception_error &ex)
- {
- pass = false;
- exception_fprintf (gdb_stderr, ex,
- _("Self test failed: arch %s: "), arch);
- }
-
- reset ();
- }
-
- SELF_CHECK (pass);
- }
+ if (strcmp ("fr300", arch) == 0)
+ {
+ /* PR 20946 */
+ return true;
+ }
+
+ if (strcmp ("powerpc:EC603e", arch) == 0
+ || strcmp ("powerpc:e500mc", arch) == 0
+ || strcmp ("powerpc:e500mc64", arch) == 0
+ || strcmp ("powerpc:titan", arch) == 0
+ || strcmp ("powerpc:vle", arch) == 0
+ || strcmp ("powerpc:e5500", arch) == 0
+ || strcmp ("powerpc:e6500", arch) == 0)
+ {
+ /* PR 19797 */
+ return true;
+ }
+
+ return false;
+}
- self_test_foreach_arch_function *function;
-};
+/* Register a kind of selftest that calls the test function once for each
+ gdbarch known to GDB. */
void
register_test_foreach_arch (const std::string &name,
self_test_foreach_arch_function *function)
{
- register_test (name, new gdbarch_selftest (function));
+ std::vector<const char *> arches = gdbarch_printable_names ();
+ for (const char *arch : arches)
+ {
+ if (skip_arch (arch))
+ continue;
+
+ auto test_fn
+ = ([=] ()
+ {
+ struct gdbarch_info info;
+ info.bfd_arch_info = bfd_scan_arch (arch);
+ struct gdbarch *gdbarch = gdbarch_find_by_info (info);
+ SELF_CHECK (gdbarch != NULL);
+ function (gdbarch);
+ reset ();
+ });
+
+ std::string test_name
+ = name + std::string ("::") + std::string (arch);
+ register_test (test_name, test_fn);
+ }
}
void