| #ifndef _ASM_FIXMAP_H |
| #define _ASM_FIXMAP_H |
| |
| /* |
| * Nothing too fancy for now. |
| * |
| * On ARM we already have well known fixed virtual addresses imposed by |
| * the architecture such as the vector page which is located at 0xffff0000, |
| * therefore a second level page table is already allocated covering |
| * 0xfff00000 upwards. |
| * |
| * The cache flushing code in proc-xscale.S uses the virtual area between |
| * 0xfffe0000 and 0xfffeffff. |
| */ |
| |
| #define FIXADDR_START 0xfff30000UL |
| #define FIXADDR_TOP 0xfffe0000UL |
| #define FIXADDR_SIZE (FIXADDR_TOP - FIXADDR_START) |
| |
| #define FIX_KMAP_BEGIN 0 |
| #define FIX_KMAP_END (FIXADDR_SIZE >> PAGE_SHIFT) |
| |
| #define __fix_to_virt(x) (FIXADDR_START + ((x) << PAGE_SHIFT)) |
| #define __virt_to_fix(x) (((x) - FIXADDR_START) >> PAGE_SHIFT) |
| |
| extern void __this_fixmap_does_not_exist(void); |
| |
| static inline unsigned long fix_to_virt(const unsigned int idx) |
| { |
| if (idx >= FIX_KMAP_END) |
| __this_fixmap_does_not_exist(); |
| return __fix_to_virt(idx); |
| } |
| |
| static inline unsigned int virt_to_fix(const unsigned long vaddr) |
| { |
| BUG_ON(vaddr >= FIXADDR_TOP || vaddr < FIXADDR_START); |
| return __virt_to_fix(vaddr); |
| } |
| |
| #endif |