diff options
-rw-r--r-- | drivers/mtd/chips/cfi_cmdset_0001.c | 52 | ||||
-rw-r--r-- | include/linux/mtd/flashchip.h | 4 |
2 files changed, 42 insertions, 14 deletions
diff --git a/drivers/mtd/chips/cfi_cmdset_0001.c b/drivers/mtd/chips/cfi_cmdset_0001.c index d49cbe2738a8..5157e3cb4b9e 100644 --- a/drivers/mtd/chips/cfi_cmdset_0001.c +++ b/drivers/mtd/chips/cfi_cmdset_0001.c | |||
@@ -478,6 +478,28 @@ struct mtd_info *cfi_cmdset_0001(struct map_info *map, int primary) | |||
478 | else | 478 | else |
479 | cfi->chips[i].erase_time = 2000000; | 479 | cfi->chips[i].erase_time = 2000000; |
480 | 480 | ||
481 | if (cfi->cfiq->WordWriteTimeoutTyp && | ||
482 | cfi->cfiq->WordWriteTimeoutMax) | ||
483 | cfi->chips[i].word_write_time_max = | ||
484 | 1<<(cfi->cfiq->WordWriteTimeoutTyp + | ||
485 | cfi->cfiq->WordWriteTimeoutMax); | ||
486 | else | ||
487 | cfi->chips[i].word_write_time_max = 50000 * 8; | ||
488 | |||
489 | if (cfi->cfiq->BufWriteTimeoutTyp && | ||
490 | cfi->cfiq->BufWriteTimeoutMax) | ||
491 | cfi->chips[i].buffer_write_time_max = | ||
492 | 1<<(cfi->cfiq->BufWriteTimeoutTyp + | ||
493 | cfi->cfiq->BufWriteTimeoutMax); | ||
494 | |||
495 | if (cfi->cfiq->BlockEraseTimeoutTyp && | ||
496 | cfi->cfiq->BlockEraseTimeoutMax) | ||
497 | cfi->chips[i].erase_time_max = | ||
498 | 1000<<(cfi->cfiq->BlockEraseTimeoutTyp + | ||
499 | cfi->cfiq->BlockEraseTimeoutMax); | ||
500 | else | ||
501 | cfi->chips[i].erase_time_max = 2000000 * 8; | ||
502 | |||
481 | cfi->chips[i].ref_point_counter = 0; | 503 | cfi->chips[i].ref_point_counter = 0; |
482 | init_waitqueue_head(&(cfi->chips[i].wq)); | 504 | init_waitqueue_head(&(cfi->chips[i].wq)); |
483 | } | 505 | } |
@@ -1012,7 +1034,7 @@ static void __xipram xip_enable(struct map_info *map, struct flchip *chip, | |||
1012 | 1034 | ||
1013 | static int __xipram xip_wait_for_operation( | 1035 | static int __xipram xip_wait_for_operation( |
1014 | struct map_info *map, struct flchip *chip, | 1036 | struct map_info *map, struct flchip *chip, |
1015 | unsigned long adr, unsigned int chip_op_time ) | 1037 | unsigned long adr, unsigned int chip_op_time_max) |
1016 | { | 1038 | { |
1017 | struct cfi_private *cfi = map->fldrv_priv; | 1039 | struct cfi_private *cfi = map->fldrv_priv; |
1018 | struct cfi_pri_intelext *cfip = cfi->cmdset_priv; | 1040 | struct cfi_pri_intelext *cfip = cfi->cmdset_priv; |
@@ -1021,7 +1043,7 @@ static int __xipram xip_wait_for_operation( | |||
1021 | flstate_t oldstate, newstate; | 1043 | flstate_t oldstate, newstate; |
1022 | 1044 | ||
1023 | start = xip_currtime(); | 1045 | start = xip_currtime(); |
1024 | usec = chip_op_time * 8; | 1046 | usec = chip_op_time_max; |
1025 | if (usec == 0) | 1047 | if (usec == 0) |
1026 | usec = 500000; | 1048 | usec = 500000; |
1027 | done = 0; | 1049 | done = 0; |
@@ -1131,8 +1153,8 @@ static int __xipram xip_wait_for_operation( | |||
1131 | #define XIP_INVAL_CACHED_RANGE(map, from, size) \ | 1153 | #define XIP_INVAL_CACHED_RANGE(map, from, size) \ |
1132 | INVALIDATE_CACHED_RANGE(map, from, size) | 1154 | INVALIDATE_CACHED_RANGE(map, from, size) |
1133 | 1155 | ||
1134 | #define INVAL_CACHE_AND_WAIT(map, chip, cmd_adr, inval_adr, inval_len, usec) \ | 1156 | #define INVAL_CACHE_AND_WAIT(map, chip, cmd_adr, inval_adr, inval_len, usec, usec_max) \ |
1135 | xip_wait_for_operation(map, chip, cmd_adr, usec) | 1157 | xip_wait_for_operation(map, chip, cmd_adr, usec_max) |
1136 | 1158 | ||
1137 | #else | 1159 | #else |
1138 | 1160 | ||
@@ -1144,7 +1166,7 @@ static int __xipram xip_wait_for_operation( | |||
1144 | static int inval_cache_and_wait_for_operation( | 1166 | static int inval_cache_and_wait_for_operation( |
1145 | struct map_info *map, struct flchip *chip, | 1167 | struct map_info *map, struct flchip *chip, |
1146 | unsigned long cmd_adr, unsigned long inval_adr, int inval_len, | 1168 | unsigned long cmd_adr, unsigned long inval_adr, int inval_len, |
1147 | unsigned int chip_op_time) | 1169 | unsigned int chip_op_time, unsigned int chip_op_time_max) |
1148 | { | 1170 | { |
1149 | struct cfi_private *cfi = map->fldrv_priv; | 1171 | struct cfi_private *cfi = map->fldrv_priv; |
1150 | map_word status, status_OK = CMD(0x80); | 1172 | map_word status, status_OK = CMD(0x80); |
@@ -1156,8 +1178,7 @@ static int inval_cache_and_wait_for_operation( | |||
1156 | INVALIDATE_CACHED_RANGE(map, inval_adr, inval_len); | 1178 | INVALIDATE_CACHED_RANGE(map, inval_adr, inval_len); |
1157 | spin_lock(chip->mutex); | 1179 | spin_lock(chip->mutex); |
1158 | 1180 | ||
1159 | /* set our timeout to 8 times the expected delay */ | 1181 | timeo = chip_op_time_max; |
1160 | timeo = chip_op_time * 8; | ||
1161 | if (!timeo) | 1182 | if (!timeo) |
1162 | timeo = 500000; | 1183 | timeo = 500000; |
1163 | reset_timeo = timeo; | 1184 | reset_timeo = timeo; |
@@ -1217,8 +1238,8 @@ static int inval_cache_and_wait_for_operation( | |||
1217 | 1238 | ||
1218 | #endif | 1239 | #endif |
1219 | 1240 | ||
1220 | #define WAIT_TIMEOUT(map, chip, adr, udelay) \ | 1241 | #define WAIT_TIMEOUT(map, chip, adr, udelay, udelay_max) \ |
1221 | INVAL_CACHE_AND_WAIT(map, chip, adr, 0, 0, udelay); | 1242 | INVAL_CACHE_AND_WAIT(map, chip, adr, 0, 0, udelay, udelay_max); |
1222 | 1243 | ||
1223 | 1244 | ||
1224 | static int do_point_onechip (struct map_info *map, struct flchip *chip, loff_t adr, size_t len) | 1245 | static int do_point_onechip (struct map_info *map, struct flchip *chip, loff_t adr, size_t len) |
@@ -1452,7 +1473,8 @@ static int __xipram do_write_oneword(struct map_info *map, struct flchip *chip, | |||
1452 | 1473 | ||
1453 | ret = INVAL_CACHE_AND_WAIT(map, chip, adr, | 1474 | ret = INVAL_CACHE_AND_WAIT(map, chip, adr, |
1454 | adr, map_bankwidth(map), | 1475 | adr, map_bankwidth(map), |
1455 | chip->word_write_time); | 1476 | chip->word_write_time, |
1477 | chip->word_write_time_max); | ||
1456 | if (ret) { | 1478 | if (ret) { |
1457 | xip_enable(map, chip, adr); | 1479 | xip_enable(map, chip, adr); |
1458 | printk(KERN_ERR "%s: word write error (status timeout)\n", map->name); | 1480 | printk(KERN_ERR "%s: word write error (status timeout)\n", map->name); |
@@ -1623,7 +1645,7 @@ static int __xipram do_write_buffer(struct map_info *map, struct flchip *chip, | |||
1623 | 1645 | ||
1624 | chip->state = FL_WRITING_TO_BUFFER; | 1646 | chip->state = FL_WRITING_TO_BUFFER; |
1625 | map_write(map, write_cmd, cmd_adr); | 1647 | map_write(map, write_cmd, cmd_adr); |
1626 | ret = WAIT_TIMEOUT(map, chip, cmd_adr, 0); | 1648 | ret = WAIT_TIMEOUT(map, chip, cmd_adr, 0, 0); |
1627 | if (ret) { | 1649 | if (ret) { |
1628 | /* Argh. Not ready for write to buffer */ | 1650 | /* Argh. Not ready for write to buffer */ |
1629 | map_word Xstatus = map_read(map, cmd_adr); | 1651 | map_word Xstatus = map_read(map, cmd_adr); |
@@ -1692,7 +1714,8 @@ static int __xipram do_write_buffer(struct map_info *map, struct flchip *chip, | |||
1692 | 1714 | ||
1693 | ret = INVAL_CACHE_AND_WAIT(map, chip, cmd_adr, | 1715 | ret = INVAL_CACHE_AND_WAIT(map, chip, cmd_adr, |
1694 | initial_adr, initial_len, | 1716 | initial_adr, initial_len, |
1695 | chip->buffer_write_time); | 1717 | chip->buffer_write_time, |
1718 | chip->buffer_write_time_max); | ||
1696 | if (ret) { | 1719 | if (ret) { |
1697 | map_write(map, CMD(0x70), cmd_adr); | 1720 | map_write(map, CMD(0x70), cmd_adr); |
1698 | chip->state = FL_STATUS; | 1721 | chip->state = FL_STATUS; |
@@ -1827,7 +1850,8 @@ static int __xipram do_erase_oneblock(struct map_info *map, struct flchip *chip, | |||
1827 | 1850 | ||
1828 | ret = INVAL_CACHE_AND_WAIT(map, chip, adr, | 1851 | ret = INVAL_CACHE_AND_WAIT(map, chip, adr, |
1829 | adr, len, | 1852 | adr, len, |
1830 | chip->erase_time); | 1853 | chip->erase_time, |
1854 | chip->erase_time_max); | ||
1831 | if (ret) { | 1855 | if (ret) { |
1832 | map_write(map, CMD(0x70), adr); | 1856 | map_write(map, CMD(0x70), adr); |
1833 | chip->state = FL_STATUS; | 1857 | chip->state = FL_STATUS; |
@@ -2006,7 +2030,7 @@ static int __xipram do_xxlock_oneblock(struct map_info *map, struct flchip *chip | |||
2006 | */ | 2030 | */ |
2007 | udelay = (!extp || !(extp->FeatureSupport & (1 << 5))) ? 1000000/HZ : 0; | 2031 | udelay = (!extp || !(extp->FeatureSupport & (1 << 5))) ? 1000000/HZ : 0; |
2008 | 2032 | ||
2009 | ret = WAIT_TIMEOUT(map, chip, adr, udelay); | 2033 | ret = WAIT_TIMEOUT(map, chip, adr, udelay, udelay * 100); |
2010 | if (ret) { | 2034 | if (ret) { |
2011 | map_write(map, CMD(0x70), adr); | 2035 | map_write(map, CMD(0x70), adr); |
2012 | chip->state = FL_STATUS; | 2036 | chip->state = FL_STATUS; |
diff --git a/include/linux/mtd/flashchip.h b/include/linux/mtd/flashchip.h index 08dd131301c1..d4f38c5fd44e 100644 --- a/include/linux/mtd/flashchip.h +++ b/include/linux/mtd/flashchip.h | |||
@@ -73,6 +73,10 @@ struct flchip { | |||
73 | int buffer_write_time; | 73 | int buffer_write_time; |
74 | int erase_time; | 74 | int erase_time; |
75 | 75 | ||
76 | int word_write_time_max; | ||
77 | int buffer_write_time_max; | ||
78 | int erase_time_max; | ||
79 | |||
76 | void *priv; | 80 | void *priv; |
77 | }; | 81 | }; |
78 | 82 | ||