| /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| |
| #include <bootmode.h> |
| #include <device/i2c_simple.h> |
| #include <soc/i2c.h> |
| #include <soc/reg_access.h> |
| #include <spi_flash.h> |
| #include <security/vboot/vboot_common.h> |
| #include <security/vboot/vbnv.h> |
| |
| #include "reg_access.h" |
| #include "gen1.h" |
| #include "gen2.h" |
| |
| int get_recovery_mode_switch(void) |
| { |
| return 0; |
| } |
| |
| int get_write_protect_state(void) |
| { |
| /* Not write protected */ |
| return 0; |
| } |
| |
| void verstage_mainboard_init(void) |
| { |
| const struct reg_script *script; |
| |
| /* Crypto Shield I2C Addresses: |
| * |
| * 0x29: AT97S3204T - TPM 1.2 |
| * 0x50: ATAES132 - AES-128 |
| * 0x60: ATECC108 - Elliptical Curve |
| * 0x64: ATSHA204 - SHA-256 |
| * 0x68: DS3231M - RTC |
| */ |
| |
| /* Determine the correct script for the board */ |
| if (CONFIG(GALILEO_GEN2)) |
| script = gen2_i2c_init; |
| else |
| /* Determine which I2C address is in use */ |
| script = (reg_legacy_gpio_read (R_QNC_GPIO_RGLVL_RESUME_WELL) |
| & GALILEO_DETERMINE_IOEXP_SLA_RESUMEWELL_GPIO) |
| ? gen1_i2c_0x20_init : gen1_i2c_0x21_init; |
| |
| /* Direct the I2C SDA and SCL signals to the Arduino connector */ |
| reg_script_run(script); |
| } |
| |
| void __weak vboot_platform_prepare_reboot(void) |
| { |
| const struct reg_script *script; |
| |
| /* Crypto Shield I2C Addresses: |
| * |
| * 0x29: AT97S3204T - TPM 1.2 |
| * 0x50: ATAES132 - AES-128 |
| * 0x60: ATECC108 - Elliptical Curve |
| * 0x64: ATSHA204 - SHA-256 |
| * 0x68: DS3231M - RTC |
| */ |
| |
| /* Determine the correct script for the board */ |
| if (CONFIG(GALILEO_GEN2)) |
| script = gen2_tpm_reset; |
| else |
| /* Determine which I2C address is in use */ |
| script = (reg_legacy_gpio_read (R_QNC_GPIO_RGLVL_RESUME_WELL) |
| & GALILEO_DETERMINE_IOEXP_SLA_RESUMEWELL_GPIO) |
| ? gen1_tpm_reset_0x20 : gen1_tpm_reset_0x21; |
| |
| /* Reset the TPM */ |
| reg_script_run(script); |
| } |
| |
| int vbnv_cmos_failed(void) |
| { |
| /* Indicate no failure until RTC failure bits are supported. */ |
| return 0; |
| } |