|
|
e1d87d |
commit cdaac320fd62bff75562aaa3e466494dc72dd175
|
|
|
e1d87d |
Author: Andreas Arnez <arnez@linux.vnet.ibm.com>
|
|
|
e1d87d |
Date: Tue Jun 13 15:20:27 2017 +0200
|
|
|
e1d87d |
|
|
|
e1d87d |
write_pieced_value: Fix copy/paste error in size calculation
|
|
|
e1d87d |
|
|
|
e1d87d |
In write_pieced_value, the number of bytes containing a portion of the
|
|
|
e1d87d |
bit-field in a given piece is calculated with the wrong starting offset;
|
|
|
e1d87d |
thus the result may be off by one. This bug was probably introduced when
|
|
|
e1d87d |
copying this logic from read_pieced_value. Fix it.
|
|
|
e1d87d |
|
|
|
e1d87d |
gdb/ChangeLog:
|
|
|
e1d87d |
|
|
|
e1d87d |
* dwarf2loc.c (write_pieced_value): Fix copy/paste error in the
|
|
|
e1d87d |
calculation of this_size.
|
|
|
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): Fix copy/paste error in the
|
|
|
e1d87d |
+ calculation of this_size.
|
|
|
e1d87d |
+
|
|
|
e1d87d |
+2017-06-13 Andreas Arnez <arnez@linux.vnet.ibm.com>
|
|
|
e1d87d |
+
|
|
|
e1d87d |
* dwarf2loc.c (read_pieced_value): Respect parent value's offset
|
|
|
e1d87d |
when targeting a bit-field.
|
|
|
e1d87d |
(write_pieced_value): Likewise.
|
|
|
e1d87d |
--- a/gdb/dwarf2loc.c
|
|
|
e1d87d |
+++ b/gdb/dwarf2loc.c
|
|
|
e1d87d |
@@ -1983,7 +1983,7 @@ write_pieced_value (struct value *to, struct value *from)
|
|
|
e1d87d |
if (this_size_bits > type_len - offset)
|
|
|
e1d87d |
this_size_bits = type_len - offset;
|
|
|
e1d87d |
|
|
|
e1d87d |
- this_size = (this_size_bits + source_offset_bits % 8 + 7) / 8;
|
|
|
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)
|