RTEMS
5.1
bsps
powerpc
include
libcpu
pte121.h
1
#ifndef _LIBCPU_PTE121_H
2
#define _LIBCPU_PTE121_H
3
4
/*
5
* Authorship
6
* ----------
7
* This software was created by
8
* Till Straumann <strauman@slac.stanford.edu>, 4/2002, 2003, 2004,
9
* Stanford Linear Accelerator Center, Stanford University.
10
*
11
* Acknowledgement of sponsorship
12
* ------------------------------
13
* This software was produced by
14
* the Stanford Linear Accelerator Center, Stanford University,
15
* under Contract DE-AC03-76SFO0515 with the Department of Energy.
16
*
17
* Government disclaimer of liability
18
* ----------------------------------
19
* Neither the United States nor the United States Department of Energy,
20
* nor any of their employees, makes any warranty, express or implied, or
21
* assumes any legal liability or responsibility for the accuracy,
22
* completeness, or usefulness of any data, apparatus, product, or process
23
* disclosed, or represents that its use would not infringe privately owned
24
* rights.
25
*
26
* Stanford disclaimer of liability
27
* --------------------------------
28
* Stanford University makes no representations or warranties, express or
29
* implied, nor assumes any liability for the use of this software.
30
*
31
* Stanford disclaimer of copyright
32
* --------------------------------
33
* Stanford University, owner of the copyright, hereby disclaims its
34
* copyright and all other rights in this software. Hence, anyone may
35
* freely use it for any purpose without restriction.
36
*
37
* Maintenance of notices
38
* ----------------------
39
* In the interest of clarity regarding the origin and status of this
40
* SLAC software, this and all the preceding Stanford University notices
41
* are to remain affixed to any copy or derivative of this software made
42
* or distributed by the recipient and are to be affixed to any copy of
43
* software made or distributed by the recipient that contains a copy or
44
* derivative of this software.
45
*
46
* ------------------ SLAC Software Notices, Set 4 OTT.002a, 2004 FEB 03
47
*/
48
49
/* Rudimentary page/hash table support for Powerpc
50
*
51
* A simple, static (i.e. no 'per-process' virtual
52
* address space etc.) page table providing
53
* one-to-one effective <-> virtual <-> physical
54
* address mapping.
55
*
56
* PURPOSE:
57
* 1) allow write-protection of text/read-only data areas
58
* 2) provide more effective-address space in case
59
* the BATs are not enough
60
* 3) allow 'alias' mappings. Such aliases can only use
61
* the upper bits of the VSID since VSID & 0xf and the
62
* PI are always mapped 1:1 to the RPN.
63
* LIMITATIONS:
64
* - no PTE replacement (makes no sense in a real-time
65
* environment, anyway) -> the page table just MUST
66
* be big enough!.
67
* - only one page table supported.
68
* - no locking implemented. If multiple threads modify
69
* the page table, it is the user's responsibility to
70
* implement exclusive access.
71
*/
72
73
74
/* I don't include mmu.h here because it says it's derived from linux
75
* and I want to avoid licensing problems
76
*/
77
78
/* Abstract handle for a page table */
79
typedef
struct
Triv121PgTblRec_
*
Triv121PgTbl
;
80
81
/* A PTE entry */
82
typedef
struct
PTERec_
{
83
volatile
unsigned
long
v:1, vsid:24, h:1, api: 6;
84
volatile
unsigned
long
rpn:20, pad: 3, r:1, c:1, wimg:4, marked:1, pp:2;
85
}
PTERec
, *
APte
;
86
87
/* Initialize a trivial page table
88
* using 2^ldSize bytes of memory starting at
89
* 'base'.
90
*
91
* RETURNS: a handle to the internal data structure
92
* used to manage the page table. NULL on
93
* error.
94
*
95
* NOTES: - 'base' must be aligned to the size
96
* - minimal ldSize is 16 (== 64k)
97
* - this routine maps the page table itself
98
* with read-only access. While this prevents
99
* the CPU from overwriting the page table,
100
* it can still be corrupted by PCI bus masters
101
* (like DMA engines, [VME] bridges etc.) and
102
* even by this CPU if either the MMU is off
103
* or if there is a DBAT mapping granting write
104
* access...
105
*/
106
Triv121PgTbl
107
triv121PgTblInit(
unsigned
long
base,
unsigned
ldSize);
108
109
/* get the log2 of the minimal page table size needed
110
* for mapping 'size' bytes.
111
*
112
* EXAMPLE: create a page table which maps the entire
113
* physical memory. The page table itself shall
114
* be allocated at the top of the available
115
* memory (assuming 'memsize' is a power of two):
116
*
117
* ldSize = triv121PgTblLdMinSize(memsize);
118
* memsize -= (1<<ldSize); / * reduce memory available to RTEMS * /
119
* pgTbl = triv121PgTblInit(memsize,ldSize);
120
*
121
*/
122
unsigned
long
123
triv121PgTblLdMinSize(
unsigned
long
size
);
124
125
/* Map an address range 1:1 in pgTbl with the given protection;
126
*
127
* RETURNS: -1 (TRIV121_MAP_SUCCESS) on success; the page index
128
* for which no PTE could be allocated, on failure.
129
*
130
* NOTES: - This routine returns MINUS ONE ON SUCCESS
131
* - (parts) of a mapping which overlap with
132
* already existing PTEs are silently ignored.
133
*
134
* Therefore, you can e.g. first create
135
* a couple of write protected maps and
136
* finally map the entire memory r/w. This
137
* will leave the write protected maps
138
* intact.
139
*/
140
long
141
triv121PgTblMap(
142
Triv121PgTbl
pgTbl,
/* handle, returned by Init or Get */
143
144
long
vsid,
/* vsid for this mapping (contains topmost 4 bits of EA);
145
*
146
* NOTE: it is allowed to pass a VSID < 0 to tell this
147
* routine it should use a VSID corresponding to a
148
* 1:1:1 effective - virtual - physical mapping
149
*/
150
151
unsigned
long
start,
/* segment offset (lowermost 28 bits of EA) of address range
152
*
153
* NOTE: if VSID < 0 (TRIV121_121_VSID), 'start' is inter-
154
* preted as an effective address (EA), i.e. all 32
155
* bits are used - the most significant four going into
156
* to the VSID...
157
*/
158
159
unsigned
long
numPages,
/* number of pages to map */
160
161
unsigned
wimgAttr,
/* 'wimg' attributes
162
* (Write thru, cache Inhibit, coherent Memory,
163
* Guarded memory)
164
*/
165
166
unsigned
protection
/* 'pp' access protection: Super User
167
*
168
* 0 r/w none
169
* 1 r/w ro
170
* 2 r/w r/w
171
* 3 ro ro
172
*/
173
);
174
175
#define TRIV121_ATTR_W 8
176
#define TRIV121_ATTR_I 4
177
#define TRIV121_ATTR_M 2
178
#define TRIV121_ATTR_G 1
179
180
/* for I/O pages (e.g. PCI, VME addresses) use cache inhibited
181
* and guarded pages. RTM about the 'eieio' instruction!
182
*/
183
#define TRIV121_ATTR_IO_PAGE (TRIV121_ATTR_I|TRIV121_ATTR_G)
184
185
#define TRIV121_PP_RO_PAGE (1)
/* read-only for key = 1, unlocked by key=0 */
186
#define TRIV121_PP_RW_PAGE (2)
/* read-write for key = 1/0 */
187
188
#define TRIV121_121_VSID (-1)
/* use 1:1 effective<->virtual address mapping */
189
#define TRIV121_SEG_VSID (-2)
/* lookup VSID in the segment register */
190
191
#define TRIV121_MAP_SUCCESS (-1)
/* triv121PgTblMap() returns this on SUCCESS */
192
193
/* get a handle to the one and only page table
194
* (must have been initialized/allocated)
195
*
196
* RETURNS: NULL if the page table has not been initialized/allocated.
197
*/
198
Triv121PgTbl
199
triv121PgTblGet(
void
);
200
201
/*
202
* compute the SDR1 register value for the page table
203
*/
204
205
unsigned
long
206
triv121PgTblSDR1(
Triv121PgTbl
pgTbl);
207
208
/*
209
* Activate the page table:
210
* - set up the segment registers for a 1:1 effective <-> virtual address mapping,
211
* give user and supervisor keys.
212
* - set up the SDR1 register
213
* - flush all tlbs
214
* - 'lock' pgTbl, i.e. prevent all further modifications.
215
*
216
* NOTE: This routine does not change any BATs. Since these
217
* have priority over the page table, the user
218
* may have to switch overlapping BATs OFF in order
219
* for the page table mappings to take effect.
220
*/
221
void
triv121PgTblActivate(
Triv121PgTbl
pgTbl);
222
223
/* Find the PTE for a EA and print its contents to stdout
224
* RETURNS: pte for EA or NULL if no entry was found.
225
*/
226
APte
triv121DumpEa(
unsigned
long
ea);
227
228
/* Find and return a PTE for a vsid/pi combination
229
* RETURNS: pte or NULL if no entry was found
230
*/
231
APte
triv121FindPte(
unsigned
long
vsid,
unsigned
long
pi);
232
233
/*
234
* Unmap an effective address
235
*
236
* RETURNS: pte that mapped the ea or NULL if no
237
* mapping existed.
238
*/
239
APte
triv121UnmapEa(
unsigned
long
ea);
240
241
/*
242
* Change the WIMG and PP attributes of the page containing 'ea'
243
*
244
* NOTES: The 'wimg' and 'pp' may be <0 to indicate that no
245
* change is desired.
246
*
247
* RETURNS: Pointer to modified PTE or NULL if 'ea' is not mapped.
248
*/
249
APte
triv121ChangeEaAttributes(
unsigned
long
ea,
int
wimg,
int
pp);
250
251
/* Make the whole page table writable
252
* NOTES: If the page table has not been initialized yet,
253
* this routine has no effect (i.e., after
254
* initialization the page table will still be read-only).
255
*/
256
void
triv121MakePgTblRW(
void
);
257
258
/* Make the whole page table read-only
259
*/
260
void
triv121MakePgTblRO(
void
);
261
262
/* Dump a pte to stdout */
263
long
triv121DumpPte(
APte
pte
);
264
265
#endif
_pte
Definition:
mmu.h:130
PTERec_
Definition:
pte121.h:82
Triv121PgTblRec_
Definition:
pte121.c:210
size
unsigned size
Definition:
tte.h:74
Generated by
1.8.15