aboutsummaryrefslogtreecommitdiff
path: root/plat/rockchip/rk3399/drivers/m0/src/main.c
blob: 0ed818d2fe3bd949ed0a5328498a38b530890b0c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/*
 * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

#include <m0_param.h>
#include "rk3399_mcu.h"

__attribute__((noreturn)) void main(void)
{
	switch (mmio_read_32(PARAM_ADDR + PARAM_M0_FUNC)) {
	case M0_FUNC_SUSPEND:
		handle_suspend();
		break;
	case M0_FUNC_DRAM:
		handle_dram();
		break;
	default:
		break;
	}

	mmio_write_32(PARAM_ADDR + PARAM_M0_DONE, M0_DONE_FLAG);

	for (;;)
		__asm__ volatile ("wfi");
}