aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Kingdon <jkingdon@engr.sgi.com>1993-04-09 20:54:02 +0000
committerJim Kingdon <jkingdon@engr.sgi.com>1993-04-09 20:54:02 +0000
commit944c1c2f3179dade4c1291a22e2bbde72f22be2d (patch)
treeaf0c0eb59ce149bed5d9c805f8cc4df8922654ab
parenta7a9a714e0648cb8b273b123247069239351add2 (diff)
downloadgdb-944c1c2f3179dade4c1291a22e2bbde72f22be2d.zip
gdb-944c1c2f3179dade4c1291a22e2bbde72f22be2d.tar.gz
gdb-944c1c2f3179dade4c1291a22e2bbde72f22be2d.tar.bz2
* rs6000-pinsn.c (print_operand): Deal with no operand instructions.
* rs6000-pinsn.c (print_operand, case LI): Print condition register operand in decimal rather than wrong textual versions.
-rw-r--r--gdb/ChangeLog5
-rw-r--r--gdb/rs6000-pinsn.c22
2 files changed, 23 insertions, 4 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index a441473..46251b7 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,5 +1,10 @@
Fri Apr 9 10:20:55 1993 Jim Kingdon (kingdon@cygnus.com)
+ * rs6000-pinsn.c (print_operand): Deal with no operand instructions.
+
+ * rs6000-pinsn.c (print_operand, case LI): Print condition register
+ operand in decimal rather than wrong textual versions.
+
* printcmd.c (_initialize_printcmd): Clean up docstring for "x"
(mention 't', remove false thing about 'g' only good with 'f').
diff --git a/gdb/rs6000-pinsn.c b/gdb/rs6000-pinsn.c
index 03261e5..08e9125 100644
--- a/gdb/rs6000-pinsn.c
+++ b/gdb/rs6000-pinsn.c
@@ -189,7 +189,7 @@ int insn_no;
/* parse the operand now. */
pp = rs6k_ops[insn_no].oprnd_format;
- while (1) {
+ while (*pp != 0) {
switch (*pp) {
case TO :
fprintf (stream, "%d", (insn_word >> 21) & 0x1f);
@@ -202,11 +202,27 @@ int insn_no;
case LI :
tmp = (insn_word >> 16) & 0x1f;
+#if 0
+ /* This is wrong, wrong, wrong. The condition code only goes
+ from 0 to 3 (for the instructions which can use extended
+ mnemonics of this type), and the XX (lt, gt, eq etc.) goes
+ into the mnemonic, not as an operand.
+
+ Probably the best way to get this right in both assembler
+ and disassembler is to switch to a match/lose style opcode
+ table like the sparc. */
if (tmp > 11) {
fprintf (stream, "{unknown cond code: 0x%x}", insn_word);
tmp = 0;
}
fprintf (stream, "%s", cond_code [tmp]);
+#else
+ /* So for just always use the "bbf/bbt" form. This is perfectly
+ correct, just not necessarily as legible.
+
+ If tmp is not in the range 0-3, we can't use an XX form anyway. */
+ fprintf (stream, "%d", tmp);
+#endif
break;
case A2 :
@@ -372,9 +388,7 @@ int insn_no;
}
++pp;
- if (*pp == '\0')
- break;
- else if (!nocomma)
+ if (*pp != '\0' && !nocomma)
fputc(',', stream);
}
}