From: Nick Clifton Date: Mon, 19 Jun 2017 14:57:19 +0000 (+0100) Subject: Fix address violation when attempting to display disassembled data. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d16fdddb4e96e9e7bcfce6fe487b321c54b2c7c7;p=binutils-gdb.git Fix address violation when attempting to display disassembled data. PR binutils/21619 * objdump.c (disassemble_bytes): Check that there is sufficient data available before attempting to display it. --- 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; - - if (bpc > 1 && inf->display_endian == BFD_ENDIAN_LITTLE) + /* PR 21619: Check for a buffer ending early. */ + if (j + bpc <= stop_offset * opb) { - 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 (' '); + int k; + + 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 (' '); } } }