1
0
Fork 0

arm: rmobile: Add Stout board support

Stout is an entry level development board based on R-Car H2 SoC (R8A7790)

This commit supports the following peripherals:
- SCIFA, I2C, Ethernet, QSPI, SDHI0/2, CPLD

Signed-off-by: Vladimir Barinov <vladimir.barinov@cogentembedded.com>
Signed-off-by: Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
utp
Vladimir Barinov 2015-07-20 20:49:59 +03:00 committed by Nobuhiro Iwamatsu
parent b8f91e2c92
commit 21871138b7
11 changed files with 3200 additions and 1 deletions

View File

@ -40,6 +40,11 @@ config TARGET_PORTER
select DM
select DM_SERIAL
config TARGET_STOUT
bool "Stout board"
select DM
select DM_SERIAL
endchoice
config SYS_SOC
@ -47,7 +52,7 @@ config SYS_SOC
config RMOBILE_EXTRAM_BOOT
bool "Enable boot from RAM"
depends on TARGET_ALT || TARGET_KOELSCH || TARGET_LAGER || TARGET_PORTER || TARGET_SILK
depends on TARGET_ALT || TARGET_KOELSCH || TARGET_LAGER || TARGET_PORTER || TARGET_SILK || TARGET_STOUT
default n
choice
@ -80,5 +85,6 @@ source "board/kmc/kzm9g/Kconfig"
source "board/renesas/alt/Kconfig"
source "board/renesas/silk/Kconfig"
source "board/renesas/porter/Kconfig"
source "board/renesas/stout/Kconfig"
endif

View File

@ -0,0 +1,12 @@
if TARGET_STOUT
config SYS_BOARD
default "stout"
config SYS_VENDOR
default "renesas"
config SYS_CONFIG_NAME
default "stout"
endif

View File

@ -0,0 +1,6 @@
STOUT BOARD
M: Cogent Embedded, Inc. <source@cogentembedded.com>
S: Maintained
F: board/renesas/stout/
F: include/configs/stout.h
F: configs/stout_defconfig

View File

@ -0,0 +1,11 @@
#
# board/renesas/stout/Makefile
#
# Copyright (C) 2015 Renesas Electronics Europe GmbH
# Copyright (C) 2015 Renesas Electronics Corporation
# Copyright (C) 2015 Cogent Embedded, Inc.
#
# SPDX-License-Identifier: GPL-2.0
#
obj-y := stout.o cpld.o qos.o ../rcar-gen2-common/common.o

View File

