Blame SOURCES/gdb-rhbz1420304-s390x-16of35.patch

e1d87d
commit f1cc987420d9d2489eb453bd1c87139666cbe7fd
e1d87d
Author: Andreas Arnez <arnez@linux.vnet.ibm.com>
e1d87d
Date:   Tue Jun 13 15:20:27 2017 +0200
e1d87d
e1d87d
    write_pieced_value: Include transfer size in byte-wise check
e1d87d
    
e1d87d
    In write_pieced_value, when checking whether the data can be transferred
e1d87d
    byte-wise, the current logic verifies the source- and destination offsets
e1d87d
    to be byte-aligned, but not the transfer size.  This is fixed.
e1d87d
    
e1d87d
    gdb/ChangeLog:
e1d87d
    
e1d87d
            * dwarf2loc.c (write_pieced_value): Include transfer size in
e1d87d
            byte-wise check.
e1d87d
e1d87d
### a/gdb/ChangeLog
e1d87d
### b/gdb/ChangeLog
e1d87d
## -1,5 +1,10 @@
e1d87d
 2017-06-13  Andreas Arnez  <arnez@linux.vnet.ibm.com>
e1d87d
 
e1d87d
+	* dwarf2loc.c (write_pieced_value): Include transfer size in
e1d87d
+	byte-wise check.
e1d87d
+
e1d87d
+2017-06-13  Andreas Arnez  <arnez@linux.vnet.ibm.com>
e1d87d
+
e1d87d
 	* dwarf2loc.c (write_pieced_value): Fix copy/paste error in the
e1d87d
 	calculation of this_size.
e1d87d
 
e1d87d
--- a/gdb/dwarf2loc.c
e1d87d
+++ b/gdb/dwarf2loc.c
e1d87d
@@ -1986,7 +1986,10 @@ write_pieced_value (struct value *to, struct value *from)
e1d87d
       this_size = (this_size_bits + dest_offset_bits % 8 + 7) / 8;
e1d87d
       source_offset = source_offset_bits / 8;
e1d87d
       dest_offset = dest_offset_bits / 8;
e1d87d
-      if (dest_offset_bits % 8 == 0 && source_offset_bits % 8 == 0)
e1d87d
+
e1d87d
+      /* Check whether the data can be transferred byte-wise.  */
e1d87d
+      if (dest_offset_bits % 8 == 0 && source_offset_bits % 8 == 0
e1d87d
+	  && this_size_bits % 8 == 0)
e1d87d
 	{
e1d87d
 	  source_buffer = contents + source_offset;
e1d87d
 	  need_bitwise = 0;