View QP/C++ Revision History at: https://www.state-machine.com/qpcpp/history.html
NOTE: If you're interested in the latest QP/C++ version from GitHub, it is recommended that you clone this repo like that:
git clone https://github.com/QuantumLeaps/qpcpp --recurse-submodules --depth 1
However, the easiest and most recommended way of getting started with QP/C++ is to download the QP-bundle, as described below.
QP/C++ real-time event framework (RTEF) is a lightweight implementation of the asynchronous, event-driven Active Object (a.k.a. Actor) model of computation specifically designed for real-time embedded systems, such as microcontrollers (MCUs). QP/C++ is both a software infrastructure for building applications consisting of Active Objects (Actors) and a runtime environment for executing the Active Objects in a deterministic, real-time fashion. Additionally, QP/C++ Framework supports Hierarchical State Machines with which to specify the behavior of Active Objects [UML 2.5], [Sutter:10], [ROOM:94]. The QP/C++ Framework can be viewed as a modern, asynchronous, and truly event-driven real-time operating system (RTOS).
QP/C++ framework is part of the larger QP family consisting of the following QP editions:
QP Edition | Language | API | Safety Functions | Certification Artifacts | Licensing |
---|---|---|---|---|---|
QP/C | C (C11) | same as SafeQP/C | Selected Assertions | Req/Arch/Design | dual |
QP/C++ | C++ (C++17) | same as SafeQP/C++ | Selected Assertions | Req/Arch/Design | dual |
SafeQP/C | C (C11) | same as QP/C | All Safety Functions | Complete Certification Kit |
commercial |
SafeQP/C++ | C++ (C++17) | same as QP/C++ | All Safety Functions | Complete Certification Kit |
commercial |
The SafeQP/C and SafeQP/C++ frameworks were originally derived from QP/C and QP/C++, respectively, but were extensively reengineered for the safety market using compliant Software Safety Lifecycle (SSL). In this process, the QP framework functional model has been subjected to a full Hazard and Risk Analysis, which identified all areas of weakness within the functional model and API. These findings led to the creation of Safety Requirements and risk mitigation by Safety Functions, which were subsequently implemented, verified, and validated. The SafeQP frameworks are accompanied by the "SafeQP Certification Kits", which provide developers with ready-to-use artifacts, enabling them to save time, mitigate risk, and reduce costs during application certification for safety-critical devices in the industrial, medical, aerospace, and automotive industries. Please contact Quantum Leaps for more information about the SafeQP frameworks and the "Certification Kits".
NOTE: The SafeQP/C++ edition remain fully API- and functionally compatible with the corresponding standard QP/C++ framework. This ensures existing QP/C Applications can transition seamlessly to SafeQP/C++ without requiring any modifications. SafeQP/C edition retain QP/C++ Frameworks' hallmark features: a small memory footprint, excellent efficiency, and hard real-time performance.
The most recommended way to get started with QP/C++ is by downloading the QP-bundle, which includes QP/C as well as the QM modeling tool and the QTools collection. The main advantage of obtaining QP/C bundled together is that you get all components, tools, and examples all ready to go.
NOTE: Perhaps the most important fact to remember is that in embedded systems, nothing works until everything works. This means that you should always start with a working system and gradually evolve it, changing one thing at a time and making sure that it keeps working every step of the way.
The provided QP/C++ example projects, such as the super-simple Blinky, or a bit more advanced Dining Philosophers Problem (DPP), allow you to get started with a working project rather than starting from scratch. You should also always try one of the unmodified examples on one of the very inexpensive evaluation boards (such as STM32 NUCLEO-U545RE) that it was designed for, before attempting to immediately adapt the projects to your specific hardware. Only once an example project is built and runs on the evaluation board, can you use it as a starting point for your specific hardware and software development.
-
Video: "Getting Started with QP Real-Time Event Frameworks" provides instructions on how to download, install, and get started with QP.
-
AppNote: "Getting Started with QP Real-Time Event Frameworks" contains also a tutorial, in which you build a simple "Blinky" application.
-
"QP/C++ Tutorial" describes a series of progressively advanced QP/C++ example applications.
The open source GPL distribution of QP/C++ can be augmented by the "QP/C++ Extras", which provide more advanced QP/C++ features, such as:
- QS software tracing component (QP Spy)
- QXK real-time kernel component
- Static-analysis configuration and automation scripts for PC-Lint-Plus
- Test suite (based on the QUTest trace-based test harness) that demonstrates 100% lines of code and 100% MC/DC code coverage for QP/C++.
NOTE: The "QP/C++ Extras" are licensed commercially only and available to the commercial licensees with the active Support Term. Please contact Quantum Leaps technical support to get the matching "QP/C++ Extras" for the public QP/C++ version.
NOTE: The "QP/C++ Extras" are also available for evaluation (upon request).
The QP/C++ real-time event framework is licensed under the dual licensing model, with the following licensing options:
NOTE: The GPL requires that all modifications to the original code as well as your application code (Derivative Works as defined in the Copyright Law) must also be released under the terms of the GPL open source license.
- Closed-source licensing under one of Quantum Leaps commercial licenses, which are specifically designed for users interested in retaining the proprietary status of their code.
NOTE: If your company has a policy forbidding open source in your product, all QP frameworks can be licensed commercially, in which case you don't use any open source license and you do not violate your policy.
NOTE: The SafeQP frameworks and the accompanying "Certification Kits" are licensed commercially only.
The online HTML documentation for the latest version of QP/C++ is located at: https://www.state-machine.com/qpcpp
The offline HTML documentation for this particular version of QP/C++ is located in the sub-folder html (included in the QP/C++ releases). To view the offline documentation, open the file html/index.html in your web browser.
- Free Support Forum
- Bug Reports
- Feature Requests
- Quantum Leaps website
- Quantum Leaps licensing
- info@state-machine.com
If you like this project, please give it a star (in the upper-right corner of your browser window):