|
@@ -304,3 +304,170 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
|
|
.controller_data = &spi_flash_chip_info,
|
|
|
.mode = SPI_MODE_3,
|
|
|
},
|
|
|
+#endif
|
|
|
+#if defined(CONFIG_SND_BF5XX_SOC_AD183X) \
|
|
|
+ || defined(CONFIG_SND_BF5XX_SOC_AD183X_MODULE)
|
|
|
+ {
|
|
|
+ .modalias = "ad183x",
|
|
|
+ .max_speed_hz = 3125000, /* max spi clock (SCK) speed in HZ */
|
|
|
+ .bus_num = 0,
|
|
|
+ .chip_select = 4,
|
|
|
+ },
|
|
|
+#endif
|
|
|
+#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
|
|
+ {
|
|
|
+ .modalias = "mmc_spi",
|
|
|
+ .max_speed_hz = 30000000, /* max spi clock (SCK) speed in HZ */
|
|
|
+ .bus_num = 0,
|
|
|
+ .chip_select = GPIO_PH3 + MAX_CTRL_CS,
|
|
|
+ .controller_data = &mmc_spi_chip_info,
|
|
|
+ .mode = SPI_MODE_3,
|
|
|
+ },
|
|
|
+#endif
|
|
|
+#if defined(CONFIG_SPI_SPIDEV) || defined(CONFIG_SPI_SPIDEV_MODULE)
|
|
|
+ {
|
|
|
+ .modalias = "spidev",
|
|
|
+ .max_speed_hz = 3125000, /* max spi clock (SCK) speed in HZ */
|
|
|
+ .bus_num = 0,
|
|
|
+ .chip_select = 1,
|
|
|
+ },
|
|
|
+#endif
|
|
|
+};
|
|
|
+
|
|
|
+#if defined(CONFIG_SPI_BFIN5XX) || defined(CONFIG_SPI_BFIN5XX_MODULE)
|
|
|
+/* SPI controller data */
|
|
|
+static struct bfin5xx_spi_master bfin_spi0_info = {
|
|
|
+ .num_chipselect = MAX_CTRL_CS + MAX_BLACKFIN_GPIOS,
|
|
|
+ .enable_dma = 1, /* master has the ability to do dma transfer */
|
|
|
+ .pin_req = {P_SPI0_SCK, P_SPI0_MISO, P_SPI0_MOSI, 0},
|
|
|
+};
|
|
|
+
|
|
|
+/* SPI (0) */
|
|
|
+static struct resource bfin_spi0_resource[] = {
|
|
|
+ [0] = {
|
|
|
+ .start = SPI0_REGBASE,
|
|
|
+ .end = SPI0_REGBASE + 0xFF,
|
|
|
+ .flags = IORESOURCE_MEM,
|
|
|
+ },
|
|
|
+ [1] = {
|
|
|
+ .start = CH_SPI,
|
|
|
+ .end = CH_SPI,
|
|
|
+ .flags = IORESOURCE_DMA,
|
|
|
+ },
|
|
|
+ [2] = {
|
|
|
+ .start = IRQ_SPI,
|
|
|
+ .end = IRQ_SPI,
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static struct platform_device bfin_spi0_device = {
|
|
|
+ .name = "bfin-spi",
|
|
|
+ .id = 0, /* Bus number */
|
|
|
+ .num_resources = ARRAY_SIZE(bfin_spi0_resource),
|
|
|
+ .resource = bfin_spi0_resource,
|
|
|
+ .dev = {
|
|
|
+ .platform_data = &bfin_spi0_info, /* Passed to driver */
|
|
|
+ },
|
|
|
+};
|
|
|
+#endif /* spi master and devices */
|
|
|
+
|
|
|
+#if defined(CONFIG_SERIAL_BFIN) || defined(CONFIG_SERIAL_BFIN_MODULE)
|
|
|
+#ifdef CONFIG_SERIAL_BFIN_UART0
|
|
|
+static struct resource bfin_uart0_resources[] = {
|
|
|
+ {
|
|
|
+ .start = UART0_THR,
|
|
|
+ .end = UART0_GCTL+2,
|
|
|
+ .flags = IORESOURCE_MEM,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = IRQ_UART0_TX,
|
|
|
+ .end = IRQ_UART0_TX,
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = IRQ_UART0_RX,
|
|
|
+ .end = IRQ_UART0_RX,
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = IRQ_UART0_ERROR,
|
|
|
+ .end = IRQ_UART0_ERROR,
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = CH_UART0_TX,
|
|
|
+ .end = CH_UART0_TX,
|
|
|
+ .flags = IORESOURCE_DMA,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = CH_UART0_RX,
|
|
|
+ .end = CH_UART0_RX,
|
|
|
+ .flags = IORESOURCE_DMA,
|
|
|
+ },
|
|
|
+};
|
|
|
+
|
|
|
+static unsigned short bfin_uart0_peripherals[] = {
|
|
|
+ P_UART0_TX, P_UART0_RX, 0
|
|
|
+};
|
|
|
+
|
|
|
+static struct platform_device bfin_uart0_device = {
|
|
|
+ .name = "bfin-uart",
|
|
|
+ .id = 0,
|
|
|
+ .num_resources = ARRAY_SIZE(bfin_uart0_resources),
|
|
|
+ .resource = bfin_uart0_resources,
|
|
|
+ .dev = {
|
|
|
+ .platform_data = &bfin_uart0_peripherals, /* Passed to driver */
|
|
|
+ },
|
|
|
+};
|
|
|
+#endif
|
|
|
+#ifdef CONFIG_SERIAL_BFIN_UART1
|
|
|
+static struct resource bfin_uart1_resources[] = {
|
|
|
+ {
|
|
|
+ .start = UART1_THR,
|
|
|
+ .end = UART1_GCTL+2,
|
|
|
+ .flags = IORESOURCE_MEM,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = IRQ_UART1_TX,
|
|
|
+ .end = IRQ_UART1_TX,
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = IRQ_UART1_RX,
|
|
|
+ .end = IRQ_UART1_RX,
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = IRQ_UART1_ERROR,
|
|
|
+ .end = IRQ_UART1_ERROR,
|
|
|
+ .flags = IORESOURCE_IRQ,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = CH_UART1_TX,
|
|
|
+ .end = CH_UART1_TX,
|
|
|
+ .flags = IORESOURCE_DMA,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ .start = CH_UART1_RX,
|
|
|
+ .end = CH_UART1_RX,
|
|
|
+ .flags = IORESOURCE_DMA,
|
|
|
+ },
|
|
|
+#ifdef CONFIG_BFIN_UART1_CTSRTS
|
|
|
+ { /* CTS pin */
|
|
|
+ .start = GPIO_PF9,
|
|
|
+ .end = GPIO_PF9,
|
|
|
+ .flags = IORESOURCE_IO,
|
|
|
+ },
|
|
|
+ { /* RTS pin */
|
|
|
+ .start = GPIO_PF10,
|
|
|
+ .end = GPIO_PF10,
|
|
|
+ .flags = IORESOURCE_IO,
|
|
|
+ },
|
|
|
+#endif
|
|
|
+};
|
|
|
+
|
|
|
+static unsigned short bfin_uart1_peripherals[] = {
|
|
|
+ P_UART1_TX, P_UART1_RX, 0
|
|
|
+};
|
|
|
+
|