mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-11 07:34:31 +00:00
Merge branch 'master' of git://git.denx.de/u-boot-ti
This commit is contained in:
commit
9844d027b5
21 changed files with 1210 additions and 25 deletions
|
@ -41,12 +41,8 @@ static struct gptimer *timer_base = (struct gptimer *)CONFIG_SYS_TIMERBASE;
|
|||
|
||||
/*
|
||||
* Nothing really to do with interrupts, just starts up a counter.
|
||||
* We run the counter with 13MHz, divided by 8, resulting in timer
|
||||
* frequency of 1.625MHz. With 32bit counter register, counter
|
||||
* overflows in ~44min
|
||||
*/
|
||||
|
||||
/* 13MHz / 8 = 1.625MHz */
|
||||
#define TIMER_CLOCK (V_SCLK / (2 << CONFIG_SYS_PTV))
|
||||
#define TIMER_LOAD_VAL 0xffffffff
|
||||
|
||||
|
@ -84,11 +80,6 @@ void set_timer(ulong t)
|
|||
/* delay x useconds */
|
||||
void __udelay(unsigned long usec)
|
||||
{
|
||||
#if defined(CONFIG_OMAP44XX)
|
||||
/* TODO temporary hack until OMAP4 clock setup routines are present */
|
||||
if (usec > 1000)
|
||||
usec = usec/1000;
|
||||
#endif
|
||||
long tmo = usec * (TIMER_CLOCK / 1000) / 1000;
|
||||
unsigned long now, last = readl(&timer_base->tcrr);
|
||||
|
||||
|
|
|
@ -88,3 +88,14 @@ int checkboard(void)
|
|||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* This function is called by start_armboot. You can reliably use static
|
||||
* data. Any boot-time function that require static data should be
|
||||
* called from here
|
||||
*/
|
||||
int arch_cpu_init(void)
|
||||
{
|
||||
set_muxconf_regs();
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -483,4 +483,7 @@ struct pm {
|
|||
#define I2C_BASE2 (OMAP34XX_CORE_L4_IO_BASE + 0x72000)
|
||||
#define I2C_BASE3 (OMAP34XX_CORE_L4_IO_BASE + 0x60000)
|
||||
|
||||
/* MUSB base */
|
||||
#define MUSB_BASE (OMAP34XX_CORE_L4_IO_BASE + 0xAB000)
|
||||
|
||||
#endif /* _CPU_H */
|
||||
|
|
|
@ -34,7 +34,9 @@ struct i2c {
|
|||
unsigned short stat; /* 0x08 */
|
||||
unsigned short res3;
|
||||
unsigned short iv; /* 0x0C */
|
||||
unsigned short res4[3];
|
||||
unsigned short res4;
|
||||
unsigned short syss; /* 0x10 */
|
||||
unsigned short res4a;
|
||||
unsigned short buf; /* 0x14 */
|
||||
unsigned short res5;
|
||||
unsigned short cnt; /* 0x18 */
|
||||
|
|
|
@ -139,4 +139,7 @@ struct watchdog {
|
|||
#define I2C_BASE2 (OMAP44XX_L4_PER_BASE + 0x72000)
|
||||
#define I2C_BASE3 (OMAP44XX_L4_PER_BASE + 0x60000)
|
||||
|
||||
/* MUSB base */
|
||||
#define MUSB_BASE (OMAP44XX_L4_CORE_BASE + 0xAB000)
|
||||
|
||||
#endif /* _CPU_H */
|
||||
|
|
344
arch/arm/include/asm/arch-omap4/mux_omap4.h
Normal file
344
arch/arm/include/asm/arch-omap4/mux_omap4.h
Normal file
|
@ -0,0 +1,344 @@
|
|||
/*
|
||||
* (C) Copyright 2004-2009
|
||||
* Texas Instruments Incorporated
|
||||
* Richard Woodruff <r-woodruff2@ti.com>
|
||||
* Aneesh V <aneesh@ti.com>
|
||||
* Balaji Krishnamoorthy <balajitk@ti.com>
|
||||
*
|
||||
* See file CREDITS for list of people who contributed to this
|
||||
* project.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*/
|
||||
#ifndef _MUX_OMAP4_H_
|
||||
#define _MUX_OMAP4_H_
|
||||
|
||||
#include <asm/types.h>
|
||||
|
||||
struct pad_conf_entry {
|
||||
|
||||
u16 offset;
|
||||
|
||||
u16 val;
|
||||
|
||||
} __attribute__ ((packed));
|
||||
|
||||
#ifdef CONFIG_OFF_PADCONF
|
||||
#define OFF_PD (1 << 12)
|
||||
#define OFF_PU (3 << 12)
|
||||
#define OFF_OUT_PTD (0 << 10)
|
||||
#define OFF_OUT_PTU (2 << 10)
|
||||
#define OFF_IN (1 << 10)
|
||||
#define OFF_OUT (0 << 10)
|
||||
#define OFF_EN (1 << 9)
|
||||
#else
|
||||
#define OFF_PD (0 << 12)
|
||||
#define OFF_PU (0 << 12)
|
||||
#define OFF_OUT_PTD (0 << 10)
|
||||
#define OFF_OUT_PTU (0 << 10)
|
||||
#define OFF_IN (0 << 10)
|
||||
#define OFF_OUT (0 << 10)
|
||||
#define OFF_EN (0 << 9)
|
||||
#endif
|
||||
|
||||
#define IEN (1 << 8)
|
||||
#define IDIS (0 << 8)
|
||||
#define PTU (3 << 3)
|
||||
#define PTD (1 << 3)
|
||||
#define EN (1 << 3)
|
||||
#define DIS (0 << 3)
|
||||
|
||||
#define M0 0
|
||||
#define M1 1
|
||||
#define M2 2
|
||||
#define M3 3
|
||||
#define M4 4
|
||||
#define M5 5
|
||||
#define M6 6
|
||||
#define M7 7
|
||||
|
||||
#define SAFE_MODE M7
|
||||
|
||||
#ifdef CONFIG_OFF_PADCONF
|
||||
#define OFF_IN_PD (OFF_PD | OFF_IN | OFF_EN)
|
||||
#define OFF_IN_PU (OFF_PU | OFF_IN | OFF_EN)
|
||||
#define OFF_OUT_PD (OFF_OUT_PTD | OFF_OUT | OFF_EN)
|
||||
#define OFF_OUT_PU (OFF_OUT_PTU | OFF_OUT | OFF_EN)
|
||||
#else
|
||||
#define OFF_IN_PD 0
|
||||
#define OFF_IN_PU 0
|
||||
#define OFF_OUT_PD 0
|
||||
#define OFF_OUT_PU 0
|
||||
#endif
|
||||
|
||||
#define CORE_REVISION 0x0000
|
||||
#define CORE_HWINFO 0x0004
|
||||
#define CORE_SYSCONFIG 0x0010
|
||||
#define GPMC_AD0 0x0040
|
||||
#define GPMC_AD1 0x0042
|
||||
#define GPMC_AD2 0x0044
|
||||
#define GPMC_AD3 0x0046
|
||||
#define GPMC_AD4 0x0048
|
||||
#define GPMC_AD5 0x004A
|
||||
#define GPMC_AD6 0x004C
|
||||
#define GPMC_AD7 0x004E
|
||||
#define GPMC_AD8 0x0050
|
||||
#define GPMC_AD9 0x0052
|
||||
#define GPMC_AD10 0x0054
|
||||
#define GPMC_AD11 0x0056
|
||||
#define GPMC_AD12 0x0058
|
||||
#define GPMC_AD13 0x005A
|
||||
#define GPMC_AD14 0x005C
|
||||
#define GPMC_AD15 0x005E
|
||||
#define GPMC_A16 0x0060
|
||||
#define GPMC_A17 0x0062
|
||||
#define GPMC_A18 0x0064
|
||||
#define GPMC_A19 0x0066
|
||||
#define GPMC_A20 0x0068
|
||||
#define GPMC_A21 0x006A
|
||||
#define GPMC_A22 0x006C
|
||||
#define GPMC_A23 0x006E
|
||||
#define GPMC_A24 0x0070
|
||||
#define GPMC_A25 0x0072
|
||||
#define GPMC_NCS0 0x0074
|
||||
#define GPMC_NCS1 0x0076
|
||||
#define GPMC_NCS2 0x0078
|
||||
#define GPMC_NCS3 0x007A
|
||||
#define GPMC_NWP 0x007C
|
||||
#define GPMC_CLK 0x007E
|
||||
#define GPMC_NADV_ALE 0x0080
|
||||
#define GPMC_NOE 0x0082
|
||||
#define GPMC_NWE 0x0084
|
||||
#define GPMC_NBE0_CLE 0x0086
|
||||
#define GPMC_NBE1 0x0088
|
||||
#define GPMC_WAIT0 0x008A
|
||||
#define GPMC_WAIT1 0x008C
|
||||
#define C2C_DATA11 0x008E
|
||||
#define C2C_DATA12 0x0090
|
||||
#define C2C_DATA13 0x0092
|
||||
#define C2C_DATA14 0x0094
|
||||
#define C2C_DATA15 0x0096
|
||||
#define HDMI_HPD 0x0098
|
||||
#define HDMI_CEC 0x009A
|
||||
#define HDMI_DDC_SCL 0x009C
|
||||
#define HDMI_DDC_SDA 0x009E
|
||||
#define CSI21_DX0 0x00A0
|
||||
#define CSI21_DY0 0x00A2
|
||||
#define CSI21_DX1 0x00A4
|
||||
#define CSI21_DY1 0x00A6
|
||||
#define CSI21_DX2 0x00A8
|
||||
#define CSI21_DY2 0x00AA
|
||||
#define CSI21_DX3 0x00AC
|
||||
#define CSI21_DY3 0x00AE
|
||||
#define CSI21_DX4 0x00B0
|
||||
#define CSI21_DY4 0x00B2
|
||||
#define CSI22_DX0 0x00B4
|
||||
#define CSI22_DY0 0x00B6
|
||||
#define CSI22_DX1 0x00B8
|
||||
#define CSI22_DY1 0x00BA
|
||||
#define CAM_SHUTTER 0x00BC
|
||||
#define CAM_STROBE 0x00BE
|
||||
#define CAM_GLOBALRESET 0x00C0
|
||||
#define USBB1_ULPITLL_CLK 0x00C2
|
||||
#define USBB1_ULPITLL_STP 0x00C4
|
||||
#define USBB1_ULPITLL_DIR 0x00C6
|
||||
#define USBB1_ULPITLL_NXT 0x00C8
|
||||
#define USBB1_ULPITLL_DAT0 0x00CA
|
||||
#define USBB1_ULPITLL_DAT1 0x00CC
|
||||
#define USBB1_ULPITLL_DAT2 0x00CE
|
||||
#define USBB1_ULPITLL_DAT3 0x00D0
|
||||
#define USBB1_ULPITLL_DAT4 0x00D2
|
||||
#define USBB1_ULPITLL_DAT5 0x00D4
|
||||
#define USBB1_ULPITLL_DAT6 0x00D6
|
||||
#define USBB1_ULPITLL_DAT7 0x00D8
|
||||
#define USBB1_HSIC_DATA 0x00DA
|
||||
#define USBB1_HSIC_STROBE 0x00DC
|
||||
#define USBC1_ICUSB_DP 0x00DE
|
||||
#define USBC1_ICUSB_DM 0x00E0
|
||||
#define SDMMC1_CLK 0x00E2
|
||||
#define SDMMC1_CMD 0x00E4
|
||||
#define SDMMC1_DAT0 0x00E6
|
||||
#define SDMMC1_DAT1 0x00E8
|
||||
#define SDMMC1_DAT2 0x00EA
|
||||
#define SDMMC1_DAT3 0x00EC
|
||||
#define SDMMC1_DAT4 0x00EE
|
||||
#define SDMMC1_DAT5 0x00F0
|
||||
#define SDMMC1_DAT6 0x00F2
|
||||
#define SDMMC1_DAT7 0x00F4
|
||||
#define ABE_MCBSP2_CLKX 0x00F6
|
||||
#define ABE_MCBSP2_DR 0x00F8
|
||||
#define ABE_MCBSP2_DX 0x00FA
|
||||
#define ABE_MCBSP2_FSX 0x00FC
|
||||
#define ABE_MCBSP1_CLKX 0x00FE
|
||||
#define ABE_MCBSP1_DR 0x0100
|
||||
#define ABE_MCBSP1_DX 0x0102
|
||||
#define ABE_MCBSP1_FSX 0x0104
|
||||
#define ABE_PDM_UL_DATA 0x0106
|
||||
#define ABE_PDM_DL_DATA 0x0108
|
||||
#define ABE_PDM_FRAME 0x010A
|
||||
#define ABE_PDM_LB_CLK 0x010C
|
||||
#define ABE_CLKS 0x010E
|
||||
#define ABE_DMIC_CLK1 0x0110
|
||||
#define ABE_DMIC_DIN1 0x0112
|
||||
#define ABE_DMIC_DIN2 0x0114
|
||||
#define ABE_DMIC_DIN3 0x0116
|
||||
#define UART2_CTS 0x0118
|
||||
#define UART2_RTS 0x011A
|
||||
#define UART2_RX 0x011C
|
||||
#define UART2_TX 0x011E
|
||||
#define HDQ_SIO 0x0120
|
||||
#define I2C1_SCL 0x0122
|
||||
#define I2C1_SDA 0x0124
|
||||
#define I2C2_SCL 0x0126
|
||||
#define I2C2_SDA 0x0128
|
||||
#define I2C3_SCL 0x012A
|
||||
#define I2C3_SDA 0x012C
|
||||
#define I2C4_SCL 0x012E
|
||||
#define I2C4_SDA 0x0130
|
||||
#define MCSPI1_CLK 0x0132
|
||||
#define MCSPI1_SOMI 0x0134
|
||||
#define MCSPI1_SIMO 0x0136
|
||||
#define MCSPI1_CS0 0x0138
|
||||
#define MCSPI1_CS1 0x013A
|
||||
#define MCSPI1_CS2 0x013C
|
||||
#define MCSPI1_CS3 0x013E
|
||||
#define UART3_CTS_RCTX 0x0140
|
||||
#define UART3_RTS_SD 0x0142
|
||||
#define UART3_RX_IRRX 0x0144
|
||||
#define UART3_TX_IRTX 0x0146
|
||||
#define SDMMC5_CLK 0x0148
|
||||
#define SDMMC5_CMD 0x014A
|
||||
#define SDMMC5_DAT0 0x014C
|
||||
#define SDMMC5_DAT1 0x014E
|
||||
#define SDMMC5_DAT2 0x0150
|
||||
#define SDMMC5_DAT3 0x0152
|
||||
#define MCSPI4_CLK 0x0154
|
||||
#define MCSPI4_SIMO 0x0156
|
||||
#define MCSPI4_SOMI 0x0158
|
||||
#define MCSPI4_CS0 0x015A
|
||||
#define UART4_RX 0x015C
|
||||
#define UART4_TX 0x015E
|
||||
#define USBB2_ULPITLL_CLK 0x0160
|
||||
#define USBB2_ULPITLL_STP 0x0162
|
||||
#define USBB2_ULPITLL_DIR 0x0164
|
||||
#define USBB2_ULPITLL_NXT 0x0166
|
||||
#define USBB2_ULPITLL_DAT0 0x0168
|
||||
#define USBB2_ULPITLL_DAT1 0x016A
|
||||
#define USBB2_ULPITLL_DAT2 0x016C
|
||||
#define USBB2_ULPITLL_DAT3 0x016E
|
||||
#define USBB2_ULPITLL_DAT4 0x0170
|
||||
#define USBB2_ULPITLL_DAT5 0x0172
|
||||
#define USBB2_ULPITLL_DAT6 0x0174
|
||||
#define USBB2_ULPITLL_DAT7 0x0176
|
||||
#define USBB2_HSIC_DATA 0x0178
|
||||
#define USBB2_HSIC_STROBE 0x017A
|
||||
#define UNIPRO_TX0 0x017C
|
||||
#define UNIPRO_TY0 0x017E
|
||||
#define UNIPRO_TX1 0x0180
|
||||
#define UNIPRO_TY1 0x0182
|
||||
#define UNIPRO_TX2 0x0184
|
||||
#define UNIPRO_TY2 0x0186
|
||||
#define UNIPRO_RX0 0x0188
|
||||
#define UNIPRO_RY0 0x018A
|
||||
#define UNIPRO_RX1 0x018C
|
||||
#define UNIPRO_RY1 0x018E
|
||||
#define UNIPRO_RX2 0x0190
|
||||
#define UNIPRO_RY2 0x0192
|
||||
#define USBA0_OTG_CE 0x0194
|
||||
#define USBA0_OTG_DP 0x0196
|
||||
#define USBA0_OTG_DM 0x0198
|
||||
#define FREF_CLK1_OUT 0x019A
|
||||
#define FREF_CLK2_OUT 0x019C
|
||||
#define SYS_NIRQ1 0x019E
|
||||
#define SYS_NIRQ2 0x01A0
|
||||
#define SYS_BOOT0 0x01A2
|
||||
#define SYS_BOOT1 0x01A4
|
||||
#define SYS_BOOT2 0x01A6
|
||||
#define SYS_BOOT3 0x01A8
|
||||
#define SYS_BOOT4 0x01AA
|
||||
#define SYS_BOOT5 0x01AC
|
||||
#define DPM_EMU0 0x01AE
|
||||
#define DPM_EMU1 0x01B0
|
||||
#define DPM_EMU2 0x01B2
|
||||
#define DPM_EMU3 0x01B4
|
||||
#define DPM_EMU4 0x01B6
|
||||
#define DPM_EMU5 0x01B8
|
||||
#define DPM_EMU6 0x01BA
|
||||
#define DPM_EMU7 0x01BC
|
||||
#define DPM_EMU8 0x01BE
|
||||
#define DPM_EMU9 0x01C0
|
||||
#define DPM_EMU10 0x01C2
|
||||
#define DPM_EMU11 0x01C4
|
||||
#define DPM_EMU12 0x01C6
|
||||
#define DPM_EMU13 0x01C8
|
||||
#define DPM_EMU14 0x01CA
|
||||
#define DPM_EMU15 0x01CC
|
||||
#define DPM_EMU16 0x01CE
|
||||
#define DPM_EMU17 0x01D0
|
||||
#define DPM_EMU18 0x01D2
|
||||
#define DPM_EMU19 0x01D4
|
||||
#define WAKEUPEVENT_0 0x01D8
|
||||
#define WAKEUPEVENT_1 0x01DC
|
||||
#define WAKEUPEVENT_2 0x01E0
|
||||
#define WAKEUPEVENT_3 0x01E4
|
||||
#define WAKEUPEVENT_4 0x01E8
|
||||
#define WAKEUPEVENT_5 0x01EC
|
||||
#define WAKEUPEVENT_6 0x01F0
|
||||
|
||||
#define WKUP_REVISION 0x0000
|
||||
#define WKUP_HWINFO 0x0004
|
||||
#define WKUP_SYSCONFIG 0x0010
|
||||
#define PAD0_SIM_IO 0x0040
|
||||
#define PAD1_SIM_CLK 0x0042
|
||||
#define PAD0_SIM_RESET 0x0044
|
||||
#define PAD1_SIM_CD 0x0046
|
||||
#define PAD0_SIM_PWRCTRL 0x0048
|
||||
#define PAD1_SR_SCL 0x004A
|
||||
#define PAD0_SR_SDA 0x004C
|
||||
#define PAD1_FREF_XTAL_IN 0x004E
|
||||
#define PAD0_FREF_SLICER_IN 0x0050
|
||||
#define PAD1_FREF_CLK_IOREQ 0x0052
|
||||
#define PAD0_FREF_CLK0_OUT 0x0054
|
||||
#define PAD1_FREF_CLK3_REQ 0x0056
|
||||
#define PAD0_FREF_CLK3_OUT 0x0058
|
||||
#define PAD1_FREF_CLK4_REQ 0x005A
|
||||
#define PAD0_FREF_CLK4_OUT 0x005C
|
||||
#define PAD1_SYS_32K 0x005E
|
||||
#define PAD0_SYS_NRESPWRON 0x0060
|
||||
#define PAD1_SYS_NRESWARM 0x0062
|
||||
#define PAD0_SYS_PWR_REQ 0x0064
|
||||
#define PAD1_SYS_PWRON_RESET 0x0066
|
||||
#define PAD0_SYS_BOOT6 0x0068
|
||||
#define PAD1_SYS_BOOT7 0x006A
|
||||
#define PAD0_JTAG_NTRST 0x006C
|
||||
#define PAD1_JTAG_TCK 0x006D
|
||||
#define PAD0_JTAG_RTCK 0x0070
|
||||
#define PAD1_JTAG_TMS_TMSC 0x0072
|
||||
#define PAD0_JTAG_TDI 0x0074
|
||||
#define PAD1_JTAG_TDO 0x0076
|
||||
#define PADCONF_WAKEUPEVENT_0 0x007C
|
||||
#define CONTROL_SMART1NOPMIO_PADCONF_0 0x05A0
|
||||
#define CONTROL_SMART1NOPMIO_PADCONF_1 0x05A4
|
||||
#define PADCONF_MODE 0x05A8
|
||||
#define CONTROL_XTAL_OSCILLATOR 0x05AC
|
||||
#define CONTROL_CONTROL_I2C_2 0x0604
|
||||
#define CONTROL_CONTROL_JTAG 0x0608
|
||||
#define CONTROL_CONTROL_SYS 0x060C
|
||||
#define CONTROL_SPARE_RW 0x0614
|
||||
#define CONTROL_SPARE_R 0x0618
|
||||
#define CONTROL_SPARE_R_C0 0x061C
|
||||
|
||||
#endif /* _MUX_OMAP4_H_ */
|
|
@ -44,6 +44,8 @@
|
|||
|
||||
/* CONTROL */
|
||||
#define CTRL_BASE (OMAP44XX_L4_CORE_BASE + 0x2000)
|
||||
#define CONTROL_PADCONF_CORE (OMAP44XX_L4_CORE_BASE + 0x100000)
|
||||
#define CONTROL_PADCONF_WKUP (OMAP44XX_L4_CORE_BASE + 0x31E000)
|
||||
|
||||
/* UART */
|
||||
#define UART1_BASE (OMAP44XX_L4_PER_BASE + 0x6a000)
|
||||
|
|
|
@ -32,6 +32,7 @@ void gpmc_init(void);
|
|||
void watchdog_init(void);
|
||||
u32 get_device_type(void);
|
||||
void invalidate_dcache(u32);
|
||||
void set_muxconf_regs(void);
|
||||
|
||||
extern const struct omap_sysinfo sysinfo;
|
||||
|
||||
|
|
|
@ -24,6 +24,8 @@
|
|||
#include <common.h>
|
||||
#include <asm/arch/sys_proto.h>
|
||||
|
||||
#include "panda.h"
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
const struct omap_sysinfo sysinfo = {
|
||||
|
@ -61,3 +63,27 @@ int misc_init_r(void)
|
|||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
void do_set_mux(u32 base, struct pad_conf_entry const *array, int size)
|
||||
{
|
||||
int i;
|
||||
struct pad_conf_entry *pad = (struct pad_conf_entry *) array;
|
||||
|
||||
for (i = 0; i < size; i++, pad++)
|
||||
writew(pad->val, base + pad->offset);
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief set_muxconf_regs Setting up the configuration Mux registers
|
||||
* specific to the board.
|
||||
*/
|
||||
void set_muxconf_regs(void)
|
||||
{
|
||||
do_set_mux(CONTROL_PADCONF_CORE, core_padconf_array,
|
||||
sizeof(core_padconf_array) /
|
||||
sizeof(struct pad_conf_entry));
|
||||
|
||||
do_set_mux(CONTROL_PADCONF_WKUP, wkup_padconf_array,
|
||||
sizeof(wkup_padconf_array) /
|
||||
sizeof(struct pad_conf_entry));
|
||||
}
|
||||
|
|
265
board/ti/panda/panda.h
Normal file
265
board/ti/panda/panda.h
Normal file
|
@ -0,0 +1,265 @@
|
|||
/*
|
||||
* (C) Copyright 2010
|
||||
* Texas Instruments Incorporated, <www.ti.com>
|
||||
*
|
||||
* Balaji Krishnamoorthy <balajitk@ti.com>
|
||||
* Aneesh V <aneesh@ti.com>
|
||||
*
|
||||
* See file CREDITS for list of people who contributed to this
|
||||
* project.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
#ifndef _PANDA_H_
|
||||
#define _PANDA_H_
|
||||
|
||||
#include <asm/io.h>
|
||||
#include <asm/arch/mux_omap4.h>
|
||||
|
||||
const struct pad_conf_entry core_padconf_array[] = {
|
||||
{GPMC_AD0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat0 */
|
||||
{GPMC_AD1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat1 */
|
||||
{GPMC_AD2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat2 */
|
||||
{GPMC_AD3, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat3 */
|
||||
{GPMC_AD4, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat4 */
|
||||
{GPMC_AD5, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat5 */
|
||||
{GPMC_AD6, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat6 */
|
||||
{GPMC_AD7, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat7 */
|
||||
{GPMC_AD8, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M3)}, /* gpio_32 */
|
||||
{GPMC_AD9, (PTU | IEN | M3)}, /* gpio_33 */
|
||||
{GPMC_AD10, (PTU | IEN | M3)}, /* gpio_34 */
|
||||
{GPMC_AD11, (PTU | IEN | M3)}, /* gpio_35 */
|
||||
{GPMC_AD12, (PTU | IEN | M3)}, /* gpio_36 */
|
||||
{GPMC_AD13, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_37 */
|
||||
{GPMC_AD14, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_38 */
|
||||
{GPMC_AD15, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_39 */
|
||||
{GPMC_A16, (M3)}, /* gpio_40 */
|
||||
{GPMC_A17, (PTD | M3)}, /* gpio_41 */
|
||||
{GPMC_A18, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row6 */
|
||||
{GPMC_A19, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row7 */
|
||||
{GPMC_A20, (IEN | M3)}, /* gpio_44 */
|
||||
{GPMC_A21, (M3)}, /* gpio_45 */
|
||||
{GPMC_A22, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col6 */
|
||||
{GPMC_A23, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col7 */
|
||||
{GPMC_A24, (PTD | M3)}, /* gpio_48 */
|
||||
{GPMC_A25, (PTD | M3)}, /* gpio_49 */
|
||||
{GPMC_NCS0, (M3)}, /* gpio_50 */
|
||||
{GPMC_NCS1, (IEN | M3)}, /* gpio_51 */
|
||||
{GPMC_NCS2, (IEN | M3)}, /* gpio_52 */
|
||||
{GPMC_NCS3, (IEN | M3)}, /* gpio_53 */
|
||||
{GPMC_NWP, (M3)}, /* gpio_54 */
|
||||
{GPMC_CLK, (PTD | M3)}, /* gpio_55 */
|
||||
{GPMC_NADV_ALE, (M3)}, /* gpio_56 */
|
||||
{GPMC_NOE, (PTU | IEN | OFF_EN | OFF_OUT_PTD | M1)}, /* sdmmc2_clk */
|
||||
{GPMC_NWE, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_cmd */
|
||||
{GPMC_NBE0_CLE, (M3)}, /* gpio_59 */
|
||||
{GPMC_NBE1, (PTD | M3)}, /* gpio_60 */
|
||||
{GPMC_WAIT0, (PTU | IEN | M3)}, /* gpio_61 */
|
||||
{GPMC_WAIT1, (IEN | M3)}, /* gpio_62 */
|
||||
{C2C_DATA11, (PTD | M3)}, /* gpio_100 */
|
||||
{C2C_DATA12, (M1)}, /* dsi1_te0 */
|
||||
{C2C_DATA13, (PTD | M3)}, /* gpio_102 */
|
||||
{C2C_DATA14, (M1)}, /* dsi2_te0 */
|
||||
{C2C_DATA15, (PTD | M3)}, /* gpio_104 */
|
||||
{HDMI_HPD, (M0)}, /* hdmi_hpd */
|
||||
{HDMI_CEC, (M0)}, /* hdmi_cec */
|
||||
{HDMI_DDC_SCL, (PTU | M0)}, /* hdmi_ddc_scl */
|
||||
{HDMI_DDC_SDA, (PTU | IEN | M0)}, /* hdmi_ddc_sda */
|
||||
{CSI21_DX0, (IEN | M0)}, /* csi21_dx0 */
|
||||
{CSI21_DY0, (IEN | M0)}, /* csi21_dy0 */
|
||||
{CSI21_DX1, (IEN | M0)}, /* csi21_dx1 */
|
||||
{CSI21_DY1, (IEN | M0)}, /* csi21_dy1 */
|
||||
{CSI21_DX2, (IEN | M0)}, /* csi21_dx2 */
|
||||
{CSI21_DY2, (IEN | M0)}, /* csi21_dy2 */
|
||||
{CSI21_DX3, (PTD | M7)}, /* csi21_dx3 */
|
||||
{CSI21_DY3, (PTD | M7)}, /* csi21_dy3 */
|
||||
{CSI21_DX4, (PTD | OFF_EN | OFF_PD | OFF_IN | M7)}, /* csi21_dx4 */
|
||||
{CSI21_DY4, (PTD | OFF_EN | OFF_PD | OFF_IN | M7)}, /* csi21_dy4 */
|
||||
{CSI22_DX0, (IEN | M0)}, /* csi22_dx0 */
|
||||
{CSI22_DY0, (IEN | M0)}, /* csi22_dy0 */
|
||||
{CSI22_DX1, (IEN | M0)}, /* csi22_dx1 */
|
||||
{CSI22_DY1, (IEN | M0)}, /* csi22_dy1 */
|
||||
{CAM_SHUTTER, (OFF_EN | OFF_PD | OFF_OUT_PTD | M0)}, /* cam_shutter */
|
||||
{CAM_STROBE, (OFF_EN | OFF_PD | OFF_OUT_PTD | M0)}, /* cam_strobe */
|
||||
{CAM_GLOBALRESET, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_83 */
|
||||
{USBB1_ULPITLL_CLK, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M4)},/* usbb1_ulpiphy_clk */
|
||||
{USBB1_ULPITLL_STP, (OFF_EN | OFF_OUT_PTD | M4)}, /* usbb1_ulpiphy_stp */
|
||||
{USBB1_ULPITLL_DIR, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dir */
|
||||
{USBB1_ULPITLL_NXT, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_nxt */
|
||||
{USBB1_ULPITLL_DAT0, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat0 */
|
||||
{USBB1_ULPITLL_DAT1, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat1 */
|
||||
{USBB1_ULPITLL_DAT2, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat2 */
|
||||
{USBB1_ULPITLL_DAT3, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat3 */
|
||||
{USBB1_ULPITLL_DAT4, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat4 */
|
||||
{USBB1_ULPITLL_DAT5, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat5 */
|
||||
{USBB1_ULPITLL_DAT6, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat6 */
|
||||
{USBB1_ULPITLL_DAT7, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat7 */
|
||||
{USBB1_HSIC_DATA, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usbb1_hsic_data */
|
||||
{USBB1_HSIC_STROBE, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usbb1_hsic_strobe */
|
||||
{USBC1_ICUSB_DP, (IEN | M0)}, /* usbc1_icusb_dp */
|
||||
{USBC1_ICUSB_DM, (IEN | M0)}, /* usbc1_icusb_dm */
|
||||
{SDMMC1_CLK, (PTU | OFF_EN | OFF_OUT_PTD | M0)}, /* sdmmc1_clk */
|
||||
{SDMMC1_CMD, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_cmd */
|
||||
{SDMMC1_DAT0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat0 */
|
||||
{SDMMC1_DAT1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat1 */
|
||||
{SDMMC1_DAT2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat2 */
|
||||
{SDMMC1_DAT3, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat3 */
|
||||
{SDMMC1_DAT4, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat4 */
|
||||
{SDMMC1_DAT5, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat5 */
|
||||
{SDMMC1_DAT6, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat6 */
|
||||
{SDMMC1_DAT7, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat7 */
|
||||
{ABE_MCBSP2_CLKX, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_mcbsp2_clkx */
|
||||
{ABE_MCBSP2_DR, (IEN | OFF_EN | OFF_OUT_PTD | M0)}, /* abe_mcbsp2_dr */
|
||||
{ABE_MCBSP2_DX, (OFF_EN | OFF_OUT_PTD | M0)}, /* abe_mcbsp2_dx */
|
||||
{ABE_MCBSP2_FSX, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_mcbsp2_fsx */
|
||||
{ABE_MCBSP1_CLKX, (IEN | M1)}, /* abe_slimbus1_clock */
|
||||
{ABE_MCBSP1_DR, (IEN | M1)}, /* abe_slimbus1_data */
|
||||
{ABE_MCBSP1_DX, (OFF_EN | OFF_OUT_PTD | M0)}, /* abe_mcbsp1_dx */
|
||||
{ABE_MCBSP1_FSX, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_mcbsp1_fsx */
|
||||
{ABE_PDM_UL_DATA, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_ul_data */
|
||||
{ABE_PDM_DL_DATA, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_dl_data */
|
||||
{ABE_PDM_FRAME, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_frame */
|
||||
{ABE_PDM_LB_CLK, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_lb_clk */
|
||||
{ABE_CLKS, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_clks */
|
||||
{ABE_DMIC_CLK1, (M0)}, /* abe_dmic_clk1 */
|
||||
{ABE_DMIC_DIN1, (IEN | M0)}, /* abe_dmic_din1 */
|
||||
{ABE_DMIC_DIN2, (IEN | M0)}, /* abe_dmic_din2 */
|
||||
{ABE_DMIC_DIN3, (IEN | M0)}, /* abe_dmic_din3 */
|
||||
{UART2_CTS, (PTU | IEN | M0)}, /* uart2_cts */
|
||||
{UART2_RTS, (M0)}, /* uart2_rts */
|
||||
{UART2_RX, (PTU | IEN | M0)}, /* uart2_rx */
|
||||
{UART2_TX, (M0)}, /* uart2_tx */
|
||||
{HDQ_SIO, (M3)}, /* gpio_127 */
|
||||
{I2C1_SCL, (PTU | IEN | M0)}, /* i2c1_scl */
|
||||
{I2C1_SDA, (PTU | IEN | M0)}, /* i2c1_sda */
|
||||
{I2C2_SCL, (PTU | IEN | M0)}, /* i2c2_scl */
|
||||
{I2C2_SDA, (PTU | IEN | M0)}, /* i2c2_sda */
|
||||
{I2C3_SCL, (PTU | IEN | M0)}, /* i2c3_scl */
|
||||
{I2C3_SDA, (PTU | IEN | M0)}, /* i2c3_sda */
|
||||
{I2C4_SCL, (PTU | IEN | M0)}, /* i2c4_scl */
|
||||
{I2C4_SDA, (PTU | IEN | M0)}, /* i2c4_sda */
|
||||
{MCSPI1_CLK, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_clk */
|
||||
{MCSPI1_SOMI, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_somi */
|
||||
{MCSPI1_SIMO, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_simo */
|
||||
{MCSPI1_CS0, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_cs0 */
|
||||
{MCSPI1_CS1, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M3)}, /* mcspi1_cs1 */
|
||||
{MCSPI1_CS2, (PTU | OFF_EN | OFF_OUT_PTU | M3)}, /* gpio_139 */
|
||||
{MCSPI1_CS3, (PTU | IEN | M3)}, /* gpio_140 */
|
||||
{UART3_CTS_RCTX, (PTU | IEN | M0)}, /* uart3_tx */
|
||||
{UART3_RTS_SD, (M0)}, /* uart3_rts_sd */
|
||||
{UART3_RX_IRRX, (IEN | M0)}, /* uart3_rx */
|
||||
{UART3_TX_IRTX, (M0)}, /* uart3_tx */
|
||||
{SDMMC5_CLK, (PTU | IEN | OFF_EN | OFF_OUT_PTD | M0)}, /* sdmmc5_clk */
|
||||
{SDMMC5_CMD, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_cmd */
|
||||
{SDMMC5_DAT0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat0 */
|
||||
{SDMMC5_DAT1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat1 */
|
||||
{SDMMC5_DAT2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat2 */
|
||||
{SDMMC5_DAT3, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat3 */
|
||||
{MCSPI4_CLK, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_clk */
|
||||
{MCSPI4_SIMO, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_simo */
|
||||
{MCSPI4_SOMI, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_somi */
|
||||
{MCSPI4_CS0, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_cs0 */
|
||||
{UART4_RX, (IEN | M0)}, /* uart4_rx */
|
||||
{UART4_TX, (M0)}, /* uart4_tx */
|
||||
{USBB2_ULPITLL_CLK, (IEN | M3)}, /* gpio_157 */
|
||||
{USBB2_ULPITLL_STP, (IEN | M5)}, /* dispc2_data23 */
|
||||
{USBB2_ULPITLL_DIR, (IEN | M5)}, /* dispc2_data22 */
|
||||
{USBB2_ULPITLL_NXT, (IEN | M5)}, /* dispc2_data21 */
|
||||
{USBB2_ULPITLL_DAT0, (IEN | M5)}, /* dispc2_data20 */
|
||||
{USBB2_ULPITLL_DAT1, (IEN | M5)}, /* dispc2_data19 */
|
||||
{USBB2_ULPITLL_DAT2, (IEN | M5)}, /* dispc2_data18 */
|
||||
{USBB2_ULPITLL_DAT3, (IEN | M5)}, /* dispc2_data15 */
|
||||
{USBB2_ULPITLL_DAT4, (IEN | M5)}, /* dispc2_data14 */
|
||||
{USBB2_ULPITLL_DAT5, (IEN | M5)}, /* dispc2_data13 */
|
||||
{USBB2_ULPITLL_DAT6, (IEN | M5)}, /* dispc2_data12 */
|
||||
{USBB2_ULPITLL_DAT7, (IEN | M5)}, /* dispc2_data11 */
|
||||
{USBB2_HSIC_DATA, (PTD | OFF_EN | OFF_OUT_PTU | M3)}, /* gpio_169 */
|
||||
{USBB2_HSIC_STROBE, (PTD | OFF_EN | OFF_OUT_PTU | M3)}, /* gpio_170 */
|
||||
{UNIPRO_TX0, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col0 */
|
||||
{UNIPRO_TY0, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col1 */
|
||||
{UNIPRO_TX1, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col2 */
|
||||
{UNIPRO_TY1, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col3 */
|
||||
{UNIPRO_TX2, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M3)}, /* gpio_0 */
|
||||
{UNIPRO_TY2, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M3)}, /* gpio_1 */
|
||||
{UNIPRO_RX0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row0 */
|
||||
{UNIPRO_RY0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row1 */
|
||||
{UNIPRO_RX1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row2 */
|
||||
{UNIPRO_RY1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row3 */
|
||||
{UNIPRO_RX2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row4 */
|
||||
{UNIPRO_RY2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row5 */
|
||||
{USBA0_OTG_CE, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M0)}, /* usba0_otg_ce */
|
||||
{USBA0_OTG_DP, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usba0_otg_dp */
|
||||
{USBA0_OTG_DM, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usba0_otg_dm */
|
||||
{FREF_CLK1_OUT, (M0)}, /* fref_clk1_out */
|
||||
{FREF_CLK2_OUT, (M0)}, /* fref_clk2_out */
|
||||
{SYS_NIRQ1, (PTU | IEN | M0)}, /* sys_nirq1 */
|
||||
{SYS_NIRQ2, (PTU | IEN | M0)}, /* sys_nirq2 */
|
||||
{SYS_BOOT0, (PTU | IEN | M3)}, /* gpio_184 */
|
||||
{SYS_BOOT1, (M3)}, /* gpio_185 */
|
||||
{SYS_BOOT2, (PTD | IEN | M3)}, /* gpio_186 */
|
||||
{SYS_BOOT3, (M3)}, /* gpio_187 */
|
||||
{SYS_BOOT4, (M3)}, /* gpio_188 */
|
||||
{SYS_BOOT5, (PTD | IEN | M3)}, /* gpio_189 */
|
||||
{DPM_EMU0, (IEN | M0)}, /* dpm_emu0 */
|
||||
{DPM_EMU1, (IEN | M0)}, /* dpm_emu1 */
|
||||
{DPM_EMU2, (IEN | M0)}, /* dpm_emu2 */
|
||||
{DPM_EMU3, (IEN | M5)}, /* dispc2_data10 */
|
||||
{DPM_EMU4, (IEN | M5)}, /* dispc2_data9 */
|
||||
{DPM_EMU5, (IEN | M5)}, /* dispc2_data16 */
|
||||
{DPM_EMU6, (IEN | M5)}, /* dispc2_data17 */
|
||||
{DPM_EMU7, (IEN | M5)}, /* dispc2_hsync */
|
||||
{DPM_EMU8, (IEN | M5)}, /* dispc2_pclk */
|
||||
{DPM_EMU9, (IEN | M5)}, /* dispc2_vsync */
|
||||
{DPM_EMU10, (IEN | M5)}, /* dispc2_de */
|
||||
{DPM_EMU11, (IEN | M5)}, /* dispc2_data8 */
|
||||
{DPM_EMU12, (IEN | M5)}, /* dispc2_data7 */
|
||||
{DPM_EMU13, (IEN | M5)}, /* dispc2_data6 */
|
||||
{DPM_EMU14, (IEN | M5)}, /* dispc2_data5 */
|
||||
{DPM_EMU15, (IEN | M5)}, /* dispc2_data4 */
|
||||
{DPM_EMU16, (IEN | M5)}, /* dispc2_data3 */
|
||||
{DPM_EMU17, (IEN | M5)}, /* dispc2_data2 */
|
||||
{DPM_EMU18, (IEN | M5)}, /* dispc2_data1 */
|
||||
{DPM_EMU19, (IEN | M5)}, /* dispc2_data0 */
|
||||
};
|
||||
|
||||
const struct pad_conf_entry wkup_padconf_array[] = {
|
||||
{PAD0_SIM_IO, (IEN | M0)}, /* sim_io */
|
||||
{PAD1_SIM_CLK, (M0)}, /* sim_clk */
|
||||
{PAD0_SIM_RESET, (M0)}, /* sim_reset */
|
||||
{PAD1_SIM_CD, (PTU | IEN | M0)}, /* sim_cd */
|
||||
{PAD0_SIM_PWRCTRL, (M0)}, /* sim_pwrctrl */
|
||||
{PAD1_SR_SCL, (PTU | IEN | M0)}, /* sr_scl */
|
||||
{PAD0_SR_SDA, (PTU | IEN | M0)}, /* sr_sda */
|
||||
{PAD1_FREF_XTAL_IN, (M0)}, /* # */
|
||||
{PAD0_FREF_SLICER_IN, (M0)}, /* fref_slicer_in */
|
||||
{PAD1_FREF_CLK_IOREQ, (M0)}, /* fref_clk_ioreq */
|
||||
{PAD0_FREF_CLK0_OUT, (M2)}, /* sys_drm_msecure */
|
||||
{PAD1_FREF_CLK3_REQ, (PTU | IEN | M0)}, /* # */
|
||||
{PAD0_FREF_CLK3_OUT, (M0)}, /* fref_clk3_out */
|
||||
{PAD1_FREF_CLK4_REQ, (PTU | IEN | M0)}, /* # */
|
||||
{PAD0_FREF_CLK4_OUT, (M0)}, /* # */
|
||||
{PAD1_SYS_32K, (IEN | M0)}, /* sys_32k */
|
||||
{PAD0_SYS_NRESPWRON, (M0)}, /* sys_nrespwron */
|
||||
{PAD1_SYS_NRESWARM, (M0)}, /* sys_nreswarm */
|
||||
{PAD0_SYS_PWR_REQ, (PTU | M0)}, /* sys_pwr_req */
|
||||
{PAD1_SYS_PWRON_RESET, (M3)}, /* gpio_wk29 */
|
||||
{PAD0_SYS_BOOT6, (IEN | M3)}, /* gpio_wk9 */
|
||||
{PAD1_SYS_BOOT7, (IEN | M3)}, /* gpio_wk10 */
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
@ -25,6 +25,8 @@
|
|||
#include <common.h>
|
||||
#include <asm/arch/sys_proto.h>
|
||||
|
||||
#include "sdp.h"
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
const struct omap_sysinfo sysinfo = {
|
||||
|
@ -62,3 +64,27 @@ int misc_init_r(void)
|
|||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
void do_set_mux(u32 base, struct pad_conf_entry const *array, int size)
|
||||
{
|
||||
int i;
|
||||
struct pad_conf_entry *pad = (struct pad_conf_entry *) array;
|
||||
|
||||
for (i = 0; i < size; i++, pad++)
|
||||
writew(pad->val, base + pad->offset);
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief set_muxconf_regs Setting up the configuration Mux registers
|
||||
* specific to the board.
|
||||
*/
|
||||
void set_muxconf_regs(void)
|
||||
{
|
||||
do_set_mux(CONTROL_PADCONF_CORE, core_padconf_array,
|
||||
sizeof(core_padconf_array) /
|
||||
sizeof(struct pad_conf_entry));
|
||||
|
||||
do_set_mux(CONTROL_PADCONF_WKUP, wkup_padconf_array,
|
||||
sizeof(wkup_padconf_array) /
|
||||
sizeof(struct pad_conf_entry));
|
||||
}
|
||||
|
|
265
board/ti/sdp4430/sdp.h
Normal file
265
board/ti/sdp4430/sdp.h
Normal file
|
@ -0,0 +1,265 @@
|
|||
/*
|
||||
* (C) Copyright 2010
|
||||
* Texas Instruments Incorporated, <www.ti.com>
|
||||
*
|
||||
* Balaji Krishnamoorthy <balajitk@ti.com>
|
||||
* Aneesh V <aneesh@ti.com>
|
||||
*
|
||||
* See file CREDITS for list of people who contributed to this
|
||||
* project.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
#ifndef _SDP_H_
|
||||
#define _SDP_H_
|
||||
|
||||
#include <asm/io.h>
|
||||
#include <asm/arch/mux_omap4.h>
|
||||
|
||||
const struct pad_conf_entry core_padconf_array[] = {
|
||||
{GPMC_AD0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat0 */
|
||||
{GPMC_AD1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat1 */
|
||||
{GPMC_AD2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat2 */
|
||||
{GPMC_AD3, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat3 */
|
||||
{GPMC_AD4, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat4 */
|
||||
{GPMC_AD5, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat5 */
|
||||
{GPMC_AD6, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat6 */
|
||||
{GPMC_AD7, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_dat7 */
|
||||
{GPMC_AD8, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M3)}, /* gpio_32 */
|
||||
{GPMC_AD9, (PTU | IEN | M3)}, /* gpio_33 */
|
||||
{GPMC_AD10, (PTU | IEN | M3)}, /* gpio_34 */
|
||||
{GPMC_AD11, (PTU | IEN | M3)}, /* gpio_35 */
|
||||
{GPMC_AD12, (PTU | IEN | M3)}, /* gpio_36 */
|
||||
{GPMC_AD13, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_37 */
|
||||
{GPMC_AD14, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_38 */
|
||||
{GPMC_AD15, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_39 */
|
||||
{GPMC_A16, (M3)}, /* gpio_40 */
|
||||
{GPMC_A17, (PTD | M3)}, /* gpio_41 */
|
||||
{GPMC_A18, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row6 */
|
||||
{GPMC_A19, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row7 */
|
||||
{GPMC_A20, (IEN | M3)}, /* gpio_44 */
|
||||
{GPMC_A21, (M3)}, /* gpio_45 */
|
||||
{GPMC_A22, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col6 */
|
||||
{GPMC_A23, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col7 */
|
||||
{GPMC_A24, (PTD | M3)}, /* gpio_48 */
|
||||
{GPMC_A25, (PTD | M3)}, /* gpio_49 */
|
||||
{GPMC_NCS0, (M3)}, /* gpio_50 */
|
||||
{GPMC_NCS1, (IEN | M3)}, /* gpio_51 */
|
||||
{GPMC_NCS2, (IEN | M3)}, /* gpio_52 */
|
||||
{GPMC_NCS3, (IEN | M3)}, /* gpio_53 */
|
||||
{GPMC_NWP, (M3)}, /* gpio_54 */
|
||||
{GPMC_CLK, (PTD | M3)}, /* gpio_55 */
|
||||
{GPMC_NADV_ALE, (M3)}, /* gpio_56 */
|
||||
{GPMC_NOE, (PTU | IEN | OFF_EN | OFF_OUT_PTD | M1)}, /* sdmmc2_clk */
|
||||
{GPMC_NWE, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* sdmmc2_cmd */
|
||||
{GPMC_NBE0_CLE, (M3)}, /* gpio_59 */
|
||||
{GPMC_NBE1, (PTD | M3)}, /* gpio_60 */
|
||||
{GPMC_WAIT0, (PTU | IEN | M3)}, /* gpio_61 */
|
||||
{GPMC_WAIT1, (IEN | M3)}, /* gpio_62 */
|
||||
{C2C_DATA11, (PTD | M3)}, /* gpio_100 */
|
||||
{C2C_DATA12, (M1)}, /* dsi1_te0 */
|
||||
{C2C_DATA13, (PTD | M3)}, /* gpio_102 */
|
||||
{C2C_DATA14, (M1)}, /* dsi2_te0 */
|
||||
{C2C_DATA15, (PTD | M3)}, /* gpio_104 */
|
||||
{HDMI_HPD, (M0)}, /* hdmi_hpd */
|
||||
{HDMI_CEC, (M0)}, /* hdmi_cec */
|
||||
{HDMI_DDC_SCL, (PTU | M0)}, /* hdmi_ddc_scl */
|
||||
{HDMI_DDC_SDA, (PTU | IEN | M0)}, /* hdmi_ddc_sda */
|
||||
{CSI21_DX0, (IEN | M0)}, /* csi21_dx0 */
|
||||
{CSI21_DY0, (IEN | M0)}, /* csi21_dy0 */
|
||||
{CSI21_DX1, (IEN | M0)}, /* csi21_dx1 */
|
||||
{CSI21_DY1, (IEN | M0)}, /* csi21_dy1 */
|
||||
{CSI21_DX2, (IEN | M0)}, /* csi21_dx2 */
|
||||
{CSI21_DY2, (IEN | M0)}, /* csi21_dy2 */
|
||||
{CSI21_DX3, (PTD | M7)}, /* csi21_dx3 */
|
||||
{CSI21_DY3, (PTD | M7)}, /* csi21_dy3 */
|
||||
{CSI21_DX4, (PTD | OFF_EN | OFF_PD | OFF_IN | M7)}, /* csi21_dx4 */
|
||||
{CSI21_DY4, (PTD | OFF_EN | OFF_PD | OFF_IN | M7)}, /* csi21_dy4 */
|
||||
{CSI22_DX0, (IEN | M0)}, /* csi22_dx0 */
|
||||
{CSI22_DY0, (IEN | M0)}, /* csi22_dy0 */
|
||||
{CSI22_DX1, (IEN | M0)}, /* csi22_dx1 */
|
||||
{CSI22_DY1, (IEN | M0)}, /* csi22_dy1 */
|
||||
{CAM_SHUTTER, (OFF_EN | OFF_PD | OFF_OUT_PTD | M0)}, /* cam_shutter */
|
||||
{CAM_STROBE, (OFF_EN | OFF_PD | OFF_OUT_PTD | M0)}, /* cam_strobe */
|
||||
{CAM_GLOBALRESET, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M3)}, /* gpio_83 */
|
||||
{USBB1_ULPITLL_CLK, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M4)},/* usbb1_ulpiphy_clk */
|
||||
{USBB1_ULPITLL_STP, (OFF_EN | OFF_OUT_PTD | M4)}, /* usbb1_ulpiphy_stp */
|
||||
{USBB1_ULPITLL_DIR, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dir */
|
||||
{USBB1_ULPITLL_NXT, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_nxt */
|
||||
{USBB1_ULPITLL_DAT0, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat0 */
|
||||
{USBB1_ULPITLL_DAT1, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat1 */
|
||||
{USBB1_ULPITLL_DAT2, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat2 */
|
||||
{USBB1_ULPITLL_DAT3, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat3 */
|
||||
{USBB1_ULPITLL_DAT4, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat4 */
|
||||
{USBB1_ULPITLL_DAT5, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat5 */
|
||||
{USBB1_ULPITLL_DAT6, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat6 */
|
||||
{USBB1_ULPITLL_DAT7, (IEN | OFF_EN | OFF_PD | OFF_IN | M4)}, /* usbb1_ulpiphy_dat7 */
|
||||
{USBB1_HSIC_DATA, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usbb1_hsic_data */
|
||||
{USBB1_HSIC_STROBE, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usbb1_hsic_strobe */
|
||||
{USBC1_ICUSB_DP, (IEN | M0)}, /* usbc1_icusb_dp */
|
||||
{USBC1_ICUSB_DM, (IEN | M0)}, /* usbc1_icusb_dm */
|
||||
{SDMMC1_CLK, (PTU | OFF_EN | OFF_OUT_PTD | M0)}, /* sdmmc1_clk */
|
||||
{SDMMC1_CMD, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_cmd */
|
||||
{SDMMC1_DAT0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat0 */
|
||||
{SDMMC1_DAT1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat1 */
|
||||
{SDMMC1_DAT2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat2 */
|
||||
{SDMMC1_DAT3, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat3 */
|
||||
{SDMMC1_DAT4, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat4 */
|
||||
{SDMMC1_DAT5, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat5 */
|
||||
{SDMMC1_DAT6, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat6 */
|
||||
{SDMMC1_DAT7, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc1_dat7 */
|
||||
{ABE_MCBSP2_CLKX, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_mcbsp2_clkx */
|
||||
{ABE_MCBSP2_DR, (IEN | OFF_EN | OFF_OUT_PTD | M0)}, /* abe_mcbsp2_dr */
|
||||
{ABE_MCBSP2_DX, (OFF_EN | OFF_OUT_PTD | M0)}, /* abe_mcbsp2_dx */
|
||||
{ABE_MCBSP2_FSX, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_mcbsp2_fsx */
|
||||
{ABE_MCBSP1_CLKX, (IEN | M1)}, /* abe_slimbus1_clock */
|
||||
{ABE_MCBSP1_DR, (IEN | M1)}, /* abe_slimbus1_data */
|
||||
{ABE_MCBSP1_DX, (OFF_EN | OFF_OUT_PTD | M0)}, /* abe_mcbsp1_dx */
|
||||
{ABE_MCBSP1_FSX, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_mcbsp1_fsx */
|
||||
{ABE_PDM_UL_DATA, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_ul_data */
|
||||
{ABE_PDM_DL_DATA, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_dl_data */
|
||||
{ABE_PDM_FRAME, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_frame */
|
||||
{ABE_PDM_LB_CLK, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_pdm_lb_clk */
|
||||
{ABE_CLKS, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* abe_clks */
|
||||
{ABE_DMIC_CLK1, (M0)}, /* abe_dmic_clk1 */
|
||||
{ABE_DMIC_DIN1, (IEN | M0)}, /* abe_dmic_din1 */
|
||||
{ABE_DMIC_DIN2, (IEN | M0)}, /* abe_dmic_din2 */
|
||||
{ABE_DMIC_DIN3, (IEN | M0)}, /* abe_dmic_din3 */
|
||||
{UART2_CTS, (PTU | IEN | M0)}, /* uart2_cts */
|
||||
{UART2_RTS, (M0)}, /* uart2_rts */
|
||||
{UART2_RX, (PTU | IEN | M0)}, /* uart2_rx */
|
||||
{UART2_TX, (M0)}, /* uart2_tx */
|
||||
{HDQ_SIO, (M3)}, /* gpio_127 */
|
||||
{I2C1_SCL, (PTU | IEN | M0)}, /* i2c1_scl */
|
||||
{I2C1_SDA, (PTU | IEN | M0)}, /* i2c1_sda */
|
||||
{I2C2_SCL, (PTU | IEN | M0)}, /* i2c2_scl */
|
||||
{I2C2_SDA, (PTU | IEN | M0)}, /* i2c2_sda */
|
||||
{I2C3_SCL, (PTU | IEN | M0)}, /* i2c3_scl */
|
||||
{I2C3_SDA, (PTU | IEN | M0)}, /* i2c3_sda */
|
||||
{I2C4_SCL, (PTU | IEN | M0)}, /* i2c4_scl */
|
||||
{I2C4_SDA, (PTU | IEN | M0)}, /* i2c4_sda */
|
||||
{MCSPI1_CLK, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_clk */
|
||||
{MCSPI1_SOMI, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_somi */
|
||||
{MCSPI1_SIMO, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_simo */
|
||||
{MCSPI1_CS0, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi1_cs0 */
|
||||
{MCSPI1_CS1, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M3)}, /* mcspi1_cs1 */
|
||||
{MCSPI1_CS2, (PTU | OFF_EN | OFF_OUT_PTU | M3)}, /* gpio_139 */
|
||||
{MCSPI1_CS3, (PTU | IEN | M3)}, /* gpio_140 */
|
||||
{UART3_CTS_RCTX, (PTU | IEN | M0)}, /* uart3_tx */
|
||||
{UART3_RTS_SD, (M0)}, /* uart3_rts_sd */
|
||||
{UART3_RX_IRRX, (IEN | M0)}, /* uart3_rx */
|
||||
{UART3_TX_IRTX, (M0)}, /* uart3_tx */
|
||||
{SDMMC5_CLK, (PTU | IEN | OFF_EN | OFF_OUT_PTD | M0)}, /* sdmmc5_clk */
|
||||
{SDMMC5_CMD, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_cmd */
|
||||
{SDMMC5_DAT0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat0 */
|
||||
{SDMMC5_DAT1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat1 */
|
||||
{SDMMC5_DAT2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat2 */
|
||||
{SDMMC5_DAT3, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* sdmmc5_dat3 */
|
||||
{MCSPI4_CLK, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_clk */
|
||||
{MCSPI4_SIMO, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_simo */
|
||||
{MCSPI4_SOMI, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_somi */
|
||||
{MCSPI4_CS0, (PTD | IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* mcspi4_cs0 */
|
||||
{UART4_RX, (IEN | M0)}, /* uart4_rx */
|
||||
{UART4_TX, (M0)}, /* uart4_tx */
|
||||
{USBB2_ULPITLL_CLK, (IEN | M3)}, /* gpio_157 */
|
||||
{USBB2_ULPITLL_STP, (IEN | M5)}, /* dispc2_data23 */
|
||||
{USBB2_ULPITLL_DIR, (IEN | M5)}, /* dispc2_data22 */
|
||||
{USBB2_ULPITLL_NXT, (IEN | M5)}, /* dispc2_data21 */
|
||||
{USBB2_ULPITLL_DAT0, (IEN | M5)}, /* dispc2_data20 */
|
||||
{USBB2_ULPITLL_DAT1, (IEN | M5)}, /* dispc2_data19 */
|
||||
{USBB2_ULPITLL_DAT2, (IEN | M5)}, /* dispc2_data18 */
|
||||
{USBB2_ULPITLL_DAT3, (IEN | M5)}, /* dispc2_data15 */
|
||||
{USBB2_ULPITLL_DAT4, (IEN | M5)}, /* dispc2_data14 */
|
||||
{USBB2_ULPITLL_DAT5, (IEN | M5)}, /* dispc2_data13 */
|
||||
{USBB2_ULPITLL_DAT6, (IEN | M5)}, /* dispc2_data12 */
|
||||
{USBB2_ULPITLL_DAT7, (IEN | M5)}, /* dispc2_data11 */
|
||||
{USBB2_HSIC_DATA, (PTD | OFF_EN | OFF_OUT_PTU | M3)}, /* gpio_169 */
|
||||
{USBB2_HSIC_STROBE, (PTD | OFF_EN | OFF_OUT_PTU | M3)}, /* gpio_170 */
|
||||
{UNIPRO_TX0, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col0 */
|
||||
{UNIPRO_TY0, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col1 */
|
||||
{UNIPRO_TX1, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col2 */
|
||||
{UNIPRO_TY1, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col3 */
|
||||
{UNIPRO_TX2, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col4 */
|
||||
{UNIPRO_TY2, (OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_col5 */
|
||||
{UNIPRO_RX0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row0 */
|
||||
{UNIPRO_RY0, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row1 */
|
||||
{UNIPRO_RX1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row2 */
|
||||
{UNIPRO_RY1, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row3 */
|
||||
{UNIPRO_RX2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row4 */
|
||||
{UNIPRO_RY2, (PTU | IEN | OFF_EN | OFF_PD | OFF_IN | M1)}, /* kpd_row5 */
|
||||
{USBA0_OTG_CE, (PTD | OFF_EN | OFF_PD | OFF_OUT_PTD | M0)}, /* usba0_otg_ce */
|
||||
{USBA0_OTG_DP, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usba0_otg_dp */
|
||||
{USBA0_OTG_DM, (IEN | OFF_EN | OFF_PD | OFF_IN | M0)}, /* usba0_otg_dm */
|
||||
{FREF_CLK1_OUT, (M0)}, /* fref_clk1_out */
|
||||
{FREF_CLK2_OUT, (M0)}, /* fref_clk2_out */
|
||||
{SYS_NIRQ1, (PTU | IEN | M0)}, /* sys_nirq1 */
|
||||
{SYS_NIRQ2, (PTU | IEN | M0)}, /* sys_nirq2 */
|
||||
{SYS_BOOT0, (PTU | IEN | M3)}, /* gpio_184 */
|
||||
{SYS_BOOT1, (M3)}, /* gpio_185 */
|
||||
{SYS_BOOT2, (PTD | IEN | M3)}, /* gpio_186 */
|
||||
{SYS_BOOT3, (M3)}, /* gpio_187 */
|
||||
{SYS_BOOT4, (M3)}, /* gpio_188 */
|
||||
{SYS_BOOT5, (PTD | IEN | M3)}, /* gpio_189 */
|
||||
{DPM_EMU0, (IEN | M0)}, /* dpm_emu0 */
|
||||
{DPM_EMU1, (IEN | M0)}, /* dpm_emu1 */
|
||||
{DPM_EMU2, (IEN | M0)}, /* dpm_emu2 */
|
||||
{DPM_EMU3, (IEN | M5)}, /* dispc2_data10 */
|
||||
{DPM_EMU4, (IEN | M5)}, /* dispc2_data9 */
|
||||
{DPM_EMU5, (IEN | M5)}, /* dispc2_data16 */
|
||||
{DPM_EMU6, (IEN | M5)}, /* dispc2_data17 */
|
||||
{DPM_EMU7, (IEN | M5)}, /* dispc2_hsync */
|
||||
{DPM_EMU8, (IEN | M5)}, /* dispc2_pclk */
|
||||
{DPM_EMU9, (IEN | M5)}, /* dispc2_vsync */
|
||||
{DPM_EMU10, (IEN | M5)}, /* dispc2_de */
|
||||
{DPM_EMU11, (IEN | M5)}, /* dispc2_data8 */
|
||||
{DPM_EMU12, (IEN | M5)}, /* dispc2_data7 */
|
||||
{DPM_EMU13, (IEN | M5)}, /* dispc2_data6 */
|
||||
{DPM_EMU14, (IEN | M5)}, /* dispc2_data5 */
|
||||
{DPM_EMU15, (IEN | M5)}, /* dispc2_data4 */
|
||||
{DPM_EMU16, (M3)}, /* gpio_27 */
|
||||
{DPM_EMU17, (IEN | M5)}, /* dispc2_data2 */
|
||||
{DPM_EMU18, (IEN | M5)}, /* dispc2_data1 */
|
||||
{DPM_EMU19, (IEN | M5)}, /* dispc2_data0 */
|
||||
};
|
||||
|
||||
const struct pad_conf_entry wkup_padconf_array[] = {
|
||||
{PAD0_SIM_IO, (IEN | M0)}, /* sim_io */
|
||||
{PAD1_SIM_CLK, (M0)}, /* sim_clk */
|
||||
{PAD0_SIM_RESET, (M0)}, /* sim_reset */
|
||||
{PAD1_SIM_CD, (PTU | IEN | M0)}, /* sim_cd */
|
||||
{PAD0_SIM_PWRCTRL, (M0)}, /* sim_pwrctrl */
|
||||
{PAD1_SR_SCL, (PTU | IEN | M0)}, /* sr_scl */
|
||||
{PAD0_SR_SDA, (PTU | IEN | M0)}, /* sr_sda */
|
||||
{PAD1_FREF_XTAL_IN, (M0)}, /* # */
|
||||
{PAD0_FREF_SLICER_IN, (M0)}, /* fref_slicer_in */
|
||||
{PAD1_FREF_CLK_IOREQ, (M0)}, /* fref_clk_ioreq */
|
||||
{PAD0_FREF_CLK0_OUT, (M2)}, /* sys_drm_msecure */
|
||||
{PAD1_FREF_CLK3_REQ, (PTU | IEN | M0)}, /* # */
|
||||
{PAD0_FREF_CLK3_OUT, (M0)}, /* fref_clk3_out */
|
||||
{PAD1_FREF_CLK4_REQ, (PTU | IEN | M0)}, /* # */
|
||||
{PAD0_FREF_CLK4_OUT, (M0)}, /* # */
|
||||
{PAD1_SYS_32K, (IEN | M0)}, /* sys_32k */
|
||||
{PAD0_SYS_NRESPWRON, (M0)}, /* sys_nrespwron */
|
||||
{PAD1_SYS_NRESWARM, (M0)}, /* sys_nreswarm */
|
||||
{PAD0_SYS_PWR_REQ, (PTU | M0)}, /* sys_pwr_req */
|
||||
{PAD1_SYS_PWRON_RESET, (M3)}, /* gpio_wk29 */
|
||||
{PAD0_SYS_BOOT6, (IEN | M3)}, /* gpio_wk9 */
|
||||
{PAD1_SYS_BOOT7, (IEN | M3)}, /* gpio_wk10 */
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
@ -27,6 +27,8 @@
|
|||
|
||||
#include "omap24xx_i2c.h"
|
||||
|
||||
#define I2C_TIMEOUT 10
|
||||
|
||||
static void wait_for_bb (void);
|
||||
static u16 wait_for_pin (void);
|
||||
static void flush_fifo(void);
|
||||
|
@ -41,6 +43,7 @@ void i2c_init (int speed, int slaveadd)
|
|||
int psc, fsscll, fssclh;
|
||||
int hsscll = 0, hssclh = 0;
|
||||
u32 scll, sclh;
|
||||
int timeout = I2C_TIMEOUT;
|
||||
|
||||
/* Only handle standard, fast and high speeds */
|
||||
if ((speed != OMAP_I2C_STANDARD) &&
|
||||
|
@ -102,15 +105,24 @@ void i2c_init (int speed, int slaveadd)
|
|||
sclh = (unsigned int)fssclh;
|
||||
}
|
||||
|
||||
writew(0x2, &i2c_base->sysc); /* for ES2 after soft reset */
|
||||
udelay(1000);
|
||||
writew(0x0, &i2c_base->sysc); /* will probably self clear but */
|
||||
|
||||
if (readw (&i2c_base->con) & I2C_CON_EN) {
|
||||
writew (0, &i2c_base->con);
|
||||
udelay (50000);
|
||||
}
|
||||
|
||||
writew(0x2, &i2c_base->sysc); /* for ES2 after soft reset */
|
||||
udelay(1000);
|
||||
|
||||
writew(I2C_CON_EN, &i2c_base->con);
|
||||
while (!(readw(&i2c_base->syss) & I2C_SYSS_RDONE) && timeout--) {
|
||||
if (timeout <= 0) {
|
||||
printf("ERROR: Timeout in soft-reset\n");
|
||||
return;
|
||||
}
|
||||
udelay(1000);
|
||||
}
|
||||
|
||||
writew(0, &i2c_base->con);
|
||||
writew(psc, &i2c_base->psc);
|
||||
writew(scll, &i2c_base->scll);
|
||||
writew(sclh, &i2c_base->sclh);
|
||||
|
@ -159,15 +171,14 @@ static int i2c_read_byte (u8 devaddr, u8 regoffset, u8 * value)
|
|||
}
|
||||
|
||||
if (!i2c_error) {
|
||||
/* free bus, otherwise we can't use a combined transction */
|
||||
writew (0, &i2c_base->con);
|
||||
while (readw (&i2c_base->stat) || (readw (&i2c_base->con) & I2C_CON_MST)) {
|
||||
writew (I2C_CON_EN, &i2c_base->con);
|
||||
while (readw(&i2c_base->stat) &
|
||||
(I2C_STAT_XRDY | I2C_STAT_ARDY)) {
|
||||
udelay (10000);
|
||||
/* Have to clear pending interrupt to clear I2C_STAT */
|
||||
writew (0xFFFF, &i2c_base->stat);
|
||||
}
|
||||
|
||||
wait_for_bb ();
|
||||
/* set slave address */
|
||||
writew (devaddr, &i2c_base->sa);
|
||||
/* read one byte from slave */
|
||||
|
@ -191,8 +202,8 @@ static int i2c_read_byte (u8 devaddr, u8 regoffset, u8 * value)
|
|||
|
||||
if (!i2c_error) {
|
||||
writew (I2C_CON_EN, &i2c_base->con);
|
||||
while (readw (&i2c_base->stat)
|
||||
|| (readw (&i2c_base->con) & I2C_CON_MST)) {
|
||||
while (readw (&i2c_base->stat) &
|
||||
(I2C_STAT_RRDY | I2C_STAT_ARDY)) {
|
||||
udelay (10000);
|
||||
writew (0xFFFF, &i2c_base->stat);
|
||||
}
|
||||
|
|
|
@ -85,6 +85,10 @@
|
|||
#define I2C_SYSTEST_SDA_I (1 << 1) /* SDA line sense input value */
|
||||
#define I2C_SYSTEST_SDA_O (1 << 0) /* SDA line drive output value */
|
||||
|
||||
/* I2C System Status Register (I2C_SYSS): */
|
||||
|
||||
#define I2C_SYSS_RDONE (1 << 0) /* Internel reset monitoring */
|
||||
|
||||
#define I2C_SCLL_SCLL 0
|
||||
#define I2C_SCLL_SCLL_M 0xFF
|
||||
#define I2C_SCLL_HSSCLL 8
|
||||
|
|
|
@ -26,6 +26,7 @@ include $(TOPDIR)/config.mk
|
|||
LIB := $(obj)libpower.a
|
||||
|
||||
COBJS-$(CONFIG_TWL4030_POWER) += twl4030.o
|
||||
COBJS-$(CONFIG_TWL6030_POWER) += twl6030.o
|
||||
|
||||
COBJS := $(COBJS-y)
|
||||
SRCS := $(COBJS:.o=.c)
|
||||
|
|
78
drivers/power/twl6030.c
Normal file
78
drivers/power/twl6030.c
Normal file
|
@ -0,0 +1,78 @@
|
|||
/*
|
||||
* (C) Copyright 2010
|
||||
* Texas Instruments, <www.ti.com>
|
||||
*
|
||||
* See file CREDITS for list of people who contributed to this
|
||||
* project.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*/
|
||||
#include <config.h>
|
||||
#ifdef CONFIG_TWL6030_POWER
|
||||
|
||||
#include <twl6030.h>
|
||||
|
||||
/* Functions to read and write from TWL6030 */
|
||||
static inline int twl6030_i2c_write_u8(u8 chip_no, u8 val, u8 reg)
|
||||
{
|
||||
return i2c_write(chip_no, reg, 1, &val, 1);
|
||||
}
|
||||
|
||||
static inline int twl6030_i2c_read_u8(u8 chip_no, u8 *val, u8 reg)
|
||||
{
|
||||
return i2c_read(chip_no, reg, 1, val, 1);
|
||||
}
|
||||
|
||||
void twl6030_start_usb_charging(void)
|
||||
{
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_CHARGER, CHARGERUSB_VICHRG_1500,
|
||||
CHARGERUSB_VICHRG);
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_CHARGER, CHARGERUSB_CIN_LIMIT_NONE,
|
||||
CHARGERUSB_CINLIMIT);
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_CHARGER, MBAT_TEMP,
|
||||
CONTROLLER_INT_MASK);
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_CHARGER, MASK_MCHARGERUSB_THMREG,
|
||||
CHARGERUSB_INT_MASK);
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_CHARGER, CHARGERUSB_VOREG_4P0,
|
||||
CHARGERUSB_VOREG);
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_CHARGER, CHARGERUSB_CTRL2_VITERM_100,
|
||||
CHARGERUSB_CTRL2);
|
||||
/* Enable USB charging */
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_CHARGER, CONTROLLER_CTRL1_EN_CHARGER,
|
||||
CONTROLLER_CTRL1);
|
||||
return;
|
||||
}
|
||||
|
||||
void twl6030_init_battery_charging(void)
|
||||
{
|
||||
twl6030_start_usb_charging();
|
||||
return;
|
||||
}
|
||||
|
||||
void twl6030_usb_device_settings()
|
||||
{
|
||||
u8 data = 0;
|
||||
|
||||
/* Select APP Group and set state to ON */
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_PM, 0x21, VUSB_CFG_STATE);
|
||||
|
||||
twl6030_i2c_read_u8(TWL6030_CHIP_PM, &data, MISC2);
|
||||
data |= 0x10;
|
||||
|
||||
/* Select the input supply for VBUS regulator */
|
||||
twl6030_i2c_write_u8(TWL6030_CHIP_PM, data, MISC2);
|
||||
}
|
||||
#endif
|
|
@ -31,6 +31,7 @@
|
|||
*/
|
||||
|
||||
#include <twl4030.h>
|
||||
#include <twl6030.h>
|
||||
#include "omap3.h"
|
||||
|
||||
static int platform_needs_initialization = 1;
|
||||
|
@ -65,7 +66,12 @@ static struct omap3_otg_regs *otg;
|
|||
|
||||
#define OMAP3_OTG_SYSSTATUS_RESETDONE 0x0001
|
||||
|
||||
/* OMAP4430 has an internal PHY, use it */
|
||||
#ifdef CONFIG_OMAP4430
|
||||
#define OMAP3_OTG_INTERFSEL_OMAP 0x0000
|
||||
#else
|
||||
#define OMAP3_OTG_INTERFSEL_OMAP 0x0001
|
||||
#endif
|
||||
|
||||
#define OMAP3_OTG_FORCESTDBY_STANDBY 0x0001
|
||||
|
||||
|
@ -105,6 +111,11 @@ int musb_platform_init(void)
|
|||
goto end;
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_TWL6030_POWER
|
||||
twl6030_usb_device_settings();
|
||||
#endif
|
||||
|
||||
otg = (struct omap3_otg_regs *)OMAP3_OTG_BASE;
|
||||
|
||||
/* Set OTG to always be on */
|
||||
|
@ -122,6 +133,11 @@ int musb_platform_init(void)
|
|||
#ifdef CONFIG_OMAP3_EVM
|
||||
musb_cfg.extvbus = omap3_evm_need_extvbus();
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_OMAP4430
|
||||
u32 *usbotghs_control = (u32 *)(CTRL_BASE + 0x33C);
|
||||
*usbotghs_control = 0x15;
|
||||
#endif
|
||||
platform_needs_initialization = 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -31,10 +31,11 @@
|
|||
#ifndef _MUSB_OMAP3_H_
|
||||
#define _MUSB_OMAP3_H_
|
||||
|
||||
#include <asm/arch/cpu.h>
|
||||
#include "musb_core.h"
|
||||
|
||||
/* Base address of MUSB registers */
|
||||
#define MENTOR_USB0_BASE (OMAP34XX_CORE_L4_IO_BASE + 0xAB000)
|
||||
#define MENTOR_USB0_BASE MUSB_BASE
|
||||
|
||||
/* Base address of OTG registers */
|
||||
#define OMAP3_OTG_BASE (MENTOR_USB0_BASE + 0x400)
|
||||
|
|
|
@ -35,6 +35,7 @@
|
|||
#define CONFIG_OMAP44XX 1 /* which is a 44XX */
|
||||
#define CONFIG_OMAP4430 1 /* which is in a 4430 */
|
||||
#define CONFIG_PANDA 1 /* working with Panda */
|
||||
#define CONFIG_ARCH_CPU_INIT
|
||||
|
||||
/* Get CPU defs */
|
||||
#include <asm/arch/cpu.h>
|
||||
|
@ -102,12 +103,29 @@
|
|||
#define CONFIG_DRIVER_OMAP34XX_I2C 1
|
||||
#define CONFIG_I2C_MULTI_BUS 1
|
||||
|
||||
/* TWL6030 */
|
||||
#define CONFIG_TWL6030_POWER 1
|
||||
|
||||
/* MMC */
|
||||
#define CONFIG_MMC 1
|
||||
#define CONFIG_OMAP3_MMC 1
|
||||
#define CONFIG_SYS_MMC_SET_DEV 1
|
||||
#define CONFIG_DOS_PARTITION 1
|
||||
|
||||
/* USB */
|
||||
#define CONFIG_MUSB_UDC 1
|
||||
#define CONFIG_USB_OMAP3 1
|
||||
|
||||
/* USB device configuration */
|
||||
#define CONFIG_USB_DEVICE 1
|
||||
#define CONFIG_USB_TTY 1
|
||||
#define CONFIG_SYS_CONSOLE_IS_IN_ENV 1
|
||||
/* Change these to suit your needs */
|
||||
#define CONFIG_USBD_VENDORID 0x0451
|
||||
#define CONFIG_USBD_PRODUCTID 0x5678
|
||||
#define CONFIG_USBD_MANUFACTURER "Texas Instruments"
|
||||
#define CONFIG_USBD_PRODUCT_NAME "OMAP4 Panda"
|
||||
|
||||
/* Flash */
|
||||
#define CONFIG_SYS_NO_FLASH 1
|
||||
|
||||
|
@ -135,16 +153,21 @@
|
|||
* Environment setup
|
||||
*/
|
||||
|
||||
#define CONFIG_BOOTDELAY 3
|
||||
|
||||
/* allow overwriting serial config and ethaddr */
|
||||
#define CONFIG_ENV_OVERWRITE
|
||||
|
||||
#define CONFIG_EXTRA_ENV_SETTINGS \
|
||||
"loadaddr=0x82000000\0" \
|
||||
"console=ttyS2,115200n8\0" \
|
||||
"usbtty=cdc_acm\0" \
|
||||
"vram=16M\0" \
|
||||
"mmcdev=1\0" \
|
||||
"mmcroot=/dev/mmcblk0p2 rw\0" \
|
||||
"mmcrootfstype=ext3 rootwait\0" \
|
||||
"mmcargs=setenv bootargs console=${console} " \
|
||||
"vram=${vram} " \
|
||||
"root=${mmcroot} " \
|
||||
"rootfstype=${mmcrootfstype}\0" \
|
||||
"loadbootscript=fatload mmc ${mmcdev} ${loadaddr} boot.scr\0" \
|
||||
|
@ -162,7 +185,6 @@
|
|||
"else " \
|
||||
"if run loaduimage; then " \
|
||||
"run mmcboot; " \
|
||||
"else run nandboot; " \
|
||||
"fi; " \
|
||||
"fi; " \
|
||||
"fi"
|
||||
|
@ -195,7 +217,7 @@
|
|||
#define CONFIG_SYS_LOAD_ADDR 0x80000000
|
||||
|
||||
/* Use General purpose timer 1 */
|
||||
#define CONFIG_SYS_TIMERBASE GPT1_BASE
|
||||
#define CONFIG_SYS_TIMERBASE GPT2_BASE
|
||||
#define CONFIG_SYS_PTV 2 /* Divisor: 2^(PTV+1) => 8 */
|
||||
#define CONFIG_SYS_HZ 1000
|
||||
|
||||
|
|
|
@ -36,6 +36,7 @@
|
|||
#define CONFIG_OMAP44XX 1 /* which is a 44XX */
|
||||
#define CONFIG_OMAP4430 1 /* which is in a 4430 */
|
||||
#define CONFIG_4430SDP 1 /* working with SDP */
|
||||
#define CONFIG_ARCH_CPU_INIT
|
||||
|
||||
/* Get CPU defs */
|
||||
#include <asm/arch/cpu.h>
|
||||
|
@ -103,12 +104,29 @@
|
|||
#define CONFIG_DRIVER_OMAP34XX_I2C 1
|
||||
#define CONFIG_I2C_MULTI_BUS 1
|
||||
|
||||
/* TWL6030 */
|
||||
#define CONFIG_TWL6030_POWER 1
|
||||
|
||||
/* MMC */
|
||||
#define CONFIG_MMC 1
|
||||
#define CONFIG_OMAP3_MMC 1
|
||||
#define CONFIG_SYS_MMC_SET_DEV 1
|
||||
#define CONFIG_DOS_PARTITION 1
|
||||
|
||||
/* USB */
|
||||
#define CONFIG_MUSB_UDC 1
|
||||
#define CONFIG_USB_OMAP3 1
|
||||
|
||||
/* USB device configuration */
|
||||
#define CONFIG_USB_DEVICE 1
|
||||
#define CONFIG_USB_TTY 1
|
||||
#define CONFIG_SYS_CONSOLE_IS_IN_ENV 1
|
||||
/* Change these to suit your needs */
|
||||
#define CONFIG_USBD_VENDORID 0x0451
|
||||
#define CONFIG_USBD_PRODUCTID 0x5678
|
||||
#define CONFIG_USBD_MANUFACTURER "Texas Instruments"
|
||||
#define CONFIG_USBD_PRODUCT_NAME "SDP4430"
|
||||
|
||||
/* Flash */
|
||||
#define CONFIG_SYS_NO_FLASH 1
|
||||
|
||||
|
@ -136,16 +154,21 @@
|
|||
* Environment setup
|
||||
*/
|
||||
|
||||
#define CONFIG_BOOTDELAY 3
|
||||
|
||||
/* allow overwriting serial config and ethaddr */
|
||||
#define CONFIG_ENV_OVERWRITE
|
||||
|
||||
#define CONFIG_EXTRA_ENV_SETTINGS \
|
||||
"loadaddr=0x82000000\0" \
|
||||
"console=ttyS2,115200n8\0" \
|
||||
"usbtty=cdc_acm\0" \
|
||||
"vram=16M\0" \
|
||||
"mmcdev=1\0" \
|
||||
"mmcroot=/dev/mmcblk0p2 rw\0" \
|
||||
"mmcrootfstype=ext3 rootwait\0" \
|
||||
"mmcargs=setenv bootargs console=${console} " \
|
||||
"vram=${vram} " \
|
||||
"root=${mmcroot} " \
|
||||
"rootfstype=${mmcrootfstype}\0" \
|
||||
"loadbootscript=fatload mmc ${mmcdev} ${loadaddr} boot.scr\0" \
|
||||
|
@ -163,7 +186,6 @@
|
|||
"else " \
|
||||
"if run loaduimage; then " \
|
||||
"run mmcboot; " \
|
||||
"else run nandboot; " \
|
||||
"fi; " \
|
||||
"fi; " \
|
||||
"fi"
|
||||
|
@ -196,7 +218,7 @@
|
|||
#define CONFIG_SYS_LOAD_ADDR 0x80000000
|
||||
|
||||
/* Use General purpose timer 1 */
|
||||
#define CONFIG_SYS_TIMERBASE GPT1_BASE
|
||||
#define CONFIG_SYS_TIMERBASE GPT2_BASE
|
||||
#define CONFIG_SYS_PTV 2 /* Divisor: 2^(PTV+1) => 8 */
|
||||
#define CONFIG_SYS_HZ 1000
|
||||
|
||||
|
|
91
include/twl6030.h
Normal file
91
include/twl6030.h
Normal file
|
@ -0,0 +1,91 @@
|
|||
/*
|
||||
* (C) Copyright 2010
|
||||
* Texas Instruments, <www.ti.com>
|
||||
*
|
||||
* See file CREDITS for list of people who contributed to this
|
||||
* project.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program; if not, write to the Free Software
|
||||
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||||
* MA 02111-1307 USA
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
#include <i2c.h>
|
||||
|
||||
/* I2C chip addresses */
|
||||
#define TWL6030_CHIP_PM 0x48
|
||||
|
||||
#define TWL6030_CHIP_USB 0x49
|
||||
#define TWL6030_CHIP_ADC 0x49
|
||||
#define TWL6030_CHIP_CHARGER 0x49
|
||||
#define TWL6030_CHIP_PWM 0x49
|
||||
|
||||
/* Battery CHARGER REGISTERS */
|
||||
#define CONTROLLER_INT_MASK 0xE0
|
||||
#define CONTROLLER_CTRL1 0xE1
|
||||
#define CONTROLLER_WDG 0xE2
|
||||
#define CONTROLLER_STAT1 0xE3
|
||||
#define CHARGERUSB_INT_STATUS 0xE4
|
||||
#define CHARGERUSB_INT_MASK 0xE5
|
||||
#define CHARGERUSB_STATUS_INT1 0xE6
|
||||
#define CHARGERUSB_STATUS_INT2 0xE7
|
||||
#define CHARGERUSB_CTRL1 0xE8
|
||||
#define CHARGERUSB_CTRL2 0xE9
|
||||
#define CHARGERUSB_CTRL3 0xEA
|
||||
#define CHARGERUSB_STAT1 0xEB
|
||||
#define CHARGERUSB_VOREG 0xEC
|
||||
#define CHARGERUSB_VICHRG 0xED
|
||||
#define CHARGERUSB_CINLIMIT 0xEE
|
||||
#define CHARGERUSB_CTRLLIMIT1 0xEF
|
||||
|
||||
/* CHARGERUSB_VICHRG */
|
||||
#define CHARGERUSB_VICHRG_500 0x4
|
||||
#define CHARGERUSB_VICHRG_1500 0xE
|
||||
/* CHARGERUSB_CINLIMIT */
|
||||
#define CHARGERUSB_CIN_LIMIT_100 0x1
|
||||
#define CHARGERUSB_CIN_LIMIT_300 0x5
|
||||
#define CHARGERUSB_CIN_LIMIT_500 0x9
|
||||
#define CHARGERUSB_CIN_LIMIT_NONE 0xF
|
||||
/* CONTROLLER_INT_MASK */
|
||||
#define MVAC_FAULT (1 << 6)
|
||||
#define MAC_EOC (1 << 5)
|
||||
#define MBAT_REMOVED (1 << 4)
|
||||
#define MFAULT_WDG (1 << 3)
|
||||
#define MBAT_TEMP (1 << 2)
|
||||
#define MVBUS_DET (1 << 1)
|
||||
#define MVAC_DET (1 << 0)
|
||||
/* CHARGERUSB_INT_MASK */
|
||||
#define MASK_MCURRENT_TERM (1 << 3)
|
||||
#define MASK_MCHARGERUSB_STAT (1 << 2)
|
||||
#define MASK_MCHARGERUSB_THMREG (1 << 1)
|
||||
#define MASK_MCHARGERUSB_FAULT (1 << 0)
|
||||
/* CHARGERUSB_VOREG */
|
||||
#define CHARGERUSB_VOREG_3P52 0x01
|
||||
#define CHARGERUSB_VOREG_4P0 0x19
|
||||
#define CHARGERUSB_VOREG_4P2 0x23
|
||||
#define CHARGERUSB_VOREG_4P76 0x3F
|
||||
/* CHARGERUSB_CTRL2 */
|
||||
#define CHARGERUSB_CTRL2_VITERM_50 (0 << 5)
|
||||
#define CHARGERUSB_CTRL2_VITERM_100 (1 << 5)
|
||||
#define CHARGERUSB_CTRL2_VITERM_150 (2 << 5)
|
||||
/* CONTROLLER_CTRL1 */
|
||||
#define CONTROLLER_CTRL1_EN_CHARGER (1 << 4)
|
||||
#define CONTROLLER_CTRL1_SEL_CHARGER (1 << 3)
|
||||
|
||||
#define VUSB_CFG_STATE 0xA2
|
||||
#define MISC2 0xE5
|
||||
|
||||
void twl6030_init_battery_charging(void);
|
||||
void twl6030_usb_device_settings(void);
|
Loading…
Reference in a new issue