Fix configuration restore

5.13.0a
 * Fix configuration restore (#2591)
This commit is contained in:
Theo Arends 2018-05-01 18:02:45 +02:00
parent 1fb9c0e531
commit 69ef562b36
2 changed files with 21 additions and 11 deletions

View File

@ -1,6 +1,7 @@
/* 5.13.0a /* 5.13.0a
* Fix JSON buffers size too small for execution in some situations (#2580) * Fix JSON buffers size too small for execution in some situations (#2580)
* Add define MODULE for user selecting default model (#569, #2589) * Add define MODULE for user selecting default model although it preferably should not be changed (#569, #2589)
* Fix configuration restore (#2591)
* *
* 5.13.0 20180430 * 5.13.0 20180430
* Change platformio option sonoff-ds18x20 to sonoff-allsensors enabling ds18x20 and all other sensors in one image * Change platformio option sonoff-ds18x20 to sonoff-allsensors enabling ds18x20 and all other sensors in one image

View File

@ -328,6 +328,8 @@ uint8_t webserver_state = HTTP_OFF;
uint8_t upload_error = 0; uint8_t upload_error = 0;
uint8_t upload_file_type; uint8_t upload_file_type;
uint8_t upload_progress_dot_count; uint8_t upload_progress_dot_count;
uint8_t config_block_count = 0;
uint8_t config_xor_on = 0;
// Helper function to avoid code duplication (saves 4k Flash) // Helper function to avoid code duplication (saves 4k Flash)
static void WebGetArg(const char* arg, char* out, size_t max) static void WebGetArg(const char* arg, char* out, size_t max)
@ -1317,17 +1319,14 @@ void HandleUploadLoop()
} }
upload_progress_dot_count = 0; upload_progress_dot_count = 0;
} else if (!upload_error && (UPLOAD_FILE_WRITE == upload.status)) { } else if (!upload_error && (UPLOAD_FILE_WRITE == upload.status)) {
if (0 == upload.totalSize) if (0 == upload.totalSize) {
{
if (upload_file_type) { if (upload_file_type) {
if (upload.buf[0] != CONFIG_FILE_SIGN) { if (upload.buf[0] != CONFIG_FILE_SIGN) {
upload_error = 8; upload_error = 8;
return; return;
} }
if (upload.currentSize > sizeof(Settings)) { config_xor_on = upload.buf[1];
upload_error = 9; config_block_count = 0;
return;
}
} else { } else {
if (upload.buf[0] != 0xE9) { if (upload.buf[0] != 0xE9) {
upload_error = 3; upload_error = 3;
@ -1343,14 +1342,24 @@ void HandleUploadLoop()
} }
if (upload_file_type) { // config if (upload_file_type) { // config
if (!upload_error) { if (!upload_error) {
if (upload.buf[1]) { if (upload.currentSize > (sizeof(Settings) - (config_block_count * HTTP_UPLOAD_BUFLEN))) {
if (config_block_count) { SettingsDefault(); }
upload_error = 9;
return;
}
if (config_xor_on) {
for (uint16_t i = 2; i < upload.currentSize; i++) { for (uint16_t i = 2; i < upload.currentSize; i++) {
upload.buf[i] ^= (CONFIG_FILE_XOR +i); upload.buf[i] ^= (CONFIG_FILE_XOR +i);
} }
} }
SettingsDefaultSet2(); if (0 == config_block_count) {
memcpy((char*)&Settings +16, upload.buf +16, upload.currentSize -16); SettingsDefaultSet2();
memcpy((char*)&Settings +8, upload.buf +8, 4); // Restore version and auto upgrade memcpy((char*)&Settings +16, upload.buf +16, upload.currentSize -16);
memcpy((char*)&Settings +8, upload.buf +8, 4); // Restore version and auto upgrade
} else {
memcpy((char*)&Settings +(config_block_count * HTTP_UPLOAD_BUFLEN), upload.buf, upload.currentSize);
}
config_block_count++;
} }
} else { // firmware } else { // firmware
if (!upload_error && (Update.write(upload.buf, upload.currentSize) != upload.currentSize)) { if (!upload_error && (Update.write(upload.buf, upload.currentSize) != upload.currentSize)) {