1b09bf723SIgor Grinberg /* 2b09bf723SIgor Grinberg * (C) Copyright 2014 CompuLab, Ltd. <www.compulab.co.il> 3b09bf723SIgor Grinberg * 4b09bf723SIgor Grinberg * Authors: Igor Grinberg <grinberg@compulab.co.il> 5b09bf723SIgor Grinberg * 6b09bf723SIgor Grinberg * SPDX-License-Identifier: GPL-2.0+ 7b09bf723SIgor Grinberg */ 8b09bf723SIgor Grinberg 9b09bf723SIgor Grinberg #include <common.h> 10b09bf723SIgor Grinberg #include <status_led.h> 11a8a78c74SIgor Grinberg #include <net.h> 12a8a78c74SIgor Grinberg #include <netdev.h> 13011f5c13SIgor Grinberg #include <usb.h> 14b09bf723SIgor Grinberg #include <mmc.h> 15b09bf723SIgor Grinberg #include <linux/compiler.h> 16011f5c13SIgor Grinberg #include <linux/usb/musb.h> 17b09bf723SIgor Grinberg 18b09bf723SIgor Grinberg #include <asm/io.h> 19b09bf723SIgor Grinberg #include <asm/arch/mem.h> 20b09bf723SIgor Grinberg #include <asm/arch/am35x_def.h> 21b09bf723SIgor Grinberg #include <asm/arch/mmc_host_def.h> 22b09bf723SIgor Grinberg #include <asm/arch/sys_proto.h> 23011f5c13SIgor Grinberg #include <asm/arch/musb.h> 24011f5c13SIgor Grinberg #include <asm/omap_musb.h> 25011f5c13SIgor Grinberg #include <asm/ehci-omap.h> 26b09bf723SIgor Grinberg 27b09bf723SIgor Grinberg #include "../common/common.h" 28a8a78c74SIgor Grinberg #include "../common/eeprom.h" 29b09bf723SIgor Grinberg 30b09bf723SIgor Grinberg DECLARE_GLOBAL_DATA_PTR; 31b09bf723SIgor Grinberg 32b09bf723SIgor Grinberg const omap3_sysinfo sysinfo = { 33b09bf723SIgor Grinberg DDR_DISCRETE, 34b09bf723SIgor Grinberg "CM-T3517 board", 35b09bf723SIgor Grinberg "NAND 128/512M", 36b09bf723SIgor Grinberg }; 37b09bf723SIgor Grinberg 38011f5c13SIgor Grinberg #ifdef CONFIG_USB_MUSB_AM35X 39011f5c13SIgor Grinberg static struct musb_hdrc_config cm_t3517_musb_config = { 40011f5c13SIgor Grinberg .multipoint = 1, 41011f5c13SIgor Grinberg .dyn_fifo = 1, 42011f5c13SIgor Grinberg .num_eps = 16, 43011f5c13SIgor Grinberg .ram_bits = 12, 44011f5c13SIgor Grinberg }; 45011f5c13SIgor Grinberg 46011f5c13SIgor Grinberg static struct omap_musb_board_data cm_t3517_musb_board_data = { 47011f5c13SIgor Grinberg .set_phy_power = am35x_musb_phy_power, 48011f5c13SIgor Grinberg .clear_irq = am35x_musb_clear_irq, 49011f5c13SIgor Grinberg .reset = am35x_musb_reset, 50011f5c13SIgor Grinberg }; 51011f5c13SIgor Grinberg 52011f5c13SIgor Grinberg static struct musb_hdrc_platform_data cm_t3517_musb_pdata = { 5395de1e2fSPaul Kocialkowski #if defined(CONFIG_USB_MUSB_HOST) 54011f5c13SIgor Grinberg .mode = MUSB_HOST, 5595de1e2fSPaul Kocialkowski #elif defined(CONFIG_USB_MUSB_GADGET) 56011f5c13SIgor Grinberg .mode = MUSB_PERIPHERAL, 57011f5c13SIgor Grinberg #else 5895de1e2fSPaul Kocialkowski #error "Please define either CONFIG_USB_MUSB_HOST or CONFIG_USB_MUSB_GADGET" 59011f5c13SIgor Grinberg #endif 60011f5c13SIgor Grinberg .config = &cm_t3517_musb_config, 61011f5c13SIgor Grinberg .power = 250, 62011f5c13SIgor Grinberg .platform_ops = &am35x_ops, 63011f5c13SIgor Grinberg .board_data = &cm_t3517_musb_board_data, 64011f5c13SIgor Grinberg }; 65011f5c13SIgor Grinberg 66011f5c13SIgor Grinberg static void cm_t3517_musb_init(void) 67011f5c13SIgor Grinberg { 68011f5c13SIgor Grinberg /* 69011f5c13SIgor Grinberg * Set up USB clock/mode in the DEVCONF2 register. 70011f5c13SIgor Grinberg * USB2.0 PHY reference clock is 13 MHz 71011f5c13SIgor Grinberg */ 72011f5c13SIgor Grinberg clrsetbits_le32(&am35x_scm_general_regs->devconf2, 73011f5c13SIgor Grinberg CONF2_REFFREQ | CONF2_OTGMODE | CONF2_PHY_GPIOMODE, 74011f5c13SIgor Grinberg CONF2_REFFREQ_13MHZ | CONF2_SESENDEN | 75011f5c13SIgor Grinberg CONF2_VBDTCTEN | CONF2_DATPOL); 76011f5c13SIgor Grinberg 77011f5c13SIgor Grinberg if (musb_register(&cm_t3517_musb_pdata, &cm_t3517_musb_board_data, 78011f5c13SIgor Grinberg (void *)AM35XX_IPSS_USBOTGSS_BASE)) 79011f5c13SIgor Grinberg printf("Failed initializing AM35x MUSB!\n"); 80011f5c13SIgor Grinberg } 81011f5c13SIgor Grinberg #else 82011f5c13SIgor Grinberg static inline void am3517_evm_musb_init(void) {} 83011f5c13SIgor Grinberg #endif 84011f5c13SIgor Grinberg 85b09bf723SIgor Grinberg int board_init(void) 86b09bf723SIgor Grinberg { 87b09bf723SIgor Grinberg gpmc_init(); /* in SRAM or SDRAM, finish GPMC */ 88b09bf723SIgor Grinberg 89b09bf723SIgor Grinberg /* boot param addr */ 90b09bf723SIgor Grinberg gd->bd->bi_boot_params = (OMAP34XX_SDRC_CS0 + 0x100); 91b09bf723SIgor Grinberg 92*2d8d190cSUri Mashiach #if defined(CONFIG_LED_STATUS) && defined(CONFIG_LED_STATUS_BOOT_ENABLE) 93*2d8d190cSUri Mashiach status_led_set(CONFIG_LED_STATUS_BOOT, CONFIG_LED_STATUS_ON); 94b09bf723SIgor Grinberg #endif 95b09bf723SIgor Grinberg 96011f5c13SIgor Grinberg cm_t3517_musb_init(); 97011f5c13SIgor Grinberg 98b09bf723SIgor Grinberg return 0; 99b09bf723SIgor Grinberg } 100b09bf723SIgor Grinberg 1010a57c037SDmitry Lifshitz /* 1020a57c037SDmitry Lifshitz * Routine: get_board_rev 1030a57c037SDmitry Lifshitz * Description: read system revision 1040a57c037SDmitry Lifshitz */ 1050a57c037SDmitry Lifshitz u32 get_board_rev(void) 1060a57c037SDmitry Lifshitz { 1070a57c037SDmitry Lifshitz return cl_eeprom_get_board_rev(CONFIG_SYS_I2C_EEPROM_BUS); 1080a57c037SDmitry Lifshitz }; 1090a57c037SDmitry Lifshitz 110b09bf723SIgor Grinberg int misc_init_r(void) 111b09bf723SIgor Grinberg { 112b09bf723SIgor Grinberg cl_print_pcb_info(); 113679f82c3SPaul Kocialkowski omap_die_id_display(); 114b09bf723SIgor Grinberg 115b09bf723SIgor Grinberg return 0; 116b09bf723SIgor Grinberg } 117b09bf723SIgor Grinberg 118b09bf723SIgor Grinberg #if defined(CONFIG_GENERIC_MMC) && !defined(CONFIG_SPL_BUILD) 119b09bf723SIgor Grinberg #define SB_T35_CD_GPIO 144 120b09bf723SIgor Grinberg #define SB_T35_WP_GPIO 59 121b09bf723SIgor Grinberg 122b09bf723SIgor Grinberg int board_mmc_init(bd_t *bis) 123b09bf723SIgor Grinberg { 124b09bf723SIgor Grinberg return omap_mmc_init(0, 0, 0, SB_T35_CD_GPIO, SB_T35_WP_GPIO); 125b09bf723SIgor Grinberg } 126b09bf723SIgor Grinberg #endif 127011f5c13SIgor Grinberg 128a8a78c74SIgor Grinberg #ifdef CONFIG_DRIVER_TI_EMAC 129a8a78c74SIgor Grinberg #define CONTROL_EFUSE_EMAC_LSB 0x48002380 130a8a78c74SIgor Grinberg #define CONTROL_EFUSE_EMAC_MSB 0x48002384 131a8a78c74SIgor Grinberg 132a8a78c74SIgor Grinberg static int am3517_get_efuse_enetaddr(u8 *enetaddr) 133a8a78c74SIgor Grinberg { 134a8a78c74SIgor Grinberg u32 lsb = __raw_readl(CONTROL_EFUSE_EMAC_LSB); 135a8a78c74SIgor Grinberg u32 msb = __raw_readl(CONTROL_EFUSE_EMAC_MSB); 136a8a78c74SIgor Grinberg 137a8a78c74SIgor Grinberg enetaddr[0] = (u8)((msb >> 16) & 0xff); 138a8a78c74SIgor Grinberg enetaddr[1] = (u8)((msb >> 8) & 0xff); 139a8a78c74SIgor Grinberg enetaddr[2] = (u8)(msb & 0xff); 140a8a78c74SIgor Grinberg enetaddr[3] = (u8)((lsb >> 16) & 0xff); 141a8a78c74SIgor Grinberg enetaddr[4] = (u8)((lsb >> 8) & 0xff); 142a8a78c74SIgor Grinberg enetaddr[5] = (u8)(lsb & 0xff); 143a8a78c74SIgor Grinberg 1440adb5b76SJoe Hershberger return is_valid_ethaddr(enetaddr); 145a8a78c74SIgor Grinberg } 146a8a78c74SIgor Grinberg 147a8a78c74SIgor Grinberg static inline int cm_t3517_init_emac(bd_t *bis) 148a8a78c74SIgor Grinberg { 149a8a78c74SIgor Grinberg int ret = cpu_eth_init(bis); 150a8a78c74SIgor Grinberg 151a8a78c74SIgor Grinberg if (ret > 0) 152a8a78c74SIgor Grinberg return ret; 153a8a78c74SIgor Grinberg 154a8a78c74SIgor Grinberg printf("Failed initializing EMAC! "); 155a8a78c74SIgor Grinberg return 0; 156a8a78c74SIgor Grinberg } 157a8a78c74SIgor Grinberg #else /* !CONFIG_DRIVER_TI_EMAC */ 158a8a78c74SIgor Grinberg static inline int am3517_get_efuse_enetaddr(u8 *enetaddr) { return 1; } 159a8a78c74SIgor Grinberg static inline int cm_t3517_init_emac(bd_t *bis) { return 0; } 160a8a78c74SIgor Grinberg #endif /* CONFIG_DRIVER_TI_EMAC */ 161a8a78c74SIgor Grinberg 162a8a78c74SIgor Grinberg /* 163a8a78c74SIgor Grinberg * Routine: handle_mac_address 164a8a78c74SIgor Grinberg * Description: prepare MAC address for on-board Ethernet. 165a8a78c74SIgor Grinberg */ 166a8a78c74SIgor Grinberg static int cm_t3517_handle_mac_address(void) 167a8a78c74SIgor Grinberg { 168a8a78c74SIgor Grinberg unsigned char enetaddr[6]; 169a8a78c74SIgor Grinberg int ret; 170a8a78c74SIgor Grinberg 171a8a78c74SIgor Grinberg ret = eth_getenv_enetaddr("ethaddr", enetaddr); 172a8a78c74SIgor Grinberg if (ret) 173a8a78c74SIgor Grinberg return 0; 174a8a78c74SIgor Grinberg 175e7a2447bSNikita Kiryanov ret = cl_eeprom_read_mac_addr(enetaddr, CONFIG_SYS_I2C_EEPROM_BUS); 176a8a78c74SIgor Grinberg if (ret) { 177a8a78c74SIgor Grinberg ret = am3517_get_efuse_enetaddr(enetaddr); 178a8a78c74SIgor Grinberg if (ret) 179a8a78c74SIgor Grinberg return ret; 180a8a78c74SIgor Grinberg } 181a8a78c74SIgor Grinberg 1820adb5b76SJoe Hershberger if (!is_valid_ethaddr(enetaddr)) 183a8a78c74SIgor Grinberg return -1; 184a8a78c74SIgor Grinberg 185a8a78c74SIgor Grinberg return eth_setenv_enetaddr("ethaddr", enetaddr); 186a8a78c74SIgor Grinberg } 187a8a78c74SIgor Grinberg 188a8a78c74SIgor Grinberg #define SB_T35_ETH_RST_GPIO 164 189a8a78c74SIgor Grinberg 190a8a78c74SIgor Grinberg /* 191a8a78c74SIgor Grinberg * Routine: board_eth_init 192a8a78c74SIgor Grinberg * Description: initialize module and base-board Ethernet chips 193a8a78c74SIgor Grinberg */ 194a8a78c74SIgor Grinberg int board_eth_init(bd_t *bis) 195a8a78c74SIgor Grinberg { 196a8a78c74SIgor Grinberg int rc = 0, rc1 = 0; 197a8a78c74SIgor Grinberg 198a8a78c74SIgor Grinberg rc1 = cm_t3517_handle_mac_address(); 199a8a78c74SIgor Grinberg if (rc1) 200a8a78c74SIgor Grinberg printf("No MAC address found! "); 201a8a78c74SIgor Grinberg 202a8a78c74SIgor Grinberg rc1 = cm_t3517_init_emac(bis); 203a8a78c74SIgor Grinberg if (rc1 > 0) 204a8a78c74SIgor Grinberg rc++; 205a8a78c74SIgor Grinberg 206a8a78c74SIgor Grinberg rc1 = cl_omap3_smc911x_init(0, 4, CONFIG_SMC911X_BASE, 207a8a78c74SIgor Grinberg NULL, SB_T35_ETH_RST_GPIO); 208a8a78c74SIgor Grinberg if (rc1 > 0) 209a8a78c74SIgor Grinberg rc++; 210a8a78c74SIgor Grinberg 211a8a78c74SIgor Grinberg return rc; 212a8a78c74SIgor Grinberg } 213a8a78c74SIgor Grinberg 214011f5c13SIgor Grinberg #ifdef CONFIG_USB_EHCI_OMAP 215011f5c13SIgor Grinberg static struct omap_usbhs_board_data cm_t3517_usbhs_bdata = { 216011f5c13SIgor Grinberg .port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, 217011f5c13SIgor Grinberg .port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, 218011f5c13SIgor Grinberg .port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, 219011f5c13SIgor Grinberg }; 220011f5c13SIgor Grinberg 221011f5c13SIgor Grinberg #define CM_T3517_USB_HUB_RESET_GPIO 152 222011f5c13SIgor Grinberg #define SB_T35_USB_HUB_RESET_GPIO 98 223011f5c13SIgor Grinberg 224011f5c13SIgor Grinberg int ehci_hcd_init(int index, enum usb_init_type init, 225011f5c13SIgor Grinberg struct ehci_hccr **hccr, struct ehci_hcor **hcor) 226011f5c13SIgor Grinberg { 227011f5c13SIgor Grinberg cl_usb_hub_init(CM_T3517_USB_HUB_RESET_GPIO, "cm-t3517 hub rst"); 228011f5c13SIgor Grinberg cl_usb_hub_init(SB_T35_USB_HUB_RESET_GPIO, "sb-t35 hub rst"); 229011f5c13SIgor Grinberg 230011f5c13SIgor Grinberg return omap_ehci_hcd_init(index, &cm_t3517_usbhs_bdata, hccr, hcor); 231011f5c13SIgor Grinberg } 232011f5c13SIgor Grinberg 233011f5c13SIgor Grinberg int ehci_hcd_stop(void) 234011f5c13SIgor Grinberg { 235011f5c13SIgor Grinberg cl_usb_hub_deinit(CM_T3517_USB_HUB_RESET_GPIO); 236011f5c13SIgor Grinberg cl_usb_hub_deinit(SB_T35_USB_HUB_RESET_GPIO); 237011f5c13SIgor Grinberg 238011f5c13SIgor Grinberg return omap_ehci_hcd_stop(); 239011f5c13SIgor Grinberg } 240011f5c13SIgor Grinberg #endif /* CONFIG_USB_EHCI_OMAP */ 241