|
@@ -339,6 +339,18 @@ static struct platform_device mipidsi0_device = {
|
|
|
},
|
|
|
};
|
|
|
|
|
|
+/* SDHI0 */
|
|
|
+static irqreturn_t ag5evm_sdhi0_gpio_cd(int irq, void *arg)
|
|
|
+{
|
|
|
+ struct device *dev = arg;
|
|
|
+ struct sh_mobile_sdhi_info *info = dev->platform_data;
|
|
|
+ struct tmio_mmc_data *pdata = info->pdata;
|
|
|
+
|
|
|
+ tmio_mmc_cd_wakeup(pdata);
|
|
|
+
|
|
|
+ return IRQ_HANDLED;
|
|
|
+}
|
|
|
+
|
|
|
static struct sh_mobile_sdhi_info sdhi0_info = {
|
|
|
.dma_slave_tx = SHDMA_SLAVE_SDHI0_TX,
|
|
|
.dma_slave_rx = SHDMA_SLAVE_SDHI0_RX,
|
|
@@ -570,6 +582,13 @@ static void __init ag5evm_init(void)
|
|
|
gpio_request(GPIO_FN_SDHID0_1, NULL);
|
|
|
gpio_request(GPIO_FN_SDHID0_0, NULL);
|
|
|
|
|
|
+ if (!request_irq(intcs_evt2irq(0x3c0), ag5evm_sdhi0_gpio_cd,
|
|
|
+ IRQF_TRIGGER_FALLING | IRQF_TRIGGER_RISING,
|
|
|
+ "sdhi0 cd", &sdhi0_device.dev))
|
|
|
+ sdhi0_info.tmio_flags |= TMIO_MMC_HAS_COLD_CD;
|
|
|
+ else
|
|
|
+ pr_warn("Unable to setup SDHI0 GPIO IRQ\n");
|
|
|
+
|
|
|
/* enable SDHI1 on CN4 [WLAN I/F] */
|
|
|
gpio_request(GPIO_FN_SDHICLK1, NULL);
|
|
|
gpio_request(GPIO_FN_SDHICMD1_PU, NULL);
|