2  * include/asm-arm/arch-versatile/entry-macro.S
 
   4  * Low-level IRQ helper macros for Versatile platforms
 
   6  * This file is licensed under  the terms of the GNU General Public
 
   7  * License version 2. This program is licensed "as is" without any
 
   8  * warranty of any kind, whether express or implied.
 
  10 #include <asm/hardware.h>
 
  11 #include <asm/hardware/vic.h>
 
  16                 .macro  get_irqnr_preamble, base, tmp
 
  17                 ldr     \base, =IO_ADDRESS(VERSATILE_VIC_BASE)
 
  20                 .macro  arch_ret_to_user, tmp1, tmp2
 
  23                 .macro  get_irqnr_and_base, irqnr, irqstat, base, tmp
 
  24                 ldr     \irqstat, [\base, #VIC_IRQ_STATUS]      @ get masked status
 
  29 1001:           tst     \irqstat, #15
 
  31                 add     \irqnr, \irqnr, #4
 
  32                 movs    \irqstat, \irqstat, lsr #4
 
  34 1002:           tst     \irqstat, #1
 
  36                 add     \irqnr, \irqnr, #1
 
  37                 movs    \irqstat, \irqstat, lsr #1
 
  39 1003:           /* EQ will be set if no irqs pending */
 
  41 @               clz     \irqnr, \irqstat
 
  42 @1003:          /* EQ will be set if we reach MAXIRQNUM */