ARM: 7409/1: Do not call flush_cache_user_range with mmap_sem held
[linux/fpc-iii.git] / arch / arm / mach-spear6xx / include / mach / entry-macro.S
blob8a0b0ed7b2035606d182541347727a0a9dbdff03
1 /*
2  * arch/arm/mach-spear6xx/include/mach/entry-macro.S
3  *
4  * Low-level IRQ helper macros for SPEAr6xx machine family
5  *
6  * Copyright (C) 2009 ST Microelectronics
7  * Rajeev Kumar<rajeev-dlh.kumar@st.com>
8  *
9  * This file is licensed under the terms of the GNU General Public
10  * License version 2. This program is licensed "as is" without any
11  * warranty of any kind, whether express or implied.
12  */
14 #include <asm/hardware/vic.h>
15 #include <mach/hardware.h>
17                 .macro  disable_fiq
18                 .endm
20                 .macro  get_irqnr_preamble, base, tmp
21                 .endm
23                 .macro  arch_ret_to_user, tmp1, tmp2
24                 .endm
26                 .macro  get_irqnr_and_base, irqnr, irqstat, base, tmp
27                 ldr     \base, =VA_SPEAR6XX_CPU_VIC_PRI_BASE
28                 ldr     \irqstat, [\base, #VIC_IRQ_STATUS]      @ get status
29                 mov     \irqnr, #0
30                 teq     \irqstat, #0
31                 bne     1001f
32                 ldr     \base, =VA_SPEAR6XX_CPU_VIC_SEC_BASE
33                 ldr     \irqstat, [\base, #VIC_IRQ_STATUS]      @ get status
34                 teq     \irqstat, #0
35                 beq     1002f                           @ this will set/reset
36                                                         @ zero register
37                 mov     \irqnr, #32
38 1001:
39                 /*
40                  * Following code will find bit position of least significang
41                  * bit set in irqstat, using following equation
42                  * least significant bit set in n = (n & ~(n-1))
43                  */
44                 sub     \tmp, \irqstat, #1              @ tmp = irqstat - 1
45                 mvn     \tmp, \tmp                      @ tmp = ~tmp
46                 and     \irqstat, \irqstat, \tmp        @ irqstat &= tmp
47                 /* Now, irqstat is = bit no. of 1st bit set in vic irq status */
48                 clz     \tmp, \irqstat                  @ tmp = leading zeros
50                 rsb     \tmp, \tmp, #0x1F               @ tmp = 32 - tmp - 1
51                 add     \irqnr, \irqnr, \tmp
53 1002:           /* EQ will be set if no irqs pending */
54                 .endm