Blame SOURCES/gdb-rhbz795424-bitpos-21of25.patch

4c2ad1
From FEDORA_PATCHES Mon Sep 17 00:00:00 2001
4c2ad1
From: Fedora GDB patches <invalid@email.com>
4c2ad1
Date: Fri, 27 Oct 2017 21:07:50 +0200
4c2ad1
Subject: gdb-rhbz795424-bitpos-21of25.patch
4c2ad1
4c2ad1
;; Fix `GDB cannot access struct member whose offset is larger than 256MB'
4c2ad1
;; (RH BZ 795424).
4c2ad1
;;=push
4c2ad1
4c2ad1
http://sourceware.org/ml/gdb-patches/2012-09/msg00632.html
4c2ad1
4c2ad1
--MP_/PnL6l3LUsXWpZ/olqawWlzb
4c2ad1
Content-Type: text/plain; charset=US-ASCII
4c2ad1
Content-Transfer-Encoding: 7bit
4c2ad1
Content-Disposition: inline
4c2ad1
4c2ad1
Hi,
4c2ad1
4c2ad1
This is part two of the bitpos expansion patch.  This implements checks
4c2ad1
in some places in the code to ensure that a type size in ULONGEST is
4c2ad1
small enough to fit into host memory.  Tested for regressions on x86_64
4c2ad1
Fedora 16.
4c2ad1
4c2ad1
Regards,
4c2ad1
Siddhesh
4c2ad1
4c2ad1
--MP_/PnL6l3LUsXWpZ/olqawWlzb
4c2ad1
Content-Type: text/plain
4c2ad1
Content-Transfer-Encoding: quoted-printable
4c2ad1
Content-Disposition: attachment; filename=ChangeLog-ensure_sizet
4c2ad1
4c2ad1
gdb/ChangeLog
4c2ad1
4c2ad1
	* alpha-tdep.c (alpha_push_dummy_call) Check for underflow in
4c2ad1
	SP.
4c2ad1
	* cp-valprint (cp_print_value): Ensure BASECLASS fits into
4c2ad1
	size_t.
4c2ad1
	* dwarf2loc.c (read_pieced_value): Ensure that THIS_SIZE fits
4c2ad1
	into size_t.
4c2ad1
	(write_pieced_value): Likewise.
4c2ad1
	* findcmd.c (parse_find_args): Ensure PATTERN_BUF_SIZE fits into
4c2ad1
	size_t.
4c2ad1
	* p-valprint (pascal_object_print_value): Ensure BASECLASS fits
4c2ad1
	into size_t.
4c2ad1
	* utils.c (ulongest_fits_host_or_error): New function to find if
4c2ad1
	a ULONGEST number fits into size_t.
4c2ad1
	* utils.h: Declare ulongest_fits_host_or_error.
4c2ad1
	* valops.c (search_struct_method): Ensure BASECLASS fits into
4c2ad1
	size_t.
4c2ad1
	* value.c (allocate_value_lazy): Ensure TYPE fits into size_t.
4c2ad1
	(allocate_value_contents): Likewise.
4c2ad1
	(set_value_enclosing_type): Ensure NEW_ENCL_TYPE fits into
4c2ad1
	size_t.
4c2ad1
	* vax-tdep.c (vax_return_value): Ensure that TYPE fits into
4c2ad1
	size_t.
4c2ad1
4c2ad1
--MP_/PnL6l3LUsXWpZ/olqawWlzb
4c2ad1
Content-Type: text/x-patch
4c2ad1
Content-Transfer-Encoding: 7bit
4c2ad1
Content-Disposition: attachment; filename=bitpos-ensure-size_t.patch
4c2ad1
4c2ad1
diff --git a/gdb/alpha-tdep.c b/gdb/alpha-tdep.c
4c2ad1
--- a/gdb/alpha-tdep.c
4c2ad1
+++ b/gdb/alpha-tdep.c
4c2ad1
@@ -413,6 +413,13 @@ alpha_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
4c2ad1
     accumulate_size = 0;
4c2ad1
   else
4c2ad1
     accumulate_size -= sizeof(arg_reg_buffer);
4c2ad1
+
4c2ad1
+  /* Check for underflow.  */
4c2ad1
+  if (sp - accumulate_size > sp)
4c2ad1
+    error (_("Insufficient memory in GDB host for arguments, "
4c2ad1
+	     "need %s bytes, but less than %s bytes available."),
4c2ad1
+	   plongest (accumulate_size), plongest (CORE_ADDR_MAX - sp));
4c2ad1
+
4c2ad1
   sp -= accumulate_size;
4c2ad1
 
4c2ad1
   /* Keep sp aligned to a multiple of 16 as the ABI requires.  */
4c2ad1
diff --git a/gdb/cp-valprint.c b/gdb/cp-valprint.c
4c2ad1
--- a/gdb/cp-valprint.c
4c2ad1
+++ b/gdb/cp-valprint.c
4c2ad1
@@ -529,6 +529,7 @@ cp_print_value (struct type *type, struct type *real_type,
4c2ad1
 	      if ((boffset + offset) < 0
4c2ad1
 		  || (boffset + offset) >= TYPE_LENGTH (real_type))
4c2ad1
 		{
4c2ad1
+		  ulongest_fits_host_or_error (TYPE_LENGTH (baseclass));
4c2ad1
 		  gdb::byte_vector buf (TYPE_LENGTH (baseclass));
4c2ad1
 
4c2ad1
 		  if (target_read_memory (address + boffset, buf.data (),
4c2ad1
diff --git a/gdb/defs.h b/gdb/defs.h
4c2ad1
--- a/gdb/defs.h
4c2ad1
+++ b/gdb/defs.h
4c2ad1
@@ -665,4 +665,6 @@ DEF_ENUM_FLAGS_TYPE (enum user_selected_what_flag, user_selected_what);
4c2ad1
 
4c2ad1
 #include "utils.h"
4c2ad1
 
4c2ad1
+extern void ulongest_fits_host_or_error (ULONGEST num);
4c2ad1
+
4c2ad1
 #endif /* #ifndef DEFS_H */
4c2ad1
diff --git a/gdb/p-valprint.c b/gdb/p-valprint.c
4c2ad1
--- a/gdb/p-valprint.c
4c2ad1
+++ b/gdb/p-valprint.c
4c2ad1
@@ -773,6 +773,7 @@ pascal_object_print_value (struct type *type, const gdb_byte *valaddr,
4c2ad1
 
4c2ad1
 	  if (boffset < 0 || boffset >= TYPE_LENGTH (type))
4c2ad1
 	    {
4c2ad1
+	      ulongest_fits_host_or_error (TYPE_LENGTH (baseclass));
4c2ad1
 	      buf.resize (TYPE_LENGTH (baseclass));
4c2ad1
 
4c2ad1
 	      base_valaddr = buf.data ();
4c2ad1
diff --git a/gdb/utils.c b/gdb/utils.c
4c2ad1
--- a/gdb/utils.c
4c2ad1
+++ b/gdb/utils.c
4c2ad1
@@ -2834,6 +2834,17 @@ string_to_core_addr (const char *my_string)
4c2ad1
   return addr;
4c2ad1
 }
4c2ad1
 
4c2ad1
+/* Ensure that the input NUM is not larger than the maximum capacity of the
4c2ad1
+   host system.  We choose SIZE_MAX / 8 as a conservative estimate of the size
4c2ad1
+   of a resource that a system may allocate.  */
4c2ad1
+void
4c2ad1
+ulongest_fits_host_or_error (ULONGEST num)
4c2ad1
+{
4c2ad1
+  if (num > SIZE_MAX / 8)
4c2ad1
+    error (_("Insufficient memory in host GDB for object of size %s bytes, "
4c2ad1
+	     "maximum allowed %s bytes."), pulongest (num),
4c2ad1
+	   pulongest (SIZE_MAX / 8));
4c2ad1
+}
4c2ad1
 #if GDB_SELF_TEST
4c2ad1
 
4c2ad1
 static void
4c2ad1
diff --git a/gdb/valops.c b/gdb/valops.c
4c2ad1
--- a/gdb/valops.c
4c2ad1
+++ b/gdb/valops.c
4c2ad1
@@ -2088,6 +2088,7 @@ search_struct_method (const char *name, struct value **arg1p,
4c2ad1
 	    {
4c2ad1
 	      CORE_ADDR address;
4c2ad1
 
4c2ad1
+	      ulongest_fits_host_or_error (TYPE_LENGTH (baseclass));
4c2ad1
 	      gdb::byte_vector tmp (TYPE_LENGTH (baseclass));
4c2ad1
 	      address = value_address (*arg1p);
4c2ad1
 
4c2ad1
diff --git a/gdb/value.c b/gdb/value.c
4c2ad1
--- a/gdb/value.c
4c2ad1
+++ b/gdb/value.c
4c2ad1
@@ -933,6 +933,7 @@ allocate_value_lazy (struct type *type)
4c2ad1
      description correctly.  */
4c2ad1
   check_typedef (type);
4c2ad1
 
4c2ad1
+  ulongest_fits_host_or_error (TYPE_LENGTH (type));
4c2ad1
   val = new struct value (type);
4c2ad1
 
4c2ad1
   /* Values start out on the all_values chain.  */
4c2ad1
@@ -1015,6 +1016,8 @@ check_type_length_before_alloc (const struct type *type)
4c2ad1
 static void
4c2ad1
 allocate_value_contents (struct value *val)
4c2ad1
 {
4c2ad1
+  ulongest_fits_host_or_error (TYPE_LENGTH (val->enclosing_type));
4c2ad1
+
4c2ad1
   if (!val->contents)
4c2ad1
     {
4c2ad1
       check_type_length_before_alloc (val->enclosing_type);
4c2ad1
@@ -2876,6 +2879,7 @@ set_value_enclosing_type (struct value *val, struct type *new_encl_type)
4c2ad1
   if (TYPE_LENGTH (new_encl_type) > TYPE_LENGTH (value_enclosing_type (val)))
4c2ad1
     {
4c2ad1
       check_type_length_before_alloc (new_encl_type);
4c2ad1
+      ulongest_fits_host_or_error (TYPE_LENGTH (new_encl_type));
4c2ad1
       val->contents
4c2ad1
 	.reset ((gdb_byte *) xrealloc (val->contents.release (),
4c2ad1
 				       TYPE_LENGTH (new_encl_type)));
4c2ad1
diff --git a/gdb/vax-tdep.c b/gdb/vax-tdep.c
4c2ad1
--- a/gdb/vax-tdep.c
4c2ad1
+++ b/gdb/vax-tdep.c
4c2ad1
@@ -218,6 +218,7 @@ vax_return_value (struct gdbarch *gdbarch, struct value *function,
4c2ad1
 	  ULONGEST addr;
4c2ad1
 
4c2ad1
 	  regcache_raw_read_unsigned (regcache, VAX_R0_REGNUM, &addr);
4c2ad1
+	  ulongest_fits_host_or_error (TYPE_LENGTH (type));
4c2ad1
 	  read_memory (addr, readbuf, len);
4c2ad1
 	}
4c2ad1