blob: 91c884634276fd1d5dad7cdb85e4165b7415188e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef __MMU_H
2#define __MMU_H
3
4#if !defined(CONFIG_MMU)
5
6struct mm_rblock_struct {
7 int size;
8 int refcount;
9 void *kblock;
10};
11
12struct mm_tblock_struct {
13 struct mm_rblock_struct *rblock;
14 struct mm_tblock_struct *next;
15};
16
17typedef struct {
18 struct mm_tblock_struct tblock;
19 unsigned long end_brk;
20} mm_context_t;
21
22#else
23
24/* Default "unsigned long" context */
25typedef unsigned long mm_context_t;
26
27#endif /* CONFIG_MMU */
Paul Mundt0c7b1df2006-09-27 15:08:07 +090028
29/*
30 * Privileged Space Mapping Buffer (PMB) definitions
31 */
32#define PMB_PASCR 0xff000070
33#define PMB_IRMCR 0xff000078
34
35#define PMB_ADDR 0xf6100000
36#define PMB_DATA 0xf7100000
37#define PMB_ENTRY_MAX 16
38#define PMB_E_MASK 0x0000000f
39#define PMB_E_SHIFT 8
40
41#define PMB_SZ_16M 0x00000000
42#define PMB_SZ_64M 0x00000010
43#define PMB_SZ_128M 0x00000080
44#define PMB_SZ_512M 0x00000090
45#define PMB_SZ_MASK PMB_SZ_512M
46#define PMB_C 0x00000008
47#define PMB_WT 0x00000001
48#define PMB_UB 0x00000200
49#define PMB_V 0x00000100
50
51#define PMB_NO_ENTRY (-1)
52
53struct pmb_entry {
54 unsigned long vpn;
55 unsigned long ppn;
56 unsigned long flags;
57
58 /*
59 * 0 .. NR_PMB_ENTRIES for specific entry selection, or
60 * PMB_NO_ENTRY to search for a free one
61 */
62 int entry;
63};
64
65/* arch/sh/mm/pmb.c */
66int __set_pmb_entry(unsigned long vpn, unsigned long ppn,
67 unsigned long flags, int *entry);
68void set_pmb_entry(struct pmb_entry *pmbe);
69void clear_pmb_entry(struct pmb_entry *pmbe);
70struct pmb_entry *pmb_alloc(unsigned long vpn, unsigned long ppn,
71 unsigned long flags);
72void pmb_free(struct pmb_entry *pmbe);
73
74#endif /* __MMU_H */
Linus Torvalds1da177e2005-04-16 15:20:36 -070075