1 // SPDX-License-Identifier: GPL-2.0+
3 * Copyright (c) 2017 Intel Corporation
6 #include <dwc3-uboot.h>
8 #include <environment.h>
10 #include <u-boot/md5.h>
14 #include <linux/usb/gadget.h>
16 #include <asm/cache.h>
19 #include <asm/u-boot-x86.h>
21 /* List of Intel Tangier LSSs */
22 #define PMU_LSS_TANGIER_SDIO0_01 1
24 int board_early_init_r(void)
26 pmu_turn_power(PMU_LSS_TANGIER_SDIO0_01, true);
30 static struct dwc3_device dwc3_device_data = {
31 .maximum_speed = USB_SPEED_HIGH,
32 .base = CONFIG_SYS_USB_OTG_BASE,
33 .dr_mode = USB_DR_MODE_PERIPHERAL,
37 int usb_gadget_handle_interrupts(int controller_index)
39 dwc3_uboot_handle_interrupt(controller_index);
44 int board_usb_init(int index, enum usb_init_type init)
46 if (index == 0 && init == USB_INIT_DEVICE)
47 return dwc3_uboot_init(&dwc3_device_data);
51 int board_usb_cleanup(int index, enum usb_init_type init)
53 if (index == 0 && init == USB_INIT_DEVICE) {
54 dwc3_uboot_exit(index);
60 static void assign_serial(void)
62 struct mmc *mmc = find_mmc_device(0);
63 unsigned char ssn[16];
71 md5((unsigned char *)mmc->cid, sizeof(mmc->cid), ssn);
73 snprintf(usb0addr, sizeof(usb0addr), "02:00:86:%02x:%02x:%02x",
74 ssn[13], ssn[14], ssn[15]);
75 env_set("usb0addr", usb0addr);
77 for (i = 0; i < 16; i++)
78 snprintf(&serial[2 * i], 3, "%02x", ssn[i]);
79 env_set("serial#", serial);
81 #if defined(CONFIG_CMD_SAVEENV) && !defined(CONFIG_ENV_IS_NOWHERE)
86 static void assign_hardware_id(void)
88 struct ipc_ifwi_version v;
92 ret = scu_ipc_command(IPCMSG_GET_FW_REVISION, 1, NULL, 0, (u32 *)&v, 4);
94 printf("Can't retrieve hardware revision\n");
96 snprintf(hardware_id, sizeof(hardware_id), "%02X", v.hardware_id);
97 env_set("hardware_id", hardware_id);
99 #if defined(CONFIG_CMD_SAVEENV) && !defined(CONFIG_ENV_IS_NOWHERE)
104 int board_late_init(void)
106 if (!env_get("serial#"))
109 if (!env_get("hardware_id"))
110 assign_hardware_id();