mirror of https://github.com/arendst/Tasmota.git
parent
1fb9c0e531
commit
69ef562b36
|
@ -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
|
||||||
|
|
|
@ -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)) {
|
||||||
|
|
Loading…
Reference in New Issue