1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * (C) Copyright 2011, 2012, 2013
4  * Yuri Tikhonov, Emcraft Systems, yur@emcraft.com
5  * Alexander Potashev, Emcraft Systems, aspotashev@emcraft.com
6  * Vladimir Khusainov, Emcraft Systems, vlad@emcraft.com
7  * Pavel Boldin, Emcraft Systems, paboldin@emcraft.com
8  *
9  * (C) Copyright 2015
10  * Kamil Lulko, <kamil.lulko@gmail.com>
11  */
12 
13 #include <common.h>
14 #include <dm.h>
15 
16 #include <asm/io.h>
17 #include <asm/arch/stm32.h>
18 
19 DECLARE_GLOBAL_DATA_PTR;
20 
21 int dram_init(void)
22 {
23 	int rv;
24 	struct udevice *dev;
25 
26 	rv = uclass_get_device(UCLASS_RAM, 0, &dev);
27 	if (rv) {
28 		debug("DRAM init failed: %d\n", rv);
29 		return rv;
30 	}
31 
32 	if (fdtdec_setup_mem_size_base() != 0)
33 		rv = -EINVAL;
34 
35 	return rv;
36 }
37 
38 int dram_init_banksize(void)
39 {
40 	fdtdec_setup_memory_banksize();
41 
42 	return 0;
43 }
44 
45 u32 get_board_rev(void)
46 {
47 	return 0;
48 }
49 
50 int board_early_init_f(void)
51 {
52 	return 0;
53 }
54 
55 int board_init(void)
56 {
57 	gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100;
58 
59 	return 0;
60 }
61 
62 #ifdef CONFIG_MISC_INIT_R
63 int misc_init_r(void)
64 {
65 	char serialno[25];
66 	uint32_t u_id_low, u_id_mid, u_id_high;
67 
68 	if (!env_get("serial#")) {
69 		u_id_low  = readl(&STM32_U_ID->u_id_low);
70 		u_id_mid  = readl(&STM32_U_ID->u_id_mid);
71 		u_id_high = readl(&STM32_U_ID->u_id_high);
72 		sprintf(serialno, "%08x%08x%08x",
73 			u_id_high, u_id_mid, u_id_low);
74 		env_set("serial#", serialno);
75 	}
76 
77 	return 0;
78 }
79 #endif
80