Merge branch 'sh-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/lethal/sh-3.x
* 'sh-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/lethal/sh-3.x: sh: fix the compile error in setup-sh7757.c serial: sh-sci: report CTS as active for get_mctrl sh: Add unaligned memory access for PC relative intructions sh: Fix unaligned memory access for branches without delay slots sh: Fix up fallout from cpuidle changes. serial: sh-sci: console Runtime PM support sh: Fix conflicting definitions of ptrace_triggered serial: sh-sci: fix DMA build by including dma-mapping.h serial: sh-sci: Fix up default regtype probing. sh: intc: enable both edges GPIO interrupts on sh7372 shwdt: fix usage of mod_timer clocksource: sh_cmt: wait for CMCNT on init V2
This commit is contained in:
@@ -15,6 +15,7 @@
|
||||
#include <linux/serial_sci.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/mm.h>
|
||||
#include <linux/dma-mapping.h>
|
||||
#include <linux/sh_timer.h>
|
||||
#include <linux/sh_dma.h>
|
||||
|
||||
|
@@ -22,7 +22,7 @@
|
||||
#include <linux/atomic.h>
|
||||
#include <asm/smp.h>
|
||||
|
||||
static void (*pm_idle)(void);
|
||||
void (*pm_idle)(void);
|
||||
|
||||
static int hlt_counter;
|
||||
|
||||
|
@@ -316,6 +316,35 @@ static int handle_unaligned_ins(insn_size_t instruction, struct pt_regs *regs,
|
||||
break;
|
||||
}
|
||||
break;
|
||||
|
||||
case 9: /* mov.w @(disp,PC),Rn */
|
||||
srcu = (unsigned char __user *)regs->pc;
|
||||
srcu += 4;
|
||||
srcu += (instruction & 0x00FF) << 1;
|
||||
dst = (unsigned char *)rn;
|
||||
*(unsigned long *)dst = 0;
|
||||
|
||||
#if !defined(__LITTLE_ENDIAN__)
|
||||
dst += 2;
|
||||
#endif
|
||||
|
||||
if (ma->from(dst, srcu, 2))
|
||||
goto fetch_fault;
|
||||
sign_extend(2, dst);
|
||||
ret = 0;
|
||||
break;
|
||||
|
||||
case 0xd: /* mov.l @(disp,PC),Rn */
|
||||
srcu = (unsigned char __user *)(regs->pc & ~0x3);
|
||||
srcu += 4;
|
||||
srcu += (instruction & 0x00FF) << 2;
|
||||
dst = (unsigned char *)rn;
|
||||
*(unsigned long *)dst = 0;
|
||||
|
||||
if (ma->from(dst, srcu, 4))
|
||||
goto fetch_fault;
|
||||
ret = 0;
|
||||
break;
|
||||
}
|
||||
return ret;
|
||||
|
||||
@@ -466,6 +495,7 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,
|
||||
case 0x0500: /* mov.w @(disp,Rm),R0 */
|
||||
goto simple;
|
||||
case 0x0B00: /* bf lab - no delayslot*/
|
||||
ret = 0;
|
||||
break;
|
||||
case 0x0F00: /* bf/s lab */
|
||||
ret = handle_delayslot(regs, instruction, ma);
|
||||
@@ -479,6 +509,7 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,
|
||||
}
|
||||
break;
|
||||
case 0x0900: /* bt lab - no delayslot */
|
||||
ret = 0;
|
||||
break;
|
||||
case 0x0D00: /* bt/s lab */
|
||||
ret = handle_delayslot(regs, instruction, ma);
|
||||
@@ -494,6 +525,9 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,
|
||||
}
|
||||
break;
|
||||
|
||||
case 0x9000: /* mov.w @(disp,Rm),Rn */
|
||||
goto simple;
|
||||
|
||||
case 0xA000: /* bra label */
|
||||
ret = handle_delayslot(regs, instruction, ma);
|
||||
if (ret==0)
|
||||
@@ -507,6 +541,9 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,
|
||||
regs->pc += SH_PC_12BIT_OFFSET(instruction);
|
||||
}
|
||||
break;
|
||||
|
||||
case 0xD000: /* mov.l @(disp,Rm),Rn */
|
||||
goto simple;
|
||||
}
|
||||
return ret;
|
||||
|
||||
|
Reference in New Issue
Block a user