2019-05-29 07:12:40 -07:00
/* SPDX-License-Identifier: GPL-2.0-only */
2011-12-20 15:34:43 +00:00
/ *
*
* Copyright ( C ) 2 0 1 0 - 2 0 1 1 F r e e s c a l e S e m i c o n d u c t o r , I n c .
*
* Author : Varun S e t h i < v a r u n . s e t h i @freescale.com>
* Author : Scott W o o d < s c o t w o o d @freescale.com>
2012-10-11 06:13:21 +00:00
* Author : Mihai C a r a m a n < m i h a i . c a r a m a n @freescale.com>
2011-12-20 15:34:43 +00:00
*
* This f i l e i s d e r i v e d f r o m a r c h / p o w e r p c / k v m / b o o k e _ i n t e r r u p t s . S
* /
# include < a s m / p p c _ a s m . h >
# include < a s m / k v m _ a s m . h >
# include < a s m / r e g . h >
# include < a s m / p a g e . h >
# include < a s m / a s m - c o m p a t . h >
# include < a s m / a s m - o f f s e t s . h >
# include < a s m / b i t s p e r l o n g . h >
2012-10-11 06:13:21 +00:00
# ifdef C O N F I G _ 6 4 B I T
# include < a s m / e x c e p t i o n - 6 4 e . h >
2013-10-23 09:26:48 +08:00
# include < a s m / h w _ i r q . h >
# include < a s m / i r q f l a g s . h >
2012-10-11 06:13:21 +00:00
# else
2011-12-20 15:34:43 +00:00
# include " . . / k e r n e l / h e a d _ b o o k e . h " / * f o r T H R E A D _ N O R M S A V E ( ) * /
2012-10-11 06:13:21 +00:00
# endif
2011-12-20 15:34:43 +00:00
# define L O N G B Y T E S ( B I T S _ P E R _ L O N G / 8 )
# define V C P U _ G U E S T _ S P R G ( n ) ( V C P U _ G U E S T _ S P R G S + ( n * L O N G B Y T E S ) )
/* The host stack layout: */
2012-10-11 06:13:21 +00:00
# define H O S T _ R 1 0 / * I m p l i e d b y s t w u . * /
# define H O S T _ C A L L E E _ L R P P C _ L R _ S T K O F F
# define H O S T _ R U N ( H O S T _ C A L L E E _ L R + L O N G B Y T E S )
2011-12-20 15:34:43 +00:00
/ *
* r2 i s s p e c i a l : i t h o l d s ' c u r r e n t ' , a n d i t m a d e n o n v o l a t i l e i n t h e
* kernel w i t h t h e - f f i x e d - r2 g c c o p t i o n .
* /
2012-10-11 06:13:21 +00:00
# define H O S T _ R 2 ( H O S T _ R U N + L O N G B Y T E S )
# define H O S T _ C R ( H O S T _ R 2 + L O N G B Y T E S )
# define H O S T _ N V _ G P R S ( H O S T _ C R + L O N G B Y T E S )
2012-07-24 13:02:34 +00:00
# define _ _ H O S T _ N V _ G P R ( n ) ( H O S T _ N V _ G P R S + ( ( n - 1 4 ) * L O N G B Y T E S ) )
# define H O S T _ N V _ G P R ( n ) _ _ H O S T _ N V _ G P R ( _ _ R E G _ ## n )
# define H O S T _ M I N _ S T A C K _ S I Z E ( H O S T _ N V _ G P R ( R 3 1 ) + L O N G B Y T E S )
2011-12-20 15:34:43 +00:00
# define H O S T _ S T A C K _ S I Z E ( ( H O S T _ M I N _ S T A C K _ S I Z E + 1 5 ) & ~ 1 5 ) / * A l i g n . * /
2012-10-11 06:13:21 +00:00
/* LR in caller stack frame. */
# define H O S T _ S T A C K _ L R ( H O S T _ S T A C K _ S I Z E + P P C _ L R _ S T K O F F )
2011-12-20 15:34:43 +00:00
# define N E E D _ E M U 0 x00 0 0 0 0 0 1 / * e m u l a t i o n - - s a v e n v r e g s * /
# define N E E D _ D E A R 0 x00 0 0 0 0 0 2 / * s a v e f a u l t i n g D E A R * /
# define N E E D _ E S R 0 x00 0 0 0 0 0 4 / * s a v e f a u l t i n g E S R * /
/ *
* On e n t r y :
* r4 = v c p u , r5 = s r r0 , r6 = s r r1
* saved i n v c p u : c r , c t r , r3 - r13
* /
.macro kvm_handler_common intno, s r r0 , f l a g s
2012-02-15 23:06:24 +00:00
/* Restore host stack pointer */
2012-06-25 13:33:10 +00:00
PPC_ S T L r1 , V C P U _ G P R ( R 1 ) ( r4 )
PPC_ S T L r2 , V C P U _ G P R ( R 2 ) ( r4 )
2012-02-15 23:06:24 +00:00
PPC_ L L r1 , V C P U _ H O S T _ S T A C K ( r4 )
PPC_ L L r2 , H O S T _ R 2 ( r1 )
2018-12-12 16:03:07 +02:00
START_ B T B _ F L U S H _ S E C T I O N
BTB_ F L U S H ( r10 )
END_ B T B _ F L U S H _ S E C T I O N
2011-12-20 15:34:43 +00:00
mfspr r10 , S P R N _ P I D
lwz r8 , V C P U _ H O S T _ P I D ( r4 )
PPC_ L L r11 , V C P U _ S H A R E D ( r4 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r14 , V C P U _ G P R ( R 1 4 ) ( r4 ) / * W e n e e d a n o n - v o l a t i l e G P R . * /
2011-12-20 15:34:43 +00:00
li r14 , \ i n t n o
stw r10 , V C P U _ G U E S T _ P I D ( r4 )
mtspr S P R N _ P I D , r8
# ifdef C O N F I G _ K V M _ E X I T _ T I M I N G
/* save exit time */
1 : mfspr r7 , S P R N _ T B R U
mfspr r8 , S P R N _ T B R L
mfspr r9 , S P R N _ T B R U
cmpw r9 , r7
2012-04-16 04:08:54 +00:00
stw r8 , V C P U _ T I M I N G _ E X I T _ T B L ( r4 )
2011-12-20 15:34:43 +00:00
bne- 1 b
2012-04-16 04:08:54 +00:00
stw r9 , V C P U _ T I M I N G _ E X I T _ T B U ( r4 )
2011-12-20 15:34:43 +00:00
# endif
oris r8 , r6 , M S R _ C E @h
2012-04-25 01:26:43 +00:00
PPC_ S T D ( r6 , V C P U _ S H A R E D _ M S R , r11 )
2011-12-20 15:34:43 +00:00
ori r8 , r8 , M S R _ M E | M S R _ R I
PPC_ S T L r5 , V C P U _ P C ( r4 )
/ *
* Make s u r e C E / M E / R I a r e s e t ( i f a p p r o p r i a t e f o r e x c e p t i o n t y p e )
* whether o r n o t t h e g u e s t h a d i t s e t . S i n c e m f m s r / m t m s r a r e
* somewhat e x p e n s i v e , s k i p i n t h e c o m m o n c a s e w h e r e t h e g u e s t
* had a l l t h e s e b i t s s e t ( a n d t h u s t h e y ' r e s t i l l s e t i f
* appropriate f o r t h e e x c e p t i o n t y p e ) .
* /
cmpw r6 , r8
beq 1 f
mfmsr r7
.if \ srr0 ! = S P R N _ M C S R R 0 & & \ s r r0 ! = S P R N _ C S R R 0
oris r7 , r7 , M S R _ C E @h
.endif
.if \ srr0 ! = S P R N _ M C S R R 0
ori r7 , r7 , M S R _ M E | M S R _ R I
.endif
mtmsr r7
1 :
.if \ flags & N E E D _ E M U
2012-06-25 13:33:10 +00:00
PPC_ S T L r15 , V C P U _ G P R ( R 1 5 ) ( r4 )
PPC_ S T L r16 , V C P U _ G P R ( R 1 6 ) ( r4 )
PPC_ S T L r17 , V C P U _ G P R ( R 1 7 ) ( r4 )
PPC_ S T L r18 , V C P U _ G P R ( R 1 8 ) ( r4 )
PPC_ S T L r19 , V C P U _ G P R ( R 1 9 ) ( r4 )
PPC_ S T L r20 , V C P U _ G P R ( R 2 0 ) ( r4 )
PPC_ S T L r21 , V C P U _ G P R ( R 2 1 ) ( r4 )
PPC_ S T L r22 , V C P U _ G P R ( R 2 2 ) ( r4 )
PPC_ S T L r23 , V C P U _ G P R ( R 2 3 ) ( r4 )
PPC_ S T L r24 , V C P U _ G P R ( R 2 4 ) ( r4 )
PPC_ S T L r25 , V C P U _ G P R ( R 2 5 ) ( r4 )
PPC_ S T L r26 , V C P U _ G P R ( R 2 6 ) ( r4 )
PPC_ S T L r27 , V C P U _ G P R ( R 2 7 ) ( r4 )
PPC_ S T L r28 , V C P U _ G P R ( R 2 8 ) ( r4 )
PPC_ S T L r29 , V C P U _ G P R ( R 2 9 ) ( r4 )
PPC_ S T L r30 , V C P U _ G P R ( R 3 0 ) ( r4 )
PPC_ S T L r31 , V C P U _ G P R ( R 3 1 ) ( r4 )
2014-07-23 19:06:22 +03:00
/ *
* We d o n ' t u s e e x t e r n a l P I D s u p p o r t . l w e p x f a u l t s w o u l d n e e d t o b e
* handled b y K V M a n d t h i s i m p l i e s a d i t i o n a l c o d e i n D O _ K V M ( f o r
* DTB_ M I S S , D S I a n d L R A T ) t o c h e c k E S R [ E P I D ] a n d E P L C [ E G S ] w h i c h
* is t o o i n t r u s i v e f o r t h e h o s t . G e t l a s t i n s t u c t i o n i n
* kvmppc_ g e t _ l a s t _ i n s t ( ) .
* /
li r9 , K V M _ I N S T _ F E T C H _ F A I L E D
2011-12-20 15:34:43 +00:00
stw r9 , V C P U _ L A S T _ I N S T ( r4 )
.endif
.if \ flags & N E E D _ E S R
mfspr r8 , S P R N _ E S R
PPC_ S T L r8 , V C P U _ F A U L T _ E S R ( r4 )
.endif
.if \ flags & N E E D _ D E A R
mfspr r9 , S P R N _ D E A R
PPC_ S T L r9 , V C P U _ F A U L T _ D E A R ( r4 )
.endif
b k v m p p c _ r e s u m e _ h o s t
.endm
2012-10-11 06:13:21 +00:00
# ifdef C O N F I G _ 6 4 B I T
/* Exception types */
# define E X _ G E N 1
# define E X _ G D B E L L 2
# define E X _ D B G 3
# define E X _ M C 4
# define E X _ C R I T 5
# define E X _ T L B 6
/ *
* For i n p u t r e g i s t e r v a l u e s , s e e a r c h / p o w e r p c / i n c l u d e / a s m / k v m _ b o o k e _ h v _ a s m . h
* /
.macro kvm_handler intno t y p e s c r a t c h , p a c a _ e x , e x _ r10 , e x _ r11 , s r r0 , s r r1 , f l a g s
_ GLOBAL( k v m p p c _ h a n d l e r _ \ i n t n o \ ( ) _ \ s r r1 )
mr r11 , r4
/ *
* Get v c p u f r o m P a c a : p a c a - > _ _ c u r r e n t . t h r e a d - > k v m _ v c p u
* /
PPC_ L L r4 , P A C A C U R R E N T ( r13 )
PPC_ L L r4 , ( T H R E A D + T H R E A D _ K V M _ V C P U ) ( r4 )
2018-10-08 16:30:58 +11:00
PPC_ S T L r10 , V C P U _ C R ( r4 )
2012-10-11 06:13:21 +00:00
PPC_ S T L r11 , V C P U _ G P R ( R 4 ) ( r4 )
PPC_ S T L r5 , V C P U _ G P R ( R 5 ) ( r4 )
PPC_ S T L r6 , V C P U _ G P R ( R 6 ) ( r4 )
PPC_ S T L r8 , V C P U _ G P R ( R 8 ) ( r4 )
PPC_ S T L r9 , V C P U _ G P R ( R 9 ) ( r4 )
2014-03-10 17:29:38 -05:00
.if \ type = = E X _ T L B
PPC_ L L r5 , E X _ T L B _ R 1 3 ( r12 )
PPC_ L L r6 , E X _ T L B _ R 1 0 ( r12 )
PPC_ L L r8 , E X _ T L B _ R 1 1 ( r12 )
mfspr r12 , \ s c r a t c h
.else
mfspr r5 , \ s c r a t c h
2012-10-11 06:13:21 +00:00
PPC_ L L r6 , ( \ p a c a _ e x + \ e x _ r10 ) ( r13 )
PPC_ L L r8 , ( \ p a c a _ e x + \ e x _ r11 ) ( r13 )
2014-03-10 17:29:38 -05:00
.endif
PPC_ S T L r5 , V C P U _ G P R ( R 1 3 ) ( r4 )
2012-10-11 06:13:21 +00:00
PPC_ S T L r3 , V C P U _ G P R ( R 3 ) ( r4 )
PPC_ S T L r7 , V C P U _ G P R ( R 7 ) ( r4 )
PPC_ S T L r12 , V C P U _ G P R ( R 1 2 ) ( r4 )
PPC_ S T L r6 , V C P U _ G P R ( R 1 0 ) ( r4 )
PPC_ S T L r8 , V C P U _ G P R ( R 1 1 ) ( r4 )
mfctr r5
PPC_ S T L r5 , V C P U _ C T R ( r4 )
mfspr r5 , \ s r r0
mfspr r6 , \ s r r1
kvm_ h a n d l e r _ c o m m o n \ i n t n o , \ s r r0 , \ f l a g s
.endm
# define E X _ P A R A M S ( t y p e ) \
EX_ ## t y p e , \
SPRN_ S P R G _ ## t y p e # # _ S C R A T C H , \
PACA_ E X ## t y p e , \
EX_ R 1 0 , \
EX_ R 1 1
# define E X _ P A R A M S _ T L B \
EX_ T L B , \
SPRN_ S P R G _ G E N _ S C R A T C H , \
PACA_ E X T L B , \
EX_ T L B _ R 1 0 , \
EX_ T L B _ R 1 1
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ C R I T I C A L , E X _ P A R A M S ( C R I T ) , \
SPRN_ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ M A C H I N E _ C H E C K , E X _ P A R A M S ( M C ) , \
SPRN_ M C S R R 0 , S P R N _ M C S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D A T A _ S T O R A G E , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 ,( N E E D _ E M U | N E E D _ D E A R | N E E D _ E S R )
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ I N S T _ S T O R A G E , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , N E E D _ E S R
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ E X T E R N A L , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ A L I G N M E N T , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 ,( N E E D _ D E A R | N E E D _ E S R )
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ P R O G R A M , E X _ P A R A M S ( G E N ) , \
2014-09-09 22:37:36 +05:30
SPRN_ S R R 0 , S P R N _ S R R 1 , ( N E E D _ E S R | N E E D _ E M U )
2012-10-11 06:13:21 +00:00
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ F P _ U N A V A I L , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ A P _ U N A V A I L , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D E C R E M E N T E R , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ F I T , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ W A T C H D O G , E X _ P A R A M S ( C R I T ) ,\
SPRN_ C S R R 0 , S P R N _ C S R R 1 , 0
/ *
* Only b o l t e d T L B m i s s e x c e p t i o n h a n d l e r s a r e s u p p o r t e d f o r n o w
* /
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D T L B _ M I S S , E X _ P A R A M S _ T L B , \
SPRN_ S R R 0 , S P R N _ S R R 1 , ( N E E D _ E M U | N E E D _ D E A R | N E E D _ E S R )
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ I T L B _ M I S S , E X _ P A R A M S _ T L B , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
2014-08-20 16:36:23 +03:00
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ A L T I V E C _ U N A V A I L , E X _ P A R A M S ( G E N ) , \
2012-10-11 06:13:21 +00:00
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
2014-08-20 16:36:23 +03:00
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ A L T I V E C _ A S S I S T , E X _ P A R A M S ( G E N ) , \
2012-10-11 06:13:21 +00:00
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ P E R F O R M A N C E _ M O N I T O R , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D O O R B E L L , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D O O R B E L L _ C R I T I C A L , E X _ P A R A M S ( C R I T ) , \
SPRN_ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ H V _ P R I V , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , N E E D _ E M U
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ H V _ S Y S C A L L , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ G U E S T _ D B E L L , E X _ P A R A M S ( G D B E L L ) , \
SPRN_ G S R R 0 , S P R N _ G S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ G U E S T _ D B E L L _ C R I T , E X _ P A R A M S ( C R I T ) , \
SPRN_ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D E B U G , E X _ P A R A M S ( D B G ) , \
SPRN_ D S R R 0 , S P R N _ D S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D E B U G , E X _ P A R A M S ( C R I T ) , \
SPRN_ C S R R 0 , S P R N _ C S R R 1 , 0
2013-08-08 15:56:09 +03:00
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ L R A T _ E R R O R , E X _ P A R A M S ( G E N ) , \
SPRN_ S R R 0 , S P R N _ S R R 1 , ( N E E D _ E M U | N E E D _ D E A R | N E E D _ E S R )
2012-10-11 06:13:21 +00:00
# else
2011-12-20 15:34:43 +00:00
/ *
* For i n p u t r e g i s t e r v a l u e s , s e e a r c h / p o w e r p c / i n c l u d e / a s m / k v m _ b o o k e _ h v _ a s m . h
* /
.macro kvm_handler intno s r r0 , s r r1 , f l a g s
_ GLOBAL( k v m p p c _ h a n d l e r _ \ i n t n o \ ( ) _ \ s r r1 )
2012-10-11 06:13:20 +00:00
PPC_ L L r11 , T H R E A D _ K V M _ V C P U ( r10 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r3 , V C P U _ G P R ( R 3 ) ( r11 )
2011-12-20 15:34:43 +00:00
mfspr r3 , S P R N _ S P R G _ R S C R A T C H 0
2012-06-25 13:33:10 +00:00
PPC_ S T L r4 , V C P U _ G P R ( R 4 ) ( r11 )
2011-12-20 15:34:43 +00:00
PPC_ L L r4 , T H R E A D _ N O R M S A V E ( 0 ) ( r10 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r5 , V C P U _ G P R ( R 5 ) ( r11 )
2018-10-08 16:30:58 +11:00
PPC_ S T L r13 , V C P U _ C R ( r11 )
2011-12-20 15:34:43 +00:00
mfspr r5 , \ s r r0
2012-06-25 13:33:10 +00:00
PPC_ S T L r3 , V C P U _ G P R ( R 1 0 ) ( r11 )
2011-12-20 15:34:43 +00:00
PPC_ L L r3 , T H R E A D _ N O R M S A V E ( 2 ) ( r10 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r6 , V C P U _ G P R ( R 6 ) ( r11 )
PPC_ S T L r4 , V C P U _ G P R ( R 1 1 ) ( r11 )
2011-12-20 15:34:43 +00:00
mfspr r6 , \ s r r1
2012-06-25 13:33:10 +00:00
PPC_ S T L r7 , V C P U _ G P R ( R 7 ) ( r11 )
PPC_ S T L r8 , V C P U _ G P R ( R 8 ) ( r11 )
PPC_ S T L r9 , V C P U _ G P R ( R 9 ) ( r11 )
PPC_ S T L r3 , V C P U _ G P R ( R 1 3 ) ( r11 )
2011-12-20 15:34:43 +00:00
mfctr r7
2012-06-25 13:33:10 +00:00
PPC_ S T L r12 , V C P U _ G P R ( R 1 2 ) ( r11 )
2011-12-20 15:34:43 +00:00
PPC_ S T L r7 , V C P U _ C T R ( r11 )
mr r4 , r11
kvm_ h a n d l e r _ c o m m o n \ i n t n o , \ s r r0 , \ f l a g s
.endm
.macro kvm_lvl_handler intno s c r a t c h s r r0 , s r r1 , f l a g s
_ GLOBAL( k v m p p c _ h a n d l e r _ \ i n t n o \ ( ) _ \ s r r1 )
mfspr r10 , S P R N _ S P R G _ T H R E A D
2012-10-11 06:13:20 +00:00
PPC_ L L r11 , T H R E A D _ K V M _ V C P U ( r10 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r3 , V C P U _ G P R ( R 3 ) ( r11 )
2011-12-20 15:34:43 +00:00
mfspr r3 , \ s c r a t c h
2012-06-25 13:33:10 +00:00
PPC_ S T L r4 , V C P U _ G P R ( R 4 ) ( r11 )
2011-12-20 15:34:43 +00:00
PPC_ L L r4 , G P R 9 ( r8 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r5 , V C P U _ G P R ( R 5 ) ( r11 )
2018-10-08 16:30:58 +11:00
PPC_ S T L r9 , V C P U _ C R ( r11 )
2011-12-20 15:34:43 +00:00
mfspr r5 , \ s r r0
2012-06-25 13:33:10 +00:00
PPC_ S T L r3 , V C P U _ G P R ( R 8 ) ( r11 )
2011-12-20 15:34:43 +00:00
PPC_ L L r3 , G P R 1 0 ( r8 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r6 , V C P U _ G P R ( R 6 ) ( r11 )
PPC_ S T L r4 , V C P U _ G P R ( R 9 ) ( r11 )
2011-12-20 15:34:43 +00:00
mfspr r6 , \ s r r1
PPC_ L L r4 , G P R 1 1 ( r8 )
2012-06-25 13:33:10 +00:00
PPC_ S T L r7 , V C P U _ G P R ( R 7 ) ( r11 )
PPC_ S T L r3 , V C P U _ G P R ( R 1 0 ) ( r11 )
2011-12-20 15:34:43 +00:00
mfctr r7
2012-06-25 13:33:10 +00:00
PPC_ S T L r12 , V C P U _ G P R ( R 1 2 ) ( r11 )
PPC_ S T L r13 , V C P U _ G P R ( R 1 3 ) ( r11 )
PPC_ S T L r4 , V C P U _ G P R ( R 1 1 ) ( r11 )
2011-12-20 15:34:43 +00:00
PPC_ S T L r7 , V C P U _ C T R ( r11 )
mr r4 , r11
kvm_ h a n d l e r _ c o m m o n \ i n t n o , \ s r r0 , \ f l a g s
.endm
kvm_ l v l _ h a n d l e r B O O K E _ I N T E R R U P T _ C R I T I C A L , \
SPRN_ S P R G _ R S C R A T C H _ C R I T , S P R N _ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ l v l _ h a n d l e r B O O K E _ I N T E R R U P T _ M A C H I N E _ C H E C K , \
SPRN_ S P R G _ R S C R A T C H _ M C , S P R N _ M C S R R 0 , S P R N _ M C S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D A T A _ S T O R A G E , \
2012-06-22 13:33:12 +00:00
SPRN_ S R R 0 , S P R N _ S R R 1 , ( N E E D _ E M U | N E E D _ D E A R | N E E D _ E S R )
2011-12-20 15:34:43 +00:00
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ I N S T _ S T O R A G E , S P R N _ S R R 0 , S P R N _ S R R 1 , N E E D _ E S R
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ E X T E R N A L , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ A L I G N M E N T , \
SPRN_ S R R 0 , S P R N _ S R R 1 , ( N E E D _ D E A R | N E E D _ E S R )
2014-09-09 22:37:36 +05:30
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ P R O G R A M , S P R N _ S R R 0 , S P R N _ S R R 1 , ( N E E D _ E S R | N E E D _ E M U )
2011-12-20 15:34:43 +00:00
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ F P _ U N A V A I L , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ S Y S C A L L , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ A P _ U N A V A I L , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D E C R E M E N T E R , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ F I T , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ l v l _ h a n d l e r B O O K E _ I N T E R R U P T _ W A T C H D O G , \
SPRN_ S P R G _ R S C R A T C H _ C R I T , S P R N _ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D T L B _ M I S S , \
SPRN_ S R R 0 , S P R N _ S R R 1 , ( N E E D _ E M U | N E E D _ D E A R | N E E D _ E S R )
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ I T L B _ M I S S , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ P E R F O R M A N C E _ M O N I T O R , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ D O O R B E L L , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ l v l _ h a n d l e r B O O K E _ I N T E R R U P T _ D O O R B E L L _ C R I T I C A L , \
SPRN_ S P R G _ R S C R A T C H _ C R I T , S P R N _ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ H V _ P R I V , S P R N _ S R R 0 , S P R N _ S R R 1 , N E E D _ E M U
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ H V _ S Y S C A L L , S P R N _ S R R 0 , S P R N _ S R R 1 , 0
kvm_ h a n d l e r B O O K E _ I N T E R R U P T _ G U E S T _ D B E L L , S P R N _ G S R R 0 , S P R N _ G S R R 1 , 0
kvm_ l v l _ h a n d l e r B O O K E _ I N T E R R U P T _ G U E S T _ D B E L L _ C R I T , \
SPRN_ S P R G _ R S C R A T C H _ C R I T , S P R N _ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ l v l _ h a n d l e r B O O K E _ I N T E R R U P T _ D E B U G , \
SPRN_ S P R G _ R S C R A T C H _ C R I T , S P R N _ C S R R 0 , S P R N _ C S R R 1 , 0
kvm_ l v l _ h a n d l e r B O O K E _ I N T E R R U P T _ D E B U G , \
SPRN_ S P R G _ R S C R A T C H _ D B G , S P R N _ D S R R 0 , S P R N _ D S R R 1 , 0
2012-10-11 06:13:21 +00:00
# endif
2011-12-20 15:34:43 +00:00
/ * Registers :
* SPRG_SCRATCH0 : guest r10
* r4 : vcpu p o i n t e r
* r11 : vcpu- > a r c h . s h a r e d
* r14 : KVM e x i t n u m b e r
* /
_ GLOBAL( k v m p p c _ r e s u m e _ h o s t )
/* Save remaining volatile guest register state to vcpu. */
mfspr r3 , S P R N _ V R S A V E
2012-06-25 13:33:10 +00:00
PPC_ S T L r0 , V C P U _ G P R ( R 0 ) ( r4 )
2011-12-20 15:34:43 +00:00
mflr r5
mfspr r6 , S P R N _ S P R G 4
PPC_ S T L r5 , V C P U _ L R ( r4 )
mfspr r7 , S P R N _ S P R G 5
2012-04-16 04:08:54 +00:00
stw r3 , V C P U _ V R S A V E ( r4 )
2014-03-10 17:29:38 -05:00
# ifdef C O N F I G _ 6 4 B I T
PPC_ L L r3 , P A C A _ S P R G _ V D S O ( r13 )
# endif
2014-07-21 11:23:26 +05:30
mfspr r5 , S P R N _ S P R G 9
2012-04-25 01:27:34 +00:00
PPC_ S T D ( r6 , V C P U _ S H A R E D _ S P R G 4 , r11 )
2011-12-20 15:34:43 +00:00
mfspr r8 , S P R N _ S P R G 6
2012-04-25 01:27:34 +00:00
PPC_ S T D ( r7 , V C P U _ S H A R E D _ S P R G 5 , r11 )
2011-12-20 15:34:43 +00:00
mfspr r9 , S P R N _ S P R G 7
2014-03-10 17:29:38 -05:00
# ifdef C O N F I G _ 6 4 B I T
mtspr S P R N _ S P R G _ V D S O _ W R I T E , r3
# endif
2014-07-21 11:23:26 +05:30
PPC_ S T D ( r5 , V C P U _ S P R G 9 , r4 )
2012-04-25 01:27:34 +00:00
PPC_ S T D ( r8 , V C P U _ S H A R E D _ S P R G 6 , r11 )
2011-12-20 15:34:43 +00:00
mfxer r3
2012-04-25 01:27:34 +00:00
PPC_ S T D ( r9 , V C P U _ S H A R E D _ S P R G 7 , r11 )
2011-12-20 15:34:43 +00:00
/* save guest MAS registers and restore host mas4 & mas6 */
mfspr r5 , S P R N _ M A S 0
PPC_ S T L r3 , V C P U _ X E R ( r4 )
mfspr r6 , S P R N _ M A S 1
stw r5 , V C P U _ S H A R E D _ M A S 0 ( r11 )
mfspr r7 , S P R N _ M A S 2
stw r6 , V C P U _ S H A R E D _ M A S 1 ( r11 )
2012-04-25 01:26:43 +00:00
PPC_ S T D ( r7 , V C P U _ S H A R E D _ M A S 2 , r11 )
2011-12-20 15:34:43 +00:00
mfspr r5 , S P R N _ M A S 3
mfspr r6 , S P R N _ M A S 4
stw r5 , V C P U _ S H A R E D _ M A S 7 _ 3 + 4 ( r11 )
mfspr r7 , S P R N _ M A S 6
stw r6 , V C P U _ S H A R E D _ M A S 4 ( r11 )
mfspr r5 , S P R N _ M A S 7
lwz r6 , V C P U _ H O S T _ M A S 4 ( r4 )
stw r7 , V C P U _ S H A R E D _ M A S 6 ( r11 )
lwz r8 , V C P U _ H O S T _ M A S 6 ( r4 )
mtspr S P R N _ M A S 4 , r6
stw r5 , V C P U _ S H A R E D _ M A S 7 _ 3 + 0 ( r11 )
mtspr S P R N _ M A S 6 , r8
2012-02-16 14:53:04 +00:00
/* Enable MAS register updates via exception */
2011-12-20 15:34:43 +00:00
mfspr r3 , S P R N _ E P C R
rlwinm r3 , r3 , 0 , ~ S P R N _ E P C R _ D M I U H
mtspr S P R N _ E P C R , r3
isync
2013-10-23 09:26:48 +08:00
# ifdef C O N F I G _ 6 4 B I T
/ *
* We e n t e r w i t h i n t e r r u p t s d i s a b l e d i n h a r d w a r e , b u t
* we n e e d t o c a l l R E C O N C I L E _ I R Q _ S T A T E t o e n s u r e
* that t h e s o f t w a r e s t a t e i s k e p t i n s y n c .
* /
RECONCILE_ I R Q _ S T A T E ( r3 ,r5 )
# endif
2011-12-20 15:34:43 +00:00
/* Switch to kernel stack and jump to handler. */
PPC_ L L r3 , H O S T _ R U N ( r1 )
mr r5 , r14 / * i n t n o * /
mr r14 , r4 / * S a v e v c p u p o i n t e r . * /
bl k v m p p c _ h a n d l e _ e x i t
/* Restore vcpu pointer and the nonvolatiles we used. */
mr r4 , r14
2012-06-25 13:33:10 +00:00
PPC_ L L r14 , V C P U _ G P R ( R 1 4 ) ( r4 )
2011-12-20 15:34:43 +00:00
andi. r5 , r3 , R E S U M E _ F L A G _ N V
beq s k i p _ n v _ l o a d
2012-06-25 13:33:10 +00:00
PPC_ L L r15 , V C P U _ G P R ( R 1 5 ) ( r4 )
PPC_ L L r16 , V C P U _ G P R ( R 1 6 ) ( r4 )
PPC_ L L r17 , V C P U _ G P R ( R 1 7 ) ( r4 )
PPC_ L L r18 , V C P U _ G P R ( R 1 8 ) ( r4 )
PPC_ L L r19 , V C P U _ G P R ( R 1 9 ) ( r4 )
PPC_ L L r20 , V C P U _ G P R ( R 2 0 ) ( r4 )
PPC_ L L r21 , V C P U _ G P R ( R 2 1 ) ( r4 )
PPC_ L L r22 , V C P U _ G P R ( R 2 2 ) ( r4 )
PPC_ L L r23 , V C P U _ G P R ( R 2 3 ) ( r4 )
PPC_ L L r24 , V C P U _ G P R ( R 2 4 ) ( r4 )
PPC_ L L r25 , V C P U _ G P R ( R 2 5 ) ( r4 )
PPC_ L L r26 , V C P U _ G P R ( R 2 6 ) ( r4 )
PPC_ L L r27 , V C P U _ G P R ( R 2 7 ) ( r4 )
PPC_ L L r28 , V C P U _ G P R ( R 2 8 ) ( r4 )
PPC_ L L r29 , V C P U _ G P R ( R 2 9 ) ( r4 )
PPC_ L L r30 , V C P U _ G P R ( R 3 0 ) ( r4 )
PPC_ L L r31 , V C P U _ G P R ( R 3 1 ) ( r4 )
2011-12-20 15:34:43 +00:00
skip_nv_load :
/* Should we return to the guest? */
andi. r5 , r3 , R E S U M E _ F L A G _ H O S T
beq l i g h t w e i g h t _ e x i t
srawi r3 , r3 , 2 / * S h i f t - E R R b a c k d o w n . * /
heavyweight_exit :
/* Not returning to guest. */
PPC_ L L r5 , H O S T _ S T A C K _ L R ( r1 )
2012-03-05 16:00:28 +01:00
lwz r6 , H O S T _ C R ( r1 )
2011-12-20 15:34:43 +00:00
/ *
* We a l r e a d y s a v e d g u e s t v o l a t i l e r e g i s t e r s t a t e ; now save the
* non- v o l a t i l e s .
* /
2012-06-25 13:33:10 +00:00
PPC_ S T L r15 , V C P U _ G P R ( R 1 5 ) ( r4 )
PPC_ S T L r16 , V C P U _ G P R ( R 1 6 ) ( r4 )
PPC_ S T L r17 , V C P U _ G P R ( R 1 7 ) ( r4 )
PPC_ S T L r18 , V C P U _ G P R ( R 1 8 ) ( r4 )
PPC_ S T L r19 , V C P U _ G P R ( R 1 9 ) ( r4 )
PPC_ S T L r20 , V C P U _ G P R ( R 2 0 ) ( r4 )
PPC_ S T L r21 , V C P U _ G P R ( R 2 1 ) ( r4 )
PPC_ S T L r22 , V C P U _ G P R ( R 2 2 ) ( r4 )
PPC_ S T L r23 , V C P U _ G P R ( R 2 3 ) ( r4 )
PPC_ S T L r24 , V C P U _ G P R ( R 2 4 ) ( r4 )
PPC_ S T L r25 , V C P U _ G P R ( R 2 5 ) ( r4 )
PPC_ S T L r26 , V C P U _ G P R ( R 2 6 ) ( r4 )
PPC_ S T L r27 , V C P U _ G P R ( R 2 7 ) ( r4 )
PPC_ S T L r28 , V C P U _ G P R ( R 2 8 ) ( r4 )
PPC_ S T L r29 , V C P U _ G P R ( R 2 9 ) ( r4 )
PPC_ S T L r30 , V C P U _ G P R ( R 3 0 ) ( r4 )
PPC_ S T L r31 , V C P U _ G P R ( R 3 1 ) ( r4 )
2011-12-20 15:34:43 +00:00
/* Load host non-volatile register state from host stack. */
2012-07-24 13:02:34 +00:00
PPC_ L L r14 , H O S T _ N V _ G P R ( R 1 4 ) ( r1 )
PPC_ L L r15 , H O S T _ N V _ G P R ( R 1 5 ) ( r1 )
PPC_ L L r16 , H O S T _ N V _ G P R ( R 1 6 ) ( r1 )
PPC_ L L r17 , H O S T _ N V _ G P R ( R 1 7 ) ( r1 )
PPC_ L L r18 , H O S T _ N V _ G P R ( R 1 8 ) ( r1 )
PPC_ L L r19 , H O S T _ N V _ G P R ( R 1 9 ) ( r1 )
PPC_ L L r20 , H O S T _ N V _ G P R ( R 2 0 ) ( r1 )
PPC_ L L r21 , H O S T _ N V _ G P R ( R 2 1 ) ( r1 )
PPC_ L L r22 , H O S T _ N V _ G P R ( R 2 2 ) ( r1 )
PPC_ L L r23 , H O S T _ N V _ G P R ( R 2 3 ) ( r1 )
PPC_ L L r24 , H O S T _ N V _ G P R ( R 2 4 ) ( r1 )
PPC_ L L r25 , H O S T _ N V _ G P R ( R 2 5 ) ( r1 )
PPC_ L L r26 , H O S T _ N V _ G P R ( R 2 6 ) ( r1 )
PPC_ L L r27 , H O S T _ N V _ G P R ( R 2 7 ) ( r1 )
PPC_ L L r28 , H O S T _ N V _ G P R ( R 2 8 ) ( r1 )
PPC_ L L r29 , H O S T _ N V _ G P R ( R 2 9 ) ( r1 )
PPC_ L L r30 , H O S T _ N V _ G P R ( R 3 0 ) ( r1 )
PPC_ L L r31 , H O S T _ N V _ G P R ( R 3 1 ) ( r1 )
2011-12-20 15:34:43 +00:00
/* Return to kvm_vcpu_run(). */
mtlr r5
2012-03-05 16:00:28 +01:00
mtcr r6
2011-12-20 15:34:43 +00:00
addi r1 , r1 , H O S T _ S T A C K _ S I Z E
/* r3 still contains the return code from kvmppc_handle_exit(). */
blr
/ * Registers :
* r3 : kvm_ r u n p o i n t e r
* r4 : vcpu p o i n t e r
* /
_ GLOBAL( _ _ k v m p p c _ v c p u _ r u n )
stwu r1 , - H O S T _ S T A C K _ S I Z E ( r1 )
PPC_ S T L r1 , V C P U _ H O S T _ S T A C K ( r4 ) / * S a v e s t a c k p o i n t e r t o v c p u . * /
/* Save host state to stack. */
PPC_ S T L r3 , H O S T _ R U N ( r1 )
mflr r3
2012-03-05 16:00:28 +01:00
mfcr r5
2011-12-20 15:34:43 +00:00
PPC_ S T L r3 , H O S T _ S T A C K _ L R ( r1 )
2012-03-05 16:00:28 +01:00
stw r5 , H O S T _ C R ( r1 )
2011-12-20 15:34:43 +00:00
/* Save host non-volatile register state to stack. */
2012-07-24 13:02:34 +00:00
PPC_ S T L r14 , H O S T _ N V _ G P R ( R 1 4 ) ( r1 )
PPC_ S T L r15 , H O S T _ N V _ G P R ( R 1 5 ) ( r1 )
PPC_ S T L r16 , H O S T _ N V _ G P R ( R 1 6 ) ( r1 )
PPC_ S T L r17 , H O S T _ N V _ G P R ( R 1 7 ) ( r1 )
PPC_ S T L r18 , H O S T _ N V _ G P R ( R 1 8 ) ( r1 )
PPC_ S T L r19 , H O S T _ N V _ G P R ( R 1 9 ) ( r1 )
PPC_ S T L r20 , H O S T _ N V _ G P R ( R 2 0 ) ( r1 )
PPC_ S T L r21 , H O S T _ N V _ G P R ( R 2 1 ) ( r1 )
PPC_ S T L r22 , H O S T _ N V _ G P R ( R 2 2 ) ( r1 )
PPC_ S T L r23 , H O S T _ N V _ G P R ( R 2 3 ) ( r1 )
PPC_ S T L r24 , H O S T _ N V _ G P R ( R 2 4 ) ( r1 )
PPC_ S T L r25 , H O S T _ N V _ G P R ( R 2 5 ) ( r1 )
PPC_ S T L r26 , H O S T _ N V _ G P R ( R 2 6 ) ( r1 )
PPC_ S T L r27 , H O S T _ N V _ G P R ( R 2 7 ) ( r1 )
PPC_ S T L r28 , H O S T _ N V _ G P R ( R 2 8 ) ( r1 )
PPC_ S T L r29 , H O S T _ N V _ G P R ( R 2 9 ) ( r1 )
PPC_ S T L r30 , H O S T _ N V _ G P R ( R 3 0 ) ( r1 )
PPC_ S T L r31 , H O S T _ N V _ G P R ( R 3 1 ) ( r1 )
2011-12-20 15:34:43 +00:00
/* Load guest non-volatiles. */
2012-06-25 13:33:10 +00:00
PPC_ L L r14 , V C P U _ G P R ( R 1 4 ) ( r4 )
PPC_ L L r15 , V C P U _ G P R ( R 1 5 ) ( r4 )
PPC_ L L r16 , V C P U _ G P R ( R 1 6 ) ( r4 )
PPC_ L L r17 , V C P U _ G P R ( R 1 7 ) ( r4 )
PPC_ L L r18 , V C P U _ G P R ( R 1 8 ) ( r4 )
PPC_ L L r19 , V C P U _ G P R ( R 1 9 ) ( r4 )
PPC_ L L r20 , V C P U _ G P R ( R 2 0 ) ( r4 )
PPC_ L L r21 , V C P U _ G P R ( R 2 1 ) ( r4 )
PPC_ L L r22 , V C P U _ G P R ( R 2 2 ) ( r4 )
PPC_ L L r23 , V C P U _ G P R ( R 2 3 ) ( r4 )
PPC_ L L r24 , V C P U _ G P R ( R 2 4 ) ( r4 )
PPC_ L L r25 , V C P U _ G P R ( R 2 5 ) ( r4 )
PPC_ L L r26 , V C P U _ G P R ( R 2 6 ) ( r4 )
PPC_ L L r27 , V C P U _ G P R ( R 2 7 ) ( r4 )
PPC_ L L r28 , V C P U _ G P R ( R 2 8 ) ( r4 )
PPC_ L L r29 , V C P U _ G P R ( R 2 9 ) ( r4 )
PPC_ L L r30 , V C P U _ G P R ( R 3 0 ) ( r4 )
PPC_ L L r31 , V C P U _ G P R ( R 3 1 ) ( r4 )
2011-12-20 15:34:43 +00:00
lightweight_exit :
PPC_ S T L r2 , H O S T _ R 2 ( r1 )
mfspr r3 , S P R N _ P I D
stw r3 , V C P U _ H O S T _ P I D ( r4 )
lwz r3 , V C P U _ G U E S T _ P I D ( r4 )
mtspr S P R N _ P I D , r3
PPC_ L L r11 , V C P U _ S H A R E D ( r4 )
2012-02-16 14:53:04 +00:00
/* Disable MAS register updates via exception */
mfspr r3 , S P R N _ E P C R
oris r3 , r3 , S P R N _ E P C R _ D M I U H @h
mtspr S P R N _ E P C R , r3
isync
2011-12-20 15:34:43 +00:00
/* Save host mas4 and mas6 and load guest MAS registers */
mfspr r3 , S P R N _ M A S 4
stw r3 , V C P U _ H O S T _ M A S 4 ( r4 )
mfspr r3 , S P R N _ M A S 6
stw r3 , V C P U _ H O S T _ M A S 6 ( r4 )
lwz r3 , V C P U _ S H A R E D _ M A S 0 ( r11 )
lwz r5 , V C P U _ S H A R E D _ M A S 1 ( r11 )
2012-04-25 01:26:43 +00:00
PPC_ L D ( r6 , V C P U _ S H A R E D _ M A S 2 , r11 )
2011-12-20 15:34:43 +00:00
lwz r7 , V C P U _ S H A R E D _ M A S 7 _ 3 + 4 ( r11 )
lwz r8 , V C P U _ S H A R E D _ M A S 4 ( r11 )
mtspr S P R N _ M A S 0 , r3
mtspr S P R N _ M A S 1 , r5
mtspr S P R N _ M A S 2 , r6
mtspr S P R N _ M A S 3 , r7
mtspr S P R N _ M A S 4 , r8
lwz r3 , V C P U _ S H A R E D _ M A S 6 ( r11 )
lwz r5 , V C P U _ S H A R E D _ M A S 7 _ 3 + 0 ( r11 )
mtspr S P R N _ M A S 6 , r3
mtspr S P R N _ M A S 7 , r5
/ *
* Host i n t e r r u p t h a n d l e r s m a y h a v e c l o b b e r e d t h e s e g u e s t - r e a d a b l e
* SPRGs, s o w e n e e d t o r e l o a d t h e m h e r e w i t h t h e g u e s t ' s v a l u e s .
* /
lwz r3 , V C P U _ V R S A V E ( r4 )
2012-04-25 01:27:34 +00:00
PPC_ L D ( r5 , V C P U _ S H A R E D _ S P R G 4 , r11 )
2011-12-20 15:34:43 +00:00
mtspr S P R N _ V R S A V E , r3
2012-04-25 01:27:34 +00:00
PPC_ L D ( r6 , V C P U _ S H A R E D _ S P R G 5 , r11 )
2011-12-20 15:34:43 +00:00
mtspr S P R N _ S P R G 4 W , r5
2012-04-25 01:27:34 +00:00
PPC_ L D ( r7 , V C P U _ S H A R E D _ S P R G 6 , r11 )
2011-12-20 15:34:43 +00:00
mtspr S P R N _ S P R G 5 W , r6
2012-04-25 01:27:34 +00:00
PPC_ L D ( r8 , V C P U _ S H A R E D _ S P R G 7 , r11 )
2011-12-20 15:34:43 +00:00
mtspr S P R N _ S P R G 6 W , r7
2014-07-21 11:23:26 +05:30
PPC_ L D ( r5 , V C P U _ S P R G 9 , r4 )
2011-12-20 15:34:43 +00:00
mtspr S P R N _ S P R G 7 W , r8
2014-07-21 11:23:26 +05:30
mtspr S P R N _ S P R G 9 , r5
2011-12-20 15:34:43 +00:00
/* Load some guest volatiles. */
PPC_ L L r3 , V C P U _ L R ( r4 )
PPC_ L L r5 , V C P U _ X E R ( r4 )
PPC_ L L r6 , V C P U _ C T R ( r4 )
2018-10-08 16:30:58 +11:00
PPC_ L L r7 , V C P U _ C R ( r4 )
2011-12-20 15:34:43 +00:00
PPC_ L L r8 , V C P U _ P C ( r4 )
2012-04-25 01:26:43 +00:00
PPC_ L D ( r9 , V C P U _ S H A R E D _ M S R , r11 )
2012-06-25 13:33:10 +00:00
PPC_ L L r0 , V C P U _ G P R ( R 0 ) ( r4 )
PPC_ L L r1 , V C P U _ G P R ( R 1 ) ( r4 )
PPC_ L L r2 , V C P U _ G P R ( R 2 ) ( r4 )
PPC_ L L r10 , V C P U _ G P R ( R 1 0 ) ( r4 )
PPC_ L L r11 , V C P U _ G P R ( R 1 1 ) ( r4 )
PPC_ L L r12 , V C P U _ G P R ( R 1 2 ) ( r4 )
PPC_ L L r13 , V C P U _ G P R ( R 1 3 ) ( r4 )
2011-12-20 15:34:43 +00:00
mtlr r3
mtxer r5
mtctr r6
mtsrr0 r8
mtsrr1 r9
# ifdef C O N F I G _ K V M _ E X I T _ T I M I N G
/* save enter time */
1 :
mfspr r6 , S P R N _ T B R U
2012-03-05 01:34:08 +00:00
mfspr r9 , S P R N _ T B R L
2011-12-20 15:34:43 +00:00
mfspr r8 , S P R N _ T B R U
cmpw r8 , r6
2012-04-16 04:08:54 +00:00
stw r9 , V C P U _ T I M I N G _ L A S T _ E N T E R _ T B L ( r4 )
2011-12-20 15:34:43 +00:00
bne 1 b
2012-04-16 04:08:54 +00:00
stw r8 , V C P U _ T I M I N G _ L A S T _ E N T E R _ T B U ( r4 )
2011-12-20 15:34:43 +00:00
# endif
2012-03-05 01:34:08 +00:00
/ *
* Don' t e x e c u t e a n y i n s t r u c t i o n w h i c h c a n c h a n g e C R a f t e r
* below i n s t r u c t i o n .
* /
mtcr r7
2011-12-20 15:34:43 +00:00
/* Finish loading guest volatiles and jump to guest. */
2012-06-25 13:33:10 +00:00
PPC_ L L r5 , V C P U _ G P R ( R 5 ) ( r4 )
PPC_ L L r6 , V C P U _ G P R ( R 6 ) ( r4 )
PPC_ L L r7 , V C P U _ G P R ( R 7 ) ( r4 )
PPC_ L L r8 , V C P U _ G P R ( R 8 ) ( r4 )
PPC_ L L r9 , V C P U _ G P R ( R 9 ) ( r4 )
PPC_ L L r3 , V C P U _ G P R ( R 3 ) ( r4 )
PPC_ L L r4 , V C P U _ G P R ( R 4 ) ( r4 )
2011-12-20 15:34:43 +00:00
rfi