TS communication minor fixes (#2847)
* console: noone use this * console: do not stop blinking if TS command executes too long Set and clear flag from the same place Co-authored-by: rusefillc <48498823+rusefillc@users.noreply.github.com>
This commit is contained in:
parent
8d0046b0de
commit
08747d036e
|
@ -99,6 +99,9 @@
|
||||||
|
|
||||||
EXTERN_ENGINE;
|
EXTERN_ENGINE;
|
||||||
|
|
||||||
|
/* 1S */
|
||||||
|
#define TS_COMMUNICATION_TIMEOUT TIME_MS2I(1000)
|
||||||
|
|
||||||
extern persistent_config_container_s persistentState;
|
extern persistent_config_container_s persistentState;
|
||||||
|
|
||||||
#if !defined(EFI_NO_CONFIG_WORKING_COPY)
|
#if !defined(EFI_NO_CONFIG_WORKING_COPY)
|
||||||
|
@ -439,18 +442,18 @@ static bool isKnownCommand(char command) {
|
||||||
|
|
||||||
TunerStudio tsInstance;
|
TunerStudio tsInstance;
|
||||||
|
|
||||||
static void tsProcessOne(TsChannelBase* tsChannel) {
|
static int tsProcessOne(TsChannelBase* tsChannel) {
|
||||||
validateStack("communication", STACK_USAGE_COMMUNICATION, 128);
|
validateStack("communication", STACK_USAGE_COMMUNICATION, 128);
|
||||||
|
|
||||||
if (!tsChannel->isReady()) {
|
if (!tsChannel->isReady()) {
|
||||||
chThdSleepMilliseconds(10);
|
chThdSleepMilliseconds(10);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
tsState.totalCounter++;
|
tsState.totalCounter++;
|
||||||
|
|
||||||
uint8_t firstByte;
|
uint8_t firstByte;
|
||||||
int received = tsChannel->read(&firstByte, 1);
|
int received = tsChannel->readTimeout(&firstByte, 1, TS_COMMUNICATION_TIMEOUT);
|
||||||
#if EFI_SIMULATOR
|
#if EFI_SIMULATOR
|
||||||
logMsg("received %d\r\n", received);
|
logMsg("received %d\r\n", received);
|
||||||
#endif
|
#endif
|
||||||
|
@ -461,19 +464,18 @@ static void tsProcessOne(TsChannelBase* tsChannel) {
|
||||||
// assume there's connection loss and notify the bluetooth init code
|
// assume there's connection loss and notify the bluetooth init code
|
||||||
bluetoothSoftwareDisconnectNotify();
|
bluetoothSoftwareDisconnectNotify();
|
||||||
#endif /* EFI_BLUETOOTH_SETUP */
|
#endif /* EFI_BLUETOOTH_SETUP */
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
onDataArrived();
|
|
||||||
|
|
||||||
if (handlePlainCommand(tsChannel, firstByte)) {
|
if (handlePlainCommand(tsChannel, firstByte)) {
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t secondByte;
|
uint8_t secondByte;
|
||||||
received = tsChannel->read(&secondByte, 1);
|
received = tsChannel->readTimeout(&secondByte, 1, TS_COMMUNICATION_TIMEOUT);
|
||||||
if (received != 1) {
|
if (received != 1) {
|
||||||
tunerStudioError("TS: ERROR: no second byte");
|
tunerStudioError("TS: ERROR: no second byte");
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t incomingPacketSize = firstByte << 8 | secondByte;
|
uint16_t incomingPacketSize = firstByte << 8 | secondByte;
|
||||||
|
@ -482,36 +484,35 @@ static void tsProcessOne(TsChannelBase* tsChannel) {
|
||||||
efiPrintf("TunerStudio: invalid size: %d", incomingPacketSize);
|
efiPrintf("TunerStudio: invalid size: %d", incomingPacketSize);
|
||||||
tunerStudioError("ERROR: CRC header size");
|
tunerStudioError("ERROR: CRC header size");
|
||||||
sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN);
|
sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
received = tsChannel->read((uint8_t* )tsChannel->scratchBuffer, 1);
|
received = tsChannel->readTimeout((uint8_t* )tsChannel->scratchBuffer, 1, TS_COMMUNICATION_TIMEOUT);
|
||||||
if (received != 1) {
|
if (received != 1) {
|
||||||
tunerStudioError("ERROR: did not receive command");
|
tunerStudioError("ERROR: did not receive command");
|
||||||
sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN);
|
sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
char command = tsChannel->scratchBuffer[0];
|
char command = tsChannel->scratchBuffer[0];
|
||||||
if (!isKnownCommand(command)) {
|
if (!isKnownCommand(command)) {
|
||||||
efiPrintf("unexpected command %x", command);
|
efiPrintf("unexpected command %x", command);
|
||||||
sendErrorCode(tsChannel, TS_RESPONSE_UNRECOGNIZED_COMMAND);
|
sendErrorCode(tsChannel, TS_RESPONSE_UNRECOGNIZED_COMMAND);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if EFI_SIMULATOR
|
#if EFI_SIMULATOR
|
||||||
logMsg("command %c\r\n", command);
|
logMsg("command %c\r\n", command);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
received = tsChannel->read((uint8_t*)(tsChannel->scratchBuffer + 1),
|
|
||||||
incomingPacketSize + CRC_VALUE_SIZE - 1);
|
|
||||||
int expectedSize = incomingPacketSize + CRC_VALUE_SIZE - 1;
|
int expectedSize = incomingPacketSize + CRC_VALUE_SIZE - 1;
|
||||||
|
received = tsChannel->readTimeout((uint8_t*)(tsChannel->scratchBuffer + 1), expectedSize, TS_COMMUNICATION_TIMEOUT);
|
||||||
if (received != expectedSize) {
|
if (received != expectedSize) {
|
||||||
efiPrintf("Got only %d bytes while expecting %d for command %c", received,
|
efiPrintf("Got only %d bytes while expecting %d for command %c", received,
|
||||||
expectedSize, command);
|
expectedSize, command);
|
||||||
tunerStudioError("ERROR: not enough bytes in stream");
|
tunerStudioError("ERROR: not enough bytes in stream");
|
||||||
sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN);
|
sendErrorCode(tsChannel, TS_RESPONSE_UNDERRUN);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t expectedCrc = *(uint32_t*) (tsChannel->scratchBuffer + incomingPacketSize);
|
uint32_t expectedCrc = *(uint32_t*) (tsChannel->scratchBuffer + incomingPacketSize);
|
||||||
|
@ -528,14 +529,17 @@ static void tsProcessOne(TsChannelBase* tsChannel) {
|
||||||
actualCrc, expectedCrc);
|
actualCrc, expectedCrc);
|
||||||
tunerStudioError("ERROR: CRC issue");
|
tunerStudioError("ERROR: CRC issue");
|
||||||
sendErrorCode(tsChannel, TS_RESPONSE_CRC_FAILURE);
|
sendErrorCode(tsChannel, TS_RESPONSE_CRC_FAILURE);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int success = tsInstance.handleCrcCommand(tsChannel, tsChannel->scratchBuffer, incomingPacketSize);
|
int success = tsInstance.handleCrcCommand(tsChannel, tsChannel->scratchBuffer, incomingPacketSize);
|
||||||
|
|
||||||
if (!success) {
|
if (!success) {
|
||||||
efiPrintf("got unexpected TunerStudio command %x:%c", command, command);
|
efiPrintf("got unexpected TunerStudio command %x:%c", command, command);
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TunerstudioThread::ThreadTask() {
|
void TunerstudioThread::ThreadTask() {
|
||||||
|
@ -548,7 +552,10 @@ void TunerstudioThread::ThreadTask() {
|
||||||
|
|
||||||
// Until the end of time, process incoming messages.
|
// Until the end of time, process incoming messages.
|
||||||
while(true) {
|
while(true) {
|
||||||
tsProcessOne(channel);
|
if (tsProcessOne(channel) == 0)
|
||||||
|
onDataArrived(true);
|
||||||
|
else
|
||||||
|
onDataArrived(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -49,8 +49,8 @@ EXTERN_ENGINE;
|
||||||
|
|
||||||
bool consoleByteArrived = false;
|
bool consoleByteArrived = false;
|
||||||
|
|
||||||
void onDataArrived(void) {
|
void onDataArrived(bool valid) {
|
||||||
consoleByteArrived = true;
|
consoleByteArrived = valid;
|
||||||
}
|
}
|
||||||
|
|
||||||
CommandHandler console_line_callback;
|
CommandHandler console_line_callback;
|
||||||
|
|
|
@ -21,4 +21,4 @@ typedef void (*CommandHandler)(char *);
|
||||||
|
|
||||||
void consoleOutputBuffer(const uint8_t *buf, int size);
|
void consoleOutputBuffer(const uint8_t *buf, int size);
|
||||||
void startConsole(CommandHandler console_line_callback_p);
|
void startConsole(CommandHandler console_line_callback_p);
|
||||||
void onDataArrived(void);
|
void onDataArrived(bool valid);
|
||||||
|
|
|
@ -404,7 +404,6 @@ extern int totalLoggedBytes;
|
||||||
offTimeMs = 50;
|
offTimeMs = 50;
|
||||||
onTimeMs = 450;
|
onTimeMs = 450;
|
||||||
} else if (consoleByteArrived) {
|
} else if (consoleByteArrived) {
|
||||||
consoleByteArrived = false;
|
|
||||||
offTimeMs = 100;
|
offTimeMs = 100;
|
||||||
onTimeMs = 33;
|
onTimeMs = 33;
|
||||||
#if EFI_INTERNAL_FLASH
|
#if EFI_INTERNAL_FLASH
|
||||||
|
|
Loading…
Reference in New Issue