]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
* frame.c: Include "gdb_string.h" and "builtin-regs.h".
authorAndrew Cagney <cagney@redhat.com>
Wed, 25 Sep 2002 20:43:23 +0000 (20:43 +0000)
committerAndrew Cagney <cagney@redhat.com>
Wed, 25 Sep 2002 20:43:23 +0000 (20:43 +0000)
(frame_map_regnum_to_name): New function.
(frame_map_name_to_regnum): New function.
* frame.h (frame_map_name_to_regnum): Declare.
(frame_map_regnum_to_name): Declare.
* builtin-regs.c (builtin_reg_map_regnum_to_name): New function.
* builtin-regs.h (builtin_reg_map_regnum_to_name): Declare.
* parse.c: Do not include "builtin-regs.h".
(target_map_name_to_register): Delete function.
(write_dollar_variable): Use frame_map_name_to_regnum.
* parser-defs.h (target_map_name_to_register): Delete declaration.
* expprint.c: Include "frame.h".
(print_subexp): Use frame_map_regnum_to_name.
* eval.c (evaluate_subexp_standard): Use frame_map_regnum_to_name.
* infcmd.c (registers_info): Use frame_map_name_to_regnum.

Testsuite:

* gdb.base/pc-fp.exp, gdb.base/pc-fp.c: New test.

gdb/ChangeLog
gdb/builtin-regs.c
gdb/builtin-regs.h
gdb/eval.c
gdb/expprint.c
gdb/frame.c
gdb/frame.h
gdb/infcmd.c
gdb/parse.c
gdb/parser-defs.h
gdb/testsuite/ChangeLog

index f0199b3b9664abade0ae2b0ea0382dc6142ca63c..dddac765ad94dabef75fa12737d78c86c52dce4e 100644 (file)
@@ -1,3 +1,21 @@
+2002-09-03  Andrew Cagney  <ac131313@redhat.com>
+
+       * frame.c: Include "gdb_string.h" and "builtin-regs.h".
+       (frame_map_regnum_to_name): New function.
+       (frame_map_name_to_regnum): New function.
+       * frame.h (frame_map_name_to_regnum): Declare.
+       (frame_map_regnum_to_name): Declare.
+       * builtin-regs.c (builtin_reg_map_regnum_to_name): New function.
+       * builtin-regs.h (builtin_reg_map_regnum_to_name): Declare.
+       * parse.c: Do not include "builtin-regs.h".
+       (target_map_name_to_register): Delete function.
+       (write_dollar_variable): Use frame_map_name_to_regnum.
+       * parser-defs.h (target_map_name_to_register): Delete declaration.
+       * expprint.c: Include "frame.h".
+       (print_subexp): Use frame_map_regnum_to_name.
+       * eval.c (evaluate_subexp_standard): Use frame_map_regnum_to_name.
+       * infcmd.c (registers_info): Use frame_map_name_to_regnum.
+
 2002-09-24  Jim Blandy  <jimb@redhat.com>
 
        Fix from Paul Breed:
index 8c488e3a55770aca7d58e65af101e7bfbf4a936f..07e5fcca58a334ec124292ff42cc0e50ddc12e49 100644 (file)
@@ -68,6 +68,15 @@ builtin_reg_map_name_to_regnum (const char *name, int len)
   return -1;
 }
 
