1 /****************************************************************************
2  ****************************************************************************
3  ***
4  ***   This header was automatically generated from a Linux kernel header
5  ***   of the same name, to make information necessary for userspace to
6  ***   call into the kernel available to libc.  It contains only constants,
7  ***   structures, and macros generated from the original header, and thus,
8  ***   contains no copyrightable information.
9  ***
10  ****************************************************************************
11  ****************************************************************************/
12 #ifndef __ARCH_OMAP_MTD_XIP_H__
13 #define __ARCH_OMAP_MTD_XIP_H__
14 
15 #include <asm/hardware.h>
16 #define OMAP_MPU_TIMER_BASE (0xfffec500)
17 #define OMAP_MPU_TIMER_OFFSET 0x100
18 
19 typedef struct {
20  u32 cntl;
21  u32 load_tim;
22  u32 read_tim;
23 } xip_omap_mpu_timer_regs_t;
24 
25 #define xip_omap_mpu_timer_base(n)  ((volatile xip_omap_mpu_timer_regs_t*)IO_ADDRESS(OMAP_MPU_TIMER_BASE +   (n)*OMAP_MPU_TIMER_OFFSET))
26 
27 #define xip_irqpending()   (omap_readl(OMAP_IH1_ITR) & ~omap_readl(OMAP_IH1_MIR))
28 #define xip_currtime() (~xip_omap_mpu_timer_read(0))
29 #define xip_elapsed_since(x) (signed)((~xip_omap_mpu_timer_read(0) - (x)) / 6)
30 #define xip_cpu_idle() asm volatile ("mcr p15, 0, %0, c7, c0, 4" :: "r" (1))
31 #endif
32