nRF51: Fix bug in Code memory size.
The code memory size was a bug and seemed to be working by accident since there happened to be 256 pages in the device that was tested on which corresponded to 256kb. Also don't fail if memory size != expected memory size based on hwid as this hwid is unstable and should be used only for debug/diagnostics. Change-Id: I4e98f7498a36c53fc51783eddfdaba704d30e3ca Signed-off-by: Michael Dietz <mjdietzx@gmail.com> Reviewed-on: http://openocd.zylin.com/3510 Tested-by: jenkins Reviewed-by: Jiří Pinkava <j-pi@seznam.cz> Reviewed-by: Tomas Vanek <vanekt@fbl.cz>
This commit is contained in:
parent
db6c6f5da4
commit
400dbedaee
|
@ -108,7 +108,6 @@ enum nrf51_nvmc_config_bits {
|
||||||
|
|
||||||
struct nrf51_info {
|
struct nrf51_info {
|
||||||
uint32_t code_page_size;
|
uint32_t code_page_size;
|
||||||
uint32_t code_memory_size;
|
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
bool probed;
|
bool probed;
|
||||||
|
@ -641,8 +640,8 @@ static int nrf51_probe(struct flash_bank *bank)
|
||||||
LOG_WARNING("Unknown device (HWID 0x%08" PRIx32 ")", hwid);
|
LOG_WARNING("Unknown device (HWID 0x%08" PRIx32 ")", hwid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (bank->base == NRF51_FLASH_BASE) {
|
if (bank->base == NRF51_FLASH_BASE) {
|
||||||
|
/* The value stored in NRF51_FICR_CODEPAGESIZE is the number of bytes in one page of FLASH. */
|
||||||
res = target_read_u32(chip->target, NRF51_FICR_CODEPAGESIZE,
|
res = target_read_u32(chip->target, NRF51_FICR_CODEPAGESIZE,
|
||||||
&chip->code_page_size);
|
&chip->code_page_size);
|
||||||
if (res != ERROR_OK) {
|
if (res != ERROR_OK) {
|
||||||
|
@ -650,20 +649,20 @@ static int nrf51_probe(struct flash_bank *bank)
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Note the register name is misleading,
|
||||||
|
* NRF51_FICR_CODESIZE is the number of pages in flash memory, not the number of bytes! */
|
||||||
res = target_read_u32(chip->target, NRF51_FICR_CODESIZE,
|
res = target_read_u32(chip->target, NRF51_FICR_CODESIZE,
|
||||||
&chip->code_memory_size);
|
(uint32_t *) &bank->num_sectors);
|
||||||
if (res != ERROR_OK) {
|
if (res != ERROR_OK) {
|
||||||
LOG_ERROR("Couldn't read code memory size");
|
LOG_ERROR("Couldn't read code memory size");
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (spec && chip->code_memory_size != spec->flash_size_kb) {
|
bank->size = bank->num_sectors * chip->code_page_size;
|
||||||
LOG_ERROR("Chip's reported Flash capacity does not match expected one");
|
|
||||||
return ERROR_FAIL;
|
if (spec && bank->size / 1024 != spec->flash_size_kb)
|
||||||
}
|
LOG_WARNING("Chip's reported Flash capacity does not match expected one");
|
||||||
|
|
||||||
bank->size = chip->code_memory_size * 1024;
|
|
||||||
bank->num_sectors = bank->size / chip->code_page_size;
|
|
||||||
bank->sectors = calloc(bank->num_sectors,
|
bank->sectors = calloc(bank->num_sectors,
|
||||||
sizeof((bank->sectors)[0]));
|
sizeof((bank->sectors)[0]));
|
||||||
if (!bank->sectors)
|
if (!bank->sectors)
|
||||||
|
@ -1272,7 +1271,7 @@ static int nrf51_info(struct flash_bank *bank, char *buf, int buf_size)
|
||||||
"reset value for XTALFREQ: %"PRIx32"\n"
|
"reset value for XTALFREQ: %"PRIx32"\n"
|
||||||
"firmware id: 0x%04"PRIx32,
|
"firmware id: 0x%04"PRIx32,
|
||||||
ficr[0].value,
|
ficr[0].value,
|
||||||
ficr[1].value,
|
(ficr[1].value * ficr[0].value) / 1024,
|
||||||
(ficr[2].value == 0xFFFFFFFF) ? 0 : ficr[2].value / 1024,
|
(ficr[2].value == 0xFFFFFFFF) ? 0 : ficr[2].value / 1024,
|
||||||
((ficr[3].value & 0xFF) == 0x00) ? "present" : "not present",
|
((ficr[3].value & 0xFF) == 0x00) ? "present" : "not present",
|
||||||
ficr[4].value,
|
ficr[4].value,
|
||||||
|
|
Loading…
Reference in New Issue