summaryrefslogtreecommitdiff
path: root/board/rockchip/evb_px5/evb-px5.c
blob: 54e62dbb6e544ef5c4e69a0482be45027d45472c (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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/*
 * Copyright (c) 2017 Andy Yan
 *
 * SPDX-License-Identifier:     GPL-2.0+
 */
#include <common.h>
#include <asm/io.h>
#include <fdtdec.h>
#include <asm/arch/clock.h>
#include <asm/arch/grf_rk3368.h>

DECLARE_GLOBAL_DATA_PTR;

int mach_cpu_init(void)
{
	struct rk3368_pmu_grf *pmugrf;
	int node;

	node = fdt_node_offset_by_compatible(gd->fdt_blob, -1, "rockchip,rk3368-pmugrf");
	pmugrf = (struct rk3368_pmu_grf *)fdtdec_get_addr(gd->fdt_blob, node, "reg");

	rk_clrsetreg(&pmugrf->gpio0d_iomux,
		     GPIO0D0_MASK | GPIO0D1_MASK |
		     GPIO0D2_MASK | GPIO0D3_MASK,
		     GPIO0D0_GPIO << GPIO0D0_SHIFT |
		     GPIO0D1_GPIO << GPIO0D1_SHIFT |
		     GPIO0D2_UART4_SOUT << GPIO0D2_SHIFT |
		     GPIO0D3_UART4_SIN << GPIO0D3_SHIFT);
	return 0;
}

int board_init(void)
{
	return 0;
}

int dram_init(void)
{
	gd->ram_size = 0x40000000;

	return 0;
}

int dram_init_banksize(void)
{
	 /* Reserve 0x200000 for ATF bl31 */
	gd->bd->bi_dram[0].start = 0x200000;
	gd->bd->bi_dram[0].size = 0x3fe00000;

	return 0;
}