From: Alan Modra Date: Mon, 16 Jun 2014 00:32:59 +0000 (+0930) Subject: Don't leave DLX the_insn uninitialised X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=97d24fbbf5300d5b03e48018454335772d9304e8;p=binutils-gdb.git Don't leave DLX the_insn uninitialised In particular the_insn.reloc must be initialised, otherwise the early exit cases for bad opcodes will result in cascading errors if write_object_file is called after an error. * config/tc-dlx.c (machine_ip): Move initialisation of the_insn earlier. --- diff --git a/gas/ChangeLog b/gas/ChangeLog index 568df4eb6c0..8f1aec1849b 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +2014-06-16 Alan Modra + + * config/tc-dlx.c (machine_ip): Move initialisation of the_insn + earlier. + 2014-06-16 Alan Modra * config/tc-i386.c (reloc): Don't avoid pcrel check for diff --git a/gas/config/tc-dlx.c b/gas/config/tc-dlx.c index 4cbc5c03db8..3c487f25a27 100644 --- a/gas/config/tc-dlx.c +++ b/gas/config/tc-dlx.c @@ -666,6 +666,9 @@ machine_ip (char *str) expressionS *operand = &the_operand; unsigned int reg, reg_shift = 0; + memset (&the_insn, '\0', sizeof (the_insn)); + the_insn.reloc = NO_RELOC; + /* Fixup the opcode string to all lower cases, and also allow numerical digits. */ s = str; @@ -690,19 +693,12 @@ machine_ip (char *str) return; } - /* Hash the opcode, insn will have the string from opcode table. - also initialized the_insn struct. */ + /* Hash the opcode, insn will have the string from opcode table. */ if ((insn = (struct machine_opcode *) hash_find (op_hash, str)) == NULL) { /* Handle the ret and return macro here. */ if ((strcmp (str, "ret") == 0) || (strcmp (str, "return") == 0)) - { - memset (&the_insn, '\0', sizeof (the_insn)); - the_insn.reloc = NO_RELOC; - the_insn.pcrel = 0; - the_insn.opcode = - (unsigned long)(JROP | 0x03e00000); /* 0x03e00000 = r31 << 21 */ - } + the_insn.opcode = JROP | 0x03e00000; /* 0x03e00000 = r31 << 21 */ else as_bad (_("Unknown opcode `%s'."), str); @@ -710,9 +706,6 @@ machine_ip (char *str) } opcode = insn->opcode; - memset (&the_insn, '\0', sizeof (the_insn)); - the_insn.reloc = NO_RELOC; - the_insn.pcrel = 0; /* Set the sip reloc HI16 flag. */ if (!set_dlx_skip_hi16_flag (1))