]> git.sur5r.net Git - u-boot/blobdiff - board/renesas/lager/lager.c
ARM: rmobile: Contain CONFIG_ARCH_RMOBILE_BOARD_STRING
[u-boot] / board / renesas / lager / lager.c
index 562be04760febfa2d622019c9a45ae6013b7a00a..586c6c3842edcedebf4b2064fa2cc414a251e66a 100644 (file)
@@ -9,6 +9,7 @@
  */
 
 #include <common.h>
+#include <environment.h>
 #include <malloc.h>
 #include <netdev.h>
 #include <dm.h>
@@ -56,105 +57,60 @@ void s_init(void)
        qos_init();
 }
 
-#define TMU0_MSTP125   (1 << 25)
-#define SCIF0_MSTP721  (1 << 21)
-#define ETHER_MSTP813  (1 << 13)
-#define MMC1_MSTP305    (1 << 5)
+#define TMU0_MSTP125   BIT(25)
 
-#define MSTPSR3                0xE6150048
-#define SMSTPCR3       0xE615013C
-#define SDHI0_MSTP314  (1 << 14)
-#define SDHI1_MSTP313  (1 << 13)
-#define SDHI2_MSTP312  (1 << 12)
-
-#define SD2CKCR                0xE6150078
-#define SD2_97500KHZ   0x7
+#define SD1CKCR                0xE6150078
+#define SD2CKCR                0xE615026C
+#define SD_97500KHZ    0x7
 
 int board_early_init_f(void)
 {
-       /* TMU0 */
        mstp_clrbits_le32(MSTPSR1, SMSTPCR1, TMU0_MSTP125);
-       /* SCIF0 */
-       mstp_clrbits_le32(MSTPSR7, SMSTPCR7, SCIF0_MSTP721);
-       /* ETHER */
-       mstp_clrbits_le32(MSTPSR8, SMSTPCR8, ETHER_MSTP813);
-       /* eMMC */
-       mstp_clrbits_le32(MSTPSR3, SMSTPCR3, MMC1_MSTP305);
-       /* 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.
+        * Set SD1 and SD2 to the 97.5MHz as well.
         */
-       writel(SD2_97500KHZ, SD2CKCR);
+       writel(SD_97500KHZ, SD1CKCR);
+       writel(SD_97500KHZ, SD2CKCR);
 
        return 0;
 }
 
-DECLARE_GLOBAL_DATA_PTR;
+#define ETHERNET_PHY_RESET     185     /* GPIO 5 31 */
+
 int board_init(void)
 {
        /* adress of boot parameters */
        gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100;
 
-       /* Init PFC controller */
-       r8a7790_pinmux_init();
-
-       /* 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_IRQ0, NULL);
-
-       gpio_request(GPIO_GP_5_31, NULL);       /* PHY_RST */
-       gpio_direction_output(GPIO_GP_5_31, 0);
-       mdelay(20);
-       gpio_set_value(GPIO_GP_5_31, 1);
-       udelay(1);
+       /* Force ethernet PHY out of reset */
+       gpio_request(ETHERNET_PHY_RESET, "phy_reset");
+       gpio_direction_output(ETHERNET_PHY_RESET, 0);
+       mdelay(10);
+       gpio_direction_output(ETHERNET_PHY_RESET, 1);
 
        return 0;
 }
 
