|
@@ -324,3 +324,149 @@ static struct resource mmcif_resources[] = {
|
|
|
static struct sh_mmcif_plat_data mmcif_info = {
|
|
|
.ocr = MMC_VDD_165_195,
|
|
|
.caps = MMC_CAP_8_BIT_DATA | MMC_CAP_NONREMOVABLE,
|
|
|
+};
|
|
|
+
|
|
|
+static struct platform_device mmcif_device = {
|
|
|
+ .name = "sh_mmcif",
|
|
|
+ .id = 0,
|
|
|
+ .dev = {
|
|
|
+ .platform_data = &mmcif_info,
|
|
|
+ },
|
|
|
+ .num_resources = ARRAY_SIZE(mmcif_resources),
|
|
|
+ .resource = mmcif_resources,
|
|
|
+};
|
|
|
+
|
|
|
+/* Fixed 3.3V regulator to be used by SDHI0 and SDHI1 */
|
|
|
+static struct regulator_consumer_supply fixed3v3_power_consumers[] =
|
|
|
+{
|
|
|
+ REGULATOR_SUPPLY("vmmc", "sh_mobile_sdhi.0"),
|
|
|
+ REGULATOR_SUPPLY("vqmmc", "sh_mobile_sdhi.0"),
|
|
|
+ REGULATOR_SUPPLY("vmmc", "sh_mobile_sdhi.1"),
|
|
|
+ REGULATOR_SUPPLY("vqmmc", "sh_mobile_sdhi.1"),
|
|
|
+};
|
|
|
+
|
|
|
+/* SDHI0 */
|
|
|
+static struct sh_mobile_sdhi_info sdhi0_info = {
|
|
|
+ .tmio_caps = MMC_CAP_SD_HIGHSPEED,
|
|
|
+ .tmio_flags = TMIO_MMC_WRPROTECT_DISABLE | TMIO_MMC_HAS_IDLE_WAIT,
|
|
|
+};
|
|
|
+
|
|
|
+static struct resource sdhi0_resources[] = {
|
|
|
+ [0] = {
|
|
|
+ .name = "SDHI0",
|
|
|
+ .start = 0xee100000,
|
|
|
+ .end = 0xee1000ff,
|
|
|
+ .flags = IORESOURCE_MEM,
|
|
|
+ },
|
|
|
+ [1] = {
|
|
|
+ .start = gic_spi(83),
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ [2] = {
|
|
|
+ .start = gic_spi(84),
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ [3] = {
|
|
|
+ .start = gic_spi(85),
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct platform_device sdhi0_device = {
|
|
|
+ .name = "sh_mobile_sdhi",
|
|
|
+ .id = 0,
|
|
|
+ .num_resources = ARRAY_SIZE(sdhi0_resources),
|
|
|
+ .resource = sdhi0_resources,
|
|
|
+ .dev = {
|
|
|
+ .platform_data = &sdhi0_info,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+/* SDHI1 */
|
|
|
+static struct sh_mobile_sdhi_info sdhi1_info = {
|
|
|
+ .tmio_caps = MMC_CAP_NONREMOVABLE | MMC_CAP_SDIO_IRQ,
|
|
|
+ .tmio_flags = TMIO_MMC_WRPROTECT_DISABLE | TMIO_MMC_HAS_IDLE_WAIT,
|
|
|
+};
|
|
|
+
|
|
|
+static struct resource sdhi1_resources[] = {
|
|
|
+ [0] = {
|
|
|
+ .name = "SDHI1",
|
|
|
+ .start = 0xee120000,
|
|
|
+ .end = 0xee1200ff,
|
|
|
+ .flags = IORESOURCE_MEM,
|
|
|
+ },
|
|
|
+ [1] = {
|
|
|
+ .start = gic_spi(87),
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ [2] = {
|
|
|
+ .start = gic_spi(88),
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ [3] = {
|
|
|
+ .start = gic_spi(89),
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct platform_device sdhi1_device = {
|
|
|
+ .name = "sh_mobile_sdhi",
|
|
|
+ .id = 1,
|
|
|
+ .num_resources = ARRAY_SIZE(sdhi1_resources),
|
|
|
+ .resource = sdhi1_resources,
|
|
|
+ .dev = {
|
|
|
+ .platform_data = &sdhi1_info,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct platform_device *kota2_devices[] __initdata = {
|
|
|
+ ð_device,
|
|
|
+ &keysc_device,
|
|
|
+ &gpio_keys_device,
|
|
|
+ &gpio_leds_device,
|
|
|
+ &leds_tpu12_device,
|
|
|
+ &leds_tpu41_device,
|
|
|
+ &leds_tpu21_device,
|
|
|
+ &leds_tpu30_device,
|
|
|
+ &mmcif_device,
|
|
|
+ &sdhi0_device,
|
|
|
+ &sdhi1_device,
|
|
|
+};
|
|
|
+
|
|
|
+static void __init kota2_init(void)
|
|
|
+{
|
|
|
+ regulator_register_always_on(0, "fixed-1.8V", fixed1v8_power_consumers,
|
|
|
+ ARRAY_SIZE(fixed1v8_power_consumers), 1800000);
|
|
|
+ regulator_register_always_on(1, "fixed-3.3V", fixed3v3_power_consumers,
|
|
|
+ ARRAY_SIZE(fixed3v3_power_consumers), 3300000);
|
|
|
+ regulator_register_fixed(2, dummy_supplies, ARRAY_SIZE(dummy_supplies));
|
|
|
+
|
|
|
+ sh73a0_pinmux_init();
|
|
|
+
|
|
|
+ /* SCIFA2 (UART2) */
|
|
|
+ gpio_request(GPIO_FN_SCIFA2_TXD1, NULL);
|
|
|
+ gpio_request(GPIO_FN_SCIFA2_RXD1, NULL);
|
|
|
+ gpio_request(GPIO_FN_SCIFA2_RTS1_, NULL);
|
|
|
+ gpio_request(GPIO_FN_SCIFA2_CTS1_, NULL);
|
|
|
+
|
|
|
+ /* SCIFA4 (UART1) */
|
|
|
+ gpio_request(GPIO_FN_SCIFA4_TXD, NULL);
|
|
|
+ gpio_request(GPIO_FN_SCIFA4_RXD, NULL);
|
|
|
+ gpio_request(GPIO_FN_SCIFA4_RTS_, NULL);
|
|
|
+ gpio_request(GPIO_FN_SCIFA4_CTS_, NULL);
|
|
|
+
|
|
|
+ /* SMSC911X */
|
|
|
+ gpio_request(GPIO_FN_D0_NAF0, NULL);
|
|
|
+ gpio_request(GPIO_FN_D1_NAF1, NULL);
|
|
|
+ gpio_request(GPIO_FN_D2_NAF2, NULL);
|
|
|
+ gpio_request(GPIO_FN_D3_NAF3, NULL);
|
|
|
+ gpio_request(GPIO_FN_D4_NAF4, NULL);
|
|
|
+ gpio_request(GPIO_FN_D5_NAF5, NULL);
|
|
|
+ gpio_request(GPIO_FN_D6_NAF6, NULL);
|
|
|
+ gpio_request(GPIO_FN_D7_NAF7, NULL);
|
|
|
+ gpio_request(GPIO_FN_D8_NAF8, NULL);
|
|
|
+ gpio_request(GPIO_FN_D9_NAF9, NULL);
|
|
|
+ gpio_request(GPIO_FN_D10_NAF10, NULL);
|
|
|
+ gpio_request(GPIO_FN_D11_NAF11, NULL);
|
|
|
+ gpio_request(GPIO_FN_D12_NAF12, NULL);
|
|
|
+ gpio_request(GPIO_FN_D13_NAF13, NULL);
|