aboutsummaryrefslogtreecommitdiffstats
path: root/arch/mn10300/mm/misalignment.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/mn10300/mm/misalignment.c')
-rw-r--r--arch/mn10300/mm/misalignment.c27
1 files changed, 9 insertions, 18 deletions
diff --git a/arch/mn10300/mm/misalignment.c b/arch/mn10300/mm/misalignment.c
index 32aa89dc3848..416c43baaa21 100644
--- a/arch/mn10300/mm/misalignment.c
+++ b/arch/mn10300/mm/misalignment.c
@@ -37,7 +37,7 @@
37#include <asm/asm-offsets.h> 37#include <asm/asm-offsets.h>
38 38
39#if 0 39#if 0
40#define kdebug(FMT, ...) printk(KERN_DEBUG FMT, ##__VA_ARGS__) 40#define kdebug(FMT, ...) printk(KERN_DEBUG "MISALIGN: "FMT"\n", ##__VA_ARGS__)
41#else 41#else
42#define kdebug(FMT, ...) do {} while (0) 42#define kdebug(FMT, ...) do {} while (0)
43#endif 43#endif
@@ -50,14 +50,6 @@ static int misalignment_reg(unsigned long *registers, unsigned params,
50 unsigned opcode, unsigned disp, 50 unsigned opcode, unsigned disp,
51 unsigned long **_register); 51 unsigned long **_register);
52 52
53static inline unsigned int_log2(unsigned x)
54{
55 unsigned y;
56 asm("bsch %1,%0" : "=r"(y) : "r"(x), "0"(0));
57 return y;
58}
59#define log2(x) int_log2(x)
60
61static const unsigned Dreg_index[] = { 53static const unsigned Dreg_index[] = {
62 REG_D0 >> 2, REG_D1 >> 2, REG_D2 >> 2, REG_D3 >> 2 54 REG_D0 >> 2, REG_D1 >> 2, REG_D2 >> 2, REG_D3 >> 2
63}; 55};
@@ -88,7 +80,7 @@ enum format_id {
88 FMT_D9, 80 FMT_D9,
89}; 81};
90 82
91struct { 83static const struct {
92 u_int8_t opsz, dispsz; 84 u_int8_t opsz, dispsz;
93} format_tbl[16] = { 85} format_tbl[16] = {
94 [FMT_S0] = { 8, 0 }, 86 [FMT_S0] = { 8, 0 },
@@ -273,7 +265,7 @@ asmlinkage void misalignment(struct pt_regs *regs, enum exception_code code)
273 void *address; 265 void *address;
274 unsigned tmp, npop; 266 unsigned tmp, npop;
275 267
276 kdebug("MISALIGN at %lx\n", regs->pc); 268 kdebug("==>misalignment({pc=%lx})", regs->pc);
277 269
278 if (in_interrupt()) 270 if (in_interrupt())
279 die("Misalignment trap in interrupt context", regs, code); 271 die("Misalignment trap in interrupt context", regs, code);
@@ -295,7 +287,7 @@ asmlinkage void misalignment(struct pt_regs *regs, enum exception_code code)
295 noc = 8; 287 noc = 8;
296 288
297 for (pop = mn10300_opcodes; pop->name; pop++) { 289 for (pop = mn10300_opcodes; pop->name; pop++) {
298 npop = log2(pop->opcode | pop->opmask); 290 npop = ilog2(pop->opcode | pop->opmask);
299 if (npop <= 0 || npop > 31) 291 if (npop <= 0 || npop > 31)
300 continue; 292 continue;
301 npop = (npop + 8) & ~7; 293 npop = (npop + 8) & ~7;
@@ -391,7 +383,7 @@ transfer_failed:
391 383
392 /* we matched the opcode */ 384 /* we matched the opcode */
393found_opcode: 385found_opcode:
394 kdebug("MISALIGN: %lx: %x==%x { %x, %x }\n", 386 kdebug("%lx: %x==%x { %x, %x }",
395 regs->pc, opcode, pop->opcode, pop->params[0], pop->params[1]); 387 regs->pc, opcode, pop->opcode, pop->params[0], pop->params[1]);
396 388
397 tmp = format_tbl[pop->format].opsz; 389 tmp = format_tbl[pop->format].opsz;
@@ -442,13 +434,13 @@ found_opcode:
442 goto bad_reg_mode; 434 goto bad_reg_mode;
443 435
444 if (strcmp(pop->name, "mov") == 0) { 436 if (strcmp(pop->name, "mov") == 0) {
445 kdebug("FIXUP: mov (%p),DARn\n", address); 437 kdebug("mov (%p),DARn", address);
446 if (copy_from_user(&data, (void *) address, 4) != 0) 438 if (copy_from_user(&data, (void *) address, 4) != 0)
447 goto transfer_failed; 439 goto transfer_failed;
448 if (pop->params[0] & 0x1000000) 440 if (pop->params[0] & 0x1000000)
449 *postinc += 4; 441 *postinc += 4;
450 } else if (strcmp(pop->name, "movhu") == 0) { 442 } else if (strcmp(pop->name, "movhu") == 0) {
451 kdebug("FIXUP: movhu (%p),DARn\n", address); 443 kdebug("movhu (%p),DARn", address);
452 data = 0; 444 data = 0;
453 if (copy_from_user(&data, (void *) address, 2) != 0) 445 if (copy_from_user(&data, (void *) address, 2) != 0)
454 goto transfer_failed; 446 goto transfer_failed;
@@ -472,14 +464,13 @@ found_opcode:
472 data = *store; 464 data = *store;
473 465
474 if (strcmp(pop->name, "mov") == 0) { 466 if (strcmp(pop->name, "mov") == 0) {
475 kdebug("FIXUP: mov %lx,(%p)\n", data, address); 467 kdebug("mov %lx,(%p)", data, address);
476 if (copy_to_user((void *) address, &data, 4) != 0) 468 if (copy_to_user((void *) address, &data, 4) != 0)
477 goto transfer_failed; 469 goto transfer_failed;
478 if (pop->params[1] & 0x1000000) 470 if (pop->params[1] & 0x1000000)
479 *postinc += 4; 471 *postinc += 4;
480 } else if (strcmp(pop->name, "movhu") == 0) { 472 } else if (strcmp(pop->name, "movhu") == 0) {
481 kdebug("FIXUP: movhu %hx,(%p)\n", 473 kdebug("movhu %hx,(%p)", (uint16_t) data, address);
482 (uint16_t) data, address);
483 if (copy_to_user((void *) address, &data, 2) != 0) 474 if (copy_to_user((void *) address, &data, 2) != 0)
484 goto transfer_failed; 475 goto transfer_failed;
485 if (pop->params[1] & 0x1000000) 476 if (pop->params[1] & 0x1000000)