]> begriffs open source - freertos/summary
 
descriptionhttps://github.com/FreeRTOS/FreeRTOS-Kernel.git
last changeWed, 19 Mar 2025 09:31:22 +0000 (15:01 +0530)
readme

CMock Unit Tests codecov

Getting started

This repository contains FreeRTOS kernel source/header files and kernel ports only. This repository is referenced as a submodule in FreeRTOS/FreeRTOS repository, which contains pre-configured demo application projects under FreeRTOS/Demo directory.

The easiest way to use FreeRTOS is to start with one of the pre-configured demo application projects. That way you will have the correct FreeRTOS source files included, and the correct include paths configured. Once a demo application is building and executing you can remove the demo application files, and start to add in your own application source files. See the FreeRTOS Kernel Quick Start Guide for detailed instructions and other useful links.

Additionally, for FreeRTOS kernel feature information refer to the Developer Documentation, and API Reference.

Also for contributing and creating a Pull Request please refer to the instructions here.

FreeRTOS-Kernel V11.1.0 source code is part of the FreeRTOS 202406.00 LTS release.

Getting help

If you have any questions or need assistance troubleshooting your FreeRTOS project, we have an active community that can help on the FreeRTOS Community Support Forum.

To consume FreeRTOS-Kernel

Consume with CMake

If using CMake, it is recommended to use this repository using FetchContent. Add the following into your project’s main or a subdirectory’s CMakeLists.txt:

FetchContent_Declare( freertos_kernel
  GIT_REPOSITORY https://github.com/FreeRTOS/FreeRTOS-Kernel.git
  GIT_TAG        main #Note: Best practice to use specific git-hash or tagged version
)

In case you prefer to add it as a git submodule, do:

git submodule add https://github.com/FreeRTOS/FreeRTOS-Kernel.git <path of the submodule>
git submodule update --init
add_library(freertos_config INTERFACE)

target_include_directories(freertos_config SYSTEM
INTERFACE
    include
)

target_compile_definitions(freertos_config
  INTERFACE
    projCOVERAGE_TEST=0
)

In case you installed FreeRTOS-Kernel as a submodule, you will have to add it as a subdirectory:

add_subdirectory(${FREERTOS_PATH})
set( FREERTOS_HEAP "4" CACHE STRING "" FORCE)
# Select the native compile PORT
set( FREERTOS_PORT "GCC_POSIX" CACHE STRING "" FORCE)
# Select the cross-compile PORT
if (CMAKE_CROSSCOMPILING)
  set(FREERTOS_PORT "GCC_ARM_CA9" CACHE STRING "" FORCE)
endif()

FetchContent_MakeAvailable(freertos_kernel)
target_compile_definitions(freertos_config INTERFACE ${definitions})
target_compile_options(freertos_config INTERFACE ${options})

Consuming stand-alone - Cloning this repository

To clone using HTTPS:

git clone https://github.com/FreeRTOS/FreeRTOS-Kernel.git

Using SSH:

git clone git@github.com:FreeRTOS/FreeRTOS-Kernel.git

Repository structure

Code Formatting

FreeRTOS files are formatted using the “uncrustify” tool. The configuration file used by uncrustify can be found in the FreeRTOS/CI-CD-GitHub-Actions’s uncrustify.cfg file.

Line Endings

File checked into the FreeRTOS-Kernel repository use unix-style LF line endings for the best compatibility with git.

For optimal compatibility with Microsoft Windows tools, it is best to enable the git autocrlf feature. You can enable this setting for the current repository using the following command:

git config core.autocrlf true

Git History Optimizations

Some commits in this repository perform large refactors which touch many lines and lead to unwanted behavior when using the git blame command. You can configure git to ignore the list of large refactor commits in this repository with the following command:

git config blame.ignoreRevsFile .git-blame-ignore-revs

Spelling and Formatting

We recommend using Visual Studio Code, commonly referred to as VSCode, when working on the FreeRTOS-Kernel. The FreeRTOS-Kernel also uses cSpell as part of its spelling check. The config file for which can be found at cspell.config.yaml There is additionally a cSpell plugin for VSCode that can be used as well. .cSpellWords.txt contains words that are not traditionally found in an English dictionary. It is used by the spellchecker to verify the various jargon, variable names, and other odd words used in the FreeRTOS code base are correct. If your pull request fails to pass the spelling and you believe this is a mistake, then add the word to .cSpellWords.txt. When adding a word please then sort the list, which can be done by running the bash command: sort -u .cSpellWords.txt -o .cSpellWords.txt Note that only the FreeRTOS-Kernel Source Files, include, portable/MemMang, and portable/Common files are checked for proper spelling, and formatting at this time.

Third Party Tools

Visit this link for detailed information about third-party tools with FreeRTOS support.

shortlog
2025-03-19 ErickReyesRFreeRTOS MPU: Remove MPU region number check (#1261) main
2025-03-17 Gaurav-Aggarwal-AWSUse UBaseType_t for ullMachineTimerCompareRegisterBase...
2025-03-13 SaiiijchanRISC-V: refine fpu reg context offset (#1257)
2025-03-13 SaiiijchanRISC-V: refine fpu offset according to portFPU_REG_SIZE...
2025-03-06 Jonathan CubidesRISCV Add FPU context save (#1250)
2025-03-04 Stefan InnerhoferAdd an assert o catch overflow of recursive mutex count...
2025-03-04 Rahul KarAdd history.txt for release V11.2.0 (#1253)
2025-02-28 Rahul KarFix MISRA violations for Kernel release V11.2.0 (#1251)
2025-02-24 Gaurav-Aggarwal-AWSDisable stack overflow check for MPU ports (#1231)
2025-02-13 Bhoomika R SUpdate instruction to suppress SIGUSR1 in Posix with...
2025-02-13 John BoilesPOSIX Simulator: Assert if vPortYield called from a...
2025-02-12 Gaurav-Aggarwal-AWSInclude current task runtime in ulTaskGetRunTimeCounter...
2025-02-12 Bhoomika R SAdd instruction to suppress SIGUSR1 in Posix with LLDB...
2025-02-10 Sudeep Mohantyfix(freertos): Correct taskRESERVED_TASK_NAME_LENGTH...
2025-02-10 Graham SandersonRP2040: update FreeRTOS_Kernel_import.cmake to match...
2025-02-07 Jakub TymejczykFix GCC/Posix port compilation on FreeBSD (#1239) ...
...
tags
9 months ago V11.2.0 Autocreated by FreeRTOS Git Tools.
20 months ago V11.1.0 Autocreated by FreeRTOS Git Tools.
2 years ago V11.0.1 Autocreated by FreeRTOS Git Tools.
2 years ago V11.0.0 Autocreated by FreeRTOS Git Tools.
2 years ago V10.6.2 Autocreated by FreeRTOS Git Tools.
2 years ago V10.6.1 Autocreated by FreeRTOS Git Tools.
2 years ago V10.6.0 Autocreated by FreeRTOS Git Tools.
3 years ago V10.5.1 Autocreated by FreeRTOS Git Tools.
3 years ago V10.5.0 Autocreated by FreeRTOS Git Tools.
3 years ago V10.4.3-LTS-Patch-3 FreeRTOS-Kernel V10.4.3 LTS Patch 3
4 years ago V10.4.6 FreeRTOS-Kernel V10.4.6
4 years ago V10.4.3-LTS-Patch-2 FreeRTOS-Kernel V10.4.3 LTS Patch 2
4 years ago V202110.00-SMP FreeRTOS SMP Kernel V202110.00
4 years ago V10.4.5 FreeRTOS-Kernel V10.4.5
4 years ago V10.4.3-LTS-Patch-1 FreeRTOS-Kernel V10.4.3 LTS Patch 1
4 years ago V10.4.4 Autocreated by FreeRTOS Git Tools.
...
heads
9 months ago main
22 months ago smp