@ -0,0 +1,167 @@
/*
* Stout board CPLD access support
*
* Copyright (C) 2015 Renesas Electronics Europe GmbH
* Copyright (C) 2015 Renesas Electronics Corporation
* Copyright (C) 2015 Cogent Embedded, Inc.
*
* SPDX-License-Identifier: GPL-2.0
*/
#include <common.h>
#include <asm/io.h>
#include <asm/gpio.h>
#include "cpld.h"
#define SCLK GPIO_GP_3_24
#define SSTBZ GPIO_GP_3_25
#define MOSI GPIO_GP_3_26
#define MISO GPIO_GP_3_27
#define CPLD_ADDR_MODE 0x00 /* RW */
#define CPLD_ADDR_MUX 0x01 /* RW */
#define CPLD_ADDR_HDMI 0x02 /* RW */
#define CPLD_ADDR_DIPSW 0x08 /* R */
#define CPLD_ADDR_RESET 0x80 /* RW */
#define CPLD_ADDR_VERSION 0xFF /* R */
static u32 cpld_read(u8 addr)
{
int i;
u32 data = 0;
for (i = 0; i < 8; i++) {
gpio_set_value(MOSI, addr & 0x80); /* MSB first */
gpio_set_value(SCLK, 1);
addr <<= 1;
gpio_set_value(SCLK, 0);
}
gpio_set_value(MOSI, 0); /* READ */
gpio_set_value(SSTBZ, 0);
gpio_set_value(SCLK, 1);
gpio_set_value(SCLK, 0);
gpio_set_value(SSTBZ, 1);
for (i = 0; i < 32; i++) {
gpio_set_value(SCLK, 1);
data <<= 1;
data |= gpio_get_value(MISO); /* MSB first */
gpio_set_value(SCLK, 0);
}
return data;
}
static void cpld_write(u8 addr, u32 data)
{
int i;
for (i = 0; i < 32; i++) {
gpio_set_value(MOSI, data & (1 << 31)); /* MSB first */
gpio_set_value(SCLK, 1);
data <<= 1;
gpio_set_value(SCLK, 0);
}
for (i = 0; i < 8; i++) {
gpio_set_value(MOSI, addr & 0x80); /* MSB first */
gpio_set_value(SCLK, 1);
addr <<= 1;
gpio_set_value(SCLK, 0);
}
gpio_set_value(MOSI, 1); /* WRITE */
gpio_set_value(SSTBZ, 0);
gpio_set_value(SCLK, 1);
gpio_set_value(SCLK, 0);
gpio_set_value(SSTBZ, 1);
}
/* LSI pin pull-up control */
#define PUPR3 0xe606010C
#define PUPR3_SD3_DAT1 (1 << 27)
void cpld_init(void)
{
u32 val;
/* PULL-UP on MISO line */
val = readl(PUPR3);
val |= PUPR3_SD3_DAT1;
writel(val, PUPR3);
gpio_request(SCLK, NULL);
gpio_request(SSTBZ, NULL);
gpio_request(MOSI, NULL);
gpio_request(MISO, NULL);
gpio_direction_output(SCLK, 0);
gpio_direction_output(SSTBZ, 1);
gpio_direction_output(MOSI, 0);
gpio_direction_input(MISO);
/* dummy read */
cpld_read(CPLD_ADDR_VERSION);
printf("CPLD version: 0x%08x\n",
cpld_read(CPLD_ADDR_VERSION));
printf("H2 Mode setting (MD0..28): 0x%08x\n",
cpld_read(CPLD_ADDR_MODE));
printf("Multiplexer settings: 0x%08x\n",
cpld_read(CPLD_ADDR_MUX));
printf("HDMI setting: 0x%08x\n",
cpld_read(CPLD_ADDR_HDMI));
printf("DIPSW (SW3): 0x%08x\n",
cpld_read(CPLD_ADDR_DIPSW));
#ifdef CONFIG_SH_SDHI
/* switch MUX to SD0 */
val = cpld_read(CPLD_ADDR_MUX);
val &= ~MUX_MSK_SD0;
val |= MUX_VAL_SD0;
cpld_write(CPLD_ADDR_MUX, val);
#endif
}
static int do_cpld(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
u32 addr, val;
if (argc < 3)
return CMD_RET_USAGE;
addr = simple_strtoul(argv[2], NULL, 16);
if (!(addr == CPLD_ADDR_VERSION || addr == CPLD_ADDR_MODE ||
addr == CPLD_ADDR_MUX || addr == CPLD_ADDR_HDMI ||
addr == CPLD_ADDR_DIPSW || addr == CPLD_ADDR_RESET)) {
printf("cpld invalid addr\n");
return CMD_RET_USAGE;
}
if (argc == 3 && strcmp(argv[1], "read") == 0) {
printf("0x%x\n", cpld_read(addr));
} else if (argc == 4 && strcmp(argv[1], "write") == 0) {
val = simple_strtoul(argv[3], NULL, 16);
if (addr == CPLD_ADDR_MUX) {
/* never mask SCIFA0 console */
val &= ~MUX_MSK_SCIFA0_USB;
val |= MUX_VAL_SCIFA0_USB;
}
cpld_write(addr, val);
}
return 0;
}
U_BOOT_CMD(
cpld, 4, 1, do_cpld,
"CPLD access",
"read addr\n"
"cpld write addr val\n"
);
void reset_cpu(ulong addr)
{
cpld_write(CPLD_ADDR_RESET, 1);
}

View File

