samd: parameterize memory and flash sizes
Various SAMD devices have different amounts of memory. Up until now, all SAMD devices have had the same amount, and therefore this value was hardcoded to 32k of RAM and 256k of flash. Add a parameter to the description field and set it to default to the previous values. Use this description field when adding memories to the target definition. Signed-off-by: Sean Cross <sean@xobs.io>
This commit is contained in:
parent
8039e2b26a
commit
d00607f71a
|
@ -341,6 +341,8 @@ struct samd_descr {
|
||||||
uint8_t series;
|
uint8_t series;
|
||||||
char revision;
|
char revision;
|
||||||
char pin;
|
char pin;
|
||||||
|
uint32_t ram_size;
|
||||||
|
uint32_t flash_size;
|
||||||
uint8_t mem;
|
uint8_t mem;
|
||||||
char variant;
|
char variant;
|
||||||
char package[3];
|
char package[3];
|
||||||
|
@ -351,6 +353,8 @@ struct samd_descr samd_parse_device_id(uint32_t did)
|
||||||
uint8_t i = 0;
|
uint8_t i = 0;
|
||||||
const struct samd_part *parts = samd_d21_parts;
|
const struct samd_part *parts = samd_d21_parts;
|
||||||
memset(samd.package, 0, 3);
|
memset(samd.package, 0, 3);
|
||||||
|
samd.ram_size = 0x8000;
|
||||||
|
samd.flash_size = 0x40000;
|
||||||
|
|
||||||
uint8_t family = (did >> SAMD_DID_FAMILY_POS)
|
uint8_t family = (did >> SAMD_DID_FAMILY_POS)
|
||||||
& SAMD_DID_FAMILY_MASK;
|
& SAMD_DID_FAMILY_MASK;
|
||||||
|
@ -513,8 +517,8 @@ bool samd_probe(target *t)
|
||||||
t->attach = samd_protected_attach;
|
t->attach = samd_protected_attach;
|
||||||
}
|
}
|
||||||
|
|
||||||
target_add_ram(t, 0x20000000, 0x8000);
|
target_add_ram(t, 0x20000000, samd.ram_size);
|
||||||
samd_add_flash(t, 0x00000000, 0x40000);
|
samd_add_flash(t, 0x00000000, samd.flash_size);
|
||||||
target_add_commands(t, samd_cmd_list, "SAMD");
|
target_add_commands(t, samd_cmd_list, "SAMD");
|
||||||
|
|
||||||
/* If we're not in reset here */
|
/* If we're not in reset here */
|
||||||
|
|
Loading…
Reference in New Issue