From 9cede73667b1f394c152ddec3ed8c7ded9d26a90 Mon Sep 17 00:00:00 2001 From: andrethomas Date: Sat, 26 Oct 2019 22:51:55 +0200 Subject: [PATCH 1/7] Remove unused library --- lib/ArduinoHexParse/README.md | 3 - lib/ArduinoHexParse/keywords.txt | 25 ---- lib/ArduinoHexParse/library.json | 12 -- lib/ArduinoHexParse/library.properties | 9 -- lib/ArduinoHexParse/src/ArduinoHexParse.cpp | 134 -------------------- lib/ArduinoHexParse/src/ArduinoHexParse.h | 47 ------- 6 files changed, 230 deletions(-) delete mode 100644 lib/ArduinoHexParse/README.md delete mode 100644 lib/ArduinoHexParse/keywords.txt delete mode 100644 lib/ArduinoHexParse/library.json delete mode 100644 lib/ArduinoHexParse/library.properties delete mode 100644 lib/ArduinoHexParse/src/ArduinoHexParse.cpp delete mode 100644 lib/ArduinoHexParse/src/ArduinoHexParse.h diff --git a/lib/ArduinoHexParse/README.md b/lib/ArduinoHexParse/README.md deleted file mode 100644 index c5c6a6751..000000000 --- a/lib/ArduinoHexParse/README.md +++ /dev/null @@ -1,3 +0,0 @@ -# ArduinoHexParse - -Parse hex files created by Arduino for Uno/Mini/Nano diff --git a/lib/ArduinoHexParse/keywords.txt b/lib/ArduinoHexParse/keywords.txt deleted file mode 100644 index c60688578..000000000 --- a/lib/ArduinoHexParse/keywords.txt +++ /dev/null @@ -1,25 +0,0 @@ -####################################### -# Syntax Coloring Map for ArduinoHexParse -# (esp8266) -####################################### - -####################################### -# Datatypes (KEYWORD1) -####################################### - -ArduinoHexParse KEYWORD1 - -####################################### -# Methods and Functions (KEYWORD2) -####################################### - -ArduinoHexParse KEYWORD2 -ParseLine KEYWORD2 -GetFlashPage KEYWORD2 -GetLoadAddress KEYWORD2 -IsFlashPageReady KEYWORD2 - -####################################### -# Constants (LITERAL1) -####################################### - diff --git a/lib/ArduinoHexParse/library.json b/lib/ArduinoHexParse/library.json deleted file mode 100644 index 896b53f6d..000000000 --- a/lib/ArduinoHexParse/library.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "name": "ArduinoHexParse", - "version": "0.0.1", - "description": "Parse hex files created by Arduino for Uno/Mini/Nano", - "repository": - { - "type": "git", - "url": "https://github.com/arendst/Sonoff-Tasmota/lib/ArduinoHexParse" - }, - "frameworks": "arduino", - "platforms": "espressif8266" -} diff --git a/lib/ArduinoHexParse/library.properties b/lib/ArduinoHexParse/library.properties deleted file mode 100644 index 034c22e64..000000000 --- a/lib/ArduinoHexParse/library.properties +++ /dev/null @@ -1,9 +0,0 @@ -name=ArduinoHexParse -version=0.0.1 -author=Andre Thomas -maintainer=Andre Thomas -sentence=Parse hex files created by Arduino for Uno/Mini/Nano -paragraph= -category=Signal Input/Output -url= -architectures=esp8266 diff --git a/lib/ArduinoHexParse/src/ArduinoHexParse.cpp b/lib/ArduinoHexParse/src/ArduinoHexParse.cpp deleted file mode 100644 index d4125f2f5..000000000 --- a/lib/ArduinoHexParse/src/ArduinoHexParse.cpp +++ /dev/null @@ -1,134 +0,0 @@ -/* - Copyright (C) 2019 Andre Thomas and Theo Arends - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . -*/ - -#include -#include "ArduinoHexParse.h" - -ArduinoHexParse::ArduinoHexParse(void) -{ - loadAddress[0] = 0; - loadAddress[1] = 0; -} - -void ArduinoHexParse::ParseLine(byte* hexline) -{ - recordType = GetRecordType(hexline); - if (0 == recordType) { - address = GetAddress(hexline); - len = GetLength(hexline); - GetData(hexline, len); - if (128 == PageMemIdx) { - if (!firstRun) { - loadAddress[1] += 0x40; - if (0 == loadAddress[1]) { - loadAddress[0] += 1; - } - } - firstRun = false; - FlashPageReady = true; - PageMemIdx = 0; - } - nextAddress = address + len; - } - if (1 == recordType) { - EndOfFile(); - FlashPageReady = true; - } -} - -bool ArduinoHexParse::IsFlashPageReady(void) -{ - return FlashPageReady; -} - -byte* ArduinoHexParse::GetFlashPage(void) -{ - FlashPageReady = false; - return FlashPage; -} - -byte* ArduinoHexParse::GetLoadAddress(void) -{ - return loadAddress; -} - -void ArduinoHexParse::GetLoadAddress(byte* hexline) -{ - char buff[3]; - buff[2] = '\0'; - buff[0] = hexline[3]; - buff[1] = hexline[4]; - loadAddress[0] = strtol(buff, 0, 16); - buff[0] = hexline[5]; - buff[1] = hexline[6]; - loadAddress[1] = strtol(buff, 0, 16); -} - -byte* ArduinoHexParse::GetData(byte* hexline, uint32_t len) -{ - uint32_t start = 9; - uint32_t end = (len * 2) + start; - char buff[3]; - buff[2] = '\0'; - for (uint32_t x = start; x < end; x = x+2) { - buff[0] = hexline[x]; - buff[1] = hexline[x+1]; - FlashPage[PageMemIdx] = strtol(buff, 0, 16); - PageMemIdx++; - } -} - -void ArduinoHexParse::EndOfFile(void) -{ - loadAddress[1] += 0x40; - if (0 == loadAddress[1]) { - loadAddress[0] += 1; - } - while (128 > PageMemIdx) { // Fill the remaing space in the memory page with 0xFF - FlashPage[PageMemIdx] = 0xFF; - PageMemIdx++; - } -} - -uint32_t ArduinoHexParse::GetAddress(byte* hexline) -{ - char buff[5]; - buff[0] = hexline[3]; - buff[1] = hexline[4]; - buff[2] = hexline[5]; - buff[3] = hexline[6]; - buff[4] = '\0'; - return strtol(buff, 0, 16); -} - -uint16_t ArduinoHexParse::GetLength(byte* hexline) -{ - char buff[3]; - buff[0] = hexline[1]; - buff[1] = hexline[2]; - buff[2] = '\0'; - return strtol(buff, 0, 16); -} - -uint16_t ArduinoHexParse::GetRecordType(byte* hexline) -{ - char buff[3]; - buff[0] = hexline[7]; - buff[1] = hexline[8]; - buff[2] = '\0'; - return strtol(buff, 0, 16); -} diff --git a/lib/ArduinoHexParse/src/ArduinoHexParse.h b/lib/ArduinoHexParse/src/ArduinoHexParse.h deleted file mode 100644 index 7b941eea1..000000000 --- a/lib/ArduinoHexParse/src/ArduinoHexParse.h +++ /dev/null @@ -1,47 +0,0 @@ -/* - Copyright (C) 2019 Andre Thomas and Theo Arends - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . -*/ - -#ifndef __ARDUINOHEXPARSE_H__ - -#include - -class ArduinoHexParse { - public: - ArduinoHexParse(void); - void ParseLine(byte* data); - byte* GetFlashPage(void); - byte* GetLoadAddress(void); - bool IsFlashPageReady(void); - private: - uint32_t address = 0; - uint32_t len = 0; - uint32_t nextAddress = 0; - uint32_t PageMemIdx = 0; - uint32_t recordType = 0; - byte FlashPage[128]; - byte loadAddress[2]; - bool FlashPageReady = false; - bool firstRun = true; - uint32_t GetAddress(byte* hexline); - uint16_t GetLength(byte* hexline); - uint16_t GetRecordType(byte* hexline); - byte* GetData(byte* hexline, uint32_t len); - void GetLoadAddress(byte* hexline); - void EndOfFile(void); -}; - -#endif // __ARDUINOHEXPARSE_H__ \ No newline at end of file From 6066eb0bfc90dd046eb4528c9c1f28fe009bc277 Mon Sep 17 00:00:00 2001 From: andrethomas Date: Sat, 26 Oct 2019 22:55:18 +0200 Subject: [PATCH 2/7] Update my_user_config.h --- sonoff/my_user_config.h | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/sonoff/my_user_config.h b/sonoff/my_user_config.h index cb067fbf7..9073d0699 100644 --- a/sonoff/my_user_config.h +++ b/sonoff/my_user_config.h @@ -534,9 +534,9 @@ //#define USE_HRE // Add support for Badger HR-E Water Meter (+1k4 code) //#define USE_A4988_STEPPER // Add support for A4988/DRV8825 stepper-motor-driver-circuit (+10k5 code) -//#define USE_ARDUINO_SLAVE // Add support for Arduino Uno/Pro Mini via serial interface including flashing (+2k3 code, 44 mem) - #define USE_ARDUINO_FLASH_SPEED 57600 // Usually 57600 for 3.3V variants and 115200 for 5V variants - #define USE_ARDUINO_SERIAL_SPEED 57600 // Depends on the sketch that is running on the Uno/Pro Mini +//#define USE_TASMOTA_SLAVE // Add support for Arduino Uno/Pro Mini via serial interface including flashing (+2k3 code, 44 mem) + #define USE_TASMOTA_SLAVE_FLASH_SPEED 57600 // Usually 57600 for 3.3V variants and 115200 for 5V variants + #define USE_TASMOTA_SLAVE_SERIAL_SPEED 57600 // Depends on the sketch that is running on the Uno/Pro Mini // -- End of general directives ------------------- From 8c5934890e8019372ff1406fac270bec97f85bbf Mon Sep 17 00:00:00 2001 From: andrethomas Date: Sat, 26 Oct 2019 22:58:04 +0200 Subject: [PATCH 3/7] ArduinoSlave->TasmotaSlave --- sonoff/sonoff_template.h | 18 +- sonoff/xdrv_01_webserver.ino | 30 +-- sonoff/xdrv_31_arduino_slave.ino | 412 ++++++++++++++++++++++--------- 3 files changed, 324 insertions(+), 136 deletions(-) diff --git a/sonoff/sonoff_template.h b/sonoff/sonoff_template.h index f85543cd0..51cd2d0fd 100644 --- a/sonoff/sonoff_template.h +++ b/sonoff/sonoff_template.h @@ -208,10 +208,9 @@ enum UserSelectablePins { GPIO_SM2135_DAT, // SM2135 Dat GPIO_DEEPSLEEP, // Kill switch for deepsleep GPIO_EXS_ENABLE, // EXS MCU Enable - GPIO_ARDUINO_TXD, // Arduino Slave TX - GPIO_ARDUINO_RXD, // Arduino Slave RX - GPIO_ARDUINO_RST, // Arduino Reset Pin - GPIO_ARDUINO_RST_INV, // Arduino Reset Pin inverted + GPIO_TASMOTASLAVE_TXD, // Arduino Slave TX + GPIO_TASMOTASLAVE_RXD, // Arduino Slave RX + GPIO_TASMOTASLAVE_RST, // Arduino Reset Pin GPIO_SENSOR_END }; // Programmer selectable GPIO functionality @@ -290,7 +289,7 @@ const char kSensorNames[] PROGMEM = D_SENSOR_DDSU666_TX "|" D_SENSOR_DDSU666_RX "|" D_SENSOR_SM2135_CLK "|" D_SENSOR_SM2135_DAT "|" D_SENSOR_DEEPSLEEP "|" D_SENSOR_EXS_ENABLE "|" - D_SENSOR_ARDUINO_TX "|" D_SENSOR_ARDUINO_RX "|" D_SENSOR_ARDUINO_RESET "|" D_SENSOR_ARDUINO_RESET "i|" + D_SENSOR_SLAVE_TX "|" D_SENSOR_SLAVE_RX "|" D_SENSOR_SLAVE_RESET "|" ; const char kSensorNamesFixed[] PROGMEM = @@ -703,11 +702,10 @@ const uint8_t kGpioNiceList[] PROGMEM = { GPIO_PN532_TXD, // PN532 HSU Tx GPIO_PN532_RXD, // PN532 HSU Rx #endif -#ifdef USE_ARDUINO_SLAVE - GPIO_ARDUINO_TXD, // Arduino Slave TX - GPIO_ARDUINO_RXD, // Arduino Slave RX - GPIO_ARDUINO_RST, // Arduino Reset Pin - GPIO_ARDUINO_RST_INV, // Arduino Reset Pin inverted +#ifdef USE_TASMOTA_SLAVE + GPIO_TASMOTASLAVE_TXD, // Tasmota Slave TX + GPIO_TASMOTASLAVE_RXD, // Tasmota Slave RX + GPIO_TASMOTASLAVE_RST, // Tasmota Reset Pin #endif #ifdef USE_RDM6300 GPIO_RDM6300_RX, diff --git a/sonoff/xdrv_01_webserver.ino b/sonoff/xdrv_01_webserver.ino index 40b3bab83..17622e920 100644 --- a/sonoff/xdrv_01_webserver.ino +++ b/sonoff/xdrv_01_webserver.ino @@ -44,7 +44,7 @@ const uint16_t HTTP_REFRESH_TIME = 2345; // milliseconds uint8_t *efm8bb1_update = nullptr; #endif // USE_RF_FLASH -enum UploadTypes { UPL_TASMOTA, UPL_SETTINGS, UPL_EFM8BB1, UPL_ARDUINOSLAVE }; +enum UploadTypes { UPL_TASMOTA, UPL_SETTINGS, UPL_EFM8BB1, UPL_TASMOTASLAVE }; static const char * HEADER_KEYS[] = { "User-Agent", }; @@ -2037,8 +2037,8 @@ void HandleUploadDone(void) WSContentSend_P(PSTR("%06x'>" D_SUCCESSFUL "
"), WebColor(COL_TEXT_SUCCESS)); WSContentSend_P(HTTP_MSG_RSTRT); ShowWebSource(SRC_WEBGUI); -#ifdef USE_ARDUINO_SLAVE - if (ArduinoSlave_GetFlagFlashing()) { +#ifdef USE_TASMOTA_SLAVE + if (TasmotaSlave_GetFlagFlashing()) { restart_flag = 0; } else { // It was a normal firmware file, or we are ready to restart device restart_flag = 2; @@ -2051,9 +2051,9 @@ void HandleUploadDone(void) WSContentSend_P(PSTR("
")); WSContentSpaceButton(BUTTON_MAIN); WSContentStop(); -#ifdef USE_ARDUINO_SLAVE - if (ArduinoSlave_GetFlagFlashing()) { - ArduinoSlave_Flash(); +#ifdef USE_TASMOTA_SLAVE + if (TasmotaSlave_GetFlagFlashing()) { + TasmotaSlave_Flash(); } #endif } @@ -2121,11 +2121,11 @@ void HandleUploadLoop(void) if (Web.upload_error != 0) { return; } } else #endif // USE_RF_FLASH -#ifdef USE_ARDUINO_SLAVE +#ifdef USE_TASMOTA_SLAVE if ((WEMOS == my_module_type) && (upload.buf[0] == ':')) { // Check if this is a ARDUINO SLAVE hex file Update.end(); // End esp8266 update session - Web.upload_file_type = UPL_ARDUINOSLAVE; - Web.upload_error = ArduinoSlave_UpdateInit(); + Web.upload_file_type = UPL_TASMOTASLAVE; + Web.upload_error = TasmotaSlave_UpdateInit(); if (Web.upload_error != 0) { return; } } else #endif @@ -2187,9 +2187,9 @@ void HandleUploadLoop(void) } } #endif // USE_RF_FLASH -#ifdef USE_ARDUINO_SLAVE - else if (UPL_ARDUINOSLAVE == Web.upload_file_type) { - ArduinoSlave_WriteBuffer(upload.buf, upload.currentSize); +#ifdef USE_TASMOTA_SLAVE + else if (UPL_TASMOTASLAVE == Web.upload_file_type) { + TasmotaSlave_WriteBuffer(upload.buf, upload.currentSize); } #endif else { // firmware @@ -2243,10 +2243,10 @@ void HandleUploadLoop(void) Web.upload_file_type = UPL_TASMOTA; } #endif // USE_RF_FLASH -#ifdef USE_ARDUINO_SLAVE - else if (UPL_ARDUINOSLAVE == Web.upload_file_type) { +#ifdef USE_TASMOTA_SLAVE + else if (UPL_TASMOTASLAVE == Web.upload_file_type) { // Done writing the hex to SPI flash - ArduinoSlave_SetFlagFlashing(true); // So we know on upload success page if it needs to flash hex or do a normal restart + TasmotaSlave_SetFlagFlashing(true); // So we know on upload success page if it needs to flash hex or do a normal restart Web.upload_file_type = UPL_TASMOTA; } #endif diff --git a/sonoff/xdrv_31_arduino_slave.ino b/sonoff/xdrv_31_arduino_slave.ino index 497ab28dd..dff94182b 100644 --- a/sonoff/xdrv_31_arduino_slave.ino +++ b/sonoff/xdrv_31_arduino_slave.ino @@ -1,5 +1,5 @@ /* - xdrv_31_arduino_slave.ino - Support for Arduino Slave on Serial + xdrv_31_tasmota_slave.ino - Support for external microcontroller slave on serial Copyright (C) 2019 Andre Thomas and Theo Arends @@ -17,9 +17,9 @@ along with this program. If not, see . */ -#ifdef USE_ARDUINO_SLAVE +#ifdef USE_TASMOTA_SLAVE /*********************************************************************************************\ - * Arduino slave + * Tasmota slave \*********************************************************************************************/ #define XDRV_31 31 @@ -34,50 +34,182 @@ #define CMND_STK_LOAD_ADDRESS 0x55 #define CMND_STK_PROG_PAGE 0x64 -#include -#include +/*************************************************\ + * Tasmota Slave Specific Commands +\*************************************************/ -struct ASLAVE { +#define CMND_START 0xFC +#define CMND_END 0xFD + +#define CMND_FEATURES 0x01 +#define CMND_JSON 0x02 + +#define PARAM_DATA_START 0xFE +#define PARAM_DATA_END 0xFF + + +#include + +/* + * Embedding class in here since its rather specific to Arduino bootloader + */ + +class SimpleHexParse { + public: + SimpleHexParse(void); + uint8_t parseLine(char *hexline); + uint8_t ptr_l = 0; + uint8_t ptr_h = 0; + bool PageIsReady = false; + bool firstrun = true; + bool EndOfFile = false; + uint8_t FlashPage[128]; + uint8_t FlashPageIdx = 0; + uint8_t layoverBuffer[16]; + uint8_t layoverIdx = 0; + uint8_t getByte(char *hexline, uint8_t idx); +}; + +SimpleHexParse::SimpleHexParse(void) +{ + +} + +uint8_t SimpleHexParse::parseLine(char *hexline) +{ + if (layoverIdx) { + memcpy(&FlashPage[0], &layoverBuffer[0], layoverIdx); + FlashPageIdx = layoverIdx; + layoverIdx = 0; + } + uint8_t len = getByte(hexline, 1); + uint8_t addr_h = getByte(hexline, 2); + uint8_t addr_l = getByte(hexline, 3); + uint8_t rectype = getByte(hexline, 4); + for (uint8_t idx = 0; idx < len; idx++) { + if (FlashPageIdx < 128) { + FlashPage[FlashPageIdx] = getByte(hexline, idx+5); + FlashPageIdx++; + } else { // We have layover bytes + layoverBuffer[layoverIdx] = getByte(hexline, idx+5); + layoverIdx++; + } + } + if (1 == rectype) { + EndOfFile = true; + while (FlashPageIdx < 128) { + FlashPage[FlashPageIdx] = 0xFF; + FlashPageIdx++; + } + } + if (FlashPageIdx == 128) { + if (firstrun) { + firstrun = false; + } else { + ptr_l += 0x40; + if (ptr_l == 0) { + ptr_l = 0; + ptr_h++; + } + } + firstrun = false; + PageIsReady = true; + } + return 0; +} + +uint8_t SimpleHexParse::getByte(char* hexline, uint8_t idx) +{ + char buff[3]; + buff[3] = '\0'; + memcpy(&buff, &hexline[(idx*2)-1], 2); + return strtol(buff, 0, 16); +} + +/* + * End of embedded class SimpleHexParse + */ + +struct TSLAVE { uint32_t spi_hex_size = 0; uint32_t spi_sector_counter = 0; uint8_t spi_sector_cursor = 0; - uint8_t inverted = LOW; bool type = false; bool flashing = false; -} ASlave; + bool SerialEnabled = false; + uint8_t waitstate = 0; // We use this so that features detection does not slow down other stuff on startup +} TSlave; -TasmotaSerial *ArduinoSlave_Serial; +typedef union { + uint16_t data; + struct { + uint16_t json : 1; + uint16_t spare1 : 1; + uint16_t spare2 : 1; + uint16_t spare3 : 1; + uint16_t spare4 : 1; + uint16_t spare5 : 1; + uint16_t spare6 : 1; + uint16_t spare7 : 1; + uint16_t spare8 : 1; + uint16_t spare9 : 1; + uint16_t spare10 : 1; + uint16_t spare11 : 1; + uint16_t spare12 : 1; + uint16_t spare13 : 1; + uint16_t spare14 : 1; + uint16_t spare15 : 1; + }; +} TSlaveFeatureCfg; -uint32_t ArduinoSlaveFlashStart(void) +/* + * The structure below must remain 4 byte aligned to be compatible with + * Tasmota as master + */ + +struct FEATURES { + uint32_t features_version; + TSlaveFeatureCfg features; + uint16_t spare4; +} TSlaveSettings; + +struct COMMAND { + uint8_t command; + uint8_t parameter; + uint8_t unused2; + uint8_t unused3; +} Command; + +TasmotaSerial *TasmotaSlave_Serial; + +uint32_t TasmotaSlave_FlashStart(void) { return (ESP.getSketchSize() / SPI_FLASH_SEC_SIZE) + 2; // Stay on the safe side } -uint8_t ArduinoSlave_UpdateInit(void) +uint8_t TasmotaSlave_UpdateInit(void) { - ASlave.spi_hex_size = 0; - ASlave.spi_sector_counter = ArduinoSlaveFlashStart(); // Reset the pre-defined write address where firmware will temporarily be stored - ASlave.spi_sector_cursor = 0; + TSlave.spi_hex_size = 0; + TSlave.spi_sector_counter = TasmotaSlave_FlashStart(); // Reset the pre-defined write address where firmware will temporarily be stored + TSlave.spi_sector_cursor = 0; return 0; } -void ArduinoSlave_Reset(void) +void TasmotaSlave_Reset(void) { - if (ASlave.type) { - digitalWrite(pin[GPIO_ARDUINO_RST], !ASlave.inverted); + if (TSlave.SerialEnabled) { + digitalWrite(pin[GPIO_TASMOTASLAVE_RST], LOW); delay(1); - digitalWrite(pin[GPIO_ARDUINO_RST], ASlave.inverted); - delay(1); - digitalWrite(pin[GPIO_ARDUINO_RST], !ASlave.inverted); + digitalWrite(pin[GPIO_TASMOTASLAVE_RST], HIGH); delay(5); } } -uint8_t ArduinoSlave_waitForSerialData(int dataCount, int timeout) +uint8_t TasmotaSlave_waitForSerialData(int dataCount, int timeout) { int timer = 0; while (timer < timeout) { - if (ArduinoSlave_Serial->available() >= dataCount) { + if (TasmotaSlave_Serial->available() >= dataCount) { return 1; } delay(1); @@ -86,25 +218,25 @@ uint8_t ArduinoSlave_waitForSerialData(int dataCount, int timeout) return 0; } -uint8_t ArduinoSlave_sendBytes(uint8_t* bytes, int count) +uint8_t TasmotaSlave_sendBytes(uint8_t* bytes, int count) { - ArduinoSlave_Serial->write(bytes, count); - ArduinoSlave_waitForSerialData(2, 1000); - uint8_t sync = ArduinoSlave_Serial->read(); - uint8_t ok = ArduinoSlave_Serial->read(); - if (sync == 0x14 && ok == 0x10) { + TasmotaSlave_Serial->write(bytes, count); + TasmotaSlave_waitForSerialData(2, 1000); + uint8_t sync = TasmotaSlave_Serial->read(); + uint8_t ok = TasmotaSlave_Serial->read(); + if ((sync == 0x14) && (ok == 0x10)) { return 1; } return 0; } -uint8_t ArduinoSlave_execCmd(uint8_t cmd) +uint8_t TasmotaSlave_execCmd(uint8_t cmd) { uint8_t bytes[] = { cmd, CONST_STK_CRC_EOP }; - return ArduinoSlave_sendBytes(bytes, 2); + return TasmotaSlave_sendBytes(bytes, 2); } -uint8_t ArduinoSlave_execParam(uint8_t cmd, uint8_t* params, int count) +uint8_t TasmotaSlave_execParam(uint8_t cmd, uint8_t* params, int count) { uint8_t bytes[32]; bytes[0] = cmd; @@ -114,50 +246,87 @@ uint8_t ArduinoSlave_execParam(uint8_t cmd, uint8_t* params, int count) i++; } bytes[i + 1] = CONST_STK_CRC_EOP; - return ArduinoSlave_sendBytes(bytes, i + 2); + return TasmotaSlave_sendBytes(bytes, i + 2); } -uint8_t ArduinoSlave_exitProgMode(void) +uint8_t TasmotaSlave_exitProgMode(void) { - return ArduinoSlave_execCmd(CMND_STK_LEAVE_PROGMODE); // Exit programming mode + return TasmotaSlave_execCmd(CMND_STK_LEAVE_PROGMODE); // Exit programming mode } -void ArduinoSlave_SetupFlash(void) +void TasmotaSlave_SetupFlash(void) { - uint8_t ProgParams[] = {0x86,0x00,0x00,0x01,0x01,0x01,0x01,0x03,0xff,0xff,0xff,0xff,0x00,0x80,0x04,0x00,0x00,0x00,0x80,0x00}; - uint8_t ExtProgParams[] = {0x05,0x04,0xd7,0xc2,0x00}; - ArduinoSlave_Serial->begin(USE_ARDUINO_FLASH_SPEED); - if (ArduinoSlave_Serial->hardwareSerial()) { + uint8_t ProgParams[] = {0x86, 0x00, 0x00, 0x01, 0x01, 0x01, 0x01, 0x03, 0xff, 0xff, 0xff, 0xff, 0x00, 0x80, 0x04, 0x00, 0x00, 0x00, 0x80, 0x00}; + uint8_t ExtProgParams[] = {0x05, 0x04, 0xd7, 0xc2, 0x00}; + TasmotaSlave_Serial->begin(USE_TASMOTA_SLAVE_FLASH_SPEED); + if (TasmotaSlave_Serial->hardwareSerial()) { ClaimSerial(); } - ArduinoSlave_Reset(); - ArduinoSlave_execCmd(CMND_STK_GET_SYNC); - ArduinoSlave_execParam(CMND_STK_SET_DEVICE, ProgParams, sizeof(ProgParams)); // Set programming parameters - ArduinoSlave_execParam(CMND_STK_SET_DEVICE_EXT, ExtProgParams, sizeof(ExtProgParams)); // Set extended programming parameters - ArduinoSlave_execCmd(CMND_STK_ENTER_PROGMODE); // Enter programming mode + TasmotaSlave_Reset(); + + uint8_t timer = 0; + bool no_error = false; + while (200 > timer) { + if (TasmotaSlave_execCmd(CMND_STK_GET_SYNC)) { + timer = 200; + no_error = true; + } + delay(1); + } + + if (no_error) { + AddLog_P2(LOG_LEVEL_INFO, PSTR("TasmotaSlave: Found bootloader")); + } else { + AddLog_P2(LOG_LEVEL_INFO, PSTR("TasmotaSlave: Bootloader could not be found")); + } + + if (no_error) { + if (TasmotaSlave_execParam(CMND_STK_SET_DEVICE, ProgParams, sizeof(ProgParams))) { + } else { + no_error = true; + AddLog_P2(LOG_LEVEL_INFO, PSTR("TasmotaSlave: Could not configure device for programming (1)")); + } + } + + if (no_error) { + if (TasmotaSlave_execParam(CMND_STK_SET_DEVICE_EXT, ExtProgParams, sizeof(ExtProgParams))) { + } else { + no_error = true; + AddLog_P2(LOG_LEVEL_INFO, PSTR("TasmotaSlave: Could not configure device for programming (2)")); + } + } + + if (no_error) { + if (TasmotaSlave_execCmd(CMND_STK_ENTER_PROGMODE)) { + } else { + no_error = true; + AddLog_P2(LOG_LEVEL_INFO, PSTR("TasmotaSlave: Failed to put bootloader into programming mode")); + } + } + } -uint8_t ArduinoSlave_loadAddress(uint8_t adrHi, uint8_t adrLo) +uint8_t TasmotaSlave_loadAddress(uint8_t adrHi, uint8_t adrLo) { - uint8_t params[] = { adrHi, adrLo }; - return ArduinoSlave_execParam(CMND_STK_LOAD_ADDRESS, params, sizeof(params)); + uint8_t params[] = { adrLo, adrHi }; + return TasmotaSlave_execParam(CMND_STK_LOAD_ADDRESS, params, sizeof(params)); } -void ArduinoSlave_FlashPage(uint8_t* address, uint8_t* data) +void TasmotaSlave_FlashPage(uint8_t addr_h, uint8_t addr_l, uint8_t* data) { uint8_t Header[] = {CMND_STK_PROG_PAGE, 0x00, 0x80, 0x46}; - ArduinoSlave_loadAddress(address[1], address[0]); - ArduinoSlave_Serial->write(Header, 4); + TasmotaSlave_loadAddress(addr_h, addr_l); + TasmotaSlave_Serial->write(Header, 4); for (int i = 0; i < 128; i++) { - ArduinoSlave_Serial->write(data[i]); + TasmotaSlave_Serial->write(data[i]); } - ArduinoSlave_Serial->write(CONST_STK_CRC_EOP); - ArduinoSlave_waitForSerialData(2, 1000); - ArduinoSlave_Serial->read(); - ArduinoSlave_Serial->read(); + TasmotaSlave_Serial->write(CONST_STK_CRC_EOP); + TasmotaSlave_waitForSerialData(2, 1000); + TasmotaSlave_Serial->read(); + TasmotaSlave_Serial->read(); } -void ArduinoSlave_Flash(void) +void TasmotaSlave_Flash(void) { bool reading = true; uint32_t read = 0; @@ -165,31 +334,31 @@ void ArduinoSlave_Flash(void) char thishexline[50]; uint8_t position = 0; char* flash_buffer; - ArduinoHexParse hexParse = ArduinoHexParse(); + SimpleHexParse hexParse = SimpleHexParse(); - ArduinoSlave_SetupFlash(); + TasmotaSlave_SetupFlash(); flash_buffer = new char[SPI_FLASH_SEC_SIZE]; - uint32_t flash_start = ArduinoSlaveFlashStart() * SPI_FLASH_SEC_SIZE; + uint32_t flash_start = TasmotaSlave_FlashStart() * SPI_FLASH_SEC_SIZE; while (reading) { ESP.flashRead(flash_start + read, (uint32_t*)flash_buffer, SPI_FLASH_SEC_SIZE); read = read + SPI_FLASH_SEC_SIZE; - if (read >= ASlave.spi_hex_size) { + if (read >= TSlave.spi_hex_size) { reading = false; } for (uint32_t ca = 0; ca < SPI_FLASH_SEC_SIZE; ca++) { processed++; - if (processed <= ASlave.spi_hex_size) { + if ((processed <= TSlave.spi_hex_size) && (!hexParse.EndOfFile)) { if (':' == flash_buffer[ca]) { position = 0; } if (0x0D == flash_buffer[ca]) { thishexline[position] = 0; - hexParse.ParseLine((uint8_t*)thishexline); - if (hexParse.IsFlashPageReady()) { - uint8_t* page = hexParse.GetFlashPage(); - uint8_t* address = hexParse.GetLoadAddress(); - ArduinoSlave_FlashPage(address, page); + hexParse.parseLine(thishexline); + if (hexParse.PageIsReady) { + TasmotaSlave_FlashPage(hexParse.ptr_h, hexParse.ptr_l, hexParse.FlashPage); + hexParse.PageIsReady = false; + hexParse.FlashPageIdx = 0; } } else { if (0x0A != flash_buffer[ca]) { @@ -200,72 +369,93 @@ void ArduinoSlave_Flash(void) } } } - ASlave.flashing = false; - ArduinoSlave_exitProgMode(); + TasmotaSlave_exitProgMode(); + TSlave.flashing = false; restart_flag = 2; } -void ArduinoSlave_SetFlagFlashing(bool value) +void TasmotaSlave_SetFlagFlashing(bool value) { - ASlave.flashing = value; + TSlave.flashing = value; } -bool ArduinoSlave_GetFlagFlashing(void) +bool TasmotaSlave_GetFlagFlashing(void) { - return ASlave.flashing ; + return TSlave.flashing; } -void ArduinoSlave_WriteBuffer(uint8_t *buf, size_t size) +void TasmotaSlave_WriteBuffer(uint8_t *buf, size_t size) { - if (0 == ASlave.spi_sector_cursor) { // Starting a new sector write so we need to erase it first - ESP.flashEraseSector(ASlave.spi_sector_counter); + if (0 == TSlave.spi_sector_cursor) { // Starting a new sector write so we need to erase it first + ESP.flashEraseSector(TSlave.spi_sector_counter); } - ASlave.spi_sector_cursor++; - ESP.flashWrite((ASlave.spi_sector_counter * SPI_FLASH_SEC_SIZE) + ((ASlave.spi_sector_cursor-1)*2048), (uint32_t*)buf, size); - ASlave.spi_hex_size = ASlave.spi_hex_size + size; - if (2 == ASlave.spi_sector_cursor) { // The web upload sends 2048 bytes at a time so keep track of the cursor position to reset it for the next flash sector erase - ASlave.spi_sector_cursor = 0; - ASlave.spi_sector_counter++; + TSlave.spi_sector_cursor++; + ESP.flashWrite((TSlave.spi_sector_counter * SPI_FLASH_SEC_SIZE) + ((TSlave.spi_sector_cursor-1)*2048), (uint32_t*)buf, size); + TSlave.spi_hex_size = TSlave.spi_hex_size + size; + if (2 == TSlave.spi_sector_cursor) { // The web upload sends 2048 bytes at a time so keep track of the cursor position to reset it for the next flash sector erase + TSlave.spi_sector_cursor = 0; + TSlave.spi_sector_counter++; } } -void ArduinoSlave_Init(void) +void TasmotaSlave_Init(void) { - if (ASlave.type) { + if (TSlave.type) { return; } - if ((pin[GPIO_ARDUINO_RXD] < 99) && (pin[GPIO_ARDUINO_TXD] < 99) && - ((pin[GPIO_ARDUINO_RST] < 99) || (pin[GPIO_ARDUINO_RST_INV] < 99))) { - ArduinoSlave_Serial = new TasmotaSerial(pin[GPIO_ARDUINO_RXD], pin[GPIO_ARDUINO_TXD], 1, 0, 200); - if (ArduinoSlave_Serial->begin(USE_ARDUINO_SERIAL_SPEED)) { - if (ArduinoSlave_Serial->hardwareSerial()) { - ClaimSerial(); + if (10 > TSlave.waitstate) { + TSlave.waitstate++; + return; + } + if (!TSlave.SerialEnabled) { + if ((pin[GPIO_TASMOTASLAVE_RXD] < 99) && (pin[GPIO_TASMOTASLAVE_TXD] < 99) && (pin[GPIO_TASMOTASLAVE_RST] < 99)) { + TasmotaSlave_Serial = new TasmotaSerial(pin[GPIO_TASMOTASLAVE_RXD], pin[GPIO_TASMOTASLAVE_TXD], 1, 0, 200); + if (TasmotaSlave_Serial->begin(USE_TASMOTA_SLAVE_SERIAL_SPEED)) { + if (TasmotaSlave_Serial->hardwareSerial()) { + ClaimSerial(); + } + pinMode(pin[GPIO_TASMOTASLAVE_RST], OUTPUT); + TasmotaSlave_Reset(); + TSlave.SerialEnabled = true; + AddLog_P2(LOG_LEVEL_INFO, PSTR("Tasmota Slave Enabled")); } - if (pin[GPIO_ARDUINO_RST_INV] < 99) { - pin[GPIO_ARDUINO_RST] = pin[GPIO_ARDUINO_RST_INV]; - pin[GPIO_ARDUINO_RST_INV] = 99; - ASlave.inverted = HIGH; - } - pinMode(pin[GPIO_ARDUINO_RST], OUTPUT); - ASlave.type = true; - ArduinoSlave_Reset(); - AddLog_P2(LOG_LEVEL_INFO, PSTR("Arduino Slave Enabled")); + } + } + if (TSlave.SerialEnabled) { // All go for hardware now we need to detect features if there are any + TasmotaSlave_sendCmnd(CMND_FEATURES, 0); + char buffer[32]; + TasmotaSlave_Serial->readBytesUntil(char(PARAM_DATA_START), buffer, sizeof(buffer)); + uint8_t len = TasmotaSlave_Serial->readBytesUntil(char(PARAM_DATA_END), buffer, sizeof(buffer)); + memcpy(&TSlaveSettings, &buffer, sizeof(TSlaveSettings)); + if (20191026 <= TSlaveSettings.features_version) { + TSlave.type = true; + AddLog_P2(LOG_LEVEL_INFO, PSTR("Tasmota Slave Version %u"), TSlaveSettings.features_version); } } } -void ArduinoSlave_Show(bool json) +void TasmotaSlave_Show(void) { - if (ASlave.type) { - ArduinoSlave_Serial->flush(); - ArduinoSlave_Serial->print("JSON"); - ArduinoSlave_Serial->find(char(0xFE)); + if ((TSlave.type) && (TSlaveSettings.features.json)) { char buffer[100]; - uint16_t haveread = ArduinoSlave_Serial->readBytesUntil(char(0xFF), buffer, sizeof(buffer)-1); - buffer[haveread] = '\0'; - if (json) { - ResponseAppend_P(PSTR(",\"ArduinoSlave\":%s"), buffer); - } + TasmotaSlave_sendCmnd(CMND_JSON, 0); + TasmotaSlave_Serial->readBytesUntil(char(PARAM_DATA_START), buffer, sizeof(buffer)-1); + uint8_t len = TasmotaSlave_Serial->readBytesUntil(char(PARAM_DATA_END), buffer, sizeof(buffer)-1); + buffer[len] = '\0'; + ResponseAppend_P(PSTR(",\"TasmotaSlave\":%s"), buffer); + } +} + +void TasmotaSlave_sendCmnd(uint8_t cmnd, uint8_t param) +{ + Command.command = cmnd; + Command.parameter = param; + char buffer[sizeof(Command)+2]; + buffer[0] = CMND_START; + memcpy(&buffer[1], &Command, sizeof(Command)); + buffer[sizeof(Command)+1] = CMND_END; + for (uint8_t ca = 0; ca < sizeof(buffer); ca++) { + TasmotaSlave_Serial->write(buffer[ca]); } } @@ -279,13 +469,13 @@ bool Xdrv31(uint8_t function) switch (function) { case FUNC_EVERY_SECOND: - ArduinoSlave_Init(); + TasmotaSlave_Init(); break; case FUNC_JSON_APPEND: - ArduinoSlave_Show(1); + TasmotaSlave_Show(); break; } return result; } -#endif // USE_ARDUINO_SLAVE \ No newline at end of file +#endif // USE_TASMOTA_SLAVE \ No newline at end of file From 71b5caa7c117c76b86124fe56a0d3779d539e269 Mon Sep 17 00:00:00 2001 From: andrethomas Date: Sat, 26 Oct 2019 22:58:48 +0200 Subject: [PATCH 4/7] Update language files --- sonoff/language/bg-BG.h | 6 +++--- sonoff/language/cs-CZ.h | 6 +++--- sonoff/language/de-DE.h | 6 +++--- sonoff/language/el-GR.h | 6 +++--- sonoff/language/en-GB.h | 6 +++--- sonoff/language/es-ES.h | 6 +++--- sonoff/language/fr-FR.h | 6 +++--- sonoff/language/he-HE.h | 6 +++--- sonoff/language/hu-HU.h | 6 +++--- sonoff/language/it-IT.h | 6 +++--- sonoff/language/ko-KO.h | 6 +++--- sonoff/language/nl-NL.h | 6 +++--- sonoff/language/pl-PL.h | 6 +++--- sonoff/language/pt-BR.h | 6 +++--- sonoff/language/pt-PT.h | 6 +++--- sonoff/language/ru-RU.h | 6 +++--- sonoff/language/sk-SK.h | 6 +++--- sonoff/language/sv-SE.h | 6 +++--- sonoff/language/tr-TR.h | 6 +++--- sonoff/language/uk-UK.h | 6 +++--- sonoff/language/zh-CN.h | 6 +++--- sonoff/language/zh-TW.h | 6 +++--- 22 files changed, 66 insertions(+), 66 deletions(-) diff --git a/sonoff/language/bg-BG.h b/sonoff/language/bg-BG.h index d765614f6..aacf93d87 100644 --- a/sonoff/language/bg-BG.h +++ b/sonoff/language/bg-BG.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/cs-CZ.h b/sonoff/language/cs-CZ.h index fd654c148..30a59a144 100644 --- a/sonoff/language/cs-CZ.h +++ b/sonoff/language/cs-CZ.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/de-DE.h b/sonoff/language/de-DE.h index acff5f96b..e0a9b5d5e 100644 --- a/sonoff/language/de-DE.h +++ b/sonoff/language/de-DE.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/el-GR.h b/sonoff/language/el-GR.h index 680633d6a..cf558c58f 100644 --- a/sonoff/language/el-GR.h +++ b/sonoff/language/el-GR.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/en-GB.h b/sonoff/language/en-GB.h index 74a2fdca0..93540788d 100644 --- a/sonoff/language/en-GB.h +++ b/sonoff/language/en-GB.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/es-ES.h b/sonoff/language/es-ES.h index 2530fd6e4..56496dc5f 100644 --- a/sonoff/language/es-ES.h +++ b/sonoff/language/es-ES.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/fr-FR.h b/sonoff/language/fr-FR.h index 1522ec15f..c98ef6740 100644 --- a/sonoff/language/fr-FR.h +++ b/sonoff/language/fr-FR.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/he-HE.h b/sonoff/language/he-HE.h index 3e5fe4031..2fcfa7215 100644 --- a/sonoff/language/he-HE.h +++ b/sonoff/language/he-HE.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/hu-HU.h b/sonoff/language/hu-HU.h index f55f8ed38..80df2a8bc 100644 --- a/sonoff/language/hu-HU.h +++ b/sonoff/language/hu-HU.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/it-IT.h b/sonoff/language/it-IT.h index 912e95ec1..113ab15ce 100644 --- a/sonoff/language/it-IT.h +++ b/sonoff/language/it-IT.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/ko-KO.h b/sonoff/language/ko-KO.h index 35ae260b6..3ccbee135 100644 --- a/sonoff/language/ko-KO.h +++ b/sonoff/language/ko-KO.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/nl-NL.h b/sonoff/language/nl-NL.h index 0e81cebff..14e4635c1 100644 --- a/sonoff/language/nl-NL.h +++ b/sonoff/language/nl-NL.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/pl-PL.h b/sonoff/language/pl-PL.h index bd03d60e3..3c28ec248 100644 --- a/sonoff/language/pl-PL.h +++ b/sonoff/language/pl-PL.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/pt-BR.h b/sonoff/language/pt-BR.h index 5d7b02613..a2e89cb5d 100644 --- a/sonoff/language/pt-BR.h +++ b/sonoff/language/pt-BR.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/pt-PT.h b/sonoff/language/pt-PT.h index f060ec5d3..6a27ce711 100644 --- a/sonoff/language/pt-PT.h +++ b/sonoff/language/pt-PT.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/ru-RU.h b/sonoff/language/ru-RU.h index 13b721092..d5ce8af77 100644 --- a/sonoff/language/ru-RU.h +++ b/sonoff/language/ru-RU.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "А" diff --git a/sonoff/language/sk-SK.h b/sonoff/language/sk-SK.h index d35fff407..99e1790bd 100644 --- a/sonoff/language/sk-SK.h +++ b/sonoff/language/sk-SK.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/sv-SE.h b/sonoff/language/sv-SE.h index 701ed43ac..9fb0b0b20 100644 --- a/sonoff/language/sv-SE.h +++ b/sonoff/language/sv-SE.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/tr-TR.h b/sonoff/language/tr-TR.h index 295664ae0..f7989f244 100755 --- a/sonoff/language/tr-TR.h +++ b/sonoff/language/tr-TR.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "A" diff --git a/sonoff/language/uk-UK.h b/sonoff/language/uk-UK.h index 67999ef11..9c07a8da1 100644 --- a/sonoff/language/uk-UK.h +++ b/sonoff/language/uk-UK.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "А" diff --git a/sonoff/language/zh-CN.h b/sonoff/language/zh-CN.h index 36f71ea4c..db3d9e979 100644 --- a/sonoff/language/zh-CN.h +++ b/sonoff/language/zh-CN.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "安" diff --git a/sonoff/language/zh-TW.h b/sonoff/language/zh-TW.h index 53bd3e1a7..482134c6e 100644 --- a/sonoff/language/zh-TW.h +++ b/sonoff/language/zh-TW.h @@ -627,9 +627,9 @@ #define D_SENSOR_SM2135_DAT "SM2135 Dat" #define D_SENSOR_DEEPSLEEP "DeepSleep" #define D_SENSOR_EXS_ENABLE "EXS Enable" -#define D_SENSOR_ARDUINO_TX "Arduino TX" -#define D_SENSOR_ARDUINO_RX "Arduino RX" -#define D_SENSOR_ARDUINO_RESET "Arduino RST" +#define D_SENSOR_SLAVE_TX "Slave TX" +#define D_SENSOR_SLAVE_RX "Slave RX" +#define D_SENSOR_SLAVE_RESET "Slave RST" // Units #define D_UNIT_AMPERE "安" From 2f90708e90a1b0ec63ee90aa3aebf9c54c570853 Mon Sep 17 00:00:00 2001 From: andrethomas Date: Sat, 26 Oct 2019 23:07:09 +0200 Subject: [PATCH 5/7] Rename slave driver file --- sonoff/{xdrv_31_arduino_slave.ino => xdrv_31_tasmota_slave.ino} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename sonoff/{xdrv_31_arduino_slave.ino => xdrv_31_tasmota_slave.ino} (100%) diff --git a/sonoff/xdrv_31_arduino_slave.ino b/sonoff/xdrv_31_tasmota_slave.ino similarity index 100% rename from sonoff/xdrv_31_arduino_slave.ino rename to sonoff/xdrv_31_tasmota_slave.ino From 85facc96dfe23f1d9885c0e4e264384f120aea9a Mon Sep 17 00:00:00 2001 From: andrethomas Date: Sat, 26 Oct 2019 23:11:35 +0200 Subject: [PATCH 6/7] Update my_user_config.h resource usage --- sonoff/my_user_config.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sonoff/my_user_config.h b/sonoff/my_user_config.h index 9073d0699..e73613466 100644 --- a/sonoff/my_user_config.h +++ b/sonoff/my_user_config.h @@ -534,7 +534,7 @@ //#define USE_HRE // Add support for Badger HR-E Water Meter (+1k4 code) //#define USE_A4988_STEPPER // Add support for A4988/DRV8825 stepper-motor-driver-circuit (+10k5 code) -//#define USE_TASMOTA_SLAVE // Add support for Arduino Uno/Pro Mini via serial interface including flashing (+2k3 code, 44 mem) +//#define USE_TASMOTA_SLAVE // Add support for Arduino Uno/Pro Mini via serial interface including flashing (+2k6 code, 64 mem) #define USE_TASMOTA_SLAVE_FLASH_SPEED 57600 // Usually 57600 for 3.3V variants and 115200 for 5V variants #define USE_TASMOTA_SLAVE_SERIAL_SPEED 57600 // Depends on the sketch that is running on the Uno/Pro Mini From 8571af489587a2d6358f97973c85cedc36672200 Mon Sep 17 00:00:00 2001 From: Andre Thomas Date: Sat, 26 Oct 2019 23:13:40 +0200 Subject: [PATCH 7/7] ArduinoSlave->TasmotaSlave --- sonoff/_changelog.ino | 1 + 1 file changed, 1 insertion(+) diff --git a/sonoff/_changelog.ino b/sonoff/_changelog.ino index 1cb954c7b..332276b28 100644 --- a/sonoff/_changelog.ino +++ b/sonoff/_changelog.ino @@ -3,6 +3,7 @@ * Release * Fix on energy monitoring devices using PowerDelta Exception0 with epc1:0x4000dce5 = Divide by zero (#6750) * Fix Script array bug (#6751) + * Move ArduinoSlave to TasmotaSlave (Experimental) * * 6.7.0 20191025 * Release