blob: 05e4d84460ae1e163721b80c7b33020129fcab89 [file] [log] [blame]
Dirk Eibach8fc40842019-03-29 10:18:19 +01001/*
2 * (C) Copyright 2015
3 * Dirk Eibach, Guntermann & Drunck GmbH, eibach@gdsys.de
4 *
5 * SPDX-License-Identifier: GPL-2.0+
6 */
7
Simon Glassed38aef2020-05-10 11:40:03 -06008#include <command.h>
Dirk Eibach8fc40842019-03-29 10:18:19 +01009#include <dm.h>
Simon Glass07dc93c2019-08-01 09:46:47 -060010#include <env.h>
Simon Glass1cedca12023-08-21 21:17:01 -060011#include <event.h>
Dirk Eibach8fc40842019-03-29 10:18:19 +010012#include <fdt_support.h>
13#include <fsl_esdhc.h>
Simon Glassa7b51302019-11-14 12:57:46 -070014#include <init.h>
Dirk Eibach8fc40842019-03-29 10:18:19 +010015#include <miiphy.h>
16#include <misc.h>
Simon Glass458b66a2020-11-05 06:32:05 -070017#include <sysinfo.h>
Dirk Eibach8fc40842019-03-29 10:18:19 +010018#include <tpm-v1.h>
19#include <video_osd.h>
Simon Glass3ba929a2020-10-30 21:38:53 -060020#include <asm/global_data.h>
Dirk Eibach8fc40842019-03-29 10:18:19 +010021
22#include "../common/ihs_mdio.h"
Simon Glass458b66a2020-11-05 06:32:05 -070023#include "../../../drivers/sysinfo/gazerbeam.h"
Dirk Eibach8fc40842019-03-29 10:18:19 +010024
25DECLARE_GLOBAL_DATA_PTR;
26
27struct ihs_mdio_info ihs_mdio_info[] = {
28 { .fpga = NULL, .name = "ihs0", .base = 0x58 },
29 { .fpga = NULL, .name = "ihs1", .base = 0x58 },
30};
31
32static int get_tpm(struct udevice **devp)
33{
34 int rc;
35
36 rc = uclass_first_device_err(UCLASS_TPM, devp);
37 if (rc) {
38 printf("Could not find TPM (ret=%d)\n", rc);
39 return CMD_RET_FAILURE;
40 }
41
42 return 0;
43}
44
45int board_early_init_r(void)
46{
Simon Glass458b66a2020-11-05 06:32:05 -070047 struct udevice *sysinfo;
Dirk Eibach8fc40842019-03-29 10:18:19 +010048 struct udevice *serdes;
49 int mc = 0;
50 int con = 0;
51
Michal Suchanek558e9f22022-10-12 21:58:04 +020052 if (sysinfo_get(&sysinfo)) {
Simon Glass458b66a2020-11-05 06:32:05 -070053 puts("Could not find sysinfo information device.\n");
Michal Suchanek558e9f22022-10-12 21:58:04 +020054 sysinfo = NULL;
55 }
Dirk Eibach8fc40842019-03-29 10:18:19 +010056
57 /* Initialize serdes */
Simon Glass458b66a2020-11-05 06:32:05 -070058 uclass_get_device_by_phandle(UCLASS_MISC, sysinfo, "serdes", &serdes);
Dirk Eibach8fc40842019-03-29 10:18:19 +010059
Simon Glass458b66a2020-11-05 06:32:05 -070060 if (sysinfo_detect(sysinfo))
Dirk Eibach8fc40842019-03-29 10:18:19 +010061 puts("Device information detection failed.\n");
62
Simon Glass458b66a2020-11-05 06:32:05 -070063 sysinfo_get_int(sysinfo, BOARD_MULTICHANNEL, &mc);
64 sysinfo_get_int(sysinfo, BOARD_VARIANT, &con);
Dirk Eibach8fc40842019-03-29 10:18:19 +010065
66 if (mc == 2 || mc == 1)
67 dev_disable_by_path("/immr@e0000000/i2c@3100/pca9698@22");
68
69 if (mc == 4) {
70 dev_disable_by_path("/immr@e0000000/i2c@3100/pca9698@20");
71 dev_enable_by_path("/localbus@e0005000/iocon_uart@2,0");
72 dev_enable_by_path("/fpga1bus");
73 }
74
75 if (mc == 2 || con == VAR_CON) {
76 dev_enable_by_path("/fpga0bus/fpga0_video1");
77 dev_enable_by_path("/fpga0bus/fpga0_iic_video1");
78 dev_enable_by_path("/fpga0bus/fpga0_axi_video1");
79 }
80
81 if (con == VAR_CON) {
82 dev_enable_by_path("/fpga0bus/fpga0_video0");
83 dev_enable_by_path("/fpga0bus/fpga0_iic_video0");
84 dev_enable_by_path("/fpga0bus/fpga0_axi_video0");
85 }
86
87 return 0;
88}
89
Simon Glass458b66a2020-11-05 06:32:05 -070090int checksysinfo(void)
Dirk Eibach8fc40842019-03-29 10:18:19 +010091{
Simon Glass458b66a2020-11-05 06:32:05 -070092 struct udevice *sysinfo;
Dirk Eibach8fc40842019-03-29 10:18:19 +010093 char *s = env_get("serial#");
94 int mc = 0;
95 int con = 0;
96
Michal Suchanek558e9f22022-10-12 21:58:04 +020097 if (sysinfo_get(&sysinfo)) {
Simon Glass458b66a2020-11-05 06:32:05 -070098 puts("Could not find sysinfo information device.\n");
Michal Suchanek558e9f22022-10-12 21:58:04 +020099 sysinfo = NULL;
100 }
Dirk Eibach8fc40842019-03-29 10:18:19 +0100101
Simon Glass458b66a2020-11-05 06:32:05 -0700102 sysinfo_get_int(sysinfo, BOARD_MULTICHANNEL, &mc);
103 sysinfo_get_int(sysinfo, BOARD_VARIANT, &con);
Dirk Eibach8fc40842019-03-29 10:18:19 +0100104
105 puts("Board: Gazerbeam ");
106 printf("%s ", mc == 4 ? "MC4" : mc == 2 ? "MC2" : "SC");
107 printf("%s", con == VAR_CON ? "CON" : "CPU");
108
109 if (s) {
110 puts(", serial# ");
111 puts(s);
112 }
113
114 puts("\n");
115
116 return 0;
117}
118
119static void display_osd_info(struct udevice *osd,
120 struct video_osd_info *osd_info)
121{
122 printf("OSD-%s: Digital-OSD version %01d.%02d, %d x %d characters\n",
123 osd->name, osd_info->major_version, osd_info->minor_version,
124 osd_info->width, osd_info->height);
125}
126
Simon Glass1cedca12023-08-21 21:17:01 -0600127static int last_stage_init(void)
Dirk Eibach8fc40842019-03-29 10:18:19 +0100128{
129 int fpga_hw_rev = 0;
130 int i;
Simon Glass458b66a2020-11-05 06:32:05 -0700131 struct udevice *sysinfo;
Dirk Eibach8fc40842019-03-29 10:18:19 +0100132 struct udevice *osd;
133 struct video_osd_info osd_info;
134 struct udevice *tpm;
135 int ret;
136
Michal Suchanek558e9f22022-10-12 21:58:04 +0200137 if (sysinfo_get(&sysinfo)) {
Simon Glass458b66a2020-11-05 06:32:05 -0700138 puts("Could not find sysinfo information device.\n");
Michal Suchanek558e9f22022-10-12 21:58:04 +0200139 sysinfo = NULL;
140 }
Dirk Eibach8fc40842019-03-29 10:18:19 +0100141
Simon Glass458b66a2020-11-05 06:32:05 -0700142 if (sysinfo) {
143 int res = sysinfo_get_int(sysinfo, BOARD_HWVERSION,
144 &fpga_hw_rev);
Dirk Eibach8fc40842019-03-29 10:18:19 +0100145
146 if (res)
Simon Glass458b66a2020-11-05 06:32:05 -0700147 printf("Could not determind FPGA HW revision (res = %d)\n",
148 res);
Dirk Eibach8fc40842019-03-29 10:18:19 +0100149 }
150
151 env_set_ulong("fpga_hw_rev", fpga_hw_rev);
152
153 ret = get_tpm(&tpm);
Simon Glass3b8692a2021-02-06 14:23:36 -0700154 if (ret || tpm_init(tpm) || tpm1_startup(tpm, TPM_ST_CLEAR) ||
155 tpm1_continue_self_test(tpm)) {
Dirk Eibach8fc40842019-03-29 10:18:19 +0100156 printf("TPM init failed\n");
157 }
158
159 if (fpga_hw_rev >= 4) {
160 for (i = 0; i < 4; i++) {
161 struct udevice *rxaui;
162 char name[8];
163
164 snprintf(name, sizeof(name), "rxaui%d", i);
165 /* Disable RXAUI polarity inversion */
Simon Glass458b66a2020-11-05 06:32:05 -0700166 ret = uclass_get_device_by_phandle(UCLASS_MISC, sysinfo,
167 name, &rxaui);
Dirk Eibach8fc40842019-03-29 10:18:19 +0100168 if (!ret)
169 misc_set_enabled(rxaui, false);
170 }
171 }
172
173 for (uclass_first_device(UCLASS_VIDEO_OSD, &osd);
174 osd;
175 uclass_next_device(&osd)) {
176 video_osd_get_info(osd, &osd_info);
177 display_osd_info(osd, &osd_info);
178 }
179
180 return 0;
181}
Simon Glass1cedca12023-08-21 21:17:01 -0600182EVENT_SPY_SIMPLE(EVT_LAST_STAGE_INIT, last_stage_init);
Dirk Eibach8fc40842019-03-29 10:18:19 +0100183
184#if defined(CONFIG_OF_BOARD_SETUP)
Masahiro Yamadaf7ed78b2020-06-26 15:13:33 +0900185int ft_board_setup(void *blob, struct bd_info *bd)
Dirk Eibach8fc40842019-03-29 10:18:19 +0100186{
187 ft_cpu_setup(blob, bd);
188 fsl_fdt_fixup_dr_usb(blob, bd);
189 fdt_fixup_esdhc(blob, bd);
190
191 return 0;
192}
193#endif