| #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		0xfff00000UL | 
 | #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 |