blob: 592f7728c02d5c72f0e842b61296ea5fbcf14012 [file] [log] [blame]
Simon Glassf1a6c762011-10-07 13:53:38 +00001/*
2 * Copyright (c) 2011 The Chromium OS Authors.
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02003 * SPDX-License-Identifier: GPL-2.0+
Simon Glassf1a6c762011-10-07 13:53:38 +00004 */
5
6#include <common.h>
Simon Glassfd173402014-02-27 13:26:13 -07007#include <cros_ec.h>
Simon Glassb4d70702014-02-26 15:59:25 -07008#include <dm.h>
Matthias Weisser0d3dd142011-11-29 12:16:40 +01009#include <os.h>
Joe Hershberger74961352015-04-21 13:57:18 -050010#include <asm/test.h>
Simon Glassb9ddbf42014-02-27 13:26:19 -070011#include <asm/u-boot-sandbox.h>
Matthias Weisser0d3dd142011-11-29 12:16:40 +010012
Simon Glassf1a6c762011-10-07 13:53:38 +000013/*
14 * Pointer to initial global data area
15 *
16 * Here we initialize it.
17 */
18gd_t *gd;
19
Simon Glassb4d70702014-02-26 15:59:25 -070020/* Add a simple GPIO device */
21U_BOOT_DEVICE(gpio_sandbox) = {
22 .name = "gpio_sandbox",
23};
24
Simon Glassf1a6c762011-10-07 13:53:38 +000025void flush_cache(unsigned long start, unsigned long size)
26{
27}
28
Thomas Chou7b059dc2015-10-30 15:35:52 +080029#ifndef CONFIG_TIMER
Joe Hershberger74961352015-04-21 13:57:18 -050030/* system timer offset in ms */
31static unsigned long sandbox_timer_offset;
32
33void sandbox_timer_add_offset(unsigned long offset)
34{
35 sandbox_timer_offset += offset;
36}
37
Rob Herring86bd4e82013-11-08 08:40:44 -060038unsigned long timer_read_counter(void)
Simon Glassf1a6c762011-10-07 13:53:38 +000039{
Joe Hershberger74961352015-04-21 13:57:18 -050040 return os_get_nsec() / 1000 + sandbox_timer_offset * 1000;
Simon Glassf1a6c762011-10-07 13:53:38 +000041}
Thomas Chou7b059dc2015-10-30 15:35:52 +080042#endif
Simon Glassf1a6c762011-10-07 13:53:38 +000043
Simon Glassf1a6c762011-10-07 13:53:38 +000044int dram_init(void)
45{
Simon Glass62cf9122013-04-26 02:53:43 +000046 gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
Simon Glassf1a6c762011-10-07 13:53:38 +000047 return 0;
48}
Simon Glassfd173402014-02-27 13:26:13 -070049
Simon Glassb9ddbf42014-02-27 13:26:19 -070050#ifdef CONFIG_BOARD_EARLY_INIT_F
51int board_early_init_f(void)
52{
53#ifdef CONFIG_VIDEO_SANDBOX_SDL
54 int ret;
55
56 ret = sandbox_lcd_sdl_early_init();
57 if (ret) {
58 puts("Could not init sandbox LCD emulation\n");
59 return ret;
60 }
61#endif
62
63 return 0;
64}
65#endif
66
Simon Glassfd173402014-02-27 13:26:13 -070067#ifdef CONFIG_BOARD_LATE_INIT
68int board_late_init(void)
69{
70 if (cros_ec_get_error()) {
71 /* Force console on */
72 gd->flags &= ~GD_FLG_SILENT;
73
74 printf("cros-ec communications failure %d\n",
75 cros_ec_get_error());
76 puts("\nPlease reset with Power+Refresh\n\n");
77 panic("Cannot init cros-ec device");
78 return -1;
79 }
80 return 0;
81}
82#endif