-#define CXR24 0xEE7003C0 /* MAC address high register */
-#define CXR25 0xEE7003C8 /* MAC address low register */
-int board_eth_init(bd_t *bis)
+int dram_init(void)
 {
-       int ret = -ENODEV;
-
-#ifdef CONFIG_SH_ETHER
-       u32 val;
-       unsigned char enetaddr[6];
-
-       ret = sh_eth_initialize(bis);
-       if (!eth_env_get_enetaddr("ethaddr", enetaddr))
-               return ret;
+       if (fdtdec_setup_memory_size() != 0)
+               return -EINVAL;
 
-       /* 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);
+       return 0;
+}
 
-#endif
+int dram_init_banksize(void)
+{
+       fdtdec_setup_memory_banksize();
 
-       return ret;
+       return 0;
 }
 
-/* lager has KSZ8041NL/RNL */
-#define PHY_CONTROL1   0x1E
-#define PHY_LED_MODE   0xC0000
+/* 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)
 {
@@ -166,97 +122,40 @@ int board_phy_config(struct phy_device *phydev)
        return 0;
 }
 
-int board_mmc_init(bd_t *bis)
+void reset_cpu(ulong addr)
 {
-       int ret = -ENODEV;
-
-#ifdef CONFIG_SH_MMCIF
-       gpio_request(GPIO_FN_MMC1_D0, NULL);
-       gpio_request(GPIO_FN_MMC1_D1, NULL);
-       gpio_request(GPIO_FN_MMC1_D2, NULL);
-       gpio_request(GPIO_FN_MMC1_D3, NULL);
-       gpio_request(GPIO_FN_MMC1_D4, NULL);
-       gpio_request(GPIO_FN_MMC1_D5, NULL);
-       gpio_request(GPIO_FN_MMC1_D6, NULL);
-       gpio_request(GPIO_FN_MMC1_D7, NULL);
-       gpio_request(GPIO_FN_MMC1_CLK, NULL);
-       gpio_request(GPIO_FN_MMC1_CMD, NULL);
+       struct udevice *dev;
+       const u8 pmic_bus = 2;
+       const u8 pmic_addr = 0x58;
+       u8 data;
+       int ret;
 
-       ret = mmcif_mmc_init();
-#endif
-
-#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);
-
-       /*
-        * SDHI 0
-        * need JP3 set to pin-1 side on board.
-        */
-       gpio_request(GPIO_GP_5_24, NULL);
-       gpio_request(GPIO_GP_5_29, NULL);
-       gpio_direction_output(GPIO_GP_5_24, 1); /* power on */
-       gpio_direction_output(GPIO_GP_5_29, 1); /* 1: 3.3V, 0: 1.8V */
+       ret = i2c_get_chip_for_busnum(pmic_bus, pmic_addr, 1, &dev);
+       if (ret)
+               hang();
 
-       ret = sh_sdhi_init(CONFIG_SYS_SH_SDHI0_BASE, 0,
-                          SH_SDHI_QUIRK_16BIT_BUF);
+       ret = dm_i2c_read(dev, 0x13, &data, 1);
        if (ret)
-               return ret;
+               hang();
 
-       /* SDHI 2 */
-       gpio_request(GPIO_GP_5_25, NULL);
-       gpio_request(GPIO_GP_5_30, NULL);
-       gpio_direction_output(GPIO_GP_5_25, 1); /* power on */
-       gpio_direction_output(GPIO_GP_5_30, 1); /* 1: 3.3V, 0: 1.8V */
+       data |= BIT(1);
 
-       ret = sh_sdhi_init(CONFIG_SYS_SH_SDHI2_BASE, 2, 0);
-#endif
-       return ret;
+       ret = dm_i2c_write(dev, 0x13, &data, 1);
+       if (ret)
+               hang();
 }
 
-
-int dram_init(void)
+enum env_location env_get_location(enum env_operation op, int prio)
 {
-       gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
+       const u32 load_magic = 0xb33fc0de;
 
-       return 0;
-}
+       /* Block environment access if loaded using JTAG */
+       if ((readl(CONFIG_SPL_TEXT_BASE + 0x24) == load_magic) &&
+           (op != ENVOP_INIT))
+               return ENVL_UNKNOWN;
 
-const struct rmobile_sysinfo sysinfo = {
-       CONFIG_ARCH_RMOBILE_BOARD_STRING
-};
+       if (prio)
+               return ENVL_UNKNOWN;
 
-void reset_cpu(ulong addr)
-{
-       u8 val;
-
-       i2c_set_bus_num(3); /* PowerIC connected to ch3 */
-       i2c_init(400000, 0);
-       i2c_read(CONFIG_SYS_I2C_POWERIC_ADDR, 0x13, 1, &val, 1);
-       val |= 0x02;
-       i2c_write(CONFIG_SYS_I2C_POWERIC_ADDR, 0x13, 1, &val, 1);
+       return ENVL_SPI_FLASH;
 }
-
-static const struct sh_serial_platdata serial_platdata = {
-       .base = SCIF0_BASE,
-       .type = PORT_SCIF,
-       .clk = 14745600,
-       .clk_mode = EXT_CLK,
-};
-
-U_BOOT_DEVICE(lager_serials) = {
-       .name = "serial_sh",
-       .platdata = &serial_platdata,
-};