2012-03-05 15:49:26 +04:00
/ *
* Based o n a r c h / a r m / m m / p r o c - m a c r o s . S
*
* Copyright ( C ) 2 0 1 2 A R M L t d .
*
* 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 .
*
* This p r o g r a m i s d i s t r i b u t e d i n t h e h o p e t h a t i t w i l l b e u s e f u l ,
* but W I T H O U T A N Y W A R R A N T Y ; without even the implied warranty of
* MERCHANTABILITY o r F I T N E S S F O R A P A R T I C U L A R P U R P O S E . S e e t h e
* GNU G e n e r a l P u b l i c L i c e n s e f o r m o r e d e t a i l s .
*
* You s h o u l d h a v e r e c e i v e d a c o p y 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
* along w i t h t h i s p r o g r a m . I f n o t , s e e < h t t p : / / w w w . g n u . o r g / l i c e n s e s / > .
* /
# include < a s m / a s m - o f f s e t s . h >
# include < a s m / t h r e a d _ i n f o . h >
/ *
* vma_ v m _ m m - g e t m m p o i n t e r f r o m v m a p o i n t e r ( v m a - > v m _ m m )
* /
.macro vma_ v m _ m m , r d , r n
ldr \ r d , [ \ r n , #V M A _ V M _ M M ]
.endm
/ *
* mmid - g e t c o n t e x t i d f r o m m m p o i n t e r ( m m - > c o n t e x t . i d )
* /
.macro mmid, r d , r n
ldr \ r d , [ \ r n , #M M _ C O N T E X T _ I D ]
.endm
/ *
* dcache_ l i n e _ s i z e - g e t t h e m i n i m u m D - c a c h e l i n e s i z e f r o m t h e C T R r e g i s t e r .
* /
.macro dcache_ l i n e _ s i z e , r e g , t m p
mrs \ t m p , c t r _ e l 0 / / r e a d C T R
2014-01-20 09:00:21 +04:00
ubfm \ t m p , \ t m p , #16 , #19 / / c a c h e l i n e s i z e e n c o d i n g
2012-03-05 15:49:26 +04:00
mov \ r e g , #4 / / b y t e s p e r w o r d
lsl \ r e g , \ r e g , \ t m p / / a c t u a l c a c h e l i n e s i z e
.endm
/ *
* icache_ l i n e _ s i z e - g e t t h e m i n i m u m I - c a c h e l i n e s i z e f r o m t h e C T R r e g i s t e r .
* /
.macro icache_ l i n e _ s i z e , r e g , t m p
mrs \ t m p , c t r _ e l 0 / / r e a d C T R
and \ t m p , \ t m p , #0xf / / c a c h e l i n e s i z e e n c o d i n g
mov \ r e g , #4 / / b y t e s p e r w o r d
lsl \ r e g , \ r e g , \ t m p / / a c t u a l c a c h e l i n e s i z e
.endm
arm64: mm: increase VA range of identity map
The page size and the number of translation levels, and hence the supported
virtual address range, are build-time configurables on arm64 whose optimal
values are use case dependent. However, in the current implementation, if
the system's RAM is located at a very high offset, the virtual address range
needs to reflect that merely because the identity mapping, which is only used
to enable or disable the MMU, requires the extended virtual range to map the
physical memory at an equal virtual offset.
This patch relaxes that requirement, by increasing the number of translation
levels for the identity mapping only, and only when actually needed, i.e.,
when system RAM's offset is found to be out of reach at runtime.
Tested-by: Laura Abbott <lauraa@codeaurora.org>
Reviewed-by: Catalin Marinas <catalin.marinas@arm.com>
Tested-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Signed-off-by: Will Deacon <will.deacon@arm.com>
2015-03-19 19:42:27 +03:00
/ *
* tcr_ s e t _ i d m a p _ t 0 s z - u p d a t e T C R . T 0 S Z s o t h a t w e c a n l o a d t h e I D m a p
* /
.macro tcr_ s e t _ i d m a p _ t 0 s z , v a l r e g , t m p r e g
# ifndef C O N F I G _ A R M 6 4 _ V A _ B I T S _ 4 8
ldr_ l \ t m p r e g , i d m a p _ t 0 s z
bfi \ v a l r e g , \ t m p r e g , #T C R _ T 0 S Z _ O F F S E T , #T C R _ T x S Z _ W I D T H
# endif
.endm
2015-12-17 12:38:32 +03:00
/ *
* Macro t o p e r f o r m a d a t a c a c h e m a i n t e n a n c e f o r t h e i n t e r v a l
* [ kaddr, k a d d r + s i z e )
*
* op : operation p a s s e d t o d c i n s t r u c t i o n
* domain : domain u s e d i n d s b i n s t r u c i t o n
* kaddr : starting v i r t u a l a d d r e s s o f t h e r e g i o n
* size : size o f t h e r e g i o n
* Corrupts : kaddr, s i z e , t m p1 , t m p2
* /
.macro dcache_by_line_op op, d o m a i n , k a d d r , s i z e , t m p1 , t m p2
dcache_ l i n e _ s i z e \ t m p1 , \ t m p2
add \ s i z e , \ k a d d r , \ s i z e
sub \ t m p2 , \ t m p1 , #1
bic \ k a d d r , \ k a d d r , \ t m p2
9998 : dc \ o p , \ k a d d r
add \ k a d d r , \ k a d d r , \ t m p1
cmp \ k a d d r , \ s i z e
b. l o 9 9 9 8 b
dsb \ d o m a i n
.endm