-
Notifications
You must be signed in to change notification settings - Fork 6.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
RFC: Evolve C++ support with Pigweed #53851
Comments
I added the TSC label to make sure we get some eyes on this tomorrow. |
The Pigweed team is still working on slides to present. There are some delays due to recent turmoil at Google but we'll post them here once ready. |
Architecture review: Need feedback about duplicate logic. Pigweed provides a C++ interface or implement to Zephyr constructs which means some duplication. Does anyone object? Examples:
|
Arch Review:
AI: @yperess to bring to the attention of the TSC. |
Have these slides been created yet? |
Are the docs out of date for pigweed? Says Zephyr "In Progress" for a bunch of things. |
If Pigweed is not supposed to be used in-tree I see no reason for it to be included in the default west manifest. We really need to move towards not including everything in the upstream west manifest, but become better at advertising external modules that work with Zephyr. Our current approach does not scale. |
I think that the module management situation should be treated separately, it's not like one module less or more would make much of a difference at this point. |
I disagree. We need to start changing the situation at some point. This might as well be that point (instead of accepting it first only to remove it again later). |
Do you think that the fix is to drop modules? If that's the case sure, but I'd imagine more likely we'd come up with a way of managing what gets downloaded by default. |
Yes, I do believe the fix is to drop modules that are not used in-tree/do not require in-tree glue code from the upstream west manifest and become better at advertising these as external projects ("Works with Zephyr"). |
Agree we need to do something about this, will put this topic in the Arch WG meeting today (#54276) |
Include documentation about: - some C++ features via Pigweed - instructions how to setup Pigweed This PR addresses some aspects of zephyrproject-rtos#53851 by giving guidance but not making Pigweed the 'selected' approach to C++. Signed-off-by: Yuval Peress <peress@google.com> Signed-off-by: Keith Short <keithshort@google.com>
Include documentation about: - some C++ features via Pigweed - instructions how to setup Pigweed This PR addresses some aspects of zephyrproject-rtos#53851 by giving guidance but not making Pigweed the 'selected' approach to C++. Signed-off-by: Yuval Peress <peress@google.com> Signed-off-by: Keith Short <keithshort@google.com>
Include documentation about: - some C++ features via Pigweed - instructions how to setup Pigweed This PR addresses some aspects of zephyrproject-rtos#53851 by giving guidance but not making Pigweed the 'selected' approach to C++. Signed-off-by: Yuval Peress <peress@google.com> Signed-off-by: Keith Short <keithshort@google.com>
Origin
Pigweed
https://pigweed.dev/
https://pigweed.googlesource.com/pigweed/pigweed
Purpose
Pigweed is a collection of embedded specific utilities that aim at making embedded application development easier/faster.
Mode of integration
I would like this to be integrated as a module. Pigweed is highly complimentary to Zephyr and provides many great utilities for our developers. It should help reduce the overhead of new projects as well as offload some feature (mainly subsystem features) by leveraging what other teams are building. I would suggest putting this in github.com/zephyrproject-rtos/pigweed
Maintainership
Maintainers:
Collaborators:
Pull Request
#53760
License
Apache 2.0
Introduction
This RFC proposes adding Pigweed as a Zephyr module to provide developers a path to using C++ as the primary language in their Zephyr projects, and to provide Zephyr with a path to general C++ support.
Pigweed is an open source project that aims to make embedded software development more efficient, robust, and enjoyable. Pigweed's collection of libraries (known as modules in the Pigweed docs) are designed to enable modern C++ best practices in embedded projects without compromising performance, safety, or size. Pigweed achieves this through modularity, allowing projects to use only the modules they need without taking on additional, unused dependencies.
The core Pigweed team is staffed by Google, but the codebase (GitHub mirror) is open source and welcomes external contributions. Pigweed is shipping in numerous Google hardware products, and is also used widely outside of Google:
Problem description
"As of 2019, 25% of embedded development occurs in C++, and that share is growing" according to the 2019 Embedded Markets Study by EETimes and embedded.com. It is particularly common in cutting-edge projects such as robotics, drones, and machine learning.
One common motivation for using C++ rather than C is that C++ interfaces are more ergonomic and less error prone than their C counterparts. For example, Pigweed mutexes can be used with std::lock_guard, which ensures a mutex is released before leaving a function. Furthermore, they are compatible with Clang's thread safety annotations, which catch synchronization bugs during compilation.
Language Features, C++ Roadmap #45785, and C++ support in Zephyr #31281 give the impression that Zephyr only has basic C++ support, therefore embedded teams with a requirement to use C++ are unlikely to consider Zephyr as a viable first choice. The following issues are examples of Zephyr developers having trouble writing Zephyr projects in C++ or evolving Zephyr itself due to C++ support limitations:
Roadblocks to threading and synchronization support due to inflexible C++ toolchain issues
The implementation proposed in C++ Roadmap #45785 will not work with Clang. The roadmap proposes implementing gthr-posix.h from libstdc++ to support the standard library for threading and synchronization, such as std::thread and std::mutex. This requires integration with GCC’s libstdc++ and is not portable to other toolchains or standard library implementations.
Other examples of C++ toolchain issues:
Missing C++ coding guidelines
Establish C++ coding guidelines #45195 indicates that Zephyr is looking for a way to establish and enforce a C++ style guide.
Proposed changes
This RFC proposes to add Pigweed as a Zephyr module.
Enable robust C++ support in Zephyr through Pigweed interfaces
Pigweed provides C++ interfaces for RTOS primitives including threads, synchronization, time, and basic I/O. Developers using Pigweed and Zephyr can write software against those interfaces and use Zephyr’s implementations of those primitives:
Pigweed has robust C++ testing support:
Pigweed provides efficient embedded-friendly features that can be used instead of Standard Library classes:
And many more. See Module guides for the full list.
Enable threading and synchronization support through the pw namespace
Rather than requiring toolchain-specific integration for threading and synchronization, Pigweed provides API-compatible versions of the standard library classes in the pw namespace. Pigweed’s classes work the same as the standard library versions, but can be used anywhere without toolchain integration. And if the toolchain’s threading and synchronization features are supported, the pw classes become trivial wrappers around the standard library classes with Pigweed’s facade pattern.
Adopt Pigweed's C++ coding guidelines
Pigweed has a C++ style guide and Embedded C++ guide that could serve as the basis of Zephyr's C++ coding guidelines. The core Pigweed team will collaborate with the Zephyr team and Zephyr developers to evolve and expand the guides as new topics come up. Pigweed’s pw_presubmit module can be used to enforce the coding guidelines and code quality.
The text was updated successfully, but these errors were encountered: