blob: 6b0a33333319a5aed7ce8a97602bd54bceff349e [file] [log] [blame]
/*
* This file is part of the coreboot project.
*
* Copyright (C) 2016 Marvell, 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.
*/
#include <stddef.h>
#include <stdint.h>
#include <stdlib.h>
#include <arch/io.h>
#include <bootblock_common.h>
#include <console/console.h>
#include <timestamp.h>
#include <console/uart.h>
#include <soc/a2bus.h>
#include <soc/addressmap.h>
#include <soc/apmu.h>
#include <soc/bdb.h>
#include <soc/gic.h>
#include <soc/load_validate.h>
#include <soc/mcu.h>
#include <soc/pmic.h>
#include <soc/uart.h>
void bootblock_soc_early_init(void)
{
timestamp_add_now(TS_START_BOOTBLOCK);
asm volatile ("bl fiq_stack_init" : : : "r0", "r1");
enable_bcm_gic();
uart_num = 0;
}
void bootblock_soc_init(void)
{
struct bdb_pointer bdb_info;
u32 boot_path;
write32((void *)MVMAP2315_BOOTBLOCK_CB1, 0);
write32((void *)MVMAP2315_BOOTBLOCK_CB2, 0);
set_bdb_pointers((u8 *)MVMAP2315_BDB_LCM_BASE, &bdb_info);
printk(BIOS_DEBUG, "loading and validating APMU firmware.\n");
load_and_validate(&bdb_info, APMU_FIRMWARE);
apmu_start();
if (!(read32((void *)MVMAP2315_LOWPWR_REG) & MVMAP2315_LOWPWR_FLAG)) {
printk(BIOS_DEBUG, "loading and validating MCU firmware.\n");
load_and_validate(&bdb_info, MCU_FIRMWARE);
mcu_start();
boot_path = get_boot_path();
} else {
printk(BIOS_DEBUG, "Low power restart. Skip MCU code load.\n");
sned_hash_msg(GET_HASH);
receive_hash_msg_respond();
printk(BIOS_DEBUG,
"MCU hash validation not currently implemented\n");
boot_path = get_boot_path();
}
switch (boot_path) {
case NO_BOOT:
no_boot();
break;
case CHARGING_SCREEN:
charging_screen();
break;
case FULL_BOOT:
full_boot();
break;
}
printk(BIOS_DEBUG, "initializing the A2 bus.\n");
init_a2bus_config();
printk(BIOS_DEBUG, "Powering up the AP core0.\n");
ap_start((void *)MVMAP2315_ROMSTAGE_BASE);
/* initializing UART1 to free UART0 to be used by romstage */
uart_num = 1;
uart_init(uart_num);
while (read32((void *)MVMAP2315_BOOTBLOCK_CB1) != 0x4)
;
printk(BIOS_DEBUG, "loading and validating AP_RW firmware.\n");
load_and_validate(&bdb_info, AP_RW_FIRMWARE);
write32((void *)MVMAP2315_BOOTBLOCK_CB2, 0x4)
;
while (1)
;
}