+const char *
+builtin_reg_map_regnum_to_name (int regnum)
+{
+  int reg = regnum - (NUM_REGS + NUM_PSEUDO_REGS);
+  if (reg < 0 || reg >= nr_builtin_regs)
+    return NULL;
+  return builtin_regs[reg].name;
+}
+
 struct value *
 value_of_builtin_reg (int regnum, struct frame_info *frame)
 {
index b35c4e91362236612b99157490012a7c3865487e..fb9fbcf8f8ed4091636de909192b4f5fc253af9d 100644 (file)
@@ -26,6 +26,8 @@
 
 extern int builtin_reg_map_name_to_regnum (const char *str, int len);
 
+extern const char *builtin_reg_map_regnum_to_name (int regnum);
+
 extern struct value *value_of_builtin_reg (int regnum,
                                           struct frame_info *frame);
 
index 33ec9438a04c8ef7dad5d8ca65ab7b59eda00acd..cbcf862e53a478975c271647680cb54076000ee8 100644 (file)
@@ -448,7 +448,8 @@ evaluate_subexp_standard (struct type *expect_type,
        struct value *val = value_of_register (regno, selected_frame);
        (*pos) += 2;
        if (val == NULL)
-         error ("Value of register %s not available.", REGISTER_NAME (regno));
+         error ("Value of register %s not available.",
+                frame_map_regnum_to_name (regno));
        else
          return val;
       }
index 9f3f17153214f75364fae4e390b8cd31c7ce9c70..aa8b87620128b45f5a50d4d4ba204f03dc24bac5 100644 (file)
@@ -26,6 +26,7 @@
 #include "value.h"
 #include "language.h"
 #include "parser-defs.h"
+#include "frame.h"             /* For frame_map_regnum_to_name.  */
 
 #ifdef HAVE_CTYPE_H
 #include <ctype.h>
@@ -119,10 +120,12 @@ print_subexp (register struct expression *exp, register int *pos,
       return;
 
     case OP_REGISTER:
-      (*pos) += 2;
-      fprintf_filtered (stream, "$%s",
-             REGISTER_NAME (longest_to_int (exp->elts[pc + 1].longconst)));
-      return;
+      {
+       int regnum = longest_to_int (exp->elts[pc + 1].longconst);
+       (*pos) += 2;
+       fprintf_filtered (stream, "$%s", frame_map_regnum_to_name (regnum));
+       return;
+      }
 
     case OP_BOOL:
       (*pos) += 2;
index 3b17bf5abf088c352997b45593edfad5f6d49d74..670eaa06f0dc18d371204cbb173dff9683b0cb4e 100644 (file)
@@ -27,6 +27,8 @@
 #include "inferior.h"  /* for inferior_ptid */
 #include "regcache.h"
 #include "gdb_assert.h"
+#include "gdb_string.h"
+#include "builtin-regs.h"
 
 /* Return a frame uniq ID that can be used to, later re-find the
    frame.  */
@@ -243,3 +245,44 @@ frame_register_read (struct frame_info *frame, int regnum, void *myaddr)
 
   return !optim;
 }
+
+
+/* Map between a frame register number and its name.  A frame register
+   space is a superset of the cooked register space --- it also
+   includes builtin registers.  */
+
+int
+frame_map_name_to_regnum (const char *name, int len)
+{
+  int i;
+
+  /* Search register name space. */
+  for (i = 0; i < NUM_REGS + NUM_PSEUDO_REGS; i++)
+    if (REGISTER_NAME (i) && len == strlen (REGISTER_NAME (i))
+       && strncmp (name, REGISTER_NAME (i), len) == 0)
+      {
+       return i;
+      }
+
+  /* Try builtin registers.  */
+  i = builtin_reg_map_name_to_regnum (name, len);
+  if (i >= 0)
+    {
+      /* A builtin register doesn't fall into the architecture's
+         register range.  */
+      gdb_assert (i >= NUM_REGS + NUM_PSEUDO_REGS);
+      return i;
+    }
+
+  return -1;
+}
+
+const char *
+frame_map_regnum_to_name (int regnum)
+{
+  if (regnum < 0)
+    return NULL;
+  if (regnum < NUM_REGS + NUM_PSEUDO_REGS)
+    return REGISTER_NAME (regnum);
+  return builtin_reg_map_regnum_to_name (regnum);
+}
index 20ffff00daffaf9b6112031e26d9fa6b75911c17..496b5da3e5bcf2a93ee694c3e998cda54ae077a9 100644 (file)
@@ -356,4 +356,11 @@ extern void get_saved_register (char *raw_buffer, int *optimized,
 extern int frame_register_read (struct frame_info *frame, int regnum,
                                void *buf);
 
+/* Map between a frame register number and its name.  A frame register
+   space is a superset of the cooked register space --- it also
+   includes builtin registers.  */
+
+extern int frame_map_name_to_regnum (const char *name, int strlen);
+extern const char *frame_map_regnum_to_name (int regnum);
+
 #endif /* !defined (FRAME_H)  */
index 95636ca466619d7bddf5a406221a9fb9c41277a0..a1d030bbce55d8edd11b00349a7dfec82fe194e0 100644 (file)
@@ -1701,7 +1701,7 @@ registers_info (char *addr_exp, int fpregs)
        ++end;
       numregs = NUM_REGS + NUM_PSEUDO_REGS;
 
-      regnum = target_map_name_to_register (addr_exp, end - addr_exp);
+      regnum = frame_map_name_to_regnum (addr_exp, end - addr_exp);
       if (regnum >= 0)
        goto found;
 
index c5de0af33346a8a9e6af646c54f28021dbcb8841..29b8e3c3709a003299e9d78c3bc0fd00b40a855e 100644 (file)
@@ -47,7 +47,6 @@
 #include "inferior.h"          /* for NUM_PSEUDO_REGS.  NOTE: replace 
                                   with "gdbarch.h" when appropriate.  */
 #include "doublest.h"
-#include "builtin-regs.h"
 #include "gdb_assert.h"
 
 \f
@@ -106,42 +105,6 @@ struct funcall
 
 static struct funcall *funcall_chain;
 
-/* The generic method for targets to specify how their registers are
-   named.  The mapping can be derived from two sources: REGISTER_NAME;
-   or builtin regs.  */
-
-int
-target_map_name_to_register (char *str, int len)
-{
-  int i;
-
-  /* Search register name space. */
-  for (i = 0; i < NUM_REGS + NUM_PSEUDO_REGS; i++)
-    if (REGISTER_NAME (i) && len == strlen (REGISTER_NAME (i))
-       && STREQN (str, REGISTER_NAME (i), len))
-      {
-       return i;
-      }
-
-  /* Try builtin registers.  */
-  i = builtin_reg_map_name_to_regnum (str, len);
-  if (i >= 0)
-    {
-      gdb_assert (i >= NUM_REGS + NUM_PSEUDO_REGS);
-      return i;
-    }
-
-  /* Try builtin registers.  */
-  i = builtin_reg_map_name_to_regnum (str, len);
-  if (i >= 0)
-    {
-      gdb_assert (i >= NUM_REGS + NUM_PSEUDO_REGS);
-      return i;
-    }
-
-  return -1;
-}
-
 /* Begin counting arguments for a function call,
    saving the data about any containing call.  */
 
@@ -491,7 +454,7 @@ write_dollar_variable (struct stoken str)
 
   /* Handle tokens that refer to machine registers:
      $ followed by a register name.  */
-  i = target_map_name_to_register (str.ptr + 1, str.length - 1);
+  i = frame_map_name_to_regnum (str.ptr + 1, str.length - 1);
   if (i >= 0)
     goto handle_register;
 
index 748208ae6d1ecac55b32649f86a7ae0737e8c8a2..b522241a464c1cfe3f6a88f36d4db6910e24a65b 100644 (file)
@@ -210,12 +210,6 @@ struct op_print
     int right_assoc;
   };
 
-/* The generic method for targets to specify how their registers are
-   named.  The mapping can be derived from two sources: REGISTER_NAME;
-   and builtin regs. */
-
-extern int target_map_name_to_register (char *, int);
-
 /* Function used to avoid direct calls to fprintf
    in the code generated by the bison parser.  */
 
index d0f9ef281c3d863a9b8eaf9bd5a44560218c0df4..b15a975c0c31c5e69c82f7fb4a70b5e50bf123ae 100644 (file)
@@ -1,3 +1,7 @@
+2002-09-04  Andrew Cagney  <ac131313@redhat.com>
+
+       * gdb.base/pc-fp.exp, gdb.base/pc-fp.c: New test.
+
 2002-09-03  Keith Seitz  <keiths@redhat.com>
 
        * lib/gdb.exp (gdb_compile_pthreads): Fix "build_bin" typo.