From cc59a42e3f70d12ce06b650c29c23f720cab98d7 Mon Sep 17 00:00:00 2001 From: Matthew Kennedy Date: Tue, 8 Dec 2020 02:05:43 -0600 Subject: [PATCH] start making TS protocol testable (#2043) * start pulling out a class * pull function out of loop * there we go * ok there we go for real Co-authored-by: Matthew Kennedy --- firmware/console/binary/tunerstudio.cpp | 164 +++++++++++---------- firmware/console/binary/tunerstudio.h | 28 +--- firmware/console/binary/tunerstudio_impl.h | 8 + firmware/console/binary/tunerstudio_io.h | 2 + 4 files changed, 98 insertions(+), 104 deletions(-) create mode 100644 firmware/console/binary/tunerstudio_impl.h diff --git a/firmware/console/binary/tunerstudio.cpp b/firmware/console/binary/tunerstudio.cpp index 032761840f..c7d7434c73 100644 --- a/firmware/console/binary/tunerstudio.cpp +++ b/firmware/console/binary/tunerstudio.cpp @@ -64,6 +64,7 @@ #include "allsensors.h" #include "tunerstudio.h" +#include "tunerstudio_impl.h" #include "main_trigger_callback.h" #include "flash_main.h" @@ -459,114 +460,118 @@ static bool isKnownCommand(char command) { || command == TS_GET_CONFIG_ERROR; } -// this function runs indefinitely -void runBinaryProtocolLoop(ts_channel_s *tsChannel) { - int wasReady = false; +TunerStudioBase tsInstance; - while (true) { - validateStack("communication", STACK_USAGE_COMMUNICATION, 128); +static void tsProcessOne(ts_channel_s* tsChannel) { + validateStack("communication", STACK_USAGE_COMMUNICATION, 128); - int isReady = sr5IsReady(tsChannel); - if (!isReady) { - chThdSleepMilliseconds(10); - wasReady = false; - continue; - } + int isReady = sr5IsReady(tsChannel); + if (!isReady) { + chThdSleepMilliseconds(10); + tsChannel->wasReady = false; + return; + } - if (!wasReady) { - wasReady = true; + if (!tsChannel->wasReady) { + tsChannel->wasReady = true; // scheduleSimpleMsg(&logger, "ts channel is now ready ", hTimeNow()); - } + } - tsState.totalCounter++; + tsState.totalCounter++; - uint8_t firstByte; - int received = sr5ReadData(tsChannel, &firstByte, 1); + uint8_t firstByte; + int received = sr5ReadData(tsChannel, &firstByte, 1); #if EFI_SIMULATOR - logMsg("received %d\r\n", received); + logMsg("received %d\r\n", received); #endif - if (received != 1) { + if (received != 1) { // tunerStudioError("ERROR: no command"); #if EFI_BLUETOOTH_SETUP - // assume there's connection loss and notify the bluetooth init code - bluetoothSoftwareDisconnectNotify(); + // assume there's connection loss and notify the bluetooth init code + bluetoothSoftwareDisconnectNotify(); #endif /* EFI_BLUETOOTH_SETUP */ - continue; - } - onDataArrived(); + return; + } + onDataArrived(); // scheduleMsg(logger, "Got first=%x=[%c]", firstByte, firstByte); - if (handlePlainCommand(tsChannel, firstByte)) - continue; + if (handlePlainCommand(tsChannel, firstByte)) + return; - uint8_t secondByte; - received = sr5ReadData(tsChannel, &secondByte, 1); - if (received != 1) { - tunerStudioError("TS: ERROR: no second byte"); - continue; - } + uint8_t secondByte; + received = sr5ReadData(tsChannel, &secondByte, 1); + if (received != 1) { + tunerStudioError("TS: ERROR: no second byte"); + return; + } // scheduleMsg(logger, "Got secondByte=%x=[%c]", secondByte, secondByte); - uint16_t incomingPacketSize = firstByte << 8 | secondByte; + uint16_t incomingPacketSize = firstByte << 8 | secondByte; - if (incomingPacketSize == 0 || incomingPacketSize > (sizeof(tsChannel->scratchBuffer) - CRC_WRAPPING_SIZE)) { - scheduleMsg(&tsLogger, "TunerStudio: invalid size: %d", incomingPacketSize); - tunerStudioError("ERROR: CRC header size"); - sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN); - continue; - } + if (incomingPacketSize == 0 || incomingPacketSize > (sizeof(tsChannel->scratchBuffer) - CRC_WRAPPING_SIZE)) { + scheduleMsg(&tsLogger, "TunerStudio: invalid size: %d", incomingPacketSize); + tunerStudioError("ERROR: CRC header size"); + sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN); + return; + } - received = sr5ReadData(tsChannel, (uint8_t* )tsChannel->scratchBuffer, 1); - if (received != 1) { - tunerStudioError("ERROR: did not receive command"); - sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN); - continue; - } + received = sr5ReadData(tsChannel, (uint8_t* )tsChannel->scratchBuffer, 1); + if (received != 1) { + tunerStudioError("ERROR: did not receive command"); + sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN); + return; + } - char command = tsChannel->scratchBuffer[0]; - if (!isKnownCommand(command)) { - scheduleMsg(&tsLogger, "unexpected command %x", command); - sendErrorCode(tsChannel, TS_RESPONSE_UNRECOGNIZED_COMMAND); - continue; - } + char command = tsChannel->scratchBuffer[0]; + if (!isKnownCommand(command)) { + scheduleMsg(&tsLogger, "unexpected command %x", command); + sendErrorCode(tsChannel, TS_RESPONSE_UNRECOGNIZED_COMMAND); + return; + } #if EFI_SIMULATOR - logMsg("command %c\r\n", command); + logMsg("command %c\r\n", command); #endif - received = sr5ReadData(tsChannel, (uint8_t * ) (tsChannel->scratchBuffer + 1), - incomingPacketSize + CRC_VALUE_SIZE - 1); - int expectedSize = incomingPacketSize + CRC_VALUE_SIZE - 1; - if (received != expectedSize) { - scheduleMsg(&tsLogger, "Got only %d bytes while expecting %d for command %c", received, - expectedSize, command); - tunerStudioError("ERROR: not enough bytes in stream"); - sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN); - continue; - } + received = sr5ReadData(tsChannel, (uint8_t * ) (tsChannel->scratchBuffer + 1), + incomingPacketSize + CRC_VALUE_SIZE - 1); + int expectedSize = incomingPacketSize + CRC_VALUE_SIZE - 1; + if (received != expectedSize) { + scheduleMsg(&tsLogger, "Got only %d bytes while expecting %d for command %c", received, + expectedSize, command); + tunerStudioError("ERROR: not enough bytes in stream"); + sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN); + return; + } - uint32_t expectedCrc = *(uint32_t*) (tsChannel->scratchBuffer + incomingPacketSize); + uint32_t expectedCrc = *(uint32_t*) (tsChannel->scratchBuffer + incomingPacketSize); - expectedCrc = SWAP_UINT32(expectedCrc); + expectedCrc = SWAP_UINT32(expectedCrc); - uint32_t actualCrc = crc32(tsChannel->scratchBuffer, incomingPacketSize); - if (actualCrc != expectedCrc) { - scheduleMsg(&tsLogger, "TunerStudio: CRC %x %x %x %x", tsChannel->scratchBuffer[incomingPacketSize + 0], - tsChannel->scratchBuffer[incomingPacketSize + 1], tsChannel->scratchBuffer[incomingPacketSize + 2], - tsChannel->scratchBuffer[incomingPacketSize + 3]); + uint32_t actualCrc = crc32(tsChannel->scratchBuffer, incomingPacketSize); + if (actualCrc != expectedCrc) { + scheduleMsg(&tsLogger, "TunerStudio: CRC %x %x %x %x", tsChannel->scratchBuffer[incomingPacketSize + 0], + tsChannel->scratchBuffer[incomingPacketSize + 1], tsChannel->scratchBuffer[incomingPacketSize + 2], + tsChannel->scratchBuffer[incomingPacketSize + 3]); - scheduleMsg(&tsLogger, "TunerStudio: command %c actual CRC %x/expected %x", tsChannel->scratchBuffer[0], - actualCrc, expectedCrc); - tunerStudioError("ERROR: CRC issue"); - sendErrorCode(tsChannel, TS_RESPONSE_CRC_FAILURE); - continue; - } + scheduleMsg(&tsLogger, "TunerStudio: command %c actual CRC %x/expected %x", tsChannel->scratchBuffer[0], + actualCrc, expectedCrc); + tunerStudioError("ERROR: CRC issue"); + sendErrorCode(tsChannel, TS_RESPONSE_CRC_FAILURE); + return; + } - int success = tunerStudioHandleCrcCommand(tsChannel, tsChannel->scratchBuffer, incomingPacketSize); - if (!success) - print("got unexpected TunerStudio command %x:%c\r\n", command, command); + int success = tsInstance.handleCrcCommand(tsChannel, tsChannel->scratchBuffer, incomingPacketSize); + if (!success) + print("got unexpected TunerStudio command %x:%c\r\n", command, command); +} +void runBinaryProtocolLoop(ts_channel_s *tsChannel) +{ + // Until the end of time, process incoming messages. + while(true) { + tsProcessOne(tsChannel); } } @@ -724,8 +729,7 @@ bool handlePlainCommand(ts_channel_s *tsChannel, uint8_t command) { static int transmitted = 0; - -int tunerStudioHandleCrcCommand(ts_channel_s *tsChannel, char *data, int incomingPacketSize) { +int TunerStudioBase::handleCrcCommand(ts_channel_s *tsChannel, char *data, int incomingPacketSize) { ScopePerf perf(PE::TunerStudioHandleCrcCommand); char command = data[0]; diff --git a/firmware/console/binary/tunerstudio.h b/firmware/console/binary/tunerstudio.h index 8480e832ec..85e6afff98 100644 --- a/firmware/console/binary/tunerstudio.h +++ b/firmware/console/binary/tunerstudio.h @@ -36,7 +36,6 @@ extern tunerstudio_counters_s tsState; * handle non CRC wrapped command */ bool handlePlainCommand(ts_channel_s *tsChannel, uint8_t command); -int tunerStudioHandleCrcCommand(ts_channel_s *tsChannel, char *data, int incomingPacketSize); /** * this command is part of protocol initialization @@ -67,28 +66,9 @@ void runBinaryProtocolLoop(ts_channel_s *tsChannel); #endif typedef pre_packed struct - post_packed { - short int offset; - short int count; - } TunerStudioOchRequest; - - - typedef pre_packed struct - post_packed { - short int offset; - short int count; - } TunerStudioWriteChunkRequest; - - typedef pre_packed struct - post_packed { - short int offset; - short int count; - } TunerStudioReadRequest; - - typedef pre_packed struct - post_packed { - short int offset; - unsigned char value; - } TunerStudioWriteValueRequest; +post_packed { + short int offset; + short int count; +} TunerStudioWriteChunkRequest; #endif /* EFI_TUNER_STUDIO */ diff --git a/firmware/console/binary/tunerstudio_impl.h b/firmware/console/binary/tunerstudio_impl.h new file mode 100644 index 0000000000..14459d4d11 --- /dev/null +++ b/firmware/console/binary/tunerstudio_impl.h @@ -0,0 +1,8 @@ +#pragma once + +class ts_channel_s; + +class TunerStudioBase { +public: + int handleCrcCommand(ts_channel_s *tsChannel, char *data, int incomingPacketSize); +}; diff --git a/firmware/console/binary/tunerstudio_io.h b/firmware/console/binary/tunerstudio_io.h index 0abb3d2238..9dcfb09fab 100644 --- a/firmware/console/binary/tunerstudio_io.h +++ b/firmware/console/binary/tunerstudio_io.h @@ -34,6 +34,8 @@ struct ts_channel_s { #if TS_UART_DMA_MODE || PRIMARY_UART_DMA_MODE || TS_UART_MODE UARTDriver *uartp = nullptr; #endif // TS_UART_DMA_MODE + + bool wasReady = false; }; #define CRC_VALUE_SIZE 4