Fix a potential illegal array access in the D30V disassembler.
* d30v-dis.c (print_insn): Check that operand index is valid before attempting to access the operands array.
This commit is contained in:
parent
993a00a986
commit
9adb259150
|
@ -1,3 +1,8 @@
|
|||
2019-10-29 Nick Clifton <nickc@redhat.com>
|
||||
|
||||
* d30v-dis.c (print_insn): Check that operand index is valid
|
||||
before attempting to access the operands array.
|
||||
|
||||
2019-10-29 Nick Clifton <nickc@redhat.com>
|
||||
|
||||
* ia64-opc.c (locate_opcode_ent): Prevent a negative shift when
|
||||
|
|
|
@ -23,6 +23,7 @@
|
|||
#include "opcode/d30v.h"
|
||||
#include "disassemble.h"
|
||||
#include "opintl.h"
|
||||
#include "libiberty.h"
|
||||
|
||||
#define PC_MASK 0xFFFFFFFF
|
||||
|
||||
|
@ -313,7 +314,9 @@ print_insn (struct disassemble_info *info,
|
|||
(*info->fprintf_func) (info->stream, "0x%x", val);
|
||||
}
|
||||
/* If there is another operand, then write a comma and space. */
|
||||
if (insn->form->operands[opind] && !(found_control && opind == 2))
|
||||
if (opind < (int) ARRAY_SIZE (insn->form->operands)
|
||||
&& insn->form->operands[opind]
|
||||
&& !(found_control && opind == 2))
|
||||
need_comma = 1;
|
||||
}
|
||||
if (need_paren)
|
||||
|
|
Loading…
Reference in New Issue