2006-02-06 23:44:37 -08:00
/ * sun4 v _ t l b _ m i s s . S : S u n 4 v T L B m i s s h a n d l e r s .
*
* Copyright ( C ) 2 0 0 6 < d a v e m @davemloft.net>
* /
.text
.align 32
2006-02-11 00:29:34 -08:00
/* Load ITLB fault information into VADDR and CTX, using BASE. */
# define L O A D _ I T L B _ I N F O ( B A S E , V A D D R , C T X ) \
ldx [ B A S E + H V _ F A U L T _ I _ A D D R _ O F F S E T ] , V A D D R ; \
ldx [ B A S E + H V _ F A U L T _ I _ C T X _ O F F S E T ] , C T X ;
/* Load DTLB fault information into VADDR and CTX, using BASE. */
# define L O A D _ D T L B _ I N F O ( B A S E , V A D D R , C T X ) \
ldx [ B A S E + H V _ F A U L T _ D _ A D D R _ O F F S E T ] , V A D D R ; \
ldx [ B A S E + H V _ F A U L T _ D _ C T X _ O F F S E T ] , C T X ;
2006-02-06 23:44:37 -08:00
2006-02-11 00:29:34 -08:00
/ * DEST = ( C T X < < 4 8 ) | ( V A D D R > > 2 2 )
*
* Branch t o Z E R O _ C T X _ L A B E L i s c o n t e x t i s z e r o .
2006-02-06 23:44:37 -08:00
* /
2006-02-11 00:29:34 -08:00
# define C O M P U T E _ T A G _ T A R G E T ( D E S T , V A D D R , C T X , T M P , Z E R O _ C T X _ L A B E L ) \
srlx V A D D R , 2 2 , T M P ; \
sllx C T X , 4 8 , D E S T ; \
brz,p n C T X , Z E R O _ C T X _ L A B E L ; \
or D E S T , T M P , D E S T ;
2006-02-06 23:44:37 -08:00
/ * Create T S B p o i n t e r . T h i s i s s o m e t h i n g l i k e :
*
* index_ m a s k = ( 5 1 2 < < ( t s b _ r e g & 0 x7 U L ) ) - 1 U L ;
* tsb_ b a s e = t s b _ r e g & ~ 0 x7 U L ;
* tsb_ i n d e x = ( ( v a d d r > > P A G E _ S H I F T ) & t s b _ m a s k ) ;
* tsb_ p t r = t s b _ b a s e + ( t s b _ i n d e x * 1 6 ) ;
* /
2006-02-11 00:29:34 -08:00
# define C O M P U T E _ T S B _ P T R ( T S B _ P T R , V A D D R , T M P 1 , T M P 2 ) \
and T S B _ P T R , 0 x7 , T M P 1 ; \
mov 5 1 2 , T M P 2 ; \
andn T S B _ P T R , 0 x7 , T S B _ P T R ; \
sllx T M P 2 , T M P 1 , T M P 2 ; \
srlx V A D D R , P A G E _ S H I F T , T M P 1 ; \
sub T M P 2 , 1 , T M P 2 ; \
and T M P 1 , T M P 2 , T M P 1 ; \
sllx T M P 1 , 4 , T M P 1 ; \
add T S B _ P T R , T M P 1 , T S B _ P T R ;
sun4v_itlb_miss :
/* Load MMU Miss base into %g2. */
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
/* Load UTSB reg into %g1. */
mov S C R A T C H P A D _ U T S B R E G 1 , % g 1
ldxa [ % g 1 ] A S I _ S C R A T C H P A D , % g 1
LOAD_ I T L B _ I N F O ( % g 2 , % g 4 , % g 5 )
COMPUTE_ T A G _ T A R G E T ( % g 6 , % g 4 , % g 5 , % g 3 , k v m a p _ i t l b _ 4 v )
COMPUTE_ T S B _ P T R ( % g 1 , % g 4 , % g 3 , % g 7 )
2006-02-06 23:44:37 -08:00
/* Load TSB tag/pte into %g2/%g3 and compare the tag. */
ldda [ % g 1 ] A S I _ Q U A D _ L D D _ P H Y S , % g 2
cmp % g 2 , % g 6
2006-02-11 21:57:54 -08:00
sethi % h i ( P A G E _ E X E C ) , % g 7
ldx [ % g 7 + % l o ( P A G E _ E X E C ) ] , % g 7
2006-02-06 23:44:37 -08:00
bne,a ,p n % x c c , t s b _ m i s s _ p a g e _ t a b l e _ w a l k
mov F A U L T _ C O D E _ I T L B , % g 3
andcc % g 3 , % g 7 , % g 0
be,a ,p n % x c c , t s b _ d o _ f a u l t
mov F A U L T _ C O D E _ I T L B , % g 3
/ * We h a v e a v a l i d e n t r y , m a k e h y p e r v i s o r c a l l t o l o a d
* I- T L B a n d r e t u r n f r o m t r a p .
*
* % g3 : PTE
* % g4 : vaddr
* % g6 : TAG T A R G E T ( o n l y " C T X < < 4 8 " p a r t m a t t e r s )
* /
sun4v_itlb_load :
mov % o 0 , % g 1 ! s a v e % o 0
mov % o 1 , % g 2 ! s a v e % o 1
mov % o 2 , % g 5 ! s a v e % o 2
mov % o 3 , % g 7 ! s a v e % o 3
mov % g 4 , % o 0 ! v a d d r
srlx % g 6 , 4 8 , % o 1 ! c t x
mov % g 3 , % o 2 ! P T E
mov H V _ M M U _ I M M U , % o 3 ! f l a g s
ta H V _ M M U _ M A P _ A D D R _ T R A P
mov % g 1 , % o 0 ! r e s t o r e % o 0
mov % g 2 , % o 1 ! r e s t o r e % o 1
mov % g 5 , % o 2 ! r e s t o r e % o 2
mov % g 7 , % o 3 ! r e s t o r e % o 3
retry
sun4v_dtlb_miss :
2006-02-10 15:39:51 -08:00
/* Load MMU Miss base into %g2. */
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
2006-02-06 23:44:37 -08:00
/* Load UTSB reg into %g1. */
2006-02-10 15:39:51 -08:00
mov S C R A T C H P A D _ U T S B R E G 1 , % g 1
2006-02-11 12:21:20 -08:00
ldxa [ % g 1 ] A S I _ S C R A T C H P A D , % g 1
2006-02-06 23:44:37 -08:00
2006-02-11 00:29:34 -08:00
LOAD_ D T L B _ I N F O ( % g 2 , % g 4 , % g 5 )
COMPUTE_ T A G _ T A R G E T ( % g 6 , % g 4 , % g 5 , % g 3 , k v m a p _ d t l b _ 4 v )
COMPUTE_ T S B _ P T R ( % g 1 , % g 4 , % g 3 , % g 7 )
2006-02-06 23:44:37 -08:00
/* Load TSB tag/pte into %g2/%g3 and compare the tag. */
ldda [ % g 1 ] A S I _ Q U A D _ L D D _ P H Y S , % g 2
cmp % g 2 , % g 6
bne,a ,p n % x c c , t s b _ m i s s _ p a g e _ t a b l e _ w a l k
mov F A U L T _ C O D E _ I T L B , % g 3
/ * We h a v e a v a l i d e n t r y , m a k e h y p e r v i s o r c a l l t o l o a d
* D- T L B a n d r e t u r n f r o m t r a p .
*
* % g3 : PTE
* % g4 : vaddr
* % g6 : TAG T A R G E T ( o n l y " C T X < < 4 8 " p a r t m a t t e r s )
* /
sun4v_dtlb_load :
mov % o 0 , % g 1 ! s a v e % o 0
mov % o 1 , % g 2 ! s a v e % o 1
mov % o 2 , % g 5 ! s a v e % o 2
mov % o 3 , % g 7 ! s a v e % o 3
mov % g 4 , % o 0 ! v a d d r
srlx % g 6 , 4 8 , % o 1 ! c t x
mov % g 3 , % o 2 ! P T E
mov H V _ M M U _ D M M U , % o 3 ! f l a g s
ta H V _ M M U _ M A P _ A D D R _ T R A P
mov % g 1 , % o 0 ! r e s t o r e % o 0
mov % g 2 , % o 1 ! r e s t o r e % o 1
mov % g 5 , % o 2 ! r e s t o r e % o 2
mov % g 7 , % o 3 ! r e s t o r e % o 3
retry
sun4v_dtlb_prot :
2006-02-10 15:39:51 -08:00
/* Load MMU Miss base into %g2. */
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
2006-02-06 23:44:37 -08:00
2006-02-10 15:39:51 -08:00
ldx [ % g 2 + H V _ F A U L T _ D _ A D D R _ O F F S E T ] , % g 5
2006-02-06 23:44:37 -08:00
rdpr % t l , % g 1
cmp % g 1 , 1
bgu,p n % x c c , w i n f i x _ t r a m p o l i n e
nop
ba,p t % x c c , s p a r c64 _ r e a l f a u l t _ c o m m o n
mov F A U L T _ C O D E _ D T L B | F A U L T _ C O D E _ W R I T E , % g 4
2006-02-10 15:39:51 -08:00
/ * Called f r o m t r a p t a b l e w i t h T A G T A R G E T p l a c e d i n t o
2006-02-11 00:29:34 -08:00
* % g6 , S C R A T C H P A D _ U T S B R E G 1 c o n t e n t s i n % g 1 , a n d
* SCRATCHPAD_ M M U _ M I S S c o n t e n t s i n % g 2 .
2006-02-09 16:12:22 -08:00
* /
sun4v_itsb_miss :
2006-02-11 12:21:20 -08:00
mov S C R A T C H P A D _ U T S B R E G 1 , % g 1
ldxa [ % g 1 ] A S I _ S C R A T C H P A D , % g 1
brz,p n % g 5 , k v m a p _ i t l b _ 4 v
2006-02-09 16:12:22 -08:00
mov F A U L T _ C O D E _ I T L B , % g 3
2006-02-10 15:39:51 -08:00
/ * Called f r o m t r a p t a b l e w i t h T A G T A R G E T p l a c e d i n t o
* % g6 a n d S C R A T C H P A D _ U T S B R E G 1 c o n t e n t s i n % g 1 .
2006-02-09 16:12:22 -08:00
* /
sun4v_dtsb_miss :
2006-02-11 12:21:20 -08:00
mov S C R A T C H P A D _ U T S B R E G 1 , % g 1
ldxa [ % g 1 ] A S I _ S C R A T C H P A D , % g 1
brz,p n % g 5 , k v m a p _ d t l b _ 4 v
mov F A U L T _ C O D E _ D T L B , % g 3
2006-02-09 16:12:22 -08:00
/ * Create T S B p o i n t e r i n t o % g 1 . T h i s i s s o m e t h i n g l i k e :
*
* index_ m a s k = ( 5 1 2 < < ( t s b _ r e g & 0 x7 U L ) ) - 1 U L ;
* tsb_ b a s e = t s b _ r e g & ~ 0 x7 U L ;
* tsb_ i n d e x = ( ( v a d d r > > P A G E _ S H I F T ) & t s b _ m a s k ) ;
* tsb_ p t r = t s b _ b a s e + ( t s b _ i n d e x * 1 6 ) ;
* /
sun4v_tsb_miss_common :
2006-02-11 00:29:34 -08:00
COMPUTE_ T S B _ P T R ( % g 1 , % g 4 , % g 5 , % g 7 )
/ * Branch d i r e c t l y t o p a g e t a b l e l o o k u p . W e h a v e S C R A T C H P A D _ M M U _ M I S S
* still i n % g 2 , s o i t ' s q u i t e t r i v i a l t o g e t a t t h e P G D P H Y S v a l u e
* so w e c a n p r e l o a d i t i n t o % g 7 .
* /
sub % g 2 , T R A P _ P E R _ C P U _ F A U L T _ I N F O , % g 2
ba,p t % x c c , t s b _ m i s s _ p a g e _ t a b l e _ w a l k _ s u n 4 v _ f a s t p a t h
ldx [ % g 2 + T R A P _ P E R _ C P U _ P G D _ P A D D R ] , % g 7
2006-02-09 16:12:22 -08:00
2006-02-09 20:20:34 -08:00
/* Instruction Access Exception, tl0. */
sun4v_iacc :
2006-02-10 15:39:51 -08:00
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
ldx [ % g 2 + H V _ F A U L T _ I _ T Y P E _ O F F S E T ] , % g 3
ldx [ % g 2 + H V _ F A U L T _ I _ A D D R _ O F F S E T ] , % g 4
ldx [ % g 2 + H V _ F A U L T _ I _ C T X _ O F F S E T ] , % g 5
2006-02-09 20:20:34 -08:00
sllx % g 3 , 1 6 , % g 3
or % g 5 , % g 3 , % g 5
ba,p t % x c c , e t r a p
rd % p c , % g 7
mov % l 4 , % o 1
mov % l 5 , % o 2
call s u n 4 v _ i n s n _ a c c e s s _ e x c e p t i o n
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
/* Instruction Access Exception, tl1. */
sun4v_iacc_tl1 :
2006-02-10 15:39:51 -08:00
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
ldx [ % g 2 + H V _ F A U L T _ I _ T Y P E _ O F F S E T ] , % g 3
ldx [ % g 2 + H V _ F A U L T _ I _ A D D R _ O F F S E T ] , % g 4
ldx [ % g 2 + H V _ F A U L T _ I _ C T X _ O F F S E T ] , % g 5
2006-02-09 20:20:34 -08:00
sllx % g 3 , 1 6 , % g 3
or % g 5 , % g 3 , % g 5
ba,p t % x c c , e t r a p t l 1
rd % p c , % g 7
mov % l 4 , % o 1
mov % l 5 , % o 2
call s u n 4 v _ i n s n _ a c c e s s _ e x c e p t i o n _ t l 1
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
/* Data Access Exception, tl0. */
sun4v_dacc :
2006-02-10 15:39:51 -08:00
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
ldx [ % g 2 + H V _ F A U L T _ D _ T Y P E _ O F F S E T ] , % g 3
ldx [ % g 2 + H V _ F A U L T _ D _ A D D R _ O F F S E T ] , % g 4
ldx [ % g 2 + H V _ F A U L T _ D _ C T X _ O F F S E T ] , % g 5
2006-02-09 20:20:34 -08:00
sllx % g 3 , 1 6 , % g 3
or % g 5 , % g 3 , % g 5
ba,p t % x c c , e t r a p
rd % p c , % g 7
mov % l 4 , % o 1
mov % l 5 , % o 2
call s u n 4 v _ d a t a _ a c c e s s _ e x c e p t i o n
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
/* Data Access Exception, tl1. */
sun4v_dacc_tl1 :
2006-02-10 15:39:51 -08:00
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
ldx [ % g 2 + H V _ F A U L T _ D _ T Y P E _ O F F S E T ] , % g 3
ldx [ % g 2 + H V _ F A U L T _ D _ A D D R _ O F F S E T ] , % g 4
ldx [ % g 2 + H V _ F A U L T _ D _ C T X _ O F F S E T ] , % g 5
2006-02-09 20:20:34 -08:00
sllx % g 3 , 1 6 , % g 3
or % g 5 , % g 3 , % g 5
ba,p t % x c c , e t r a p t l 1
rd % p c , % g 7
mov % l 4 , % o 1
mov % l 5 , % o 2
call s u n 4 v _ d a t a _ a c c e s s _ e x c e p t i o n _ t l 1
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
/* Memory Address Unaligned. */
sun4v_mna :
2006-02-10 15:39:51 -08:00
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
2006-02-09 20:20:34 -08:00
mov H V _ F A U L T _ T Y P E _ U N A L I G N E D , % g 3
2006-02-10 15:39:51 -08:00
ldx [ % g 2 + H V _ F A U L T _ D _ A D D R _ O F F S E T ] , % g 4
ldx [ % g 2 + H V _ F A U L T _ D _ C T X _ O F F S E T ] , % g 5
2006-02-09 20:20:34 -08:00
sllx % g 3 , 1 6 , % g 3
or % g 5 , % g 3 , % g 5
/* Window fixup? */
rdpr % t l , % g 2
cmp % g 2 , 1
bgu,p n % i c c , w i n f i x _ m n a
rdpr % t p c , % g 3
ba,p t % x c c , e t r a p
rd % p c , % g 7
mov % l 4 , % o 1
mov % l 5 , % o 2
2006-02-14 16:39:22 -08:00
call s u n 4 v _ d o _ m n a
2006-02-09 20:20:34 -08:00
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
/* Privileged Action. */
sun4v_privact :
ba,p t % x c c , e t r a p
rd % p c , % g 7
call d o _ p r i v a c t
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
/* Unaligned ldd float, tl0. */
sun4v_lddfmna :
2006-02-10 15:39:51 -08:00
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
ldx [ % g 2 + H V _ F A U L T _ D _ T Y P E _ O F F S E T ] , % g 3
ldx [ % g 2 + H V _ F A U L T _ D _ A D D R _ O F F S E T ] , % g 4
ldx [ % g 2 + H V _ F A U L T _ D _ C T X _ O F F S E T ] , % g 5
2006-02-09 20:20:34 -08:00
sllx % g 3 , 1 6 , % g 3
or % g 5 , % g 3 , % g 5
ba,p t % x c c , e t r a p
rd % p c , % g 7
mov % l 4 , % o 1
mov % l 5 , % o 2
call h a n d l e _ l d d f m n a
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
/* Unaligned std float, tl0. */
sun4v_stdfmna :
2006-02-10 15:39:51 -08:00
ldxa [ % g 0 ] A S I _ S C R A T C H P A D , % g 2
ldx [ % g 2 + H V _ F A U L T _ D _ T Y P E _ O F F S E T ] , % g 3
ldx [ % g 2 + H V _ F A U L T _ D _ A D D R _ O F F S E T ] , % g 4
ldx [ % g 2 + H V _ F A U L T _ D _ C T X _ O F F S E T ] , % g 5
2006-02-09 20:20:34 -08:00
sllx % g 3 , 1 6 , % g 3
or % g 5 , % g 3 , % g 5
ba,p t % x c c , e t r a p
rd % p c , % g 7
mov % l 4 , % o 1
mov % l 5 , % o 2
call h a n d l e _ s t d f m n a
add % s p , P T R E G S _ O F F , % o 0
ba,a ,p t % x c c , r t r a p _ c l r _ l 6
2006-02-09 16:12:22 -08:00
2006-02-06 23:44:37 -08:00
# define B R A N C H _ A L W A Y S 0 x10 6 8 0 0 0 0
# define N O P 0 x01 0 0 0 0 0 0
# define S U N 4 V _ D O _ P A T C H ( O L D , N E W ) \
sethi % h i ( N E W ) , % g 1 ; \
or % g 1 , % l o ( N E W ) , % g 1 ; \
sethi % h i ( O L D ) , % g 2 ; \
or % g 2 , % l o ( O L D ) , % g 2 ; \
sub % g 1 , % g 2 , % g 1 ; \
sethi % h i ( B R A N C H _ A L W A Y S ) , % g 3 ; \
2006-02-11 12:21:20 -08:00
sll % g 1 , 1 1 , % g 1 ; \
srl % g 1 , 1 1 + 2 , % g 1 ; \
2006-02-06 23:44:37 -08:00
or % g 3 , % l o ( B R A N C H _ A L W A Y S ) , % g 3 ; \
or % g 3 , % g 1 , % g 3 ; \
stw % g 3 , [ % g 2 ] ; \
sethi % h i ( N O P ) , % g 3 ; \
or % g 3 , % l o ( N O P ) , % g 3 ; \
stw % g 3 , [ % g 2 + 0 x4 ] ; \
flush % g 2 ;
.globl sun4v_patch_tlb_handlers
.type sun4 v _ p a t c h _ t l b _ h a n d l e r s ,#f u n c t i o n
sun4v_patch_tlb_handlers :
SUN4 V _ D O _ P A T C H ( t l 0 _ i a m i s s , s u n 4 v _ i t l b _ m i s s )
SUN4 V _ D O _ P A T C H ( t l 1 _ i a m i s s , s u n 4 v _ i t l b _ m i s s )
SUN4 V _ D O _ P A T C H ( t l 0 _ d a m i s s , s u n 4 v _ d t l b _ m i s s )
SUN4 V _ D O _ P A T C H ( t l 1 _ d a m i s s , s u n 4 v _ d t l b _ m i s s )
SUN4 V _ D O _ P A T C H ( t l 0 _ d a p r o t , s u n 4 v _ d t l b _ p r o t )
SUN4 V _ D O _ P A T C H ( t l 1 _ d a p r o t , s u n 4 v _ d t l b _ p r o t )
2006-02-09 20:20:34 -08:00
SUN4 V _ D O _ P A T C H ( t l 0 _ i a x , s u n 4 v _ i a c c )
SUN4 V _ D O _ P A T C H ( t l 1 _ i a x , s u n 4 v _ i a c c _ t l 1 )
SUN4 V _ D O _ P A T C H ( t l 0 _ d a x , s u n 4 v _ d a c c )
SUN4 V _ D O _ P A T C H ( t l 1 _ d a x , s u n 4 v _ d a c c _ t l 1 )
SUN4 V _ D O _ P A T C H ( t l 0 _ m n a , s u n 4 v _ m n a )
SUN4 V _ D O _ P A T C H ( t l 1 _ m n a , s u n 4 v _ m n a )
SUN4 V _ D O _ P A T C H ( t l 0 _ l d d f m n a , s u n 4 v _ l d d f m n a )
SUN4 V _ D O _ P A T C H ( t l 0 _ s t d f m n a , s u n 4 v _ s t d f m n a )
SUN4 V _ D O _ P A T C H ( t l 0 _ p r i v a c t , s u n 4 v _ p r i v a c t )
2006-02-06 23:44:37 -08:00
retl
nop
.size sun4 v _ p a t c h _ t l b _ h a n d l e r s ,. - s u n 4 v _ p a t c h _ t l b _ h a n d l e r s