summaryrefslogtreecommitdiff
path: root/tools/configure_zephyr.py
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2025-04-06 20:02:56 +0200
committerxengineering <me@xengineering.eu>2025-04-06 20:02:56 +0200
commitee1dea051b0a43c02cf56dfc6a812c1a32910bc6 (patch)
tree6f555191efc74f7ada207990a233466e953175b8 /tools/configure_zephyr.py
parentd19fc7e34f783b343e77b757c4f37aaadb5b66ca (diff)
parentda27d61588202d6b460e36d29a8789d206495bd6 (diff)
downloadiot-contact-ee1dea051b0a43c02cf56dfc6a812c1a32910bc6.tar
iot-contact-ee1dea051b0a43c02cf56dfc6a812c1a32910bc6.tar.zst
iot-contact-ee1dea051b0a43c02cf56dfc6a812c1a32910bc6.zip
Merge website and CMake to Meson transition
Building a website to structure and deploy the artifacts was planned and requires a well set-up build system to handle all the file paths targets and dependencies. Since multiple CMake Zephyr builds are required for the application firmware, bootloader firmware and the native_sim application firmware simulation CMake external project was used. Since this generates a build tree with a confusing structure Meson was evaluated. Finally the Meson build system was a good fit as top-level build system and allows external projects as an experimental feature if they can configure a Make-based build system which is given for Zephyr.
Diffstat (limited to 'tools/configure_zephyr.py')
-rwxr-xr-xtools/configure_zephyr.py52
1 files changed, 52 insertions, 0 deletions
diff --git a/tools/configure_zephyr.py b/tools/configure_zephyr.py
new file mode 100755
index 0000000..e709063
--- /dev/null
+++ b/tools/configure_zephyr.py
@@ -0,0 +1,52 @@
+#!/usr/bin/env python3
+
+
+# This Source Code Form is subject to the terms of the Mozilla Public License,
+# v. 2.0. If a copy of the MPL was not distributed with this file, You can
+# obtain one at https://mozilla.org/MPL/2.0/.
+
+
+import argparse
+import subprocess
+
+
+def main() -> None:
+ parser = argparse.ArgumentParser(
+ description="Configure a Zephyr CMake build",
+ )
+
+ parser.add_argument("-S", "--source-tree", required=True)
+ parser.add_argument("-B", "--build-tree", required=True)
+ parser.add_argument("-b", "--board", required=True)
+ parser.add_argument("-z", "--zephyr-base", required=True)
+ parser.add_argument("-m", "--zephyr-modules", required=False)
+ parser.add_argument("-c", "--extra-config", required=False)
+ parser.add_argument("-k", "--signing-key", required=False)
+ parser.add_argument("--prefix", required=False)
+ parser.add_argument("--libdir", required=False)
+ parser.add_argument("--bindir", required=False)
+
+ args = parser.parse_args()
+
+ command = [
+ "cmake",
+ f"-S{args.source_tree}",
+ f"-B{args.build_tree}",
+ f"-DBOARD={args.board}",
+ f"-DZEPHYR_BASE={args.zephyr_base}",
+ ]
+
+ if args.zephyr_modules is not None:
+ command.append(f"-DZEPHYR_MODULES={args.zephyr_modules}")
+
+ if args.extra_config is not None:
+ command.append(f"-DEXTRA_CONF_FILE={args.extra_config}")
+
+ if args.signing_key is not None:
+ command.append(f"-DCONFIG_BOOT_SIGNATURE_KEY_FILE=\"{args.signing_key}\"")
+
+ subprocess.run(command, shell=False, check=True)
+
+
+if __name__ == "__main__":
+ main()