xref: /rk3399_ARM-atf/plat/arm/board/fvp/aarch64/fvp_helpers.S (revision c8f0c3f76caaaa110d50027d6e1635d88e30c464)
13fc4124cSDan Handley/*
23fc4124cSDan Handley * Copyright (c) 2013-2015, ARM Limited and Contributors. All rights reserved.
33fc4124cSDan Handley *
43fc4124cSDan Handley * Redistribution and use in source and binary forms, with or without
53fc4124cSDan Handley * modification, are permitted provided that the following conditions are met:
63fc4124cSDan Handley *
73fc4124cSDan Handley * Redistributions of source code must retain the above copyright notice, this
83fc4124cSDan Handley * list of conditions and the following disclaimer.
93fc4124cSDan Handley *
103fc4124cSDan Handley * Redistributions in binary form must reproduce the above copyright notice,
113fc4124cSDan Handley * this list of conditions and the following disclaimer in the documentation
123fc4124cSDan Handley * and/or other materials provided with the distribution.
133fc4124cSDan Handley *
143fc4124cSDan Handley * Neither the name of ARM nor the names of its contributors may be used
153fc4124cSDan Handley * to endorse or promote products derived from this software without specific
163fc4124cSDan Handley * prior written permission.
173fc4124cSDan Handley *
183fc4124cSDan Handley * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
193fc4124cSDan Handley * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
203fc4124cSDan Handley * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
213fc4124cSDan Handley * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
223fc4124cSDan Handley * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
233fc4124cSDan Handley * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
243fc4124cSDan Handley * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
253fc4124cSDan Handley * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
263fc4124cSDan Handley * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
273fc4124cSDan Handley * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
283fc4124cSDan Handley * POSSIBILITY OF SUCH DAMAGE.
293fc4124cSDan Handley */
303fc4124cSDan Handley
313fc4124cSDan Handley#include <arch.h>
323fc4124cSDan Handley#include <asm_macros.S>
333fc4124cSDan Handley#include <gic_v2.h>
343fc4124cSDan Handley#include <platform_def.h>
353fc4124cSDan Handley#include <v2m_def.h>
363fc4124cSDan Handley#include "../drivers/pwrc/fvp_pwrc.h"
373fc4124cSDan Handley#include "../fvp_def.h"
383fc4124cSDan Handley
393fc4124cSDan Handley	.globl	plat_secondary_cold_boot_setup
403fc4124cSDan Handley	.globl	platform_get_entrypoint
413fc4124cSDan Handley	.globl	platform_mem_init
423fc4124cSDan Handley	.globl	platform_is_primary_cpu
433fc4124cSDan Handley
443fc4124cSDan Handley	.macro	fvp_choose_gicmmap  param1, param2, x_tmp, w_tmp, res
453fc4124cSDan Handley	ldr	\x_tmp, =V2M_SYSREGS_BASE + V2M_SYS_ID
463fc4124cSDan Handley	ldr	\w_tmp, [\x_tmp]
473fc4124cSDan Handley	ubfx	\w_tmp, \w_tmp, #V2M_SYS_ID_BLD_SHIFT, #V2M_SYS_ID_BLD_LENGTH
483fc4124cSDan Handley	cmp	\w_tmp, #BLD_GIC_VE_MMAP
493fc4124cSDan Handley	csel	\res, \param1, \param2, eq
503fc4124cSDan Handley	.endm
513fc4124cSDan Handley
523fc4124cSDan Handley	/* -----------------------------------------------------
533fc4124cSDan Handley	 * void plat_secondary_cold_boot_setup (void);
543fc4124cSDan Handley	 *
553fc4124cSDan Handley	 * This function performs any platform specific actions
563fc4124cSDan Handley	 * needed for a secondary cpu after a cold reset e.g
573fc4124cSDan Handley	 * mark the cpu's presence, mechanism to place it in a
583fc4124cSDan Handley	 * holding pen etc.
593fc4124cSDan Handley	 * TODO: Should we read the PSYS register to make sure
603fc4124cSDan Handley	 * that the request has gone through.
613fc4124cSDan Handley	 * -----------------------------------------------------
623fc4124cSDan Handley	 */
633fc4124cSDan Handleyfunc plat_secondary_cold_boot_setup
643fc4124cSDan Handley	/* ---------------------------------------------
653fc4124cSDan Handley	 * Power down this cpu.
663fc4124cSDan Handley	 * TODO: Do we need to worry about powering the
673fc4124cSDan Handley	 * cluster down as well here. That will need
683fc4124cSDan Handley	 * locks which we won't have unless an elf-
693fc4124cSDan Handley	 * loader zeroes out the zi section.
703fc4124cSDan Handley	 * ---------------------------------------------
713fc4124cSDan Handley	 */
723fc4124cSDan Handley	mrs	x0, mpidr_el1
733fc4124cSDan Handley	ldr	x1, =PWRC_BASE
743fc4124cSDan Handley	str	w0, [x1, #PPOFFR_OFF]
753fc4124cSDan Handley
763fc4124cSDan Handley	/* ---------------------------------------------
773fc4124cSDan Handley	 * Deactivate the gic cpu interface as well
783fc4124cSDan Handley	 * ---------------------------------------------
793fc4124cSDan Handley	 */
803fc4124cSDan Handley	ldr	x0, =VE_GICC_BASE
813fc4124cSDan Handley	ldr	x1, =BASE_GICC_BASE
823fc4124cSDan Handley	fvp_choose_gicmmap	x0, x1, x2, w2, x1
833fc4124cSDan Handley	mov	w0, #(IRQ_BYP_DIS_GRP1 | FIQ_BYP_DIS_GRP1)
843fc4124cSDan Handley	orr	w0, w0, #(IRQ_BYP_DIS_GRP0 | FIQ_BYP_DIS_GRP0)
853fc4124cSDan Handley	str	w0, [x1, #GICC_CTLR]
863fc4124cSDan Handley
873fc4124cSDan Handley	/* ---------------------------------------------
883fc4124cSDan Handley	 * There is no sane reason to come out of this
893fc4124cSDan Handley	 * wfi so panic if we do. This cpu will be pow-
903fc4124cSDan Handley	 * ered on and reset by the cpu_on pm api
913fc4124cSDan Handley	 * ---------------------------------------------
923fc4124cSDan Handley	 */
933fc4124cSDan Handley	dsb	sy
943fc4124cSDan Handley	wfi
953fc4124cSDan Handleycb_panic:
963fc4124cSDan Handley	b	cb_panic
973fc4124cSDan Handleyendfunc plat_secondary_cold_boot_setup
983fc4124cSDan Handley
993fc4124cSDan Handley
1003fc4124cSDan Handley	/* -----------------------------------------------------
1013fc4124cSDan Handley	 * void platform_get_entrypoint (unsigned int mpid);
1023fc4124cSDan Handley	 *
1033fc4124cSDan Handley	 * Main job of this routine is to distinguish between
1043fc4124cSDan Handley	 * a cold and warm boot.
1053fc4124cSDan Handley	 * On a cold boot the secondaries first wait for the
1063fc4124cSDan Handley	 * platform to be initialized after which they are
1073fc4124cSDan Handley	 * hotplugged in. The primary proceeds to perform the
1083fc4124cSDan Handley	 * platform initialization.
1093fc4124cSDan Handley	 * On a warm boot, each cpu jumps to the address in its
1103fc4124cSDan Handley	 * mailbox.
1113fc4124cSDan Handley	 *
1123fc4124cSDan Handley	 * TODO: Not a good idea to save lr in a temp reg
1133fc4124cSDan Handley	 * TODO: PSYSR is a common register and should be
1143fc4124cSDan Handley	 * 	accessed using locks. Since its not possible
1153fc4124cSDan Handley	 * 	to use locks immediately after a cold reset
1163fc4124cSDan Handley	 * 	we are relying on the fact that after a cold
1173fc4124cSDan Handley	 * 	reset all cpus will read the same WK field
1183fc4124cSDan Handley	 * -----------------------------------------------------
1193fc4124cSDan Handley	 */
1203fc4124cSDan Handleyfunc platform_get_entrypoint
1213fc4124cSDan Handley	mov	x9, x30 // lr
1223fc4124cSDan Handley	mov	x2, x0
1233fc4124cSDan Handley	ldr	x1, =PWRC_BASE
1243fc4124cSDan Handley	str	w2, [x1, #PSYSR_OFF]
1253fc4124cSDan Handley	ldr	w2, [x1, #PSYSR_OFF]
126*c8f0c3f7SSoby Mathew	ubfx	w2, w2, #PSYSR_WK_SHIFT, #PSYSR_WK_WIDTH
1273fc4124cSDan Handley	cmp	w2, #WKUP_PPONR
1283fc4124cSDan Handley	beq	warm_reset
1293fc4124cSDan Handley	cmp	w2, #WKUP_GICREQ
1303fc4124cSDan Handley	beq	warm_reset
1313fc4124cSDan Handley	mov	x0, #0
1323fc4124cSDan Handley	b	exit
1333fc4124cSDan Handleywarm_reset:
1343fc4124cSDan Handley	/* ---------------------------------------------
1353fc4124cSDan Handley	 * A per-cpu mailbox is maintained in the tru-
1363fc4124cSDan Handley	 * sted DRAM. Its flushed out of the caches
1373fc4124cSDan Handley	 * after every update using normal memory so
1383fc4124cSDan Handley	 * its safe to read it here with SO attributes
1393fc4124cSDan Handley	 * ---------------------------------------------
1403fc4124cSDan Handley	 */
1413fc4124cSDan Handley	ldr	x10, =MBOX_BASE
1423fc4124cSDan Handley	bl	platform_get_core_pos
1433fc4124cSDan Handley	lsl	x0, x0, #ARM_CACHE_WRITEBACK_SHIFT
1443fc4124cSDan Handley	ldr	x0, [x10, x0]
1453fc4124cSDan Handley	cbz	x0, _panic
1463fc4124cSDan Handleyexit:
1473fc4124cSDan Handley	ret	x9
1483fc4124cSDan Handley_panic:	b	_panic
1493fc4124cSDan Handleyendfunc platform_get_entrypoint
1503fc4124cSDan Handley
1513fc4124cSDan Handley
1523fc4124cSDan Handley	/* -----------------------------------------------------
1533fc4124cSDan Handley	 * void platform_mem_init (void);
1543fc4124cSDan Handley	 *
1553fc4124cSDan Handley	 * Zero out the mailbox registers in the shared memory.
1563fc4124cSDan Handley	 * The mmu is turned off right now and only the primary can
1573fc4124cSDan Handley	 * ever execute this code. Secondaries will read the
1583fc4124cSDan Handley	 * mailboxes using SO accesses. In short, BL31 will
1593fc4124cSDan Handley	 * update the mailboxes after mapping the tzdram as
1603fc4124cSDan Handley	 * normal memory. It will flush its copy after update.
1613fc4124cSDan Handley	 * BL1 will always read the mailboxes with the MMU off
1623fc4124cSDan Handley	 * -----------------------------------------------------
1633fc4124cSDan Handley	 */
1643fc4124cSDan Handleyfunc platform_mem_init
1653fc4124cSDan Handley	ldr	x0, =MBOX_BASE
1663fc4124cSDan Handley	mov	w1, #PLATFORM_CORE_COUNT
1673fc4124cSDan Handleyloop:
1683fc4124cSDan Handley	str	xzr, [x0], #CACHE_WRITEBACK_GRANULE
1693fc4124cSDan Handley	subs	w1, w1, #1
1703fc4124cSDan Handley	b.gt	loop
1713fc4124cSDan Handley	ret
1723fc4124cSDan Handleyendfunc platform_mem_init
1733fc4124cSDan Handley
1743fc4124cSDan Handley
1753fc4124cSDan Handleyfunc platform_is_primary_cpu
1763fc4124cSDan Handley	and	x0, x0, #(MPIDR_CLUSTER_MASK | MPIDR_CPU_MASK)
1773fc4124cSDan Handley	cmp	x0, #FVP_PRIMARY_CPU
1783fc4124cSDan Handley	cset	x0, eq
1793fc4124cSDan Handley	ret
1803fc4124cSDan Handleyendfunc platform_is_primary_cpu
181