[PATCH V4 5/5] arm: mvebu: Added SMP support for Armada XP

Gregory CLEMENT gregory.clement at free-electrons.com
Wed Nov 21 03:49:29 EST 2012


On 11/20/2012 05:40 PM, Will Deacon wrote:
> On Mon, Nov 19, 2012 at 08:35:59PM +0000, Gregory CLEMENT wrote:
>> +/*
>> + * Armada XP specific entry point for secondary CPUs.
>> + * We add the CPU to the coherency fabric and then jump to secondary
>> + * startup
>> + */
>> +ENTRY(armada_xp_secondary_startup)
>> +
>> +	/* Read CPU id */
>> + 	mrc     p15, 0, r1, c0, c0, 5
>> +	and     r1, r1, #0xF
>> +
>> +	/* Add CPU to coherency fabric */
>> +
>> +	ldr     r0, = ARMADA_XP_CFB_BASE
>> +	mov	lr, pc
>> +	b	ll_set_cpu_coherent
>> +	b	secondary_startup
> 
> adr	lr, BSYM(secondary_startup)
> bl	ll_set_cpu_coherent

I will try it.

> 
> should let you get rid of the mov, b, b, although I think you could do
> better than that by making this function a prefix of ll_set_cpu_coherent:
> 
> ENTRY(armada_xp_secondary_startup)
> 	ldr     r0, =ARMADA_XP_CFB_BASE
> 	mrc     p15, 0, r1, c0, c0, 5
> 	and     r1, r1, #0xF
> 	adr	lr, BSYM(secondary_startup)
> 
> 	/* Fallthrough */
> 
> ENTRY(ll_set_cpu_coherent)
> ...
> ENDPROC(ll_set_cpu_coherent)
> ENDPROC(armada_xp_secondary_startup)
> 
> what do you think?
> 

I prefer to keep them separate, as we can use coherency without SMP.
That's why I create the coherency_ll.S file instead of putting everything
in this file.


> Will
> 


-- 
Gregory Clement, Free Electrons
Kernel, drivers, real-time and embedded Linux
development, consulting, training and support.
http://free-electrons.com


More information about the devicetree-discuss mailing list