 2e651ea159
			
		
	
	
	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>
		
			
				
	
	
		
			29 lines
		
	
	
	
		
			797 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			29 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 */
 |