rusefi/firmware/console/binary_log/binary_logging.cpp

140 lines
3.1 KiB
C++
Raw Normal View History

2020-06-14 10:07:06 -07:00
/**
* See also BinarySensorLog.java
* See also mlq_file_format.txt
*/
#include "pch.h"
#include "binary_logging.h"
#include "log_field.h"
#include "buffered_writer.h"
2022-09-12 17:38:59 -07:00
#include "tunerstudio.h"
2020-10-08 14:50:43 -07:00
2022-12-17 11:58:10 -08:00
#if EFI_FILE_LOGGING
2020-10-08 14:50:43 -07:00
#define TIME_PRECISION 1000
// floating number of seconds with millisecond precision
2020-10-08 14:58:58 -07:00
static scaled_channel<uint32_t, TIME_PRECISION> packedTime;
2020-10-08 14:50:43 -07:00
// The list of logged fields lives in a separate file so it can eventually be tool-generated
#include "log_fields_generated.h"
static constexpr uint16_t computeFieldsRecordLength() {
uint16_t recLength = 0;
for (size_t i = 0; i < efi::size(fields); i++) {
recLength += fields[i].getSize();
}
return recLength;
}
2022-09-12 17:38:59 -07:00
static uint64_t binaryLogCount = 0;
extern bool main_loop_started;
2022-10-11 20:27:15 -07:00
void writeSdLogLine(Writer& bufferedWriter) {
2022-09-12 17:38:59 -07:00
if (!main_loop_started)
return;
if (binaryLogCount == 0) {
2022-10-11 20:27:15 -07:00
writeFileHeader(bufferedWriter);
2022-09-12 17:38:59 -07:00
} else {
updateTunerStudioState();
writeBlock(bufferedWriter);
2022-09-12 17:38:59 -07:00
}
binaryLogCount++;
}
#endif /* EFI_FILE_LOGGING */
static constexpr uint16_t recordLength = computeFieldsRecordLength();
2022-09-12 17:38:59 -07:00
void writeFileHeader(Writer& outBuffer) {
char buffer[MLQ_HEADER_SIZE];
// File format: MLVLG\0
strncpy(buffer, "MLVLG", 6);
// Format version = 01
buffer[6] = 0;
buffer[7] = 1;
// Timestamp
buffer[8] = 0;
buffer[9] = 0;
buffer[10] = 0;
buffer[11] = 0;
// Info data start
buffer[12] = 0;
buffer[13] = 0;
size_t headerSize = MLQ_HEADER_SIZE + efi::size(fields) * 55;
// Data begin index: begins immediately after the header
buffer[14] = 0;
buffer[15] = 0;
buffer[16] = (headerSize >> 8) & 0xFF;
buffer[17] = headerSize & 0xFF;
// Record length - length of a single data record: sum size of all fields
buffer[18] = recordLength >> 8;
buffer[19] = recordLength & 0xFF;
// Number of logger fields
int fieldsCount = efi::size(fields);
buffer[20] = fieldsCount >> 8;
buffer[21] = fieldsCount;
outBuffer.write(buffer, MLQ_HEADER_SIZE);
// Write the actual logger fields, offset 22
for (size_t i = 0; i < efi::size(fields); i++) {
fields[i].writeHeader(outBuffer);
}
}
static uint8_t blockRollCounter = 0;
2022-09-12 17:56:57 -07:00
//static efitimeus_t prevSdCardLineTime = 0;
void writeBlock(Writer& outBuffer) {
static char buffer[16];
// Offset 0 = Block type, standard data block in this case
buffer[0] = 0;
// Offset 1 = rolling counter sequence number
buffer[1] = blockRollCounter++;
// Offset 2, size 2 = Timestamp at 10us resolution
2022-09-12 17:56:57 -07:00
efitimeus_t nowUs = getTimeNowUs();
uint16_t timestamp = nowUs / 10;
buffer[2] = timestamp >> 8;
buffer[3] = timestamp & 0xFF;
outBuffer.write(buffer, 4);
2022-09-12 17:56:57 -07:00
// todo: add a log field for SD card period
// prevSdCardLineTime = nowUs;
packedTime = getTimeNowMs() * 1.0 / TIME_PRECISION;
2020-10-08 14:50:43 -07:00
2022-10-11 20:31:47 -07:00
uint8_t sum = 0;
for (size_t fieldIndex = 0; fieldIndex < efi::size(fields); fieldIndex++) {
size_t entrySize = fields[fieldIndex].writeData(buffer);
2022-10-11 20:31:47 -07:00
for (size_t byteIndex = 0; byteIndex < entrySize; byteIndex++) {
// "CRC" at the end is just the sum of all bytes
sum += buffer[byteIndex];
2022-10-11 20:31:47 -07:00
}
outBuffer.write(buffer, entrySize);
}
buffer[0] = sum;
// 1 byte checksum footer
outBuffer.write(buffer, 1);
}