diff options
author | Mike Frysinger <vapier@gentoo.org> | 2010-09-22 21:54:33 +0000 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2010-09-22 21:54:33 +0000 |
commit | 35fc57f38cc162286190ec02e5a0064cc9bc71cf (patch) | |
tree | be3d8fa165d4631fbc39e096d9925ead3f4d7ba7 /opcodes | |
parent | 219b747a3b6a879303423836a4eea7372e43a4cd (diff) | |
download | gdb-35fc57f38cc162286190ec02e5a0064cc9bc71cf.zip gdb-35fc57f38cc162286190ec02e5a0064cc9bc71cf.tar.gz gdb-35fc57f38cc162286190ec02e5a0064cc9bc71cf.tar.bz2 |
opcodes: blackfin: fix decoding of all register move insns
Many register move insns were not being decoded properly, so rewrite
the whole function to be a bit more manageable in terms of valid
combinations.
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Diffstat (limited to 'opcodes')
-rw-r--r-- | opcodes/ChangeLog | 4 | ||||
-rw-r--r-- | opcodes/bfin-dis.c | 42 |
2 files changed, 34 insertions, 12 deletions
diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog index a142b91..07c4d89 100644 --- a/opcodes/ChangeLog +++ b/opcodes/ChangeLog @@ -1,3 +1,7 @@ +2010-09-22 Mike Frysinger <vapier@gentoo.org> + + * bfin-dis.c (decode_REGMV_0): Rewrite valid combo checks. + 2010-09-22 Robin Getz <robin.getz@analog.com> * bfin-dis.c (decode_ProgCtrl_0): Check for parallel insns. diff --git a/opcodes/bfin-dis.c b/opcodes/bfin-dis.c index c77a5da..b17e055 100644 --- a/opcodes/bfin-dis.c +++ b/opcodes/bfin-dis.c @@ -1385,19 +1385,37 @@ decode_REGMV_0 (TIword iw0, disassemble_info *outf) int src = ((iw0 >> RegMv_src_bits) & RegMv_src_mask); int dst = ((iw0 >> RegMv_dst_bits) & RegMv_dst_mask); - if (!((IS_GENREG (gd, dst) && IS_GENREG (gs, src)) - || (IS_GENREG (gd, dst) && IS_DAGREG (gs, src)) - || (IS_DAGREG (gd, dst) && IS_GENREG (gs, src)) - || (IS_DAGREG (gd, dst) && IS_DAGREG (gs, src)) - || (IS_GENREG (gd, dst) && gs == 7 && src == 0) - || (gd == 7 && dst == 0 && IS_GENREG (gs, src)) - || (IS_DREG (gd, dst) && IS_SYSREG (gs, src)) - || (IS_PREG (gd, dst) && IS_SYSREG (gs, src)) - || (IS_SYSREG (gd, dst) && IS_DREG (gs, src)) - || (IS_SYSREG (gd, dst) && IS_PREG (gs, src)) - || (IS_SYSREG (gd, dst) && gs == 7 && src == 0))) - return 0; + /* Reserved slots cannot be a src/dst. */ + if (IS_RESERVEDREG (gs, src) || IS_RESERVEDREG (gd, dst)) + goto invalid_move; + + /* Standard register moves */ + if ((gs < 2) || /* Dregs/Pregs as source */ + (gd < 2) || /* Dregs/Pregs as dest */ + (gs == 4 && src < 4) || /* Accumulators as source */ + (gd == 4 && dst < 4 && (gs < 4)) || /* Accumulators as dest */ + (gs == 7 && src == 7 && !(gd == 4 && dst < 4)) || /* EMUDAT as src */ + (gd == 7 && dst == 7)) /* EMUDAT as dest */ + goto valid_move; + + /* dareg = dareg (IMBL) */ + if (gs < 4 && gd < 4) + goto valid_move; + + /* USP can be src to sysregs, but not dagregs. */ + if ((gs == 7 && src == 0) && (gd >= 4)) + goto valid_move; + + /* USP can move between genregs (only check Accumulators). */ + if (((gs == 7 && src == 0) && (gd == 4 && dst < 4)) || + ((gd == 7 && dst == 0) && (gs == 4 && src < 4))) + goto valid_move; + + /* Still here ? Invalid reg pair. */ + invalid_move: + return 0; + valid_move: OUTS (outf, allregs (dst, gd)); OUTS (outf, " = "); OUTS (outf, allregs (src, gs)); |