blob: f3a1a19f2b658dae49b9ce386c6666fe7bf8e8fd [file] [log] [blame]
Simon Glass8fbf9922019-01-21 14:53:36 -07001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright 2018 Google
4 */
5
Alper Nebi Yasakf55f3882020-10-28 00:15:11 +03006#include <dm.h>
Simon Glass97589732020-05-10 11:40:02 -06007#include <init.h>
Alper Nebi Yasak437fa8d2021-12-24 16:43:43 +03008#include <asm/arch-rockchip/clock.h>
Simon Glass8fbf9922019-01-21 14:53:36 -07009
Simon Glass49c24a82024-09-29 19:49:47 -060010#ifdef CONFIG_XPL_BUILD
Simon Glass8fbf9922019-01-21 14:53:36 -070011/* provided to defeat compiler optimisation in board_init_f() */
12void gru_dummy_function(int i)
13{
14}
Kever Yangb22e9fd2019-07-22 19:59:41 +080015
16int board_early_init_f(void)
17{
Marty E. Plummerb20a8dac2021-12-24 16:43:46 +030018# if defined(CONFIG_TARGET_CHROMEBOOK_BOB) || defined(CONFIG_TARGET_CHROMEBOOK_KEVIN)
Kever Yangb22e9fd2019-07-22 19:59:41 +080019 int sum, i;
20
21 /*
22 * Add a delay and ensure that the compiler does not optimise this out.
23 * This is needed since the power rails tail a while to turn on, and
24 * we get garbage serial output otherwise.
25 */
26 sum = 0;
27 for (i = 0; i < 150000; i++)
28 sum += i;
29 gru_dummy_function(sum);
30#endif /* CONFIG_TARGET_CHROMEBOOK_BOB */
31
32 return 0;
33}
34#endif
Alper Nebi Yasakf55f3882020-10-28 00:15:11 +030035
Simon Glass49c24a82024-09-29 19:49:47 -060036#ifndef CONFIG_XPL_BUILD
Alper Nebi Yasakf55f3882020-10-28 00:15:11 +030037int board_early_init_r(void)
38{
39 struct udevice *clk;
40 int ret;
41
42 /*
43 * This init is done in SPL, but when chain-loading U-Boot SPL will
44 * have been skipped. Allow the clock driver to check if it needs
45 * setting up.
46 */
47 ret = uclass_get_device_by_driver(UCLASS_CLK,
Simon Glass65130cd2020-12-28 20:34:56 -070048 DM_DRIVER_GET(clk_rk3399), &clk);
Alper Nebi Yasakf55f3882020-10-28 00:15:11 +030049 if (ret) {
50 debug("%s: CLK init failed: %d\n", __func__, ret);
51 return ret;
52 }
53
54 return 0;
55}
56#endif