2005-04-16 15:20:36 -07:00
/ *
* linux/ a r c h / a r m / m m / t l b v4 w b . S
*
* Copyright ( C ) 1 9 9 7 - 2 0 0 2 R u s s e l l K i n g
*
* 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
* it 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 v e r s i o n 2 a s
* published 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 .
*
* ARM a r c h i t e c t u r e v e r s i o n 4 T L B h a n d l i n g f u n c t i o n s .
* These a s s u m e a s p l i t I / D T L B s w / o I T L B e n t r y , w i t h a w r i t e b u f f e r .
*
* Processors : SA1 1 0 S A 1 1 0 0 S A 1 1 1 0
* /
# include < l i n u x / l i n k a g e . h >
# include < l i n u x / i n i t . h >
2014-06-30 16:29:12 +01:00
# include < a s m / a s s e m b l e r . h >
2005-09-09 21:08:59 +02:00
# include < a s m / a s m - o f f s e t s . h >
2005-04-16 15:20:36 -07:00
# include < a s m / t l b f l u s h . h >
# include " p r o c - m a c r o s . S "
.align 5
/ *
* v4 w b _ f l u s h _ u s e r _ t l b _ r a n g e ( s t a r t , e n d , m m )
*
* Invalidate a r a n g e o f T L B e n t r i e s i n t h e s p e c i f i e d a d d r e s s s p a c e .
*
* - start - r a n g e s t a r t a d d r e s s
* - end - r a n g e e n d a d d r e s s
* - mm - m m _ s t r u c t d e s c r i b i n g a d d r e s s s p a c e
* /
.align 5
ENTRY( v4 w b _ f l u s h _ u s e r _ t l b _ r a n g e )
vma_ v m _ m m i p , r2
act_ m m r3 @ get current->active_mm
eors r3 , i p , r3 @ == mm ?
2014-06-30 16:29:12 +01:00
retne l r @ no, we dont do anything
2005-04-16 15:20:36 -07:00
vma_ v m _ f l a g s r2 , r2
mcr p15 , 0 , r3 , c7 , c10 , 4 @ drain WB
tst r2 , #V M _ E X E C
mcrne p15 , 0 , r3 , c8 , c5 , 0 @ invalidate I TLB
bic r0 , r0 , #0x0ff
bic r0 , r0 , #0xf00
1 : mcr p15 , 0 , r0 , c8 , c6 , 1 @ invalidate D TLB entry
add r0 , r0 , #P A G E _ S Z
cmp r0 , r1
blo 1 b
2014-06-30 16:29:12 +01:00
ret l r
2005-04-16 15:20:36 -07:00
/ *
* v4 _ f l u s h _ k e r n _ t l b _ r a n g e ( s t a r t , e n d )
*
* Invalidate a r a n g e o f T L B e n t r i e s i n t h e s p e c i f i e d k e r n e l
* address r a n g e .
*
* - start - v i r t u a l a d d r e s s ( m a y n o t b e a l i g n e d )
* - end - v i r t u a l a d d r e s s ( m a y n o t b e a l i g n e d )
* /
ENTRY( v4 w b _ f l u s h _ k e r n _ t l b _ r a n g e )
mov r3 , #0
mcr p15 , 0 , r3 , c7 , c10 , 4 @ drain WB
bic r0 , r0 , #0x0ff
bic r0 , r0 , #0xf00
mcr p15 , 0 , r3 , c8 , c5 , 0 @ invalidate I TLB
1 : mcr p15 , 0 , r0 , c8 , c6 , 1 @ invalidate D TLB entry
add r0 , r0 , #P A G E _ S Z
cmp r0 , r1
blo 1 b
2014-06-30 16:29:12 +01:00
ret l r
2005-04-16 15:20:36 -07:00
_ _ INITDATA
2011-06-23 17:30:11 +01:00
/* define struct cpu_tlb_fns (see <asm/tlbflush.h> and proc-macros.S) */
define_ t l b _ f u n c t i o n s v4 w b , v4 w b _ t l b _ f l a g s