summaryrefslogtreecommitdiffstats
path: root/target/linux/ixp4xx/patches/420-pronghorn_metro_mtd_microcode.patch
blob: 0c304c78ffe36c5c7652aaffab03cfe3406e321e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
diff -Nur linux-2.6.21.1/arch/arm/mach-ixp4xx/pronghornmetro-setup.c linux-2.6.21.1-owrt/arch/arm/mach-ixp4xx/pronghornmetro-setup.c
--- linux-2.6.21.1/arch/arm/mach-ixp4xx/pronghornmetro-setup.c	2007-06-10 14:10:24.000000000 +0200
+++ linux-2.6.21.1-owrt/arch/arm/mach-ixp4xx/pronghornmetro-setup.c	2007-06-10 14:10:15.000000000 +0200
@@ -17,6 +17,7 @@
 #include <linux/serial.h>
 #include <linux/tty.h>
 #include <linux/serial_8250.h>
+#include <linux/mtd/mtd.h>
 #include <linux/slab.h>
 
 #include <asm/types.h>
@@ -122,11 +123,34 @@
 	.resource	= &res_mac1,
 };
 
+struct npe_ucode_platform_data pronghornmetro_npe_ucode_data = {
+	.mtd_partition	= "RedBoot",
+};
+
+static struct platform_device pronghornmetro_npe_ucode = {
+	.name			= "ixp4xx_npe_ucode",
+	.id			= 0,
+	.dev.platform_data	= &pronghornmetro_npe_ucode_data,
+};
+
 static struct platform_device *pronghornmetro_devices[] __initdata = {
 	&pronghornmetro_flash,
 	&pronghornmetro_uart,
 	&mac0,
 	&mac1,
+	&pronghornmetro_npe_ucode,
+};
+
+static void pronghornmetro_flash_add(struct mtd_info *mtd)
+{
+}
+
+static void pronghornmetro_flash_remove(struct mtd_info *mtd) {
+}
+
+static struct mtd_notifier pronghornmetro_flash_notifier = {
+	.add = pronghornmetro_flash_add,
+	.remove = pronghornmetro_flash_remove,
 };
 
 static void __init pronghornmetro_init(void)
@@ -140,6 +164,8 @@
 	*IXP4XX_EXP_CS1 = *IXP4XX_EXP_CS0;
 
 	platform_add_devices(pronghornmetro_devices, ARRAY_SIZE(pronghornmetro_devices));
+
+	register_mtd_user(&pronghornmetro_flash_notifier);
 }
 
 #ifdef CONFIG_MACH_PRONGHORNMETRO