2019-05-27 08:55:01 +02:00
/* SPDX-License-Identifier: GPL-2.0-or-later */
2007-09-22 00:44:38 +10:00
/ *
* This f i l e c o n t a i n s l o w l e v e l C P U s e t u p f u n c t i o n s .
* Valentine B a r s h a k < v b a r s h a k @ru.mvista.com>
* MontaVista S o f t w a r e , I n c ( c ) 2 0 0 7
*
2008-02-24 08:07:41 +11:00
* Based o n c p u _ s e t u p _ 6 x x c o d e b y
2007-09-22 00:44:38 +10:00
* Benjamin H e r r e n s c h m i d t < b e n h @kernel.crashing.org>
* /
# include < a s m / p r o c e s s o r . h >
# include < a s m / c p u t a b l e . h >
# include < a s m / p p c _ a s m . h >
2007-09-22 00:46:57 +10:00
_ GLOBAL( _ _ s e t u p _ c p u _ 4 4 0 e p )
b _ _ i n i t _ f p u _ 4 4 x
_ GLOBAL( _ _ s e t u p _ c p u _ 4 4 0 e p x )
2007-09-22 00:50:09 +10:00
mflr r4
bl _ _ i n i t _ f p u _ 4 4 x
bl _ _ p l b _ d i s a b l e _ w r p
2007-12-21 15:39:21 +11:00
bl _ _ f i x u p _ 4 4 0 A _ m c h e c k
2007-09-22 00:50:09 +10:00
mtlr r4
blr
_ GLOBAL( _ _ s e t u p _ c p u _ 4 4 0 g r x )
2007-12-04 13:02:18 -06:00
mflr r4
bl _ _ p l b _ d i s a b l e _ w r p
bl _ _ f i x u p _ 4 4 0 A _ m c h e c k
mtlr r4
blr
2008-02-24 08:07:41 +11:00
_ GLOBAL( _ _ s e t u p _ c p u _ 4 6 0 e x )
2008-06-11 07:52:40 -04:00
_ GLOBAL( _ _ s e t u p _ c p u _ 4 6 0 g t )
2009-02-05 13:31:36 +00:00
_ GLOBAL( _ _ s e t u p _ c p u _ 4 6 0 s x )
2010-09-13 13:26:11 +00:00
_ GLOBAL( _ _ s e t u p _ c p u _ a p m 8 2 1 x x )
2008-11-11 16:02:43 +00:00
mflr r4
bl _ _ i n i t _ f p u _ 4 4 x
bl _ _ f i x u p _ 4 4 0 A _ m c h e c k
mtlr r4
blr
2008-12-04 05:39:55 +00:00
_ GLOBAL( _ _ s e t u p _ c p u _ 4 4 0 x5 )
2007-12-21 15:39:21 +11:00
_ GLOBAL( _ _ s e t u p _ c p u _ 4 4 0 g x )
_ GLOBAL( _ _ s e t u p _ c p u _ 4 4 0 s p e )
b _ _ f i x u p _ 4 4 0 A _ m c h e c k
2007-09-22 00:50:09 +10:00
2007-09-22 00:46:57 +10:00
/* enable APU between CPU and FPU */
_ GLOBAL( _ _ i n i t _ f p u _ 4 4 x )
mfspr r3 ,S P R N _ C C R 0
/* Clear DAPUIB flag in CCR0 */
rlwinm r3 ,r3 ,0 ,1 2 ,1 0
mtspr S P R N _ C C R 0 ,r3
isync
blr
2007-09-22 00:50:09 +10:00
/ *
* Workaround f o r t h e i n c o r r e c t w r i t e t o D D R S D R A M e r r a t a .
* The w r i t e a d d r e s s c a n b e c o r r u p t e d d u r i n g w r i t e s t o
* DDR S D R A M w h e n w r i t e p i p e l i n i n g i s e n a b l e d o n P L B 0 .
* Disable w r i t e p i p e l i n i n g h e r e .
* /
# define D C R N _ P L B 4 A 0 _ A C R 0 x81
_ GLOBAL( _ _ p l b _ d i s a b l e _ w r p )
mfdcr r3 ,D C R N _ P L B 4 A 0 _ A C R
/* clear WRP bit in PLB4A0_ACR */
rlwinm r3 ,r3 ,0 ,8 ,6
mtdcr D C R N _ P L B 4 A 0 _ A C R ,r3
isync
blr