MN10300: Fix register-postinc addressing misalignment handling

Fix misalignment handling of operands with register postincrement addressing.
The flag to indicate that postincrement is required should not be interpreted
as an specification of a value to be added to the address.

Also add BUGs to catch unimplemented parameter markings in the opcodes table.

Signed-off-by: David Howells <dhowells@redhat.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
David Howells 2008-11-12 15:35:20 +00:00 коммит произвёл Linus Torvalds
Родитель b308bf3be1
Коммит f911c685d6
1 изменённых файлов: 3 добавлений и 1 удалений

Просмотреть файл

@ -543,7 +543,7 @@ static int misalignment_addr(unsigned long *registers, unsigned params,
{ {
unsigned long *postinc = NULL, address = 0, tmp; unsigned long *postinc = NULL, address = 0, tmp;
params &= 0x7fffffff; params &= 0x00ffffff;
do { do {
switch (params & 0xff) { switch (params & 0xff) {
@ -631,6 +631,7 @@ static int misalignment_addr(unsigned long *registers, unsigned params,
address += disp; address += disp;
break; break;
default: default:
BUG();
return 0; return 0;
} }
} while ((params >>= 8)); } while ((params >>= 8));
@ -697,6 +698,7 @@ static int misalignment_reg(unsigned long *registers, unsigned params,
break; break;
default: default:
BUG();
return 0; return 0;
} }