@ -0,0 +1,183 @@
/*
* Stout board CPLD definition
*
* Copyright (C) 2015 Renesas Electronics Europe GmbH
* Copyright (C) 2015 Renesas Electronics Corporation
* Copyright (C) 2015 Cogent Embedded, Inc.
*
* SPDX-License-Identifier: GPL-2.0
*/
#ifndef _CPLD_H_
#define _CPLD_H_
/* power-up behaviour */
#define MODE_MSK_FREE_RUN 0x00000001
#define MODE_VAL_FREE_RUN 0x00000000
#define MODE_MSK_STEP_UP 0x00000001
#define MODE_VAL_STEP_UP 0x00000000
/* boot source */
#define MODE_MSK_BOOT_SQPI_16KB_FAST 0x0000000E
#define MODE_VAL_BOOT_SQPI_16KB_FAST 0x00000004
#define MODE_MSK_BOOT_SQPI_16KB_SLOW 0x0000000E
#define MODE_VAL_BOOT_SQPI_16KB_SLOW 0x00000008
#define MODE_MSK_BOOT_SQPI_4KB_SLOW 0x0000000E
#define MODE_VAL_BOOT_SQPI_4KB_SLOW 0x0000000C
/* booting CPU */
#define MODE_MSK_BOOT_CA15 0x000000C0
#define MODE_VAL_BOOT_CA15 0x00000000
#define MODE_MSK_BOOT_CA7 0x000000C0
#define MODE_VAL_BOOT_CA7 0x00000040
#define MODE_MSK_BOOT_SH4 0x000000C0
#define MODE_VAL_BOOT_SH4 0x000000C0
/* JTAG connection */
#define MODE_MSK_JTAG_CORESIGHT 0xC0301C00
#define MODE_VAL_JTAG_CORESIGHT 0x00200000
#define MODE_MSK_JTAG_SH4 0xC0301C00
#define MODE_VAL_JTAG_SH4 0x00300000
/* DDR3 (PLL) speed */
#define MODE_MSK_DDR3_1600 0x00080000
#define MODE_VAL_DDR3_1600 0x00000000
#define MODE_MSK_DDR3_1333 0x00080000
#define MODE_VAL_DDR3_1333 0x00080000
/* ComboPhy0 mode */
#define MODE_MSK_PHY0_SATA0 0x01000000
#define MODE_VAL_PHY0_SATA0 0x00000000
#define MODE_MSK_PHY0_PCIE 0x01000000
#define MODE_VAL_PHY0_PCIE 0x01000000
/* ComboPhy1 mode */
#define MODE_MSK_PHY1_SATA1 0x00800000
#define MODE_VAL_PHY1_SATA1 0x00000000
#define MODE_MSK_PHY1_USB3 0x00800000
#define MODE_VAL_PHY1_USB3 0x00800000
/*
* Illegal multiplexer combinations.
* MUX Conflicts
* name with any one of
* VIN0_BT656 VIN0_full, SD2
* VIN0_full VIN0_BT656, SD2, AVB, VIN2_(all)
* VIN1_BT656 VIN1_(others), SD0
* VIN1_10bit VIN1_(others), SD0, VIN3_with*, I2C1
* VIN1_12bit VIN1_(others), SD0, VIN3_with*, I2C1, SCIFA0_(all)
* VIN2_BT656 VIN0_full, VIN2_(others), AVB,
* VIN2_withSYNC VIN0_full, VIN2_(others), AVB, I2C1, SCIFA0_(all),
* VIN3_with*
* VIN2_withFIELD VIN0_full, VIN2_(others), AVB, SQPI_(all)
* VIN2_withSYNCandFIELD VIN0_full, VIN2_(others), AVB, SQPI_(all), I2C1,
* SCIFA0_(all), VIN3_with*
* VIN3_BT656 VIN3_(others), IRQ3
* VIN3_withFIELD VIN3_(others), IRQ3, VIN1_12bit, VIN2_withSYNC,
* VIN2_withSYNCandFIELD, VIN1_10bit
* VIN3_withSYNCandFIELD VIN3_(others), IRQ3, VIN1_12bit, VIN2_withSYNC,
* VIN2_withSYNCandFIELD, VIN1_10bit, I2C1
* AVB VIN0_full, VIN2_(all)
* QSPI_ONBOARD VIN2_withFIELD, VIN2_withSYNCandFIELD, QSPI_COMEXPRESS
* QSPI_COMEXPRESS VIN2_withFIELD, VIN2_withSYNCandFIELD, QSPI_ONBOARD
* I2C1 VIN1_12bit, VIN2_withSYNC, VIN2_withSYNCandFIELD,
* VIN3_withSYNCandFIELD
* IRQ3 VIN3_(all)
* SCIFA0_USB VIN1_12bit, VIN2_withSYNC, VIN2_withSYNCandFIELD,
* SCIFA0_COMEXPRESS
* SCIFA0_COMEXPRESS VIN1_12bit, VIN2_withSYNC, VIN2_withSYNCandFIELD,
* SCIFA0_USB
* SCIFA2 PWM210
* ETH_ONBOARD ETH_COMEXPRESS
* ETH_COMEXPRESS ETH_ONBOARD
* SD0 VIN1_(all)
* SD2 VIN0_(all)
* PWM210 SCIFA2
*/
/* connected to COM Express connector and CN6 for camera, BT656 only */
#define MUX_MSK_VIN0_BT656 0x00001001
#define MUX_VAL_VIN0_BT656 0x00000000
/* connected to COM Express connector and CN6 for camera, all modes */
#define MUX_MSK_VIN0_full 0x00001007
#define MUX_VAL_VIN0_full 0x00000002
/* connected to COM Express connector, BT656 only */
#define MUX_MSK_VIN1_BT656 0x00000801
#define MUX_VAL_VIN1_BT656 0x00000800
/* connected to COM Express connector, all 10-bit modes */
#define MUX_MSK_VIN1_10bit 0x00000821
#define MUX_VAL_VIN1_10bit 0x00000800
/* connected to COM Express connector, all 12-bit modes */
#define MUX_MSK_VIN1_12bit 0x000008A1
#define MUX_VAL_VIN1_12bit 0x00000880
/* connected to COM Express connector, BT656 only */
#define MUX_MSK_VIN2_BT656 0x00000007
#define MUX_VAL_VIN2_BT656 0x00000006
/* connected to COM Express connector, modes with sync signals */
#define MUX_MSK_VIN2_withSYNC 0x000000A7
#define MUX_VAL_VIN2_withSYNC 0x00000086
/* connected to COM Express connector, modes with field, clken signals */
#define MUX_MSK_VIN2_withFIELD 0x0000000F
#define MUX_VAL_VIN2_withFIELD 0x0000000E
/* connected to COM Express connector, modes with sync, field, clken signals */
#define MUX_MSK_VIN2_withSYNCandFIELD 0x000000AF
#define MUX_VAL_VIN2_withSYNCandFIELD 0x0000008E
/* connected to COM Express connector, BT656 only */
#define MUX_MSK_VIN3_BT656 0x00000101
#define MUX_VAL_VIN3_BT656 0x00000100
/* connected to COM Express connector, modes with field, clken signals */
#define MUX_MSK_VIN3_withFIELD 0x00000121
#define MUX_VAL_VIN3_withFIELD 0x00000120
/* connected to COM Express connector, modes with sync, field, clken signals */
#define MUX_MSK_VIN3_withSYNCandFIELD 0x00000161
#define MUX_VAL_VIN3_withSYNCandFIELD 0x00000120
/* connected to COM Express connector (RGMII) */
#define MUX_MSK_AVB 0x00000003
#define MUX_VAL_AVB 0x00000000
/* connected to on-board QSPI flash */
#define MUX_MSK_QSPI_ONBOARD 0x00000019
#define MUX_VAL_QSPI_ONBOARD 0x00000000
/* connected to COM Express connector */
#define MUX_MSK_QSPI_COMEXPRESS 0x00000019
#define MUX_VAL_QSPI_COMEXPRESS 0x00000010
/* connected to COM Express connector and PMIC */
#define MUX_MSK_I2C1 0x00000061
#define MUX_VAL_I2C1 0x00000060
/* connected to HDMI driver */
#define MUX_MSK_IRQ3 0x00000101
#define MUX_VAL_IRQ3 0x00000000
/* connected to USB/FTDI */
#define MUX_MSK_SCIFA0_USB 0x00004081
#define MUX_VAL_SCIFA0_USB 0x00004000
/* connected to COM Express connector */
#define MUX_MSK_SCIFA0_COMEXPRESS 0x00004081
#define MUX_VAL_SCIFA0_COMEXPRESS 0x00000000
/* connected to COM Express connector */
#define MUX_MSK_SCIFA2 0x00002001
#define MUX_VAL_SCIFA2 0x00000000
/* connected to on-board 10/100 Phy */
#define MUX_MSK_ETH_ONBOARD 0x00000600
#define MUX_VAL_ETH_ONBOARD 0x00000000
/* connected to COM Express connector (RMII) */
#define MUX_MSK_ETH_COMEXPRESS 0x00000600
#define MUX_VAL_ETH_COMEXPRESS 0x00000400
/* connected to on-board MicroSD slot */
#define MUX_MSK_SD0 0x00000801
#define MUX_VAL_SD0 0x00000000
/* connected to COM Express connector */
#define MUX_MSK_SD2 0x00001001
#define MUX_VAL_SD2 0x00001000
/* connected to COM Express connector */
#define MUX_MSK_PWM210 0x00002001
#define MUX_VAL_PWM210 0x00002000
#define HDMI_MSK 0x07
#define HDMI_OFF 0x00
#define HDMI_ONBOARD 0x07
#define HDMI_COMEXPRESS 0x05
#define HDMI_ONBOARD_NODDC 0x03
#define HDMI_COMEXPRESS_NODDC 0x01
void cpld_init(void);
#endif /* _CPLD_H_ */

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,14 @@
/*
* Copyright (C) 2015 Renesas Electronics Europe GmbH
* Copyright (C) 2015 Renesas Electronics Corporation
* Copyright (C) 2015 Cogent Embedded, Inc.
*
* SPDX-License-Identifier: GPL-2.0
*/
#ifndef __QOS_H__
#define __QOS_H__
void qos_init(void);
#endif

