2006-03-27 14:58:25 +01:00
/ *
* linux/ a r c h / a r m / k e r n e l / h e a d - n o m m u . S
*
* Copyright ( C ) 1 9 9 4 - 2 0 0 2 R u s s e l l K i n g
* Copyright ( C ) 2 0 0 3 - 2 0 0 6 H y o k S . C h o i
*
* 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 .
*
* Common k e r n e l s t a r t u p c o d e ( n o n - p a g e d M M )
*
* /
# 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 >
# include < a s m / a s s e m b l e r . h >
# include < a s m / p t r a c e . h >
2006-05-05 15:11:14 +01:00
# include < a s m / a s m - o f f s e t s . h >
2012-03-28 18:30:01 +01:00
# include < a s m / c p15 . h >
2006-04-24 09:45:35 +01:00
# include < a s m / t h r e a d _ i n f o . h >
2010-05-21 18:06:41 +01:00
# include < a s m / v7 m . h >
2006-03-27 14:58:25 +01:00
/ *
* Kernel s t a r t u p e n t r y p o i n t .
* - - - - - - - - - - - - - - - - - - - - - - - - - - -
*
* This i s n o r m a l l y c a l l e d f r o m t h e d e c o m p r e s s o r c o d e . T h e r e q u i r e m e n t s
* are : MMU = o f f , D - c a c h e = o f f , I - c a c h e = d o n t c a r e , r0 = 0 ,
* r1 = m a c h i n e n r .
*
* See l i n u x / a r c h / a r m / t o o l s / m a c h - t y p e s f o r t h e c o m p l e t e l i s t o f m a c h i n e
* numbers f o r r1 .
*
* /
2011-07-13 15:53:30 +01:00
2009-10-02 16:32:46 -04:00
_ _ HEAD
2011-12-09 20:52:10 +01:00
# ifdef C O N F I G _ C P U _ T H U M B O N L Y
.thumb
ENTRY( s t e x t )
# else
.arm
2006-03-27 14:58:25 +01:00
ENTRY( s t e x t )
2011-07-13 15:53:30 +01:00
THUMB( a d r r9 , B S Y M ( 1 f ) ) @ Kernel is always entered in ARM.
THUMB( b x r9 ) @ If this is a Thumb-2 kernel,
THUMB( . t h u m b ) @ switch to Thumb now.
THUMB( 1 : )
2011-12-09 20:52:10 +01:00
# endif
2011-07-13 15:53:30 +01:00
2009-07-24 12:32:54 +01:00
setmode P S R _ F _ B I T | P S R _ I _ B I T | S V C _ M O D E , r9 @ ensure svc mode
2006-03-27 14:58:25 +01:00
@ and irqs disabled
2010-05-21 18:06:41 +01:00
# if d e f i n e d ( C O N F I G _ C P U _ C P 1 5 )
2006-03-27 14:58:25 +01:00
mrc p15 , 0 , r9 , c0 , c0 @ get processor id
2010-05-21 18:06:41 +01:00
# elif d e f i n e d ( C O N F I G _ C P U _ V 7 M )
ldr r9 , =BASEADDR_V7M_SCB
ldr r9 , [ r9 , V 7 M _ S C B _ C P U I D ]
# else
ldr r9 , =CONFIG_PROCESSOR_ID
2006-09-26 17:36:37 +09:00
# endif
2006-03-27 14:58:25 +01:00
bl _ _ l o o k u p _ p r o c e s s o r _ t y p e @ r5=procinfo r9=cpuid
movs r10 , r5 @ invalid processor (r5=0)?
beq _ _ e r r o r _ p @ yes, error 'p'
2012-02-28 11:50:32 +00:00
ldr r13 , =__mmap_switched @ address to jump to after
@ initialising sctlr
adr l r , B S Y M ( 1 f ) @ return (PIC) address
2009-07-24 12:32:54 +01:00
ARM( a d d p c , r10 , #P R O C I N F O _ I N I T F U N C )
THUMB( a d d r12 , r10 , #P R O C I N F O _ I N I T F U N C )
THUMB( m o v p c , r12 )
2012-02-28 11:50:32 +00:00
1 : b _ _ a f t e r _ p r o c _ i n i t
2008-08-28 11:22:32 +01:00
ENDPROC( s t e x t )
2006-03-27 14:58:25 +01:00
2012-02-28 11:50:32 +00:00
# ifdef C O N F I G _ S M P
_ _ CPUINIT
ENTRY( s e c o n d a r y _ s t a r t u p )
/ *
* Common e n t r y p o i n t f o r s e c o n d a r y C P U s .
*
* Ensure t h a t w e ' r e i n S V C m o d e , a n d I R Q s a r e d i s a b l e d . L o o k u p
* the p r o c e s s o r t y p e - t h e r e i s n o n e e d t o c h e c k t h e m a c h i n e t y p e
* as i t h a s a l r e a d y b e e n v a l i d a t e d b y t h e p r i m a r y p r o c e s s o r .
* /
setmode P S R _ F _ B I T | P S R _ I _ B I T | S V C _ M O D E , r9
# ifndef C O N F I G _ C P U _ C P 1 5
ldr r9 , =CONFIG_PROCESSOR_ID
# else
mrc p15 , 0 , r9 , c0 , c0 @ get processor id
# endif
bl _ _ l o o k u p _ p r o c e s s o r _ t y p e @ r5=procinfo r9=cpuid
movs r10 , r5 @ invalid processor?
beq _ _ e r r o r _ p @ yes, error 'p'
adr r4 , _ _ s e c o n d a r y _ d a t a
ldmia r4 , { r7 , r12 }
adr l r , B S Y M ( _ _ a f t e r _ p r o c _ i n i t ) @ return address
mov r13 , r12 @ __secondary_switched address
ARM( a d d p c , r10 , #P R O C I N F O _ I N I T F U N C )
THUMB( a d d r12 , r10 , #P R O C I N F O _ I N I T F U N C )
THUMB( m o v p c , r12 )
ENDPROC( s e c o n d a r y _ s t a r t u p )
ENTRY( _ _ s e c o n d a r y _ s w i t c h e d )
ldr s p , [ r7 , #8 ] @ set up the stack pointer
mov f p , #0
b s e c o n d a r y _ s t a r t _ k e r n e l
ENDPROC( _ _ s e c o n d a r y _ s w i t c h e d )
.type _ _ secondary_ d a t a , % o b j e c t
__secondary_data :
.long secondary_data
.long __secondary_switched
# endif / * C O N F I G _ S M P * /
2006-03-27 14:58:25 +01:00
/ *
* Set t h e C o n t r o l R e g i s t e r a n d R e a d t h e p r o c e s s I D .
* /
__after_proc_init :
2006-09-26 17:36:37 +09:00
# ifdef C O N F I G _ C P U _ C P 1 5
2009-07-24 12:34:59 +01:00
/ *
* CP1 5 s y s t e m c o n t r o l r e g i s t e r v a l u e r e t u r n e d i n r0 f r o m
* the C P U i n i t f u n c t i o n .
* /
2012-12-04 10:34:39 +01:00
# if d e f i n e d ( C O N F I G _ A L I G N M E N T _ T R A P ) & & _ _ L I N U X _ A R M _ A R C H _ _ < 6
2006-03-27 14:58:25 +01:00
orr r0 , r0 , #C R _ A
# else
bic r0 , r0 , #C R _ A
# endif
# ifdef C O N F I G _ C P U _ D C A C H E _ D I S A B L E
bic r0 , r0 , #C R _ C
# endif
# ifdef C O N F I G _ C P U _ B P R E D I C T _ D I S A B L E
bic r0 , r0 , #C R _ Z
# endif
# ifdef C O N F I G _ C P U _ I C A C H E _ D I S A B L E
bic r0 , r0 , #C R _ I
2006-09-28 21:46:34 +09:00
# endif
# ifdef C O N F I G _ C P U _ H I G H _ V E C T O R
orr r0 , r0 , #C R _ V
# else
bic r0 , r0 , #C R _ V
2006-03-27 14:58:25 +01:00
# endif
mcr p15 , 0 , r0 , c1 , c0 , 0 @ write control reg
2006-09-26 17:36:37 +09:00
# endif / * C O N F I G _ C P U _ C P 1 5 * /
2012-02-28 11:50:32 +00:00
mov p c , r13
2008-08-28 11:22:32 +01:00
ENDPROC( _ _ a f t e r _ p r o c _ i n i t )
2006-04-24 09:45:35 +01:00
.ltorg
2006-03-27 14:58:25 +01:00
# include " h e a d - c o m m o n . S "