blob: 97915f94c401187ea196f946581cf35a4a5283a5 [file] [log] [blame]
Aleksandar Gerasimovski91ee5472021-02-22 18:18:11 +00001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright 2020 Hitachi Power Grids. All rights reserved.
4 */
5
6#include <common.h>
7#include <i2c.h>
8#include <asm/io.h>
9#include <asm/arch/immap_ls102xa.h>
10#include <asm/arch/clock.h>
11#include <asm/arch/fsl_serdes.h>
12#include <asm/arch/ls102xa_devdis.h>
13#include <asm/arch/ls102xa_soc.h>
14#include <hwconfig.h>
15#include <mmc.h>
16#include <fsl_csu.h>
17#include <fsl_esdhc.h>
18#include <fsl_ifc.h>
19#include <fsl_immap.h>
20#include <netdev.h>
21#include <fsl_mdio.h>
22#include <tsec.h>
23#include <fsl_sec.h>
24#include <fsl_devdis.h>
25#include <fsl_ddr.h>
26#include <spl.h>
27#include <fdt_support.h>
28#include <fsl_qe.h>
29#include <fsl_validate.h>
30
31#include "../common/common.h"
32#include "../common/qrio.h"
33
34DECLARE_GLOBAL_DATA_PTR;
35
36static uchar ivm_content[CONFIG_SYS_IVM_EEPROM_MAX_LEN];
37
38int checkboard(void)
39{
40 show_qrio();
41
42 return 0;
43}
44
45int dram_init(void)
46{
47 return fsl_initdram();
48}
49
50int board_early_init_f(void)
51{
52 struct ccsr_scfg *scfg = (struct ccsr_scfg *)CONFIG_SYS_FSL_SCFG_ADDR;
53 struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
54 struct fsl_ifc ifc = {(void *)CONFIG_SYS_IFC_ADDR, (void *)NULL};
55
56 /* Disable unused MCK1 */
57 setbits_be32(&gur->ddrclkdr, 2);
58
59 /* IFC Global Configuration */
60 setbits_be32(&ifc.gregs->ifc_gcr, 12 << IFC_GCR_TBCTL_TRN_TIME_SHIFT);
61 setbits_be32(&ifc.gregs->ifc_ccr, IFC_CCR_CLK_DIV(3) |
62 IFC_CCR_INV_CLK_EN);
63
64 /* clear BD & FR bits for BE BD's and frame data */
65 clrbits_be32(&scfg->etsecdmamcr, SCFG_ETSECDMAMCR_LE_BD_FR);
66 out_be32(&scfg->etsecmcr, SCFG_ETSECCMCR_GE2_CLK125);
67
68 init_early_memctl_regs();
69
70 /* QRIO Configuration */
71 qrio_uprstreq(UPREQ_CORE_RST);
72
Aleksandar Gerasimovskia7fd6fa2021-06-08 14:16:28 +000073#if CONFIG_IS_ENABLED(TARGET_PG_WCOM_SELI8)
74 qrio_prstcfg(KM_LIU_RST, PRSTCFG_POWUP_UNIT_RST);
75 qrio_wdmask(KM_LIU_RST, true);
Aleksandar Gerasimovski91ee5472021-02-22 18:18:11 +000076
Aleksandar Gerasimovskia7fd6fa2021-06-08 14:16:28 +000077 qrio_prstcfg(KM_PAXK_RST, PRSTCFG_POWUP_UNIT_RST);
78 qrio_wdmask(KM_PAXK_RST, true);
79#endif
Aleksandar Gerasimovski91ee5472021-02-22 18:18:11 +000080
Aleksandar Gerasimovskia7fd6fa2021-06-08 14:16:28 +000081#if CONFIG_IS_ENABLED(TARGET_PG_WCOM_EXPU1)
82 qrio_prstcfg(WCOM_TMG_RST, PRSTCFG_POWUP_UNIT_RST);
83 qrio_wdmask(WCOM_TMG_RST, true);
84
85 qrio_prstcfg(WCOM_PHY_RST, PRSTCFG_POWUP_UNIT_RST);
86 qrio_prst(WCOM_PHY_RST, false, false);
87
88 qrio_prstcfg(WCOM_QSFP_RST, PRSTCFG_POWUP_UNIT_RST);
89 qrio_wdmask(WCOM_QSFP_RST, true);
90
91 qrio_prstcfg(WCOM_CLIPS_RST, PRSTCFG_POWUP_UNIT_RST);
92 qrio_prst(WCOM_CLIPS_RST, false, false);
93#endif
94 qrio_prstcfg(KM_DBG_ETH_RST, PRSTCFG_POWUP_UNIT_CORE_RST);
95 qrio_prst(KM_DBG_ETH_RST, false, false);
Aleksandar Gerasimovski91ee5472021-02-22 18:18:11 +000096
97 i2c_deblock_gpio_cfg();
98
99 arch_soc_init();
100
101 return 0;
102}
103
104int board_init(void)
105{
106 if (IS_ENABLED(CONFIG_SYS_FSL_ERRATUM_A010315))
107 erratum_a010315();
108
109 fsl_serdes_init();
110
111 ls102xa_smmu_stream_id_init();
112
113 u_qe_init();
114
115 return 0;
116}
117
118int board_late_init(void)
119{
120 return 0;
121}
122
123int misc_init_r(void)
124{
125 if (IS_ENABLED(CONFIG_FSL_DEVICE_DISABLE))
126 device_disable(devdis_tbl, ARRAY_SIZE(devdis_tbl));
127
128 ivm_read_eeprom(ivm_content, CONFIG_SYS_IVM_EEPROM_MAX_LEN,
129 CONFIG_PIGGY_MAC_ADDRESS_OFFSET);
130
131 return 0;
132}
133
134int ft_board_setup(void *blob, struct bd_info *bd)
135{
136 ft_cpu_setup(blob, bd);
137
138 if (IS_ENABLED(CONFIG_PCI))
139 ft_pci_setup(blob, bd);
140
141 return 0;
142}
143
Aleksandar Gerasimovski3aea3dd2021-06-08 14:17:34 +0000144#if defined(CONFIG_POST)
145int post_hotkeys_pressed(void)
146{
147 /* DIC26_SELFTEST: GPRTA0, GPA0 */
148 qrio_gpio_direction_input(QRIO_GPIO_A, 0);
149 return qrio_get_gpio(QRIO_GPIO_A, 0);
150}
151
152ulong post_word_load(void)
153{
154 /* POST word is located at the beginning of reserved physical RAM */
155 void *addr = (void *)(CONFIG_SYS_SDRAM_BASE +
156 gd->ram_size - CONFIG_KM_RESERVED_PRAM + 8);
157 return in_le32(addr);
158}
159
160void post_word_store(ulong value)
161{
162 /* POST word is located at the beginning of reserved physical RAM */
163 void *addr = (void *)(CONFIG_SYS_SDRAM_BASE +
164 gd->ram_size - CONFIG_KM_RESERVED_PRAM + 8);
165 out_le32(addr, value);
166}
167
168int arch_memory_test_prepare(u32 *vstart, u32 *size, phys_addr_t *phys_offset)
169{
170 /* Define only 1MiB range for mem_regions at the middle of the RAM */
171 /* For 1GiB range mem_regions takes approx. 4min */
172 *vstart = CONFIG_SYS_SDRAM_BASE + (gd->ram_size >> 1);
173 *size = 1 << 20;
174 return 0;
175}
176#endif
177
Aleksandar Gerasimovski91ee5472021-02-22 18:18:11 +0000178u8 flash_read8(void *addr)
179{
180 return __raw_readb(addr + 1);
181}
182
183void flash_write16(u16 val, void *addr)
184{
185 u16 shftval = (((val >> 8) & 0xff) | ((val << 8) & 0xff00));
186
187 __raw_writew(shftval, addr);
188}
189
190u16 flash_read16(void *addr)
191{
192 u16 val = __raw_readw(addr);
193
194 return (((val) >> 8) & 0x00ff) | (((val) << 8) & 0xff00);
195}
196
197int hush_init_var(void)
198{
199 ivm_analyze_eeprom(ivm_content, CONFIG_SYS_IVM_EEPROM_MAX_LEN);
200 return 0;
201}
202
203int last_stage_init(void)
204{
205 set_km_env();
206 return 0;
207}