2005-06-23 22:01:16 -07:00
/ *
* arch/ x t e n s a / k e r n e l / h e a d . S
*
* Xtensa P r o c e s s o r s t a r t u p c o d e .
*
* This f i l e i s s u b j e c t t o t h e t e r m s a n d c o n d i t i o n s o f t h e G N U G e n e r a l P u b l i c
* License. S e e t h e f i l e " C O P Y I N G " i n t h e m a i n d i r e c t o r y o f t h i s a r c h i v e
* for m o r e d e t a i l s .
*
* Copyright ( C ) 2 0 0 1 - 2 0 0 5 T e n s i l i c a I n c .
*
* Chris Z a n k e l < c h r i s @zankel.net>
* Marc G a u t h i e r < m a r c @tensilica.com, marc@alumni.uwaterloo.ca>
* Joe T a y l o r < j o e @tensilica.com, joetylr@yahoo.com>
* Kevin C h e a
* /
# include < a s m / p r o c e s s o r . h >
# include < a s m / p a g e . h >
2006-12-10 02:18:48 -08:00
# include < a s m / c a c h e a s m . h >
2005-06-23 22:01:16 -07:00
2009-04-25 22:10:57 -04:00
# include < l i n u x / i n i t . h >
2007-05-31 17:48:07 -07:00
# include < l i n u x / l i n k a g e . h >
2005-06-23 22:01:16 -07:00
/ *
* This m o d u l e c o n t a i n s t h e e n t r y c o d e f o r k e r n e l i m a g e s . I t p e r f o r m s t h e
* minimal s e t u p n e e d e d t o c a l l t h e g e n e r i c C r o u t i n e s .
*
* Prerequisites :
*
* - The k e r n e l i m a g e h a s b e e n l o a d e d t o t h e a c t u a l a d d r e s s w h e r e i t w a s
* compiled t o .
* - a2 c o n t a i n s e i t h e r 0 o r a p o i n t e r t o a l i s t o f b o o t p a r a m e t e r s .
* ( see s e t u p . c f o r m o r e d e t a i l s )
*
* /
/ *
* _ start
*
* The b o o t l o a d e r p a s s e s a p o i n t e r t o a l i s t o f b o o t p a r a m e t e r s i n a2 .
* /
/ * The f i r s t b y t e s o f t h e k e r n e l i m a g e m u s t b e a n i n s t r u c t i o n , s o w e
* manually a l l o c a t e a n d d e f i n e t h e l i t e r a l c o n s t a n t w e n e e d f o r a j x
* instruction.
* /
2009-04-25 22:10:57 -04:00
_ _ HEAD
2005-06-23 22:01:16 -07:00
.globl _start
_start : _ j 2 f
.align 4
1 : .word _ s t a r t u p
2 : l3 2 r a0 , 1 b
jx a0
2009-03-11 14:15:11 +01:00
.section .init .text , " ax"
2005-06-23 22:01:16 -07:00
.align 4
_startup :
/* Disable interrupts and exceptions. */
2006-12-10 02:18:48 -08:00
movi a0 , L O C K L E V E L
2005-06-23 22:01:16 -07:00
wsr a0 , P S
/* Preserve the pointer to the boot parameter list in EXCSAVE_1 */
wsr a2 , E X C S A V E _ 1
/* Start with a fresh windowbase and windowstart. */
movi a1 , 1
movi a0 , 0
wsr a1 , W I N D O W S T A R T
wsr a0 , W I N D O W B A S E
rsync
/* Set a0 to 0 for the remaining initialization. */
movi a0 , 0
/* Clear debugging registers. */
# if X C H A L _ H A V E _ D E B U G
wsr a0 , I B R E A K E N A B L E
wsr a0 , I C O U N T
movi a1 , 1 5
wsr a0 , I C O U N T L E V E L
2006-12-10 02:18:48 -08:00
.set _ index, 0
.rept XCHAL_NUM_DBREAK - 1
wsr a0 , D B R E A K C + _ i n d e x
.set _ index, _ i n d e x + 1
.endr
2005-06-23 22:01:16 -07:00
# endif
/* Clear CCOUNT (not really necessary, but nice) */
wsr a0 , C C O U N T # n o t r e a l l y n e c e s s a r y , b u t n i c e
/* Disable zero-loops. */
# if X C H A L _ H A V E _ L O O P S
wsr a0 , L C O U N T
# endif
/* Disable all timers. */
2006-12-10 02:18:48 -08:00
.set _ index, 0
.rept XCHAL_NUM_TIMERS - 1
wsr a0 , C C O M P A R E + _ i n d e x
.set _ index, _ i n d e x + 1
.endr
2005-06-23 22:01:16 -07:00
/* Interrupt initialization. */
movi a2 , X C H A L _ I N T T Y P E _ M A S K _ S O F T W A R E | X C H A L _ I N T T Y P E _ M A S K _ E X T E R N _ E D G E
wsr a0 , I N T E N A B L E
wsr a2 , I N T C L E A R
/* Disable coprocessors. */
# if X C H A L _ C P _ N U M > 0
wsr a0 , C P E N A B L E
# endif
/ * Set P S . I N T L E V E L =1 , P S . W O E =0 , k e r n e l s t a c k , P S . E X C M =0
*
* Note : PS. E X C M m u s t b e c l e a r e d b e f o r e u s i n g a n y l o o p
* instructions; otherwise, they are silently disabled, and
* at m o s t o n e i t e r a t i o n o f t h e l o o p i s e x e c u t e d .
* /
movi a1 , 1
wsr a1 , P S
rsync
/ * Initialize t h e c a c h e s .
2006-12-10 02:18:48 -08:00
* a2 , a3 a r e j u s t w o r k i n g r e g i s t e r s ( c l o b b e r e d ) .
2005-06-23 22:01:16 -07:00
* /
2006-12-10 02:18:48 -08:00
# if X C H A L _ D C A C H E _ L I N E _ L O C K A B L E
_ _ _ unlock_ d c a c h e _ a l l a2 a3
# endif
# if X C H A L _ I C A C H E _ L I N E _ L O C K A B L E
_ _ _ unlock_ i c a c h e _ a l l a2 a3
# endif
_ _ _ invalidate_ d c a c h e _ a l l a2 a3
_ _ _ invalidate_ i c a c h e _ a l l a2 a3
isync
2005-06-23 22:01:16 -07:00
/ * Unpack d a t a s e c t i o n s
*
* The l i n k e r s c r i p t u s e d t o b u i l d t h e L i n u x k e r n e l i m a g e
* creates a t a b l e l o c a t e d a t _ _ b o o t _ r e l o c _ t a b l e _ s t a r t
* that c o n t a n s t h e i n f o r m a t i o n w h a t d a t a n e e d s t o b e u n p a c k e d .
*
* Uses a2 - a7 .
* /
movi a2 , _ _ b o o t _ r e l o c _ t a b l e _ s t a r t
movi a3 , _ _ b o o t _ r e l o c _ t a b l e _ e n d
1 : beq a2 , a3 , 3 f # n o m o r e e n t r i e s ?
l3 2 i a4 , a2 , 0 # s t a r t d e s t i n a t i o n ( i n R A M )
l3 2 i a5 , a2 , 4 # e n d d e s i n a t i o n ( i n R A M )
l3 2 i a6 , a2 , 8 # s t a r t s o u r c e ( i n R O M )
addi a2 , a2 , 1 2 # n e x t e n t r y
beq a4 , a5 , 1 b # s k i p , e m p t y e n t r y
beq a4 , a6 , 1 b # s k i p , s o u r c e a n d d e s t . a r e t h e s a m e
2 : l3 2 i a7 , a6 , 0 # l o a d w o r d
addi a6 , a6 , 4
s3 2 i a7 , a4 , 0 # s t o r e w o r d
addi a4 , a4 , 4
bltu a4 , a5 , 2 b
j 1 b
3 :
/ * All c o d e a n d i n i t i a l i z e d d a t a s e g m e n t s h a v e b e e n c o p i e d .
* Now c l e a r t h e B S S s e g m e n t .
* /
2010-05-01 23:05:29 -07:00
movi a2 , _ _ b s s _ s t a r t # s t a r t o f B S S
movi a3 , _ _ b s s _ s t o p # e n d o f B S S
2005-06-23 22:01:16 -07:00
2006-12-10 02:18:48 -08:00
_ _ loopt a2 , a3 , a4 , 2
2005-06-23 22:01:16 -07:00
s3 2 i a0 , a2 , 0
2006-12-10 02:18:48 -08:00
_ _ endla a2 , a4 , 4
2005-06-23 22:01:16 -07:00
# if X C H A L _ D C A C H E _ I S _ W R I T E B A C K
/ * After u n p a c k i n g , f l u s h t h e w r i t e b a c k c a c h e t o m e m o r y s o t h e
* instructions/ d a t a a r e a v a i l a b l e .
* /
2006-12-10 02:18:48 -08:00
_ _ _ flush_ d c a c h e _ a l l a2 a3
2005-06-23 22:01:16 -07:00
# endif
/* Setup stack and enable window exceptions (keep irqs disabled) */
movi a1 , i n i t _ t h r e a d _ u n i o n
addi a1 , a1 , K E R N E L _ S T A C K _ S I Z E
movi a2 , 0 x00 0 4 0 0 0 1 # W O E = 1 , I N T L E V E L =1 , U M =0
wsr a2 , P S # ( e n a b l e r e g - w i n d o w s ; p r o g m o d e s t a c k )
rsync
/* Set up EXCSAVE[DEBUGLEVEL] to point to the Debug Exception Handler.*/
movi a2 , d e b u g _ e x c e p t i o n
wsr a2 , E X C S A V E + X C H A L _ D E B U G L E V E L
/* Set up EXCSAVE[1] to point to the exc_table. */
movi a6 , e x c _ t a b l e
xsr a6 , E X C S A V E _ 1
/* init_arch kick-starts the linux kernel */
movi a4 , i n i t _ a r c h
callx4 a4
movi a4 , s t a r t _ k e r n e l
callx4 a4
should_never_return :
j s h o u l d _ n e v e r _ r e t u r n
2007-05-31 17:48:07 -07:00
/ *
* BSS s e c t i o n
* /
2009-09-20 18:14:14 -04:00
_ _ PAGE_ A L I G N E D _ B S S
2009-03-04 16:21:31 +01:00
# ifdef C O N F I G _ M M U
2007-05-31 17:48:07 -07:00
ENTRY( s w a p p e r _ p g _ d i r )
.fill PAGE_ S I Z E , 1 , 0
2009-03-04 16:21:31 +01:00
# endif
2007-05-31 17:48:07 -07:00
ENTRY( e m p t y _ z e r o _ p a g e )
.fill PAGE_ S I Z E , 1 , 0