-
Notifications
You must be signed in to change notification settings - Fork 312
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Shouldn't check_start_application clear *DBL_TAP_PTR on BOD reset, also? #88
Comments
I took a chance and flashed this bootloader onto a chip, and bricked it. I've ordered an ATMEL-ICE, should be here tomorrow. Not sure if I loaded it incorrectly (I used the resulting |
I generally had good luck using Particle Debugger (with openocd). |
Thanks. I'll order one of those, too. The ATMEL-ICE is already on its way. |
Most of us at Adafruit use J-Links. This one is inexpensive: https://www.adafruit.com/product/3571 (out of stock now, but do a websearch for other suppliers). This breakout is also useful: https://www.adafruit.com/product/2743 |
What |
The following should work:
Note that for bootloader it becomes much more tricky if the write protection is enabled. There are some scripts in this repo to disable it with openocd but it is a bit of a hit and miss for me. |
Thank you for your help so far. I’m running into this error, not sure if you can help. Google seems to turn up surprisingly little around this. $ openocd -f interface/cmsis-dap.cfg -f target/at91samdXX.cfg -c 'program build/feather_m0/bootloader-feather_m0-v3.7.0-73-g5ebe947a4384.elf verify reset exit'
Open On-Chip Debugger 0.10.0
Licensed under GNU GPL v2
For bug reports, read
http://openocd.org/doc/doxygen/bugs.html
Info : auto-selecting first available session transport "swd". To override use 'transport select <transport>'.
none separate
adapter speed: 400 kHz
cortex_m reset_config sysresetreq
Info : CMSIS-DAP: SWD Supported
Info : CMSIS-DAP: JTAG Supported
Info : CMSIS-DAP: Interface Initialised (SWD)
Info : CMSIS-DAP: FW Version = 01.00.0021
Info : SWCLK/TCK = 1 SWDIO/TMS = 1 TDI = 1 TDO = 1 nTRST = 0 nRESET = 1
Info : CMSIS-DAP: Interface ready
Info : clock speed 400 kHz
Info : SWD DPIDR 0x0bb11477
Info : at91samd.cpu: hardware has 4 breakpoints, 2 watchpoints
target halted due to debug-request, current mode: Thread
xPSR: 0xc1000000 pc: 0x000006d0 msp: 0x000007c0
** Programming Started **
auto erase enabled
Error: Couldn't find part corresponding to DID 00000000
Error: auto_probe failed
** Programming Failed **
shutdown command invoked I tried running the fuse repair (had to modify the I have an Atmel-ICE connected:
$ scripts/dbgtool.js fuses
File: fuses
pkgDir: /Users/rmann/Library/Arduino15/packages/arduino/
Starting /usr/local/Cellar/open-ocd/0.10.0/bin/openocd -d2 -s /usr/local/Cellar/open-ocd/0.10.0//share/openocd/scripts/ -f interface/cmsis-dap.cfg -f target/at91samdXX.cfg -f scripts/fuses.tcl
Open On-Chip Debugger 0.10.0
Licensed under GNU GPL v2
For bug reports, read
http://openocd.org/doc/doxygen/bugs.html
debug_level: 2
Info : auto-selecting first available session transport "swd". To override use 'transport select <transport>'.
none separate
adapter speed: 400 kHz
cortex_m reset_config sysresetreq
Info : CMSIS-DAP: SWD Supported
Info : CMSIS-DAP: JTAG Supported
Info : CMSIS-DAP: Interface Initialised (SWD)
Info : CMSIS-DAP: FW Version = 01.00.0021
Info : SWCLK/TCK = 1 SWDIO/TMS = 1 TDI = 1 TDO = 1 nTRST = 0 nRESET = 1
Info : CMSIS-DAP: Interface ready
Info : clock speed 400 kHz
Info : SWD DPIDR 0x0bb11477
Info : at91samd.cpu: hardware has 4 breakpoints, 2 watchpoints
Fuses:
0
0
*** Updating fuses! ***
7
0
shutdown command invoked |
Update: I was trying this with my bricked Feather M0 BLE. I tried it with a Feather M0 Basic, and it seems to have worked. So, I'm not sure what's going on. Initial programming attempt: $ openocd -f interface/cmsis-dap.cfg -f target/at91samdXX.cfg -c 'program build/feather_m0/bootloader-feather_m0-v3.7.0-73-g5ebe947a4384.elf verify reset exit'
Open On-Chip Debugger 0.10.0
Licensed under GNU GPL v2
For bug reports, read
http://openocd.org/doc/doxygen/bugs.html
Info : auto-selecting first available session transport "swd". To override use 'transport select <transport>'.
none separate
adapter speed: 400 kHz
cortex_m reset_config sysresetreq
Info : CMSIS-DAP: SWD Supported
Info : CMSIS-DAP: JTAG Supported
Info : CMSIS-DAP: Interface Initialised (SWD)
Info : CMSIS-DAP: FW Version = 01.00.0021
Info : SWCLK/TCK = 1 SWDIO/TMS = 1 TDI = 1 TDO = 1 nTRST = 0 nRESET = 1
Info : CMSIS-DAP: Interface ready
Info : clock speed 400 kHz
Info : SWD DPIDR 0x0bc11477
Info : at91samd.cpu: hardware has 4 breakpoints, 2 watchpoints
target halted due to debug-request, current mode: Thread
xPSR: 0x01000000 pc: 0x00000288 msp: 0x20002dd8
** Programming Started **
auto erase enabled
Info : SAMD MCU: SAMD21G18A (256KB Flash, 32KB RAM)
Info : Padding image section 1 with 268 bytes
Error: SAMD: NVM lock error
Error: Failed to erase row containing 00000000
Error: SAMD: failed to erase sector 0
Error: failed erasing sectors 0 to 0
** Programming Failed **
shutdown command invoked Successful fuse change: $ scripts/dbgtool.js fuses
File: fuses
pkgDir: /Users/rmann/Library/Arduino15/packages/arduino/
Starting /usr/local/Cellar/open-ocd/0.10.0/bin/openocd -d2 -s /usr/local/Cellar/open-ocd/0.10.0//share/openocd/scripts/ -f interface/cmsis-dap.cfg -f target/at91samdXX.cfg -f scripts/fuses.tcl
Open On-Chip Debugger 0.10.0
Licensed under GNU GPL v2
For bug reports, read
http://openocd.org/doc/doxygen/bugs.html
debug_level: 2
Info : auto-selecting first available session transport "swd". To override use 'transport select <transport>'.
none separate
adapter speed: 400 kHz
cortex_m reset_config sysresetreq
Info : CMSIS-DAP: SWD Supported
Info : CMSIS-DAP: JTAG Supported
Info : CMSIS-DAP: Interface Initialised (SWD)
Info : CMSIS-DAP: FW Version = 01.00.0021
Info : SWCLK/TCK = 1 SWDIO/TMS = 1 TDI = 1 TDO = 1 nTRST = 0 nRESET = 1
Info : CMSIS-DAP: Interface ready
Info : clock speed 400 kHz
Info : SWD DPIDR 0x0bc11477
Info : at91samd.cpu: hardware has 4 breakpoints, 2 watchpoints
Fuses:
d800c772
ffff005d
*** Updating fuses! ***
d800c777
ffff005d
shutdown command invoked Successful flash: $ openocd -f interface/cmsis-dap.cfg -f target/at91samdXX.cfg -c 'program build/feather_m0/bootloader-feather_m0-v3.7.0-73-g5ebe947a4384.elf verify reset exit'
Open On-Chip Debugger 0.10.0
Licensed under GNU GPL v2
For bug reports, read
http://openocd.org/doc/doxygen/bugs.html
Info : auto-selecting first available session transport "swd". To override use 'transport select <transport>'.
none separate
adapter speed: 400 kHz
cortex_m reset_config sysresetreq
Info : CMSIS-DAP: SWD Supported
Info : CMSIS-DAP: JTAG Supported
Info : CMSIS-DAP: Interface Initialised (SWD)
Info : CMSIS-DAP: FW Version = 01.00.0021
Info : SWCLK/TCK = 1 SWDIO/TMS = 1 TDI = 1 TDO = 1 nTRST = 0 nRESET = 1
Info : CMSIS-DAP: Interface ready
Info : clock speed 400 kHz
Info : SWD DPIDR 0x0bc11477
Info : at91samd.cpu: hardware has 4 breakpoints, 2 watchpoints
target halted due to debug-request, current mode: Thread
xPSR: 0x81000000 pc: 0x00000288 msp: 0x20002dd8
** Programming Started **
auto erase enabled
Info : SAMD MCU: SAMD21G18A (256KB Flash, 32KB RAM)
Info : Padding image section 1 with 268 bytes
wrote 16384 bytes from file build/feather_m0/bootloader-feather_m0-v3.7.0-73-g5ebe947a4384.elf in 1.649708s (9.699 KiB/s)
** Programming Finished **
** Verify Started **
verified 7924 bytes in 0.793008s (9.758 KiB/s)
** Verified OK **
** Resetting Target **
shutdown command invoked |
Oh, and the most important news: My proposed fix above seems to work. I'll make a PR. |
… double-click reset to invoke boot loader. Works for SAMD21, not sure about SAMD51.
Well, dammit. It seems this was not enough to fix the issue. It's much harder to reproduce now, but the bootloader is still spuriously triggered with poor startup power. |
add m4 hallowing & m4sk + fixes UART defs on pygamer/pybadge
I've been experiencing an issue where poor power rails cause the bootloader to be entered spontaneously. You can simulate this by applying power to a Feather M0 by holding the ends of two wires together to complete the path to the positive power supply, and then rub them to make a series of interrupted power spikes.1
I think this is triggering the brown-out detection circuitry, and setting the
RESET_CONTROLLER->RCAUSE.bit.BODxx
bit(s), rather thanRESET_CONTROLLER->RCAUSE.bit.POR
. The code, as written inmain.c
interprets this as the user pressing the reset button, and it enters the boot loader.Ignoring
SINGLE_RESET
, I think more robust code might look like this. I have not tested this as I currently have no way to load the boot loader:This change should do a couple of things: treat power-on and brown-out-detect resets the same, and only count a /RESET assertion as the second press.
I’m not sure if the SAM51 has different BOD bits.
Footnotes
In my case, I have an Adafruit solar lipo charger. When the battery is depleted and the sun is just beginning to shine on the panel, the power provided to the load can be spotty. ↩
The text was updated successfully, but these errors were encountered: