| 
									
										
										
										
											2010-02-11 21:56:07 +00:00
										 |  |  | /* | 
					
						
							| 
									
										
										
										
											2011-01-19 10:24:56 +00:00
										 |  |  |  *  linux/arch/arm/plat-versatile/headsmp.S | 
					
						
							| 
									
										
										
										
											2010-02-11 21:56:07 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  *  Copyright (c) 2003 ARM Limited | 
					
						
							|  |  |  |  *  All Rights Reserved | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or modify
 | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License version 2 as | 
					
						
							|  |  |  |  * published by the Free Software Foundation. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #include <linux/linkage.h> | 
					
						
							|  |  |  | #include <linux/init.h> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	__INIT | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							| 
									
										
										
										
											2011-01-19 10:24:56 +00:00
										 |  |  |  * Realview/Versatile Express specific entry point for secondary CPUs. | 
					
						
							|  |  |  |  * This provides a "holding pen" into which all secondary cores are held | 
					
						
							| 
									
										
										
										
											2010-02-11 21:56:07 +00:00
										 |  |  |  * until we're ready for them to initialise. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2011-01-19 10:24:56 +00:00
										 |  |  | ENTRY(versatile_secondary_startup) | 
					
						
							| 
									
										
										
										
											2010-02-11 21:56:07 +00:00
										 |  |  | 	mrc	p15, 0, r0, c0, c0, 5 | 
					
						
							| 
									
										
										
										
											2013-01-22 10:56:40 +00:00
										 |  |  | 	bic	r0, #0xff000000 | 
					
						
							| 
									
										
										
										
											2010-02-11 21:56:07 +00:00
										 |  |  | 	adr	r4, 1f | 
					
						
							|  |  |  | 	ldmia	r4, {r5, r6} | 
					
						
							|  |  |  | 	sub	r4, r4, r5 | 
					
						
							|  |  |  | 	add	r6, r6, r4 | 
					
						
							|  |  |  | pen:	ldr	r7, [r6] | 
					
						
							|  |  |  | 	cmp	r7, r0 | 
					
						
							|  |  |  | 	bne	pen | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* | 
					
						
							|  |  |  | 	 * we've been released from the holding pen: secondary_stack | 
					
						
							|  |  |  | 	 * should now contain the SVC stack for this core | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	b	secondary_startup | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-30 13:05:10 +01:00
										 |  |  | 	.align | 
					
						
							| 
									
										
										
										
											2010-02-11 21:56:07 +00:00
										 |  |  | 1:	.long	. | 
					
						
							|  |  |  | 	.long	pen_release
 | 
					
						
							| 
									
										
										
										
											2011-12-15 14:02:33 +00:00
										 |  |  | ENDPROC(versatile_secondary_startup) |