Commit 8c03a888 authored by Bartosz Golaszewski's avatar Bartosz Golaszewski Committed by Sekhar Nori

ARM: davinci: dm365-evm: use the ti-aemif soc driver

We now support board files in the aemif driver. Register a platform
device instead of using the handcrafted API in dm365-evm.
Signed-off-by: default avatarBartosz Golaszewski <bgolaszewski@baylibre.com>
Signed-off-by: default avatarSekhar Nori <nsekhar@ti.com>
parent d51626ce
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include <linux/spi/spi.h> #include <linux/spi/spi.h>
#include <linux/spi/eeprom.h> #include <linux/spi/eeprom.h>
#include <linux/v4l2-dv-timings.h> #include <linux/v4l2-dv-timings.h>
#include <linux/platform_data/ti-aemif.h>
#include <asm/mach-types.h> #include <asm/mach-types.h>
#include <asm/mach/arch.h> #include <asm/mach/arch.h>
...@@ -159,14 +160,47 @@ static struct resource davinci_nand_resources[] = { ...@@ -159,14 +160,47 @@ static struct resource davinci_nand_resources[] = {
}, },
}; };
static struct platform_device davinci_nand_device = { static struct platform_device davinci_aemif_devices[] = {
.name = "davinci_nand", {
.id = 0, .name = "davinci_nand",
.num_resources = ARRAY_SIZE(davinci_nand_resources), .id = 0,
.resource = davinci_nand_resources, .num_resources = ARRAY_SIZE(davinci_nand_resources),
.dev = { .resource = davinci_nand_resources,
.platform_data = &davinci_nand_data, .dev = {
.platform_data = &davinci_nand_data,
},
}
};
static struct resource davinci_aemif_resources[] = {
{
.start = DM365_ASYNC_EMIF_CONTROL_BASE,
.end = DM365_ASYNC_EMIF_CONTROL_BASE + SZ_4K - 1,
.flags = IORESOURCE_MEM,
},
};
static struct aemif_abus_data da850_evm_aemif_abus_data[] = {
{
.cs = 1,
},
};
static struct aemif_platform_data davinci_aemif_pdata = {
.abus_data = da850_evm_aemif_abus_data,
.num_abus_data = ARRAY_SIZE(da850_evm_aemif_abus_data),
.sub_devices = davinci_aemif_devices,
.num_sub_devices = ARRAY_SIZE(davinci_aemif_devices),
};
static struct platform_device davinci_aemif_device = {
.name = "ti-aemif",
.id = -1,
.dev = {
.platform_data = &davinci_aemif_pdata,
}, },
.resource = davinci_aemif_resources,
.num_resources = ARRAY_SIZE(davinci_aemif_resources),
}; };
static struct at24_platform_data eeprom_info = { static struct at24_platform_data eeprom_info = {
...@@ -537,10 +571,6 @@ static void __init evm_init_i2c(void) ...@@ -537,10 +571,6 @@ static void __init evm_init_i2c(void)
i2c_register_board_info(1, i2c_info, ARRAY_SIZE(i2c_info)); i2c_register_board_info(1, i2c_info, ARRAY_SIZE(i2c_info));
} }
static struct platform_device *dm365_evm_nand_devices[] __initdata = {
&davinci_nand_device,
};
static inline int have_leds(void) static inline int have_leds(void)
{ {
#ifdef CONFIG_LEDS_CLASS #ifdef CONFIG_LEDS_CLASS
...@@ -628,6 +658,7 @@ static void __init evm_init_cpld(void) ...@@ -628,6 +658,7 @@ static void __init evm_init_cpld(void)
u8 mux, resets; u8 mux, resets;
const char *label; const char *label;
struct clk *aemif_clk; struct clk *aemif_clk;
int rc;
/* Make sure we can configure the CPLD through CS1. Then /* Make sure we can configure the CPLD through CS1. Then
* leave it on for later access to MMC and LED registers. * leave it on for later access to MMC and LED registers.
...@@ -660,8 +691,10 @@ static void __init evm_init_cpld(void) ...@@ -660,8 +691,10 @@ static void __init evm_init_cpld(void)
/* external keypad mux */ /* external keypad mux */
mux |= BIT(7); mux |= BIT(7);
platform_add_devices(dm365_evm_nand_devices, rc = platform_device_register(&davinci_aemif_device);
ARRAY_SIZE(dm365_evm_nand_devices)); if (rc)
pr_warn("%s(): error registering the aemif device: %d\n",
__func__, rc);
} else { } else {
/* no OneNAND support yet */ /* no OneNAND support yet */
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment