Skip to content

xEmbeddedTools/xmcu

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

README

Repository for xMCU project.

Overview

The xMCU is a Hardware Abstraction Layer (HAL) utilizing the power and flexibility of modern C++.

Our goals:

  • Modular SoC Support: Implement each System on Chip (SoC) as a separate Git submodule, enabling users to selectively download only necessary components tailored to their hardware.
  • Compile-Time Checks: Conduct thorough compile-time validation to ensure compatibility with available hardware resources such as GPIO pins, ADC channels, and other peripherals, minimizing runtime errors and optimizing resource utilization.
  • Embedded Documentation: Implement self-documenting practices within the codebase. This approach enables developers to leverage IDE features like code completion and error checking to catch potential issues early in the development process.
  • Minimal Dependencies: Utilize only CMSIS (Cortex Microcontroller Software Interface Standard) and the C++ Standard Library to maintain portability, reduce overhead, and promote compatibility across various microcontroller platforms.
  • Low Overhead Design: Design the HAL with a focus on minimizing memory footprint and processing overhead, optimizing performance for resource-constrained embedded environments.

Supported SOC:

  • ST
    • stm32l0 - rm0451
    • stm32wb - rm0434

Get started

First, add the xmcu submodule to your Git repository. The following command clones xmcu into the "externals" directory:

git submodule add https://github.com/xEmbeddedTools/xmcu.git externals/xmcu

Next, add the specific SoC submodule you are interested in. For example, to add stm32wb/rm0434:

cd externals/xmcu
git submodule update --init soc/ST/arm/m4/wb/rm0434/

Usage

Examples of usage you can find here (under development) in another repository.

Contribution and Support

We welcome contributions from the community to help improve and extend the xMCU Project. To ensure consistency and maintain quality, please adhere to our Coding Standards when contributing.

For support and questions, feel free to open an issue on GitHub or contact us at [email protected].

Roadmap

To view the detailed roadmap for this project, please visit our official page: https://xembedded.io/xmcu-roadmap/.

License

The xMCU Project is licensed under the Apache 2.0 License. See the LICENSE file for more details.