+2018-08-07 James Patrick Conlon <cptjustice@gmail.com>
+ Nick Clifton <nickc@redhat.com>
+
+ PR 23481
+ * config/tc-pdp11.c (parse_op_noreg): Check for deferred register
+ addressing before assuming non-deferred addressing.
+ * testsuite/gas/pdp11/pr23481.s: New test source file.
+ * testsuite/gas/pdp11/pr23481.d: New test driver file.
+ * testsuite/gas/pdp11/pdp11.exp: Run the new test.
+
2018-08-06 Claudiu Zissulescu <claziss@synopsys.com>
* config/tc-arc.c (rf16_only): New static variable.
(swap_2_operands): Also swap flags fields.
* config/tc-i386-intel.c (i386_intel_operand): Likewise.
-2018-08-01 James Patrick Conlon <cptjustice@gmail.com>
+2018-08-01 James Patrick Conlon <cptjustice@gmail.com>
Nick Clifton <nickc@redhat.com>
PR 14480
str += 2;
}
else
- {
- operand->error = _("Bad register name");
- return str;
- }
+ operand->error = _("Bad register name");
return str;
}
str = parse_op_no_deferred (str, operand);
}
else
- str = parse_op_no_deferred (str + 1, operand);
+ {
+ /* @Rn == (Rn): Register deferred. */
+ str = parse_reg (str + 1, operand);
+
+ /* Not @Rn */
+ if (operand->error)
+ {
+ operand->error = NULL;
+ str = parse_op_no_deferred (str, operand);
+ }
+ }
if (operand->error)
return str;
+
operand->code |= 010;
}
else
run_dump_test "opcode"
run_dump_test "absreloc"
run_dump_test "pr14480"
+ run_dump_test "pr23481"
}
--- /dev/null
+#name: PR 23481 - correct assembly of '@rN' and '(rN)'
+#objdump: -dw
+
+dump.o: +file format .*
+
+Disassembly of section .text:
+
+0+00 <start>:
+[ ]+0:[ ]+2009[ ]+cmp[ ]+r0, \(r1\)
+[ ]+2:[ ]+2009[ ]+cmp[ ]+r0, \(r1\)
+[ ]+4:[ ]+2240[ ]+cmp[ ]+\(r1\), r0
+[ ]+6:[ ]+2240[ ]+cmp[ ]+\(r1\), r0
+[ ]+8:[ ]+2249[ ]+cmp[ ]+\(r1\), \(r1\)
+#pass
--- /dev/null
+start:
+ cmp r0,(r1)
+ cmp r0,@r1
+ cmp (r1),r0
+ cmp @r1,r0
+ cmp (r1),@r1
+
+ halt
+
+ .END