blob: e35a3e3a704e122ca381eae766dbe9e78f2cc565 [file] [log] [blame]
Chandan Nath5289e832011-10-14 02:58:26 +00001/*
2 * board.c
3 *
4 * Common board functions for AM33XX based boards
5 *
6 * Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of
11 * the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR /PURPOSE. See the
16 * GNU General Public License for more details.
17 */
18
19#include <common.h>
Tom Rini973b6632012-07-30 16:13:10 -070020#include <errno.h>
Tom Rini47f7bca2012-08-13 12:03:19 -070021#include <spl.h>
Chandan Nath5289e832011-10-14 02:58:26 +000022#include <asm/arch/cpu.h>
23#include <asm/arch/hardware.h>
Chandan Nath8a8f0842012-01-09 20:38:59 +000024#include <asm/arch/omap.h>
Chandan Nath5289e832011-10-14 02:58:26 +000025#include <asm/arch/ddr_defs.h>
26#include <asm/arch/clock.h>
Steve Sakoman3b971522012-06-04 05:35:34 +000027#include <asm/arch/gpio.h>
Ilya Yanok8eb16b72012-11-06 13:06:30 +000028#include <asm/arch/mem.h>
Chandan Nath8a8f0842012-01-09 20:38:59 +000029#include <asm/arch/mmc_host_def.h>
Tom Rinidb7dd812012-07-31 10:50:01 -070030#include <asm/arch/sys_proto.h>
Chandan Nath5289e832011-10-14 02:58:26 +000031#include <asm/io.h>
Tom Rinifda35eb2012-07-03 08:51:34 -070032#include <asm/emif.h>
Tom Rini65d750b2012-07-31 08:55:01 -070033#include <asm/gpio.h>
Tom Rini973b6632012-07-30 16:13:10 -070034#include <i2c.h>
35#include <miiphy.h>
36#include <cpsw.h>
Ilya Yanok7df5cf32012-11-06 13:48:23 +000037#include <asm/errno.h>
38#include <linux/usb/ch9.h>
39#include <linux/usb/gadget.h>
40#include <linux/usb/musb.h>
41#include <asm/omap_musb.h>
Chandan Nath5289e832011-10-14 02:58:26 +000042
43DECLARE_GLOBAL_DATA_PTR;
44
Steve Sakoman3b971522012-06-04 05:35:34 +000045static const struct gpio_bank gpio_bank_am33xx[4] = {
46 { (void *)AM33XX_GPIO0_BASE, METHOD_GPIO_24XX },
47 { (void *)AM33XX_GPIO1_BASE, METHOD_GPIO_24XX },
48 { (void *)AM33XX_GPIO2_BASE, METHOD_GPIO_24XX },
49 { (void *)AM33XX_GPIO3_BASE, METHOD_GPIO_24XX },
50};
51
52const struct gpio_bank *const omap_gpio_bank = gpio_bank_am33xx;
53
Chandan Nath876bdd62012-01-09 20:38:58 +000054#if defined(CONFIG_OMAP_HSMMC) && !defined(CONFIG_SPL_BUILD)
Peter Korsgaard75a23882012-10-18 01:21:10 +000055int cpu_mmc_init(bd_t *bis)
Chandan Nath876bdd62012-01-09 20:38:58 +000056{
Tom Rini0689a2e2012-08-08 10:31:08 -070057 int ret;
Peter Korsgaard75a23882012-10-18 01:21:10 +000058
Nikita Kiryanove3913f52012-12-03 02:19:47 +000059 ret = omap_mmc_init(0, 0, 0, -1, -1);
Tom Rini0689a2e2012-08-08 10:31:08 -070060 if (ret)
61 return ret;
62
Nikita Kiryanove3913f52012-12-03 02:19:47 +000063 return omap_mmc_init(1, 0, 0, -1, -1);
Chandan Nath876bdd62012-01-09 20:38:58 +000064}
65#endif
Chandan Nath8a8f0842012-01-09 20:38:59 +000066
67void setup_clocks_for_console(void)
68{
69 /* Not yet implemented */
70 return;
71}
Ilya Yanok7df5cf32012-11-06 13:48:23 +000072
73/* AM33XX has two MUSB controllers which can be host or gadget */
74#if (defined(CONFIG_MUSB_GADGET) || defined(CONFIG_MUSB_HOST)) && \
75 (defined(CONFIG_AM335X_USB0) || defined(CONFIG_AM335X_USB1))
76static struct ctrl_dev *cdev = (struct ctrl_dev *)CTRL_DEVICE_BASE;
77
78/* USB 2.0 PHY Control */
79#define CM_PHY_PWRDN (1 << 0)
80#define CM_PHY_OTG_PWRDN (1 << 1)
81#define OTGVDET_EN (1 << 19)
82#define OTGSESSENDEN (1 << 20)
83
84static void am33xx_usb_set_phy_power(u8 on, u32 *reg_addr)
85{
86 if (on) {
87 clrsetbits_le32(reg_addr, CM_PHY_PWRDN | CM_PHY_OTG_PWRDN,
88 OTGVDET_EN | OTGSESSENDEN);
89 } else {
90 clrsetbits_le32(reg_addr, 0, CM_PHY_PWRDN | CM_PHY_OTG_PWRDN);
91 }
92}
93
94static struct musb_hdrc_config musb_config = {
95 .multipoint = 1,
96 .dyn_fifo = 1,
97 .num_eps = 16,
98 .ram_bits = 12,
99};
100
101#ifdef CONFIG_AM335X_USB0
102static void am33xx_otg0_set_phy_power(u8 on)
103{
104 am33xx_usb_set_phy_power(on, &cdev->usb_ctrl0);
105}
106
107struct omap_musb_board_data otg0_board_data = {
108 .set_phy_power = am33xx_otg0_set_phy_power,
109};
110
111static struct musb_hdrc_platform_data otg0_plat = {
112 .mode = CONFIG_AM335X_USB0_MODE,
113 .config = &musb_config,
114 .power = 50,
115 .platform_ops = &musb_dsps_ops,
116 .board_data = &otg0_board_data,
117};
118#endif
119
120#ifdef CONFIG_AM335X_USB1
121static void am33xx_otg1_set_phy_power(u8 on)
122{
123 am33xx_usb_set_phy_power(on, &cdev->usb_ctrl1);
124}
125
126struct omap_musb_board_data otg1_board_data = {
127 .set_phy_power = am33xx_otg1_set_phy_power,
128};
129
130static struct musb_hdrc_platform_data otg1_plat = {
131 .mode = CONFIG_AM335X_USB1_MODE,
132 .config = &musb_config,
133 .power = 50,
134 .platform_ops = &musb_dsps_ops,
135 .board_data = &otg1_board_data,
136};
137#endif
138#endif
139
140int arch_misc_init(void)
141{
142#ifdef CONFIG_AM335X_USB0
143 musb_register(&otg0_plat, &otg0_board_data,
144 (void *)AM335X_USB0_OTG_BASE);
145#endif
146#ifdef CONFIG_AM335X_USB1
147 musb_register(&otg1_plat, &otg1_board_data,
148 (void *)AM335X_USB1_OTG_BASE);
149#endif
150 return 0;
151}