2011-02-09 12:47:47 +00:00
|
|
|
/*
|
|
|
|
* (C) Copyright 2011
|
|
|
|
* Marvell Semiconductor <www.marvell.com>
|
|
|
|
* Written-by: Lei Wen <leiwen@marvell.com>
|
|
|
|
*
|
2013-07-08 07:37:19 +00:00
|
|
|
* SPDX-License-Identifier: GPL-2.0+
|
2011-02-09 12:47:47 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <common.h>
|
|
|
|
#include <mvmfp.h>
|
2011-10-03 20:33:42 +00:00
|
|
|
#include <i2c.h>
|
2011-02-09 12:47:47 +00:00
|
|
|
#include <asm/arch/mfp.h>
|
|
|
|
#include <asm/arch/cpu.h>
|
2011-10-03 20:33:42 +00:00
|
|
|
#ifdef CONFIG_GENERIC_MMC
|
|
|
|
#include <sdhci.h>
|
|
|
|
#endif
|
2011-02-09 12:47:47 +00:00
|
|
|
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
|
|
|
|
int board_early_init_f(void)
|
|
|
|
{
|
|
|
|
u32 mfp_cfg[] = {
|
|
|
|
/* Enable Console on UART2 */
|
|
|
|
MFP47_UART2_RXD,
|
|
|
|
MFP48_UART2_TXD,
|
|
|
|
|
2011-04-13 18:18:34 +00:00
|
|
|
/* I2C */
|
|
|
|
MFP53_CI2C_SCL,
|
|
|
|
MFP54_CI2C_SDA,
|
|
|
|
|
2011-10-03 20:33:42 +00:00
|
|
|
/* MMC1 */
|
|
|
|
MFP_MMC1_DAT7,
|
|
|
|
MFP_MMC1_DAT6,
|
|
|
|
MFP_MMC1_DAT5,
|
|
|
|
MFP_MMC1_DAT4,
|
|
|
|
MFP_MMC1_DAT3,
|
|
|
|
MFP_MMC1_DAT2,
|
|
|
|
MFP_MMC1_DAT1,
|
|
|
|
MFP_MMC1_DAT0,
|
|
|
|
MFP_MMC1_CMD,
|
|
|
|
MFP_MMC1_CLK,
|
|
|
|
MFP_MMC1_CD,
|
|
|
|
MFP_MMC1_WP,
|
|
|
|
|
2011-02-09 12:47:47 +00:00
|
|
|
MFP_EOC /*End of configureation*/
|
|
|
|
};
|
|
|
|
/* configure MFP's */
|
|
|
|
mfp_config(mfp_cfg);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int board_init(void)
|
|
|
|
{
|
|
|
|
/* arch number of Board */
|
|
|
|
gd->bd->bi_arch_number = MACH_TYPE_TTC_DKB;
|
|
|
|
/* adress of boot parameters */
|
|
|
|
gd->bd->bi_boot_params = panth_sdram_base(0) + 0x100;
|
|
|
|
return 0;
|
|
|
|
}
|
2011-10-03 20:33:42 +00:00
|
|
|
|
|
|
|
#ifdef CONFIG_GENERIC_MMC
|
|
|
|
#define I2C_SLAVE_ADDR 0x34
|
|
|
|
#define LDO13_REG 0x28
|
|
|
|
#define LDO_V30 0x6
|
|
|
|
#define LDO_VOLTAGE(x) ((x & 0x7) << 1)
|
|
|
|
#define LDO_EN 0x1
|
|
|
|
int board_mmc_init(bd_t *bd)
|
|
|
|
{
|
|
|
|
ulong mmc_base_address[CONFIG_SYS_MMC_NUM] = CONFIG_SYS_MMC_BASE;
|
|
|
|
u8 i, data;
|
|
|
|
|
|
|
|
/* set LDO 13 to 3.0v */
|
|
|
|
data = LDO_VOLTAGE(LDO_V30) | LDO_EN;
|
|
|
|
i2c_write(I2C_SLAVE_ADDR, LDO13_REG, 1, &data, 1);
|
|
|
|
|
|
|
|
for (i = 0; i < CONFIG_SYS_MMC_NUM; i++) {
|
|
|
|
if (mv_sdh_init(mmc_base_address[i], 0, 0,
|
|
|
|
SDHCI_QUIRK_32BIT_DMA_ADDR))
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif
|