From e45e9dfec9492bbc037d783a82a7c9a1d66e2f0a Mon Sep 17 00:00:00 2001 From: Liyou Zhou Date: Tue, 24 Nov 2015 18:31:42 +0000 Subject: [PATCH 1/2] Call bootloader_start implicitly trough a event handler call work around for bootloader_start not being public in sdk 8.1 --- ble/services/DFUService.h | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/ble/services/DFUService.h b/ble/services/DFUService.h index 253890e..ed33252 100644 --- a/ble/services/DFUService.h +++ b/ble/services/DFUService.h @@ -20,7 +20,9 @@ #include "ble/BLE.h" #include "ble/UUID.h" -extern "C" void bootloader_start(void); +extern "C" { +#include "dfu_app_handler.h" +} extern const uint8_t DFUServiceBaseUUID[]; extern const uint16_t DFUServiceShortUUID; @@ -101,7 +103,13 @@ public: handoverCallback(); } - bootloader_start(); + // Call bootloader_start trough a event handler + // it is a work around for bootloader_start not being public in sdk 8.1 + ble_dfu_t *p_dfu; + p_dfu-> conn_handle = params->connHandle; + ble_dfu_evt_t *p_evt; + p_evt->ble_dfu_evt_type = BLE_DFU_START; + dfu_app_on_dfu_evt(p_dfu, p_evt); } } From 2bcad22d0804b19fb03fcace25c0d7513e31d6a3 Mon Sep 17 00:00:00 2001 From: Liyou Zhou Date: Tue, 24 Nov 2015 18:31:42 +0000 Subject: [PATCH 2/2] Call bootloader_start implicitly trough a event handler call work around for bootloader_start not being public in sdk 8.1 --- ble/services/DFUService.h | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/ble/services/DFUService.h b/ble/services/DFUService.h index 253890e..8eab0d7 100644 --- a/ble/services/DFUService.h +++ b/ble/services/DFUService.h @@ -20,7 +20,9 @@ #include "ble/BLE.h" #include "ble/UUID.h" -extern "C" void bootloader_start(void); +extern "C" { +#include "dfu_app_handler.h" +} extern const uint8_t DFUServiceBaseUUID[]; extern const uint16_t DFUServiceShortUUID; @@ -101,7 +103,13 @@ public: handoverCallback(); } - bootloader_start(); + // Call bootloader_start implicitly trough a event handler call + // it is a work around for bootloader_start not being public in sdk 8.1 + ble_dfu_t *p_dfu; + p_dfu-> conn_handle = params->connHandle; + ble_dfu_evt_t *p_evt; + p_evt->ble_dfu_evt_type = BLE_DFU_START; + dfu_app_on_dfu_evt(p_dfu, p_evt); } }