From db0258a7d8e6b2067f99d7127d7ce32d23c92846 Mon Sep 17 00:00:00 2001 From: Stefan Rueger <stefan.rueger@urclocks.com> Date: Sat, 10 Dec 2022 23:28:56 +0000 Subject: [PATCH] Add fuses, usersig, userrow, signature and data to elf_mem_limits() --- src/fileio.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/fileio.c b/src/fileio.c index b2f29bf7..77cedbe3 100644 --- a/src/fileio.c +++ b/src/fileio.c @@ -730,11 +730,15 @@ static int elf_mem_limits(const AVRMEM *mem, const AVRPART *p, *lowbound = 0; *highbound = 0x7Fffff; // Max 8 MiB *fileoff = 0; + } else if (strcmp(mem->desc, "data") == 0) { // Volatile SRAM for XMEGA (not the .data section) + *lowbound = 0x802000; + *highbound = 0x80ffff; + *fileoff = 0; } else if (strcmp(mem->desc, "eeprom") == 0) { *lowbound = 0x810000; *highbound = 0x81ffff; // Max 64 KiB *fileoff = 0; - } else if (strcmp(mem->desc, "lfuse") == 0) { + } else if (strcmp(mem->desc, "lfuse") == 0 || strcmp(mem->desc, "fuses") == 0) { *lowbound = 0x820000; *highbound = 0x82ffff; *fileoff = 0; @@ -752,10 +756,18 @@ static int elf_mem_limits(const AVRMEM *mem, const AVRPART *p, *lowbound = 0x820000; *highbound = 0x82ffff; *fileoff = mem->desc[4] - '0'; - } else if (strncmp(mem->desc, "lock", 4) == 0) { + } else if (strncmp(mem->desc, "lock", 4) == 0) { // Lock or lockbits *lowbound = 0x830000; *highbound = 0x83ffff; *fileoff = 0; + } else if (strcmp(mem->desc, "signature") == 0) { // Read only + *lowbound = 0x840000; + *highbound = 0x84ffff; + *fileoff = 0; + } else if (strncmp(mem->desc, "user", 4) == 0) { // Usersig or userrow + *lowbound = 0x850000; + *highbound = 0x85ffff; + *fileoff = 0; } else { rv = -1; }