danube gpio cleanup
[openwrt.git] / target / linux / rb532 / files / arch / mips / rb500 / devices.c
index d8342fe..dec2be9 100644 (file)
@@ -23,6 +23,8 @@
 #include <linux/mtd/mtd.h>
 #include <linux/mtd/partitions.h>
 
+#include <asm/bootinfo.h>
+
 #include <asm/rc32434/rc32434.h>
 #include <asm/rc32434/dma.h>
 #include <asm/rc32434/dma_v.h>
@@ -151,7 +153,7 @@ void rb500_cmd_ctrl(struct mtd_info *mtd, int cmd, unsigned int ctrl)
 }
 
 static struct resource nand_slot0_res[] = {
-       {
+       [0] = {
                .name = "nand_membase",
                .flags = IORESOURCE_MEM
        }
@@ -163,8 +165,8 @@ struct platform_nand_data rb500_nand_data = {
 };
 
 static struct platform_device nand_slot0 = {
-       .id = 0,
        .name = "gen_nand",
+       .id = -1,
        .resource = nand_slot0_res,
        .num_resources = ARRAY_SIZE(nand_slot0_res),
        .dev.platform_data = &rb500_nand_data,
@@ -182,11 +184,16 @@ static struct mtd_partition rb500_partition_info[] = {
        }
 };
 
+static struct platform_device rb500_led = {
+       .name = "rb500-led",
+       .id = 0,
+};
 
 static struct platform_device *rb500_devs[] = {
        &korina_dev0,
        &nand_slot0,
-       &cf_slot0
+       &cf_slot0,
+       &rb500_led
 };
 
 static void __init parse_mac_addr(char *macstr)
@@ -230,10 +237,21 @@ static void __init parse_mac_addr(char *macstr)
 
 static void __init rb500_nand_setup(void)
 {
-       if (!strcmp(board_type, "500r5"))
+       switch (mips_machtype) {
+       case MACH_MIKROTIK_RB532A:
                changeLatchU5(LO_FOFF | LO_CEX, LO_ULED | LO_ALE | LO_CLE | LO_WPX);
-        else
+               break;
+       default:
                changeLatchU5(LO_WPX | LO_FOFF | LO_CEX, LO_ULED | LO_ALE | LO_CLE);
+               break;
+       }
+
+       /* Setup NAND specific settings */
+       rb500_nand_data.chip.nr_chips = 1;
+       rb500_nand_data.chip.nr_partitions = ARRAY_SIZE(rb500_partition_info);
+       rb500_nand_data.chip.partitions = rb500_partition_info;
+       rb500_nand_data.chip.chip_delay = NAND_CHIP_DELAY;
+       rb500_nand_data.chip.options = NAND_NO_AUTOINCR;
 }
 
 
@@ -248,19 +266,12 @@ static int __init plat_setup_devices(void)
                cf_slot0_res[0].end = cf_slot0_res[0].start + 0x1000;
        }
 
-       /* Initialise the NAND device */
-       rb500_nand_setup();
-
        /* Read the NAND resources from the device controller */
        nand_slot0_res[0].start = readl(CFG_DC_DEV2 + CFG_DC_DEVBASE);
        nand_slot0_res[0].end = nand_slot0_res[0].start + 0x1000;
 
-       /* Setup NAND specific settings */
-       rb500_nand_data.chip.nr_chips = 1;
-       rb500_nand_data.chip.nr_partitions = ARRAY_SIZE(rb500_partition_info);
-       rb500_nand_data.chip.partitions = rb500_partition_info;
-       rb500_nand_data.chip.chip_delay = NAND_CHIP_DELAY;
-       rb500_nand_data.chip.options = NAND_NO_AUTOINCR;
+       /* Initialise the NAND device */
+       rb500_nand_setup();
 
        return platform_add_devices(rb500_devs, ARRAY_SIZE(rb500_devs));
 }
This page took 0.026393 seconds and 4 git commands to generate.