View File

@ -0,0 +1,232 @@
/*
* board/renesas/stout/stout.c
* This file is Stout board support.
*
* Copyright (C) 2015 Renesas Electronics Europe GmbH
* Copyright (C) 2015 Renesas Electronics Corporation
* Copyright (C) 2015 Cogent Embedded, Inc.
*
* SPDX-License-Identifier: GPL-2.0
*/
#include <common.h>
#include <malloc.h>
#include <netdev.h>
#include <dm.h>
#include <dm/platform_data/serial_sh.h>
#include <asm/processor.h>
#include <asm/mach-types.h>
#include <asm/io.h>
#include <asm/errno.h>
#include <asm/arch/sys_proto.h>
#include <asm/gpio.h>
#include <asm/arch/rmobile.h>
#include <asm/arch/rcar-mstp.h>
#include <asm/arch/mmc.h>
#include <asm/arch/sh_sdhi.h>
#include <miiphy.h>
#include <i2c.h>
#include <mmc.h>
#include "qos.h"
#include "cpld.h"
DECLARE_GLOBAL_DATA_PTR;
#define CLK2MHZ(clk) (clk / 1000 / 1000)
void s_init(void)
{
struct rcar_rwdt *rwdt = (struct rcar_rwdt *)RWDT_BASE;
struct rcar_swdt *swdt = (struct rcar_swdt *)SWDT_BASE;
/* Watchdog init */
writel(0xA5A5A500, &rwdt->rwtcsra);
writel(0xA5A5A500, &swdt->swtcsra);
/* CPU frequency setting. Set to 1.4GHz */
if (rmobile_get_cpu_rev_integer() >= R8A7790_CUT_ES2X) {
u32 stat = 0;
u32 stc = ((1400 / CLK2MHZ(CONFIG_SYS_CLK_FREQ)) - 1)
<< PLL0_STC_BIT;
clrsetbits_le32(PLL0CR, PLL0_STC_MASK, stc);
do {
stat = readl(PLLECR) & PLL0ST;
} while (stat == 0x0);
}
/* QoS(Quality-of-Service) Init */
qos_init();
}
#define TMU0_MSTP125 (1 << 25)
#define SCIFA0_MSTP204 (1 << 4)
#define SDHI0_MSTP314 (1 << 14)
#define SDHI2_MSTP312 (1 << 12)
#define ETHER_MSTP813 (1 << 13)
#define MSTPSR3 0xE6150048
#define SMSTPCR3 0xE615013C
#define SD2CKCR 0xE6150078
#define SD2_97500KHZ 0x7
int board_early_init_f(void)
{
/* TMU0 */
mstp_clrbits_le32(MSTPSR1, SMSTPCR1, TMU0_MSTP125);
/* SCIFA0 */
mstp_clrbits_le32(MSTPSR2, SMSTPCR2, SCIFA0_MSTP204);
/* ETHER */
mstp_clrbits_le32(MSTPSR8, SMSTPCR8, ETHER_MSTP813);
/* SDHI0,2 */
mstp_clrbits_le32(MSTPSR3, SMSTPCR3, SDHI0_MSTP314 | SDHI2_MSTP312);
/*
* SD0 clock is set to 97.5MHz by default.
* Set SD2 to the 97.5MHz as well.
*/
writel(SD2_97500KHZ, SD2CKCR);
return 0;
}
int board_init(void)
{
/* adress of boot parameters */
gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100;
/* Init PFC controller */
r8a7790_pinmux_init();
cpld_init();
#ifdef CONFIG_SH_ETHER
/* ETHER Enable */
gpio_request(GPIO_FN_ETH_CRS_DV, NULL);
gpio_request(GPIO_FN_ETH_RX_ER, NULL);
gpio_request(GPIO_FN_ETH_RXD0, NULL);
gpio_request(GPIO_FN_ETH_RXD1, NULL);
gpio_request(GPIO_FN_ETH_LINK, NULL);
gpio_request(GPIO_FN_ETH_REF_CLK, NULL);
gpio_request(GPIO_FN_ETH_MDIO, NULL);
gpio_request(GPIO_FN_ETH_TXD1, NULL);
gpio_request(GPIO_FN_ETH_TX_EN, NULL);
gpio_request(GPIO_FN_ETH_MAGIC, NULL);
gpio_request(GPIO_FN_ETH_TXD0, NULL);
gpio_request(GPIO_FN_ETH_MDC, NULL);
gpio_request(GPIO_FN_IRQ1, NULL);
gpio_request(GPIO_GP_3_31, NULL); /* PHY_RST */
gpio_direction_output(GPIO_GP_3_31, 0);
mdelay(20);
gpio_set_value(GPIO_GP_3_31, 1);
udelay(1);
#endif
return 0;
}
#define CXR24 0xEE7003C0 /* MAC address high register */
#define CXR25 0xEE7003C8 /* MAC address low register */
int board_eth_init(bd_t *bis)
{
int ret = -ENODEV;
#ifdef CONFIG_SH_ETHER
u32 val;
unsigned char enetaddr[6];
ret = sh_eth_initialize(bis);
if (!eth_getenv_enetaddr("ethaddr", enetaddr))
return ret;
/* Set Mac address */
val = enetaddr[0] << 24 | enetaddr[1] << 16 |
enetaddr[2] << 8 | enetaddr[3];
writel(val, CXR24);
val = enetaddr[4] << 8 | enetaddr[5];
writel(val, CXR25);
#endif
return ret;
}
/* Stout has KSZ8041NL/RNL */
#define PHY_CONTROL1 0x1E
#define PHY_LED_MODE 0xC0000
#define PHY_LED_MODE_ACK 0x4000
int board_phy_config(struct phy_device *phydev)
{
int ret = phy_read(phydev, MDIO_DEVAD_NONE, PHY_CONTROL1);
ret &= ~PHY_LED_MODE;
ret |= PHY_LED_MODE_ACK;
ret = phy_write(phydev, MDIO_DEVAD_NONE, PHY_CONTROL1, (u16)ret);
return 0;
}
int board_mmc_init(bd_t *bis)
{
int ret = -ENODEV;
#ifdef CONFIG_SH_SDHI
gpio_request(GPIO_FN_SD0_DAT0, NULL);
gpio_request(GPIO_FN_SD0_DAT1, NULL);
gpio_request(GPIO_FN_SD0_DAT2, NULL);
gpio_request(GPIO_FN_SD0_DAT3, NULL);
gpio_request(GPIO_FN_SD0_CLK, NULL);
gpio_request(GPIO_FN_SD0_CMD, NULL);
gpio_request(GPIO_FN_SD0_CD, NULL);
gpio_request(GPIO_FN_SD2_DAT0, NULL);
gpio_request(GPIO_FN_SD2_DAT1, NULL);
gpio_request(GPIO_FN_SD2_DAT2, NULL);
gpio_request(GPIO_FN_SD2_DAT3, NULL);
gpio_request(GPIO_FN_SD2_CLK, NULL);
gpio_request(GPIO_FN_SD2_CMD, NULL);
gpio_request(GPIO_FN_SD2_CD, NULL);
/* SDHI0 - needs CPLD mux setup */
gpio_request(GPIO_GP_3_30, NULL);
gpio_direction_output(GPIO_GP_3_30, 1); /* VLDO3=3.3V */
gpio_request(GPIO_GP_5_24, NULL);
gpio_direction_output(GPIO_GP_5_24, 1); /* power on */
ret = sh_sdhi_init(CONFIG_SYS_SH_SDHI0_BASE, 0,
SH_SDHI_QUIRK_16BIT_BUF);
if (ret)
return ret;
/* SDHI2 - needs CPLD mux setup */
gpio_request(GPIO_GP_3_29, NULL);
gpio_direction_output(GPIO_GP_3_29, 1); /* VLDO4=3.3V */
gpio_request(GPIO_GP_5_25, NULL);
gpio_direction_output(GPIO_GP_5_25, 1); /* power on */
ret = sh_sdhi_init(CONFIG_SYS_SH_SDHI2_BASE, 2, 0);
#endif
return ret;
}
int dram_init(void)
{
gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
return 0;
}
const struct rmobile_sysinfo sysinfo = {
CONFIG_RMOBILE_BOARD_STRING
};
static const struct sh_serial_platdata serial_platdata = {
.base = SCIFA0_BASE,
.type = PORT_SCIFA,
.clk = CONFIG_MP_CLK_FREQ,
};
U_BOOT_DEVICE(stout_serials) = {
.name = "serial_sh",
.platdata = &serial_platdata,
};

