// SPDX-License-Identifier: GPL-2.0+ /* * Copyright 2020 Hitachi Power Grids. All rights reserved. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #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 CONFIG_IS_ENABLED(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 *ctx, struct event *event) { if (IS_ENABLED(CONFIG_PG_WCOM_UBOOT_UPDATE_SUPPORTED)) check_for_uboot_update(); return 0; } EVENT_SPY(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; } int last_stage_init(void) { set_km_env(); return 0; }