source: rtems/c/src/lib/libcpu/powerpc/shared/mmu.h @ a4f6b02

4.104.114.84.95
Last change on this file since a4f6b02 was a4f6b02, checked in by Joel Sherrill <joel.sherrill@…>, on 06/14/99 at 17:54:21

This is a large patch from Eric Valette <valette@…> that was
described in the message following this paragraph. This patch also includes
a mcp750 BSP.

From valette@… Mon Jun 14 10:03:08 1999
Date: Tue, 18 May 1999 01:30:14 +0200 (CEST)
From: VALETTE Eric <valette@…>
To: joel@…
Cc: raguet@…, rtems-snapshots@…, valette@…
Subject: Questions/Suggestion? regarding RTEMS PowerPC code (long)

Dear knowledgeable RTEMS powerpc users,

As some of you may know, I'm currently finalizing a port
of RTEMS on a MCP750 Motorola board. I have done most
of it but have some questions to ask before submitting
the port.

In order to understand some of the changes I have made
or would like to make, maybe it is worth describing the
MCP750 Motorola board.

the MCP750 is a COMPACT PCI powerpc board with :

1) a MPC750 233 MHz processor,
2) a raven bus bridge/PCI controller that
implement an OPENPIC compliant interrupt controller,
3) a VIA 82C586 PCI/ISA bridge that offers a PC
compliant IO for keyboard, serial line, IDE, and
the well known PC 8259 cascaded PIC interrupt
architecture model,
4) a DEC 21140 Ethernet controller,
5) the PPCBUG Motorola firmware in flash,
6) A DEC PCI bridge,

This architecture is common to most Motorola 60x/7xx
board except that :

1) on VME board, the DEC PCI bridge is replaced by
a VME chipset,
2) the VIA 82C586 PCI/ISA bridge is replaced by
another bridge that is almost fully compatible
with the via bridge...

So the port should be a rather close basis for many
60x/7xx motorola board...

On this board, I already have ported Linux 2.2.3 and
use it both as a development and target board.

Now the questions/suggestions I have :

1) EXCEPTION CODE


As far as I know exceptions on PPC are handled like
interrupts. I dislike this very much as :

a) Except for the decrementer exception (and
maybe some other on mpc8xx), exceptions are
not recoverable and the handler just need to print
the full context and go to the firmware or debugger...
b) The interrupt switch is only necessary for the
decrementer and external interrupt (at least on
6xx,7xx).
c) The full context for exception is never saved and
thus cannot be used by debugger... I do understand
the most important for interrupts low level code
is to save the minimal context enabling to call C
code for performance reasons. On non recoverable
exception on the other hand, the most important is
to save the maximum information concerning proc status
in order to analyze the reason of the fault. At
least we will need this in order to implement the
port of RGDB on PPC

==> I wrote an API for connecting raw exceptions (and thus
raw interrupts) for mpc750. It should be valid for most
powerpc processors... I hope to find a way to make this coexist
with actual code layout. The code is actually located
in lib/libcpu/powerpc/mpc750 and is thus optional
(provided I write my own version of exec/score/cpu/powerpc/cpu.c ...)

See remark about files/directory layout organization in 4)

2) Current Implementation of ISR low level code


I do not understand why the MSR EE flags is cleared
again in exec/score/cpu/powerpc/irq_stubs.S

#if (PPC_USE_SPRG)

mfmsr r5
mfspr r6, sprg2

#else

lwz r6,msr_initial(r11)
lis r5,~PPC_MSR_DISABLE_MASK@ha
ori r5,r5,~PPC_MSR_DISABLE_MASK@l
and r6,r6,r5
mfmsr r5

#endif

Reading the doc, when a decrementer interrupt or an
external interrupt is active, the MSR EE flag is already
cleared. BTW if exception/interrupt could occur, it would
trash SRR0 and SRR1. In fact the code may be useful to set
MSR[RI] that re-enables exception processing. BTW I will need
to set other value in MSR to handle interrupts :

a) I want the MSR[IR] and MSR[DR] to be set for
performance reasons and also because I need DBAT
support to have access to PCI memory space as the
interrupt controller is in the PCI space.

Reading the code, I see others have the same kind of request :

/* SCE 980217

*

  • We need address translation ON when we call our ISR routine

mtmsr r5

*/

This is just another prof that even the lowest level
IRQ code is fundamentally board dependent and
not simply processor dependent especially when
the processor use external interrupt controller
because it has a single interrupt request line...

