Skip to content

Commit

Permalink
Merge pull request #1883 from stefanrueger/erase
Browse files Browse the repository at this point in the history
Silently skip erasing read-only parts of a memory
  • Loading branch information
stefanrueger authored Aug 14, 2024
2 parents 2407424 + abb6fe6 commit 55fbcbd
Showing 1 changed file with 38 additions and 7 deletions.
45 changes: 38 additions & 7 deletions src/term.c
Original file line number Diff line number Diff line change
Expand Up @@ -1193,16 +1193,47 @@ static int cmd_erase(const PROGRAMMER *pgm, const AVRPART *p, int argc, const ch
return -1;
}
const char *args[] = {"write", memstr, "", "", "0xff", "...", NULL};
// erase <mem>
if (argc == 2) {
// Erase <mem>
if (argc == 2 && pgm->readonly) { // Process intervals that are writable
int addr, start = 0, end, memend = mem->size - 1;
do {
for(addr = start; addr <= memend; addr++)
if(!pgm->readonly(pgm, p, mem, addr)) {
start = addr;
break;
}
if(addr > memend)
break;
end = memend;
for(addr = start+1; addr <= memend; addr++)
if(pgm->readonly(pgm, p, mem, addr)) {
end = addr-1;
break;
}
if(start <= end) {
char nums[2][128];
sprintf(nums[0], "0x%04x", start);
sprintf(nums[1], "0x%04x", end-start+1);
args[2] = nums[0];
args[3] = nums[1];
if(cmd_write(pgm, p, 6, args) < 0)
return -1;
}
start = end+1;
} while (start <= memend);

return 0;
}

if(argc == 2) {
args[2] = "0";
args[3] = "-1";
return cmd_write(pgm, p, 6, args);
}
// erase <mem> <addr> <len>
else {
args[2] = argv[2];
args[3] = argv[3];
}

// Erase <mem> <addr> <len>
args[2] = argv[2];
args[3] = argv[3];
return cmd_write(pgm, p, 6, args);
}

Expand Down

0 comments on commit 55fbcbd

Please sign in to comment.