summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWolfgang Denk <wd@denx.de>2011-03-31 08:59:32 +0200
committerWolfgang Denk <wd@denx.de>2011-03-31 08:59:32 +0200
commit53ce77eef1090e3f4004398c1d2abb410b63235c (patch)
treecee5ca1c3948bfdc8769c6658ced66bcd775487e
parent7ec830d5804337afe19413c3eaedd16583af9076 (diff)
parentaf5673015315d069b7e2d64acbbf8b5f5fcc385d (diff)
downloadu-boot-imx-53ce77eef1090e3f4004398c1d2abb410b63235c.zip
u-boot-imx-53ce77eef1090e3f4004398c1d2abb410b63235c.tar.gz
u-boot-imx-53ce77eef1090e3f4004398c1d2abb410b63235c.tar.bz2
Merge branch 'master' of git://git.denx.de/u-boot-cfi-flash
-rw-r--r--drivers/mtd/cfi_flash.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/mtd/cfi_flash.c b/drivers/mtd/cfi_flash.c
index dd394a8..0909fe7 100644
--- a/drivers/mtd/cfi_flash.c
+++ b/drivers/mtd/cfi_flash.c
@@ -744,8 +744,12 @@ static void flash_add_byte (flash_info_t * info, cfiword_t * cword, uchar c)
static flash_sect_t find_sector (flash_info_t * info, ulong addr)
{
static flash_sect_t saved_sector = 0; /* previously found sector */
+ static flash_info_t *saved_info = 0; /* previously used flash bank */
flash_sect_t sector = saved_sector;
+ if ((info != saved_info) || (sector >= info->sector_count))
+ sector = 0;
+
while ((info->start[sector] < addr)
&& (sector < info->sector_count - 1))
sector++;
@@ -757,6 +761,7 @@ static flash_sect_t find_sector (flash_info_t * info, ulong addr)
sector--;
saved_sector = sector;
+ saved_info = info;
return sector;
}