USB uses its own channel, add implementations for serial channels (#2472)

* USB uses its own channel

* revise channels

* put serial ports in their own file

* h7 uart incompatible for now

* guard for sim
This commit is contained in:
Matthew Kennedy 2021-03-19 14:05:04 -07:00 committed by GitHub
parent 650d148008
commit 599a9b0183
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 126 additions and 56 deletions

View File

@ -346,7 +346,6 @@
#undef TS_SERIAL_DEVICE #undef TS_SERIAL_DEVICE
#undef TS_UART_MODE #undef TS_UART_MODE
#define EFI_CONSOLE_SERIAL_DEVICE (&SD1) #define EFI_CONSOLE_SERIAL_DEVICE (&SD1)
//#define EFI_CONSOLE_USB_DEVICE SDU1
#define EFI_UART_ECHO_TEST_MODE TRUE #define EFI_UART_ECHO_TEST_MODE TRUE
// USART3 is Alternate Function 7, UART4 is AF8 // USART3 is Alternate Function 7, UART4 is AF8

View File

@ -1,5 +1,6 @@
TUNERSTUDIO_SRC_CPP = $(PROJECT_DIR)/console/binary/tunerstudio_io.cpp \ TUNERSTUDIO_SRC_CPP = $(PROJECT_DIR)/console/binary/tunerstudio_io.cpp \
$(PROJECT_DIR)/console/binary/tunerstudio_io_serial.cpp \
$(PROJECT_DIR)/console/binary/ts_can_channel.cpp \ $(PROJECT_DIR)/console/binary/ts_can_channel.cpp \
$(PROJECT_DIR)/console/binary/tunerstudio.cpp \ $(PROJECT_DIR)/console/binary/tunerstudio.cpp \
$(PROJECT_DIR)/console/binary/tunerstudio_commands.cpp \ $(PROJECT_DIR)/console/binary/tunerstudio_commands.cpp \

View File

@ -277,37 +277,3 @@ bool ts_channel_s::isConfigured() const {
#endif #endif
this->channel; this->channel;
} }
bool ts_channel_s::isReady() const {
#if EFI_USB_SERIAL
if (isUsbSerial(this->channel)) {
// TS uses USB when console uses serial
return is_usb_serial_ready();
}
#endif /* EFI_USB_SERIAL */
return true;
}
#if EFI_PROD_CODE || EFI_SIMULATOR
void BaseChannelTsChannel::write(const uint8_t* buffer, size_t size) {
chnWriteTimeout(m_channel, buffer, size, BINARY_IO_TIMEOUT);
}
size_t BaseChannelTsChannel::readTimeout(uint8_t* buffer, size_t size, int timeout) {
return chnReadTimeout(m_channel, buffer, size, timeout);
}
void BaseChannelTsChannel::flush() {
// nop for this channel, writes automatically flush
}
bool BaseChannelTsChannel::isReady() const {
#if EFI_USB_SERIAL
if (isUsbSerial(m_channel)) {
// TS uses USB when console uses serial
return is_usb_serial_ready();
}
#endif /* EFI_USB_SERIAL */
return true;
}
#endif // EFI_PROD_CODE || EFI_SIMULATOR

View File

