gdbserver: Add assert in find_register_by_number
authorThiago Jung Bauermann <thiago.bauermann@linaro.org>
Tue, 16 Aug 2022 17:18:47 +0000 (17:18 +0000)
committerThiago Jung Bauermann <thiago.bauermann@linaro.org>
Wed, 1 Feb 2023 19:48:07 +0000 (19:48 +0000)
It helped me during development, catching bugs closer to when they actually
happened.

Also remove the equivalent gdb_assert in regcache_raw_read_unsigned, since
it's checking the same condition a few frames above.

Suggested-By: Simon Marchi <simon.marchi@efficios.com>
Approved-By: Simon Marchi <simon.marchi@efficios.com>
gdbserver/regcache.cc

index 3aeefcc79a374063d2bf4716754989def8690289..0b1141662ac692977d526f3d05a304532c0805d1 100644 (file)
@@ -199,6 +199,9 @@ regcache_cpy (struct regcache *dst, struct regcache *src)
 static const struct gdb::reg &
 find_register_by_number (const struct target_desc *tdesc, int n)
 {
+  gdb_assert (n >= 0);
+  gdb_assert (n < tdesc->reg_defs.size ());
+
   return tdesc->reg_defs[n];
 }
 
@@ -440,8 +443,6 @@ regcache_raw_read_unsigned (struct regcache *regcache, int regnum,
   int size;
 
   gdb_assert (regcache != NULL);
-  gdb_assert (regnum >= 0
-             && regnum < regcache->tdesc->reg_defs.size ());
 
   size = register_size (regcache->tdesc, regnum);