global: fix MD007 unordered list indentation in markdown files Normalize unordered list indentation to use 2-space multiples: - Top-level list items start at column 0 - Nested list items use 2 additional spaces per level Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> global: fix MD009 trailing whitespace in markdown files Remove trailing whitespace from all affected markdown files. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> global: fix MD010 hard tabs in markdown files Replace hard tab characters with 4 spaces. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> global: fix MD012 multiple consecutive blank lines in markdown Collapse multiple consecutive blank lines to single blank lines across all markdown files (excluding vendored code). Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> global: fix MD007 list indentation base level in markdown Shift list indentation left by 2 spaces so top-level list items start at column 0 instead of column 2. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD022 blank lines around headings in markdown Ensure headings are surrounded by blank lines as required by markdownlint MD022 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD032 blank lines around lists in markdown Ensure lists are surrounded by blank lines as required by markdownlint MD032 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD031 blank lines around code blocks in markdown Ensure fenced code blocks are surrounded by blank lines as required by markdownlint MD031 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD047 files should end with single newline Ensure all markdown files end with exactly one newline character as required by markdownlint MD047 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD023 headings must start at beginning of line Remove leading whitespace from heading lines as required by markdownlint MD023 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD007 remaining list indentation in markdown Fix unordered list indentation to use correct spacing as required by markdownlint MD007 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD030 spaces after list markers in markdown Reduce multiple spaces after list markers to single space as required by markdownlint MD030 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD022 blank lines around setext headings Ensure setext-style headings (underlined with === or ---) are surrounded by blank lines as required by markdownlint MD022 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD018 missing space after hash in headings Add space after hash marks in atx-style headings as required by markdownlint MD018 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD019 multiple spaces after hash in headings Reduce multiple spaces after hash marks to single space in atx-style headings as required by markdownlint MD019 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD012 multiple consecutive blank lines in markdown Remove multiple consecutive blank lines and ensure files end with exactly one newline as required by markdownlint MD012 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD023 headings with leading whitespace Remove leading whitespace from setext-style heading text lines as required by markdownlint MD023 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD022 blank line after heading in markdown Add missing blank line after heading as required by markdownlint MD022 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD009 trailing non-breaking space in markdown Remove trailing non-breaking space (U+00A0) as required by markdownlint MD009 rule. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> Tools/scripts: fix MD012 remaining multiple blank lines in markdown Remove leading blank lines and whitespace-only lines that create multiple consecutive blank lines. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2.1 KiB
CAN Playback
The CAN_playback.lua script plays back captured CAN frames from a flight log. This can be used to reproduce servo movement from a flight which is useful for measuing the expected lifetime of CAN servos.
Capturing CAN traffic
To capture all CAN traffic on a CAN bus while flying set bit zero of CAN_Pn_OPTIONS, so if no other bits are set then set:
- CAN_P1_OPTIONS=1
- CAN_P2_OPTIONS=1
This assumes you want to capture all CAN bus traffic on both CAN buses.
Note that this will result in a large flight log. It will capture CAN frames into CANF log messages.
Processing flight log
After capturing the flight log from a real flight you need to process the log so that it only contains the CANF messages. To do that run the following pymavlink command on the command line:
mavlogdump.py -q -o CANF.bin inlog.BIN --type CANF
that will create a file CANF.bin which contains just the CANF frames from inlog.bin.
Setup for playback
On the playback system copy the CANF.bin file to the root of the microSD card. This assumes you are using the script unmodified to playback ArrayCommand servo actuator commands for servo testing.
Then set the following parameters for the first CAN bus:
- CAN_P1_PROTOCOL2 = 10
- CAN_D1_UC_SRV_BM = 0
- CAN_D1_UC_OPTION = 1024
and the following parameters for the second CAN bus:
- CAN_P2_PROTOCOL2 = 12
- CAN_D2_UC_SRV_BM = 0
- CAN_D2_UC_OPTION = 1024
You may also wish to set CAN_Dn_UC_ESC_BM to 0 to stop ESC control traffic on the CAN bus to make the bus less busy.
Then load CAN_playback.lua into the APM/SCRIPTS/ directory on the microSD card and set:
- SCR_ENABLE = 1
- SCR_VM_I_COUNT = 200000
After you reboot you should see a message:
`` CAN_playback: starting
and if you monitor the CAN bus you should see the ArrayCommand
messages from your flight on the CAN bus. Your CAN servos should move
in an identical way to the movement in flight.
When the end of the CANF.bin file is reached you will see a message:
``
CAN_playback: rewind
and the playback will automatically restart from the start of the log.