12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- #pragma once
- #include "AP_RCProtocol.h"
- #include "SoftSerial.h"
- #define SUMD_MAX_CHANNELS 32
- #define SUMD_FRAME_MAXLEN 40
- class AP_RCProtocol_SUMD : public AP_RCProtocol_Backend {
- public:
- AP_RCProtocol_SUMD(AP_RCProtocol &_frontend) : AP_RCProtocol_Backend(_frontend) {}
- void process_pulse(uint32_t width_s0, uint32_t width_s1) override;
- void process_byte(uint8_t byte, uint32_t baudrate) override;
- private:
- void _process_byte(uint32_t timestamp_us, uint8_t byte);
- static uint8_t sumd_crc8(uint8_t crc, uint8_t value);
- #pragma pack(push, 1)
- typedef struct {
- uint8_t header;
- uint8_t status;
- uint8_t length;
- uint8_t sumd_data[(SUMD_MAX_CHANNELS+1) * 2];
- uint8_t crc16_high;
- uint8_t crc16_low;
- uint8_t telemetry;
- uint8_t crc8;
- } ReceiverFcPacketHoTT;
- #pragma pack(pop)
- enum SUMD_DECODE_STATE {
- SUMD_DECODE_STATE_UNSYNCED = 0,
- SUMD_DECODE_STATE_GOT_HEADER,
- SUMD_DECODE_STATE_GOT_STATE,
- SUMD_DECODE_STATE_GOT_LEN,
- SUMD_DECODE_STATE_GOT_DATA,
- SUMD_DECODE_STATE_GOT_CRC,
- SUMD_DECODE_STATE_GOT_CRC16_BYTE_1,
- SUMD_DECODE_STATE_GOT_CRC16_BYTE_2
- };
- enum SUMD_DECODE_STATE _decode_state = SUMD_DECODE_STATE_UNSYNCED;
- uint8_t _rxlen;
- ReceiverFcPacketHoTT _rxpacket;
- uint8_t _crc8 = 0x00;
- uint16_t _crc16 = 0x0000;
- bool _sumd = true;
- bool _crcOK = false;
- uint32_t last_packet_us;
- SoftSerial ss{115200, SoftSerial::SERIAL_CONFIG_8N1};
- };
|