This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: [patch] DW_AT_byte_size for array type entries


On Wednesday, November 03, 2010 3:22:50 pm Ken Werner wrote:
> On Tuesday, November 02, 2010 11:31:03 pm Tom Tromey wrote:
> > >>>>> "Ken" == Ken Werner <ken@linux.vnet.ibm.com> writes:
> > Ken> Index: gdb/c-valprint.c
> > Ken> ===================================================================
> > Ken> RCS file: /cvs/src/src/gdb/c-valprint.c,v
> > Ken> retrieving revision 1.74
> > Ken> diff -p -u -r1.74 c-valprint.c
> > Ken> --- gdb/c-valprint.c	15 Oct 2010 18:54:12 -0000	1.74
> > Ken> +++ gdb/c-valprint.c	19 Oct 2010 12:15:30 -0000
> > Ken> @@ -171,8 +171,13 @@ c_val_print (struct type *type, const gd
> > Ken>        elttype = check_typedef (unresolved_elttype);
> > Ken>        if (TYPE_LENGTH (type) > 0 && TYPE_LENGTH
> > (unresolved_elttype)
> > 
> > > 0) Ken>  	{
> > 
> > Ken> +          LONGEST low_bound, high_bound;
> > Ken> +
> > Ken> +          if (!get_array_bounds(type, &low_bound, &high_bound))
> > 
> > Missing space before open paren.
> 
> Fixed.
> 
> > Ken> +            error (_("Could not determine the array high bound"));
> > Ken> +
> > Ken>  	  eltlen = TYPE_LENGTH (elttype);
> > Ken> -	  len = TYPE_LENGTH (type) / eltlen;
> > Ken> +	  len = high_bound - low_bound + 1;
> > 
> > I guess it is ok to use 'eltlen' elsewhere in the function because it is
> > only the array's overall size which is "weird" -- the element size is
> > still correct.  (Since we don't implement the DWARF stride stuff...)
> 
> Yes, that is also my understanding.
> 
> > The patch is ok with the above nit fixed.
> 
> Thanks. I've checked in the version below:
> http://sourceware.org/ml/gdb-cvs/2010-11/msg00014.html

Hi,

The attached patch changes the value_one(), value_complement() and value_neg() 
functions to use get_array_bounds to compute the number of array elements 
instead of dividing the length of the array by the length of the element 
types. It seems that I overlooked these in the first place.

Tested on i686-*-linux-gnu with no regressions.
Ok to apply?

Regards
Ken
2010-12-13  Ken Werner  <ken.werner@de.ibm.com>

	* valops.c (value_one): Use get_array_bounds to compute the number
	of array elements instead of dividing the length of the array by the
	length of the element types.
	* valarith.c (value_complement, value_neg): Likewise.

 
Index: gdb/valarith.c
===================================================================
RCS file: /cvs/src/src/gdb/valarith.c,v
retrieving revision 1.91
diff -u -r1.91 valarith.c
--- gdb/valarith.c	29 Nov 2010 21:18:16 -0000	1.91
+++ gdb/valarith.c	13 Dec 2010 19:43:52 -0000
@@ -1766,9 +1766,13 @@
     {
       struct value *tmp, *val = allocate_value (type);
       struct type *eltype = check_typedef (TYPE_TARGET_TYPE (type));
-      int i, n = TYPE_LENGTH (type) / TYPE_LENGTH (eltype);
+      int i;
+      LONGEST low_bound, high_bound;
 
-      for (i = 0; i < n; i++)
+      if (!get_array_bounds (type, &low_bound, &high_bound))
+	error (_("Could not determine the vector bounds"));
+
+      for (i = 0; i < high_bound - low_bound + 1; i++)
 	{
 	  tmp = value_neg (value_subscript (arg1, i));
 	  memcpy (value_contents_writeable (val) + i * TYPE_LENGTH (eltype),
@@ -1798,10 +1802,14 @@
     {
       struct value *tmp;
       struct type *eltype = check_typedef (TYPE_TARGET_TYPE (type));
-      int i, n = TYPE_LENGTH (type) / TYPE_LENGTH (eltype);
+      int i;
+      LONGEST low_bound, high_bound;
+
+      if (!get_array_bounds (type, &low_bound, &high_bound))
+	error (_("Could not determine the vector bounds"));
 
       val = allocate_value (type);
-      for (i = 0; i < n; i++)
+      for (i = 0; i < high_bound - low_bound + 1; i++)
         {
           tmp = value_complement (value_subscript (arg1, i));
           memcpy (value_contents_writeable (val) + i * TYPE_LENGTH (eltype),
Index: gdb/valops.c
===================================================================
RCS file: /cvs/src/src/gdb/valops.c,v
retrieving revision 1.259
diff -u -r1.259 valops.c
--- gdb/valops.c	1 Dec 2010 16:49:41 -0000	1.259
+++ gdb/valops.c	13 Dec 2010 19:43:52 -0000
@@ -877,11 +877,15 @@
   else if (TYPE_CODE (type1) == TYPE_CODE_ARRAY && TYPE_VECTOR (type1))
     {
       struct type *eltype = check_typedef (TYPE_TARGET_TYPE (type1));
-      int i, n = TYPE_LENGTH (type1) / TYPE_LENGTH (eltype);
+      int i;
+      LONGEST low_bound, high_bound;
       struct value *tmp;
 
+      if (!get_array_bounds (type1, &low_bound, &high_bound))
+	error (_("Could not determine the vector bounds"));
+
       val = allocate_value (type);
-      for (i = 0; i < n; i++)
+      for (i = 0; i < high_bound - low_bound + 1; i++)
 	{
 	  tmp = value_one (eltype, lv);
 	  memcpy (value_contents_writeable (val) + i * TYPE_LENGTH (eltype),

Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]