mirror of https://github.com/arendst/Tasmota.git
Refactor WebGui fw upgrade
This commit is contained in:
parent
fab5f3ddc3
commit
92a9d5cda0
|
@ -34,7 +34,7 @@
|
||||||
const uint16_t CHUNKED_BUFFER_SIZE = (MESSZ / 2) - 100; // Chunk buffer size (should be smaller than half mqtt_data size = MESSZ)
|
const uint16_t CHUNKED_BUFFER_SIZE = (MESSZ / 2) - 100; // Chunk buffer size (should be smaller than half mqtt_data size = MESSZ)
|
||||||
|
|
||||||
const uint16_t HTTP_REFRESH_TIME = 2345; // milliseconds
|
const uint16_t HTTP_REFRESH_TIME = 2345; // milliseconds
|
||||||
const uint16_t HTTP_RESTART_RECONNECT_TIME = 9000; // milliseconds - Allow time for restart and wifi reconnect
|
const uint16_t HTTP_RESTART_RECONNECT_TIME = 10000; // milliseconds - Allow time for restart and wifi reconnect
|
||||||
const uint16_t HTTP_OTA_RESTART_RECONNECT_TIME = 24000; // milliseconds - Allow time for uploading binary, unzip/write to final destination and wifi reconnect
|
const uint16_t HTTP_OTA_RESTART_RECONNECT_TIME = 24000; // milliseconds - Allow time for uploading binary, unzip/write to final destination and wifi reconnect
|
||||||
|
|
||||||
#include <ESP8266WebServer.h>
|
#include <ESP8266WebServer.h>
|
||||||
|
@ -2605,12 +2605,6 @@ uint32_t BUploadWriteBuffer(uint8_t *buf, size_t size) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void BUploadDone(void) {
|
|
||||||
Web.upload_file_type = UPL_TASMOTA;
|
|
||||||
BUpload.active = false;
|
|
||||||
BUpload.ready = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // USE_WEB_FW_UPGRADE
|
#endif // USE_WEB_FW_UPGRADE
|
||||||
|
|
||||||
void HandleUpgradeFirmware(void)
|
void HandleUpgradeFirmware(void)
|
||||||
|
@ -2664,7 +2658,7 @@ void HandleUploadDone(void)
|
||||||
|
|
||||||
#if defined(USE_ZIGBEE_EZSP)
|
#if defined(USE_ZIGBEE_EZSP)
|
||||||
if ((UPL_EFR32 == Web.upload_file_type) && !Web.upload_error && BUpload.ready) {
|
if ((UPL_EFR32 == Web.upload_file_type) && !Web.upload_error && BUpload.ready) {
|
||||||
BUploadDone(); // Make sure not to follow thru again
|
BUpload.ready = false; // Make sure not to follow thru again
|
||||||
// GUI xmodem
|
// GUI xmodem
|
||||||
ZigbeeUploadStep1Done(BUploadStartSector(), BUpload.spi_hex_size);
|
ZigbeeUploadStep1Done(BUploadStartSector(), BUpload.spi_hex_size);
|
||||||
HandleZigbeeXfer();
|
HandleZigbeeXfer();
|
||||||
|
@ -2685,13 +2679,7 @@ void HandleUploadDone(void)
|
||||||
|
|
||||||
WSContentStart_P(PSTR(D_INFORMATION));
|
WSContentStart_P(PSTR(D_INFORMATION));
|
||||||
if (!Web.upload_error) {
|
if (!Web.upload_error) {
|
||||||
uint32_t javascript_settimeout = HTTP_OTA_RESTART_RECONNECT_TIME;
|
WSContentSend_P(HTTP_SCRIPT_RELOAD_TIME, (UPL_TASMOTA == Web.upload_file_type) ? HTTP_OTA_RESTART_RECONNECT_TIME : HTTP_RESTART_RECONNECT_TIME); // Refesh main web ui after OTA upgrade
|
||||||
#if defined(USE_ZIGBEE_EZSP)
|
|
||||||
if (ZigbeeUploadFinish()) {
|
|
||||||
javascript_settimeout = 10000; // Refesh main web ui after transfer upgrade
|
|
||||||
}
|
|
||||||
#endif // USE_ZIGBEE_EZSP
|
|
||||||
WSContentSend_P(HTTP_SCRIPT_RELOAD_TIME, javascript_settimeout); // Refesh main web ui after OTA upgrade
|
|
||||||
}
|
}
|
||||||
WSContentSendStyle();
|
WSContentSendStyle();
|
||||||
WSContentSend_P(PSTR("<div style='text-align:center;'><b>" D_UPLOAD " <font color='#"));
|
WSContentSend_P(PSTR("<div style='text-align:center;'><b>" D_UPLOAD " <font color='#"));
|
||||||
|
@ -2708,34 +2696,13 @@ void HandleUploadDone(void)
|
||||||
} else {
|
} else {
|
||||||
WSContentSend_P(PSTR("%06x'>" D_SUCCESSFUL "</font></b><br>"), WebColor(COL_TEXT_SUCCESS));
|
WSContentSend_P(PSTR("%06x'>" D_SUCCESSFUL "</font></b><br>"), WebColor(COL_TEXT_SUCCESS));
|
||||||
TasmotaGlobal.restart_flag = 2; // Always restart to re-enable disabled features during update
|
TasmotaGlobal.restart_flag = 2; // Always restart to re-enable disabled features during update
|
||||||
|
WSContentSend_P(HTTP_MSG_RSTRT);
|
||||||
#ifdef USE_TASMOTA_CLIENT
|
ShowWebSource(SRC_WEBGUI);
|
||||||
if (BUpload.ready) {
|
|
||||||
WSContentSend_P(PSTR("<br><div style='text-align:center;'><b>" D_TRANSFER_STARTED " ...</b></div>"));
|
|
||||||
TasmotaGlobal.restart_flag = 0; // Hold restart as code still needs to be transferred to STM
|
|
||||||
}
|
|
||||||
#endif // USE_TASMOTA_CLIENT or SHELLY_FW_UPGRADE
|
|
||||||
|
|
||||||
if (TasmotaGlobal.restart_flag) {
|
|
||||||
WSContentSend_P(HTTP_MSG_RSTRT);
|
|
||||||
ShowWebSource(SRC_WEBGUI);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
SettingsBufferFree();
|
SettingsBufferFree();
|
||||||
WSContentSend_P(PSTR("</div><br>"));
|
WSContentSend_P(PSTR("</div><br>"));
|
||||||
WSContentSpaceButton(BUTTON_MAIN);
|
WSContentSpaceButton(BUTTON_MAIN);
|
||||||
WSContentStop();
|
WSContentStop();
|
||||||
|
|
||||||
#ifdef USE_WEB_FW_UPGRADE
|
|
||||||
if (BUpload.ready) {
|
|
||||||
#ifdef USE_TASMOTA_CLIENT
|
|
||||||
if (UPL_TASMOTACLIENT == Web.upload_file_type) {
|
|
||||||
TasmotaClient_Flash(BUploadStartSector() * SPI_FLASH_SEC_SIZE, BUpload.spi_hex_size);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
BUploadDone();
|
|
||||||
}
|
|
||||||
#endif // USE_WEB_FW_UPGRADE
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void HandleUploadLoop(void)
|
void HandleUploadLoop(void)
|
||||||
|
@ -2795,6 +2762,16 @@ void HandleUploadLoop(void)
|
||||||
BUploadInit(UPL_EFM8BB1);
|
BUploadInit(UPL_EFM8BB1);
|
||||||
}
|
}
|
||||||
#endif // USE_RF_FLASH
|
#endif // USE_RF_FLASH
|
||||||
|
#ifdef USE_TASMOTA_CLIENT
|
||||||
|
else if (TasmotaClient_Available() && (':' == upload.buf[0])) { // Check if this is a ARDUINO CLIENT hex file
|
||||||
|
BUploadInit(UPL_TASMOTACLIENT);
|
||||||
|
}
|
||||||
|
#endif // USE_TASMOTA_CLIENT
|
||||||
|
#ifdef SHELLY_FW_UPGRADE
|
||||||
|
else if (ShdPresent() && (0x00 == upload.buf[0]) && (0x10 == upload.buf[1])) {
|
||||||
|
BUploadInit(UPL_SHD);
|
||||||
|
}
|
||||||
|
#endif // SHELLY_FW_UPGRADE
|
||||||
#ifdef USE_ZIGBEE_EZSP
|
#ifdef USE_ZIGBEE_EZSP
|
||||||
#ifdef ESP8266
|
#ifdef ESP8266
|
||||||
else if ((SONOFF_ZB_BRIDGE == TasmotaGlobal.module_type) && (0xEB == upload.buf[0])) { // Check if this is a Zigbee bridge FW file
|
else if ((SONOFF_ZB_BRIDGE == TasmotaGlobal.module_type) && (0xEB == upload.buf[0])) { // Check if this is a Zigbee bridge FW file
|
||||||
|
@ -2807,17 +2784,7 @@ void HandleUploadLoop(void)
|
||||||
if (Web.upload_error != 0) { return; }
|
if (Web.upload_error != 0) { return; }
|
||||||
BUploadInit(UPL_EFR32);
|
BUploadInit(UPL_EFR32);
|
||||||
}
|
}
|
||||||
#endif
|
#endif // USE_ZIGBEE_EZSP
|
||||||
#ifdef USE_TASMOTA_CLIENT
|
|
||||||
else if (TasmotaClient_Available() && (':' == upload.buf[0])) { // Check if this is a ARDUINO CLIENT hex file
|
|
||||||
BUploadInit(UPL_TASMOTACLIENT);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#ifdef SHELLY_FW_UPGRADE
|
|
||||||
else if (ShdPresent() && (0x00 == upload.buf[0]) && (0x10 == upload.buf[1])) {
|
|
||||||
BUploadInit(UPL_SHD);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif // USE_WEB_FW_UPGRADE
|
#endif // USE_WEB_FW_UPGRADE
|
||||||
else if ((upload.buf[0] != 0xE9) && (upload.buf[0] != 0x1F)) { // 0x1F is gzipped 0xE9
|
else if ((upload.buf[0] != 0xE9) && (upload.buf[0] != 0x1F)) { // 0x1F is gzipped 0xE9
|
||||||
Web.upload_error = 3; // Invalid file signature - Magic byte is not 0xE9
|
Web.upload_error = 3; // Invalid file signature - Magic byte is not 0xE9
|
||||||
|
@ -2914,8 +2881,9 @@ void HandleUploadLoop(void)
|
||||||
}
|
}
|
||||||
#ifdef USE_WEB_FW_UPGRADE
|
#ifdef USE_WEB_FW_UPGRADE
|
||||||
else if (BUpload.active) {
|
else if (BUpload.active) {
|
||||||
// Done writing the hex to SPI flash
|
// Done writing the data to SPI flash
|
||||||
BUpload.ready = true; // So we know on upload success page if it needs to flash hex or do a normal restart
|
BUpload.active = false;
|
||||||
|
|
||||||
AddLog_P(LOG_LEVEL_INFO, PSTR(D_LOG_UPLOAD "Transfer %u bytes"), upload.totalSize);
|
AddLog_P(LOG_LEVEL_INFO, PSTR(D_LOG_UPLOAD "Transfer %u bytes"), upload.totalSize);
|
||||||
|
|
||||||
uint8_t* data = (uint8_t*)(0x40200000 + (BUploadStartSector() * SPI_FLASH_SEC_SIZE));
|
uint8_t* data = (uint8_t*)(0x40200000 + (BUploadStartSector() * SPI_FLASH_SEC_SIZE));
|
||||||
|
@ -2927,15 +2895,23 @@ void HandleUploadLoop(void)
|
||||||
#ifdef USE_RF_FLASH
|
#ifdef USE_RF_FLASH
|
||||||
if (UPL_EFM8BB1 == Web.upload_file_type) {
|
if (UPL_EFM8BB1 == Web.upload_file_type) {
|
||||||
error = SnfBrUpdateFirmware(data, BUpload.spi_hex_size);
|
error = SnfBrUpdateFirmware(data, BUpload.spi_hex_size);
|
||||||
BUploadDone();
|
|
||||||
}
|
}
|
||||||
#endif // USE_RF_FLASH
|
#endif // USE_RF_FLASH
|
||||||
|
#ifdef USE_TASMOTA_CLIENT
|
||||||
|
else if (UPL_TASMOTACLIENT == Web.upload_file_type) {
|
||||||
|
error = TasmotaClient_Flash(BUploadStartSector() * SPI_FLASH_SEC_SIZE, BUpload.spi_hex_size);
|
||||||
|
}
|
||||||
|
#endif // USE_TASMOTA_CLIENT
|
||||||
#ifdef SHELLY_FW_UPGRADE
|
#ifdef SHELLY_FW_UPGRADE
|
||||||
else if (UPL_SHD == Web.upload_file_type) {
|
else if (UPL_SHD == Web.upload_file_type) {
|
||||||
error = ShdFlash(data, BUpload.spi_hex_size);
|
error = ShdFlash(data, BUpload.spi_hex_size);
|
||||||
BUploadDone();
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif // SHELLY_FW_UPGRADE
|
||||||
|
#ifdef USE_ZIGBEE_EZSP
|
||||||
|
else if (UPL_EFR32 == Web.upload_file_type) {
|
||||||
|
BUpload.ready = true; // So we know on upload success page if it needs to flash hex or do a normal restart
|
||||||
|
}
|
||||||
|
#endif // USE_ZIGBEE_EZSP
|
||||||
if (error != 0) {
|
if (error != 0) {
|
||||||
AddLog_P(LOG_LEVEL_DEBUG, PSTR(D_LOG_UPLOAD "Transfer error %d"), error);
|
AddLog_P(LOG_LEVEL_DEBUG, PSTR(D_LOG_UPLOAD "Transfer error %d"), error);
|
||||||
Web.upload_error = 8; // File invalid
|
Web.upload_error = 8; // File invalid
|
||||||
|
|
|
@ -328,8 +328,7 @@ void TasmotaClient_FlashPage(uint8_t addr_h, uint8_t addr_l, uint8_t* data) {
|
||||||
|
|
||||||
uint32_t TasmotaClient_Flash(uint32_t data, size_t size) {
|
uint32_t TasmotaClient_Flash(uint32_t data, size_t size) {
|
||||||
if (!TasmotaClient_SetupFlash()) {
|
if (!TasmotaClient_SetupFlash()) {
|
||||||
AddLog_P(LOG_LEVEL_INFO, PSTR("TCL: Flashing aborted!"));
|
// AddLog_P(LOG_LEVEL_INFO, PSTR("TCL: Flashing aborted!"));
|
||||||
TasmotaGlobal.restart_flag = 2;
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -372,8 +371,7 @@ uint32_t TasmotaClient_Flash(uint32_t data, size_t size) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
TasmotaClient_exitProgMode();
|
TasmotaClient_exitProgMode();
|
||||||
AddLog_P(LOG_LEVEL_INFO, PSTR("TCL: Flash done!"));
|
// AddLog_P(LOG_LEVEL_INFO, PSTR("TCL: Flash done!"));
|
||||||
TasmotaGlobal.restart_flag = 2;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue