Commit 2119c0a7 authored by Spencer Oliver's avatar Spencer Oliver
Browse files

STM32: Add Value Line Flash Programming Support


Signed-off-by: default avatarSpencer Oliver <ntfreak@users.sourceforge.net>
parent 381ce430
...@@ -743,6 +743,21 @@ static int stm32x_probe(struct flash_bank *bank) ...@@ -743,6 +743,21 @@ static int stm32x_probe(struct flash_bank *bank)
num_pages = 256; num_pages = 256;
} }
} }
else if ((device_id & 0x7ff) == 0x420)
{
/* value line density - we have 1k pages
* 4 pages for a protection area */
page_size = 1024;
stm32x_info->ppage_size = 4;
/* check for early silicon */
if (num_pages == 0xffff)
{
/* number of sectors may be incorrrect on early silicon */
LOG_WARNING("STM32 flash size failed, probe inaccurate - assuming 128k flash");
num_pages = 128;
}
}
else else
{ {
LOG_WARNING("Cannot identify target as a STM32 family."); LOG_WARNING("Cannot identify target as a STM32 family.");
...@@ -884,6 +899,27 @@ static int stm32x_info(struct flash_bank *bank, char *buf, int buf_size) ...@@ -884,6 +899,27 @@ static int stm32x_info(struct flash_bank *bank, char *buf, int buf_size)
break; break;
} }
} }
else if ((device_id & 0x7ff) == 0x420)
{
printed = snprintf(buf, buf_size, "stm32x (Value) - Rev: ");
buf += printed;
buf_size -= printed;
switch (device_id >> 16)
{
case 0x1000:
snprintf(buf, buf_size, "A");
break;
case 0x1001:
snprintf(buf, buf_size, "Z");
break;
default:
snprintf(buf, buf_size, "unknown");
break;
}
}
else else
{ {
snprintf(buf, buf_size, "Cannot identify target as a stm32x\n"); snprintf(buf, buf_size, "Cannot identify target as a stm32x\n");
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment