void bootblock_mainboard_init(void) { if (rkclk_was_watchdog_reset()) reboot_from_watchdog(); gpio_output(GPIO(0, B, 3), 1); /* Power LED */ /* 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(APLL_1800_MHZ); /* i2c1 for tpm */ write32(&rk3288_grf->iomux_i2c1, IOMUX_I2C1); i2c_init(1, 400*KHz); /* spi2 for firmware ROM */ write32(&rk3288_grf->iomux_spi2csclk, IOMUX_SPI2_CSCLK); write32(&rk3288_grf->iomux_spi2txrx, IOMUX_SPI2_TXRX); rockchip_spi_init(CONFIG_BOOT_MEDIA_SPI_BUS, 24750*KHz); setup_chromeos_gpios(); }
void bootblock_mainboard_init(void) { /* adjust gpio params when external voltage is 1.8V */ gpio_init(GPIO_EINT_1P8V); /* set i2c related gpio */ i2c_set_gpio_pinmux(); setup_chromeos_gpios(); if (board_id() < 4) mt6391_enable_reset_when_ap_resets(); }
void bootblock_mainboard_init(void) { /* adjust gpio params when external voltage is 1.8V */ gpio_init(GPIO_EINT_1P8V); /* set i2c related gpio */ i2c_set_gpio_pinmux(); mtk_spi_init(CONFIG_EC_GOOGLE_CHROMEEC_SPI_BUS, SPI_PAD1_MASK, 6*MHz); setup_chromeos_gpios(); if (board_id() < 4) mt6391_enable_reset_when_ap_resets(); }
void bootblock_mainboard_init(void) { /* Set pinmux and configure spi flashrom. */ write32(&rk3399_pmugrf->spi1_rxd, IOMUX_SPI1_RX); write32(&rk3399_pmugrf->spi1_csclktx, IOMUX_SPI1_CSCLKTX); rockchip_spi_init(CONFIG_BOOT_MEDIA_SPI_BUS, 24750*KHz); /* Set pinmux and configure EC SPI. */ write32(&rk3399_grf->iomux_spi5, IOMUX_SPI5); rockchip_spi_init(CONFIG_EC_GOOGLE_CHROMEEC_SPI_BUS, 3093750); if (IS_ENABLED(CONFIG_GRU_HAS_TPM2)) { /* Set pinmux and configure TPM SPI, which is not very fast. */ write32(&rk3399_grf->iomux_spi0, IOMUX_SPI0); rockchip_spi_init(CONFIG_DRIVER_TPM_SPI_BUS, 1500*KHz); } else { /* Set pinmux and configure TPM I2C */ write32(&rk3399_pmugrf->iomux_i2c0_scl, IOMUX_I2C0_SCL); write32(&rk3399_pmugrf->iomux_i2c0_sda, IOMUX_I2C0_SDA); i2c_init(0, 400*KHz); } setup_chromeos_gpios(); }