|
@@ -16,25 +16,27 @@
|
|
|
|
|
|
#include "bootloader.h"
|
|
|
#include "samd51j18a.h"
|
|
|
+#include "md_bootloader.h"
|
|
|
|
|
|
|
|
|
-void bootloader_jump(void)
|
|
|
-{
|
|
|
-
|
|
|
- uint8_t ver_no_jump[] = "v2.18Jun 22 2018 17:28:08";
|
|
|
- uint8_t *ver_check = ver_no_jump;
|
|
|
- uint8_t *boot_check = (uint8_t *)0x21A0;
|
|
|
- while (*ver_check && *boot_check == *ver_check)
|
|
|
- {
|
|
|
- ver_check++;
|
|
|
- boot_check++;
|
|
|
+void bootloader_jump(void) {
|
|
|
+#ifdef KEYBOARD_massdrop_ctrl
|
|
|
+
|
|
|
+ uint8_t ver_ram_method[] = "v2.18Jun 22 2018 17:28:08";
|
|
|
+ uint8_t *ver_check = ver_ram_method;
|
|
|
+ uint8_t *ver_rom = (uint8_t *)0x21A0;
|
|
|
+
|
|
|
+ while (*ver_check && *ver_rom == *ver_check) {
|
|
|
+ ver_check++;
|
|
|
+ ver_rom++;
|
|
|
}
|
|
|
- if (!*ver_check)
|
|
|
- {
|
|
|
-
|
|
|
-
|
|
|
- return;
|
|
|
+
|
|
|
+ if (!*ver_check) {
|
|
|
+ *MAGIC_ADDR = BOOTLOADER_MAGIC;
|
|
|
+ NVIC_SystemReset();
|
|
|
+ while (1) {}
|
|
|
}
|
|
|
+#endif
|
|
|
|
|
|
WDT->CTRLA.bit.ENABLE = 0;
|
|
|
while (WDT->SYNCBUSY.bit.ENABLE) {}
|