Note that if you look at the PPC code high level interrupt
handling code, as the "set_vector" routine that really connects
the interrupt is in the BSP/startup/genpvec.c,
the fact that IRQ handling is BSP specific is DE-FACTO
acknowledged.

I know I have already expressed this and understand that this
would require some heavy change in the code but believe
me you will reach a point where you will not be able
to find a compatible while optimum implementation for low level
interrupt handling code...) In my case this is already true...

So please consider removing low level IRQ handling from
exec/score/cpu/* and only let there exception handling code...
Exceptions are usually only processor dependent and do
not depend on external hardware mechanism to be masked or
acknowledged or re-enabled (there are probably exception but ...)

I have already done this for pc386 bsp but need to make it again.
This time I will even propose an API.

3) R2/R13 manipulation for EABI implementation


I do not understand the handling of r2 and r13 in the
EABI case. The specification for r2 says pointer to sdata2,
sbss2 section => constant. However I do not see -ffixed-r2
passed to any compilation system in make/custom/*
(for info linux does this on PPC).

So either this is a default compiler option when choosing
powerpc-rtems and thus we do not need to do anything with
this register as all the code is compiled with this compiler
and linked together OR this register may be used by rtems code
and then we do not need any special initialization or
handling.

The specification for r13 says pointer to the small data
area. r13 argumentation is the same except that as far
as I know the usage of the small data area requires
specific compiler support so that access to variables is
compiled via loading the LSB in a register and then
using r13 to get full address... It is like a small
memory model and it was present in IBM C compilers.

=> I propose to suppress any specific code for r2 and
r13 in the EABI case.

4) Code layout organization (yes again :-))


I think there are a number of design flaws in the way
the code is for ppc organized and I will try to point them out.
I have been beaten by this again on this new port, and
was beaten last year while modifying code for pc386.

a) exec/score/cpu/* vs lib/libcpu/cpu/*.

I think that too many things are put in exec/score/cpu that
have nothing to do with RTEMS internals but are rather
related to CPU feature.

This include at least :

a) registers access routine (e.g GET_MSR_Value),
b) interrupt masking/unmasking routines,
c) cache_mngt_routine,
d) mmu_mngt_routine,
e) Routines to connect the raw_exception, raw_interrupt
handler,

b) lib/libcpu/cpu/powerpc/*

With a processor family as exuberant as the powerpc family,
and their well known subtle differences (604 vs 750) or
unfortunately majors (8xx vs 60x) the directory structure
is fine (except maybe the names that are not homogeneous)

powerpc

ppc421 mpc821 ...

I only needed to add mpc750. But the fact that libcpu.a was not
produced was a pain and the fact that this organization may
duplicates code is also problematic.

So, except if the support of automake provides a better solution
I would like to propose something like this :

powerpc

mpc421 mpc821 ... mpc750 shared wrapup

with the following rules :

a) "shared" would act as a source container for sources that may
be shared among processors. Needed files would be compiled inside
the processor specific directory using the vpath Makefile
mechanism. "shared" may also contain compilation code
for routine that are really shared and not worth to inline...
(did not found many things so far as registers access routine
ARE WORTH INLINING)... In the case something is compiled there,
it should create libcpushared.a

b) layout under processor specific directory is free provided
that

1)the result of the compilation process exports :

libcpu/powerpc/"PROC"/*.h in $(PROJECT_INCLUDE)/libcpu

2) each processor specific directory creates
a library called libcpuspecific.a

Note that this organization enables to have a file that
is nearly the same than in shared but that must differ
because of processor differences...

c) "wrapup" should create libcpu.a using libcpushared.a
libcpuspecific.a and export it $(PROJECT_INCLUDE)/libcpu

The only thing I have no ideal solution is the way to put shared
definitions in "shared" and only processor specific definition
in "proc". To give a concrete example, most MSR bit definition
are shared among PPC processors and only some differs. if we create
a single msr.h in shared it will have ifdef. If in msr.h we
include libcpu/msr_c.h we will need to have it in each prowerpc
specific directory (even empty). Opinions are welcomed ...

Note that a similar mechanism exist in libbsp/i386 that also
contains a shared directory that is used by several bsp
like pc386 and i386ex and a similar wrapup mechanism...

NB: I have done this for mpc750 and other processors could just use
similar Makefiles...

c) The exec/score/cpu/powerpc directory layout.

I think the directory layout should be the same than the
libcpu/powerpc. As it is not, there are a lot of ifdefs
inside the code... And of course low level interrupt handling
code should be removed...

Besides that I do not understand why

1) things are compiled in the wrap directory,
2) some includes are moved to rtems/score,

I think the "preinstall" mechanism enables to put
everything in the current directory (or better in a per processor
directory),

5) Interrupt handling API


Again :-). But I think that using all the features the PIC
offers is a MUST for RT system. I already explained in the
prologue of this (long and probably boring) mail that the MCP750
boards offers an OPENPIC compliant architecture and that
the VIA 82586 PCI/ISA bridge offers a PC compatible IO and
PIC mapping. Here is a logical view of the RAVEN/VIA 82586
interrupt mapping :


| OPEN | <-----|8259|
| PIC | | | 2 ------
|(RAVEN)| | | <-----|8259|
| | | | | | 11
| | | | | | <----
| | | | | |
| | | | | |


------
| VIA PCI/ISA bridge
| x
-------- PCI interrupts

OPENPIC offers interrupt priorities among PCI interrupts
and interrupt selective masking. The 8259 offers the same kind
of feature. With actual powerpc interrupt code :

1) there is no way to specify priorities among
interrupts handler. This is REALLY a bad thing.
For me it is as importnat as having priorities
for threads...
2) for my implementation, each ISR should
contain the code that acknowledge the RAVEN
and 8259 cascade, modify interrupt mask on both
chips, and reenable interrupt at processor level,
..., restore then on interrupt return,.... This code
is actually similar to code located in some
genpvec.c powerpc files,
3) I must update _ISR_Nesting_level because
irq.inl use it...
4) the libchip code connects the ISR via set_vector
but the libchip handler code does not contain any code to
manipulate external interrupt controller hardware
in order to acknoledge the interrupt or re-enable
them (except for the target hardware of course)
So this code is broken unless set_vector adds an
additionnal prologue/epilogue before calling/returning
from in order to acknoledge/mask the raven and the
8259 PICS... => Anyway already EACH BSP MUST REWRITE
PART OF INTERRUPT HANDLING CODE TO CORRECTLY IMPLEMENT
SET_VECTOR.

I would rather offer an API similar to the one provided
in libbsp/i386/shared/irq/irq.h so that :

1) Once the driver supplied methods is called the
only things the ISR has to do is to worry about the
external hardware that triggered the interrupt.
Everything on openpic/VIA/processor would have been
done by the low levels (same things as set-vector)
2) The caller will need to supply the on/off/isOn
routine that are fundamental to correctly implements
debuggers/performance monitoring is a portable way
3) A globally configurable interrupt priorities
mechanism...

I have nothing against providing a compatible
set_vector just to make libchip happy but
as I have already explained in other
mails (months ago), I really think that the ISR
connection should be handled by the BSP and that no
code containing irq connection should exist the
rtems generic layers... Thus I really dislike
libchip on this aspect because in a long term
it will force to adopt the less reach API
for interrupt handling that exists (set_vector).

Additional note : I think the _ISR_Is_in_progress()
inline routine should be :

1) Put in a processor specific section,
2) Should not rely on a global variable,

As :

a) on symmetric MP, there is one interrupt level
per CPU,
b) On processor that have an ISP (e,g 68040),
this variable is useless (MSR bit testing could
be used)
c) On PPC, instead of using the address of the
variable via CPU_IRQ_info.Nest_level a dedicated
SPR could be used.

NOTE: most of this is also true for _Thread_Dispatch_disable_level

END NOTE


Please do not take what I said in the mail as a criticism for
anyone who submitted ppc code. Any code present helped me
a lot understanding PPC behavior. I just wanted by this
mail to :

1) try to better understand the actual code,
2) propose concrete ways of enhancing current code
by providing an alternative implementation for MCP750. I
will make my best effort to try to brake nothing but this
is actually hard due to the file layout organisation.
3) make understandable some changes I will probably make
if joel let me do them :-)

Any comments/objections are welcomed as usual.

--


/ ` Eric Valette

/-- o _. Canon CRF

(_, / (_(_( Rue de la touche lambert

35517 Cesson-Sevigne Cedex
FRANCE

Tel: +33 (0)2 99 87 68 91 Fax: +33 (0)2 99 84 11 30
E-mail: valette@…

  • Property mode set to 100644
File size: 10.4 KB
Line 
1/*
2 * PowerPC memory management structures
3 */
4
5#ifndef _PPC_MMU_H_
6#define _PPC_MMU_H_
7
8#ifndef ASM
9/* Hardware Page Table Entry */
10typedef struct _PTE {
11        unsigned long v:1;      /* Entry is valid */
12        unsigned long vsid:24;  /* Virtual segment identifier */
13        unsigned long h:1;      /* Hash algorithm indicator */
14        unsigned long api:6;    /* Abbreviated page index */
15        unsigned long rpn:20;   /* Real (physical) page number */
16        unsigned long    :3;    /* Unused */
17        unsigned long r:1;      /* Referenced */
18        unsigned long c:1;      /* Changed */
19        unsigned long w:1;      /* Write-thru cache mode */
20        unsigned long i:1;      /* Cache inhibited */
21        unsigned long m:1;      /* Memory coherence */
22        unsigned long g:1;      /* Guarded */
23        unsigned long  :1;      /* Unused */
24        unsigned long pp:2;     /* Page protection */
25} PTE;
26
27/* Values for PP (assumes Ks=0, Kp=1) */
28#define PP_RWXX 0       /* Supervisor read/write, User none */
29#define PP_RWRX 1       /* Supervisor read/write, User read */
30#define PP_RWRW 2       /* Supervisor read/write, User read/write */
31#define PP_RXRX 3       /* Supervisor read,       User read */
32
33/* Segment Register */
34typedef struct _SEGREG {
35        unsigned long t:1;      /* Normal or I/O  type */
36        unsigned long ks:1;     /* Supervisor 'key' (normally 0) */
37        unsigned long kp:1;     /* User 'key' (normally 1) */
38        unsigned long n:1;      /* No-execute */
39        unsigned long :4;       /* Unused */
40        unsigned long vsid:24;  /* Virtual Segment Identifier */
41} SEGREG;
42
43/* Block Address Translation (BAT) Registers */
44typedef struct _P601_BATU {     /* Upper part of BAT for 601 processor */
45        unsigned long bepi:15;  /* Effective page index (virtual address) */
46        unsigned long :8;       /* unused */
47        unsigned long w:1;
48        unsigned long i:1;      /* Cache inhibit */
49        unsigned long m:1;      /* Memory coherence */
50        unsigned long ks:1;     /* Supervisor key (normally 0) */
51        unsigned long kp:1;     /* User key (normally 1) */
52        unsigned long pp:2;     /* Page access protections */
53} P601_BATU;
54
55typedef struct _BATU {          /* Upper part of BAT (all except 601) */
56        unsigned long bepi:15;  /* Effective page index (virtual address) */
57        unsigned long :4;       /* Unused */
58        unsigned long bl:11;    /* Block size mask */
59        unsigned long vs:1;     /* Supervisor valid */
60        unsigned long vp:1;     /* User valid */
61} BATU;   
62
63typedef struct _P601_BATL {     /* Lower part of BAT for 601 processor */
64        unsigned long brpn:15;  /* Real page index (physical address) */
65        unsigned long :10;      /* Unused */
66        unsigned long v:1;      /* Valid bit */
67        unsigned long bl:6;     /* Block size mask */
68} P601_BATL;
69
70typedef struct _BATL {          /* Lower part of BAT (all except 601) */
71        unsigned long brpn:15;  /* Real page index (physical address) */
72        unsigned long :10;      /* Unused */
73        unsigned long w:1;      /* Write-thru cache */
74        unsigned long i:1;      /* Cache inhibit */
75        unsigned long m:1;      /* Memory coherence */
76        unsigned long g:1;      /* Guarded (MBZ in IBAT) */
77        unsigned long :1;       /* Unused */
78        unsigned long pp:2;     /* Page access protections */
79} BATL;
80
81typedef struct _BAT {
82        BATU batu;              /* Upper register */
83        BATL batl;              /* Lower register */
84} BAT;
85
86typedef struct _P601_BAT {
87        P601_BATU batu;         /* Upper register */
88        P601_BATL batl;         /* Lower register */
89} P601_BAT;
90
91/* Block size masks */
92#define BL_128K 0x000
93#define BL_256K 0x001
94#define BL_512K 0x003
95#define BL_1M   0x007
96#define BL_2M   0x00F
97#define BL_4M   0x01F
98#define BL_8M   0x03F
99#define BL_16M  0x07F
100#define BL_32M  0x0FF
101#define BL_64M  0x1FF
102#define BL_128M 0x3FF
103#define BL_256M 0x7FF
104
105/* BAT Access Protection */
106#define BPP_XX  0x00            /* No access */
107#define BPP_RX  0x01            /* Read only */
108#define BPP_RW  0x02            /* Read/write */
109
110/*
111 * Simulated two-level MMU.  This structure is used by the kernel
112 * to keep track of MMU mappings and is used to update/maintain
113 * the hardware HASH table which is really a cache of mappings.
114 *
115 * The simulated structures mimic the hardware available on other
116 * platforms, notably the 80x86 and 680x0.
117 */
118
119typedef struct _pte {
120        unsigned long page_num:20;
121        unsigned long flags:12;         /* Page flags (some unused bits) */
122} pte;
123
124#define PD_SHIFT (10+12)                /* Page directory */
125#define PD_MASK  0x03FF
126#define PT_SHIFT (12)                   /* Page Table */
127#define PT_MASK  0x03FF
128#define PG_SHIFT (12)                   /* Page Entry */
129 
130
131/* MMU context */
132
133typedef struct _MMU_context {
134        SEGREG  segs[16];       /* Segment registers */
135        pte     **pmap;         /* Two-level page-map structure */
136} MMU_context;
137
138/* Used to set up SDR1 register */
139#define HASH_TABLE_SIZE_64K     0x00010000
140#define HASH_TABLE_SIZE_128K    0x00020000
141#define HASH_TABLE_SIZE_256K    0x00040000
142#define HASH_TABLE_SIZE_512K    0x00080000
143#define HASH_TABLE_SIZE_1M      0x00100000
144#define HASH_TABLE_SIZE_2M      0x00200000
145#define HASH_TABLE_SIZE_4M      0x00400000
146#define HASH_TABLE_MASK_64K     0x000   
147#define HASH_TABLE_MASK_128K    0x001   
148#define HASH_TABLE_MASK_256K    0x003   
149#define HASH_TABLE_MASK_512K    0x007
150#define HASH_TABLE_MASK_1M      0x00F   
151#define HASH_TABLE_MASK_2M      0x01F   
152#define HASH_TABLE_MASK_4M      0x03F   
153
154/* invalidate a TLB entry */
155extern inline void _tlbie(unsigned long va)
156{
157        asm volatile ("tlbie %0" : : "r"(va));
158}
159
160extern void _tlbia(void);               /* invalidate all TLB entries */
161#endif /* ASM */
162
163/* Control/status registers for the MPC8xx.
164 * A write operation to these registers causes serialized access.
165 * During software tablewalk, the registers used perform mask/shift-add
166 * operations when written/read.  A TLB entry is created when the Mx_RPN
167 * is written, and the contents of several registers are used to
168 * create the entry.
169 */
170#define MI_CTR          784     /* Instruction TLB control register */
171#define MI_GPM          0x80000000      /* Set domain manager mode */
172#define MI_PPM          0x40000000      /* Set subpage protection */
173#define MI_CIDEF        0x20000000      /* Set cache inhibit when MMU dis */
174#define MI_RSV4I        0x08000000      /* Reserve 4 TLB entries */
175#define MI_PPCS         0x02000000      /* Use MI_RPN prob/priv state */
176#define MI_IDXMASK      0x00001f00      /* TLB index to be loaded */
177#define MI_RESETVAL     0x00000000      /* Value of register at reset */
178
179/* These are the Ks and Kp from the PowerPC books.  For proper operation,
180 * Ks = 0, Kp = 1.
181 */
182#define MI_AP           786
183#define MI_Ks           0x80000000      /* Should not be set */
184#define MI_Kp           0x40000000      /* Should always be set */
185
186/* The effective page number register.  When read, contains the information
187 * about the last instruction TLB miss.  When MI_RPN is written, bits in
188 * this register are used to create the TLB entry.
189 */
190#define MI_EPN          787
191#define MI_EPNMASK      0xfffff000      /* Effective page number for entry */
192#define MI_EVALID       0x00000200      /* Entry is valid */
193#define MI_ASIDMASK     0x0000000f      /* ASID match value */
194                                        /* Reset value is undefined */
195
196/* A "level 1" or "segment" or whatever you want to call it register.
197 * For the instruction TLB, it contains bits that get loaded into the
198 * TLB entry when the MI_RPN is written.
199 */
200#define MI_TWC          789
201#define MI_APG          0x000001e0      /* Access protection group (0) */
202#define MI_GUARDED      0x00000010      /* Guarded storage */
203#define MI_PSMASK       0x0000000c      /* Mask of page size bits */
204#define MI_PS8MEG       0x0000000c      /* 8M page size */
205#define MI_PS512K       0x00000004      /* 512K page size */
206#define MI_PS4K_16K     0x00000000      /* 4K or 16K page size */
207#define MI_SVALID       0x00000001      /* Segment entry is valid */
208                                        /* Reset value is undefined */
209
210/* Real page number.  Defined by the pte.  Writing this register
211 * causes a TLB entry to be created for the instruction TLB, using
212 * additional information from the MI_EPN, and MI_TWC registers.
213 */
214#define MI_RPN          790
215
216/* Define an RPN value for mapping kernel memory to large virtual
217 * pages for boot initialization.  This has real page number of 0,
218 * large page size, shared page, cache enabled, and valid.
219 * Also mark all subpages valid and write access.
220 */
221#define MI_BOOTINIT     0x000001fd
222
223#define MD_CTR          792     /* Data TLB control register */
224#define MD_GPM          0x80000000      /* Set domain manager mode */
225#define MD_PPM          0x40000000      /* Set subpage protection */
226#define MD_CIDEF        0x20000000      /* Set cache inhibit when MMU dis */
227#define MD_WTDEF        0x10000000      /* Set writethrough when MMU dis */
228#define MD_RSV4I        0x08000000      /* Reserve 4 TLB entries */
229#define MD_TWAM         0x04000000      /* Use 4K page hardware assist */
230#define MD_PPCS         0x02000000      /* Use MI_RPN prob/priv state */
231#define MD_IDXMASK      0x00001f00      /* TLB index to be loaded */
232#define MD_RESETVAL     0x04000000      /* Value of register at reset */
233
234#define M_CASID         793     /* Address space ID (context) to match */
235#define MC_ASIDMASK     0x0000000f      /* Bits used for ASID value */
236
237
238/* These are the Ks and Kp from the PowerPC books.  For proper operation,
239 * Ks = 0, Kp = 1.
240 */
241#define MD_AP           794
242#define MD_Ks           0x80000000      /* Should not be set */
243#define MD_Kp           0x40000000      /* Should always be set */
244
245/* The effective page number register.  When read, contains the information
246 * about the last instruction TLB miss.  When MD_RPN is written, bits in
247 * this register are used to create the TLB entry.
248 */
249#define MD_EPN          795
250#define MD_EPNMASK      0xfffff000      /* Effective page number for entry */
251#define MD_EVALID       0x00000200      /* Entry is valid */
252#define MD_ASIDMASK     0x0000000f      /* ASID match value */
253                                        /* Reset value is undefined */
254
255/* The pointer to the base address of the first level page table.
256 * During a software tablewalk, reading this register provides the address
257 * of the entry associated with MD_EPN.
258 */
259#define M_TWB           796
260#define M_L1TB          0xfffff000      /* Level 1 table base address */
261#define M_L1INDX        0x00000ffc      /* Level 1 index, when read */
262                                        /* Reset value is undefined */
263
264/* A "level 1" or "segment" or whatever you want to call it register.
265 * For the data TLB, it contains bits that get loaded into the TLB entry
266 * when the MD_RPN is written.  It is also provides the hardware assist
267 * for finding the PTE address during software tablewalk.
268 */
269#define MD_TWC          797
270#define MD_L2TB         0xfffff000      /* Level 2 table base address */
271#define MD_L2INDX       0xfffffe00      /* Level 2 index (*pte), when read */
272#define MD_APG          0x000001e0      /* Access protection group (0) */
273#define MD_GUARDED      0x00000010      /* Guarded storage */
274#define MD_PSMASK       0x0000000c      /* Mask of page size bits */
275#define MD_PS8MEG       0x0000000c      /* 8M page size */
276#define MD_PS512K       0x00000004      /* 512K page size */
277#define MD_PS4K_16K     0x00000000      /* 4K or 16K page size */
278#define MD_WT           0x00000002      /* Use writethrough page attribute */
279#define MD_SVALID       0x00000001      /* Segment entry is valid */
280                                        /* Reset value is undefined */
281
282
283/* Real page number.  Defined by the pte.  Writing this register
284 * causes a TLB entry to be created for the data TLB, using
285 * additional information from the MD_EPN, and MD_TWC registers.
286 */
287#define MD_RPN          798
288
289/* This is a temporary storage register that could be used to save
290 * a processor working register during a tablewalk.
291 */
292#define M_TW            799
293#endif /* _PPC_MMU_H_ */
Note: See TracBrowser for help on using the repository browser.