 f80dff9da0
			
		
	
	
	f80dff9da0
	
	
	
		
			
			get_irqnr_preamble allows machines to take some action before entering the get_irqnr_and_base loop. On iop we enable cp6 access. arch_ret_to_user is added to the userspace return path to allow individual architectures to take actions, like disabling coprocessor access, before the final return to userspace. Per Nicolas Pitre's note, there is no need to cp_wait on the return to user as the latency to return is sufficient. Signed-off-by: Dan Williams <dan.j.williams@intel.com> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
		
			
				
	
	
		
			41 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /*
 | |
|  * include/asm-arm/arch-netx/entry-macro.S
 | |
|  *
 | |
|  * Low-level IRQ helper macros for Hilscher netX based platforms
 | |
|  *
 | |
|  * Copyright (C) 2005 Sascha Hauer <s.hauer@pengutronix.de>, Pengutronix
 | |
|  *
 | |
|  * 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.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | |
|  */
 | |
| #include <asm/hardware.h>
 | |
| 
 | |
| 		.macro  disable_fiq
 | |
| 		.endm
 | |
| 
 | |
| 		.macro  get_irqnr_preamble, base, tmp
 | |
| 		.endm
 | |
| 
 | |
| 		.macro  arch_ret_to_user, tmp1, tmp2
 | |
| 		.endm
 | |
| 
 | |
| 		.macro  get_irqnr_and_base, irqnr, irqstat, base, tmp
 | |
| 		mov	\base, #io_p2v(0x00100000)
 | |
| 		add	\base, \base, #0x000ff000
 | |
| 
 | |
| 		ldr	\irqstat, [\base, #0]
 | |
| 		clz	\irqnr, \irqstat
 | |
| 		rsb     \irqnr, \irqnr, #31
 | |
| 		cmp	\irqstat, #0
 | |
| 		.endm
 | |
| 
 |