Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thirdpin/Zephyr-CMake-Helpers
This bunch of files allow building Zephyr application from the root folder
https://github.com/thirdpin/Zephyr-CMake-Helpers
Last synced: 29 days ago
JSON representation
This bunch of files allow building Zephyr application from the root folder
- Host: GitHub
- URL: https://github.com/thirdpin/Zephyr-CMake-Helpers
- Owner: thirdpin
- License: lgpl-3.0
- Created: 2021-04-27T22:53:31.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2022-05-27T16:06:54.000Z (over 2 years ago)
- Last Synced: 2024-08-04T01:14:23.390Z (4 months ago)
- Language: CMake
- Homepage:
- Size: 78.1 KB
- Stars: 2
- Watchers: 5
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: COPYING.LESSER
Awesome Lists containing this project
- awesome-zephyr-rtos - CMake Zephyr helpers - Enhance CMake automation for use with VS Code. (Tools / Editors & IDEs)
README
# CMake Zephyr helpers
## Overview
This bunch of files allow to build Zephyr application without West
(Zephyr’s meta-tool). It is very useful while using CMake-based IDEs.
E.g. in VS Code you can just push CMake build/configure button in
[CMake extension](https://github.com/microsoft/vscode-cmake-tools) panel.Zephyr supports to build by CMake, but with it lost some automatically
environment preparings. E.g. configurations set in West manifest. So these
scripts try to make up for the loss.## How to use
> **Note** Application root is not the root of your C/C++ project. See
> [Zephyr freestanding
> application](https://docs.zephyrproject.org/latest/develop/application/index.html#zephyr-freestanding-application).
>
> For this helpers the application root is assumed to be an "app" folder in
> project root directory.> **Note** If you want to setup CMake to build from the project root, not
> application root see "Use from root of project" section below.Add this repository as a submodule or Zephyr module somewhere in your project.
Copy **CMakeList.txt.app.template** directly into your project structure into
the root of your application (where "boards", "soc" and other
"out-of-tree" folders usually located) and rename it to **CMakeList.txt**. Path
to the helpers is assumed to be **/app/cmake/helpers**, but it can be any.You should list your application source files in **app/CMakeList.txt** as
usual by passing it to the `target_sources` CMake function.Customise your you IDE settings to set CMake source directory if it's needed.
For example for VS Code in **.vscode/settings.json** file add next line:```js
"cmake.sourceDirectory": "${workspaceFolder}/app"
```Now you can call CMake configure command from root folder with
```shell
cmake -Happ -Bbuild
```there `app` is your application root directory relative to the root of the
project.Another available and quite handy option to configure project is to use
**CMakePresets.json**. Copy it from the templates folder into the application
root. Correct some fields. Then you can run CMake configuration with```bash
cmake . -Happ --preset qemu_riscv32
```and build with
```bash
cmake --build ./app/build/qemu_riscv32
```If your IDE supports CMakePresets.json (VS Code do) when you can select preset
and trigger configure/build process from IDE.Finally you can use `west` to build and configure you application too if it's
needed but you should pass to it a path to application root (see `west` tool
help).### Use from root of project
If you don't want to move the root CMakeLists.txt to the application root, you
can leave it in the project root. Just simply:- copy **CMakeLists.txt.app.template** into your root dir and rename it to
**CMakeList.txt**;
- set path to helpers correctly;
- create **CMakeLists.txt** in application root;
- move everything after line `project(app C CXX ASM)` into the application root
**CMakeLists.txt**;
- append the toplevel **CMakeLists.txt** with
`add_subdirectory()`.It's done! You can configure and build your project. But remember that from now
there is no need in changing *CMake source directory* in your IDE settings and
during the command line build (you can get rid of `-H` arg).## Zephyr location
The preferred way is to define a Zephyr location in **.west/config** file. You
can do it with `zephyr.base` option (see [Zephyr
docs](https://docs.zephyrproject.org/latest/guides/west/config.html)).
`zephyr.base-prefer` option should be also set to `configfile` to override
`ZEPYR_BASE` env variable. Otherwise `ZEPYR_BASE` env varialble will be used as
the Zephyr location by helpers.You can also force the Zephyr location by setting `-DZEPHYR_BASE_LOC` CMake
argument.## Application source dir
Zephyr finds "out of tree" DTS-files in
[APPLICATION_SOURCE_DIR](https://docs.zephyrproject.org/latest/develop/application/index.html#devicetree-definitions).
Helpers sets this variable to your application root, but you can rewrite it by
setting `APPLICATION_SOURCE_DIR` manually with flag `-DAPPLICATION_SOURCE_DIR`
or with the `set` CMake function. Do it before including helpers boilerplate.
`APPLICATION_SOURCE_DIR` must be an absolute path.You also can set `DTS_ROOT` variable manualy to change DTS root without touching
application source dir. `DTS_ROOT` must be an absoulute path.## Out of tree board
You can use `-DOUT_OF_TREE_BOARD=ON` to let helpers know if your application
root contains out of tree board description. You also can set it manually with
`-DBOARD_ROOT` according to the Zephyr docs.Other arguments
===============You can use other arguments, like `CONF_FILE` and `BOARD` as usual. See details
about these in Zephyr docs.VS Code
=======For VS Code IDE you can use "cmake-variants.yaml.template". Propose and
description of this could be found in [CMake Tools extension
docs](https://vector-of-bool.github.io/docs/vscode-cmake-tools/variants.html).