summaryrefslogtreecommitdiff
path: root/sim/sh/gencode.c
diff options
context:
space:
mode:
authorJoern Rennecke <joern.rennecke@arc.com>2004-08-18 11:47:15 +0000
committerJoern Rennecke <joern.rennecke@arc.com>2004-08-18 11:47:15 +0000
commit61dc6d3e6e5f84cf773b3c841fcc4d71f21779aa (patch)
tree7af6c296e5f4ca0914ac5e8cf54325f8b6372890 /sim/sh/gencode.c
parent2139716170daa0253964910fcebd9f31c522196c (diff)
downloadgdb-61dc6d3e6e5f84cf773b3c841fcc4d71f21779aa.tar.gz
* gencode.c (tab): For shad snd shld, fix result for
(op1 < 0 && shift_amount == 0).
Diffstat (limited to 'sim/sh/gencode.c')
-rw-r--r--sim/sh/gencode.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/sim/sh/gencode.c b/sim/sh/gencode.c
index 33475918704..155138a2daf 100644
--- a/sim/sh/gencode.c
+++ b/sim/sh/gencode.c
@@ -1054,7 +1054,7 @@ op tab[] =
},
{ "n", "mn", "shad <REG_M>,<REG_N>", "0100nnnnmmmm1100",
- "R[n] = (R[m] < 0) ? (R[n] >> ((-R[m])&0x1f)) : (R[n] << (R[m] & 0x1f));",
+ "R[n] = (R[m] < 0) ? (R[m]&0x1f ? R[n] >> ((-R[m])&0x1f) : R[n] >> 31) : (R[n] << (R[m] & 0x1f));",
},
{ "n", "n", "shal <REG_N>", "0100nnnn00100000",
@@ -1068,7 +1068,7 @@ op tab[] =
},
{ "n", "mn", "shld <REG_M>,<REG_N>", "0100nnnnmmmm1101",
- "R[n] = (R[m] < 0) ? (UR[n] >> ((-R[m])&0x1f)): (R[n] << (R[m] & 0x1f));",
+ "R[n] = (R[m] < 0) ? (R[m]&0x1f ? UR[n] >> ((-R[m])&0x1f) : 0): (R[n] << (R[m] & 0x1f));",
},
{ "n", "n", "shll <REG_N>", "0100nnnn00000000",