2018-05-06 21:58:06 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0+
|
2016-02-26 06:46:07 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 David Lechner <david@lechnology.com>
|
|
|
|
*
|
|
|
|
* Based on da850evm.c
|
|
|
|
*
|
|
|
|
* Copyright (C) 2010 Texas Instruments Incorporated - http://www.ti.com/
|
|
|
|
*
|
|
|
|
* Based on da830evm.c. Original Copyrights follow:
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009 Nick Thompson, GE Fanuc, Ltd. <nick.thompson@gefanuc.com>
|
|
|
|
* Copyright (C) 2007 Sergey Kubushyn <ksi@koi8.net>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <common.h>
|
2021-01-11 19:24:44 +00:00
|
|
|
#include <env.h>
|
2016-02-26 06:46:07 +00:00
|
|
|
#include <i2c.h>
|
2020-05-10 17:40:02 +00:00
|
|
|
#include <init.h>
|
2016-02-26 06:46:07 +00:00
|
|
|
#include <spi.h>
|
|
|
|
#include <spi_flash.h>
|
|
|
|
#include <asm/arch/hardware.h>
|
|
|
|
#include <asm/arch/pinmux_defs.h>
|
|
|
|
#include <asm/io.h>
|
|
|
|
#include <asm/arch/davinci_misc.h>
|
2016-09-21 02:28:55 +00:00
|
|
|
#include <linux/errno.h>
|
2016-02-26 06:46:07 +00:00
|
|
|
#include <hwconfig.h>
|
2017-06-01 01:47:48 +00:00
|
|
|
#include <asm/mach-types.h>
|
2017-05-17 14:23:00 +00:00
|
|
|
#include <asm/setup.h>
|
2016-02-26 06:46:07 +00:00
|
|
|
|
|
|
|
DECLARE_GLOBAL_DATA_PTR;
|
|
|
|
|
|
|
|
#define EEPROM_I2C_ADDR 0x50
|
|
|
|
#define EEPROM_REV_OFFSET 0x3F00
|
2021-01-11 19:24:44 +00:00
|
|
|
#define EEPROM_BDADDR_OFFSET 0x3F06
|
2016-02-26 06:46:07 +00:00
|
|
|
|
|
|
|
const struct pinmux_resource pinmuxes[] = {
|
|
|
|
PINMUX_ITEM(spi0_pins_base),
|
|
|
|
PINMUX_ITEM(spi0_pins_scs0),
|
|
|
|
PINMUX_ITEM(uart1_pins_txrx),
|
|
|
|
PINMUX_ITEM(i2c0_pins),
|
|
|
|
PINMUX_ITEM(mmc0_pins),
|
|
|
|
};
|
|
|
|
|
|
|
|
const int pinmuxes_size = ARRAY_SIZE(pinmuxes);
|
|
|
|
|
|
|
|
const struct lpsc_resource lpsc[] = {
|
|
|
|
{ DAVINCI_LPSC_SPI0 }, /* Serial Flash */
|
|
|
|
{ DAVINCI_LPSC_UART1 }, /* console */
|
|
|
|
{ DAVINCI_LPSC_MMC_SD },
|
|
|
|
};
|
|
|
|
|
|
|
|
const int lpsc_size = ARRAY_SIZE(lpsc);
|
|
|
|
|
|
|
|
/*
|
2021-01-11 19:24:44 +00:00
|
|
|
* The Bluetooth address serves as the board serial number.
|
2016-02-26 06:46:07 +00:00
|
|
|
*/
|
2021-01-11 19:24:44 +00:00
|
|
|
static void setup_serial_number(void)
|
2016-02-26 06:46:07 +00:00
|
|
|
{
|
|
|
|
u32 offset;
|
2021-01-11 19:24:44 +00:00
|
|
|
char serial_number[13];
|
2016-02-26 06:46:07 +00:00
|
|
|
u8 buf[6];
|
2021-01-11 19:24:44 +00:00
|
|
|
u8 eeprom_rev;
|
|
|
|
|
|
|
|
if (env_get("serial#"))
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (i2c_read(EEPROM_I2C_ADDR, EEPROM_REV_OFFSET, 2, buf, 2)) {
|
|
|
|
printf("\nEEPROM revision read failed!\n");
|
|
|
|
return;
|
|
|
|
}
|
2016-02-26 06:46:07 +00:00
|
|
|
|
2021-01-11 19:24:44 +00:00
|
|
|
/*
|
|
|
|
* EEPROM rev 3 has Bluetooth address at EEPROM_REV_OFFSET.
|
|
|
|
* Other revisions have checksum at EEPROM_REV_OFFSET+1
|
|
|
|
* to detect this.
|
|
|
|
*/
|
|
|
|
if ((buf[0] ^ buf[1]) == 0xFF)
|
|
|
|
eeprom_rev = buf[0];
|
|
|
|
else
|
|
|
|
eeprom_rev = 3;
|
2016-02-26 06:46:07 +00:00
|
|
|
|
2021-01-11 19:24:44 +00:00
|
|
|
/* EEPROM rev 3 has Bluetooth address where rev should be */
|
|
|
|
offset = (eeprom_rev == 3) ? EEPROM_REV_OFFSET : EEPROM_BDADDR_OFFSET;
|
2016-02-26 06:46:07 +00:00
|
|
|
|
|
|
|
if (i2c_read(EEPROM_I2C_ADDR, offset, 2, buf, 6)) {
|
2021-01-11 19:24:44 +00:00
|
|
|
printf("\nEEPROM serial read failed!\n");
|
|
|
|
return;
|
2016-02-26 06:46:07 +00:00
|
|
|
}
|
2021-01-11 19:24:44 +00:00
|
|
|
|
|
|
|
sprintf(serial_number, "%02X%02X%02X%02X%02X%02X",
|
|
|
|
buf[0], buf[1], buf[2], buf[3], buf[4], buf[5]);
|
|
|
|
|
|
|
|
env_set("serial#", serial_number);
|
2016-02-26 06:46:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int board_early_init_f(void)
|
|
|
|
{
|
2018-05-20 04:25:04 +00:00
|
|
|
/* enable the console UART */
|
|
|
|
writel((DAVINCI_UART_PWREMU_MGMT_FREE | DAVINCI_UART_PWREMU_MGMT_URRST |
|
|
|
|
DAVINCI_UART_PWREMU_MGMT_UTRST),
|
|
|
|
&davinci_uart1_ctrl_regs->pwremu_mgmt);
|
|
|
|
|
2016-02-26 06:46:07 +00:00
|
|
|
/*
|
|
|
|
* Power on required peripherals
|
|
|
|
* ARM does not have access by default to PSC0 and PSC1
|
|
|
|
* assuming here that the DSP bootloader has set the IOPU
|
|
|
|
* such that PSC access is available to ARM
|
|
|
|
*/
|
|
|
|
if (da8xx_configure_lpsc_items(lpsc, ARRAY_SIZE(lpsc)))
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int board_init(void)
|
|
|
|
{
|
|
|
|
irq_init();
|
|
|
|
|
|
|
|
/* address of boot parameters */
|
|
|
|
gd->bd->bi_boot_params = LINUX_BOOT_PARAM_ADDR;
|
|
|
|
|
|
|
|
/* setup the SUSPSRC for ARM to control emulation suspend */
|
|
|
|
writel(readl(&davinci_syscfg_regs->suspsrc) &
|
2018-05-20 04:25:05 +00:00
|
|
|
~(DAVINCI_SYSCFG_SUSPSRC_I2C |
|
2016-02-26 06:46:07 +00:00
|
|
|
DAVINCI_SYSCFG_SUSPSRC_SPI0 | DAVINCI_SYSCFG_SUSPSRC_TIMER0 |
|
|
|
|
DAVINCI_SYSCFG_SUSPSRC_UART1),
|
|
|
|
&davinci_syscfg_regs->suspsrc);
|
|
|
|
|
|
|
|
/* configure pinmux settings */
|
|
|
|
if (davinci_configure_pin_mux_items(pinmuxes, ARRAY_SIZE(pinmuxes)))
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2021-01-11 19:24:44 +00:00
|
|
|
|
|
|
|
int board_late_init(void)
|
|
|
|
{
|
|
|
|
setup_serial_number();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|