| // SPDX-License-Identifier: GPL-2.0+ |
| /* |
| * Copyright 2020 Hitachi Power Grids. All rights reserved. |
| */ |
| |
| #include <config.h> |
| #include <event.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(); |
| |
| /* |
| * Reset I2C bus. When the board is powercycled during a bus |
| * transfer it might hang; for details see doc/I2C_Edge_Conditions. |
| * Now run the AbortSequence() |
| */ |
| i2c_make_abort(); |
| |
| 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); |