DShotRMT/DShotRMT.h

127 lines
3.9 KiB
C
Raw Normal View History

2021-07-04 02:01:26 +01:00
//
// Name: DShotRMT.h
2021-07-04 02:01:26 +01:00
// Created: 20.03.2021 00:49:15
// Author: derdoktor667
//
2021-06-29 19:05:20 +01:00
#ifndef _DSHOTRMT_h
#define _DSHOTRMT_h
2021-06-29 19:05:20 +01:00
#include <Arduino.h>
2022-11-26 12:52:46 +00:00
// The RMT (Remote Control) module library is used for generating the DShot signal.
2021-06-29 19:05:20 +01:00
#include <driver/rmt.h>
// Defines the library version
constexpr auto DSHOT_LIB_VERSION = "0.2.4";
// Constants related to the DShot protocol
2023-03-26 16:58:24 +01:00
constexpr auto DSHOT_CLK_DIVIDER = 8; // Slow down RMT clock to 0.1 microseconds / 100 nanoseconds per cycle
constexpr auto DSHOT_PACKET_LENGTH = 17; // Last pack is the pause
2021-06-29 19:05:20 +01:00
constexpr auto DSHOT_THROTTLE_MIN = 48;
constexpr auto DSHOT_THROTTLE_MAX = 2047;
constexpr auto DSHOT_NULL_PACKET = 0b0000000000000000;
constexpr auto DSHOT_PAUSE = 21; // 21-bit is recommended
2021-06-29 19:05:20 +01:00
constexpr auto DSHOT_PAUSE_BIT = 16;
2021-07-17 05:40:21 +01:00
constexpr auto F_CPU_RMT = APB_CLK_FREQ;
2021-06-29 19:05:20 +01:00
constexpr auto RMT_CYCLES_PER_SEC = (F_CPU_RMT / DSHOT_CLK_DIVIDER);
constexpr auto RMT_CYCLES_PER_ESP_CYCLE = (F_CPU / RMT_CYCLES_PER_SEC);
// Enumeration for the DShot mode
2022-11-25 15:08:58 +00:00
typedef enum dshot_mode_e
{
2023-03-24 12:44:49 +00:00
DSHOT_OFF,
DSHOT150,
DSHOT300,
DSHOT600,
DSHOT1200
2021-06-29 19:05:20 +01:00
} dshot_mode_t;
// Array of human-readable DShot mode names
2023-03-24 12:44:49 +00:00
static const char *const dshot_mode_name[] = {
"DSHOT_OFF",
"DSHOT150",
"DSHOT300",
"DSHOT600",
"DSHOT1200"};
2021-06-29 19:05:20 +01:00
// Enumeration for telemetric request
2022-11-25 15:08:58 +00:00
typedef enum telemetric_request_e
{
2023-03-24 12:44:49 +00:00
NO_TELEMETRIC,
ENABLE_TELEMETRIC,
2021-06-29 19:05:20 +01:00
} telemetric_request_t;
// Structure for DShot packets
2022-11-25 15:08:58 +00:00
typedef struct dshot_packet_s
{
2023-03-24 12:44:49 +00:00
uint16_t throttle_value : 11;
telemetric_request_t telemetric_request : 1;
uint16_t checksum : 4;
2021-06-29 19:05:20 +01:00
} dshot_packet_t;
// Structure for eRPM packets
2022-11-25 15:08:58 +00:00
typedef struct eRPM_packet_s
{
2023-03-24 12:44:49 +00:00
uint16_t eRPM_data : 12;
uint8_t checksum : 4;
2021-08-03 22:22:06 +01:00
} eRPM_packet_t;
// Structure for all settings for the DShot mode
2022-11-25 15:08:58 +00:00
typedef struct dshot_config_s
{
2023-03-24 12:44:49 +00:00
dshot_mode_t mode;
String name_str;
bool is_bidirectional;
2023-03-24 12:44:49 +00:00
gpio_num_t gpio_num;
uint8_t pin_num;
rmt_channel_t rmt_channel;
uint8_t mem_block_num;
uint16_t ticks_per_bit;
uint8_t clk_div;
uint16_t ticks_zero_high;
uint16_t ticks_zero_low;
uint16_t ticks_one_high;
uint16_t ticks_one_low;
2021-06-29 19:05:20 +01:00
} dshot_config_t;
// The main DShotRMT class
2022-11-25 15:08:58 +00:00
class DShotRMT
{
2023-03-24 12:44:49 +00:00
public:
// Constructor for the DShotRMT class
DShotRMT(gpio_num_t gpio, rmt_channel_t rmtChannel);
DShotRMT(uint8_t pin, uint8_t channel);
// Destructor for the DShotRMT class
2023-03-24 12:44:49 +00:00
~DShotRMT();
// Copy constructor for the DShotRMT class
2023-03-24 12:44:49 +00:00
DShotRMT(DShotRMT const &);
2021-06-29 19:05:20 +01:00
// The begin() function initializes the DShotRMT class with
// a given DShot mode (DSHOT_OFF, DSHOT150, DSHOT300, DSHOT600, DSHOT1200)
// and a bidirectional flag. It returns a boolean value
// indicating whether or not the initialization was successful.
bool begin(dshot_mode_t dshot_mode = DSHOT_OFF, bool is_bidirectional = false);
2021-06-29 19:05:20 +01:00
// The sendThrottleValue() function sends a DShot packet with a given
// throttle value (between 0 and 2047) and an optional telemetry
// request flag.
2023-04-13 20:10:51 +01:00
// void sendThrottleValue(uint16_t throttle_value, telemetric_request_t telemetric_request = NO_TELEMETRIC);
void sendThrottleValue(uint16_t throttle_value);
2021-06-29 19:05:20 +01:00
2023-03-24 12:44:49 +00:00
private:
rmt_item32_t dshot_tx_rmt_item[DSHOT_PACKET_LENGTH]; // An array of RMT items used to send a DShot packet.
rmt_config_t dshot_tx_rmt_config; // The RMT configuration used for sending DShot packets.
dshot_config_t dshot_config; // The configuration for the DShot mode.
2021-06-29 19:05:20 +01:00
rmt_item32_t *buildTxRmtItem(uint16_t parsed_packet); // Constructs an RMT item from a parsed DShot packet.
uint16_t calculateCRC(const dshot_packet_t &dshot_packet); // Calculates the CRC checksum for a DShot packet.
uint16_t parseRmtPaket(const dshot_packet_t &dshot_packet); // Parses an RMT packet to obtain a DShot packet.
2021-06-29 19:05:20 +01:00
void sendRmtPaket(const dshot_packet_t &dshot_packet); // Sends a DShot packet via RMT.
2021-06-29 19:05:20 +01:00
};
#endif