]> git.sur5r.net Git - openocd/commitdiff
Author: Raúl Sánchez Siles <rsanchezs@infoglobal.es>
authorkc8apf <kc8apf@b42882b7-edfa-0310-969c-e2dbd0fdcd60>
Fri, 22 May 2009 17:48:26 +0000 (17:48 +0000)
committerkc8apf <kc8apf@b42882b7-edfa-0310-969c-e2dbd0fdcd60>
Fri, 22 May 2009 17:48:26 +0000 (17:48 +0000)
- Fix calculation of flash_address for x16 devices used as x8

git-svn-id: svn://svn.berlios.de/openocd/trunk@1885 b42882b7-edfa-0310-969c-e2dbd0fdcd60

src/flash/cfi.c

index c51539fe54da8201a3cac18ca979394345aa55bc..7ae58f10439b5172038a217652f8b017d1c774d8 100644 (file)
@@ -112,9 +112,11 @@ static void cfi_fixup(flash_bank_t *bank, cfi_fixup_t *fixups)
 /* inline u32 flash_address(flash_bank_t *bank, int sector, u32 offset) */
 static __inline__ u32 flash_address(flash_bank_t *bank, int sector, u32 offset)
 {
+       cfi_flash_bank_t *cfi_info = bank->driver_priv;
+
        /* while the sector list isn't built, only accesses to sector 0 work */
        if (sector == 0)
-               return bank->base + offset * bank->bus_width;
+               return bank->base + (offset * bank->bus_width << cfi_info->x16_as_x8 );
        else
        {
                if (!bank->sectors)
@@ -122,7 +124,7 @@ static __inline__ u32 flash_address(flash_bank_t *bank, int sector, u32 offset)
                        LOG_ERROR("BUG: sector list not yet built");
                        exit(-1);
                }
-               return bank->base + bank->sectors[sector].offset + offset * bank->bus_width;
+               return bank->base + bank->sectors[sector].offset + (offset * bank->bus_width << cfi_info->x16_as_x8 );
        }
 
 }