2005-04-16 15:20:36 -07:00
/ *
* linux/ a r c h / a r m / m m / t l b v4 . 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 , a n d n o w r i t e b u f f e r .
*
* Processors : ARM7 2 0 T
* /
# 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 >
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 _ 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 u s e r 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 _ 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 ?
movne p c , l r @ no, we dont do anything
.v4_flush_kern_tlb_range :
bic r0 , r0 , #0x0ff
bic r0 , r0 , #0xf00
1 : mcr p15 , 0 , r0 , c8 , c7 , 1 @ invalidate TLB entry
add r0 , r0 , #P A G E _ S Z
cmp r0 , r1
blo 1 b
mov p c , l r
/ *
* 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 )
* /
.globl v4_flush_kern_tlb_range
.equ v4 _ f l u s h _ k e r n _ t l b _ r a n g e , . v4 _ f l u s h _ k e r n _ t l b _ r a n g e
_ _ INITDATA
2011-06-23 17:29:19 +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 , v4 _ t l b _ f l a g s