-
Notifications
You must be signed in to change notification settings - Fork 263
Troubleshooting Firmware Upload Issues
While in most cases uploading new firmware to your Model 01 is a simple and straightforward process, sometimes things don't work as well as they should. This page tracks and provides solutions to issues that you may experience. If the information here does not solve your issue, please reach out the Keyboardio Community in the Help and Getting Started category.
Turning on Verbose output can assist you in determining any issues. To do this, in the Arduino IDE, open the Preferences dialog either from the menu, File > Preferences, or by typing Ctrl+Comma
. On the "Settings" tab of the Preferences dialog window, there is an option labeled "Show verbose output during:". Check the "upload" checkbox for that option. Click OK to save the setting change and close the Preferences dialog.
One of the most common, and simplest to resolve issues is that the bootloader times out before the Arduino IDE is able to make a connection to it during the Upload process. When you hold down te prog
key, the Model 01 goes into bootloader mode, but for only about 8 seconds. After that it reverts back to its "just a keyboard" state. There are a few potential causes for this and corresponding things we can do to mitigate them.
When you click the Upload function, the Arduino IDE first compiles and then uploads the built binary to the Model 01. However, it needs to start the "uploading" phase before the Model 01 bootloader connection times out. If it does not, the upload will fail. For a variety of reasons -- a slow system, resource constraints, a complicated sketch, etc. -- the "compiling" phase can dramatically extend the total time it takes for the full Upload process ("Compiling" then "Uploading") to complete.
Always run Verify (The check-mark button) before you run Upload. While the Upload process does compile the sketch, it will run faster if you first do a Verify.
Often, just running the Upload process a second time is all it takes to get a successful upload. But if you have to continually do this, then try some of the other Mitigation Suggestions provided.
Ultimately, the prog
button on your Model 01 needs to be pushed (and held in) before the "Uploading" phase of the full Upload process. If you wait until the "Compiling" phase is partially or nearly complete before you press and hold the prog
button, you can help to ensure that the Model 01 does not timeout of the bootloader mode before it begins the "Uploading" phase. When you run the Upload process, you will see a status message on the left side of the teal bar that separates the top white editor section and black output console of the Arduino IDE. During the Upload process, the message will first say "Compiling Sketch...". Once the "Compiling" phase completes, it will switch to "Uploading...". During the "Compiling" phase, there will also be a progress bar on the right side of the teal separation bar. You can use this progress bar to wait until the "Compiling Phase" is near completion before pressing and holding the prog
button. It is important however that you do push and hold it before the "Uploading..." phase starts. Sometimes the Progress Bar may only proceed to about ½ way, hold for a moment, and then jump to completion. Usually after a few attempts, you will get a feel for the timing on your system with your sketch. Alternatively, just use the Release and Repress mitigation below.
After initially pressing the prog
button, either use a clock/timer or count the seconds using a second long placeholder word to track the duration. Every 7 or 8 seconds, quickly release and repress the prog
button. This method has been successfully used many time. The process works fine as long as you are not in a "release and repress" cycle (which likely only takes a ¼-½ second) at the very instance the Upload process switches from its "Compiling" phase to its "Uploading" phase. And if that happens, just wait for the process to fail and then do it again.
While the above mitigation suggestions work most of the time, an alternative and almost surefire way to deal with the timing issue is to upload the firmware via the command line. This breaks the Upload process into two distinct steps -- creating the binary and then uploading it -- rather than a single combined process.
- Command Line Upload Instructions for Windows
- Command Line Upload Instructions for Mac PENDING
- Command Line Upload Instructions for Linux PENDING
Troubleshooting
Advanced Topics
Development and customization
Keyboardio Model 01 docs
- Keyboardio Model 01 Introduction
- Flashing a new bootloader
- Default Model 01 QWERTY Layout
- Common Alternate Layouts
- Hardware Test Mode
Community