forked from Minki/linux
2e651ea159
ARC700 doesn't natively support unaligned access, but can be emulated -Unaligned Access Exception -Disassembly at the Fault address to find the exact insn (long/short) Also per Arnd's comment, we runtime control it using 2 sysctl knobs: * SYSCTL_ARCH_UNALIGN_ALLOW: Runtime enable/disble * SYSCTL_ARCH_UNALIGN_NO_WARN: Warn on each emulation attempt Originally contributed by Tim Yao <tim.yao@amlogic.com> Signed-off-by: Vineet Gupta <vgupta@synopsys.com> Cc: Tim Yao <tim.yao@amlogic.com> Acked-by: Arnd Bergmann <arnd@arndb.de>
30 lines
797 B
C
30 lines
797 B
C
/*
|
|
* Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*/
|
|
|
|
#ifndef _ASM_ARC_UNALIGNED_H
|
|
#define _ASM_ARC_UNALIGNED_H
|
|
|
|
/* ARC700 can't handle unaligned Data accesses. */
|
|
|
|
#include <asm-generic/unaligned.h>
|
|
#include <asm/ptrace.h>
|
|
|
|
#ifdef CONFIG_ARC_MISALIGN_ACCESS
|
|
int misaligned_fixup(unsigned long address, struct pt_regs *regs,
|
|
unsigned long cause, struct callee_regs *cregs);
|
|
#else
|
|
static inline int
|
|
misaligned_fixup(unsigned long address, struct pt_regs *regs,
|
|
unsigned long cause, struct callee_regs *cregs)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
#endif /* _ASM_ARC_UNALIGNED_H */
|