blob: b7967b8577836f00e37328467219bd8183e75d1c [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Jacob Chen746070c2016-09-19 18:46:27 +08002/*
3 * (C) Copyright 2015 Rockchip Electronics Co., Ltd
Jacob Chen746070c2016-09-19 18:46:27 +08004 */
5
6#include <common.h>
7#include <clk.h>
8#include <dm.h>
9#include <ram.h>
Simon Glassf473eba2019-01-21 14:53:31 -070010#include <asm/gpio.h>
Jacob Chen746070c2016-09-19 18:46:27 +080011#include <asm/io.h>
Kever Yang9fbe17c2019-03-28 11:01:23 +080012#include <asm/arch-rockchip/clock.h>
13#include <asm/arch-rockchip/periph.h>
14#include <asm/arch-rockchip/grf_rk3036.h>
15#include <asm/arch-rockchip/boot_mode.h>
16#include <asm/arch-rockchip/sdram_rk3036.h>
Jacob Chen746070c2016-09-19 18:46:27 +080017
18DECLARE_GLOBAL_DATA_PTR;
19
Jacob Chenc95f3782016-09-19 18:46:28 +080020__weak int rk_board_late_init(void)
21{
22 return 0;
23}
24
25int board_late_init(void)
26{
27 setup_boot_mode();
28
29 return rk_board_late_init();
30}
31
Jacob Chen746070c2016-09-19 18:46:27 +080032int board_init(void)
33{
34 return 0;
35}
36
Kever Yang6c15a542017-06-23 16:11:06 +080037#if !CONFIG_IS_ENABLED(RAM)
38/*
39 * When CONFIG_RAM is enabled, the dram_init() function is implemented
40 * in sdram_common.c.
41 */
Jacob Chen746070c2016-09-19 18:46:27 +080042int dram_init(void)
43{
44 gd->ram_size = sdram_size();
45
46 return 0;
47}
Kever Yang6c15a542017-06-23 16:11:06 +080048#endif
Jacob Chen746070c2016-09-19 18:46:27 +080049
Trevor Woerner43ec7e02019-05-03 09:41:00 -040050#if !CONFIG_IS_ENABLED(SYS_DCACHE_OFF)
Jacob Chen746070c2016-09-19 18:46:27 +080051void enable_caches(void)
52{
53 /* Enable D-cache. I-cache is already enabled in start.S */
54 dcache_enable();
55}
56#endif
57
58#if defined(CONFIG_USB_GADGET) && defined(CONFIG_USB_GADGET_DWC2_OTG)
59#include <usb.h>
60#include <usb/dwc2_udc.h>
61
Kever Yang3f4a2a72019-07-22 20:02:00 +080062static struct dwc2_plat_otg_data otg_data = {
Jacob Chen746070c2016-09-19 18:46:27 +080063 .rx_fifo_sz = 512,
64 .np_tx_fifo_sz = 16,
65 .tx_fifo_sz = 128,
66};
67
68int board_usb_init(int index, enum usb_init_type init)
69{
70 int node;
71 const char *mode;
72 bool matched = false;
73 const void *blob = gd->fdt_blob;
74
75 /* find the usb_otg node */
76 node = fdt_node_offset_by_compatible(blob, -1,
Kever Yang3f4a2a72019-07-22 20:02:00 +080077 "snps,dwc2");
Jacob Chen746070c2016-09-19 18:46:27 +080078
79 while (node > 0) {
80 mode = fdt_getprop(blob, node, "dr_mode", NULL);
81 if (mode && strcmp(mode, "otg") == 0) {
82 matched = true;
83 break;
84 }
85
86 node = fdt_node_offset_by_compatible(blob, node,
Kever Yang3f4a2a72019-07-22 20:02:00 +080087 "snps,dwc2");
Jacob Chen746070c2016-09-19 18:46:27 +080088 }
89 if (!matched) {
90 debug("Not found usb_otg device\n");
91 return -ENODEV;
92 }
Kever Yang3f4a2a72019-07-22 20:02:00 +080093 otg_data.regs_otg = fdtdec_get_addr(blob, node, "reg");
Jacob Chen746070c2016-09-19 18:46:27 +080094
Kever Yang3f4a2a72019-07-22 20:02:00 +080095 return dwc2_udc_probe(&otg_data);
Jacob Chen746070c2016-09-19 18:46:27 +080096}
97
98int board_usb_cleanup(int index, enum usb_init_type init)
99{
100 return 0;
101}
102#endif