[commit/Ada] Fix crash printing packed record containing a packed array

Joel Brobecker brobecker@adacore.com
Thu Mar 12 23:56:00 GMT 2009


This was noticed when debugging on sparc-elf using the GDB simulator.
A testcase is provided as well.

There was a couple of issues:
  - The first is documented through comments in the code, so I won't
    repeat them here;
  - The second was a tiny bug in the extraction of the packed array
    value...

2009-03-12  Joel Brobecker  <brobecker@adacore.com>

        Fix crash printing packed record with packed array.

        * ada-lang.c (ada_modulus_from_name): New function.
        (ada_modulus): In the case where the type length is bigger than
        the size of the type used to hold the bounds, try determining
        the modulus from the type name.
        (ada_value_primitive_packed_val): Fix bug in the computation of
        ntarg causing an out-of-buffer invalid access.

2009-03-12  Joel Brobecker  <brobecker@adacore.com>

        * gdb.ada/mod_from_name: New testcase.

Re-tested on amd64-linux. Checked in.

-- 
Joel
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 03-ada-modulus.diff
Type: text/x-diff
Size: 2396 bytes
Desc: not available
URL: <http://sourceware.org/pipermail/gdb-patches/attachments/20090312/39976a0c/attachment.bin>
-------------- next part --------------
--  Copyright 2009 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 <http://www.gnu.org/licenses/>.

procedure Foo is

   type Small is range -32 .. 31;

   type SomePackedArray is array (Integer range <>) of Small;
   pragma Pack (SomePackedArray);

   type SomePackedRecord is record
      Y: SomePackedArray (1 .. 10);
   end record;
   pragma Pack (SomePackedRecord);

   Suite : SomePackedArray := (-1, -2, -3, -4, -5, -6, -7, -8, -9, -10);
   XP: SomePackedRecord := (Y => Suite);

   Slice : SomePackedArray renames XP.Y (3 .. 5);

begin
   Slice (4) := 4;  --  START
end Foo;

-------------- next part --------------
# Copyright 2009 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 <http://www.gnu.org/licenses/>.

if $tracelevel then {
    strace $tracelevel
}

load_lib "ada.exp"

set testdir "mod_from_name"
set testfile "${testdir}/foo"
set srcfile ${srcdir}/${subdir}/${testfile}.adb
set binfile ${objdir}/${subdir}/${testfile}

file mkdir ${objdir}/${subdir}/${testdir}
if {[gdb_compile_ada "${srcfile}" "${binfile}" executable [list debug ]] != "" } {
  return -1
}

gdb_exit
gdb_start
gdb_reinitialize_dir $srcdir/$subdir
gdb_load ${binfile}

set bp_location [gdb_get_line_number "START" ${testdir}/foo.adb]
if ![runto "foo.adb:$bp_location" ] then {
  perror "Couldn't run ${testfile}"
  return
} 

gdb_test "print xp" \
         "= \\(y => \\(-1, -2, -3, -4, -5, -6, -7, -8, -9, -10\\)\\)" \
         "print xp"




More information about the Gdb-patches mailing list