2009-03-25 14:10:01 +03:00
/ *
* linux/ a r c h / a r m / m m / p r o c - f a52 6 . S : M M U f u n c t i o n s f o r F A 5 2 6
*
* Written b y : L u k e L e e
* Copyright ( C ) 2 0 0 5 F a r a d a y C o r p .
* Copyright ( C ) 2 0 0 8 - 2 0 0 9 P a u l i u s Z a l e c k a s < p a u l i u s . z a l e c k a s @teltonika.lt>
*
* 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 a s p u b l i s h e d b y
* the F r e e S o f t w a r e F o u n d a t i o n ; either version 2 of the License, or
* ( at y o u r o p t i o n ) a n y l a t e r v e r s i o n .
*
*
* These a r e t h e l o w l e v e l a s s e m b l e r f o r p e r f o r m i n g c a c h e a n d T L B
* functions o n t h e f a52 6 .
* /
# 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 / h w c a p . h >
# include < a s m / p g t a b l e - h w d e f . h >
# include < a s m / p g t a b l e . h >
# include < a s m / p a g e . h >
# include < a s m / p t r a c e . h >
# include < a s m / s y s t e m . h >
# include " p r o c - m a c r o s . S "
# define C A C H E _ D L I N E S I Z E 1 6
.text
/ *
* cpu_ f a52 6 _ p r o c _ i n i t ( )
* /
ENTRY( c p u _ f a52 6 _ p r o c _ i n i t )
mov p c , l r
/ *
* cpu_ f a52 6 _ p r o c _ f i n ( )
* /
ENTRY( c p u _ f a52 6 _ p r o c _ f i n )
stmfd s p ! , { l r }
mov i p , #P S R _ F _ B I T | P S R _ I _ B I T | S V C _ M O D E
msr c p s r _ c , i p
bl f a _ f l u s h _ k e r n _ c a c h e _ a l l
mrc p15 , 0 , r0 , c1 , c0 , 0 @ ctrl register
bic r0 , r0 , #0x1000 @ ...i............
bic r0 , r0 , #0x000e @ ............wca.
mcr p15 , 0 , r0 , c1 , c0 , 0 @ disable caches
nop
nop
ldmfd s p ! , { p c }
/ *
* cpu_ f a52 6 _ r e s e t ( l o c )
*
* Perform a s o f t r e s e t o f t h e s y s t e m . P u t t h e C P U i n t o t h e
* same s t a t e a s i t w o u l d b e i f i t h a d b e e n r e s e t , a n d b r a n c h
* to w h a t w o u l d b e t h e r e s e t v e c t o r .
*
* loc : location t o j u m p t o f o r s o f t r e s e t
* /
.align 4
ENTRY( c p u _ f a52 6 _ r e s e t )
/* TODO: Use CP8 if possible... */
mov i p , #0
mcr p15 , 0 , i p , c7 , c7 , 0 @ invalidate I,D caches
mcr p15 , 0 , i p , c7 , c10 , 4 @ drain WB
# ifdef C O N F I G _ M M U
mcr p15 , 0 , i p , c8 , c7 , 0 @ invalidate I & D TLBs
# endif
mrc p15 , 0 , i p , c1 , c0 , 0 @ ctrl register
bic i p , i p , #0x000f @ ............wcam
bic i p , i p , #0x1100 @ ...i...s........
bic i p , i p , #0x0800 @ BTB off
mcr p15 , 0 , i p , c1 , c0 , 0 @ ctrl register
nop
nop
mov p c , r0
/ *
* cpu_ f a52 6 _ d o _ i d l e ( )
* /
.align 4
ENTRY( c p u _ f a52 6 _ d o _ i d l e )
mcr p15 , 0 , r0 , c7 , c0 , 4 @ Wait for interrupt
mov p c , l r
ENTRY( c p u _ f a52 6 _ d c a c h e _ c l e a n _ a r e a )
1 : mcr p15 , 0 , r0 , c7 , c10 , 1 @ clean D entry
add r0 , r0 , #C A C H E _ D L I N E S I Z E
subs r1 , r1 , #C A C H E _ D L I N E S I Z E
bhi 1 b
mcr p15 , 0 , r0 , c7 , c10 , 4 @ drain WB
mov p c , l r
/* =============================== PageTable ============================== */
/ *
* cpu_ f a52 6 _ s w i t c h _ m m ( p g d )
*
* Set t h e t r a n s l a t i o n b a s e p o i n t e r t o b e a s d e s c r i b e d b y p g d .
*
* pgd : new p a g e t a b l e s
* /
.align 4
ENTRY( c p u _ f a52 6 _ s w i t c h _ m m )
# ifdef C O N F I G _ M M U
mov i p , #0
# ifdef C O N F I G _ C P U _ D C A C H E _ W R I T E T H R O U G H
mcr p15 , 0 , i p , c7 , c6 , 0 @ invalidate D cache
# else
mcr p15 , 0 , i p , c7 , c14 , 0 @ clean and invalidate whole D cache
# endif
mcr p15 , 0 , i p , c7 , c5 , 0 @ invalidate I cache
mcr p15 , 0 , i p , c7 , c5 , 6 @ invalidate BTB since mm changed
mcr p15 , 0 , i p , c7 , c10 , 4 @ data write barrier
mcr p15 , 0 , i p , c7 , c5 , 4 @ prefetch flush
mcr p15 , 0 , r0 , c2 , c0 , 0 @ load page table pointer
mcr p15 , 0 , i p , c8 , c7 , 0 @ invalidate UTLB
# endif
mov p c , l r
/ *
* cpu_ f a52 6 _ s e t _ p t e _ e x t ( p t e p , p t e , e x t )
*
* Set a P T E a n d f l u s h i t o u t
* /
.align 4
ENTRY( c p u _ f a52 6 _ s e t _ p t e _ e x t )
# ifdef C O N F I G _ M M U
armv3 _ s e t _ p t e _ e x t
mov r0 , r0
mcr p15 , 0 , r0 , c7 , c10 , 1 @ clean D entry
mov r0 , #0
mcr p15 , 0 , r0 , c7 , c10 , 4 @ drain WB
# endif
mov p c , l r
_ _ INIT
.type _ _ fa5 2 6 _ s e t u p , #f u n c t i o n
__fa526_setup :
/* On return of this routine, r0 must carry correct flags for CFG register */
mov r0 , #0
mcr p15 , 0 , r0 , c7 , c7 @ invalidate I,D caches on v4
mcr p15 , 0 , r0 , c7 , c10 , 4 @ drain write buffer on v4
# ifdef C O N F I G _ M M U
mcr p15 , 0 , r0 , c8 , c7 @ invalidate I,D TLBs on v4
# endif
mcr p15 , 0 , r0 , c7 , c5 , 5 @ invalidate IScratchpad RAM
mov r0 , #1
mcr p15 , 0 , r0 , c1 , c1 , 0 @ turn-on ECR
mov r0 , #0
mcr p15 , 0 , r0 , c7 , c5 , 6 @ invalidate BTB All
mcr p15 , 0 , r0 , c7 , c10 , 4 @ data write barrier
mcr p15 , 0 , r0 , c7 , c5 , 4 @ prefetch flush
mov r0 , #0x1f @ Domains 0, 1 = manager, 2 = client
mcr p15 , 0 , r0 , c3 , c0 @ load domain access register
mrc p15 , 0 , r0 , c1 , c0 @ get control register v4
ldr r5 , f a52 6 _ c r1 _ c l e a r
bic r0 , r0 , r5
ldr r5 , f a52 6 _ c r1 _ s e t
orr r0 , r0 , r5
mov p c , l r
.size _ _ fa5 2 6 _ s e t u p , . - _ _ f a52 6 _ s e t u p
/ *
* .RVI ZFRS BLDP W C A M
* . .11 1001 .111 1101
*
* /
.type fa5 2 6 _ c r1 _ c l e a r , #o b j e c t
.type fa5 2 6 _ c r1 _ s e t , #o b j e c t
fa526_cr1_clear :
.word 0x3f3f
fa526_cr1_set :
.word 0x397D
_ _ INITDATA
/ *
* Purpose : F u n c t i o n p o i n t e r s u s e d t o a c c e s s a b o v e f u n c t i o n s - a l l c a l l s
* come t h r o u g h t h e s e
* /
.type fa5 2 6 _ p r o c e s s o r _ f u n c t i o n s , #o b j e c t
fa526_processor_functions :
.word v4_early_abort
2009-09-25 16:39:47 +04:00
.word legacy_pabort
2009-03-25 14:10:01 +03:00
.word cpu_fa526_proc_init
.word cpu_fa526_proc_fin
.word cpu_fa526_reset
.word cpu_fa526_do_idle
.word cpu_fa526_dcache_clean_area
.word cpu_fa526_switch_mm
.word cpu_fa526_set_pte_ext
.size fa5 2 6 _ p r o c e s s o r _ f u n c t i o n s , . - f a52 6 _ p r o c e s s o r _ f u n c t i o n s
.section " .rodata "
.type cpu_ a r c h _ n a m e , #o b j e c t
cpu_arch_name :
.asciz " armv4 "
.size cpu_ a r c h _ n a m e , . - c p u _ a r c h _ n a m e
.type cpu_ e l f _ n a m e , #o b j e c t
cpu_elf_name :
.asciz " v4 "
.size cpu_ e l f _ n a m e , . - c p u _ e l f _ n a m e
.type cpu_ f a52 6 _ n a m e , #o b j e c t
cpu_fa526_name :
.asciz " FA5 2 6 "
.size cpu_ f a52 6 _ n a m e , . - c p u _ f a52 6 _ n a m e
.align
.section " .proc .info .init " , # alloc, #e x e c i n s t r
.type _ _ fa5 2 6 _ p r o c _ i n f o ,#o b j e c t
__fa526_proc_info :
.long 0x66015261
.long 0xff01fff1
.long PMD_TYPE_SECT | \
PMD_ S E C T _ B U F F E R A B L E | \
PMD_ S E C T _ C A C H E A B L E | \
PMD_ B I T 4 | \
PMD_ S E C T _ A P _ W R I T E | \
PMD_ S E C T _ A P _ R E A D
.long PMD_TYPE_SECT | \
PMD_ B I T 4 | \
PMD_ S E C T _ A P _ W R I T E | \
PMD_ S E C T _ A P _ R E A D
b _ _ f a52 6 _ s e t u p
.long cpu_arch_name
.long cpu_elf_name
.long HWCAP_SWP | HWCAP_ H A L F
.long cpu_fa526_name
.long fa526_processor_functions
.long fa_tlb_fns
.long fa_user_fns
.long fa_cache_fns
.size _ _ fa5 2 6 _ p r o c _ i n f o , . - _ _ f a52 6 _ p r o c _ i n f o