rusefi-full/firmware/console/binary/tunerstudio_io.h

105 lines
3.0 KiB
C
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file tunerstudio_io.h
*
* @date Mar 8, 2015
2017-01-03 03:05:22 -08:00
* @author Andrey Belomutskiy, (c) 2012-2017
2015-07-10 06:01:56 -07:00
*/
#ifndef CONSOLE_TUNERSTUDIO_TUNERSTUDIO_IO_H_
#define CONSOLE_TUNERSTUDIO_TUNERSTUDIO_IO_H_
#include "main.h"
#if EFI_PROD_CODE
#include "usbconsole.h"
#include "pin_repository.h"
#endif
// that's hex for "~\n", see
#define BINARY_SWITCH_TAG 0x7e0a
#define SWITCH_TO_BINARY_COMMAND "~"
#define PROTOCOL "001"
2018-01-24 12:08:10 -08:00
#define TS_SIGNATURE "rusEFI v1.04"
2015-07-10 06:01:56 -07:00
#define TS_RESPONSE_OK 0x00
#define TS_RESPONSE_BURN_OK 0x04
#define TS_RESPONSE_COMMAND_OK 0x07
#define TS_RESPONSE_UNDERRUN 0x80
#define TS_RESPONSE_CRC_FAILURE 0x82
typedef enum {
TS_PLAIN = 0,
TS_CRC = 1
} ts_response_format_e;
typedef struct {
BaseChannel * channel;
2017-05-23 10:10:43 -07:00
uint8_t writeBuffer[7]; // size(2 bytes) + response(1 byte) + crc32 (4 bytes)
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
*/
2016-12-29 18:02:50 -08:00
char crcReadBuffer[BLOCKING_FACTOR + 30];
2015-07-10 06:01:56 -07:00
} ts_channel_s;
2017-05-23 10:10:43 -07:00
// See uart_dma_s
#define TS_FIFO_BUFFER_SIZE (BLOCKING_FACTOR + 30)
// This must be a power of 2!
#define TS_DMA_BUFFER_SIZE 32
// struct needed for async DMA transfer mode (see TS_UART_DMA_MODE)
typedef struct {
// circular DMA buffer
uint8_t dmaBuffer[TS_DMA_BUFFER_SIZE];
// current read position for the DMA buffer
volatile int readPos;
// secondary FIFO buffer for async. transfer
uint8_t buffer[TS_FIFO_BUFFER_SIZE];
// input FIFO Rx queue
input_queue_t fifoRxQueue;
} uart_dma_s;
2016-12-22 11:02:38 -08:00
#define TS_HELLO_COMMAND_DEPRECATED 'H' // 0x48
2017-05-26 20:02:13 -07:00
#define TS_HELLO_COMMAND 'S' // 0x53 queryCommand
2016-12-22 11:02:38 -08:00
#define TS_TEST_COMMAND 't' // 0x74
2017-07-26 19:52:13 -07:00
#define TS_TOOTH_COMMAND 'L' // 0x4C
2016-12-22 11:02:38 -08:00
#define TS_LEGACY_HELLO_COMMAND 'Q' // 0x51
2017-05-26 20:02:13 -07:00
#define TS_OUTPUT_COMMAND 'O' // 0x4F ochGetCommand
2016-12-22 11:02:38 -08:00
#define TS_READ_COMMAND 'R' // 0x52
#define TS_PAGE_COMMAND 'P' // 0x50
#define TS_COMMAND_F 'F' // 0x46
#define TS_EXECUTE 'E' // 0x45
#define TS_GET_TEXT 'G' // 0x47
2016-05-06 20:02:23 -07:00
#define TS_GET_FILE_RANGE '2'
2017-05-26 20:02:13 -07:00
#define TS_GET_FIRMWARE_VERSION 'V' // versionInfo
2015-07-10 06:01:56 -07:00
2017-05-26 20:02:13 -07:00
#define TS_SINGLE_WRITE_COMMAND 'W' // 0x57 pageValueWrite
#define TS_CHUNK_WRITE_COMMAND 'C' // 0x43 pageChunkWrite
#define TS_BURN_COMMAND 'B' // 0x42 burnCommand
2016-12-22 11:02:38 -08:00
#define TS_IO_TEST_COMMAND 'w' // 0x77
2015-07-10 06:01:56 -07:00
2016-12-22 11:02:38 -08:00
#define TS_CRC_CHECK_COMMAND 'k' // 0x6B
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
void startTsPort(ts_channel_s *tsChannel);
bool stopTsPort(ts_channel_s *tsChannel);
2017-05-23 10:10:43 -07:00
// that's 1 second
#define BINARY_IO_TIMEOUT MS2ST(1000)
2015-07-10 06:01:56 -07:00
2017-05-23 11:54:40 -07:00
// that's 1 second
#define SR5_READ_TIMEOUT MS2ST(1000)
void sr5WriteData(ts_channel_s *tsChannel, const uint8_t * buffer, int size);
void sr5WriteCrcPacket(ts_channel_s *tsChannel, const uint8_t responseCode, const void *buf, const uint16_t size);
void sr5SendResponse(ts_channel_s *tsChannel, ts_response_format_e mode, const uint8_t * buffer, int size);
int sr5ReadData(ts_channel_s *tsChannel, uint8_t * buffer, int size);
2017-05-30 11:08:12 -07:00
int sr5ReadDataTimeout(ts_channel_s *tsChannel, uint8_t * buffer, int size, int timeout);
2017-05-23 12:53:31 -07:00
bool sr5IsReady(bool isConsoleRedirect);
2015-07-10 06:01:56 -07:00
#endif /* CONSOLE_TUNERSTUDIO_TUNERSTUDIO_IO_H_ */