Does anyone know how to fix this error on the Bangle.js 2?
FW addr 0x00201c00 fail
About a week ago, I decided to update my watch's firmware to 2v19 from 2v18 (DFU version 2v14), and I installed it with the "Firmware Update" app on the app loader. It updated, then refused to connect to my computer, and kept rapidly connecting and disconnecting as the BLE pairings failed. I wondered if the settings had gotten messed up with the update and went into the Settings app on the watch. I toggled "Bluetooth->Programmable" off and back on, but I noticed that the screen wasn't updating properly. I then held the side button to return to the watch face. The usual "Reloading..." screen appeared, but in the "light" color scheme whereas it had been set to "dark". And it hung there for a couple of minutes. Thinking that it was stuck, I rebooted several times to no avail. Guessing that maybe the firmware had gotten corrupted in transmit, I tried reflashing 2v19 with the firmware updater, getting the same result. Wondering if the firmware had a bug, I tried rolling back to 2v18 with the firmware updater. The watch looked like it was installing it but it then booted into 2v19. I then proceeded to flash the firmware with the Web IDE's Flasher tool, and it successfully rolled back to 2v18, but still wouldn't load past the "Reloading..." screen. I checked the file list on the watch (from the Web IDE's storage viewer) against a backup I had made in June 2023 and found that setting.json and gane1024.json were both missing. Several files had been added, most of which were more recently installed apps, but there were also two empty files that had nonsense UTF-8 names ("pµ\rM\rLd\u001b¤\u0 and "Í\t" [quotes are part of the filenames, maybe they are the corrupted setting.json and game1024.json?]). I then downloaded the code that was in RAM, and tried reading setting.json (var s = require("Storage").readJSON("setting.json",1)||{};), and of course received an empty object. I then tried to upload the setting.json file from the backup and the watch seemingly refused the file, giving me only the message "FW addr 0x00201c00 fail" followed by a couple of uncaught "File already written with different data" errors. Viewing storage shows that it did not take the file, but on one occasion of attempting this, I was able to load setting.json (after saving it to storage) from the Web IDE REPL to get... the save data for game1024?! I have not been able to repeat this feat, but the watch still refuses the additional files. I can read other files from it just fine and even run most applications, but not the settings app. Everything is running on default settings.
My current best guess for the problem is a corrupt or malfunctioning flash chip or block on the flash chip, but I really don't know. Does anyone have any ideas about why I might be having this problem, or even better, how to fix it? In case it's helpful, I have an Arduino Uno and Mega (to use with the debug pins on the back of the watch).
Espruino is a JavaScript interpreter for low-power Microcontrollers. This site is both a support community for Espruino and a place to share what you are working on.
Does anyone know how to fix this error on the Bangle.js 2?
FW addr 0x00201c00 fail
About a week ago, I decided to update my watch's firmware to 2v19 from 2v18 (DFU version 2v14), and I installed it with the "Firmware Update" app on the app loader. It updated, then refused to connect to my computer, and kept rapidly connecting and disconnecting as the BLE pairings failed. I wondered if the settings had gotten messed up with the update and went into the Settings app on the watch. I toggled "Bluetooth->Programmable" off and back on, but I noticed that the screen wasn't updating properly. I then held the side button to return to the watch face. The usual "Reloading..." screen appeared, but in the "light" color scheme whereas it had been set to "dark". And it hung there for a couple of minutes. Thinking that it was stuck, I rebooted several times to no avail. Guessing that maybe the firmware had gotten corrupted in transmit, I tried reflashing 2v19 with the firmware updater, getting the same result. Wondering if the firmware had a bug, I tried rolling back to 2v18 with the firmware updater. The watch looked like it was installing it but it then booted into 2v19. I then proceeded to flash the firmware with the Web IDE's Flasher tool, and it successfully rolled back to 2v18, but still wouldn't load past the "Reloading..." screen. I checked the file list on the watch (from the Web IDE's storage viewer) against a backup I had made in June 2023 and found that setting.json and gane1024.json were both missing. Several files had been added, most of which were more recently installed apps, but there were also two empty files that had nonsense UTF-8 names ("pµ\rM\rLd\u001b¤\u0 and "Í\t" [quotes are part of the filenames, maybe they are the corrupted setting.json and game1024.json?]). I then downloaded the code that was in RAM, and tried reading setting.json (var s = require("Storage").readJSON("setting.json",1)||{};), and of course received an empty object. I then tried to upload the setting.json file from the backup and the watch seemingly refused the file, giving me only the message "FW addr 0x00201c00 fail" followed by a couple of uncaught "File already written with different data" errors. Viewing storage shows that it did not take the file, but on one occasion of attempting this, I was able to load setting.json (after saving it to storage) from the Web IDE REPL to get... the save data for game1024?! I have not been able to repeat this feat, but the watch still refuses the additional files. I can read other files from it just fine and even run most applications, but not the settings app. Everything is running on default settings.
My current best guess for the problem is a corrupt or malfunctioning flash chip or block on the flash chip, but I really don't know. Does anyone have any ideas about why I might be having this problem, or even better, how to fix it? In case it's helpful, I have an Arduino Uno and Mega (to use with the debug pins on the back of the watch).