Don't use NUM_REGS to determine array size.
authorKevin Buettner <kevinb@redhat.com>
Tue, 17 Dec 2002 23:13:31 +0000 (23:13 +0000)
committerKevin Buettner <kevinb@redhat.com>
Tue, 17 Dec 2002 23:13:31 +0000 (23:13 +0000)
gdb/ChangeLog
gdb/dve3900-rom.c

index 0de88ffbf0c4efe45000ba7fc5a2b214f2bfd7eb..ebd56b73a18dde2fc5c1503f55f0b5a4b0928b16 100644 (file)
@@ -1,3 +1,10 @@
+2002-12-17  Kevin Buettner  <kevinb@redhat.com>
+
+       * dve3900-rom.c (r3900_regnames): Don't use NUM_REGS to determine
+       array size.
+       (fetch_bitmapped_register, store_bitmapped_register): Add bounds
+       checks for r3900_regnames[].
+
 2002-12-17  Richard Earnshaw  <rearnsha@arm.com>
 
        * armnbsd-tdep.c (ARM_NBSD_JB_PC): Renamed from JB_PC.
index feb8e12001a9c72c37113985075260b045b2b731..c8834e927956dff6629307a1ca2665b1e0bc34f1 100644 (file)
@@ -113,7 +113,7 @@ static int ethernet = 0;
    different names than GDB does, and don't support all the registers
    either.  */
 
-static char *r3900_regnames[NUM_REGS] =
+static char *r3900_regnames[] =
 {
   "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
   "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
@@ -456,8 +456,15 @@ fetch_bitmapped_register (int regno, struct bit_field *bf)
 {
   unsigned long val;
   unsigned char regbuf[MAX_REGISTER_RAW_SIZE];
+  char *regname = NULL;
 
-  monitor_printf ("x%s\r", r3900_regnames[regno]);
+  if (regno >= sizeof (r3900_regnames) / sizeof (r3900_regnames[0]))
+    internal_error (__FILE__, __LINE__,
+                    "fetch_bitmapped_register: regno out of bounds");
+  else
+    regname = r3900_regnames[regno];
+
+  monitor_printf ("x%s\r", regname);
   val = fetch_fields (bf);
   monitor_printf (".\r");
   monitor_expect_prompt (NULL, 0);
@@ -501,9 +508,16 @@ static void
 store_bitmapped_register (int regno, struct bit_field *bf)
 {
   unsigned long oldval, newval;
+  char *regname = NULL;
+
+  if (regno >= sizeof (r3900_regnames) / sizeof (r3900_regnames[0]))
+    internal_error (__FILE__, __LINE__,
+                    "fetch_bitmapped_register: regno out of bounds");
+  else
+    regname = r3900_regnames[regno];
 
   /* Fetch the current value of the register.  */
-  monitor_printf ("x%s\r", r3900_regnames[regno]);
+  monitor_printf ("x%s\r", regname);
   oldval = fetch_fields (bf);
   newval = read_register (regno);
 
This page took 0.03069 seconds and 4 git commands to generate.