From: Spencer Oliver Date: Tue, 6 Aug 2013 13:36:12 +0000 (+0100) Subject: flash: fix stm32f1x dual bank detection X-Git-Tag: v0.8.0-rc1~308 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=017a202086603119793d8da56989591512d08ed0;p=users%2Fborneoa%2Fopenocd-next.git flash: fix stm32f1x dual bank detection Not all devices with devce id 0x419 have dual flash banks, only those with > 1024kB. Change-Id: I197d2b87df7599cd0837e25648af48439f2f1e50 Signed-off-by: Spencer Oliver Reviewed-on: http://openocd.zylin.com/1544 Tested-by: jenkins --- diff --git a/src/flash/nor/stm32f2x.c b/src/flash/nor/stm32f2x.c index 89fad60c7..91baec4b8 100644 --- a/src/flash/nor/stm32f2x.c +++ b/src/flash/nor/stm32f2x.c @@ -770,7 +770,6 @@ static int stm32x_probe(struct flash_bank *bank) break; case 0x419: max_flash_size_in_kb = 2048; - stm32x_info->has_large_mem = true; break; case 0x423: max_flash_size_in_kb = 256; @@ -798,6 +797,10 @@ static int stm32x_probe(struct flash_bank *bank) flash_size_in_kb = stm32x_info->user_bank_size / 1024; } + /* only devices with > 1024kB have dual banks */ + if (flash_size_in_kb > 1024) + stm32x_info->has_large_mem = true; + LOG_INFO("flash size = %dkbytes", flash_size_in_kb); /* did we assign flash size? */