...some tiny fixes from dev
* ...update workflow * Update esp32.yml * ...testing new workflow config * ...testing new Github Actions * Update ci.yml
This commit is contained in:
parent
9ee5aea348
commit
102a60e327
|
|
@ -0,0 +1,138 @@
|
||||||
|
name: ESP32 Build & Quality Check
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: [ '*' ]
|
||||||
|
release:
|
||||||
|
types: [ published ]
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
env:
|
||||||
|
ARDUINO_CLI_VERSION: 'latest'
|
||||||
|
ESP32_CORE_VERSION: 'latest'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
# ============================================================================
|
||||||
|
# Code Quality & Linting
|
||||||
|
# ============================================================================
|
||||||
|
quality-check:
|
||||||
|
name: 'Code Quality'
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 10
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Arduino Lint
|
||||||
|
uses: arduino/arduino-lint-action@v1
|
||||||
|
with:
|
||||||
|
path: ${{ github.workspace }}
|
||||||
|
compliance: strict
|
||||||
|
library-manager: update
|
||||||
|
verbose: true
|
||||||
|
|
||||||
|
# ============================================================================
|
||||||
|
# Compilation Test
|
||||||
|
# ============================================================================
|
||||||
|
compile-test:
|
||||||
|
name: 'Compile Example Sketch'
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 15
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
example:
|
||||||
|
- "examples/dshot300/dshot300.ino"
|
||||||
|
build-flags:
|
||||||
|
- name: "Release"
|
||||||
|
flags: "Automated Build"
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Compile Example (${{ matrix.build-flags.name }})
|
||||||
|
uses: arduino/compile-sketches@v1
|
||||||
|
with:
|
||||||
|
fqbn: esp32:esp32:esp32
|
||||||
|
libraries: |
|
||||||
|
- source-path: ${{ github.workspace }}
|
||||||
|
|
||||||
|
# ============================================================================
|
||||||
|
# Static Code Analysis
|
||||||
|
# ============================================================================
|
||||||
|
static-analysis:
|
||||||
|
name: 'Static Analysis'
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 10
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout Repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Install Cppcheck
|
||||||
|
run: sudo apt-get update && sudo apt-get install -y cppcheck
|
||||||
|
|
||||||
|
- name: Run Cppcheck
|
||||||
|
run: |
|
||||||
|
cppcheck --enable=warning,performance \
|
||||||
|
--std=c++17 \
|
||||||
|
--language=c++ \
|
||||||
|
--platform=unix32 \
|
||||||
|
--inline-suppr \
|
||||||
|
./DShotRMT.cpp ./DShotRMT.h
|
||||||
|
|
||||||
|
# ============================================================================
|
||||||
|
# Build Status Report
|
||||||
|
# ============================================================================
|
||||||
|
build-summary:
|
||||||
|
name: 'Build Summary'
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
if: always()
|
||||||
|
needs: [quality-check, compile-test, static-analysis]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Create Build Summary
|
||||||
|
run: |
|
||||||
|
echo "# 🔧 DShotRMT Build Report" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "| Check | Status | Details |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "|-------|--------|---------|" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
# Quality Check Status
|
||||||
|
if [[ "${{ needs.quality-check.result }}" == "success" ]]; then
|
||||||
|
echo "| 📋 Quality Check | ✅ Passed | Arduino Lint completed successfully |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
else
|
||||||
|
echo "| 📋 Quality Check | ❌ Failed | Check Arduino Lint report |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Compile Test Status
|
||||||
|
if [[ "${{ needs.compile-test.result }}" == "success" ]]; then
|
||||||
|
echo "| 🔨 Compilation | ✅ Passed | All examples compiled successfully |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
else
|
||||||
|
echo "| 🔨 Compilation | ❌ Failed | Compilation errors detected |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Static Analysis Status
|
||||||
|
if [[ "${{ needs.static-analysis.result }}" == "success" ]]; then
|
||||||
|
echo "| 🔍 Static Analysis | ✅ Passed | No critical issues found |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
else
|
||||||
|
echo "| 🔍 Static Analysis | ❌ Failed | Issues detected by CPPCheck |" >> $GITHUB_STEP_SUMMARY
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
|
# Overall Status
|
||||||
|
if [[ "${{ needs.quality-check.result }}" == "success" &&
|
||||||
|
"${{ needs.compile-test.result }}" == "success" &&
|
||||||
|
"${{ needs.static-analysis.result }}" == "success" ]]; then
|
||||||
|
echo "## 🎉 All Checks Passed!" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Your DShotRMT library is ready for deployment." >> $GITHUB_STEP_SUMMARY
|
||||||
|
else
|
||||||
|
echo "## ⚠️ Action Required" >> $GITHUB_STEP_SUMMARY
|
||||||
|
echo "Please review the failed checks and address any issues."
|
||||||
|
fi
|
||||||
|
|
@ -1,30 +0,0 @@
|
||||||
name: Build DShotRMT Example Sketch
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- '*'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout repository
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Set up Arduino CLI
|
|
||||||
run: |
|
|
||||||
curl -fsSL https://raw.githubusercontent.com/arduino/arduino-cli/master/install.sh | BINDIR=/usr/local/bin sh
|
|
||||||
arduino-cli core update-index
|
|
||||||
arduino-cli core install esp32:esp32
|
|
||||||
|
|
||||||
- name: Install DShotRMT as library
|
|
||||||
run: |
|
|
||||||
mkdir -p $HOME/Arduino/libraries
|
|
||||||
ln -s $PWD $HOME/Arduino/libraries/DShotRMT
|
|
||||||
|
|
||||||
- name: Compile dshot300.ino example
|
|
||||||
run: |
|
|
||||||
arduino-cli compile --fqbn esp32:esp32:esp32 examples/dshot300/dshot300.ino
|
|
||||||
|
|
||||||
|
|
@ -274,7 +274,7 @@ dshot_packet_t DShotRMT::_buildDShotPacket(const uint16_t value)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Encodes DShot packet into RMT buffer and places code into IRAM instead of flash
|
// Encodes DShot packet into RMT buffer and places code into IRAM instead of flash
|
||||||
bool IRAM_ATTR DShotRMT::_encodeDShotFrame(const dshot_packet_t &packet, rmt_symbol_word_t *symbols)
|
bool DShotRMT::_encodeDShotFrame(const dshot_packet_t &packet, rmt_symbol_word_t *symbols)
|
||||||
{
|
{
|
||||||
// Parse actual packet into buffer
|
// Parse actual packet into buffer
|
||||||
_current_packet = _parseDShotPacket(packet);
|
_current_packet = _parseDShotPacket(packet);
|
||||||
|
|
@ -337,7 +337,7 @@ uint16_t DShotRMT::_decodeDShotFrame(const rmt_symbol_word_t *symbols)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Timer triggered
|
// Timer triggered
|
||||||
bool IRAM_ATTR DShotRMT::_timer_signal()
|
bool DShotRMT::_timer_signal()
|
||||||
{
|
{
|
||||||
// trying new tricks
|
// trying new tricks
|
||||||
return __builtin_expect((micros() - _last_transmission_time >= _frame_timer_us), 1);
|
return __builtin_expect((micros() - _last_transmission_time >= _frame_timer_us), 1);
|
||||||
|
|
|
||||||
|
|
@ -67,14 +67,16 @@ class DShotRMT
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
// --- DShot Config ---
|
// --- DShot Config ---
|
||||||
DShotRMT(gpio_num_t gpio, dshot_mode_t mode = DSHOT300, bool is_bidirectional = false);
|
explicit DShotRMT(gpio_num_t gpio = GPIO_NUM_16, dshot_mode_t mode = DSHOT300, bool is_bidirectional = false);
|
||||||
DShotRMT(uint16_t pin_nr, dshot_mode_t mode, bool is_bidirectional);
|
DShotRMT(uint16_t pin_nr, dshot_mode_t mode, bool is_bidirectional);
|
||||||
|
|
||||||
// --- Init RMT Module ---
|
// --- Init RMT Module ---
|
||||||
bool begin();
|
bool begin();
|
||||||
|
|
||||||
// Sets the throttle value and transmits
|
// Sets the throttle value and transmits
|
||||||
bool setThrottle(uint16_t throttle); // deprecated
|
[[deprecated("Use sendThrottle() instead")]]
|
||||||
|
bool setThrottle(uint16_t throttle);
|
||||||
|
|
||||||
bool sendThrottle(uint16_t throttle);
|
bool sendThrottle(uint16_t throttle);
|
||||||
|
|
||||||
// Sends a DShot Command
|
// Sends a DShot Command
|
||||||
|
|
@ -145,7 +147,7 @@ private:
|
||||||
static constexpr auto DSHOT_OK = 0;
|
static constexpr auto DSHOT_OK = 0;
|
||||||
static constexpr auto DSHOT_ERROR = 1;
|
static constexpr auto DSHOT_ERROR = 1;
|
||||||
static constexpr auto *DSHOT_MSG_01 = "Failed to initialize TX channel!";
|
static constexpr auto *DSHOT_MSG_01 = "Failed to initialize TX channel!";
|
||||||
static constexpr auto *DSHOT_MSG_02 = "Failed to initialize RX channe!l";
|
static constexpr auto *DSHOT_MSG_02 = "Failed to initialize RX channel!";
|
||||||
static constexpr auto *DSHOT_MSG_03 = "Failed to initialize DShot encoder!";
|
static constexpr auto *DSHOT_MSG_03 = "Failed to initialize DShot encoder!";
|
||||||
static constexpr auto *DSHOT_MSG_04 = "RX CRC Check failed!";
|
static constexpr auto *DSHOT_MSG_04 = "RX CRC Check failed!";
|
||||||
static constexpr auto *DSHOT_MSG_05 = "Throttle value not in range (48 - 2047)!";
|
static constexpr auto *DSHOT_MSG_05 = "Throttle value not in range (48 - 2047)!";
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
name=DShotRMT
|
name=DShotRMT
|
||||||
version=0.6.0
|
version=0.6.1
|
||||||
author=derdoktor667
|
author=derdoktor667
|
||||||
maintainer=derdoktor667
|
maintainer=derdoktor667
|
||||||
sentence=DShotRMT Library supporting all DShot Types and speeds. Tested with BlHeli_S.
|
sentence=DShotRMT Library supporting all DShot Types and speeds. Tested with BlHeli_S.
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue