diff options
author | Tamar Christina <tamar.christina@arm.com> | 2018-05-01 17:11:11 +0100 |
---|---|---|
committer | Tamar Christina <tamar.christina@arm.com> | 2018-05-01 17:12:58 +0100 |
commit | b3ac5c6c286c5b5c1909628e85754edfb403cf1a (patch) | |
tree | 213f9a7268462fb49e4ecc9fae20bdd2aa62a3c6 /opcodes/aarch64-dis.c | |
parent | 8e4bd9922ae37809021ca660782295fc2de3ee73 (diff) | |
download | binutils-gdb-b3ac5c6c286c5b5c1909628e85754edfb403cf1a.tar.gz |
Fix unintialized memory in aarch64 opcodes.
This patch fixes an issue where the memory for the opcode structure is not zero'd before
the first exit branch. So there is one failure mode for which uninitialized memory
is returned.
This causes weird failures when the return code is not checked before inst is used.
opcodes/
* aarch64-dis.c (aarch64_opcode_decode): Moved memory clear code.
Diffstat (limited to 'opcodes/aarch64-dis.c')
-rw-r--r-- | opcodes/aarch64-dis.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/opcodes/aarch64-dis.c b/opcodes/aarch64-dis.c index c63f595f682..e7bece9c1ac 100644 --- a/opcodes/aarch64-dis.c +++ b/opcodes/aarch64-dis.c @@ -2733,6 +2733,9 @@ aarch64_opcode_decode (const aarch64_opcode *opcode, const aarch64_insn code, assert (opcode && inst); + /* Clear inst. */ + memset (inst, '\0', sizeof (aarch64_inst)); + /* Check the base opcode. */ if ((code & opcode->mask) != (opcode->opcode & opcode->mask)) { @@ -2740,9 +2743,6 @@ aarch64_opcode_decode (const aarch64_opcode *opcode, const aarch64_insn code, goto decode_fail; } - /* Clear inst. */ - memset (inst, '\0', sizeof (aarch64_inst)); - inst->opcode = opcode; inst->value = code; |