xref: /openbmc/linux/arch/arc/include/asm/highmem.h (revision 39cac191)
1d2912cb1SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-only */
245890f6dSVineet Gupta /*
345890f6dSVineet Gupta  * Copyright (C) 2015 Synopsys, Inc. (www.synopsys.com)
445890f6dSVineet Gupta  */
545890f6dSVineet Gupta 
645890f6dSVineet Gupta #ifndef _ASM_HIGHMEM_H
745890f6dSVineet Gupta #define _ASM_HIGHMEM_H
845890f6dSVineet Gupta 
945890f6dSVineet Gupta #ifdef CONFIG_HIGHMEM
1045890f6dSVineet Gupta 
1145890f6dSVineet Gupta #include <uapi/asm/page.h>
12*39cac191SThomas Gleixner #include <asm/kmap_size.h>
13*39cac191SThomas Gleixner 
14*39cac191SThomas Gleixner #define FIXMAP_SIZE		PGDIR_SIZE
15*39cac191SThomas Gleixner #define PKMAP_SIZE		PGDIR_SIZE
1645890f6dSVineet Gupta 
1745890f6dSVineet Gupta /* start after vmalloc area */
1845890f6dSVineet Gupta #define FIXMAP_BASE		(PAGE_OFFSET - FIXMAP_SIZE - PKMAP_SIZE)
19*39cac191SThomas Gleixner 
20*39cac191SThomas Gleixner #define FIX_KMAP_SLOTS		(KM_MAX_IDX * NR_CPUS)
21*39cac191SThomas Gleixner #define FIX_KMAP_BEGIN		(0UL)
22*39cac191SThomas Gleixner #define FIX_KMAP_END		((FIX_KMAP_BEGIN + FIX_KMAP_SLOTS) - 1)
23*39cac191SThomas Gleixner 
24*39cac191SThomas Gleixner #define FIXADDR_TOP		(FIXMAP_BASE + (FIX_KMAP_END << PAGE_SHIFT))
25*39cac191SThomas Gleixner 
26*39cac191SThomas Gleixner /*
27*39cac191SThomas Gleixner  * This should be converted to the asm-generic version, but of course this
28*39cac191SThomas Gleixner  * is needlessly different from all other architectures. Sigh - tglx
29*39cac191SThomas Gleixner  */
30*39cac191SThomas Gleixner #define __fix_to_virt(x)	(FIXADDR_TOP - ((x) << PAGE_SHIFT))
31*39cac191SThomas Gleixner #define __virt_to_fix(x)	(((FIXADDR_TOP - ((x) & PAGE_MASK))) >> PAGE_SHIFT)
3245890f6dSVineet Gupta 
3345890f6dSVineet Gupta /* start after fixmap area */
3445890f6dSVineet Gupta #define PKMAP_BASE		(FIXMAP_BASE + FIXMAP_SIZE)
3545890f6dSVineet Gupta #define LAST_PKMAP		(PKMAP_SIZE >> PAGE_SHIFT)
3645890f6dSVineet Gupta #define LAST_PKMAP_MASK		(LAST_PKMAP - 1)
3745890f6dSVineet Gupta #define PKMAP_ADDR(nr)		(PKMAP_BASE + ((nr) << PAGE_SHIFT))
3845890f6dSVineet Gupta #define PKMAP_NR(virt)		(((virt) - PKMAP_BASE) >> PAGE_SHIFT)
3945890f6dSVineet Gupta 
4045890f6dSVineet Gupta #include <asm/cacheflush.h>
4145890f6dSVineet Gupta 
4245890f6dSVineet Gupta extern void kmap_init(void);
4345890f6dSVineet Gupta 
44*39cac191SThomas Gleixner #define arch_kmap_local_post_unmap(vaddr)			\
45*39cac191SThomas Gleixner 	local_flush_tlb_kernel_range(vaddr, vaddr + PAGE_SIZE)
46*39cac191SThomas Gleixner 
flush_cache_kmaps(void)4745890f6dSVineet Gupta static inline void flush_cache_kmaps(void)
4845890f6dSVineet Gupta {
4945890f6dSVineet Gupta 	flush_cache_all();
5045890f6dSVineet Gupta }
5145890f6dSVineet Gupta #endif
5245890f6dSVineet Gupta 
5345890f6dSVineet Gupta #endif
54