ralink: bump to the target to v4.3
[openwrt/svn-archive/archive.git] / target / linux / ramips / patches-4.3 / 0037-mtd-cfi-cmdset-0002-force-word-write.patch
1 From ee9081b2726a5ca8cde5497afdc5425e21ff8f8b Mon Sep 17 00:00:00 2001
2 From: John Crispin <blogic@openwrt.org>
3 Date: Mon, 15 Jul 2013 00:39:21 +0200
4 Subject: [PATCH 37/53] mtd: cfi cmdset 0002 force word write
5
6 ---
7 drivers/mtd/chips/cfi_cmdset_0002.c | 9 +++++++--
8 1 file changed, 7 insertions(+), 2 deletions(-)
9
10 diff --git a/drivers/mtd/chips/cfi_cmdset_0002.c b/drivers/mtd/chips/cfi_cmdset_0002.c
11 index 60d960a..a663e3b 100644
12 --- a/drivers/mtd/chips/cfi_cmdset_0002.c
13 +++ b/drivers/mtd/chips/cfi_cmdset_0002.c
14 @@ -40,7 +40,7 @@
15 #include <linux/mtd/xip.h>
16
17 #define AMD_BOOTLOC_BUG
18 -#define FORCE_WORD_WRITE 0
19 +#define FORCE_WORD_WRITE 1
20
21 #define MAX_WORD_RETRIES 3
22
23 @@ -51,7 +51,9 @@
24
25 static int cfi_amdstd_read (struct mtd_info *, loff_t, size_t, size_t *, u_char *);
26 static int cfi_amdstd_write_words(struct mtd_info *, loff_t, size_t, size_t *, const u_char *);
27 +#if !FORCE_WORD_WRITE
28 static int cfi_amdstd_write_buffers(struct mtd_info *, loff_t, size_t, size_t *, const u_char *);
29 +#endif
30 static int cfi_amdstd_erase_chip(struct mtd_info *, struct erase_info *);
31 static int cfi_amdstd_erase_varsize(struct mtd_info *, struct erase_info *);
32 static void cfi_amdstd_sync (struct mtd_info *);
33 @@ -202,6 +204,7 @@ static void fixup_amd_bootblock(struct mtd_info *mtd)
34 }
35 #endif
36
37 +#if !FORCE_WORD_WRITE
38 static void fixup_use_write_buffers(struct mtd_info *mtd)
39 {
40 struct map_info *map = mtd->priv;
41 @@ -211,6 +214,7 @@ static void fixup_use_write_buffers(struct mtd_info *mtd)
42 mtd->_write = cfi_amdstd_write_buffers;
43 }
44 }
45 +#endif /* !FORCE_WORD_WRITE */
46
47 /* Atmel chips don't use the same PRI format as AMD chips */
48 static void fixup_convert_atmel_pri(struct mtd_info *mtd)
49 @@ -1789,6 +1793,7 @@ static int cfi_amdstd_write_words(struct mtd_info *mtd, loff_t to, size_t len,
50 /*
51 * FIXME: interleaved mode not tested, and probably not supported!
52 */
53 +#if !FORCE_WORD_WRITE
54 static int __xipram do_write_buffer(struct map_info *map, struct flchip *chip,
55 unsigned long adr, const u_char *buf,
56 int len)
57 @@ -1916,7 +1921,6 @@ static int __xipram do_write_buffer(struct map_info *map, struct flchip *chip,
58 return ret;
59 }
60
61 -
62 static int cfi_amdstd_write_buffers(struct mtd_info *mtd, loff_t to, size_t len,
63 size_t *retlen, const u_char *buf)
64 {
65 @@ -1991,6 +1995,7 @@ static int cfi_amdstd_write_buffers(struct mtd_info *mtd, loff_t to, size_t len,
66
67 return 0;
68 }
69 +#endif /* !FORCE_WORD_WRITE */
70
71 /*
72 * Wait for the flash chip to become ready to write data
73 --
74 1.7.10.4
75