2005-09-26 16:04:21 +10:00
/ *
* $ Id : hashtable. S ,v 1 . 6 1 9 9 9 / 1 0 / 0 8 0 1 : 5 6 : 1 5 p a u l u s E x p $
*
* PowerPC v e r s i o n
* Copyright ( C ) 1 9 9 5 - 1 9 9 6 G a r y T h o m a s ( g d t @linuxppc.org)
* Rewritten b y C o r t D o u g a n ( c o r t @cs.nmt.edu) for PReP
* Copyright ( C ) 1 9 9 6 C o r t D o u g a n < c o r t @cs.nmt.edu>
* Adapted f o r P o w e r M a c i n t o s h b y P a u l M a c k e r r a s .
* Low- l e v e l e x c e p t i o n h a n d l e r s a n d M M U s u p p o r t
* rewritten b y P a u l M a c k e r r a s .
* Copyright ( C ) 1 9 9 6 P a u l M a c k e r r a s .
*
* This f i l e c o n t a i n s l o w - l e v e l a s s e m b l e r r o u t i n e s f o r m a n a g i n g
* the P o w e r P C M M U h a s h t a b l e . ( P P C 8 x x p r o c e s s o r s d o n ' t u s e a
* hash t a b l e , s o t h i s f i l e i s n o t u s e d o n t h e m . )
*
* This p r o g r a m i s f r e e s o f t w a r e ; you can redistribute it and/or
* modify i t u n d e r t h e t e r m s o f t h e G N U G e n e r a l P u b l i c L i c e n s e
* as p u b l i s h e d b y t h e F r e e S o f t w a r e F o u n d a t i o n ; either version
* 2 of t h e L i c e n s e , o r ( a t y o u r o p t i o n ) a n y l a t e r v e r s i o n .
*
* /
2005-10-10 22:20:10 +10:00
# include < a s m / r e g . h >
2005-09-26 16:04:21 +10:00
# include < a s m / p a g e . h >
# include < a s m / p g t a b l e . h >
# include < a s m / c p u t a b l e . h >
# include < a s m / p p c _ a s m . h >
# include < a s m / t h r e a d _ i n f o . h >
# include < a s m / a s m - o f f s e t s . h >
# ifdef C O N F I G _ S M P
2007-05-14 17:11:58 -05:00
.section .bss
.align 2
.globl mmu_hash_lock
mmu_hash_lock :
.space 4
2005-09-26 16:04:21 +10:00
# endif / * C O N F I G _ S M P * /
/ *
* Sync C P U s w i t h h a s h _ p a g e t a k i n g & r e l e a s i n g t h e h a s h
* table l o c k
* /
# ifdef C O N F I G _ S M P
.text
_ GLOBAL( h a s h _ p a g e _ s y n c )
lis r8 ,m m u _ h a s h _ l o c k @h
ori r8 ,r8 ,m m u _ h a s h _ l o c k @l
lis r0 ,0 x0 f f f
b 1 0 f
11 : lwz r6 ,0 ( r8 )
cmpwi 0 ,r6 ,0
bne 1 1 b
10 : lwarx r6 ,0 ,r8
cmpwi 0 ,r6 ,0
bne- 1 1 b
stwcx. r0 ,0 ,r8
bne- 1 0 b
isync
eieio
li r0 ,0
stw r0 ,0 ( r8 )
blr
# endif
/ *
* Load a P T E i n t o t h e h a s h t a b l e , i f p o s s i b l e .
* The a d d r e s s i s i n r4 , a n d r3 c o n t a i n s a n a c c e s s f l a g :
* _ PAGE_ R W ( 0 x40 0 ) i f a w r i t e .
* r9 c o n t a i n s t h e S R R 1 v a l u e , f r o m w h i c h w e u s e t h e M S R _ P R b i t .
* SPRG3 c o n t a i n s t h e p h y s i c a l a d d r e s s o f t h e c u r r e n t t a s k ' s t h r e a d .
*
* Returns t o t h e c a l l e r i f t h e a c c e s s i s i l l e g a l o r t h e r e i s n o
* mapping f o r t h e a d d r e s s . O t h e r w i s e i t p l a c e s a n a p p r o p r i a t e P T E
* in t h e h a s h t a b l e a n d r e t u r n s f r o m t h e e x c e p t i o n .
* Uses r0 , r3 - r8 , c t r , l r .
* /
.text
_ GLOBAL( h a s h _ p a g e )
tophys( r7 ,0 ) / * g e t s - K E R N E L B A S E i n t o r7 * /
# ifdef C O N F I G _ S M P
addis r8 ,r7 ,m m u _ h a s h _ l o c k @h
ori r8 ,r8 ,m m u _ h a s h _ l o c k @l
lis r0 ,0 x0 f f f
b 1 0 f
11 : lwz r6 ,0 ( r8 )
cmpwi 0 ,r6 ,0
bne 1 1 b
10 : lwarx r6 ,0 ,r8
cmpwi 0 ,r6 ,0
bne- 1 1 b
stwcx. r0 ,0 ,r8
bne- 1 0 b
isync
# endif
/* Get PTE (linux-style) and check access */
lis r0 ,K E R N E L B A S E @h /* check if kernel address */
cmplw 0 ,r4 ,r0
mfspr r8 ,S P R N _ S P R G 3 / * c u r r e n t t a s k ' s T H R E A D ( p h y s ) * /
ori r3 ,r3 ,_ P A G E _ U S E R | _ P A G E _ P R E S E N T / * t e s t l o w a d d r e s s e s a s u s e r * /
lwz r5 ,P G D I R ( r8 ) / * v i r t p a g e - t a b l e r o o t * /
blt+ 1 1 2 f / * a s s u m e u s e r m o r e l i k e l y * /
lis r5 ,s w a p p e r _ p g _ d i r @ha /* if kernel address, use */
addi r5 ,r5 ,s w a p p e r _ p g _ d i r @l /* kernel page table */
rlwimi r3 ,r9 ,3 2 - 1 2 ,2 9 ,2 9 / * M S R _ P R - > _ P A G E _ U S E R * /
112 : add r5 ,r5 ,r7 / * c o n v e r t t o p h y s a d d r * /
rlwimi r5 ,r4 ,1 2 ,2 0 ,2 9 / * i n s e r t t o p 1 0 b i t s o f a d d r e s s * /
lwz r8 ,0 ( r5 ) / * g e t p m d e n t r y * /
rlwinm. r8 ,r8 ,0 ,0 ,1 9 / * e x t r a c t a d d r e s s o f p t e p a g e * /
# ifdef C O N F I G _ S M P
beq- h a s h _ p a g e _ o u t / * r e t u r n i f n o m a p p i n g * /
# else
/ * XXX i t s e e m s l i k e t h e 6 0 1 w i l l g i v e a m a c h i n e f a u l t o n t h e
rfi i f i t s a l i g n m e n t i s w r o n g ( b o t t o m 4 b i t s o f a d d r e s s a r e
8 or 0 x c ) a n d w e h a v e h a d a n o t - t a k e n c o n d i t i o n a l b r a n c h
to t h e a d d r e s s f o l l o w i n g t h e r f i . * /
beqlr-
# endif
rlwimi r8 ,r4 ,2 2 ,2 0 ,2 9 / * i n s e r t n e x t 1 0 b i t s o f a d d r e s s * /
rlwinm r0 ,r3 ,3 2 - 3 ,2 4 ,2 4 / * _ P A G E _ R W a c c e s s - > _ P A G E _ D I R T Y * /
ori r0 ,r0 ,_ P A G E _ A C C E S S E D | _ P A G E _ H A S H P T E
/ *
* Update t h e l i n u x P T E a t o m i c a l l y . W e d o t h e l w a r x u p - f r o n t
* because a l m o s t a l w a y s , t h e r e w o n ' t b e a p e r m i s s i o n v i o l a t i o n
* and t h e r e w o n ' t a l r e a d y b e a n H P T E , a n d t h u s w e w i l l h a v e
* to u p d a t e t h e P T E t o s e t _ P A G E _ H A S H P T E . - - p a u l u s .
* /
retry :
lwarx r6 ,0 ,r8 / * g e t l i n u x - s t y l e p t e * /
andc. r5 ,r3 ,r6 / * c h e c k a c c e s s & ~ p e r m i s s i o n * /
# ifdef C O N F I G _ S M P
bne- h a s h _ p a g e _ o u t / * r e t u r n i f a c c e s s n o t p e r m i t t e d * /
# else
bnelr-
# endif
or r5 ,r0 ,r6 / * s e t a c c e s s e d / d i r t y b i t s * /
stwcx. r5 ,0 ,r8 / * a t t e m p t t o u p d a t e P T E * /
bne- r e t r y / * r e t r y i f s o m e o n e g o t t h e r e f i r s t * /
mfsrin r3 ,r4 / * g e t s e g m e n t r e g f o r s e g m e n t * /
mfctr r0
stw r0 ,_ C T R ( r11 )
bl c r e a t e _ h p t e / * a d d t h e h a s h t a b l e e n t r y * /
# ifdef C O N F I G _ S M P
eieio
addis r8 ,r7 ,m m u _ h a s h _ l o c k @ha
li r0 ,0
stw r0 ,m m u _ h a s h _ l o c k @l(r8)
# endif
/* Return from the exception */
lwz r5 ,_ C T R ( r11 )
mtctr r5
lwz r0 ,G P R 0 ( r11 )
lwz r7 ,G P R 7 ( r11 )
lwz r8 ,G P R 8 ( r11 )
b f a s t _ e x c e p t i o n _ r e t u r n
# ifdef C O N F I G _ S M P
hash_page_out :
eieio
addis r8 ,r7 ,m m u _ h a s h _ l o c k @ha
li r0 ,0
stw r0 ,m m u _ h a s h _ l o c k @l(r8)
blr
# endif / * C O N F I G _ S M P * /
/ *
* Add a n e n t r y f o r a p a r t i c u l a r p a g e t o t h e h a s h t a b l e .
*
* add_ h a s h _ p a g e ( u n s i g n e d c o n t e x t , u n s i g n e d l o n g v a , u n s i g n e d l o n g p m d v a l )
*
* We a s s u m e a n y n e c e s s a r y m o d i f i c a t i o n s t o t h e p t e ( e . g . s e t t i n g
* the a c c e s s e d b i t ) h a v e a l r e a d y b e e n d o n e a n d t h a t t h e r e i s a c t u a l l y
* a h a s h t a b l e i n u s e ( i . e . w e ' r e n o t o n a 6 0 3 ) .
* /
_ GLOBAL( a d d _ h a s h _ p a g e )
mflr r0
stw r0 ,4 ( r1 )
/* Convert context and va to VSID */
mulli r3 ,r3 ,8 9 7 * 1 6 / * m u l t i p l y c o n t e x t b y c o n t e x t s k e w * /
rlwinm r0 ,r4 ,4 ,2 8 ,3 1 / * g e t E S I D ( t o p 4 b i t s o f v a ) * /
mulli r0 ,r0 ,0 x11 1 / * m u l t i p l y b y E S I D s k e w * /
add r3 ,r3 ,r0 / * n o t e c r e a t e _ h p t e t r i m s t o 2 4 b i t s * /
# ifdef C O N F I G _ S M P
rlwinm r8 ,r1 ,0 ,0 ,1 8 / * u s e c p u n u m b e r t o m a k e t a g * /
lwz r8 ,T I _ C P U ( r8 ) / * t o g o i n m m u _ h a s h _ l o c k * /
oris r8 ,r8 ,1 2
# endif / * C O N F I G _ S M P * /
/ *
* We d i s a b l e i n t e r r u p t s h e r e , e v e n o n U P , b e c a u s e w e d o n ' t
* want t o r a c e w i t h h a s h _ p a g e , a n d b e c a u s e w e w a n t t h e
* _ PAGE_ H A S H P T E b i t t o b e a r e l i a b l e i n d i c a t i o n o f w h e t h e r
* the H P T E e x i s t s ( o r a t l e a s t w h e t h e r o n e d i d o n c e ) .
* We a l s o t u r n o f f t h e M M U f o r d a t a a c c e s s e s s o t h a t w e
* we c a n ' t t a k e a h a s h t a b l e m i s s ( a s s u m i n g t h e c o d e i s
* covered b y a B A T ) . - - p a u l u s
* /
mfmsr r10
SYNC
rlwinm r0 ,r10 ,0 ,1 7 ,1 5 / * c l e a r b i t 1 6 ( M S R _ E E ) * /
rlwinm r0 ,r0 ,0 ,2 8 ,2 6 / * c l e a r M S R _ D R * /
mtmsr r0
SYNC_ 6 0 1
isync
tophys( r7 ,0 )
# ifdef C O N F I G _ S M P
addis r9 ,r7 ,m m u _ h a s h _ l o c k @ha
addi r9 ,r9 ,m m u _ h a s h _ l o c k @l
10 : lwarx r0 ,0 ,r9 / * t a k e t h e m m u _ h a s h _ l o c k * /
cmpi 0 ,r0 ,0
bne- 1 1 f
stwcx. r8 ,0 ,r9
beq+ 1 2 f
11 : lwz r0 ,0 ( r9 )
cmpi 0 ,r0 ,0
beq 1 0 b
b 1 1 b
12 : isync
# endif
/ *
* Fetch t h e l i n u x p t e a n d t e s t a n d s e t _ P A G E _ H A S H P T E a t o m i c a l l y .
* If _ P A G E _ H A S H P T E w a s a l r e a d y s e t , w e d o n ' t r e p l a c e t h e e x i s t i n g
* HPTE, s o w e j u s t u n l o c k a n d r e t u r n .
* /
mr r8 ,r5
rlwimi r8 ,r4 ,2 2 ,2 0 ,2 9
1 : lwarx r6 ,0 ,r8
andi. r0 ,r6 ,_ P A G E _ H A S H P T E
bne 9 f / * i f H A S H P T E a l r e a d y s e t , d o n e * /
ori r5 ,r6 ,_ P A G E _ H A S H P T E
stwcx. r5 ,0 ,r8
bne- 1 b
bl c r e a t e _ h p t e
9 :
# ifdef C O N F I G _ S M P
eieio
li r0 ,0
stw r0 ,0 ( r9 ) / * c l e a r m m u _ h a s h _ l o c k * /
# endif
/* reenable interrupts and DR */
mtmsr r10
SYNC_ 6 0 1
isync
lwz r0 ,4 ( r1 )
mtlr r0
blr
/ *
* This r o u t i n e a d d s a h a r d w a r e P T E t o t h e h a s h t a b l e .
* It i s d e s i g n e d t o b e c a l l e d w i t h t h e M M U e i t h e r o n o r o f f .
* r3 c o n t a i n s t h e V S I D , r4 c o n t a i n s t h e v i r t u a l a d d r e s s ,
* r5 c o n t a i n s t h e l i n u x P T E , r6 c o n t a i n s t h e o l d v a l u e o f t h e
* linux P T E ( b e f o r e s e t t i n g _ P A G E _ H A S H P T E ) a n d r7 c o n t a i n s t h e
* offset t o b e a d d e d t o a d d r e s s e s ( 0 i f t h e M M U i s o n ,
* - KERNELBASE i f i t i s o f f ) .
* On S M P , t h e c a l l e r s h o u l d h a v e t h e m m u _ h a s h _ l o c k h e l d .
* We a s s u m e t h a t t h e c a l l e r h a s ( o r w i l l ) s e t t h e _ P A G E _ H A S H P T E
* bit i n t h e l i n u x P T E i n m e m o r y . T h e v a l u e p a s s e d i n r6 s h o u l d
* be t h e o l d l i n u x P T E v a l u e ; if it doesn't have _PAGE_HASHPTE set
* this r o u t i n e w i l l s k i p t h e s e a r c h f o r a n e x i s t i n g H P T E .
* This p r o c e d u r e m o d i f i e s r0 , r3 - r6 , r8 , c r0 .
* - - paulus.
*
* For s p e e d , 4 o f t h e i n s t r u c t i o n s g e t p a t c h e d o n c e t h e s i z e a n d
* physical a d d r e s s o f t h e h a s h t a b l e a r e k n o w n . T h e s e d e f i n i t i o n s
* of H a s h _ b a s e a n d H a s h _ b i t s b e l o w a r e j u s t a n e x a m p l e .
* /
Hash_ b a s e = 0 x c01 8 0 0 0 0
Hash_ b i t s = 1 2 / * e . g . 2 5 6 k B h a s h t a b l e * /
Hash_ m s k = ( ( ( 1 < < H a s h _ b i t s ) - 1 ) * 6 4 )
/* defines for the PTE format for 32-bit PPCs */
# define P T E _ S I Z E 8
# define P T E G _ S I Z E 6 4
# define L G _ P T E G _ S I Z E 6
# define L D P T E u l w z u
2007-04-12 15:30:22 +10:00
# define L D P T E l w z
2005-09-26 16:04:21 +10:00
# define S T P T E s t w
# define C M P P T E c m p w
# define P T E _ H 0 x40
# define P T E _ V 0 x80 0 0 0 0 0 0
# define T S T _ V ( r ) r l w i n m . r ,r ,0 ,0 ,0
# define S E T _ V ( r ) o r i s r ,r ,P T E _ V @h
# define C L R _ V ( r ,t ) r l w i n m r ,r ,0 ,1 ,3 1
# define H A S H _ L E F T 3 1 - ( L G _ P T E G _ S I Z E + H a s h _ b i t s - 1 )
# define H A S H _ R I G H T 3 1 - L G _ P T E G _ S I Z E
_ GLOBAL( c r e a t e _ h p t e )
/* Convert linux-style PTE (r5) to low word of PPC-style PTE (r8) */
rlwinm r8 ,r5 ,3 2 - 1 0 ,3 1 ,3 1 / * _ P A G E _ R W - > P P l s b * /
rlwinm r0 ,r5 ,3 2 - 7 ,3 1 ,3 1 / * _ P A G E _ D I R T Y - > P P l s b * /
and r8 ,r8 ,r0 / * w r i t a b l e i f _ R W & _ D I R T Y * /
rlwimi r5 ,r5 ,3 2 - 1 ,3 0 ,3 0 / * _ P A G E _ U S E R - > P P m s b * /
rlwimi r5 ,r5 ,3 2 - 2 ,3 1 ,3 1 / * _ P A G E _ U S E R - > P P l s b * /
ori r8 ,r8 ,0 x e 1 4 / * c l e a r o u t r e s e r v e d b i t s a n d M * /
andc r8 ,r5 ,r8 / * P P = u s e r ? ( r w & d i r t y ? 2 : 3 ) : 0 * /
BEGIN_ F T R _ S E C T I O N
ori r8 ,r8 ,_ P A G E _ C O H E R E N T / * s e t M ( c o h e r e n c e r e q u i r e d ) * /
END_ F T R _ S E C T I O N _ I F S E T ( C P U _ F T R _ N E E D _ C O H E R E N T )
/* Construct the high word of the PPC-style PTE (r5) */
rlwinm r5 ,r3 ,7 ,1 ,2 4 / * p u t V S I D i n 0 x7 f f f f f80 b i t s * /
rlwimi r5 ,r4 ,1 0 ,2 6 ,3 1 / * p u t i n A P I ( a b b r e v p a g e i n d e x ) * /
SET_ V ( r5 ) / * s e t V ( v a l i d ) b i t * /
/* Get the address of the primary PTE group in the hash table (r3) */
_ GLOBAL( h a s h _ p a g e _ p a t c h _ A )
addis r0 ,r7 ,H a s h _ b a s e @h /* base address of hash table */
rlwimi r0 ,r3 ,L G _ P T E G _ S I Z E ,H A S H _ L E F T ,H A S H _ R I G H T / * V S I D - > h a s h * /
rlwinm r3 ,r4 ,2 0 + L G _ P T E G _ S I Z E ,H A S H _ L E F T ,H A S H _ R I G H T / * P I - > h a s h * /
xor r3 ,r3 ,r0 / * m a k e p r i m a r y h a s h * /
li r0 ,8 / * P T E s / g r o u p * /
/ *
* Test t h e _ P A G E _ H A S H P T E b i t i n t h e o l d l i n u x P T E , a n d s k i p t h e s e a r c h
* if i t i s c l e a r , m e a n i n g t h a t t h e H P T E i s n ' t t h e r e a l r e a d y . . .
* /
andi. r6 ,r6 ,_ P A G E _ H A S H P T E
beq+ 1 0 f / * n o P T E : g o l o o k f o r a n e m p t y s l o t * /
tlbie r4
addis r4 ,r7 ,h t a b _ h a s h _ s e a r c h e s @ha
lwz r6 ,h t a b _ h a s h _ s e a r c h e s @l(r4)
addi r6 ,r6 ,1 / * c o u n t h o w m a n y s e a r c h e s w e d o * /
stw r6 ,h t a b _ h a s h _ s e a r c h e s @l(r4)
/* Search the primary PTEG for a PTE whose 1st (d)word matches r5 */
mtctr r0
addi r4 ,r3 ,- P T E _ S I Z E
1 : LDPTEu r6 ,P T E _ S I Z E ( r4 ) / * g e t n e x t P T E * /
CMPPTE 0 ,r6 ,r5
bdnzf 2 ,1 b / * l o o p w h i l e c t r ! = 0 & & ! c r0 . e q * /
beq+ f o u n d _ s l o t
/* Search the secondary PTEG for a matching PTE */
ori r5 ,r5 ,P T E _ H / * s e t H ( s e c o n d a r y h a s h ) b i t * /
_ GLOBAL( h a s h _ p a g e _ p a t c h _ B )
xoris r4 ,r3 ,H a s h _ m s k > > 1 6 / * c o m p u t e s e c o n d a r y h a s h * /
xori r4 ,r4 ,( - P T E G _ S I Z E & 0 x f f f f )
addi r4 ,r4 ,- P T E _ S I Z E
mtctr r0
2 : LDPTEu r6 ,P T E _ S I Z E ( r4 )
CMPPTE 0 ,r6 ,r5
bdnzf 2 ,2 b
beq+ f o u n d _ s l o t
xori r5 ,r5 ,P T E _ H / * c l e a r H b i t a g a i n * /
/* Search the primary PTEG for an empty slot */
10 : mtctr r0
addi r4 ,r3 ,- P T E _ S I Z E / * s e a r c h p r i m a r y P T E G * /
1 : LDPTEu r6 ,P T E _ S I Z E ( r4 ) / * g e t n e x t P T E * /
TST_ V ( r6 ) / * t e s t v a l i d b i t * /
bdnzf 2 ,1 b / * l o o p w h i l e c t r ! = 0 & & ! c r0 . e q * /
beq+ f o u n d _ e m p t y
/* update counter of times that the primary PTEG is full */
addis r4 ,r7 ,p r i m a r y _ p t e g _ f u l l @ha
lwz r6 ,p r i m a r y _ p t e g _ f u l l @l(r4)
addi r6 ,r6 ,1
stw r6 ,p r i m a r y _ p t e g _ f u l l @l(r4)
/* Search the secondary PTEG for an empty slot */
ori r5 ,r5 ,P T E _ H / * s e t H ( s e c o n d a r y h a s h ) b i t * /
_ GLOBAL( h a s h _ p a g e _ p a t c h _ C )
xoris r4 ,r3 ,H a s h _ m s k > > 1 6 / * c o m p u t e s e c o n d a r y h a s h * /
xori r4 ,r4 ,( - P T E G _ S I Z E & 0 x f f f f )
addi r4 ,r4 ,- P T E _ S I Z E
mtctr r0
2 : LDPTEu r6 ,P T E _ S I Z E ( r4 )
TST_ V ( r6 )
bdnzf 2 ,2 b
beq+ f o u n d _ e m p t y
xori r5 ,r5 ,P T E _ H / * c l e a r H b i t a g a i n * /
/ *
* Choose a n a r b i t r a r y s l o t i n t h e p r i m a r y P T E G t o o v e r w r i t e .
* Since b o t h t h e p r i m a r y a n d s e c o n d a r y P T E G s a r e f u l l , a n d w e
* have n o i n f o r m a t i o n t h a t t h e P T E s i n t h e p r i m a r y P T E G a r e
* more i m p o r t a n t o r u s e f u l t h a n t h o s e i n t h e s e c o n d a r y P T E G ,
* and w e k n o w t h e r e i s a d e f i n i t e ( a l t h o u g h s m a l l ) s p e e d
* advantage t o p u t t i n g t h e P T E i n t h e p r i m a r y P T E G , w e a l w a y s
* put t h e P T E i n t h e p r i m a r y P T E G .
2007-04-12 15:30:22 +10:00
*
* In a d d i t i o n , w e s k i p a n y s l o t t h a t i s m a p p i n g k e r n e l t e x t i n
* order t o a v o i d a d e a d l o c k w h e n n o t u s i n g B A T m a p p i n g s i f
* trying t o h a s h i n t h e k e r n e l h a s h c o d e i t s e l f a f t e r i t h a s
* already t a k e n t h e h a s h t a b l e l o c k . T h i s w o r k s i n c o n j u n c t i o n
* with p r e - f a u l t i n g o f t h e k e r n e l t e x t .
*
* If t h e h a s h t a b l e b u c k e t i s f u l l o f k e r n e l t e x t e n t r i e s , w e ' l l
* lockup h e r e b u t t h a t s h o u l d n ' t h a p p e n
2005-09-26 16:04:21 +10:00
* /
2007-04-12 15:30:22 +10:00
1 : addis r4 ,r7 ,n e x t _ s l o t @ha /* get next evict slot */
2005-09-26 16:04:21 +10:00
lwz r6 ,n e x t _ s l o t @l(r4)
2007-04-12 15:30:22 +10:00
addi r6 ,r6 ,P T E _ S I Z E / * s e a r c h f o r c a n d i d a t e * /
2005-09-26 16:04:21 +10:00
andi. r6 ,r6 ,7 * P T E _ S I Z E
stw r6 ,n e x t _ s l o t @l(r4)
add r4 ,r3 ,r6
2007-04-12 15:30:22 +10:00
LDPTE r0 ,P T E _ S I Z E / 2 ( r4 ) / * g e t P T E s e c o n d w o r d * /
clrrwi r0 ,r0 ,1 2
lis r6 ,e t e x t @h
ori r6 ,r6 ,e t e x t @l /* get etext */
tophys( r6 ,r6 )
cmpl c r0 ,r0 ,r6 / * c o m p a r e a n d t r y a g a i n * /
blt 1 b
2005-09-26 16:04:21 +10:00
# ifndef C O N F I G _ S M P
/* Store PTE in PTEG */
found_empty :
STPTE r5 ,0 ( r4 )
found_slot :
STPTE r8 ,P T E _ S I Z E / 2 ( r4 )
# else / * C O N F I G _ S M P * /
/ *
* Between t h e t l b i e a b o v e a n d u p d a t i n g t h e h a s h t a b l e e n t r y b e l o w ,
* another C P U c o u l d r e a d t h e h a s h t a b l e e n t r y a n d p u t i t i n i t s T L B .
* There a r e 3 c a s e s :
* 1 . using a n e m p t y s l o t
* 2 . updating a n e a r l i e r e n t r y t o c h a n g e p e r m i s s i o n s ( i . e . e n a b l e w r i t e )
* 3 . taking o v e r t h e P T E f o r a n u n r e l a t e d a d d r e s s
*
* In e a c h c a s e i t d o e s n ' t r e a l l y m a t t e r i f t h e o t h e r C P U s h a v e t h e o l d
* PTE i n t h e i r T L B . S o w e d o n ' t n e e d t o b o t h e r w i t h a n o t h e r t l b i e h e r e ,
* which i s c o n v e n i e n t a s w e ' v e o v e r w r i t t e n t h e r e g i s t e r t h a t h a d t h e
* address. : - ) T h e t l b i e a b o v e i s m a i n l y t o m a k e s u r e t h a t t h i s C P U c o m e s
* and g e t s t h e n e w P T E f r o m t h e h a s h t a b l e .
*
* We d o h o w e v e r h a v e t o m a k e s u r e t h a t t h e P T E i s n e v e r i n a n i n v a l i d
* state w i t h t h e V b i t s e t .
* /
found_empty :
found_slot :
CLR_ V ( r5 ,r0 ) / * c l e a r V ( v a l i d ) b i t i n P T E * /
STPTE r5 ,0 ( r4 )
sync
TLBSYNC
STPTE r8 ,P T E _ S I Z E / 2 ( r4 ) / * p u t i n c o r r e c t R P N , W I M G , P P b i t s * /
sync
SET_ V ( r5 )
STPTE r5 ,0 ( r4 ) / * f i n a l l y s e t V b i t i n P T E * /
# endif / * C O N F I G _ S M P * /
sync / * m a k e s u r e p t e u p d a t e s g e t t o m e m o r y * /
blr
2007-05-14 17:11:58 -05:00
.section .bss
.align 2
next_slot :
.space 4
primary_pteg_full :
.space 4
htab_hash_searches :
.space 4
.previous
2005-09-26 16:04:21 +10:00
/ *
* Flush t h e e n t r y f o r a p a r t i c u l a r p a g e f r o m t h e h a s h t a b l e .
*
* flush_ h a s h _ p a g e s ( u n s i g n e d c o n t e x t , u n s i g n e d l o n g v a , u n s i g n e d l o n g p m d v a l ,
* int c o u n t )
*
* We a s s u m e t h a t t h e r e i s a h a s h t a b l e i n u s e ( H a s h ! = 0 ) .
* /
_ GLOBAL( f l u s h _ h a s h _ p a g e s )
tophys( r7 ,0 )
/ *
* We d i s a b l e i n t e r r u p t s h e r e , e v e n o n U P , b e c a u s e w e w a n t
* the _ P A G E _ H A S H P T E b i t t o b e a r e l i a b l e i n d i c a t i o n o f
* whether t h e H P T E e x i s t s ( o r a t l e a s t w h e t h e r o n e d i d o n c e ) .
* We a l s o t u r n o f f t h e M M U f o r d a t a a c c e s s e s s o t h a t w e
* we c a n ' t t a k e a h a s h t a b l e m i s s ( a s s u m i n g t h e c o d e i s
* covered b y a B A T ) . - - p a u l u s
* /
mfmsr r10
SYNC
rlwinm r0 ,r10 ,0 ,1 7 ,1 5 / * c l e a r b i t 1 6 ( M S R _ E E ) * /
rlwinm r0 ,r0 ,0 ,2 8 ,2 6 / * c l e a r M S R _ D R * /
mtmsr r0
SYNC_ 6 0 1
isync
/* First find a PTE in the range that has _PAGE_HASHPTE set */
rlwimi r5 ,r4 ,2 2 ,2 0 ,2 9
1 : lwz r0 ,0 ( r5 )
cmpwi c r1 ,r6 ,1
andi. r0 ,r0 ,_ P A G E _ H A S H P T E
bne 2 f
ble c r1 ,1 9 f
addi r4 ,r4 ,0 x10 0 0
addi r5 ,r5 ,4
addi r6 ,r6 ,- 1
b 1 b
/* Convert context and va to VSID */
2 : mulli r3 ,r3 ,8 9 7 * 1 6 / * m u l t i p l y c o n t e x t b y c o n t e x t s k e w * /
rlwinm r0 ,r4 ,4 ,2 8 ,3 1 / * g e t E S I D ( t o p 4 b i t s o f v a ) * /
mulli r0 ,r0 ,0 x11 1 / * m u l t i p l y b y E S I D s k e w * /
add r3 ,r3 ,r0 / * n o t e c o d e b e l o w t r i m s t o 2 4 b i t s * /
/* Construct the high word of the PPC-style PTE (r11) */
rlwinm r11 ,r3 ,7 ,1 ,2 4 / * p u t V S I D i n 0 x7 f f f f f80 b i t s * /
rlwimi r11 ,r4 ,1 0 ,2 6 ,3 1 / * p u t i n A P I ( a b b r e v p a g e i n d e x ) * /
SET_ V ( r11 ) / * s e t V ( v a l i d ) b i t * /
# ifdef C O N F I G _ S M P
addis r9 ,r7 ,m m u _ h a s h _ l o c k @ha
addi r9 ,r9 ,m m u _ h a s h _ l o c k @l
rlwinm r8 ,r1 ,0 ,0 ,1 8
add r8 ,r8 ,r7
lwz r8 ,T I _ C P U ( r8 )
oris r8 ,r8 ,9
10 : lwarx r0 ,0 ,r9
cmpi 0 ,r0 ,0
bne- 1 1 f
stwcx. r8 ,0 ,r9
beq+ 1 2 f
11 : lwz r0 ,0 ( r9 )
cmpi 0 ,r0 ,0
beq 1 0 b
b 1 1 b
12 : isync
# endif
/ *
* Check t h e _ P A G E _ H A S H P T E b i t i n t h e l i n u x P T E . I f i t i s
* already c l e a r , w e ' r e d o n e ( f o r t h i s p t e ) . I f n o t ,
* clear i t ( a t o m i c a l l y ) a n d p r o c e e d . - - p a u l u s .
* /
33 : lwarx r8 ,0 ,r5 / * f e t c h t h e p t e * /
andi. r0 ,r8 ,_ P A G E _ H A S H P T E
beq 8 f / * d o n e i f H A S H P T E i s a l r e a d y c l e a r * /
rlwinm r8 ,r8 ,0 ,3 1 ,2 9 / * c l e a r H A S H P T E b i t * /
stwcx. r8 ,0 ,r5 / * u p d a t e t h e p t e * /
bne- 3 3 b
/* Get the address of the primary PTE group in the hash table (r3) */
_ GLOBAL( f l u s h _ h a s h _ p a t c h _ A )
addis r8 ,r7 ,H a s h _ b a s e @h /* base address of hash table */
rlwimi r8 ,r3 ,L G _ P T E G _ S I Z E ,H A S H _ L E F T ,H A S H _ R I G H T / * V S I D - > h a s h * /
rlwinm r0 ,r4 ,2 0 + L G _ P T E G _ S I Z E ,H A S H _ L E F T ,H A S H _ R I G H T / * P I - > h a s h * /
xor r8 ,r0 ,r8 / * m a k e p r i m a r y h a s h * /
/* Search the primary PTEG for a PTE whose 1st (d)word matches r5 */
li r0 ,8 / * P T E s / g r o u p * /
mtctr r0
addi r12 ,r8 ,- P T E _ S I Z E
1 : LDPTEu r0 ,P T E _ S I Z E ( r12 ) / * g e t n e x t P T E * /
CMPPTE 0 ,r0 ,r11
bdnzf 2 ,1 b / * l o o p w h i l e c t r ! = 0 & & ! c r0 . e q * /
beq+ 3 f
/* Search the secondary PTEG for a matching PTE */
ori r11 ,r11 ,P T E _ H / * s e t H ( s e c o n d a r y h a s h ) b i t * /
li r0 ,8 / * P T E s / g r o u p * /
_ GLOBAL( f l u s h _ h a s h _ p a t c h _ B )
xoris r12 ,r8 ,H a s h _ m s k > > 1 6 / * c o m p u t e s e c o n d a r y h a s h * /
xori r12 ,r12 ,( - P T E G _ S I Z E & 0 x f f f f )
addi r12 ,r12 ,- P T E _ S I Z E
mtctr r0
2 : LDPTEu r0 ,P T E _ S I Z E ( r12 )
CMPPTE 0 ,r0 ,r11
bdnzf 2 ,2 b
xori r11 ,r11 ,P T E _ H / * c l e a r H a g a i n * /
bne- 4 f / * s h o u l d r a r e l y f a i l t o f i n d i t * /
3 : li r0 ,0
STPTE r0 ,0 ( r12 ) / * i n v a l i d a t e e n t r y * /
4 : sync
tlbie r4 / * i n h w t l b t o o * /
sync
8 : ble c r1 ,9 f / * i f a l l p t e s c h e c k e d * /
81 : addi r6 ,r6 ,- 1
addi r5 ,r5 ,4 / * a d v a n c e t o n e x t p t e * /
addi r4 ,r4 ,0 x10 0 0
lwz r0 ,0 ( r5 ) / * c h e c k n e x t p t e * /
cmpwi c r1 ,r6 ,1
andi. r0 ,r0 ,_ P A G E _ H A S H P T E
bne 3 3 b
bgt c r1 ,8 1 b
9 :
# ifdef C O N F I G _ S M P
TLBSYNC
li r0 ,0
stw r0 ,0 ( r9 ) / * c l e a r m m u _ h a s h _ l o c k * /
# endif
19 : mtmsr r10
SYNC_ 6 0 1
isync
blr