4d244214ce
This moves PMIC_BUS from each mainboard's board.h file to a per- mainboard Kconfig variable. To prevent humans from forgetting to set a valid value, an invalid default is set in the rk3288 Kconfig and checked in rk808.c so that compilation will fail if the mainboard Kconfig does not override it. Originally, PMIC_BUS was only used by mainboard code as an argument to RK808 PMIC functions. To conform to the generic RTC API, however, the RK808 code needs to have the bus number globally defined somewhere since the rtc_get() and rtc_set() functions don't take any args. Since CONFIG_PMIC_BUS is globally visible, we no longer need to pass bus number to the PMIC functions. BUG=chrome-os-partner:34436 BRANCH=none TEST=built and booted on Pinky Signed-off-by: David Hendricks <dhendrix@chromium.org> Change-Id: I73783878e507b2e7b1526dd2f81cfbdf8f1e2a55 Reviewed-on: https://chromium-review.googlesource.com/240203 Reviewed-by: Julius Werner <jwerner@chromium.org> Reviewed-on: http://review.coreboot.org/9642 Tested-by: build bot (Jenkins) Reviewed-by: Marc Jones <marc.jones@se-eng.com>
80 lines
2.4 KiB
C
80 lines
2.4 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright 2014 Rockchip Inc.
|
|
* Copyright 2014 Google Inc.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; version 2 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include <arch/io.h>
|
|
#include <assert.h>
|
|
#include <bootblock_common.h>
|
|
#include <console/console.h>
|
|
#include <delay.h>
|
|
#include <reset.h>
|
|
#include <soc/clock.h>
|
|
#include <soc/i2c.h>
|
|
#include <soc/grf.h>
|
|
#include <soc/pmu.h>
|
|
#include <soc/rk808.h>
|
|
#include <soc/spi.h>
|
|
#include <vendorcode/google/chromeos/chromeos.h>
|
|
|
|
#include "board.h"
|
|
|
|
void bootblock_mainboard_early_init()
|
|
{
|
|
if (IS_ENABLED(CONFIG_CONSOLE_SERIAL_UART)) {
|
|
assert(CONFIG_CONSOLE_SERIAL_UART_ADDRESS == UART2_BASE);
|
|
writel(IOMUX_UART2, &rk3288_grf->iomux_uart2);
|
|
}
|
|
|
|
}
|
|
|
|
void bootblock_mainboard_init(void)
|
|
{
|
|
/* Up VDD_CPU (BUCK1) to 1.4V to support max CPU frequency (1.8GHz). */
|
|
setbits_le32(&rk3288_pmu->iomux_i2c0scl, IOMUX_I2C0SCL);
|
|
setbits_le32(&rk3288_pmu->iomux_i2c0sda, IOMUX_I2C0SDA);
|
|
assert(CONFIG_PMIC_BUS == 0); /* must correspond with IOMUX */
|
|
i2c_init(CONFIG_PMIC_BUS, 400*KHz);
|
|
|
|
/* Slowly raise to max CPU voltage to prevent overshoot */
|
|
rk808_configure_buck(1, 1200);
|
|
udelay(175);/* Must wait for voltage to stabilize,2mV/us */
|
|
rk808_configure_buck(1, 1400);
|
|
udelay(100);/* Must wait for voltage to stabilize,2mV/us */
|
|
rkclk_configure_cpu();
|
|
|
|
if (rkclk_was_watchdog_reset()) {
|
|
printk(BIOS_INFO, "Last reset was watchdog... rebooting via GPIO!\n");
|
|
hard_reset();
|
|
}
|
|
|
|
/* i2c1 for tpm */
|
|
writel(IOMUX_I2C1, &rk3288_grf->iomux_i2c1);
|
|
i2c_init(1, 400*KHz);
|
|
|
|
/* spi2 for firmware ROM */
|
|
writel(IOMUX_SPI2_CSCLK, &rk3288_grf->iomux_spi2csclk);
|
|
writel(IOMUX_SPI2_TXRX, &rk3288_grf->iomux_spi2txrx);
|
|
rockchip_spi_init(CONFIG_BOOT_MEDIA_SPI_BUS, 11*MHz);
|
|
|
|
/* spi0 for chrome ec */
|
|
writel(IOMUX_SPI0, &rk3288_grf->iomux_spi0);
|
|
rockchip_spi_init(CONFIG_EC_GOOGLE_CHROMEEC_SPI_BUS, 9*MHz);
|
|
|
|
setup_chromeos_gpios();
|
|
}
|