@ -62,7 +62,6 @@ struct BaseChannel;
struct ts_channel_s : public TsChannelBase { struct ts_channel_s : public TsChannelBase {
void write(const uint8_t* buffer, size_t size) override; void write(const uint8_t* buffer, size_t size) override;
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override; size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override;
bool isReady() const override;
bool isConfigured() const override; bool isConfigured() const override;
BaseChannel * channel = nullptr; BaseChannel * channel = nullptr;
@ -72,18 +71,46 @@ struct ts_channel_s : public TsChannelBase {
#endif // TS_UART_DMA_MODE #endif // TS_UART_DMA_MODE
}; };
class BaseChannelTsChannel : public TsChannelBase { // This class represents a channel for a physical async serial poart
class SerialTsChannelBase : public TsChannelBase {
public: public:
BaseChannelTsChannel(BaseChannel* channel) : m_channel(channel) { } // Open the serial port with the specified baud rate
virtual void start(uint32_t baud) = 0;
};
#if HAL_USE_SERIAL
// This class implements a ChibiOS Serial Driver
class SerialTsChannel : public SerialTsChannelBase {
public:
SerialTsChannel(SerialDriver& driver) : m_driver(&driver) { }
void start(uint32_t baud) override;
void stop() override;
void write(const uint8_t* buffer, size_t size) override; void write(const uint8_t* buffer, size_t size) override;
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override; size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override;
void flush() override;
bool isReady() const override;
private: private:
BaseChannel* const m_channel; SerialDriver* const m_driver;
}; };
#endif // HAL_USE_SERIAL
#if HAL_USE_UART
// This class implements a ChibiOS UART Driver
class UartTsChannel : public SerialTsChannelBase {
UartTsChannel(UARTDriver& driver) : m_driver(&driver) { }
void start(uint32_t baud) override;
void stop() override;
void write(const uint8_t* buffer, size_t size) override;
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override;
private:
UARTDriver* const m_driver;
UARTConfig m_config;
};
#endif // HAL_USE_UART
#define CRC_VALUE_SIZE 4 #define CRC_VALUE_SIZE 4
// todo: double-check this // todo: double-check this

View File

@ -0,0 +1,66 @@
/**
* Implementation for hardware-serial TunerStudio ports
*/
#include "tunerstudio_io.h"
#if HAL_USE_SERIAL
void SerialTsChannel::start(uint32_t baud) {
SerialConfig cfg = {
#if EFI_PROD_CODE
.speed = baud,
.cr1 = 0,
.cr2 = USART_CR2_STOP1_BITS | USART_CR2_LINEN,
.cr3 = 0
#endif // EFI_PROD_CODE
};
sdStart(m_driver, &cfg);
}
void SerialTsChannel::stop() {
sdStop(m_driver);
}
void SerialTsChannel::write(const uint8_t* buffer, size_t size) {
chnWriteTimeout(m_driver, buffer, size, BINARY_IO_TIMEOUT);
}
size_t SerialTsChannel::readTimeout(uint8_t* buffer, size_t size, int timeout) {
return chnReadTimeout(m_driver, buffer, size, timeout);
}
#endif // HAL_USE_SERIAL
#if HAL_USE_UART
void UartTsChannel::start(uint32_t baud) {
m_config = {
.txend1_cb = NULL,
.txend2_cb = NULL,
.rxend_cb = NULL,
.rxchar_cb = NULL,
.rxerr_cb = NULL,
.timeout_cb = NULL,
.speed = baud,
.cr1 = 0,
.cr2 = 0/*USART_CR2_STOP1_BITS*/ | USART_CR2_LINEN,
.cr3 = 0,
.rxhalf_cb = NULL
};
uartStart(m_driver, &m_config);
}
void UartTsChannel::stop() {
uartStop(m_driver);
}
void UartTsChannel::write(const uint8_t* buffer, size_t size) {
uartSendTimeout(m_driver, &size, buffer, BINARY_IO_TIMEOUT);
}
size_t UartTsChannel::readTimeout(uint8_t* buffer, size_t size, int timeout) {
uartReceiveTimeout(m_driver, &size, buffer, timeout);
return size;
}
#endif // HAL_USE_UART

View File

@ -160,17 +160,6 @@ ts_channel_s primaryChannel;
#if EFI_PROD_CODE || EFI_EGT #if EFI_PROD_CODE || EFI_EGT
#if HAL_USE_SERIAL_USB
extern SerialUSBDriver EFI_CONSOLE_USB_DEVICE;
#endif /* HAL_USE_SERIAL_USB */
bool isUsbSerial(BaseChannel * channel) {
#if HAL_USE_SERIAL_USB
return channel == (BaseChannel *) &EFI_CONSOLE_USB_DEVICE;
#else
return false;
#endif /* EFI_CONSOLE_USB_DEVICE */
}
BaseChannel * getConsoleChannel(void) { BaseChannel * getConsoleChannel(void) {
#if PRIMARY_UART_DMA_MODE #if PRIMARY_UART_DMA_MODE
if (primaryChannel.uartp != nullptr) { if (primaryChannel.uartp != nullptr) {

View File

@ -28,8 +28,6 @@ void onDataArrived(void);
#if EFI_PROD_CODE || EFI_SIMULATOR || EFI_EGT #if EFI_PROD_CODE || EFI_SIMULATOR || EFI_EGT
bool isCommandLineConsoleReady(void); bool isCommandLineConsoleReady(void);
bool isUsbSerial(BaseChannel * channel);
BaseChannel * getConsoleChannel(void); BaseChannel * getConsoleChannel(void);
#else #else

View File

@ -11,7 +11,31 @@
static_assert(SERIAL_USB_BUFFERS_SIZE >= BLOCKING_FACTOR + 10); static_assert(SERIAL_USB_BUFFERS_SIZE >= BLOCKING_FACTOR + 10);
extern SerialUSBDriver EFI_CONSOLE_USB_DEVICE; extern SerialUSBDriver EFI_CONSOLE_USB_DEVICE;
static BaseChannelTsChannel usbChannel((BaseChannel*)&EFI_CONSOLE_USB_DEVICE);
class UsbChannel : public TsChannelBase {
public:
UsbChannel(SerialUSBDriver& driver)
: m_channel(reinterpret_cast<BaseChannel*>(&driver))
{
}
bool isReady() const override {
return is_usb_serial_ready();
}
void write(const uint8_t* buffer, size_t size) override {
chnWriteTimeout(m_channel, buffer, size, BINARY_IO_TIMEOUT);
}
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override {
return chnReadTimeout(m_channel, buffer, size, timeout);
}
private:
BaseChannel* const m_channel;
};
static UsbChannel usbChannel(EFI_CONSOLE_USB_DEVICE);
struct UsbThread : public TunerstudioThread { struct UsbThread : public TunerstudioThread {
UsbThread() : TunerstudioThread("USB Console") { } UsbThread() : TunerstudioThread("USB Console") { }

View File

@ -123,7 +123,7 @@
* @brief Enables the UART subsystem. * @brief Enables the UART subsystem.
*/ */
#if !defined(HAL_USE_UART) || defined(__DOXYGEN__) #if !defined(HAL_USE_UART) || defined(__DOXYGEN__)
#define HAL_USE_UART TRUE #define HAL_USE_UART FALSE
#endif #endif
/** /**