rusefi/firmware/console/binary/tunerstudio_io.h

124 lines
3.3 KiB
C
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file tunerstudio_io.h
2020-05-25 09:55:26 -07:00
* @file TS protocol commands and methods are here
2015-07-10 06:01:56 -07:00
*
* @date Mar 8, 2015
2020-01-13 18:57:43 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
2015-07-10 06:01:56 -07:00
*/
2020-04-01 16:00:56 -07:00
#pragma once
2018-09-16 19:25:17 -07:00
#include "global.h"
2015-07-10 06:01:56 -07:00
2021-07-26 06:08:05 -07:00
#if (!defined(TS_NO_PRIMARY) && (defined(TS_PRIMARY_UART) || defined(TS_PRIMARY_SERIAL)))
#define HAS_PRIMARY true
#else
#define HAS_PRIMARY false
#endif
#if (!defined(TS_NO_SECONDARY) && (defined(TS_SECONDARY_UART) || defined(TS_SECONDARY_SERIAL)))
#define HAS_SECONDARY true
#else
#define HAS_SECONDARY false
#endif
#if EFI_USB_SERIAL
2015-07-10 06:01:56 -07:00
#include "usbconsole.h"
#endif // EFI_USB_SERIAL
2020-09-09 11:35:01 -07:00
#if EFI_PROD_CODE
2015-07-10 06:01:56 -07:00
#include "pin_repository.h"
#endif
typedef enum {
TS_PLAIN = 0,
TS_CRC = 1
} ts_response_format_e;
class TsChannelBase {
public:
// Virtual functions - implement these for your underlying transport
virtual void write(const uint8_t* buffer, size_t size) = 0;
virtual size_t readTimeout(uint8_t* buffer, size_t size, int timeout) = 0;
// These functions are optional to implement, not all channels need them
virtual void flush() { }
virtual bool isConfigured() const { return true; }
virtual bool isReady() const { return true; }
virtual void stop() { }
// Base functions that use the above virtual implementation
size_t read(uint8_t* buffer, size_t size);
#ifdef TS_CAN_DEVICE
virtual // CAN device needs this function to be virtual for small-packet optimization
#endif
void writeCrcPacket(uint8_t responseCode, const uint8_t* buf, size_t size);
void sendResponse(ts_response_format_e mode, const uint8_t * buffer, int size);
2015-08-22 10:01:35 -07:00
/**
2017-06-20 21:16:19 -07:00
* See 'blockingFactor' in rusefi.ini
2015-08-22 10:01:35 -07:00
*/
char scratchBuffer[BLOCKING_FACTOR + 30];
2020-06-21 13:37:33 -07:00
private:
void writeCrcPacketSmall(uint8_t responseCode, const uint8_t* buf, size_t size);
void writeCrcPacketLarge(uint8_t responseCode, const uint8_t* buf, size_t size);
2020-06-21 13:37:33 -07:00
};
2015-07-10 06:01:56 -07:00
// This class represents a channel for a physical async serial poart
class SerialTsChannelBase : public TsChannelBase {
public:
// 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;
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override;
private:
SerialDriver* const m_driver;
};
#endif // HAL_USE_SERIAL
#if HAL_USE_UART
// This class implements a ChibiOS UART Driver
class UartTsChannel : public SerialTsChannelBase {
public:
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;
protected:
UARTDriver* const m_driver;
UARTConfig m_config;
};
#endif // HAL_USE_UART
2015-07-10 06:01:56 -07:00
#define CRC_VALUE_SIZE 4
// todo: double-check this
#define CRC_WRAPPING_SIZE (CRC_VALUE_SIZE + 3)
2017-05-23 10:10:43 -07:00
// that's 1 second
2019-01-28 17:00:17 -08:00
#define BINARY_IO_TIMEOUT TIME_MS2I(1000)
2015-07-10 06:01:56 -07:00
2017-05-23 11:54:40 -07:00
// that's 1 second
2019-01-28 17:00:17 -08:00
#define SR5_READ_TIMEOUT TIME_MS2I(1000)
void startSerialChannels();
SerialTsChannelBase* getBluetoothChannel();
void sendOkResponse(TsChannelBase *tsChannel, ts_response_format_e mode);