From 4858ec0aefc9ce978589e8f49aefd61a40003c97 Mon Sep 17 00:00:00 2001 From: Theo Arends <11044339+arendst@users.noreply.github.com> Date: Tue, 11 Jun 2024 12:41:19 +0200 Subject: [PATCH] Allow receive or send using SerialBridge --- CHANGELOG.md | 1 + RELEASENOTES.md | 1 + .../xdrv_08_serial_bridge.ino | 32 +++++++++++++++---- 3 files changed, 27 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 524bb3a34..c0fde9652 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -22,6 +22,7 @@ All notable changes to this project will be documented in this file. - Matter filter suffix automatically added for sensors (#21589) - Display timing splash screen with display modes 1 to 5 - ESP32 MI32 refactoring, bugfixes, generic device scanning (#21603) +- Allow receive or send using SerialBridge ### Fixed - Berry `input()` returns empty string and does not crash (#21565) diff --git a/RELEASENOTES.md b/RELEASENOTES.md index 2d8d2e622..b3a877d30 100644 --- a/RELEASENOTES.md +++ b/RELEASENOTES.md @@ -132,6 +132,7 @@ The latter links can be used for OTA upgrades too like ``OtaUrl https://ota.tasm ### Changed - Optional MQTT_TELE_RETAIN to Energy Margins message replaced by ``SensorRetain`` - Display timing splash screen with display modes 1 to 5 +- Allow receive or send using SerialBridge - ESP32 Core3 platform update from 2024.05.13 to 2024.06.10 [#21569](https://github.com/arendst/Tasmota/issues/21569) - ESP32 MI32 refactoring, bugfixes, generic device scanning [#21603](https://github.com/arendst/Tasmota/issues/21603) - Matter refactoring of bridged devices [#21575](https://github.com/arendst/Tasmota/issues/21575) diff --git a/tasmota/tasmota_xdrv_driver/xdrv_08_serial_bridge.ino b/tasmota/tasmota_xdrv_driver/xdrv_08_serial_bridge.ino index fdce70e4a..62cb40a9d 100644 --- a/tasmota/tasmota_xdrv_driver/xdrv_08_serial_bridge.ino +++ b/tasmota/tasmota_xdrv_driver/xdrv_08_serial_bridge.ino @@ -20,6 +20,24 @@ #ifdef USE_SERIAL_BRIDGE /*********************************************************************************************\ * Serial Bridge using Software Serial library (TasmotaSerial) + * + * SBaudrate - Set baudrate + * SBaudrate 9600 + * SSerialConfig - Set serial config + * SSerialConfig 8N1 + * SSerialBuffer - Set serial receive buffer + * SSerialSend "Hello Tiger" - Send "Hello Tiger\n" + * SSerialSend - Set to text decoding + * SSerialSend1 "Hello Tiger" - Send "Hello Tiger\n" + * SSerialSend2 "Hello Tiger" - Send "Hello Tiger" + * SSerialSend3 "Hello Tiger" - Send "Hello Tiger\f" + * SSerialSend4 - Set to binary decoding + * SSerialSend4 "Hello Tiger" - Send "Hello Tiger" and set to binary decoding + * SSerialSend5 "AA004566" - Send "AA004566" as hex values + * SSerialSend6 "72,101,108,108" - Send decimals as hex values + * SerialDelimiter 255 - Receive data between 32 and 127 only + * SerialDelimiter 254 - Receive hexadecimal data + * SerialDelimiter 128 - Receive no data between 32 and 127 \*********************************************************************************************/ #define XDRV_08 8 @@ -91,7 +109,7 @@ void SerialBridgeInput(void) { uint8_t serial_in_byte = SerialBridgeSerial->read(); #ifdef USE_SERIAL_BRIDGE_TEE - if (Settings->sbflag1.serbridge_console) { + if (Settings->sbflag1.serbridge_console) { // CMND_SSERIALSEND9 - Enable logging tee to serialbridge static bool serial_bridge_overrun = false; if (isprint(serial_in_byte)) { // Any char between 32 and 127 @@ -117,7 +135,7 @@ void SerialBridgeInput(void) { } } else { #endif // USE_SERIAL_BRIDGE_TEE - serial_bridge_raw = (254 == Settings->serial_delimiter); + serial_bridge_raw = (254 == Settings->serial_delimiter); // SerialDelimiter if ((serial_in_byte > 127) && !serial_bridge_raw) { // Discard binary data above 127 if no raw reception allowed serial_bridge_in_byte_counter = 0; SerialBridgeSerial->flush(); @@ -147,17 +165,17 @@ void SerialBridgeInput(void) { } #ifdef USE_SERIAL_BRIDGE_TEE - if (Settings->sbflag1.serbridge_console) { + if (Settings->sbflag1.serbridge_console) { // CMND_SSERIALSEND9 - Enable logging tee to serialbridge return; } #endif // USE_SERIAL_BRIDGE_TEE if (serial_bridge_in_byte_counter && (millis() > (serial_bridge_polling_window + SERIAL_POLLING))) { - serial_bridge_buffer[serial_bridge_in_byte_counter] = 0; // Serial data completed + serial_bridge_buffer[serial_bridge_in_byte_counter] = 0; // Serial data completed bool assume_json = (!serial_bridge_raw && (serial_bridge_buffer[0] == '{')); - TasmotaGlobal.serial_skip++; // SetOption35 Skip number of serial messages received (default 0) - if (TasmotaGlobal.serial_skip > Settings->param[P_SERIAL_SKIP]) { // Handle intermediate changes to SetOption35 + TasmotaGlobal.serial_skip++; // SetOption35 Skip number of serial messages received (default 0) + if (TasmotaGlobal.serial_skip > Settings->param[P_SERIAL_SKIP]) { // Handle intermediate changes to SetOption35 TasmotaGlobal.serial_skip = 0; Response_P(PSTR("{\"" D_JSON_SSERIALRECEIVED "\":")); @@ -188,7 +206,7 @@ void SerialBridgeInput(void) { /********************************************************************************************/ void SerialBridgeInit(void) { - if (PinUsed(GPIO_SBR_RX) && PinUsed(GPIO_SBR_TX)) { + if (PinUsed(GPIO_SBR_RX) || PinUsed(GPIO_SBR_TX)) { // SerialBridgeSerial = new TasmotaSerial(Pin(GPIO_SBR_RX), Pin(GPIO_SBR_TX), HARDWARE_FALLBACK); // Default TM_SERIAL_BUFFER_SIZE (=64) size SerialBridgeSerial = new TasmotaSerial(Pin(GPIO_SBR_RX), Pin(GPIO_SBR_TX), HARDWARE_FALLBACK, 0, MIN_INPUT_BUFFER_SIZE); // 256 if (SetSSerialBegin()) {