diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 0766e670709..6997db969c1 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,9 @@ +2017-06-19 Nick Clifton + + PR binutils/21619 + * objdump.c (disassemble_bytes): Check that there is sufficient + data available before attempting to display it. + 2017-06-06 Simon Marchi * sysinfo.y: Free memory allocated by token NAME. diff --git a/binutils/objdump.c b/binutils/objdump.c index 05402edbebf..16e1f0ea9fa 100644 --- a/binutils/objdump.c +++ b/binutils/objdump.c @@ -1982,20 +1982,23 @@ disassemble_bytes (struct disassemble_info * inf, pb = octets; for (; j < addr_offset * opb + pb; j += bpc) { - int k; + /* PR 21619: Check for a buffer ending early. */ + if (j + bpc <= stop_offset * opb) + { + int k; - if (bpc > 1 && inf->display_endian == BFD_ENDIAN_LITTLE) - { - for (k = bpc - 1; k >= 0; k--) - printf ("%02x", (unsigned) data[j + k]); - putchar (' '); - } - else - { - for (k = 0; k < bpc; k++) - printf ("%02x", (unsigned) data[j + k]); - putchar (' '); + if (inf->display_endian == BFD_ENDIAN_LITTLE) + { + for (k = bpc - 1; k >= 0; k--) + printf ("%02x", (unsigned) data[j + k]); + } + else + { + for (k = 0; k < bpc; k++) + printf ("%02x", (unsigned) data[j + k]); + } } + putchar (' '); } } }