From 326ef512cb1b2bb772b2e483b52608ea43bcacde Mon Sep 17 00:00:00 2001 From: Scott Gibb <44235263+ScottGibb@users.noreply.github.com> Date: Wed, 20 Nov 2024 11:43:55 +0000 Subject: [PATCH 01/16] Create Static Analysis.yml --- .github/workflows/Static Analysis.yml | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) create mode 100644 .github/workflows/Static Analysis.yml diff --git a/.github/workflows/Static Analysis.yml b/.github/workflows/Static Analysis.yml new file mode 100644 index 0000000..c3740b2 --- /dev/null +++ b/.github/workflows/Static Analysis.yml @@ -0,0 +1,16 @@ +--- +name: Static Analysis +on: [push] +jobs: + Markdown_Lint_Check: + name: Markdown Lint Check + runs-on: ubuntu-latest + steps: + - name: Install markdownlint-cli + run: npm install -g markdownlint-cli + - name: Checkout code + uses: actions/checkout@v2 + - name: Run markdownlint + run: | + echo "Checking Markdown files" + find . -type f -name "*.md" -print0 | xargs -0 markdownlint From 26e0b57cff4a432969d0a33114772d6fe2ddf032 Mon Sep 17 00:00:00 2001 From: Scott Gibb <44235263+ScottGibb@users.noreply.github.com> Date: Wed, 20 Nov 2024 11:45:44 +0000 Subject: [PATCH 02/16] Create .markdownlint.json --- .markdownlint.json | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 .markdownlint.json diff --git a/.markdownlint.json b/.markdownlint.json new file mode 100644 index 0000000..7d6c49e --- /dev/null +++ b/.markdownlint.json @@ -0,0 +1,13 @@ +{ + "default": true, + "MD041": false, + "MD045": false, + "MD033": false, + "MD026": false, + "MD013": false, + "line-length": { + "line_length": 800, + "code_blocks": false, + "tables": true + } + } From 3313e168de8c9717cf38e211a760655616c4b60d Mon Sep 17 00:00:00 2001 From: Scott Gibb <44235263+ScottGibb@users.noreply.github.com> Date: Wed, 20 Nov 2024 11:46:02 +0000 Subject: [PATCH 03/16] Update Static Analysis.yml --- .github/workflows/Static Analysis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Static Analysis.yml b/.github/workflows/Static Analysis.yml index c3740b2..dd49817 100644 --- a/.github/workflows/Static Analysis.yml +++ b/.github/workflows/Static Analysis.yml @@ -1,6 +1,6 @@ --- name: Static Analysis -on: [push] +on: [push, pull_request] jobs: Markdown_Lint_Check: name: Markdown Lint Check From 53a04c7966f8df7db6df9a46a05439367b87ccb3 Mon Sep 17 00:00:00 2001 From: Scott Gibb <44235263+ScottGibb@users.noreply.github.com> Date: Wed, 20 Nov 2024 11:48:23 +0000 Subject: [PATCH 04/16] Adding Static Analysis Badge --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index 959a534..5be65bb 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,7 @@ # Embedded Rust [![Awesome](https://awesome.re/badge.svg)](https://awesome.re) +[![Static Analysis](https://github.com/rust-embedded/awesome-embedded-rust/actions/workflows/Static%20Analysis.yml/badge.svg?branch=master)](https://github.com/rust-embedded/awesome-embedded-rust/actions/workflows/Static%20Analysis.yml) This is a curated list of resources related to embedded and low-level programming in the Rust programming language, including a selection of useful crates. From 8badb0f8bea06742c8c257c4d5adea838b55a8ff Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:07:40 +0000 Subject: [PATCH 05/16] Updated Markdown to meet linter criteria --- .github/workflows/Static Analysis.yaml | 32 +++ .github/workflows/Static Analysis.yml | 16 -- .markdownlint.json | 13 -- .markdownlint.yaml | 277 +++++++++++++++++++++++++ Code-of-Conduct.md | 2 +- README.md | 58 +++--- 6 files changed, 335 insertions(+), 63 deletions(-) create mode 100644 .github/workflows/Static Analysis.yaml delete mode 100644 .github/workflows/Static Analysis.yml delete mode 100644 .markdownlint.json create mode 100644 .markdownlint.yaml diff --git a/.github/workflows/Static Analysis.yaml b/.github/workflows/Static Analysis.yaml new file mode 100644 index 0000000..7df9a6e --- /dev/null +++ b/.github/workflows/Static Analysis.yaml @@ -0,0 +1,32 @@ +--- + name: Linting + + on: # yamllint disable-line rule:truthy + # push: null + pull_request: null + + permissions: {} + + jobs: + Super_Linter: + name: Super Linter + runs-on: ubuntu-latest + + permissions: + contents: read + packages: read + # To report GitHub Actions status checks + statuses: write + + steps: + - name: Checkout code + uses: actions/checkout@v4 + - name: Super-linter + uses: super-linter/super-linter@v7.2.0 # x-release-please-version + env: + # Linters + VALIDATE_MARKDOWN: true + VALIDATE_YAML: true + FIX_MARKDOWN: true + ENABLE_GITHUB_ACTIONS_STEP_SUMMARY: true + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/Static Analysis.yml b/.github/workflows/Static Analysis.yml deleted file mode 100644 index dd49817..0000000 --- a/.github/workflows/Static Analysis.yml +++ /dev/null @@ -1,16 +0,0 @@ ---- -name: Static Analysis -on: [push, pull_request] -jobs: - Markdown_Lint_Check: - name: Markdown Lint Check - runs-on: ubuntu-latest - steps: - - name: Install markdownlint-cli - run: npm install -g markdownlint-cli - - name: Checkout code - uses: actions/checkout@v2 - - name: Run markdownlint - run: | - echo "Checking Markdown files" - find . -type f -name "*.md" -print0 | xargs -0 markdownlint diff --git a/.markdownlint.json b/.markdownlint.json deleted file mode 100644 index 7d6c49e..0000000 --- a/.markdownlint.json +++ /dev/null @@ -1,13 +0,0 @@ -{ - "default": true, - "MD041": false, - "MD045": false, - "MD033": false, - "MD026": false, - "MD013": false, - "line-length": { - "line_length": 800, - "code_blocks": false, - "tables": true - } - } diff --git a/.markdownlint.yaml b/.markdownlint.yaml new file mode 100644 index 0000000..99c54ea --- /dev/null +++ b/.markdownlint.yaml @@ -0,0 +1,277 @@ +# Example markdownlint configuration with all properties set to their default value + +# Default state for all rules +default: true + +# Path to configuration file to extend +extends: null + +# MD001/heading-increment : Heading levels should only increment by one level at a time : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md001.md +MD001: true + +# MD003/heading-style : Heading style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md003.md +MD003: + # Heading style + style: "consistent" + +# MD004/ul-style : Unordered list style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md004.md +MD004: + # List style + style: "consistent" + +# MD005/list-indent : Inconsistent indentation for list items at the same level : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md005.md +MD005: true + +# MD007/ul-indent : Unordered list indentation : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md007.md +MD007: + # Spaces for indent + indent: 2 + # Whether to indent the first level of the list + start_indented: false + # Spaces for first level indent (when start_indented is set) + start_indent: 2 + +# MD009/no-trailing-spaces : Trailing spaces : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md009.md +MD009: + # Spaces for line break + br_spaces: 2 + # Allow spaces for empty lines in list items + list_item_empty_lines: false + # Include unnecessary breaks + strict: false + +# MD010/no-hard-tabs : Hard tabs : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md010.md +MD010: + # Include code blocks + code_blocks: true + # Fenced code languages to ignore + ignore_code_languages: [] + # Number of spaces for each hard tab + spaces_per_tab: 1 + +# MD011/no-reversed-links : Reversed link syntax : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md011.md +MD011: true + +# MD012/no-multiple-blanks : Multiple consecutive blank lines : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md012.md +MD012: + # Consecutive blank lines + maximum: 1 + +# MD013/line-length : Line length : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md013.md +MD013: false +# # Number of characters +# line_length: 200 +# # Number of characters for headings +# heading_line_length: 80 +# # Number of characters for code blocks +# code_block_line_length: 200 +# # Include code blocks +# code_blocks: true +# # Include tables +# tables: true +# # Include headings +# headings: true +# # Strict length checking +# strict: false +# # Stern length checking +# stern: false + +# MD014/commands-show-output : Dollar signs used before commands without showing output : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md014.md +MD014: true + +# MD018/no-missing-space-atx : No space after hash on atx style heading : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md018.md +MD018: true + +# MD019/no-multiple-space-atx : Multiple spaces after hash on atx style heading : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md019.md +MD019: true + +# MD020/no-missing-space-closed-atx : No space inside hashes on closed atx style heading : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md020.md +MD020: true + +# MD021/no-multiple-space-closed-atx : Multiple spaces inside hashes on closed atx style heading : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md021.md +MD021: true + +# MD022/blanks-around-headings : Headings should be surrounded by blank lines : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md022.md +MD022: + # Blank lines above heading + lines_above: 1 + # Blank lines below heading + lines_below: 1 + +# MD023/heading-start-left : Headings must start at the beginning of the line : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md023.md +MD023: true + +# MD024/no-duplicate-heading : Multiple headings with the same content : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md024.md +MD024: + # Only check sibling headings + siblings_only: true + +# MD025/single-title/single-h1 : Multiple top-level headings in the same document : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md025.md +MD025: + # Heading level + level: 1 + # RegExp for matching title in front matter + front_matter_title: "^\\s*title\\s*[:=]" + +# MD026/no-trailing-punctuation : Trailing punctuation in heading : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md026.md +MD026: + # Punctuation characters + punctuation: ".,;:!。,;:!" + +# MD027/no-multiple-space-blockquote : Multiple spaces after blockquote symbol : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md027.md +MD027: true + +# MD028/no-blanks-blockquote : Blank line inside blockquote : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md028.md +MD028: true + +# MD029/ol-prefix : Ordered list item prefix : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md029.md +MD029: + # List style + style: "one_or_ordered" + +# MD030/list-marker-space : Spaces after list markers : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md030.md +MD030: + # Spaces for single-line unordered list items + ul_single: 1 + # Spaces for single-line ordered list items + ol_single: 1 + # Spaces for multi-line unordered list items + ul_multi: 1 + # Spaces for multi-line ordered list items + ol_multi: 1 + +# MD031/blanks-around-fences : Fenced code blocks should be surrounded by blank lines : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md031.md +MD031: + # Include list items + list_items: true + +# MD032/blanks-around-lists : Lists should be surrounded by blank lines : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md032.md +MD032: true + +# MD033/no-inline-html : Inline HTML : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md033.md +MD033: false +# # Allowed elements +# allowed_elements: [] + +# MD034/no-bare-urls : Bare URL used : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md034.md +MD034: false + +# MD035/hr-style : Horizontal rule style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md035.md +MD035: + # Horizontal rule style + style: "consistent" + +# MD036/no-emphasis-as-heading : Emphasis used instead of a heading : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md036.md +MD036: + # Punctuation characters + punctuation: ".,;:!?。,;:!?" + +# MD037/no-space-in-emphasis : Spaces inside emphasis markers : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md037.md +MD037: true + +# MD038/no-space-in-code : Spaces inside code span elements : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md038.md +MD038: true + +# MD039/no-space-in-links : Spaces inside link text : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md039.md +MD039: true + +# MD040/fenced-code-language : Fenced code blocks should have a language specified : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md040.md +MD040: + # List of languages + allowed_languages: [] + # Require language only + language_only: false + +# MD041/first-line-heading/first-line-h1 : First line in a file should be a top-level heading : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md041.md +MD041: + # Heading level + level: 1 + # RegExp for matching title in front matter + front_matter_title: "^\\s*title\\s*[:=]" + +# MD042/no-empty-links : No empty links : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md042.md +MD042: true + +# MD043/required-headings : Required heading structure : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md043.md +MD043: + # List of headings + headings: [ "*" ] + # Match case of headings + match_case: false + +# MD044/proper-names : Proper names should have the correct capitalization : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md044.md +MD044: + # List of proper names + names: [] + # Include code blocks + code_blocks: true + # Include HTML elements + html_elements: true + +# MD045/no-alt-text : Images should have alternate text (alt text) : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md045.md +MD045: true + +# MD046/code-block-style : Code block style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md046.md +MD046: + # Block style + style: "consistent" + +# MD047/single-trailing-newline : Files should end with a single newline character : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md047.md +MD047: true + +# MD048/code-fence-style : Code fence style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md048.md +MD048: + # Code fence style + style: "consistent" + +# MD049/emphasis-style : Emphasis style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md049.md +MD049: + # Emphasis style + style: "consistent" + +# MD050/strong-style : Strong style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md050.md +MD050: + # Strong style + style: "consistent" + +# MD051/link-fragments : Link fragments should be valid : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md051.md +MD051: + # Ignore case of fragments + ignore_case: false + +# MD052/reference-links-images : Reference links and images should use a label that is defined : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md052.md +MD052: + # Include shortcut syntax + shortcut_syntax: false + +# MD053/link-image-reference-definitions : Link and image reference definitions should be needed : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md053.md +MD053: + # Ignored definitions + ignored_definitions: + - "//" + +# MD054/link-image-style : Link and image style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md054.md +MD054: + # Allow autolinks + autolink: true + # Allow inline links and images + inline: true + # Allow full reference links and images + full: true + # Allow collapsed reference links and images + collapsed: true + # Allow shortcut reference links and images + shortcut: true + # Allow URLs as inline links + url_inline: true + +# MD055/table-pipe-style : Table pipe style : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md055.md +MD055: + # Table pipe style + style: "consistent" + +# MD056/table-column-count : Table column count : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md056.md +MD056: true + +# MD058/blanks-around-tables : Tables should be surrounded by blank lines : https://github.com/DavidAnson/markdownlint/blob/v0.36.1/doc/md058.md +MD058: true \ No newline at end of file diff --git a/Code-of-Conduct.md b/Code-of-Conduct.md index f2e5bdc..c92197d 100644 --- a/Code-of-Conduct.md +++ b/Code-of-Conduct.md @@ -30,7 +30,7 @@ Project maintainers have the right and responsibility to remove, edit, or reject ## Scope -This Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or its community. Examples of representing a project or community include using an official project e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event. Representation of a project may be further defined and clarified by project maintainers. +This Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or its community. Examples of representing a project or community include using an official project e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event. Representation of a project may be further defined and clarified by project maintainers. ## Enforcement diff --git a/README.md b/README.md index 5be65bb..0325173 100644 --- a/README.md +++ b/README.md @@ -171,7 +171,7 @@ specifically endorsed or reviewed for accuracy or quality by the Embedded Workin ## Tools - [xargo](https://github.com/japaric/xargo) Rust package manager with support for non-default std libraries — build Rust runtime for your embedded system. - - xargo is great, but since it's in maintenance mode, [cargo-xbuild](https://github.com/rust-osdev/cargo-xbuild) is catching up as its intended replacement. + - xargo is great, but since it's in maintenance mode, [cargo-xbuild](https://github.com/rust-osdev/cargo-xbuild) is catching up as its intended replacement. - [svd2rust](https://github.com/japaric/svd2rust) Generate Rust structs with register mappings from SVD files. - [edc2svd](https://github.com/kiffie/edc2svd) Generate SVD files for PIC32 devices from EDC files. - [![crates.io](https://img.shields.io/crates/v/edc2svd.svg)](https://crates.io/crates/edc2svd) - [embedded-hal-mock] Mock implementation of `embedded-hal` traits for testing without accessing real hardware. - [![crates.io](https://img.shields.io/crates/v/embedded-hal-mock.svg)](https://crates.io/crates/embedded-hal-mock) @@ -190,15 +190,14 @@ specifically endorsed or reviewed for accuracy or quality by the Embedded Workin - [uf2](https://github.com/sajattack/uf2conv-rs) Converts binary files to Microsoft's UF2 format for copying over to mass storage device uf2 bootloaders - [![crates.io](https://img.shields.io/crates/v/uf2.svg)](https://crates.io/crates/uf2) - [probe-rs](https://github.com/probe-rs/probe-rs): a modern, embedded debugging toolkit, written in Rust - [Knurling Tools](https://knurling.ferrous-systems.com/tools/) are developed by [Ferrous Systems] to ease the development process for building, debugging, and testing embedded Rust systems. These tools include: - - [defmt](https://github.com/knurling-rs/defmt): a highly efficient logging framework that targets resource-constrained devices, like microcontrollers. - - [flip-link](https://github.com/knurling-rs/flip-link), a linker wrapper that provides stack overflow protection without an MMU by flipping the standard memory layout of ARM Cortex-M programs - - [app-template](https://github.com/knurling-rs/app-template), a `cargo-generate` powered project template for quickly setting up new projects using the Knurling Tools. - - [defmt-test](https://github.com/knurling-rs/defmt-test), an embedded test harness that lets you write and run unit tests as if you were using the built-in `#[test]` attribute, but will run on an embedded target + - [defmt](https://github.com/knurling-rs/defmt): a highly efficient logging framework that targets resource-constrained devices, like microcontrollers. + - [flip-link](https://github.com/knurling-rs/flip-link), a linker wrapper that provides stack overflow protection without an MMU by flipping the standard memory layout of ARM Cortex-M programs + - [app-template](https://github.com/knurling-rs/app-template), a `cargo-generate` powered project template for quickly setting up new projects using the Knurling Tools. + - [defmt-test](https://github.com/knurling-rs/defmt-test), an embedded test harness that lets you write and run unit tests as if you were using the built-in `#[test]` attribute, but will run on an embedded target - [embedded-hal-compat](https://github.com/ryankurte/embedded-hal-compat), a compatibility layer to provide interoperability between `v0.2.x` and `v1.x.x` hal implementations and drivers - [Embassy start](https://github.com/titanclass/embassy-start) is a GitHub repo template for setting up async embedded Rust projects that use [Embassy](https://github.com/embassy-rs/embassy). This particular template targets nRF hardware and networking using the Uarte for the purposes of illustration only. - [svd-generator](https://codeberg.org/weathered-steel/svd-generator) CLI tool to parse flattened device tree files, and create a SVD file. - [![crates.io](https://img.shields.io/crates/v/svd-generator.svg)](https://crates.io/crates/svd-generator) - [embedded-hal-mock]: https://crates.io/crates/embedded-hal-mock ## Real-time @@ -215,8 +214,8 @@ specifically endorsed or reviewed for accuracy or quality by the Embedded Workin ### Real-time tools - [RTIC v1.0](https://rtic.rs/1/book/en/) Real-Time Interrupt-driven Concurrency — A concurrency framework for building real-time systems: - - [cortex-m rtic](https://github.com/rtic-rs/cortex-m-rtic) RTIC framework for ARM Cortex-M microcontrollers - - [msp430 rtfm](https://github.com/japaric/msp430-rtfm) RTFM framework for MSP430 MCUs + - [cortex-m rtic](https://github.com/rtic-rs/cortex-m-rtic) RTIC framework for ARM Cortex-M microcontrollers + - [msp430 rtfm](https://github.com/japaric/msp430-rtfm) RTFM framework for MSP430 MCUs ## Peripheral Access Crates @@ -325,7 +324,7 @@ The [`stm32-rs`](https://github.com/stm32-rs/stm32-rs) project has peripheral ac ### MSP430 - [`msp430g2553`](https://github.com/japaric/msp430g2553) Peripheral access API for MSP430G2553 microcontrollers (generated using svd2rust) - - [msp430 quickstart](https://github.com/rust-embedded/msp430-quickstart) some examples for msp430 + - [msp430 quickstart](https://github.com/rust-embedded/msp430-quickstart) some examples for msp430 - [`msp430fr2355`](https://crates.io/crates/msp430fr2355) Peripheral access API for MSP430FR2355 microcontrollers (generated using svd2rust) - [`msp430fr6972`](https://crates.io/crates/msp430fr6972) - [![crates.io](https://img.shields.io/crates/v/msp430fr6972)](https://crates.io/crates/msp430fr6972) @@ -376,6 +375,7 @@ Peripheral access crates for the different XMC4xxx families of microcontrollers - [`w7500x-pac`](https://crates.io/crates/w7500x-pac) Peripheral Access Crate for Wiznet's W7500x microcontrollers (generated using svd2rust) - [![crates.io](https://img.shields.io/crates/v/w7500x-pac.svg)](https://crates.io/crates/w7500x-pac) ### Renesas + - [`ra2a1`](https://github.com/ra-rs/ra/tree/main/pac/ra2a1) Peripheral Access Crate for ra2a1 microcontrollers (generated using svd2rust) - [![crates.io](https://img.shields.io/crates/v/ra2a1.svg)](https://crates.io/crates/ra2a1) - [`ra2e1`](https://github.com/ra-rs/ra/tree/main/pac/ra2e1) Peripheral Access Crate for ra2e1 microcontrollers (generated using svd2rust) - [![crates.io](https://img.shields.io/crates/v/ra2e1.svg)](https://crates.io/crates/ra2e1) - [`ra2e2`](https://github.com/ra-rs/ra/tree/main/pac/ra2e2) Peripheral Access Crate for ra2e2 microcontrollers (generated using svd2rust) - [![crates.io](https://img.shields.io/crates/v/ra2e2.svg)](https://crates.io/crates/ra2e2) @@ -394,7 +394,6 @@ Peripheral access crates for the different XMC4xxx families of microcontrollers - [`ra6t2`](https://github.com/ra-rs/ra/tree/main/pac/ra6t2) Peripheral Access Crate for ra6t2 microcontrollers (generated using svd2rust) - [![crates.io](https://img.shields.io/crates/v/ra6t2.svg)](https://crates.io/crates/ra6t2) - [`da14531`](https://crates.io/crates/da14531) Peripheral Access Crate for DA14531 Ultra-Low Power BT 5.1 System-on-Chip - [![crates.io](https://img.shields.io/crates/v/da14531.svg)](https://crates.io/crates/da14531) - ## HAL implementation crates Implementations of [`embedded-hal`] for microcontroller families and systems running some OS. - [![crates.io](https://img.shields.io/crates/v/embedded-hal.svg)](https://crates.io/crates/embedded-hal) @@ -464,31 +463,27 @@ Also check the list of [STMicroelectronics board support crates][stm-bsc]! - [`stm32f0xx-hal`](https://crates.io/crates/stm32f0xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32f0xx-hal.svg)](https://crates.io/crates/stm32f0xx-hal) - Has examples that can run on boards like the [Nucleo-F042K6] and similar boards - -[Nucleo-F042K6]: http://www.st.com/en/evaluation-tools/nucleo-f042k6.html - +[Nucleo-F042K6]: - [`stm32f1xx-hal`](https://github.com/stm32-rs/stm32f1xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32f1xx-hal.svg)](https://crates.io/crates/stm32f1xx-hal) - Can be run on boards like the [Blue pill], [Nucleo-F103RB], and similar boards - -[Blue pill]: https://stm32duinoforum.com/forum/wiki_subdomain/index_title_Blue_Pill.html -[Nucleo-F103RB]: http://www.st.com/en/evaluation-tools/nucleo-f103rb.html - +[Blue pill]: +[Nucleo-F103RB]: - [`stm32f3xx-hal`](https://crates.io/crates/stm32f3xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32f3xx-hal.svg)](https://crates.io/crates/stm32f3xx-hal) - [`stm32f4xx-hal`](https://crates.io/crates/stm32f4xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32f4xx-hal.svg)](https://crates.io/crates/stm32f4xx-hal) - - Generic HAL implementation for all MCUs of the stm32f4 series + - Generic HAL implementation for all MCUs of the stm32f4 series - [`stm32f7xx-hal`](https://crates.io/crates/stm32f7xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32f7xx-hal.svg)](https://crates.io/crates/stm32f7xx-hal) - - Generic HAL implementation for all MCUs of the stm32f7 series + - Generic HAL implementation for all MCUs of the stm32f7 series - [`stm32g0xx-hal`](https://crates.io/crates/stm32g0xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32g0xx-hal.svg)](https://crates.io/crates/stm32g0xx-hal) - [`stm32h7xx-hal`](https://crates.io/crates/stm32h7xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32h7xx-hal.svg)](https://crates.io/crates/stm32h7xx-hal) - - HAL implementation for the STMicro STM32H7xx family of microcontrollers + - HAL implementation for the STMicro STM32H7xx family of microcontrollers - [`stm32l0xx-hal`](https://crates.io/crates/stm32l0xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32l0xx-hal.svg)](https://crates.io/crates/stm32l0xx-hal) - - HAL implementation for the the STMicro STM32L0xx family of microcontrollers + - HAL implementation for the the STMicro STM32L0xx family of microcontrollers - [`stm32l1xx-hal`](https://crates.io/crates/stm32l1xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32l1xx-hal.svg)](https://crates.io/crates/stm32l1xx-hal) - [`stm32l151-hal`](https://crates.io/crates/stm32l151-hal) - [![crates.io](https://img.shields.io/crates/v/stm32l151-hal.svg)](https://crates.io/crates/stm32l151-hal) - [`stm32l4xx-hal`](https://crates.io/crates/stm32l4xx-hal) - [![crates.io](https://img.shields.io/crates/v/stm32l4xx-hal.svg)](https://crates.io/crates/stm32l4xx-hal) - - Generic hal support for stm32l4 devices, has examples that can run on boards like the [Nucleo-L432KC], [Solo], and similar boards + - Generic hal support for stm32l4 devices, has examples that can run on boards like the [Nucleo-L432KC], [Solo], and similar boards - [`stm32-hal`](https://crates.io/crates/stm32-hal2) - [![crates.io](https://img.shields.io/crates/v/stm32-hal2.svg)](https://crates.io/crates/stm32-hal2) - - HAL implementation for STM32 devices across multiple families, with a focus on newer ones like L4, L5, and H7. + - HAL implementation for STM32 devices across multiple families, with a focus on newer ones like L4, L5, and H7. [Nucleo-L432KC]: https://www.st.com/content/st_com/en/products/evaluation-tools/product-evaluation-tools/mcu-eval-tools/stm32-mcu-eval-tools/stm32-mcu-nucleo/nucleo-l432kc.html [Solo]: https://solokeys.com/ @@ -500,7 +495,7 @@ Also check the list of [STMicroelectronics board support crates][stm-bsc]! ### MSP430 - [`msp430fr2x5x-hal`](https://crates.io/crates/msp430fr2x5x-hal) - - HAL implementation for the MSP430FR2x5x family of microcontrollers + - HAL implementation for the MSP430FR2x5x family of microcontrollers ### Espressif @@ -509,11 +504,10 @@ Also check the list of [STMicroelectronics board support crates][stm-bsc]! - [`esp-hal`](https://github.com/esp-rs/esp-hal) - A `no_std` Hardware Abstraction Layers for ESP32 microcontrollers - ### Silicon Labs - [`tomu-hal`](https://github.com/fudanchii/imtomu-rs) - - HAL implementation targeted for [Tomu] USB board with EFM32HG309F64 ARMv6-M core. Has support to configure [tomu bootloader] directly from an application via the `toboot_config` macro. + - HAL implementation targeted for [Tomu] USB board with EFM32HG309F64 ARMv6-M core. Has support to configure [tomu bootloader] directly from an application via the `toboot_config` macro. [Tomu]: https://tomu.im/ [tomu bootloader]: https://github.com/im-tomu/tomu-bootloader @@ -538,6 +532,7 @@ Also check the list of [STMicroelectronics board support crates][stm-bsc]! - [Blogpost](https://robamu.github.io/post/rust-ecosystem/) ### Renesas + - [`da14531-hal`](https://crates.io/crates/da14531-hal) HAL crate for DA14531 Ultra-Low Power BT 5.1 System-on-Chip - [![crates.io](https://img.shields.io/crates/v/da14531-hal.svg)](https://crates.io/crates/da14531-hal) ### StarFive @@ -660,9 +655,7 @@ Crates tailored for specific boards. - [`pimoroni-pico-explorer`](https://github.com/rp-rs/rp-hal) - Board Support for the [Pimoroni Pico Explorer] - [`pimoroni-pico-lipo-16mb`](https://github.com/rp-rs/rp-hal) - Board Support for the [Pimoroni Pico Lipo 16MB] -[pimoroni-pico-explorer]: https://github.com/rp-rs/rp-hal/tree/main/boards/pimoroni-pico-explorer [Pimoroni Pico Explorer]: https://shop.pimoroni.com/products/pico-explorer-base -[pimoroni-pico-lipo-16mb]: https://github.com/rp-rs/rp-hal/tree/main/boards/pimoroni_pico_lipo_16mb [Pimoroni Pico Lipo 16MB]: https://shop.pimoroni.com/products/pimoroni-pico-lipo?variant=39335427080275 ### Raspberry Pi @@ -711,10 +704,10 @@ Crates tailored for specific boards. - [`stm32f429i-disc`](https://crates.io/crates/stm32f429i-disc) Board Support Crate for the [STM32F429DISCOVERY] (WIP) - [![crates.io](https://img.shields.io/crates/v/stm32f429i-disc.svg)](https://crates.io/crates/stm32f429i-disc) - [`stm32f3-discovery`](https://crates.io/crates/stm32f3-discovery) Board Support Crate for the [STM32F3DISCOVERY] used in [Rust Embedded Discovery book](https://rust-embedded.github.io/discovery/index.html) - [![crates.io](https://img.shields.io/crates/v/stm32f3-discovery)](https://crates.io/crates/stm32f3-discovery) - [Nucleo-F401RE]: https://www.st.com/en/evaluation-tools/nucleo-f401re.html ### Teensy + - [`teensy4-rs`](https://github.com/mciantyre/teensy4-rs) Board Support crate for the [Teensy 4.0] ### Vorago @@ -757,7 +750,6 @@ devices that go beyond what is available in [`embedded-hal`]: - [`embedded-storage`](https://github.com/rust-embedded-community/embedded-storage): An Embedded Storage Abstraction Layer - [`switch-hal`](https://github.com/rubberduck203/switch-hal): An "on"/"off" abstraction for input and output switches - [![crates.io](https://img.shields.io/crates/v/switch-hal.svg)](https://crates.io/crates/switch-hal) - ## Driver crates You can also find many of these drivers [on drive-rs](https://tweedegolf.github.io/drive-rs/); please consider adding your driver there ([in the GitHub repo](https://github.com/tweedegolf/drive-rs)) while we work to port everything across. @@ -772,7 +764,7 @@ The list below contains drivers that have achieved the "released" status. To add to this list, please ensure that your driver has a short blog post, article, or sufficiently explanatory README showing an example of its use. Ideally, this post would demonstrate using the device in a small project so that a Rust and/or embedded newcomer can also understand it. -Otherwise, please add it to the [WIP section](#WIP) below. +Otherwise, please add it to the [WIP section](#wip) below. 1. [AD983x] - SPI - AD9833/AD9837 waveform generators / DDS - [Intro blog post][25] - [![crates.io](https://img.shields.io/crates/v/ad983x.svg)](https://crates.io/crates/ad983x) 1. [adafruit-alphanum4] - I2C - Driver for [Adafruit 14-segment LED Alphanumeric Backpack][29] based on the ht16k33 chip - [![crates.io](https://img.shields.io/crates/v/adafruit-alphanum4.svg)](https://crates.io/crates/adafruit-alphanum4) @@ -1370,8 +1362,8 @@ These materials may be outdated and reflect earlier practices, but they might st This list is licensed under -- CC0 1.0 Universal License ([LICENSE-CC0](LICENSE-CC0) or - https://creativecommons.org/publicdomain/zero/1.0/legalcode) +- CC0 1.0 Universal License ([LICENSE-CC0](./LICENSE-CC0) or + [license](https://creativecommons.org/publicdomain/zero/1.0/legalcode)) ## Code of Conduct From 4b4e2fd8b8f4668ec666a85d53a7671b685dce8f Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:08:34 +0000 Subject: [PATCH 06/16] fixed license link --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 0325173..d81f49d 100644 --- a/README.md +++ b/README.md @@ -1363,7 +1363,7 @@ These materials may be outdated and reflect earlier practices, but they might st This list is licensed under - CC0 1.0 Universal License ([LICENSE-CC0](./LICENSE-CC0) or - [license](https://creativecommons.org/publicdomain/zero/1.0/legalcode)) + https://creativecommons.org/publicdomain/zero/1.0/legalcode) ## Code of Conduct From 264916b2e0e36da0c502459a62a53584cb79c3b7 Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:09:38 +0000 Subject: [PATCH 07/16] Updated Linting --- .github/workflows/{Static Analysis.yaml => Linting.yaml} | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename .github/workflows/{Static Analysis.yaml => Linting.yaml} (97%) diff --git a/.github/workflows/Static Analysis.yaml b/.github/workflows/Linting.yaml similarity index 97% rename from .github/workflows/Static Analysis.yaml rename to .github/workflows/Linting.yaml index 7df9a6e..da9f126 100644 --- a/.github/workflows/Static Analysis.yaml +++ b/.github/workflows/Linting.yaml @@ -2,7 +2,7 @@ name: Linting on: # yamllint disable-line rule:truthy - # push: null + push: null pull_request: null permissions: {} From 9045dfab4ca5f2b127f3324d32fe1ae951ec9e0f Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:18:22 +0000 Subject: [PATCH 08/16] Markdownlint settings --- .github/workflows/Linting.yaml | 2 ++ .markdownlint.yaml => .markdown-lint.yaml | 0 2 files changed, 2 insertions(+) rename .markdownlint.yaml => .markdown-lint.yaml (100%) diff --git a/.github/workflows/Linting.yaml b/.github/workflows/Linting.yaml index da9f126..95e8ed0 100644 --- a/.github/workflows/Linting.yaml +++ b/.github/workflows/Linting.yaml @@ -21,6 +21,8 @@ steps: - name: Checkout code uses: actions/checkout@v4 + with: + fetch-depth: 0 - name: Super-linter uses: super-linter/super-linter@v7.2.0 # x-release-please-version env: diff --git a/.markdownlint.yaml b/.markdown-lint.yaml similarity index 100% rename from .markdownlint.yaml rename to .markdown-lint.yaml From 1126bbcce102534a3269cbce10cd96158d8c4a00 Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:19:50 +0000 Subject: [PATCH 09/16] removing autofixes --- .github/workflows/Linting.yaml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/Linting.yaml b/.github/workflows/Linting.yaml index 95e8ed0..0346d22 100644 --- a/.github/workflows/Linting.yaml +++ b/.github/workflows/Linting.yaml @@ -29,6 +29,5 @@ # Linters VALIDATE_MARKDOWN: true VALIDATE_YAML: true - FIX_MARKDOWN: true ENABLE_GITHUB_ACTIONS_STEP_SUMMARY: true GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} From 6d82f450d6e8b5fba80b81fd3bc498949e658635 Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:23:54 +0000 Subject: [PATCH 10/16] renaming yaml files --- .github/workflows/{Linting.yaml => Linting.yml} | 0 .markdown-lint.yaml => .markdown-lint.yml | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename .github/workflows/{Linting.yaml => Linting.yml} (100%) rename .markdown-lint.yaml => .markdown-lint.yml (100%) diff --git a/.github/workflows/Linting.yaml b/.github/workflows/Linting.yml similarity index 100% rename from .github/workflows/Linting.yaml rename to .github/workflows/Linting.yml diff --git a/.markdown-lint.yaml b/.markdown-lint.yml similarity index 100% rename from .markdown-lint.yaml rename to .markdown-lint.yml From d78b1f39f687556c2972ed3ba5fb3c0295d67121 Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:28:00 +0000 Subject: [PATCH 11/16] Added markdownlint config file path --- .github/workflows/Linting.yml | 1 + .markdown-lint.yml => .markdownlint.yml | 0 2 files changed, 1 insertion(+) rename .markdown-lint.yml => .markdownlint.yml (100%) diff --git a/.github/workflows/Linting.yml b/.github/workflows/Linting.yml index 0346d22..c8a245d 100644 --- a/.github/workflows/Linting.yml +++ b/.github/workflows/Linting.yml @@ -29,5 +29,6 @@ # Linters VALIDATE_MARKDOWN: true VALIDATE_YAML: true + MARKDOWN_CONFIG_FILE: .markdownlint.yml ENABLE_GITHUB_ACTIONS_STEP_SUMMARY: true GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.markdown-lint.yml b/.markdownlint.yml similarity index 100% rename from .markdown-lint.yml rename to .markdownlint.yml From 5c10a13a6316f97d77ca1d8ac4f9b6f7f6c70f03 Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:30:21 +0000 Subject: [PATCH 12/16] changing path --- .github/workflows/Linting.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Linting.yml b/.github/workflows/Linting.yml index c8a245d..1cb7c28 100644 --- a/.github/workflows/Linting.yml +++ b/.github/workflows/Linting.yml @@ -29,6 +29,6 @@ # Linters VALIDATE_MARKDOWN: true VALIDATE_YAML: true - MARKDOWN_CONFIG_FILE: .markdownlint.yml + MARKDOWN_CONFIG_FILE: ./.markdownlint.yml ENABLE_GITHUB_ACTIONS_STEP_SUMMARY: true GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} From 121a1e41aad794aa41b1fa6078b0ad802a8f6e4f Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:32:28 +0000 Subject: [PATCH 13/16] Setting linter path --- .github/workflows/Linting.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/Linting.yml b/.github/workflows/Linting.yml index 1cb7c28..8a16193 100644 --- a/.github/workflows/Linting.yml +++ b/.github/workflows/Linting.yml @@ -29,6 +29,7 @@ # Linters VALIDATE_MARKDOWN: true VALIDATE_YAML: true - MARKDOWN_CONFIG_FILE: ./.markdownlint.yml + LINTER_RULES_PATH: ./ + MARKDOWN_CONFIG_FILE: .markdownlint.yml ENABLE_GITHUB_ACTIONS_STEP_SUMMARY: true GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} From 3da4b37007b18fbcfcb79e280d0b96f9d1696a6a Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:36:07 +0000 Subject: [PATCH 14/16] Fixing image --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index d81f49d..1bf81bb 100644 --- a/README.md +++ b/README.md @@ -5,7 +5,7 @@ This is a curated list of resources related to embedded and low-level programming in the Rust programming language, including a selection of useful crates. -[](http://www.rust-embedded.org) +[Rust Embedded Logo](http://www.rust-embedded.org) This project is developed and maintained by the [Resources team][team]. From ffa0888ba4faa33b842fc7ae9f9726cb1901bcfe Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:38:02 +0000 Subject: [PATCH 15/16] Fixing Badge --- README.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/README.md b/README.md index 1bf81bb..e480a46 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,6 @@ # Embedded Rust -[![Awesome](https://awesome.re/badge.svg)](https://awesome.re) -[![Static Analysis](https://github.com/rust-embedded/awesome-embedded-rust/actions/workflows/Static%20Analysis.yml/badge.svg?branch=master)](https://github.com/rust-embedded/awesome-embedded-rust/actions/workflows/Static%20Analysis.yml) +[![Awesome](https://awesome.re/badge.svg)](https://awesome.re) [![Linting](https://github.com/rust-embedded/awesome-embedded-rust/actions/workflows/Static%20Analysis.yml/badge.svg?branch=master)](https://github.com/rust-embedded/awesome-embedded-rust/actions/workflows/Static%20Analysis.yml) This is a curated list of resources related to embedded and low-level programming in the Rust programming language, including a selection of useful crates. From 6220679d2aca800b293f5fecd9a71d21ff7b2a77 Mon Sep 17 00:00:00 2001 From: Scott Date: Wed, 20 Nov 2024 22:39:18 +0000 Subject: [PATCH 16/16] removing ./ --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index e480a46..f08b6ae 100644 --- a/README.md +++ b/README.md @@ -1361,7 +1361,7 @@ These materials may be outdated and reflect earlier practices, but they might st This list is licensed under -- CC0 1.0 Universal License ([LICENSE-CC0](./LICENSE-CC0) or +- CC0 1.0 Universal License ([LICENSE-CC0](LICENSE-CC0) or https://creativecommons.org/publicdomain/zero/1.0/legalcode) ## Code of Conduct