blob: 27fda3fc1d2171e1afce9a889ba42aa730c47997 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Andy Shevchenkod31315d2017-07-06 14:41:53 +03002/*
3 * Copyright (c) 2017 Intel Corporation
Andy Shevchenkod31315d2017-07-06 14:41:53 +03004 */
Simon Glass5e6201b2019-08-01 09:46:51 -06005#include <env.h>
Simon Glassa7b51302019-11-14 12:57:46 -07006#include <init.h>
Andy Shevchenkod31315d2017-07-06 14:41:53 +03007#include <mmc.h>
8#include <u-boot/md5.h>
Andy Shevchenkod31315d2017-07-06 14:41:53 +03009
10#include <asm/cache.h>
Andy Shevchenko5ea5c952019-06-25 23:52:04 +030011#include <asm/pmu.h>
Andy Shevchenkod31315d2017-07-06 14:41:53 +030012#include <asm/scu.h>
13#include <asm/u-boot-x86.h>
14
Andy Shevchenko5ea5c952019-06-25 23:52:04 +030015/* List of Intel Tangier LSSs */
16#define PMU_LSS_TANGIER_SDIO0_01 1
17
18int board_early_init_r(void)
19{
20 pmu_turn_power(PMU_LSS_TANGIER_SDIO0_01, true);
21 return 0;
22}
23
Andy Shevchenkod31315d2017-07-06 14:41:53 +030024static void assign_serial(void)
25{
26 struct mmc *mmc = find_mmc_device(0);
27 unsigned char ssn[16];
28 char usb0addr[18];
29 char serial[33];
30 int i;
31
32 if (!mmc)
33 return;
34
Raymond Maoc35e1a42024-10-03 14:50:17 -070035 md5_wd((unsigned char *)mmc->cid, sizeof(mmc->cid), ssn,
36 MD5_DEF_CHUNK_SZ);
Andy Shevchenkod31315d2017-07-06 14:41:53 +030037
38 snprintf(usb0addr, sizeof(usb0addr), "02:00:86:%02x:%02x:%02x",
39 ssn[13], ssn[14], ssn[15]);
Simon Glass6a38e412017-08-03 12:22:09 -060040 env_set("usb0addr", usb0addr);
Andy Shevchenkod31315d2017-07-06 14:41:53 +030041
42 for (i = 0; i < 16; i++)
43 snprintf(&serial[2 * i], 3, "%02x", ssn[i]);
Simon Glass6a38e412017-08-03 12:22:09 -060044 env_set("serial#", serial);
Andy Shevchenkod31315d2017-07-06 14:41:53 +030045
46#if defined(CONFIG_CMD_SAVEENV) && !defined(CONFIG_ENV_IS_NOWHERE)
Simon Glassd49b8892017-08-03 12:22:08 -060047 env_save();
Andy Shevchenkod31315d2017-07-06 14:41:53 +030048#endif
49}
50
51static void assign_hardware_id(void)
52{
53 struct ipc_ifwi_version v;
54 char hardware_id[4];
55 int ret;
56
57 ret = scu_ipc_command(IPCMSG_GET_FW_REVISION, 1, NULL, 0, (u32 *)&v, 4);
58 if (ret < 0)
59 printf("Can't retrieve hardware revision\n");
60
61 snprintf(hardware_id, sizeof(hardware_id), "%02X", v.hardware_id);
Simon Glass6a38e412017-08-03 12:22:09 -060062 env_set("hardware_id", hardware_id);
Andy Shevchenkod31315d2017-07-06 14:41:53 +030063
64#if defined(CONFIG_CMD_SAVEENV) && !defined(CONFIG_ENV_IS_NOWHERE)
Simon Glassd49b8892017-08-03 12:22:08 -060065 env_save();
Andy Shevchenkod31315d2017-07-06 14:41:53 +030066#endif
67}
68
69int board_late_init(void)
70{
Simon Glass64b723f2017-08-03 12:22:12 -060071 if (!env_get("serial#"))
Andy Shevchenkod31315d2017-07-06 14:41:53 +030072 assign_serial();
73
Simon Glass64b723f2017-08-03 12:22:12 -060074 if (!env_get("hardware_id"))
Andy Shevchenkod31315d2017-07-06 14:41:53 +030075 assign_hardware_id();
76
77 return 0;
78}