1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
| /* SPDX-License-Identifier: GPL-2.0-only */
| /*
| * arch/arm/include/asm/map.h
| *
| * Copyright (C) 1999-2000 Russell King
| *
| * Page table mapping constructs and function prototypes
| */
| #ifndef __ASM_MACH_MAP_H
| #define __ASM_MACH_MAP_H
|
| #include <asm/io.h>
|
| struct map_desc {
| unsigned long virtual;
| unsigned long pfn;
| unsigned long length;
| unsigned int type;
| };
|
| /* types 0-3 are defined in asm/io.h */
| enum {
| MT_UNCACHED = 4,
| MT_CACHECLEAN,
| MT_MINICLEAN,
| MT_LOW_VECTORS,
| MT_HIGH_VECTORS,
| MT_MEMORY_RWX,
| MT_MEMORY_RW,
| MT_MEMORY_RO,
| MT_ROM,
| MT_MEMORY_RWX_NONCACHED,
| MT_MEMORY_RW_DTCM,
| MT_MEMORY_RWX_ITCM,
| MT_MEMORY_RW_SO,
| MT_MEMORY_DMA_READY,
| };
|
| #ifdef CONFIG_MMU
| extern void iotable_init(struct map_desc *, int);
| extern void vm_reserve_area_early(unsigned long addr, unsigned long size,
| void *caller);
| extern void create_mapping_late(struct mm_struct *mm, struct map_desc *md,
| bool ng);
|
| #ifdef CONFIG_DEBUG_LL
| extern void debug_ll_addr(unsigned long *paddr, unsigned long *vaddr);
| extern void debug_ll_io_init(void);
| #else
| static inline void debug_ll_io_init(void) {}
| #endif
|
| struct mem_type;
| extern const struct mem_type *get_mem_type(unsigned int type);
| /*
| * external interface to remap single page with appropriate type
| */
| extern int ioremap_page(unsigned long virt, unsigned long phys,
| const struct mem_type *mtype);
| #else
| #define iotable_init(map,num) do { } while (0)
| #define vm_reserve_area_early(a,s,c) do { } while (0)
| #endif
|
| #endif
|
|