mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-07 18:58:56 +00:00
91caa3bb89
Add a new event which handles this function. Convert existing use of the function to use the new event instead. Make sure that EVENT is enabled by affected boards, by selecting it from the LAST_STAGE_INIT option. For x86, enable it by default since all boards need it. For controlcenterdc, inline the get_tpm() function and make sure the event is not built in SPL. Signed-off-by: Simon Glass <sjg@chromium.org>
218 lines
4.5 KiB
C
218 lines
4.5 KiB
C
// SPDX-License-Identifier: GPL-2.0+
|
|
/*
|
|
* Copyright 2020 Hitachi Power Grids. All rights reserved.
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <event.h>
|
|
#include <i2c.h>
|
|
#include <asm/io.h>
|
|
#include <asm/arch/immap_ls102xa.h>
|
|
#include <asm/arch/clock.h>
|
|
#include <asm/arch/fsl_serdes.h>
|
|
#include <asm/arch/ls102xa_devdis.h>
|
|
#include <asm/arch/ls102xa_soc.h>
|
|
#include <hwconfig.h>
|
|
#include <mmc.h>
|
|
#include <fsl_csu.h>
|
|
#include <fsl_esdhc.h>
|
|
#include <fsl_ifc.h>
|
|
#include <fsl_immap.h>
|
|
#include <netdev.h>
|
|
#include <fsl_mdio.h>
|
|
#include <tsec.h>
|
|
#include <fsl_sec.h>
|
|
#include <fsl_devdis.h>
|
|
#include <fsl_ddr.h>
|
|
#include <spl.h>
|
|
#include <fdt_support.h>
|
|
#include <fsl_qe.h>
|
|
#include <fsl_validate.h>
|
|
|
|
#include "../common/common.h"
|
|
#include "../common/qrio.h"
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
static uchar ivm_content[CONFIG_SYS_IVM_EEPROM_MAX_LEN];
|
|
|
|
int checkboard(void)
|
|
{
|
|
show_qrio();
|
|
|
|
return 0;
|
|
}
|
|
|
|
int dram_init(void)
|
|
{
|
|
return fsl_initdram();
|
|
}
|
|
|
|
int board_early_init_f(void)
|
|
{
|
|
struct ccsr_scfg *scfg = (struct ccsr_scfg *)CFG_SYS_FSL_SCFG_ADDR;
|
|
struct ccsr_gur __iomem *gur = (void *)CFG_SYS_FSL_GUTS_ADDR;
|
|
struct fsl_ifc ifc = {(void *)CFG_SYS_IFC_ADDR, (void *)NULL};
|
|
|
|
/* Disable unused MCK1 */
|
|
setbits_be32(&gur->ddrclkdr, 2);
|
|
|
|
/* IFC Global Configuration */
|
|
setbits_be32(&ifc.gregs->ifc_gcr, 12 << IFC_GCR_TBCTL_TRN_TIME_SHIFT);
|
|
setbits_be32(&ifc.gregs->ifc_ccr, IFC_CCR_CLK_DIV(3) |
|
|
IFC_CCR_INV_CLK_EN);
|
|
|
|
/* clear BD & FR bits for BE BD's and frame data */
|
|
clrbits_be32(&scfg->etsecdmamcr, SCFG_ETSECDMAMCR_LE_BD_FR);
|
|
out_be32(&scfg->etsecmcr, SCFG_ETSECCMCR_GE2_CLK125);
|
|
|
|
init_early_memctl_regs();
|
|
|
|
/* QRIO Configuration */
|
|
qrio_uprstreq(UPREQ_CORE_RST);
|
|
|
|
#if IS_ENABLED(CONFIG_TARGET_PG_WCOM_SELI8)
|
|
qrio_prstcfg(KM_LIU_RST, PRSTCFG_POWUP_UNIT_RST);
|
|
qrio_wdmask(KM_LIU_RST, true);
|
|
|
|
qrio_prstcfg(KM_PAXK_RST, PRSTCFG_POWUP_UNIT_RST);
|
|
qrio_wdmask(KM_PAXK_RST, true);
|
|
#endif
|
|
|
|
#if IS_ENABLED(CONFIG_TARGET_PG_WCOM_EXPU1)
|
|
qrio_prstcfg(WCOM_TMG_RST, PRSTCFG_POWUP_UNIT_RST);
|
|
qrio_wdmask(WCOM_TMG_RST, true);
|
|
|
|
qrio_prstcfg(WCOM_PHY_RST, PRSTCFG_POWUP_UNIT_RST);
|
|
qrio_prst(WCOM_PHY_RST, false, false);
|
|
|
|
qrio_prstcfg(WCOM_QSFP_RST, PRSTCFG_POWUP_UNIT_RST);
|
|
qrio_wdmask(WCOM_QSFP_RST, true);
|
|
|
|
qrio_prstcfg(WCOM_CLIPS_RST, PRSTCFG_POWUP_UNIT_RST);
|
|
qrio_prst(WCOM_CLIPS_RST, false, false);
|
|
#endif
|
|
|
|
/* deasset debug phy reset only if piggy is present */
|
|
qrio_prstcfg(KM_DBG_ETH_RST, PRSTCFG_POWUP_UNIT_CORE_RST);
|
|
qrio_prst(KM_DBG_ETH_RST, !qrio_get_pgy_pres_pin(), false);
|
|
|
|
i2c_deblock_gpio_cfg();
|
|
|
|
/* enable the Unit LED (red) & Boot LED (on) */
|
|
qrio_set_leds();
|
|
|
|
/* enable Application Buffer */
|
|
qrio_enable_app_buffer();
|
|
|
|
arch_soc_init();
|
|
|
|
return 0;
|
|
}
|
|
|
|
static int pg_wcom_misc_init_f(void)
|
|
{
|
|
if (IS_ENABLED(CONFIG_PG_WCOM_UBOOT_UPDATE_SUPPORTED))
|
|
check_for_uboot_update();
|
|
|
|
return 0;
|
|
}
|
|
EVENT_SPY_SIMPLE(EVT_MISC_INIT_F, pg_wcom_misc_init_f);
|
|
|
|
int board_init(void)
|
|
{
|
|
if (IS_ENABLED(CONFIG_SYS_FSL_ERRATUM_A010315))
|
|
erratum_a010315();
|
|
|
|
fsl_serdes_init();
|
|
|
|
ls102xa_smmu_stream_id_init();
|
|
|
|
u_qe_init();
|
|
|
|
return 0;
|
|
}
|
|
|
|
int board_late_init(void)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
int misc_init_r(void)
|
|
{
|
|
device_disable(devdis_tbl, ARRAY_SIZE(devdis_tbl));
|
|
|
|
ivm_read_eeprom(ivm_content, CONFIG_SYS_IVM_EEPROM_MAX_LEN,
|
|
CONFIG_PIGGY_MAC_ADDRESS_OFFSET);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int ft_board_setup(void *blob, struct bd_info *bd)
|
|
{
|
|
ft_cpu_setup(blob, bd);
|
|
|
|
if (IS_ENABLED(CONFIG_PCI))
|
|
ft_pci_setup(blob, bd);
|
|
|
|
return 0;
|
|
}
|
|
|
|
#if defined(CONFIG_POST)
|
|
int post_hotkeys_pressed(void)
|
|
{
|
|
/* DIC26_SELFTEST: QRIO, SLFTEST */
|
|
return qrio_get_selftest_pin();
|
|
}
|
|
|
|
/* POST word is located in the unused SCRATCHRW4 register */
|
|
#define CCSR_SCRATCHRW4_ADDR 0x1ee020c
|
|
|
|
ulong post_word_load(void)
|
|
{
|
|
void *addr = (void *)CCSR_SCRATCHRW4_ADDR;
|
|
return in_le32(addr);
|
|
}
|
|
|
|
void post_word_store(ulong value)
|
|
{
|
|
void *addr = (void *)CCSR_SCRATCHRW4_ADDR;
|
|
out_le32(addr, value);
|
|
}
|
|
|
|
int arch_memory_test_prepare(u32 *vstart, u32 *size, phys_addr_t *phys_offset)
|
|
{
|
|
/* Define only 1MiB range for mem_regions at the middle of the RAM */
|
|
/* For 1GiB range mem_regions takes approx. 4min */
|
|
*vstart = CFG_SYS_SDRAM_BASE + (gd->ram_size >> 1);
|
|
*size = 1 << 20;
|
|
return 0;
|
|
}
|
|
#endif
|
|
|
|
u8 flash_read8(void *addr)
|
|
{
|
|
return __raw_readb(addr + 1);
|
|
}
|
|
|
|
void flash_write16(u16 val, void *addr)
|
|
{
|
|
u16 shftval = (((val >> 8) & 0xff) | ((val << 8) & 0xff00));
|
|
|
|
__raw_writew(shftval, addr);
|
|
}
|
|
|
|
u16 flash_read16(void *addr)
|
|
{
|
|
u16 val = __raw_readw(addr);
|
|
|
|
return (((val) >> 8) & 0x00ff) | (((val) << 8) & 0xff00);
|
|
}
|
|
|
|
int hush_init_var(void)
|
|
{
|
|
ivm_analyze_eeprom(ivm_content, CONFIG_SYS_IVM_EEPROM_MAX_LEN);
|
|
return 0;
|
|
}
|
|
|
|
EVENT_SPY_SIMPLE(EVT_LAST_STAGE_INIT, set_km_env);
|