blob: 5c17d2dec777f627eaf6b706f92053065d5fa06b [file] [log] [blame]
Nicolas Pitre5f0fbf92008-09-16 13:05:53 -04001#ifndef _ASM_FIXMAP_H
2#define _ASM_FIXMAP_H
3
Liu Huaa05e54c2014-04-18 09:43:32 +01004#define FIXADDR_START 0xffc00000UL
Rob Herring836a2412014-07-02 02:01:15 -05005#define FIXADDR_END 0xfff00000UL
Mark Salterb615bbb2014-08-13 09:04:49 -07006#define FIXADDR_TOP (FIXADDR_END - PAGE_SIZE)
Nicolas Pitre5f0fbf92008-09-16 13:05:53 -04007
Mark Salterb615bbb2014-08-13 09:04:49 -07008#include <asm/kmap_types.h>
Stefan Agnera5f4c562015-08-13 00:01:52 +01009#include <asm/pgtable.h>
Nicolas Pitre5f0fbf92008-09-16 13:05:53 -040010
Mark Salterb615bbb2014-08-13 09:04:49 -070011enum fixed_addresses {
Stefan Agnera5f4c562015-08-13 00:01:52 +010012 FIX_EARLYCON_MEM_BASE,
13 __end_of_permanent_fixed_addresses,
14
15 FIX_KMAP_BEGIN = __end_of_permanent_fixed_addresses,
Mark Salterb615bbb2014-08-13 09:04:49 -070016 FIX_KMAP_END = FIX_KMAP_BEGIN + (KM_TYPE_NR * NR_CPUS) - 1,
Nicolas Pitre5f0fbf92008-09-16 13:05:53 -040017
Rabin Vincentab0615e2014-04-24 23:28:57 +020018 /* Support writing RO kernel text via kprobes, jump labels, etc. */
19 FIX_TEXT_POKE0,
20 FIX_TEXT_POKE1,
21
Ard Biesheuvel29373672015-09-01 08:59:28 +020022 __end_of_fixmap_region,
23
24 /*
25 * Share the kmap() region with early_ioremap(): this is guaranteed
26 * not to clash since early_ioremap() is only available before
27 * paging_init(), and kmap() only after.
28 */
29#define NR_FIX_BTMAPS 32
30#define FIX_BTMAPS_SLOTS 7
31#define TOTAL_FIX_BTMAPS (NR_FIX_BTMAPS * FIX_BTMAPS_SLOTS)
32
33 FIX_BTMAP_END = __end_of_permanent_fixed_addresses,
34 FIX_BTMAP_BEGIN = FIX_BTMAP_END + TOTAL_FIX_BTMAPS - 1,
35 __end_of_early_ioremap_region
Mark Salterb615bbb2014-08-13 09:04:49 -070036};
Nicolas Pitre5f0fbf92008-09-16 13:05:53 -040037
Ard Biesheuvel29373672015-09-01 08:59:28 +020038static const enum fixed_addresses __end_of_fixed_addresses =
39 __end_of_fixmap_region > __end_of_early_ioremap_region ?
40 __end_of_fixmap_region : __end_of_early_ioremap_region;
41
Stefan Agnera5f4c562015-08-13 00:01:52 +010042#define FIXMAP_PAGE_COMMON (L_PTE_YOUNG | L_PTE_PRESENT | L_PTE_XN | L_PTE_DIRTY)
43
44#define FIXMAP_PAGE_NORMAL (FIXMAP_PAGE_COMMON | L_PTE_MT_WRITEBACK)
Ard Biesheuvel29373672015-09-01 08:59:28 +020045#define FIXMAP_PAGE_RO (FIXMAP_PAGE_NORMAL | L_PTE_RDONLY)
Stefan Agnera5f4c562015-08-13 00:01:52 +010046
47/* Used by set_fixmap_(io|nocache), both meant for mapping a device */
48#define FIXMAP_PAGE_IO (FIXMAP_PAGE_COMMON | L_PTE_MT_DEV_SHARED | L_PTE_SHARED)
49#define FIXMAP_PAGE_NOCACHE FIXMAP_PAGE_IO
50
Ard Biesheuvel29373672015-09-01 08:59:28 +020051#define __early_set_fixmap __set_fixmap
52
53#ifdef CONFIG_MMU
54
Kees Cook99b4ac92014-04-04 23:27:49 +020055void __set_fixmap(enum fixed_addresses idx, phys_addr_t phys, pgprot_t prot);
Stefan Agnera5f4c562015-08-13 00:01:52 +010056void __init early_fixmap_init(void);
Kees Cook99b4ac92014-04-04 23:27:49 +020057
Mark Salterb615bbb2014-08-13 09:04:49 -070058#include <asm-generic/fixmap.h>
Nicolas Pitre5f0fbf92008-09-16 13:05:53 -040059
Ard Biesheuvel29373672015-09-01 08:59:28 +020060#else
61
62static inline void early_fixmap_init(void) { }
63
64#endif
Nicolas Pitre5f0fbf92008-09-16 13:05:53 -040065#endif