pmu_sram_cpus_on.S 910 Bytes
Newer Older
Tony Xie's avatar
Tony Xie committed
1
2
3
/*
 * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved.
 *
dp-arm's avatar
dp-arm committed
4
 * SPDX-License-Identifier: BSD-3-Clause
Tony Xie's avatar
Tony Xie committed
5
6
7
8
9
10
 */

#include <arch.h>
#include <asm_macros.S>
#include <platform_def.h>

Lin Huang's avatar
Lin Huang committed
11
12
13
14
15
16
17
	.globl pmu_cpuson_entrypoint
	.macro pmusram_entry_func _name
	.section .pmusram.entry, "ax"
	.type \_name, %function
	.cfi_startproc
	\_name:
	.endm
Tony Xie's avatar
Tony Xie committed
18

Lin Huang's avatar
Lin Huang committed
19
20
pmusram_entry_func pmu_cpuson_entrypoint

21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#if PSRAM_CHECK_WAKEUP_CPU
check_wake_cpus:
	mrs	x0, MPIDR_EL1
	and	x1, x0, #MPIDR_CPU_MASK
	and	x0, x0, #MPIDR_CLUSTER_MASK
	orr	x0, x0, x1

	/* primary_cpu */
	ldr	w1, boot_mpidr
	cmp	w0, w1
	b.eq	sys_wakeup

	/*
	 * If the core is not the primary cpu,
	 * force the core into wfe.
	 */
wfe_loop:
	wfe
	b	wfe_loop
sys_wakeup:
#endif

Lin Huang's avatar
Lin Huang committed
43
#if PSRAM_DO_DDR_RESUME
Tony Xie's avatar
Tony Xie committed
44
ddr_resume:
Lin Huang's avatar
Lin Huang committed
45
46
	ldr	x2, =__bl31_sram_stack_end
	mov     sp, x2
47
	bl	dmc_resume
Lin Huang's avatar
Lin Huang committed
48
#endif
49
	bl	sram_restore
Lin Huang's avatar
Lin Huang committed
50
51
sys_resume:
	bl	psci_entrypoint
Tony Xie's avatar
Tony Xie committed
52
endfunc pmu_cpuson_entrypoint