Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Develop to Master #2

Merged
merged 18 commits into from
Aug 18, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
18 commits
Select commit Hold shift + click to select a range
e819403
Небольшие изменения
Jun 24, 2022
b689b98
Добавил базовую поддержку приёма данных через UDP
Jun 24, 2022
5ec6e1b
Приём данных через UDP полностью работает
Jun 24, 2022
82ba1ac
Переделаны очереди приёма и обработки данных из последовательного порта
Jun 26, 2022
dd4ed03
Исправил кодировку
Jun 26, 2022
ccfb808
Отказался от очередей, переписал парсе CAN-пакетов
Jun 27, 2022
adf1a12
Закончил с парсером
Jun 28, 2022
912cacd
Переделал кадр отрисовки графика
Jun 29, 2022
c55429c
Данные UDP обрабатываются пакетно
Jun 29, 2022
4c0929f
Реализованы приём и отправка пакетов через Wi-Fi
Jun 30, 2022
a1a431c
Переделал фоновый поток на события
Jul 3, 2022
2b2c0ce
Переделал фоновый поток на события
Jul 3, 2022
5dfd461
Исправил очистку буфера приёма данных при "аварийном" отключении COM-…
KruFFT Jul 9, 2022
fdcd48c
Полностью переделан процесс отображения данных в таблицу
KruFFT Jul 17, 2022
b6ed1c3
Исправил кодировку символов файла
KruFFT Jul 17, 2022
a453d2d
Исправлено вычисление размера отправляемого CAN-пакета
KruFFT Jul 17, 2022
ded972d
Переход на wxWidgets 3.2.0
KruFFT Aug 18, 2022
98a372e
Update README.md
KruFFT Aug 18, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Реализованы приём и отправка пакетов через Wi-Fi
  • Loading branch information
KruFFT authored and KruFFT committed Jun 30, 2022
commit 4c0929ff4417d9e89e805afa0c5dde0546aea89f
13 changes: 6 additions & 7 deletions wxCAN Sniffer/CANParser.cpp
Original file line number Diff line number Diff line change
@@ -1,21 +1,20 @@
#include "CANParser.h"

// Собрать CAN-пакет из входящего потока байтов (контроль границ вне этого кода, должно быть не менее 17 байт данных)
bool CANParser::Parse(uint8_t** bufferHead, CANFrame& frame)
bool CANParser::Parse(uint8_t** bufferHead, VisualCANFrame& frame)
{
// ниже "магия" указателей на указатели :)
// поиск сигнатуры в потоке байтов
if (*(uint32_t*)*bufferHead == SIG_DWORD)
{
*bufferHead += 4;
// сборка пакета
frame.ID = *(uint32_t*)*bufferHead;
frame.Frame.ID = *(uint32_t*)*bufferHead;
*bufferHead += 4;
frame.Length = *(*bufferHead)++;
if (frame.Length <= 8)
frame.Frame.Length = *(*bufferHead)++;
if (frame.Frame.Length <= 8)
{
for (size_t iData = 0; iData < frame.Length; iData++)
frame.Data[iData] = *(*bufferHead)++;
for (size_t iData = 0; iData < frame.Frame.Length; iData++)
frame.Frame.Data[iData] = *(*bufferHead)++;

return true;
}
Expand Down
2 changes: 1 addition & 1 deletion wxCAN Sniffer/CANParser.h
Original file line number Diff line number Diff line change
Expand Up @@ -6,5 +6,5 @@ class CANParser
{
public:
CANParser() = default;
static bool Parse(uint8_t** bufferHead, CANFrame& frame);
static bool Parse(uint8_t** bufferHead, VisualCANFrame& frame);
};
28 changes: 16 additions & 12 deletions wxCAN Sniffer/Common.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,30 +24,42 @@ using namespace std;
#define SIG_BYTE_3 0x55
#define SIG_DWORD (uint32_t)(SIG_BYTE_3 << 24 | SIG_BYTE_2 << 16 | SIG_BYTE_1 << 8 | SIG_BYTE_0)

// CAN-пакет данных
// CAN-пакет для отправки данных
#pragma pack (push, 1)
struct CANFrame
{
public:
uint32_t ID; // идентификатор пакета
uint8_t Length; // длина пакета
uint8_t Data[8]; // массив данных пакета, до 8 байт
};
#pragma pack(pop)

uint8_t Tick[8]; // счётчик тактов появления пакета, используется для выделения цветом в таблице
// CAN-пакет для отображения в таблице
#pragma pack (push, 1)
struct VisualCANFrame
{
public:
CANFrame Frame = { 0 }; // пакет с данными
uint8_t Tick[8]; // счётчик тактов появления пакета, используется для выделения цветом в таблице

// оператор сравнения CAN-пакета необходим для сортировки
bool operator < (const CANFrame& frame) const
bool operator < (const VisualCANFrame& frame) const
{
return (ID < frame.ID);
return (Frame.ID < frame.Frame.ID);
}
};
#pragma pack(pop)

// CAN-пакет для отправки данных
#pragma pack (push, 1)
struct SendCANFrame
{
public:
uint32_t Signature = SIG_DWORD;
CANFrame Frame = { 0 }; // пакет для отправки
};
#pragma pack(pop)

// Описание log-файла
struct LogFile
Expand All @@ -56,11 +68,3 @@ struct LogFile
uint32_t ID; // идентификатор пакета
wxFFile* File; // хэндл ассоциированного файла
};

// Описание одного байтового буфера
struct Buffer
{
public:
uint8_t* Pointer;
size_t Size;
};
Loading