Hi Dave,
> My question therefore is - why doesn't "Burn via Programmer" automatically
> set "BOOTRST" ??
I think the original workflow was that "Burn bootloader" is something to
do once (or at least rarely), and "Upload using programmer" is something
to do many times. Since setting up most fuses only needs to happen once,
it probably made sense to do that in "Burn Bootloader", but not during
"Upload using programmer".
However, as you say, the BOOTRST fuse is intended to be different
between both cases, as it determines whether the main application (at
the start of flash, as uploaded using "Upload using programmer") or the
bootloader (at the end of flash, uploading using "Burn bootloader") is
to be started.
However, in practice, for most cases it actually works to leave the
BOOTRST fuse unchanged (in the "start bootloader" setting). Then startup
will run from the bootloader area, which is filled up with 0xff, which
are effectively NOPs (see
https://www.avrfreaks.net/comment/1847371#comment-1847371), and once
execution reaches the end of flash, it wraps around and starts the
application as intended. I recall this did not work on all atmega chips,
but I couldn't find the corresponding bug report now. Because of this
behavior, I suspect that nobody originally realized that there was any
need to change the BOOTRST fuse, since it worked as intended (or maybe
people knowingly chose to rely on this behavior, dunno).
So then I wonder: Do you *really* need to change the BOOTRST fuse?
Does the wraparound trick not work for you? Bill Westfield theorized
that Atmega2560 doesn't support the wraparound trick (here:
https://github.com/arduino/ArduinoCore-avr/issues/246#issuecomment-51999965),
but I'm not sure that was ever confirmed or debunked.
What this trick does mean is that when using "Upload using programmer",
you cannot actually use all of the flash - the bootloader area must be
kept at 0xff. IIRC in the current boards.txt spec there is also no way
to specify a different maximum sketch size for the two upload methods,
so keeping the bootloader area clear will happen automatically anyway.
There is this issue, which is about allowing use of the bootloader flash
area, which also discusses the need to change BOOTRST when using "Upload
using programmer". I suspect that this might be the most appropriate
github issue to track this issue now:
https://github.com/arduino/arduino-cli/issues/1035
I also found another issue mentioning BOOTRST, but it *seems* that that
issue is really a couple of different things intermixed, some of which
are fixed with a USBAsp firmware update it seems:
https://github.com/arduino/ArduinoCore-avr/issues/246
I cannot comment with much certainty, but I hope sharing my thoughts and
recollections would help here.
Gr.
Matthijs