View File

@ -0,0 +1,21 @@
CONFIG_ARM=y
CONFIG_RMOBILE=y
CONFIG_TARGET_STOUT=y
# CONFIG_CMD_BDI is not set
# CONFIG_CMD_CONSOLE is not set
# CONFIG_CMD_BOOTD is not set
# CONFIG_CMD_IMI is not set
# CONFIG_CMD_IMLS is not set
# CONFIG_CMD_XIMG is not set
# CONFIG_CMD_ENV_EXISTS is not set
# CONFIG_CMD_LOADB is not set
# CONFIG_CMD_FLASH is not set
# CONFIG_CMD_FPGA is not set
# CONFIG_CMD_ECHO is not set
# CONFIG_CMD_ITEST is not set
# CONFIG_CMD_SOURCE is not set
# CONFIG_CMD_SETEXPR is not set
# CONFIG_CMD_MISC is not set
CONFIG_SPI_FLASH=y
CONFIG_SPI_FLASH_BAR=y
CONFIG_SH_SDHI=y

View File

@ -0,0 +1,112 @@
/*
* include/configs/stout.h
* This file is Stout board configuration.
*
* Copyright (C) 2015 Renesas Electronics Europe GmbH
* Copyright (C) 2015 Renesas Electronics Corporation
* Copyright (C) 2015 Cogent Embedded, Inc.
*
* SPDX-License-Identifier: GPL-2.0
*/
#ifndef __STOUT_H
#define __STOUT_H
#undef DEBUG
#define CONFIG_R8A7790
#define CONFIG_RMOBILE_BOARD_STRING "Stout"
#include "rcar-gen2-common.h"
/* #define CONFIG_BOARD_LATE_INIT */
#if defined(CONFIG_RMOBILE_EXTRAM_BOOT)
#define CONFIG_SYS_TEXT_BASE 0xB0000000
#else
#define CONFIG_SYS_TEXT_BASE 0xE8080000
#endif
/* STACK */
#if defined(CONFIGF_RMOBILE_EXTRAM_BOOT)
#define CONFIG_SYS_INIT_SP_ADDR 0xB003FFFC
#else
#define CONFIG_SYS_INIT_SP_ADDR 0xE827FFFC
#endif
#define STACK_AREA_SIZE 0xC000
#define LOW_LEVEL_MERAM_STACK \
(CONFIG_SYS_INIT_SP_ADDR + STACK_AREA_SIZE - 4)
/* MEMORY */
#define RCAR_GEN2_SDRAM_BASE 0x40000000
#define RCAR_GEN2_SDRAM_SIZE (1024u * 1024 * 1024)
#define RCAR_GEN2_UBOOT_SDRAM_SIZE (512 * 1024 * 1024)
/* SCIF */
#define CONFIG_SCIF_CONSOLE
#define CONFIG_SCIF_A
/* SPI */
#define CONFIG_SPI
#define CONFIG_SH_QSPI
#define CONFIG_SPI_FLASH_SPANSION
#define CONFIG_SPI_FLASH_QUAD
#define CONFIG_SYS_NO_FLASH
/* SH Ether */
#define CONFIG_SH_ETHER
#define CONFIG_SH_ETHER_USE_PORT 0
#define CONFIG_SH_ETHER_PHY_ADDR 0x1
#define CONFIG_SH_ETHER_PHY_MODE PHY_INTERFACE_MODE_RMII
#define CONFIG_SH_ETHER_ALIGNE_SIZE 64
#define CONFIG_SH_ETHER_CACHE_WRITEBACK
#define CONFIG_SH_ETHER_CACHE_INVALIDATE
#define CONFIG_PHYLIB
#define CONFIG_PHY_MICREL
#define CONFIG_BITBANGMII
#define CONFIG_BITBANGMII_MULTI
/* I2C */
#define CONFIG_SYS_I2C
#define CONFIG_SYS_I2C_RCAR
#define CONFIG_SYS_RCAR_I2C0_SPEED 400000
#define CONFIG_SYS_RCAR_I2C1_SPEED 400000
#define CONFIG_SYS_RCAR_I2C2_SPEED 400000
#define CONFIG_SYS_RCAR_I2C3_SPEED 400000
#define CONFIF_SYS_RCAR_I2C_NUM_CONTROLLERS 4
#define CONFIG_SYS_I2C_POWERIC_ADDR 0x58 /* da9063 */
/* Board Clock */
#define RMOBILE_XTAL_CLK 20000000u
#define CONFIG_SYS_CLK_FREQ RMOBILE_XTAL_CLK
#define CONFIG_SH_TMU_CLK_FREQ (CONFIG_SYS_CLK_FREQ / 2) /* EXT / 2 */
#define CONFIG_PLL1_CLK_FREQ (CONFIG_SYS_CLK_FREQ * 156 / 2)
#define CONFIG_PLL1_DIV2_CLK_FREQ (CONFIG_PLL1_CLK_FREQ / 2)
#define CONFIG_MP_CLK_FREQ (CONFIG_PLL1_DIV2_CLK_FREQ / 15)
#define CONFIG_HP_CLK_FREQ (CONFIG_PLL1_CLK_FREQ / 12)
#define CONFIG_SYS_TMU_CLK_DIV 4
/* USB */
#define CONFIG_USB_EHCI
#define CONFIG_USB_EHCI_RMOBILE
#define CONFIG_USB_MAX_CONTROLLER_COUNT 3
#define CONFIG_USB_STORAGE
/* MMC */
#define CONFIG_MMC
#define CONFIG_CMD_MMC
#define CONFIG_GENERIC_MMC
/* Module stop status bits */
/* INTC-RT */
#define CONFIG_SMSTP0_ENA 0x00400000
/* MSIF, SCIFA0 */
#define CONFIG_SMSTP2_ENA 0x00002010
/* INTC-SYS, IRQC */
#define CONFIG_SMSTP4_ENA 0x00000180
/* SDHI */
#define CONFIG_SH_SDHI_FREQ 97500000
#endif /* __STOUT_H */