blob: aa93534ac680dc08246207a50dbc8075ef08a500 [file] [log] [blame]
Yuantian Tang92f18ff2019-04-10 16:43:34 +08001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright 2019 NXP
4 */
5
6#include <common.h>
7#include <malloc.h>
8#include <errno.h>
9#include <fsl_ddr.h>
10#include <asm/io.h>
11#include <hwconfig.h>
12#include <fdt_support.h>
13#include <linux/libfdt.h>
Simon Glass9d1f6192019-08-02 09:44:25 -060014#include <env_internal.h>
Yuantian Tang92f18ff2019-04-10 16:43:34 +080015#include <asm/arch-fsl-layerscape/soc.h>
Laurentiu Tudor01dc5472019-07-30 17:29:59 +030016#include <asm/arch-fsl-layerscape/fsl_icid.h>
Yuantian Tang92f18ff2019-04-10 16:43:34 +080017#include <i2c.h>
18#include <asm/arch/soc.h>
19#ifdef CONFIG_FSL_LS_PPA
20#include <asm/arch/ppa.h>
21#endif
22#include <fsl_immap.h>
23#include <netdev.h>
24
25#include <fdtdec.h>
26#include <miiphy.h>
27#include "../common/qixis.h"
Alex Marginean805b8592019-12-10 16:55:39 +020028#include "../drivers/net/fsl_enetc.h"
Yuantian Tang92f18ff2019-04-10 16:43:34 +080029
30DECLARE_GLOBAL_DATA_PTR;
31
Yuantian Tang473bbc42019-04-10 16:43:35 +080032int config_board_mux(void)
33{
34#if defined(CONFIG_TARGET_LS1028AQDS) && defined(CONFIG_FSL_QIXIS)
35 u8 reg;
36
37 reg = QIXIS_READ(brdcfg[13]);
38 /* Field| Function
39 * 7-6 | Controls I2C3 routing (net CFG_MUX_I2C3):
40 * I2C3 | 10= Routes {SCL, SDA} to CAN1 transceiver as {TX, RX}.
41 * 5-4 | Controls I2C4 routing (net CFG_MUX_I2C4):
42 * I2C4 |11= Routes {SCL, SDA} to CAN2 transceiver as {TX, RX}.
43 */
44 reg &= ~(0xf0);
45 reg |= 0xb0;
46 QIXIS_WRITE(brdcfg[13], reg);
47
48 reg = QIXIS_READ(brdcfg[15]);
49 /* Field| Function
50 * 7 | Controls the CAN1 transceiver (net CFG_CAN1_STBY):
51 * CAN1 | 0= CAN #1 transceiver enabled
52 * 6 | Controls the CAN2 transceiver (net CFG_CAN2_STBY):
53 * CAN2 | 0= CAN #2 transceiver enabled
54 */
55 reg &= ~(0xc0);
56 QIXIS_WRITE(brdcfg[15], reg);
57#endif
58 return 0;
59}
60
Yuantian Tang92f18ff2019-04-10 16:43:34 +080061int board_init(void)
62{
63#ifdef CONFIG_ENV_IS_NOWHERE
64 gd->env_addr = (ulong)&default_environment[0];
65#endif
66
Udit Agarwal383a6502019-09-30 10:16:57 +000067#ifdef CONFIG_FSL_CAAM
68 sec_init();
69#endif
70
Yuantian Tang92f18ff2019-04-10 16:43:34 +080071#ifdef CONFIG_FSL_LS_PPA
72 ppa_init();
73#endif
74
75#ifndef CONFIG_SYS_EARLY_PCI_INIT
76 pci_init();
77#endif
78
79#if defined(CONFIG_TARGET_LS1028ARDB)
80 u8 val = I2C_MUX_CH_DEFAULT;
81
Chuanhua Haneaf4a7c2019-07-10 21:16:49 +080082#ifndef CONFIG_DM_I2C
Yuantian Tang92f18ff2019-04-10 16:43:34 +080083 i2c_write(I2C_MUX_PCA_ADDR_PRI, 0x0b, 1, &val, 1);
Chuanhua Haneaf4a7c2019-07-10 21:16:49 +080084#else
85 struct udevice *dev;
86
87 if (!i2c_get_chip_for_busnum(0, I2C_MUX_PCA_ADDR_PRI, 1, &dev))
88 dm_i2c_write(dev, 0x0b, &val, 1);
89#endif
Wen He41e63db2019-11-18 13:26:09 +080090#endif
91
92#if defined(CONFIG_TARGET_LS1028ARDB)
93 u8 reg;
Chuanhua Haneaf4a7c2019-07-10 21:16:49 +080094
Wen He41e63db2019-11-18 13:26:09 +080095 reg = QIXIS_READ(brdcfg[4]);
96 /*
97 * Field | Function
98 * 3 | DisplayPort Power Enable (net DP_PWR_EN):
99 * DPPWR | 0= DP_PWR is enabled.
100 */
101 reg &= ~(DP_PWD_EN_DEFAULT_MASK);
102 QIXIS_WRITE(brdcfg[4], reg);
Yuantian Tang92f18ff2019-04-10 16:43:34 +0800103#endif
104 return 0;
105}
106
107int board_eth_init(bd_t *bis)
108{
109 return pci_eth_init(bis);
110}
111
Alex Margineanf57e45a2020-01-11 01:05:39 +0200112#ifdef CONFIG_MISC_INIT_R
113int misc_init_r(void)
Yuantian Tang473bbc42019-04-10 16:43:35 +0800114{
115 config_board_mux();
116
117 return 0;
118}
119#endif
120
Yuantian Tang92f18ff2019-04-10 16:43:34 +0800121int board_early_init_f(void)
122{
123#ifdef CONFIG_SYS_I2C_EARLY_INIT
124 i2c_early_init_f();
125#endif
126
127 fsl_lsch3_early_init_f();
128 return 0;
129}
130
131void detail_board_ddr_info(void)
132{
133 puts("\nDDR ");
134 print_size(gd->bd->bi_dram[0].size + gd->bd->bi_dram[1].size, "");
135 print_ddr_info(0);
136}
137
138#ifdef CONFIG_OF_BOARD_SETUP
139int ft_board_setup(void *blob, bd_t *bd)
140{
141 u64 base[CONFIG_NR_DRAM_BANKS];
142 u64 size[CONFIG_NR_DRAM_BANKS];
143
144 ft_cpu_setup(blob, bd);
145
146 /* fixup DT for the two GPP DDR banks */
147 base[0] = gd->bd->bi_dram[0].start;
148 size[0] = gd->bd->bi_dram[0].size;
149 base[1] = gd->bd->bi_dram[1].start;
150 size[1] = gd->bd->bi_dram[1].size;
151
152#ifdef CONFIG_RESV_RAM
153 /* reduce size if reserved memory is within this bank */
154 if (gd->arch.resv_ram >= base[0] &&
155 gd->arch.resv_ram < base[0] + size[0])
156 size[0] = gd->arch.resv_ram - base[0];
157 else if (gd->arch.resv_ram >= base[1] &&
158 gd->arch.resv_ram < base[1] + size[1])
159 size[1] = gd->arch.resv_ram - base[1];
160#endif
161
162 fdt_fixup_memory_banks(blob, base, size, 2);
163
Laurentiu Tudor01dc5472019-07-30 17:29:59 +0300164 fdt_fixup_icid(blob);
165
Alex Marginean805b8592019-12-10 16:55:39 +0200166#ifdef CONFIG_FSL_ENETC
167 fdt_fixup_enetc_mac(blob);
168#endif
169
Yuantian Tang92f18ff2019-04-10 16:43:34 +0800170 return 0;
171}
172#endif
173
174#ifdef CONFIG_FSL_QIXIS
175int checkboard(void)
176{
177#ifdef CONFIG_TFABOOT
178 enum boot_src src = get_boot_src();
179#endif
180 u8 sw;
181
182 int clock;
183 char *board;
184 char buf[64] = {0};
185 static const char *freq[6] = {"100.00", "125.00", "156.25",
186 "161.13", "322.26", "100.00 SS"};
187
188 cpu_name(buf);
189 /* find the board details */
190 sw = QIXIS_READ(id);
191
192 switch (sw) {
193 case 0x46:
194 board = "QDS";
195 break;
196 case 0x47:
197 board = "RDB";
198 break;
199 case 0x49:
200 board = "HSSI";
201 break;
202 default:
203 board = "unknown";
204 break;
205 }
206
207 sw = QIXIS_READ(arch);
208 printf("Board: %s-%s, Version: %c, boot from ",
209 buf, board, (sw & 0xf) + 'A' - 1);
210
211 sw = QIXIS_READ(brdcfg[0]);
212 sw = (sw & QIXIS_LBMAP_MASK) >> QIXIS_LBMAP_SHIFT;
213
214#ifdef CONFIG_TFABOOT
215 if (src == BOOT_SOURCE_SD_MMC) {
216 puts("SD\n");
217 } else if (src == BOOT_SOURCE_SD_MMC2) {
218 puts("eMMC\n");
219 } else {
220#endif
221#ifdef CONFIG_SD_BOOT
222 puts("SD\n");
223#elif defined(CONFIG_EMMC_BOOT)
224 puts("eMMC\n");
225#else
226 switch (sw) {
227 case 0:
228 case 4:
229 printf("NOR\n");
230 break;
231 case 1:
232 printf("NAND\n");
233 break;
234 default:
235 printf("invalid setting of SW%u\n", QIXIS_LBMAP_SWITCH);
236 break;
237 }
238#endif
239#ifdef CONFIG_TFABOOT
240 }
241#endif
242
243 printf("FPGA: v%d (%s)\n", QIXIS_READ(scver), board);
244 puts("SERDES1 Reference : ");
245
246 sw = QIXIS_READ(brdcfg[2]);
247#ifdef CONFIG_TARGET_LS1028ARDB
248 clock = (sw >> 6) & 3;
249#else
250 clock = (sw >> 4) & 0xf;
251#endif
252
253 printf("Clock1 = %sMHz ", freq[clock]);
254#ifdef CONFIG_TARGET_LS1028ARDB
255 clock = (sw >> 4) & 3;
256#else
257 clock = sw & 0xf;
258#endif
259 printf("Clock2 = %sMHz\n", freq[clock]);
260
261 return 0;
262}
263#endif