diff --git a/.gitmodules b/.gitmodules
index 8c45f353d..c7d2d0150 100644
--- a/.gitmodules
+++ b/.gitmodules
@@ -1,3 +1,6 @@
[submodule "3rd_party"]
path = 3rd_party
url = https://github.com/QuantumLeaps/3rd_party.git
+[submodule "examples"]
+ path = examples
+ url = https://github.com/QuantumLeaps/qpcpp-examples
diff --git a/3rd_party b/3rd_party
index 2b7bb752b..025100adc 160000
--- a/3rd_party
+++ b/3rd_party
@@ -1 +1 @@
-Subproject commit 2b7bb752b7f137dc12138e8461c65994c899e831
+Subproject commit 025100adc4853702cd6ce6fa733b206c6a70ee8a
diff --git a/examples b/examples
new file mode 160000
index 000000000..9b8141914
--- /dev/null
+++ b/examples
@@ -0,0 +1 @@
+Subproject commit 9b8141914cce0d7320b1407c0c4c2448f046c271
diff --git a/examples/arm-cm/README.md b/examples/arm-cm/README.md
deleted file mode 100644
index cfb91ccde..000000000
--- a/examples/arm-cm/README.md
+++ /dev/null
@@ -1,146 +0,0 @@
-> **NOTE**
-This file is best viewed in a **markdown viewer**, such as the one built into GitHub. Markdown viewers are also available as plug-ins to popular Internet browsers.
-
-# About QP Examples for ARM Cortex-M (arm-cm)
-This directory provides QP examples for ARM Cortex-M based MCUs.
-
-These examples are intended to be used "as-is", or [adapted](#adapting-the-examples) for any ARM Cortex-M MCU that is not directly supported.
-
-
-
-
-
-> **NOTE**
-The most simplifying factor is that the QP-ports to Cortex-M don't need to change at all (the correct port is selected automatically based on the standard preprocessor macros provided by the compiler).
-
-# Example Applications
-This directory contains two types of example applications:
-- `blinky_` demonstrates a [simple "blinky" application](https://www.state-machine.com/qpc/tut_blinky.html) with only one Active Object that periodically blinks an on-board LED. The "blinky" example is intentionally minimal and demonstrates only the QV and QK kernels (QXK is not demonstrated). Also, this example does not demonstrate the [QP/Spy software tracing](https://www.state-machine.com/qtools/qpspy.html).
-
-- `dpp_` demonstrates a more complete ["DPP" application (Dining Philosophers Problem)](https://www.state-machine.com/qpc/tut_dpp.html), with multiple, communicating Active Objects. The "dpp" example demonstrates all three built-in kernels (QV, QK, and QXK). Also, this example demonstrates the [QP/Spy software tracing](https://www.state-machine.com/qtools/qpspy.html).
-
-# Supported Compilers
-The following compilers/toolchains for ARM Cortex-M are supported and demonstrated:
-- ARM-KEIL toolchain
-- GNU-ARM toolchain
-- IAR-ARM toolchain
-
-## Build Configurations
-- Debug
-- Release
-- Spy (only in the "DPP" examples)
-
-# Adapting the Examples
-With dozens of silicon vendors offering ARM Cortex-M MCUs, each providing hundreds if not thousands of MCU variants, it is *impossible* to offer direct support for each and every such MCU. But this is also not necessary because the already provided examples can be adapted relatively easily. The most important simplifying fact is that the [QP-ports to Cortex-M](https://www.state-machine.com/qpc/arm-cm.html) don't need to change at all.
-
-This is how you might go about an MCU that is not directly supported in the `qpc/examples/arm-cm`:
-
-- choose example that most closely matches your particular MCU. For instance, suppose that you're interested in NXP MKE02Z64VLC2, which is based on the Cortex-M0+ core, the closest are the examples for NUCLEO-C031C6 (also based on M0+)
-
-- choose the kernel you'd like to use. For example, assuming that you like QK, you are interested in the qk subdirectory.
-
-- choose the compiler you'd like to use. For example, assuming that you like GNU-ARM, you are interested in the gnu subdirectory
-
-- build the chosen example project. Again, it **doesn't matter** at this stage that it is not exactly your final hardware. Your objective is testing your QP installation and the compiler installation. You are also getting familiar with QP. These goals are worth but a few minutes of your time.
-
-- at this point, it is highly recommend that you just buy one of the supported ARM Cortex-M boards, which are carefully chosen to be very inexpensive. With your own board, you'd be able to run and debug the QP application at your desk, which is priceless because as you surely remember: *In embedded systems NOTING works until EVERYTHING works*.
-
-- only *after* you get started with a working example, you can try to modify it for your own board. This typically requires only changes to the BSP (Board Support Package), which is provided in the `bsp.c` file.
-
-
-# Code Organization
-The following listing shows a typical organization of the example code:
-```
-examples\arm-cm\dpp_nucleo-c031c6
-|
-+---qk // preemptive QK kernel
-| +---gnu // GNU-ARM toolchain
-| | \---targetConfigs
-| | Makefile // Makefile for GNU-ARM
-| +---armclang // ARM/KEIL toolchain with Compiler 6 (ARM/CLANG)
-| | dpp-qk.uvprojx // uVision project
-| \---iar // IAR EWARM
-| dpp-qk.eww // IAR EW-ARM workspace
-|
-\---qv // cooperative QK kernel
-| +---gnu // GNU-ARM toolchain
-| | \---targetConfigs
-| | Makefile // Makefile for GNU-ARM
-| +---armclang // ARM/KEIL toolchain with Compiler 6 (ARM/CLANG)
-| | dpp-qv.uvprojx // uVision project
-| \---iar // IAR EWARM
-| dpp-qv.eww // IAR EW-ARM workspace
-|
-+---qxk // preemptive, dual-mode QXK kernel
-| +---gnu // GNU-ARM toolchain
-| | \---targetConfigs
-| | Makefile // Makefile for GNU-ARM
-| +---armclang // ARM/KEIL toolchain with Compiler 6 (ARM/CLANG)
-| | dpp-qxk.uvprojx // uVision project
-| \---iar // IAR EWARM
-| dpp-qxk.eww // IAR EW-ARM workspace
-|
-```
-
-# Building the example
-
-### GNU/ARM
-- open terminal window
-- change to the desired directory (either `examples\arm-cm\dpp_nucleo-c031c6\qk\gnu`, `examples\arm-cm\dpp_nucleo-c031c6\qv\gnu`, or `examples\arm-cm\dpp_nucleo-c031c6\qxk\gnu`)
-- to build the default Debug configuration, type:
-
-```
-make
-```
-
-> **NOTE**
-The `make` utility for Windows is provided in the QTools collection for Windows.
-
-- to build the Release configuration, type:
-
-```
-make CONF=rel
-```
-
-- to build the Spy configuration, type:
-
-```
-make CONF=spy
-```
-
-
-### ARM/KEIL MDK
-- Open the provided KEIL uVision project (either `dpp-qk.uvprojx`, `dpp-qv.uvprojx`, or `dpp-qxk.uvprojx`)
-in Keil uVision IDE. Build/Debug/Download to the board from the IDE.
-- Change the build configuration in the "Project Target" drop-down menu.
-
-
-### IAR EWARM
-- Open the provided IAR EWARM workspace (either `dpp-qk.eww`, `dpp-qv.eww`, or `dpp-qxk.eww`)
-in IAR EWARM IDE. Build/Debug/Download to the board from the IDE.
-- Change the build configuration in the "Project Configuration" drop-down menu.
-
-
-
-# Tracing with QP/Spy
-When the board is flashed with the Spy build configuration, it produces the QP/Spy software tracing output to the built-in virtual COM port of the TivaC LauchPad board. The trace is binary rather than ASCII, and therefore requires a special host-based application called QSPY.
-
-> **NOTE** QSPY host application is available in the QTools collection.
-
-To launch the QSPY host application:
-- open terminal window
-- type:
-
-```
-qspy -c COM5
-```
-
-where "COM5" is an example virtual COM port enumerated by the board. You need to check the specific COM port number on your host computer using the Device Manager application, Ports (COM and LPT) section.
-
-
-The following screen shot shows a typical output from QSPY:
-
-
-
-Typical QSPY output produced by the Spy build configuration
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/README.md b/examples/arm-cm/blinky_ek-tm4c123gxl/README.md
deleted file mode 100644
index b8dd279b8..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/README.md
+++ /dev/null
@@ -1,81 +0,0 @@
-> **NOTE**
-This file is best viewed in a **markdown viewer**, such as the one built into GitHub. Markdown viewers are also available as plug-ins to popular Internet browsers.
-
-# Blinky on EK-TM4C123GXL
-This example implements the simple [Blinky application](https://www.state-machine.com/qpcpp/tut_blinky.html) on the EK-TM4C123GLX board (ARM Cortex-M4F). The example blinks the LED
-on the EK-TM4C123GXL board at 1Hz (0.5 seconds on, 0.5 seconds off).
-
-
-
-EK-TM4C123GXL (TivaC LaunchPad)
-
-
-## Features Demonstrated
-- cooperative QV kernel
- + with ARM-KEIL toolchain
- + with GNU-ARM toolchain
- + with IAR-ARM toolchain
-- preemptive run-to-completion QK kernel
- + with ARM-KEIL toolchain
- + with GNU-ARM toolchain
- + with IAR-ARM toolchain
-
-## Build Configurations
-- Debug
-- Release
-- Spy - NOT supported for the simple Blinky example
-
-# Code Organization
-```
-examples\arm-cm\blinky_ek-tm4c123gxl
-|
-+---qk // preemptive QK kernel
-| +---gnu // GNU-ARM toolchain
-| | Makefile // Makefile for GNU-ARM
-| +---armclang // ARM/KEIL toolchain with Compiler 6 (ARM/CLANG)
-| | blinky-qk.uvprojx // uVision project
-| \---iar // IAR EWARM
-| blinky-qk.eww // IAR EW-ARM workspace
-|
-\---qv // cooperative QK kernel
-| +---gnu // GNU-ARM toolchain
-| | Makefile // Makefile for GNU-ARM
-| +---armclang // ARM/KEIL toolchain with Compiler 6 (ARM/CLANG)
-| | blinky-qv.uvprojx // uVision project
-| \---iar // IAR EWARM
-| blinky-qv.eww // IAR EW-ARM workspace
-```
-
-# Building the example
-
-### GNU/ARM
-- open terminal window
-- change to the desired directory (either `examples\arm-cm\blinky_ek-tm4c123gxl\qk\gnu`
-or `examples\arm-cm\blinky_ek-tm4c123gxl\qv\gnu`)
-- to build the default Debug configuration, type:
-
-```
-make
-```
-
-> **NOTE**
-The `make` utility for Windows is provided in the QTools collection for Windows.
-
-- to build the Release configuration, type:
-
-```
-make CONF=rel
-```
-
-
-### ARM/KEIL MDK
-- Open the provided KEIL uVision project (either `blinky-qk.uvprojx` or `blinky-qv.uvprojx`)
-in Keil uVision IDE. Build/Debug/Download to the board from the IDE.
-- Change the build configuration in the "Project Target" drop-down menu.
-
-
-### IAR EWARM
-- Open the provided IAR EWARM workspace (either `blinky-qk.eww` or `blinky-qv.eww`)
-in IAR EWARM IDE. Build/Debug/Download to the board from the IDE.
-- Change the build configuration in the "Project Configuration" drop-down menu.
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/blinky.cpp b/examples/arm-cm/blinky_ek-tm4c123gxl/blinky.cpp
deleted file mode 100644
index 59d24191e..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/blinky.cpp
+++ /dev/null
@@ -1,123 +0,0 @@
-//============================================================================
-// QP/C++ Real-Time Embedded Framework (RTEF)
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-//! @date Last updated on: 2022-08-25
-//! @version Last updated Zephyr 3.1.99 and @ref qpcpp_7_1_0
-//!
-//! @file
-//! @brief Blinky example
-//!
-#include "qpcpp.hpp"
-#include "bsp.hpp"
-#include "blinky.hpp"
-
-// unnamed namespace for local definitions with internal linkage
-namespace {
-
-//Q_DEFINE_THIS_FILE
-
-} // unnamed namespace
-
-namespace APP {
-
-//............................................................................
-class Blinky : public QP::QActive {
-private:
- QP::QTimeEvt m_timeEvt;
-
-public:
- Blinky();
- static Blinky inst;
-
-protected:
- Q_STATE_DECL(initial);
- Q_STATE_DECL(off);
- Q_STATE_DECL(on);
-};
-
-// local objects --------------------------------------------------------------
-Blinky Blinky::inst;
-
-// global objects ------------------------------------------------------------
-QP::QActive * const AO_Blinky = &Blinky::inst; // opaque pointer
-
-//............................................................................
-Blinky::Blinky()
- : QP::QActive(&initial),
- m_timeEvt(this, TIMEOUT_SIG, 0U)
-{
- // empty
-}
-
-// HSM definition ------------------------------------------------------------
-Q_STATE_DEF(Blinky, initial) {
- (void)e; // unused parameter
-
- // arm the time event to expire in half a second and every half second
- m_timeEvt.armX(BSP::TICKS_PER_SEC/2U, BSP::TICKS_PER_SEC/2U);
- return tran(&off);
-}
-//............................................................................
-Q_STATE_DEF(Blinky, off) {
- QP::QState status;
- switch (e->sig) {
- case Q_ENTRY_SIG: {
- BSP::ledOff();
- status = Q_RET_HANDLED;
- break;
- }
- case TIMEOUT_SIG: {
- status = tran(&on);
- break;
- }
- default: {
- status = super(&top);
- break;
- }
- }
- return status;
-}
-//............................................................................
-Q_STATE_DEF(Blinky, on) {
- QP::QState status;
- switch (e->sig) {
- case Q_ENTRY_SIG: {
- BSP::ledOn();
- status = Q_RET_HANDLED;
- break;
- }
- case TIMEOUT_SIG: {
- status = tran(&off);
- break;
- }
- default: {
- status = super(&top);
- break;
- }
- }
- return status;
-}
-
-} // namespace APP
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/blinky.hpp b/examples/arm-cm/blinky_ek-tm4c123gxl/blinky.hpp
deleted file mode 100644
index 205c41ed1..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/blinky.hpp
+++ /dev/null
@@ -1,53 +0,0 @@
-//============================================================================
-// Blinky example
-// Last Updated for Version: 7.3.0
-// Date of the Last Update: 2023-08-24
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-
-#ifndef BLINKY_HPP_
-#define BLINKY_HPP_
-
-namespace APP {
-
-enum AppSignals : QP::QSignal {
- DUMMY_SIG = QP::Q_USER_SIG,
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG,
- MAX_SIG // the last signal
-};
-
-// opaque pointer to the Blinky AO
-extern QP::QActive * const AO_Blinky;
-
-} // namespace APP
-
-#endif // BLINKY_HPP_
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/bsp.hpp b/examples/arm-cm/blinky_ek-tm4c123gxl/bsp.hpp
deleted file mode 100644
index b9a8a7e1b..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/bsp.hpp
+++ /dev/null
@@ -1,50 +0,0 @@
-//============================================================================
-// Blinky example
-// Last Updated for Version: 7.3.0
-// Date of the Last Update: 2023-08-24
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef BSP_HPP_
-#define BSP_HPP_
-
-namespace BSP {
-
-constexpr std::uint32_t TICKS_PER_SEC {1000U};
-
-void init();
-void start();
-void terminate(std::int16_t const result);
-void ledOn(void);
-void ledOff(void);
-
-} // namespace BSP
-
-#endif // BSP_HPP_
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/ek-tm4c123gxl.jpg b/examples/arm-cm/blinky_ek-tm4c123gxl/ek-tm4c123gxl.jpg
deleted file mode 100644
index 5ed6188cd..000000000
Binary files a/examples/arm-cm/blinky_ek-tm4c123gxl/ek-tm4c123gxl.jpg and /dev/null differ
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/main.cpp b/examples/arm-cm/blinky_ek-tm4c123gxl/main.cpp
deleted file mode 100644
index b30685b92..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/main.cpp
+++ /dev/null
@@ -1,44 +0,0 @@
-//============================================================================
-// APP example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-09
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "blinky.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//............................................................................
-int main() {
- QP::QF::init(); // initialize the framework
- BSP::init(); // initialize the BSP
- BSP::start(); // start the AOs/Threads
- return QP::QF::run(); // run the QF application
-}
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/README.txt b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/README.txt
deleted file mode 100644
index 7cc9a7f3d..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/README.txt
+++ /dev/null
@@ -1,61 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-***
-NOTE: This example requires installing the following Software Pack
-in the Keil uVision: Keil::TM4C_DFP.
-***
-
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP/C framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size (for most embedded projects
-yyy should be 0, as the using the heap is not recommended).
-
-***
-NOTE:
-C++ programs seem not to tolerate heap size of 0. Therefore it is
-recommended to set the Heap_Size symbol to a minimal value of 16.
-***
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.sct b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.sct
deleted file mode 100644
index 458d5506e..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Adapted by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00040000 { ; load region size_region
- ER_IROM1 0x00000000 0x00040000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: assume STACK size 2048!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.uvoptx b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.uvoptx
deleted file mode 100644
index a419b9d48..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.uvoptx
+++ /dev/null
@@ -1,1004 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- DLGUARM
- ÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÈ`»
-´ª¤ô
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
-
-
- 0
- 0
- 686
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
- 0
- 0
- 686
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\blinky.cpp
- blinky.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
- 1
- 4
- 5
- 0
- 0
- 0
- ..\..\blinky.hpp
- blinky.hpp
- 0
- 0
-
-
- 1
- 5
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
-
-
- ek-tm4c123gxl
- 1
- 0
- 0
- 0
-
- 2
- 6
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
- system_TM4C123GH6PM.c
- 0
- 0
-
-
- 2
- 7
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
- TM4C123GH6PM.h
- 0
- 0
-
-
- 2
- 8
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
- startup_TM4C123GH6PM.s
- 0
- 0
-
-
- 2
- 9
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
- gpio.h
- 0
- 0
-
-
- 2
- 10
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
- rom.h
- 0
- 0
-
-
- 2
- 11
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
- sysctl.h
- 0
- 0
-
-
- 2
- 12
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
- system_TM4C123GH6PM.h
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 13
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qk\qk.cpp
- qk.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
- qk_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.uvprojx b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.uvprojx
deleted file mode 100644
index 935af2627..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/armclang/blinky-qk.uvprojx
+++ /dev/null
@@ -1,1792 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- blinky-qk
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\blinky-qk.bin .\dbg\blinky-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- blinky-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- blinky-qk
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\blinky-qk.bin .\rel\blinky-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- blinky-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- blinky-qk
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\blinky-qk.bin .\spy\blinky-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- Q_SPY
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- blinky-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/bsp.cpp b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/bsp.cpp
deleted file mode 100644
index d39a74f79..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/bsp.cpp
+++ /dev/null
@@ -1,252 +0,0 @@
-//============================================================================
-// Blinky example, EK-TM4C123GXL board, QK kernel
-// Last updated for: @ref qpcpp_7_3_0
-// Last updated on 2023-08-24
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "blinky.hpp" // Blinky Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "TM4C123GH6PM.h" // the device specific header (TI)
-#include "rom.h" // the built-in ROM functions (TI)
-#include "sysctl.h" // system control driver (TI)
-#include "gpio.h" // GPIO driver (TI)
-// add other drivers if necessary...
-
-#ifdef Q_SPY
- #error Simple Blinky Application does not provide Spy build configuration
-#endif
-
-namespace { // unnamed local namespace
-
-//Q_DEFINE_THIS_FILE
-
-} // unnamed local namespace
-
-// Local-scope defines -------------------------------------------------------
-#define LED_RED (1U << 1U)
-#define LED_GREEN (1U << 3U)
-#define LED_BLUE (1U << 2U)
-
-#define BTN_SW1 (1U << 4U)
-#define BTN_SW2 (1U << 0U)
-
-//============================================================================
-// Error handler and ISRs...
-
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the assertion handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up all LEDs
- GPIOF_AHB->DATA_Bits[LED_GREEN | LED_RED | LED_BLUE] = 0xFFU;
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#endif
-
- NVIC_SystemReset();
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QK_ISR_ENTRY(); // inform QK about entering an ISR
-
- QP::QTimeEvt::TICK_X(0U, nullptr); // process time events at rate 0
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QV
-
- // enable clock for to the peripherals used by this application...
- SYSCTL->RCGCGPIO |= (1U << 5U); // enable Run mode for GPIOF
- SYSCTL->GPIOHBCTL |= (1U << 5U); // enable AHB for GPIOF
- __ISB();
- __DSB();
-
- // configure LEDs (digital output)
- GPIOF_AHB->DIR |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DEN |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DATA_Bits[LED_RED | LED_BLUE | LED_GREEN] = 0U;
-
- // configure switches...
-
- // unlock access to the SW2 pin because it is PROTECTED
- GPIOF_AHB->LOCK = 0x4C4F434BU; // unlock GPIOCR register for SW2
- // commit the write (cast const away)
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x01U;
-
- GPIOF_AHB->DIR &= ~(BTN_SW1 | BTN_SW2); // input
- GPIOF_AHB->DEN |= (BTN_SW1 | BTN_SW2); // digital enable
- GPIOF_AHB->PUR |= (BTN_SW1 | BTN_SW2); // pull-up resistor enable
-
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x00U;
- GPIOF_AHB->LOCK = 0x0; // lock GPIOCR register for SW2
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(QP::QEvt) smlPoolSto[20];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // instantiate and start AOs/threads...
-
- static QP::QEvt const *blinkyQueueSto[10];
- APP::AO_Blinky->start(
- 1U, // QP prio. of the AO
- blinkyQueueSto, // event queue storage
- Q_DIM(blinkyQueueSto), // queue length [events]
- nullptr, 0U, // no stack storage
- nullptr); // no initialization param
-}
-//............................................................................
-void ledOn() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0xFFU;
-}
-//............................................................................
-void ledOff() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0x00U;
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QK::onIdle() {
-
- // toggle the User LED on and then off, see NOTE2
- QF_INT_DISABLE();
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0xFFU; // turn the Blue LED on
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0U; // turn the Blue LED off
- QF_INT_ENABLE();
-
-#ifdef NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- __WFI(); // Wait-For-Interrupt
-#endif
-}
-
-
-} // namespace QP
-
-//============================================================================
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call any QF services. These ISRs
-// are "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call any QF services. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// One of the LEDs is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop. Please note
-// that the LED is toggled with interrupts locked, so no interrupt execution
-// time contributes to the brightness of the User LED.
-//
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/Makefile b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/Makefile
deleted file mode 100644
index 782edff70..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/Makefile
+++ /dev/null
@@ -1,309 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EK-TM4C123GXL, QK kernel, GNU-ARM
-# Last Updated for Version: 7.0.1
-# Date of the Last Update: 2022-05-23
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005-2021 Quantum Leaps, LLC. All rights reserved.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# http://sourceforge.net/projects/qpc/files/Qtools/
-#
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := blinky-qk
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qk/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qk \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/ek-tm4c123gxl \
- $(QPCPP)/3rd_party/ek-tm4c123gxl/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/ek-tm4c123gxl
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_TM4C123GH6PM.c \
- startup_TM4C123GH6PM.c
-
-# C++ source files
-CPP_SRCS := \
- blinky.cpp \
- bsp.cpp \
- main.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qk.cpp \
- qk_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DTARGET_IS_TM4C123_RB1
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=vfp
-FLOAT_ABI := -mfloat-abi=softfp
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically, you should not need to change anything below this line
-
-# basic utilities (included in Qtools for Windows), see:
-# http://sourceforge.net/projects/qpc/files/Qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M4F
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O1 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O1 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-.PHONY : clean
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/README.txt b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/README.txt
deleted file mode 100644
index 18bf73076..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/README.txt
+++ /dev/null
@@ -1,71 +0,0 @@
-About this Example
-==================
-This example can be built in two different ways:
-- from the command prompt with the provided Makefile.
-- from the TI Code Composer Studio with the provided CCS project.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-Also, the Makefile has been specifically designed to work as an external
-Makefile with the Eclipse CDT.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\gcc\startup_TM4C123GH6PM.c
-
-The file startup_TM4C123GH6PM.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/blinky-qk.ld b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/blinky-qk.ld
deleted file mode 100644
index 5139ce62b..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/blinky-qk.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EK-TM4C123GXL, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* Web : http://www.state-machine.com
-* Email: info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Tiva TM4C123GH6PM */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/flash.bat b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/flash.bat
deleted file mode 100644
index cb2a3886e..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/gnu/flash.bat
+++ /dev/null
@@ -1,33 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EK-TM4C123GXL
-::
-:: NOTE: requires the LMFlash programmer (included in QTools for Windows)
-::
-@echo off
-setlocal
-
-@echo Load a given binary file to the flash of EK-TM4C123GXL
-@echo usage: flash binary-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: The following symbol LMFLASH assumes that LMFlash.exe can
-:: be found on the PATH. You might need to adjust this symbol to the
-:: location of the LMFlash utility on your machine
-::
-set LMFLASH=LMFlash.exe
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-%LMFLASH% -q ek-tm4c123gxl -e -v -r %1
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/README.txt b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/README.txt
deleted file mode 100644
index b4203fb7b..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-------------
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.ewd b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.ewd
deleted file mode 100644
index e0a637de4..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.ewp b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.ewp
deleted file mode 100644
index c8a827584..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.ewp
+++ /dev/null
@@ -1,3347 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\..\blinky.cpp
-
-
- $PROJ_DIR$\..\..\blinky.hpp
-
-
- $PROJ_DIR$\..\..\blinky.hpp
-
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
-
- ek-tm4c123gxl
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qk\qk.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qk\iar\qk_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.eww b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.eww
deleted file mode 100644
index c99248567..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\blinky-qk.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.icf b/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.icf
deleted file mode 100644
index 0fdfc4b30..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qk/iar/blinky-qk.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK };
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/README.txt b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/README.txt
deleted file mode 100644
index 7cc9a7f3d..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/README.txt
+++ /dev/null
@@ -1,61 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-***
-NOTE: This example requires installing the following Software Pack
-in the Keil uVision: Keil::TM4C_DFP.
-***
-
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP/C framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size (for most embedded projects
-yyy should be 0, as the using the heap is not recommended).
-
-***
-NOTE:
-C++ programs seem not to tolerate heap size of 0. Therefore it is
-recommended to set the Heap_Size symbol to a minimal value of 16.
-***
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.sct b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.sct
deleted file mode 100644
index 458d5506e..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Adapted by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00040000 { ; load region size_region
- ER_IROM1 0x00000000 0x00040000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: assume STACK size 2048!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.uvoptx b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.uvoptx
deleted file mode 100644
index 73f617990..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.uvoptx
+++ /dev/null
@@ -1,976 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- DLGUARM
- ÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÈ`F
-X0ÂiôîA
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- DLGUARM
- ÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÈ`»
-´ª¤ô
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\blinky.cpp
- blinky.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
- 1
- 4
- 5
- 0
- 0
- 0
- ..\..\blinky.hpp
- blinky.hpp
- 0
- 0
-
-
- 1
- 5
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
-
-
- ek-tm4c123gxl
- 1
- 0
- 0
- 0
-
- 2
- 6
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
- system_TM4C123GH6PM.c
- 0
- 0
-
-
- 2
- 7
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
- TM4C123GH6PM.h
- 0
- 0
-
-
- 2
- 8
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
- startup_TM4C123GH6PM.s
- 0
- 0
-
-
- 2
- 9
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
- gpio.h
- 0
- 0
-
-
- 2
- 10
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
- rom.h
- 0
- 0
-
-
- 2
- 11
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
- sysctl.h
- 0
- 0
-
-
- 2
- 12
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
- system_TM4C123GH6PM.h
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 13
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qv\qv.cpp
- qv.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
- qv_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.uvprojx b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.uvprojx
deleted file mode 100644
index 6f82168af..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/armclang/blinky-qv.uvprojx
+++ /dev/null
@@ -1,1792 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- blinky-qv
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\blinky-qv.bin .\dbg\blinky-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- blinky-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
- 5060020::V5.06 (build 20)::ARMCC
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- blinky-qv
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\blinky-qv.bin .\rel\blinky-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- blinky-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
- 5060020::V5.06 (build 20)::ARMCC
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- blinky-qv
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\blinky-qv.bin .\spy\blinky-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- Q_SPY
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- blinky-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/bsp.cpp b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/bsp.cpp
deleted file mode 100644
index 5851393f3..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/bsp.cpp
+++ /dev/null
@@ -1,252 +0,0 @@
-//============================================================================
-// Blinky example, EK-TM4C123GXL board, QV kernel
-// Last updated for: @ref qpcpp_7_3_0
-// Last updated on 2023-08-24
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "blinky.hpp" // Blinky Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "TM4C123GH6PM.h" // the device specific header (TI)
-#include "rom.h" // the built-in ROM functions (TI)
-#include "sysctl.h" // system control driver (TI)
-#include "gpio.h" // GPIO driver (TI)
-// add other drivers if necessary...
-
-#ifdef Q_SPY
- #error Simple Blinky Application does not provide Spy build configuration
-#endif
-
-namespace { // unnamed local namespace
-
-//Q_DEFINE_THIS_FILE
-
-} // unnamed local namespace
-
-// Local-scope defines -------------------------------------------------------
-#define LED_RED (1U << 1U)
-#define LED_GREEN (1U << 3U)
-#define LED_BLUE (1U << 2U)
-
-#define BTN_SW1 (1U << 4U)
-#define BTN_SW2 (1U << 0U)
-
-//============================================================================
-// Error handler and ISRs...
-
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up all LEDs
- GPIOF_AHB->DATA_Bits[LED_GREEN | LED_RED | LED_BLUE] = 0xFFU;
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#endif
-
- NVIC_SystemReset();
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-//............................................................................
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QP::QTimeEvt::TICK_X(0U, nullptr); // process time events at rate 0
-}
-
-} // extern "C"
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QV
-
- // enable clock for to the peripherals used by this application...
- SYSCTL->RCGCGPIO |= (1U << 5U); // enable Run mode for GPIOF
- SYSCTL->GPIOHBCTL |= (1U << 5U); // enable AHB for GPIOF
- __ISB();
- __DSB();
-
- // configure LEDs (digital output)
- GPIOF_AHB->DIR |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DEN |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DATA_Bits[LED_RED | LED_BLUE | LED_GREEN] = 0U;
-
- // configure switches...
-
- // unlock access to the SW2 pin because it is PROTECTED
- GPIOF_AHB->LOCK = 0x4C4F434BU; // unlock GPIOCR register for SW2
- // commit the write (cast const away)
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x01U;
-
- GPIOF_AHB->DIR &= ~(BTN_SW1 | BTN_SW2); // input
- GPIOF_AHB->DEN |= (BTN_SW1 | BTN_SW2); // digital enable
- GPIOF_AHB->PUR |= (BTN_SW1 | BTN_SW2); // pull-up resistor enable
-
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x00U;
- GPIOF_AHB->LOCK = 0x0; // lock GPIOCR register for SW2
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(QP::QEvt) smlPoolSto[200];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // instantiate and start AOs/threads...
-
- static QP::QEvt const *blinkyQueueSto[10];
- APP::AO_Blinky->start(
- 1U, // QP prio. of the AO
- blinkyQueueSto, // event queue storage
- Q_DIM(blinkyQueueSto), // queue length [events]
- nullptr, 0U, // no stack storage
- nullptr); // no initialization param
-}
-//............................................................................
-void ledOn() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0xFFU;
-}
-//............................................................................
-void ledOff() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0x00U;
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-namespace QP {
-
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP_TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI);
- // ...
-
- // enable IRQs...
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QV::onIdle() { // CATION: called with interrupts DISABLED, NOTE0
-
- // toggle the User LED on and then off, see NOTE2
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0xFFU; // turn the Blue LED on
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0U; // turn the Blue LED off
-
-#ifdef NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- QV_CPU_SLEEP(); // atomically go to sleep and enable interrupts
-#else
- QF_INT_ENABLE(); // just enable interrupts
-#endif
-}
-
-
-} // namespace QP
-
-//============================================================================
-// NOTE0:
-// The QV::onIdle() callback is called with interrupts disabled, because the
-// determination of the idle condition might change by any interrupt posting
-// an event. QV::onIdle() must internally enable interrupts, ideally
-// atomically with putting the CPU to the power-saving mode.
-//
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call any QF services. These ISRs
-// are "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call any QF services. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// One of the LEDs is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop. Please note
-// that the LED is toggled with interrupts locked, so no interrupt execution
-// time contributes to the brightness of the User LED.
-//
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/Makefile b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/Makefile
deleted file mode 100644
index 03ce5132c..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/Makefile
+++ /dev/null
@@ -1,309 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EK-TM4C123GXL, QV kernel, GNU-ARM
-# Last Updated for Version: 7.0.1
-# Date of the Last Update: 2022-05-23
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005-2021 Quantum Leaps, LLC. All rights reserved.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# http://sourceforge.net/projects/qpc/files/Qtools/
-#
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := blinky-qv
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qv/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qv \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/ek-tm4c123gxl \
- $(QPCPP)/3rd_party/ek-tm4c123gxl/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/ek-tm4c123gxl
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_TM4C123GH6PM.c \
- startup_TM4C123GH6PM.c
-
-# C++ source files
-CPP_SRCS := \
- blinky.cpp \
- bsp.cpp \
- main.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qv.cpp \
- qv_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DTARGET_IS_TM4C123_RB1
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=vfp
-FLOAT_ABI := -mfloat-abi=softfp
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically, you should not need to change anything below this line
-
-# basic utilities (included in Qtools for Windows), see:
-# http://sourceforge.net/projects/qpc/files/Qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M4F
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O3 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O3 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-.PHONY : clean
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/README.txt b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/README.txt
deleted file mode 100644
index 18bf73076..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/README.txt
+++ /dev/null
@@ -1,71 +0,0 @@
-About this Example
-==================
-This example can be built in two different ways:
-- from the command prompt with the provided Makefile.
-- from the TI Code Composer Studio with the provided CCS project.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-Also, the Makefile has been specifically designed to work as an external
-Makefile with the Eclipse CDT.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\gcc\startup_TM4C123GH6PM.c
-
-The file startup_TM4C123GH6PM.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/blinky-qv.ld b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/blinky-qv.ld
deleted file mode 100644
index 5139ce62b..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/blinky-qv.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EK-TM4C123GXL, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* Web : http://www.state-machine.com
-* Email: info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Tiva TM4C123GH6PM */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/flash.bat b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/flash.bat
deleted file mode 100644
index cb2a3886e..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/gnu/flash.bat
+++ /dev/null
@@ -1,33 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EK-TM4C123GXL
-::
-:: NOTE: requires the LMFlash programmer (included in QTools for Windows)
-::
-@echo off
-setlocal
-
-@echo Load a given binary file to the flash of EK-TM4C123GXL
-@echo usage: flash binary-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: The following symbol LMFLASH assumes that LMFlash.exe can
-:: be found on the PATH. You might need to adjust this symbol to the
-:: location of the LMFlash utility on your machine
-::
-set LMFLASH=LMFlash.exe
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-%LMFLASH% -q ek-tm4c123gxl -e -v -r %1
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/README.txt b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/README.txt
deleted file mode 100644
index b4203fb7b..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-------------
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.ewd b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.ewd
deleted file mode 100644
index f32068d93..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.ewp b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.ewp
deleted file mode 100644
index 83deee62d..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.ewp
+++ /dev/null
@@ -1,3341 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\..\blinky.cpp
-
-
- $PROJ_DIR$\..\..\blinky.hpp
-
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
-
- ek-tm4c123gxl
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qv\qv.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qv\iar\qv_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.eww b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.eww
deleted file mode 100644
index fa7c77317..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\blinky-qv.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.icf b/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.icf
deleted file mode 100644
index 0fdfc4b30..000000000
--- a/examples/arm-cm/blinky_ek-tm4c123gxl/qv/iar/blinky-qv.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK };
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/README.md b/examples/arm-cm/blinky_nucleo-c031c6/README.md
deleted file mode 100644
index ba383678f..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/README.md
+++ /dev/null
@@ -1,80 +0,0 @@
-> **NOTE**
-This file is best viewed in a **markdown viewer**, such as the one built into GitHub. Markdown viewers are also available as plug-ins to popular Internet browsers.
-
-# Blinky on NUCLEO-C031C6
-This example demonstrates the [Blinky application](https://www.state-machine.com/qpcpp/tut_blinky.html) on the STM32 NUCLEO-C031C6 board (ARM Cortex-M0+).
-
-
-
-STM32 NUCLEO-C031C6
-
-
-## Features Demonstrated
-- cooperative QV kernel
- + with ARM-KEIL toolchain
- + with GNU-ARM toolchain
- + with IAR-ARM toolchain
-- preemptive run-to-completion QK kernel
- + with ARM-KEIL toolchain
- + with GNU-ARM toolchain
- + with IAR-ARM toolchain
-
-## Build Configurations
-- Debug
-- Release
-- Spy - NOT supported for the simple Blinky example
-
-# Code Organization
-```
-examples\arm-cm\blinky_nucleo-c031c6
-|
-+---qk // preemptive QK kernel
-| +---gnu // GNU-ARM toolchain
-| | Makefile // Makefile for GNU-ARM
-| +---armclang // ARM/KEIL toolchain with Compiler 6 (ARM/CLANG)
-| | blinky-qk.uvprojx // uVision project
-| \---iar // IAR EWARM
-| blinky-qk.eww // IAR EW-ARM workspace
-|
-\---qv // cooperative QK kernel
-| +---gnu // GNU-ARM toolchain
-| | Makefile // Makefile for GNU-ARM
-| +---armclang // ARM/KEIL toolchain with Compiler 6 (ARM/CLANG)
-| | blinky-qv.uvprojx // uVision project
-| \---iar // IAR EWARM
-| blinky-qv.eww // IAR EW-ARM workspace
-```
-
-# Building the example
-
-### GNU/ARM
-- open terminal window
-- change to the desired directory (either `examples\arm-cm\blinky_nucleo-c031c6\qk\gnu`
-or `examples\arm-cm\blinky_nucleo-c031c6\qv\gnu`)
-- to build the default Debug configuration, type:
-
-```
-make
-```
-
-> **NOTE**
-The `make` utility for Windows is provided in the QTools collection for Windows.
-
-- to build the Release configuration, type:
-
-```
-make CONF=rel
-```
-
-
-### ARM/KEIL MDK
-- Open the provided KEIL uVision project (either `blinky-qk.uvprojx` or `blinky-qv.uvprojx`)
-in Keil uVision IDE. Build/Debug/Download to the board from the IDE.
-- Change the build configuration in the "Project Target" drop-down menu.
-
-
-### IAR EWARM
-- Open the provided IAR EWARM workspace (either `blinky-qk.eww` or `blinky-qv.eww`)
-in IAR EWARM IDE. Build/Debug/Download to the board from the IDE.
-- Change the build configuration in the "Project Configuration" drop-down menu.
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/blinky.cpp b/examples/arm-cm/blinky_nucleo-c031c6/blinky.cpp
deleted file mode 100644
index 59d24191e..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/blinky.cpp
+++ /dev/null
@@ -1,123 +0,0 @@
-//============================================================================
-// QP/C++ Real-Time Embedded Framework (RTEF)
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-//! @date Last updated on: 2022-08-25
-//! @version Last updated Zephyr 3.1.99 and @ref qpcpp_7_1_0
-//!
-//! @file
-//! @brief Blinky example
-//!
-#include "qpcpp.hpp"
-#include "bsp.hpp"
-#include "blinky.hpp"
-
-// unnamed namespace for local definitions with internal linkage
-namespace {
-
-//Q_DEFINE_THIS_FILE
-
-} // unnamed namespace
-
-namespace APP {
-
-//............................................................................
-class Blinky : public QP::QActive {
-private:
- QP::QTimeEvt m_timeEvt;
-
-public:
- Blinky();
- static Blinky inst;
-
-protected:
- Q_STATE_DECL(initial);
- Q_STATE_DECL(off);
- Q_STATE_DECL(on);
-};
-
-// local objects --------------------------------------------------------------
-Blinky Blinky::inst;
-
-// global objects ------------------------------------------------------------
-QP::QActive * const AO_Blinky = &Blinky::inst; // opaque pointer
-
-//............................................................................
-Blinky::Blinky()
- : QP::QActive(&initial),
- m_timeEvt(this, TIMEOUT_SIG, 0U)
-{
- // empty
-}
-
-// HSM definition ------------------------------------------------------------
-Q_STATE_DEF(Blinky, initial) {
- (void)e; // unused parameter
-
- // arm the time event to expire in half a second and every half second
- m_timeEvt.armX(BSP::TICKS_PER_SEC/2U, BSP::TICKS_PER_SEC/2U);
- return tran(&off);
-}
-//............................................................................
-Q_STATE_DEF(Blinky, off) {
- QP::QState status;
- switch (e->sig) {
- case Q_ENTRY_SIG: {
- BSP::ledOff();
- status = Q_RET_HANDLED;
- break;
- }
- case TIMEOUT_SIG: {
- status = tran(&on);
- break;
- }
- default: {
- status = super(&top);
- break;
- }
- }
- return status;
-}
-//............................................................................
-Q_STATE_DEF(Blinky, on) {
- QP::QState status;
- switch (e->sig) {
- case Q_ENTRY_SIG: {
- BSP::ledOn();
- status = Q_RET_HANDLED;
- break;
- }
- case TIMEOUT_SIG: {
- status = tran(&off);
- break;
- }
- default: {
- status = super(&top);
- break;
- }
- }
- return status;
-}
-
-} // namespace APP
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/blinky.hpp b/examples/arm-cm/blinky_nucleo-c031c6/blinky.hpp
deleted file mode 100644
index 205c41ed1..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/blinky.hpp
+++ /dev/null
@@ -1,53 +0,0 @@
-//============================================================================
-// Blinky example
-// Last Updated for Version: 7.3.0
-// Date of the Last Update: 2023-08-24
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-
-#ifndef BLINKY_HPP_
-#define BLINKY_HPP_
-
-namespace APP {
-
-enum AppSignals : QP::QSignal {
- DUMMY_SIG = QP::Q_USER_SIG,
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG,
- MAX_SIG // the last signal
-};
-
-// opaque pointer to the Blinky AO
-extern QP::QActive * const AO_Blinky;
-
-} // namespace APP
-
-#endif // BLINKY_HPP_
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/bsp.hpp b/examples/arm-cm/blinky_nucleo-c031c6/bsp.hpp
deleted file mode 100644
index b9a8a7e1b..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/bsp.hpp
+++ /dev/null
@@ -1,50 +0,0 @@
-//============================================================================
-// Blinky example
-// Last Updated for Version: 7.3.0
-// Date of the Last Update: 2023-08-24
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef BSP_HPP_
-#define BSP_HPP_
-
-namespace BSP {
-
-constexpr std::uint32_t TICKS_PER_SEC {1000U};
-
-void init();
-void start();
-void terminate(std::int16_t const result);
-void ledOn(void);
-void ledOff(void);
-
-} // namespace BSP
-
-#endif // BSP_HPP_
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/main.cpp b/examples/arm-cm/blinky_nucleo-c031c6/main.cpp
deleted file mode 100644
index b30685b92..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/main.cpp
+++ /dev/null
@@ -1,44 +0,0 @@
-//============================================================================
-// APP example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-09
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "blinky.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//............................................................................
-int main() {
- QP::QF::init(); // initialize the framework
- BSP::init(); // initialize the BSP
- BSP::start(); // start the AOs/Threads
- return QP::QF::run(); // run the QF application
-}
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.sct b/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.sct
deleted file mode 100644
index ba687922e..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Adapted by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x08000000 0x00008000 { ; load region size_region
- ER_IROM1 0x08000000 0x00008000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; STACK area
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00003000 - 2048) {
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.uvoptx b/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.uvoptx
deleted file mode 100644
index a4af70264..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.uvoptx
+++ /dev/null
@@ -1,1024 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.hpp *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 18
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 6
-
-
-
-
-
-
-
-
-
-
- STLink\ST-LINKIII-KEIL_SWO.dll
-
-
-
- 0
- ST-LINKIII-KEIL_SWO
- -U066BFF505153848667095842 -O206 -SF10000 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight SW-DP (ARM Core") -D00(0BC11477) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32.FLM -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- UL2CM3
- -U -O206 -S8 -C0 -P00 -N00("") -D00(00000000) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32.FLM -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- DLGUARM
- (105=-1,-1,-1,-1,0)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
- 1
- 0
- 0
- 2
- 10000000
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 18
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 6
-
-
-
-
-
-
-
-
-
-
- STLink\ST-LINKIII-KEIL_SWO.dll
-
-
-
- 0
- UL2CM3
- UL2CM3(-S0 -C0 -P0 ) -FN1 -FC1000 -FD20000000 -FF0STM32C0x_32 -FL08000 -FS08000000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- ST-LINKIII-KEIL_SWO
- UL2CM3(-S0 -C0 -P0 ) -FN1 -FC1000 -FD20000000 -FF0STM32C0x_32 -FL08000 -FS08000000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- DLGUARM
- (105=-1,-1,-1,-1,0)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
- 1
- 1
- 0
- 2
- 10000000
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 18
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 6
-
-
-
-
-
-
-
-
-
-
- STLink\ST-LINKIII-KEIL_SWO.dll
-
-
-
- 0
- UL2CM3
- UL2CM3(-S0 -C0 -P0 ) -FN1 -FC1000 -FD20000000 -FF0STM32C0x_32 -FL08000 -FS08000000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- ST-LINKIII-KEIL_SWO
- -U-O206 -O206 -SF10000 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight SW-DP (ARM Core") -D00(0BC11477) -L00(0) -TO131090 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32.FLM -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- DLGUARM
- (105=-1,-1,-1,-1,0)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
- 1
- 0
- 0
- 2
- 10000000
-
-
-
-
-
- Source Code
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
- 1
- 3
- 5
- 0
- 0
- 0
- ..\..\blinky.hpp
- blinky.hpp
- 0
- 0
-
-
- 1
- 4
- 5
- 0
- 0
- 0
- .\blinky-qk.sct
- blinky-qk.sct
- 0
- 0
-
-
- 1
- 5
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
- 1
- 6
- 8
- 0
- 0
- 0
- ..\..\blinky.cpp
- blinky.cpp
- 0
- 0
-
-
-
-
- nucleo-c031c6
- 1
- 0
- 0
- 0
-
- 2
- 7
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
- stm32c0xx.h
- 0
- 0
-
-
- 2
- 8
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
- stm32c031xx.h
- 0
- 0
-
-
- 2
- 9
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
- system_stm32c0xx.c
- 0
- 0
-
-
- 2
- 10
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
- startup_stm32c031xx.s
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 11
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 12
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 13
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qk\qk.cpp
- qk.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 24
- 5
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qs_port.hpp
- qs_port.hpp
- 0
- 0
-
-
- 4
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
- qk_port.cpp
- 0
- 0
-
-
- 4
- 26
- 5
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qp_port.hpp
- qp_port.hpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_64bit.cpp
- qs_64bit.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.uvprojx b/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.uvprojx
deleted file mode 100644
index de7331bf9..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/armclang/blinky-qk.uvprojx
+++ /dev/null
@@ -1,1823 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- STM32C031C6Tx
- STMicroelectronics
- Keil.STM32C0xx_DFP.1.0.0
- https://www.keil.com/pack/
- IRAM(0x20000000,0x00003000) IROM(0x08000000,0x00008000) CPUTYPE("Cortex-M0+") CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32 -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM))
- 0
- $$Device:STM32C031C6Tx$Drivers\CMSIS\Device\ST\STM32C0xx\Include\stm32c0xx.h
-
-
-
-
-
-
-
-
-
- $$Device:STM32C031C6Tx$CMSIS\SVD\STM32C031.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- blinky-qk
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\blinky-qk.bin .\dbg\blinky-qk.axf
-
- 0
- 0
- 0
- 0
-
- 0
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -REMAP-MPU
- DARMCM1.DLL
- -pCM0+
- SARMCM3.DLL
- -MPU
- TARMCM1.DLL
- -pCM0+
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M0+"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 1
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
-
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\nucleo-c031c6
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\blinky-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Source Code
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- blinky-qk.sct
- 5
- .\blinky-qk.sct
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
-
-
- nucleo-c031c6
-
-
- stm32c0xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- stm32c031xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- system_stm32c0xx.c
- 1
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
- startup_stm32c031xx.s
- 2
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qs_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qs_port.hpp
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
- qp_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qp_port.hpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- STM32C031C6Tx
- STMicroelectronics
- Keil.STM32C0xx_DFP.1.0.0
- https://www.keil.com/pack/
- IRAM(0x20000000,0x00003000) IROM(0x08000000,0x00008000) CPUTYPE("Cortex-M0+") CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32 -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM))
- 0
- $$Device:STM32C031C6Tx$Drivers\CMSIS\Device\ST\STM32C0xx\Include\stm32c0xx.h
-
-
-
-
-
-
-
-
-
- $$Device:STM32C031C6Tx$CMSIS\SVD\STM32C031.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- blinky-qk
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\blinky-qk.bin .\rel\blinky-qk.axf
-
- 0
- 0
- 0
- 0
-
- 0
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -REMAP-MPU
- DARMCM1.DLL
- -pCM0+
- SARMCM3.DLL
- -MPU
- TARMCM1.DLL
- -pCM0+
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M0+"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 6
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\nucleo-c031c6
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\blinky-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Source Code
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- blinky-qk.sct
- 5
- .\blinky-qk.sct
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
-
-
- nucleo-c031c6
-
-
- stm32c0xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- stm32c031xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- system_stm32c0xx.c
- 1
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
- startup_stm32c031xx.s
- 2
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qs_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qs_port.hpp
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
- qp_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qp_port.hpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- STM32C031C6Tx
- STMicroelectronics
- Keil.STM32C0xx_DFP.1.0.0
- https://www.keil.com/pack/
- IRAM(0x20000000,0x00003000) IROM(0x08000000,0x00008000) CPUTYPE("Cortex-M0+") CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32 -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM))
- 0
- $$Device:STM32C031C6Tx$Drivers\CMSIS\Device\ST\STM32C0xx\Include\stm32c0xx.h
-
-
-
-
-
-
-
-
-
- $$Device:STM32C031C6Tx$CMSIS\SVD\STM32C031.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- blinky-qk
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\blinky-qk.bin .\spy\blinky-qk.axf
-
- 0
- 0
- 0
- 0
-
- 0
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -REMAP-MPU
- DARMCM1.DLL
- -pCM0+
- SARMCM3.DLL
- -MPU
- TARMCM1.DLL
- -pCM0+
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M0+"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 2
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- Q_SPY
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\nucleo-c031c6
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\blinky-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Source Code
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- blinky-qk.sct
- 5
- .\blinky-qk.sct
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
-
-
- nucleo-c031c6
-
-
- stm32c0xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- stm32c031xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- system_stm32c0xx.c
- 1
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
- startup_stm32c031xx.s
- 2
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qs_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qs_port.hpp
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
- qp_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qp_port.hpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/bsp.cpp b/examples/arm-cm/blinky_nucleo-c031c6/qk/bsp.cpp
deleted file mode 100644
index 1638e11b1..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/bsp.cpp
+++ /dev/null
@@ -1,248 +0,0 @@
-//============================================================================
-// Blinky example, NUCLEO-C031C6 board, QK kernel
-// Last updated for version 7.3.0
-// Last updated on 2023-08-28
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "blinky.hpp" // Blinky Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "stm32c0xx.h" // CMSIS-compliant header file for the MCU used
-// add other drivers if necessary...
-
-#ifdef Q_SPY
- #error Simple Blinky Application does not provide Spy build configuration
-#endif
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr std::uint32_t LD4_PIN {5U};
-constexpr std::uint32_t B1_PIN {13U};
-
-//Q_DEFINE_THIS_FILE
-
-} // unnamed local namespace
-
-//============================================================================
-// Error handler and ISRs...
-
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the assertion handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up the user LED
- GPIOA->BSRR = (1U << LD4_PIN); // turn LED on
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#endif
-
- NVIC_SystemReset();
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QK_ISR_ENTRY(); // inform QK about entering an ISR
-
- QP::QTimeEvt::TICK_X(0U, nullptr); // process time events at rate 0
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // enable GPIOA clock port for the LED LD4
- RCC->IOPENR |= (1U << 0U);
-
- // set all used GPIOA pins as push-pull output, no pull-up, pull-down
- GPIOA->MODER &= ~(3U << 2U*LD4_PIN);
- GPIOA->MODER |= (1U << 2U*LD4_PIN);
- GPIOA->OTYPER &= ~(1U << LD4_PIN);
- GPIOA->OSPEEDR &= ~(3U << 2U*LD4_PIN);
- GPIOA->OSPEEDR |= (1U << 2U*LD4_PIN);
- GPIOA->PUPDR &= ~(3U << 2U*LD4_PIN);
-
- // enable GPIOC clock port for the Button B1
- RCC->IOPENR |= (1U << 2U);
-
- // configure Button B1 pin on GPIOC as input, no pull-up, pull-down
- GPIOC->MODER &= ~(3U << 2U*B1_PIN);
- GPIOC->PUPDR &= ~(3U << 2U*B1_PIN);
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(QP::QEvt) smlPoolSto[20];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // instantiate and start AOs/threads...
-
- static QP::QEvt const *blinkyQueueSto[10];
- APP::AO_Blinky->start(
- 1U, // QP prio. of the AO
- blinkyQueueSto, // event queue storage
- Q_DIM(blinkyQueueSto), // queue length [events]
- nullptr, 0U, // no stack storage
- nullptr); // no initialization param
-}
-//............................................................................
-void ledOn() {
- GPIOA->BSRR = (1U << LD4_PIN); // turn LED on
-}
-//............................................................................
-void ledOff() {
- GPIOA->BSRR = (1U << (LD4_PIN + 16U)); // turn LED off
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- // NOTE: this might have been changed by STM32Cube.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QK::onIdle() {
-
- // toggle an LED on and then off (not enough LEDs, see NOTE02)
- //QF_INT_DISABLE();
- //GPIOA->BSRR = (1U << LD4_PIN); // turn LED[n] on
- //GPIOA->BSRR = (1U << (LD4_PIN + 16U)); // turn LED[n] off
- //QF_INT_ENABLE();
-
-#ifdef NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- // !!!CAUTION!!!
- // The WFI instruction stops the CPU clock, which unfortunately disables
- // the JTAG port, so the ST-Link debugger can no longer connect to the
- // board. For that reason, the call to __WFI() has to be used with CAUTION.
- //
- // NOTE: If you find your board "frozen" like this, strap BOOT0 to VDD and
- // reset the board, then connect with ST-Link Utilities and erase the part.
- // The trick with BOOT(0) is it gets the part to run the System Loader
- // instead of your broken code. When done disconnect BOOT0, and start over.
- //
- //__WFI(); // Wait-For-Interrupt
-#endif
-}
-
-
-} // namespace QP
-
-//============================================================================
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call any QF services. These ISRs
-// are "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call any QF services. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// One of the LEDs is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of invocations of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-//
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/gnu/Makefile b/examples/arm-cm/blinky_nucleo-c031c6/qk/gnu/Makefile
deleted file mode 100644
index ae9ea72f9..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/gnu/Makefile
+++ /dev/null
@@ -1,311 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on NUCLEO-C031C6, QK kernel, GNU-ARM
-# Last Updated for Version: 7.3.0
-# Date of the Last Update: 2023-08-26
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := blinky-qk
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qk/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qk \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/nucleo-c031c6 \
- $(QPCPP)/3rd_party/nucleo-c031c6/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/nucleo-c031c6
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_stm32c0xx.c \
- startup_stm32c031xx.c
-
-# C++ source files
-CPP_SRCS := \
- blinky.cpp \
- bsp.cpp \
- main.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qk.cpp \
- qk_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := \
- -DSTM32C031xx \
- -DQK_USE_IRQ_NUM=31 \
- -DQK_USE_IRQ_HANDLER=Reserved31_IRQHandler
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m0plus
-ARM_FPU :=
-FLOAT_ABI :=
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically you should not need to change anything below this line
-
-# basic utilities (included in QTools for Windows), see:
-# https://www.state-machine.com/qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-.PHONY : clean
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/gnu/blinky-qk.ld b/examples/arm-cm/blinky_nucleo-c031c6/qk/gnu/blinky-qk.ld
deleted file mode 100644
index 5139ce62b..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/gnu/blinky-qk.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EK-TM4C123GXL, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* Web : http://www.state-machine.com
-* Email: info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Tiva TM4C123GH6PM */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.ewd b/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.ewd
deleted file mode 100644
index b3712b658..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.ewp b/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.ewp
deleted file mode 100644
index 205f9b309..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.ewp
+++ /dev/null
@@ -1,3349 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\..\blinky.cpp
-
-
- $PROJ_DIR$\..\..\blinky.hpp
-
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
-
- nucleo-c031c6
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\iar\startup_stm32c031xx.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qk\qk.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qk\iar\qk_port.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qk\iar\qp_port.hpp
-
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qk\iar\qs_port.hpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.eww b/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.eww
deleted file mode 100644
index c99248567..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\blinky-qk.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.icf b/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.icf
deleted file mode 100644
index db057b16c..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qk/iar/blinky-qk.icf
+++ /dev/null
@@ -1,165 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_4.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x08000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_IROM1_start__ = 0x08000000;
-define symbol __ICFEDIT_region_IROM1_end__ = 0x08007FFF;
-define symbol __ICFEDIT_region_IROM2_start__ = 0x0;
-define symbol __ICFEDIT_region_IROM2_end__ = 0x0;
-define symbol __ICFEDIT_region_EROM1_start__ = 0x0;
-define symbol __ICFEDIT_region_EROM1_end__ = 0x0;
-define symbol __ICFEDIT_region_EROM2_start__ = 0x0;
-define symbol __ICFEDIT_region_EROM2_end__ = 0x0;
-define symbol __ICFEDIT_region_EROM3_start__ = 0x0;
-define symbol __ICFEDIT_region_EROM3_end__ = 0x0;
-define symbol __ICFEDIT_region_IRAM1_start__ = 0x20000000;
-define symbol __ICFEDIT_region_IRAM1_end__ = 0x20002FFF;
-define symbol __ICFEDIT_region_IRAM2_start__ = 0x0;
-define symbol __ICFEDIT_region_IRAM2_end__ = 0x0;
-define symbol __ICFEDIT_region_ERAM1_start__ = 0x0;
-define symbol __ICFEDIT_region_ERAM1_end__ = 0x0;
-define symbol __ICFEDIT_region_ERAM2_start__ = 0x0;
-define symbol __ICFEDIT_region_ERAM2_end__ = 0x0;
-define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
-define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_proc_stack__ = 0x0;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define symbol use_IROM1 = (__ICFEDIT_region_IROM1_start__ != 0x0 || __ICFEDIT_region_IROM1_end__ != 0x0);
-define symbol use_IROM2 = (__ICFEDIT_region_IROM2_start__ != 0x0 || __ICFEDIT_region_IROM2_end__ != 0x0);
-define symbol use_EROM1 = (__ICFEDIT_region_EROM1_start__ != 0x0 || __ICFEDIT_region_EROM1_end__ != 0x0);
-define symbol use_EROM2 = (__ICFEDIT_region_EROM2_start__ != 0x0 || __ICFEDIT_region_EROM2_end__ != 0x0);
-define symbol use_EROM3 = (__ICFEDIT_region_EROM3_start__ != 0x0 || __ICFEDIT_region_EROM3_end__ != 0x0);
-define symbol use_IRAM1 = (__ICFEDIT_region_IRAM1_start__ != 0x0 || __ICFEDIT_region_IRAM1_end__ != 0x0);
-define symbol use_IRAM2 = (__ICFEDIT_region_IRAM2_start__ != 0x0 || __ICFEDIT_region_IRAM2_end__ != 0x0);
-define symbol use_ERAM1 = (__ICFEDIT_region_ERAM1_start__ != 0x0 || __ICFEDIT_region_ERAM1_end__ != 0x0);
-define symbol use_ERAM2 = (__ICFEDIT_region_ERAM2_start__ != 0x0 || __ICFEDIT_region_ERAM2_end__ != 0x0);
-define symbol use_ERAM3 = (__ICFEDIT_region_ERAM3_start__ != 0x0 || __ICFEDIT_region_ERAM3_end__ != 0x0);
-
-if (use_IROM1)
-{
- define region IROM1_region = mem:[from __ICFEDIT_region_IROM1_start__ to __ICFEDIT_region_IROM1_end__];
-}
-else
-{
- define region IROM1_region = [];
-}
-
-if (use_IROM2)
-{
- define region IROM2_region = mem:[from __ICFEDIT_region_IROM2_start__ to __ICFEDIT_region_IROM2_end__];
-}
-else
-{
- define region IROM2_region = [];
-}
-define region IROM_region = IROM1_region | IROM2_region;
-
-if (use_EROM1)
-{
- define region EROM1_region = mem:[from __ICFEDIT_region_EROM1_start__ to __ICFEDIT_region_EROM1_end__];
-}
-else
-{
- define region EROM1_region = [];
-}
-if (use_EROM2)
-{
- define region EROM2_region = mem:[from __ICFEDIT_region_EROM2_start__ to __ICFEDIT_region_EROM2_end__];
-}
-else
-{
- define region EROM2_region = [];
-}
-if (use_EROM3)
-{
- define region EROM3_region = mem:[from __ICFEDIT_region_EROM3_start__ to __ICFEDIT_region_EROM3_end__];
-}
-else
-{
- define region EROM3_region = [];
-}
-define region EROM_region = EROM1_region | EROM2_region | EROM3_region;
-
-if (use_IRAM1)
-{
- define region IRAM1_region = mem:[from __ICFEDIT_region_IRAM1_start__ to __ICFEDIT_region_IRAM1_end__];
-}
-else
-{
- define region IRAM1_region = [];
-}
-if (use_IRAM2)
-{
- define region IRAM2_region = mem:[from __ICFEDIT_region_IRAM2_start__ to __ICFEDIT_region_IRAM2_end__];
-}
-else
-{
- define region IRAM2_region = [];
-}
-define region IRAM_region = IRAM1_region | IRAM2_region;
-
-if (use_ERAM1)
-{
- define region ERAM1_region = mem:[from __ICFEDIT_region_ERAM1_start__ to __ICFEDIT_region_ERAM1_end__];
-}
-else
-{
- define region ERAM1_region = [];
-}
-if (use_ERAM2)
-{
- define region ERAM2_region = mem:[from __ICFEDIT_region_ERAM2_start__ to __ICFEDIT_region_ERAM2_end__];
-}
-else
-{
- define region ERAM2_region = [];
-}
-if (use_ERAM3)
-{
- define region ERAM3_region = mem:[from __ICFEDIT_region_ERAM3_start__ to __ICFEDIT_region_ERAM3_end__];
-}
-else
-{
- define region ERAM3_region = [];
-}
-define region ERAM_region = ERAM1_region | ERAM2_region | ERAM3_region;
-
-initialize by copy { readwrite };
-if (isdefinedsymbol(__USE_DLIB_PERTHREAD))
-{
- // Required in a multi-threaded application
- initialize by copy with packing = none { section __DLIB_PERTHREAD };
-}
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-
-if (!isempty(IROM_region))
-{
- place in IROM_region { readonly };
-}
-
-if (!isempty(EROM_region))
-{
- place in EROM_region { readonly section application_specific_ro };
-}
-
-if (!isempty(IRAM_region))
-{
- define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
- define block PROC_STACK with alignment = 8, size = __ICFEDIT_size_proc_stack__ { };
- define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
- place at start of IRAM_region {block CSTACK }; /* <== Quantum Leaps */
- place in IRAM_region { readwrite, block PROC_STACK, block HEAP };
-}
-
-if (!isempty(ERAM_region))
-{
- place in ERAM_region { readwrite section application_specific_rw };
-}
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.sct b/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.sct
deleted file mode 100644
index ba687922e..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Adapted by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x08000000 0x00008000 { ; load region size_region
- ER_IROM1 0x08000000 0x00008000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; STACK area
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00003000 - 2048) {
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.uvoptx b/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.uvoptx
deleted file mode 100644
index b37bde5db..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.uvoptx
+++ /dev/null
@@ -1,1024 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.hpp *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 18
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 6
-
-
-
-
-
-
-
-
-
-
- STLink\ST-LINKIII-KEIL_SWO.dll
-
-
-
- 0
- ST-LINKIII-KEIL_SWO
- -U066BFF505153848667095842 -O206 -SF10000 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight SW-DP (ARM Core") -D00(0BC11477) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32.FLM -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- UL2CM3
- -U -O206 -S8 -C0 -P00 -N00("") -D00(00000000) -L00(0) -TO65554 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32.FLM -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- DLGUARM
- (105=-1,-1,-1,-1,0)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
- 1
- 0
- 0
- 2
- 10000000
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 18
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 6
-
-
-
-
-
-
-
-
-
-
- STLink\ST-LINKIII-KEIL_SWO.dll
-
-
-
- 0
- UL2CM3
- UL2CM3(-S0 -C0 -P0 ) -FN1 -FC1000 -FD20000000 -FF0STM32C0x_32 -FL08000 -FS08000000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- ST-LINKIII-KEIL_SWO
- UL2CM3(-S0 -C0 -P0 ) -FN1 -FC1000 -FD20000000 -FF0STM32C0x_32 -FL08000 -FS08000000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- DLGUARM
- (105=-1,-1,-1,-1,0)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
- 1
- 1
- 0
- 2
- 10000000
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 18
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 6
-
-
-
-
-
-
-
-
-
-
- STLink\ST-LINKIII-KEIL_SWO.dll
-
-
-
- 0
- UL2CM3
- UL2CM3(-S0 -C0 -P0 ) -FN1 -FC1000 -FD20000000 -FF0STM32C0x_32 -FL08000 -FS08000000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- ST-LINKIII-KEIL_SWO
- -U-O206 -O206 -SF10000 -C0 -A0 -I0 -HNlocalhost -HP7184 -P1 -N00("ARM CoreSight SW-DP (ARM Core") -D00(0BC11477) -L00(0) -TO131090 -TC10000000 -TT10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32.FLM -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM)
-
-
- 0
- DLGUARM
- (105=-1,-1,-1,-1,0)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
- 1
- 0
- 0
- 2
- 10000000
-
-
-
-
-
- Source Code
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
- 1
- 3
- 5
- 0
- 0
- 0
- ..\..\blinky.hpp
- blinky.hpp
- 0
- 0
-
-
- 1
- 4
- 5
- 0
- 0
- 0
- .\blinky-qv.sct
- blinky-qv.sct
- 0
- 0
-
-
- 1
- 5
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
- 1
- 6
- 8
- 0
- 0
- 0
- ..\..\blinky.cpp
- blinky.cpp
- 0
- 0
-
-
-
-
- nucleo-c031c6
- 1
- 0
- 0
- 0
-
- 2
- 7
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
- stm32c0xx.h
- 0
- 0
-
-
- 2
- 8
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
- stm32c031xx.h
- 0
- 0
-
-
- 2
- 9
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
- system_stm32c0xx.c
- 0
- 0
-
-
- 2
- 10
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
- startup_stm32c031xx.s
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 11
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 12
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 13
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qv\qv.cpp
- qv.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 24
- 5
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qs_port.hpp
- qs_port.hpp
- 0
- 0
-
-
- 4
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
- qv_port.cpp
- 0
- 0
-
-
- 4
- 26
- 5
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qp_port.hpp
- qp_port.hpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_64bit.cpp
- qs_64bit.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.uvprojx b/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.uvprojx
deleted file mode 100644
index 72f4f3a01..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/armclang/blinky-qv.uvprojx
+++ /dev/null
@@ -1,1823 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- blinky-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- STM32C031C6Tx
- STMicroelectronics
- Keil.STM32C0xx_DFP.1.0.0
- https://www.keil.com/pack/
- IRAM(0x20000000,0x00003000) IROM(0x08000000,0x00008000) CPUTYPE("Cortex-M0+") CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32 -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM))
- 0
- $$Device:STM32C031C6Tx$Drivers\CMSIS\Device\ST\STM32C0xx\Include\stm32c0xx.h
-
-
-
-
-
-
-
-
-
- $$Device:STM32C031C6Tx$CMSIS\SVD\STM32C031.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- blinky-qv
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\blinky-qv.bin .\dbg\blinky-qv.axf
-
- 0
- 0
- 0
- 0
-
- 0
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -REMAP-MPU
- DARMCM1.DLL
- -pCM0+
- SARMCM3.DLL
- -MPU
- TARMCM1.DLL
- -pCM0+
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M0+"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 1
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
-
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\nucleo-c031c6
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\blinky-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Source Code
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- blinky-qv.sct
- 5
- .\blinky-qv.sct
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
-
-
- nucleo-c031c6
-
-
- stm32c0xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- stm32c031xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- system_stm32c0xx.c
- 1
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
- startup_stm32c031xx.s
- 2
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qs_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qs_port.hpp
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
- qp_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qp_port.hpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-rel
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- STM32C031C6Tx
- STMicroelectronics
- Keil.STM32C0xx_DFP.1.0.0
- https://www.keil.com/pack/
- IRAM(0x20000000,0x00003000) IROM(0x08000000,0x00008000) CPUTYPE("Cortex-M0+") CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32 -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM))
- 0
- $$Device:STM32C031C6Tx$Drivers\CMSIS\Device\ST\STM32C0xx\Include\stm32c0xx.h
-
-
-
-
-
-
-
-
-
- $$Device:STM32C031C6Tx$CMSIS\SVD\STM32C031.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- blinky-qv
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\blinky-qv.bin .\rel\blinky-qv.axf
-
- 0
- 0
- 0
- 0
-
- 0
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -REMAP-MPU
- DARMCM1.DLL
- -pCM0+
- SARMCM3.DLL
- -MPU
- TARMCM1.DLL
- -pCM0+
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M0+"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 6
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\nucleo-c031c6
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\blinky-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Source Code
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- blinky-qv.sct
- 5
- .\blinky-qv.sct
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
-
-
- nucleo-c031c6
-
-
- stm32c0xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- stm32c031xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- system_stm32c0xx.c
- 1
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
- startup_stm32c031xx.s
- 2
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qs_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qs_port.hpp
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
- qp_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qp_port.hpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- blinky-spy
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- STM32C031C6Tx
- STMicroelectronics
- Keil.STM32C0xx_DFP.1.0.0
- https://www.keil.com/pack/
- IRAM(0x20000000,0x00003000) IROM(0x08000000,0x00008000) CPUTYPE("Cortex-M0+") CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0STM32C0x_32 -FS08000000 -FL08000 -FP0($$Device:STM32C031C6Tx$CMSIS\Flash\STM32C0x_32.FLM))
- 0
- $$Device:STM32C031C6Tx$Drivers\CMSIS\Device\ST\STM32C0xx\Include\stm32c0xx.h
-
-
-
-
-
-
-
-
-
- $$Device:STM32C031C6Tx$CMSIS\SVD\STM32C031.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- blinky-qv
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\blinky-qv.bin .\spy\blinky-qv.axf
-
- 0
- 0
- 0
- 0
-
- 0
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -REMAP-MPU
- DARMCM1.DLL
- -pCM0+
- SARMCM3.DLL
- -MPU
- TARMCM1.DLL
- -pCM0+
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M0+"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x8000000
- 0x8000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x3000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 2
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- Q_SPY
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\nucleo-c031c6
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\blinky-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Source Code
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- blinky.hpp
- 5
- ..\..\blinky.hpp
-
-
- blinky-qv.sct
- 5
- .\blinky-qv.sct
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- blinky.cpp
- 8
- ..\..\blinky.cpp
-
-
-
-
- nucleo-c031c6
-
-
- stm32c0xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- stm32c031xx.h
- 5
- ..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- system_stm32c0xx.c
- 1
- ..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
- startup_stm32c031xx.s
- 2
- ..\..\..\..\..\3rd_party\nucleo-c031c6\arm\startup_stm32c031xx.s
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qs_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qs_port.hpp
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
- qp_port.hpp
- 5
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qp_port.hpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/bsp.cpp b/examples/arm-cm/blinky_nucleo-c031c6/qv/bsp.cpp
deleted file mode 100644
index 2126676f7..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/bsp.cpp
+++ /dev/null
@@ -1,255 +0,0 @@
-//============================================================================
-// Blinky example, NUCLEO-C031C6 board, QV kernel
-// Last updated for version 7.3.0
-// Last updated on 2023-08-28
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "blinky.hpp" // Blinky Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "stm32c0xx.h" // CMSIS-compliant header file for the MCU used
-// add other drivers if necessary...
-
-#ifdef Q_SPY
- #error Simple Blinky Application does not provide Spy build configuration
-#endif
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr std::uint32_t LD4_PIN {5U};
-constexpr std::uint32_t B1_PIN {13U};
-
-//Q_DEFINE_THIS_FILE
-
-} // unnamed local namespace
-
-//============================================================================
-// Error handler and ISRs...
-
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the assertion handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up the user LED
- GPIOA->BSRR = (1U << LD4_PIN); // turn LED on
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#endif
-
- NVIC_SystemReset();
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
-
- QP::QTimeEvt::TICK_X(0U, nullptr); // process time events at rate 0
-
- QV_ARM_ERRATUM_838869();
-}
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // enable GPIOA clock port for the LED LD4
- RCC->IOPENR |= (1U << 0U);
-
- // set all used GPIOA pins as push-pull output, no pull-up, pull-down
- GPIOA->MODER &= ~(3U << 2U*LD4_PIN);
- GPIOA->MODER |= (1U << 2U*LD4_PIN);
- GPIOA->OTYPER &= ~(1U << LD4_PIN);
- GPIOA->OSPEEDR &= ~(3U << 2U*LD4_PIN);
- GPIOA->OSPEEDR |= (1U << 2U*LD4_PIN);
- GPIOA->PUPDR &= ~(3U << 2U*LD4_PIN);
-
- // enable GPIOC clock port for the Button B1
- RCC->IOPENR |= (1U << 2U);
-
- // configure Button B1 pin on GPIOC as input, no pull-up, pull-down
- GPIOC->MODER &= ~(3U << 2U*B1_PIN);
- GPIOC->PUPDR &= ~(3U << 2U*B1_PIN);
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(QP::QEvt) smlPoolSto[20];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // instantiate and start AOs/threads...
-
- static QP::QEvt const *blinkyQueueSto[10];
- APP::AO_Blinky->start(
- 1U, // QP prio. of the AO
- blinkyQueueSto, // event queue storage
- Q_DIM(blinkyQueueSto), // queue length [events]
- nullptr, 0U, // no stack storage
- nullptr); // no initialization param
-}
-//............................................................................
-void ledOn() {
- GPIOA->BSRR = (1U << LD4_PIN); // turn LED on
-}
-//............................................................................
-void ledOff() {
- GPIOA->BSRR = (1U << (LD4_PIN + 16U)); // turn LED off
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- // NOTE: this might have been changed by STM32Cube.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QV::onIdle() {
-
- // toggle an LED on and then off (not enough LEDs, see NOTE02)
- //GPIOA->BSRR = (1U << LD4_PIN); // turn LED[n] on
- //GPIOA->BSRR = (1U << (LD4_PIN + 16U)); // turn LED[n] off
-
-#ifdef NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- // !!!CAUTION!!!
- // QV_CPU_SLEEP() contains the WFI instruction, which stops the CPU
- // clock, which unfortunately disables the JTAG port, so the ST-Link
- // debugger can no longer connect to the board. For that reason, the call
- // to QV_CPU_SLEEP() has to be used with CAUTION.
- //
- // NOTE: If you find your board "frozen" like this, strap BOOT0 to VDD and
- // reset the board, then connect with ST-Link Utilities and erase the part.
- // The trick with BOOT(0) is it gets the part to run the System Loader
- // instead of your broken code. When done disconnect BOOT0, and start over.
- //
- //QV_CPU_SLEEP(); // atomically go to sleep and enable interrupts
- QF_INT_ENABLE(); // for now, just enable interrupts
-#else
- QF_INT_ENABLE(); // just enable interrupts
-#endif
-}
-
-
-} // namespace QP
-
-//============================================================================
-// NOTE0:
-// The QV_onIdle() callback is called with interrupts disabled, because the
-// determination of the idle condition might change by any interrupt posting
-// an event. QV_onIdle() must internally enable interrupts, ideally
-// atomically with putting the CPU to the power-saving mode.
-//
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call any other QF/QV services.
-// These ISRs are "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QV services. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-//
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/gnu/Makefile b/examples/arm-cm/blinky_nucleo-c031c6/qv/gnu/Makefile
deleted file mode 100644
index 0e0a3ebe1..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/gnu/Makefile
+++ /dev/null
@@ -1,309 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on NUCLEO-C031C6, QV kernel, GNU-ARM
-# Last Updated for Version: 7.3.0
-# Date of the Last Update: 2023-05-26
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := blinky-qv
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qv/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qv \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/nucleo-c031c6 \
- $(QPCPP)/3rd_party/nucleo-c031c6/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/nucleo-c031c6
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_stm32c0xx.c \
- startup_stm32c031xx.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- blinky.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qv.cpp \
- qv_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := \
- -DSTM32C031xx
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m0plus
-ARM_FPU :=
-FLOAT_ABI :=
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically you should not need to change anything below this line
-
-# basic utilities (included in QTools for Windows), see:
-# https://www.state-machine.com/qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-.PHONY : clean
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/gnu/blinky-qv.ld b/examples/arm-cm/blinky_nucleo-c031c6/qv/gnu/blinky-qv.ld
deleted file mode 100644
index 4a3ba8516..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/gnu/blinky-qv.ld
+++ /dev/null
@@ -1,135 +0,0 @@
-/*****************************************************************************
-* Linker script for for STM32C031C6, GNU-ARM linker
-*
-* Q u a n t u m L e a P s
-* ------------------------
-* Modern Embedded Software
-*
-* Copyright (C) 2005 Quantum Leaps, LLC .
-*
-* SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-*
-* This software is dual-licensed under the terms of the open source GNU
-* General Public License version 3 (or any later version), or alternatively,
-* under the terms of one of the closed source Quantum Leaps commercial
-* licenses.
-*
-* The terms of the open source GNU General Public License version 3
-* can be found at:
-*
-* The terms of the closed source Quantum Leaps commercial licenses
-* can be found at:
-*
-* Redistributions in source code must retain this top-level comment block.
-* Plagiarizing this software to sidestep the license obligations is illegal.
-*
-* Contact information:
-*
-*
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of STM32C031C6 */
- ROM (rx) : ORIGIN = 0x08000000, LENGTH = 32K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 12K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.ewd b/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.ewd
deleted file mode 100644
index b3712b658..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.ewp b/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.ewp
deleted file mode 100644
index dc600a0b6..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.ewp
+++ /dev/null
@@ -1,3349 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\..\blinky.cpp
-
-
- $PROJ_DIR$\..\..\blinky.hpp
-
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
-
- nucleo-c031c6
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\iar\startup_stm32c031xx.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c031xx.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\stm32c0xx.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\nucleo-c031c6\system_stm32c0xx.c
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qv\qv.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qv\iar\qp_port.hpp
-
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qv\iar\qs_port.hpp
-
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qv\iar\qv_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.eww b/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.eww
deleted file mode 100644
index fa7c77317..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\blinky-qv.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.icf b/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.icf
deleted file mode 100644
index db057b16c..000000000
--- a/examples/arm-cm/blinky_nucleo-c031c6/qv/iar/blinky-qv.icf
+++ /dev/null
@@ -1,165 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_4.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x08000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_IROM1_start__ = 0x08000000;
-define symbol __ICFEDIT_region_IROM1_end__ = 0x08007FFF;
-define symbol __ICFEDIT_region_IROM2_start__ = 0x0;
-define symbol __ICFEDIT_region_IROM2_end__ = 0x0;
-define symbol __ICFEDIT_region_EROM1_start__ = 0x0;
-define symbol __ICFEDIT_region_EROM1_end__ = 0x0;
-define symbol __ICFEDIT_region_EROM2_start__ = 0x0;
-define symbol __ICFEDIT_region_EROM2_end__ = 0x0;
-define symbol __ICFEDIT_region_EROM3_start__ = 0x0;
-define symbol __ICFEDIT_region_EROM3_end__ = 0x0;
-define symbol __ICFEDIT_region_IRAM1_start__ = 0x20000000;
-define symbol __ICFEDIT_region_IRAM1_end__ = 0x20002FFF;
-define symbol __ICFEDIT_region_IRAM2_start__ = 0x0;
-define symbol __ICFEDIT_region_IRAM2_end__ = 0x0;
-define symbol __ICFEDIT_region_ERAM1_start__ = 0x0;
-define symbol __ICFEDIT_region_ERAM1_end__ = 0x0;
-define symbol __ICFEDIT_region_ERAM2_start__ = 0x0;
-define symbol __ICFEDIT_region_ERAM2_end__ = 0x0;
-define symbol __ICFEDIT_region_ERAM3_start__ = 0x0;
-define symbol __ICFEDIT_region_ERAM3_end__ = 0x0;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_proc_stack__ = 0x0;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define symbol use_IROM1 = (__ICFEDIT_region_IROM1_start__ != 0x0 || __ICFEDIT_region_IROM1_end__ != 0x0);
-define symbol use_IROM2 = (__ICFEDIT_region_IROM2_start__ != 0x0 || __ICFEDIT_region_IROM2_end__ != 0x0);
-define symbol use_EROM1 = (__ICFEDIT_region_EROM1_start__ != 0x0 || __ICFEDIT_region_EROM1_end__ != 0x0);
-define symbol use_EROM2 = (__ICFEDIT_region_EROM2_start__ != 0x0 || __ICFEDIT_region_EROM2_end__ != 0x0);
-define symbol use_EROM3 = (__ICFEDIT_region_EROM3_start__ != 0x0 || __ICFEDIT_region_EROM3_end__ != 0x0);
-define symbol use_IRAM1 = (__ICFEDIT_region_IRAM1_start__ != 0x0 || __ICFEDIT_region_IRAM1_end__ != 0x0);
-define symbol use_IRAM2 = (__ICFEDIT_region_IRAM2_start__ != 0x0 || __ICFEDIT_region_IRAM2_end__ != 0x0);
-define symbol use_ERAM1 = (__ICFEDIT_region_ERAM1_start__ != 0x0 || __ICFEDIT_region_ERAM1_end__ != 0x0);
-define symbol use_ERAM2 = (__ICFEDIT_region_ERAM2_start__ != 0x0 || __ICFEDIT_region_ERAM2_end__ != 0x0);
-define symbol use_ERAM3 = (__ICFEDIT_region_ERAM3_start__ != 0x0 || __ICFEDIT_region_ERAM3_end__ != 0x0);
-
-if (use_IROM1)
-{
- define region IROM1_region = mem:[from __ICFEDIT_region_IROM1_start__ to __ICFEDIT_region_IROM1_end__];
-}
-else
-{
- define region IROM1_region = [];
-}
-
-if (use_IROM2)
-{
- define region IROM2_region = mem:[from __ICFEDIT_region_IROM2_start__ to __ICFEDIT_region_IROM2_end__];
-}
-else
-{
- define region IROM2_region = [];
-}
-define region IROM_region = IROM1_region | IROM2_region;
-
-if (use_EROM1)
-{
- define region EROM1_region = mem:[from __ICFEDIT_region_EROM1_start__ to __ICFEDIT_region_EROM1_end__];
-}
-else
-{
- define region EROM1_region = [];
-}
-if (use_EROM2)
-{
- define region EROM2_region = mem:[from __ICFEDIT_region_EROM2_start__ to __ICFEDIT_region_EROM2_end__];
-}
-else
-{
- define region EROM2_region = [];
-}
-if (use_EROM3)
-{
- define region EROM3_region = mem:[from __ICFEDIT_region_EROM3_start__ to __ICFEDIT_region_EROM3_end__];
-}
-else
-{
- define region EROM3_region = [];
-}
-define region EROM_region = EROM1_region | EROM2_region | EROM3_region;
-
-if (use_IRAM1)
-{
- define region IRAM1_region = mem:[from __ICFEDIT_region_IRAM1_start__ to __ICFEDIT_region_IRAM1_end__];
-}
-else
-{
- define region IRAM1_region = [];
-}
-if (use_IRAM2)
-{
- define region IRAM2_region = mem:[from __ICFEDIT_region_IRAM2_start__ to __ICFEDIT_region_IRAM2_end__];
-}
-else
-{
- define region IRAM2_region = [];
-}
-define region IRAM_region = IRAM1_region | IRAM2_region;
-
-if (use_ERAM1)
-{
- define region ERAM1_region = mem:[from __ICFEDIT_region_ERAM1_start__ to __ICFEDIT_region_ERAM1_end__];
-}
-else
-{
- define region ERAM1_region = [];
-}
-if (use_ERAM2)
-{
- define region ERAM2_region = mem:[from __ICFEDIT_region_ERAM2_start__ to __ICFEDIT_region_ERAM2_end__];
-}
-else
-{
- define region ERAM2_region = [];
-}
-if (use_ERAM3)
-{
- define region ERAM3_region = mem:[from __ICFEDIT_region_ERAM3_start__ to __ICFEDIT_region_ERAM3_end__];
-}
-else
-{
- define region ERAM3_region = [];
-}
-define region ERAM_region = ERAM1_region | ERAM2_region | ERAM3_region;
-
-initialize by copy { readwrite };
-if (isdefinedsymbol(__USE_DLIB_PERTHREAD))
-{
- // Required in a multi-threaded application
- initialize by copy with packing = none { section __DLIB_PERTHREAD };
-}
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-
-if (!isempty(IROM_region))
-{
- place in IROM_region { readonly };
-}
-
-if (!isempty(EROM_region))
-{
- place in EROM_region { readonly section application_specific_ro };
-}
-
-if (!isempty(IRAM_region))
-{
- define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
- define block PROC_STACK with alignment = 8, size = __ICFEDIT_size_proc_stack__ { };
- define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
- place at start of IRAM_region {block CSTACK }; /* <== Quantum Leaps */
- place in IRAM_region { readwrite, block PROC_STACK, block HEAP };
-}
-
-if (!isempty(ERAM_region))
-{
- place in ERAM_region { readwrite section application_specific_rw };
-}
\ No newline at end of file
diff --git a/examples/arm-cm/blinky_nucleo-c031c6/stm32-nucleo-c031c6.jpg b/examples/arm-cm/blinky_nucleo-c031c6/stm32-nucleo-c031c6.jpg
deleted file mode 100644
index 6647e2d49..000000000
Binary files a/examples/arm-cm/blinky_nucleo-c031c6/stm32-nucleo-c031c6.jpg and /dev/null differ
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/README.md b/examples/arm-cm/dpp_efm32-slstk3401a/README.md
deleted file mode 100644
index 2810293ea..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/README.md
+++ /dev/null
@@ -1,5 +0,0 @@
-![STM32 EFM32-SLSTK3401A](../../../doxygen/images/bd_EFM32-SLSTK3401A.jpg)
-
-Documentation for this example is available in the QP/C Manual at:
-
-- https://www.state-machine.com/qpcpp/arm-cm_dpp_efm32-slstk3401a.html
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/bsp.hpp b/examples/arm-cm/dpp_efm32-slstk3401a/bsp.hpp
deleted file mode 100644
index 2479d54c1..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/bsp.hpp
+++ /dev/null
@@ -1,59 +0,0 @@
-//============================================================================
-// Product: DPP example
-// Last Updated for Version: 7.3.0
-// Date of the Last Update: 2023-08-12
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef BSP_HPP_
-#define BSP_HPP_
-
-namespace BSP {
-
-constexpr std::uint32_t TICKS_PER_SEC {100};
-
-void init();
-void start();
-void displayPaused(std::uint8_t const paused);
-void displayPhilStat(std::uint8_t const n, char const *stat);
-void terminate(std::int16_t const result);
-
-void randomSeed(std::uint32_t const seed); // random seed
-std::uint32_t random(); // pseudo-random generator
-
-// for testing...
-void wait4SW1();
-void ledOn();
-void ledOff();
-
-extern QP::QTicker *AO_Ticker0;
-
-} // namespace BSP
-
-#endif // BSP_HPP_
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/dpp.hpp b/examples/arm-cm/dpp_efm32-slstk3401a/dpp.hpp
deleted file mode 100644
index 5172c9a52..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/dpp.hpp
+++ /dev/null
@@ -1,111 +0,0 @@
-//$file${.::dpp.hpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp.qm
-// File: ${.::dpp.hpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::dpp.hpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#ifndef DPP_HPP_
-#define DPP_HPP_
-
-//$declare${Shared} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::AppSignals} ......................................................
-enum AppSignals : QP::QSignal {
- EAT_SIG = QP::Q_USER_SIG, // published by Table to let a Philo eat
- DONE_SIG, // published by Philo when done eating
- PAUSE_SIG, // published by BSP to pause the application
- SERVE_SIG, // published by BSP to serve re-start serving forks
- TEST_SIG, // published by BSP to test the application
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG, // posted by time event to Philo
- HUNGRY_SIG, // posted by hungry Philo to Table
- MAX_SIG // the last signal
-};
-
-//${Shared::produce_sig_dict} ................................................
-#ifdef Q_SPY
-inline void produce_sig_dict() {
- QS_SIG_DICTIONARY(EAT_SIG, nullptr);
- QS_SIG_DICTIONARY(DONE_SIG, nullptr);
- QS_SIG_DICTIONARY(PAUSE_SIG, nullptr);
- QS_SIG_DICTIONARY(SERVE_SIG, nullptr);
- QS_SIG_DICTIONARY(TEST_SIG, nullptr);
-
- QS_SIG_DICTIONARY(TIMEOUT_SIG, nullptr);
- QS_SIG_DICTIONARY(HUNGRY_SIG, nullptr);
-}
-#endif // def Q_SPY
-
-//${Shared::N_PHILO} .........................................................
-constexpr std::uint8_t N_PHILO {5};
-
-//${Shared::TableEvt} ........................................................
-class TableEvt : public QP::QEvt {
-public:
- std::uint8_t philoId;
-
-public:
- constexpr TableEvt(
- QP::QSignal sig,
- std::uint8_t id)
- : QEvt(sig),
- philoId(id)
- {}
-
-#ifdef QEVT_DYN_CTOR
- TableEvt(std::uint8_t id)
- : QEvt(QP::QEvt::DYNAMIC),
- philoId(id)
- {}
-#endif // def QEVT_DYN_CTOR
-}; // class TableEvt
-
-//${Shared::AO_Philo[N_PHILO]} ...............................................
-extern QP::QActive * const AO_Philo[N_PHILO];
-
-//${Shared::AO_Table} ........................................................
-extern QP::QActive * const AO_Table;
-
-} // namespace APP
-//$enddecl${Shared} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-#ifdef QXK_HPP_
-
-namespace APP {
-
-extern QP::QXThread * const TH_XThread1;
-extern QP::QXThread * const TH_XThread2;
-extern QP::QXSemaphore TH_sema;
-extern QP::QXMutex TH_mutex;
-
-} // namespace APP
-
-#endif // QXK_HPP_
-
-#endif // DPP_HPP_
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/dpp.qm b/examples/arm-cm/dpp_efm32-slstk3401a/dpp.qm
deleted file mode 100644
index 1de2b108f..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/dpp.qm
+++ /dev/null
@@ -1,528 +0,0 @@
-
-
- Dining Philosopher Problem example application
-
-
-
-
-
-
- : QP::QSignal {
- EAT_SIG = QP::Q_USER_SIG, // published by Table to let a Philo eat
- DONE_SIG, // published by Philo when done eating
- PAUSE_SIG, // published by BSP to pause the application
- SERVE_SIG, // published by BSP to serve re-start serving forks
- TEST_SIG, // published by BSP to test the application
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG, // posted by time event to Philo
- HUNGRY_SIG, // posted by hungry Philo to Table
- MAX_SIG // the last signal
-};
-
-
-
- QS_SIG_DICTIONARY(EAT_SIG, nullptr);
-QS_SIG_DICTIONARY(DONE_SIG, nullptr);
-QS_SIG_DICTIONARY(PAUSE_SIG, nullptr);
-QS_SIG_DICTIONARY(SERVE_SIG, nullptr);
-QS_SIG_DICTIONARY(TEST_SIG, nullptr);
-
-QS_SIG_DICTIONARY(TIMEOUT_SIG, nullptr);
-QS_SIG_DICTIONARY(HUNGRY_SIG, nullptr);
-
-
-
- {5};
-
-
-
-
-
-
-
-
-
-
-
- : QEvt(sig),
- philoId(id)
-
-
-
-
-
- : QEvt(QP::QEvt::DYNAMIC),
- philoId(id)
-
-
-
-
- = {
- &Philo::inst[0],
- &Philo::inst[1],
- &Philo::inst[2],
- &Philo::inst[3],
- &Philo::inst[4]
-};
-
-
-
- = &Table::inst;
-
-
-
-
-
-
- The Philo AO and the N_PHILO instances
-
-
-
-
-
-
-
-
- : QActive(Q_STATE_CAST(&initial)),
- m_timeEvt(this, TIMEOUT_SIG, 0U),
- m_id(0xFFU)
-
-
-
-
-
- Q_UNUSED_PAR(e);
-
-m_id = static_cast<std::uint8_t>(this - &inst[0]);
-
-QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id], m_id);
-QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id].m_timeEvt, m_id);
-
-subscribe(EAT_SIG);
-subscribe(TEST_SIG);
-
-
-
-
-
-
- m_timeEvt.armX(think_time(), 0U);
- m_timeEvt.disarm();
-
-
-
-
-
-
-
-
- // EAT or DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- #ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, HUNGRY_SIG, m_id);
-#else
-TableEvt *pe = Q_NEW(TableEvt, HUNGRY_SIG);
-pe->philoId = m_id;
-#endif
-AO_Table->POST(pe, this);
-
-
-
-
- Q_EVT_CAST(TableEvt)->philoId == m_id
-
-
-
-
-
-
-
-
-
-
- // DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
- m_timeEvt.armX(eat_time(), 0U);
- m_timeEvt.disarm();
-
-#ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, DONE_SIG, m_id);
-#else
-TableEvt *pe = Q_NEW(TableEvt, DONE_SIG);
-pe->philoId = m_id;
-#endif
-QP::QActive::PUBLISH(pe, this);
-
-
-
-
-
-
-
-
- // EAT or DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- : QActive(Q_STATE_CAST(&initial))
-
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
-}
-
-
-
-
-
- Q_UNUSED_PAR(e);
-
-QS_OBJ_DICTIONARY(&Table::inst);
-
-subscribe(DONE_SIG);
-subscribe(PAUSE_SIG);
-subscribe(SERVE_SIG);
-subscribe(TEST_SIG);
-
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, THINKING);
-}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Q_ERROR();
-
-
-
-
-
-
- // give permissions to eat...
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- if (m_isHungry[n]
- && (m_fork[left(n)] == FREE)
- && (m_fork[n] == FREE))
- {
- m_fork[left(n)] = USED;
- m_fork[n] = USED;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *te = Q_NEW(TableEvt, EAT_SIG, n);
-#else
- TableEvt *te = Q_NEW(TableEvt, EAT_SIG);
- te->philoId = n;
-#endif
- QP::QActive::PUBLISH(te, this);
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, EATING);
- }
-}
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, HUNGRY);
-std::uint8_t m = left(n);
-
-
- (m_fork[m] == FREE) && (m_fork[n] == FREE)
- m_fork[m] = USED;
-m_fork[n] = USED;
-#ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, n);
-#else
-TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
-pe->philoId = n;
-#endif
-QP::QActive::PUBLISH(pe, this);
-BSP::displayPhilStat(n, EATING);
-
-
-
-
-
-
- else
- m_isHungry[n] = true;
-
-
-
-
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, THINKING);
-std::uint8_t m = left(n);
-
-// both forks of Phil[n] must be used
-Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
-m_fork[m] = FREE;
-m_fork[n] = FREE;
-m = right(n); // check the right neighbor
-
-if (m_isHungry[m] && (m_fork[m] == FREE)) {
- m_fork[n] = USED;
- m_fork[m] = USED;
- m_isHungry[m] = false;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
-#else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
-#endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
-}
-m = left(n); // check the left neighbor
-n = left(m); // left fork of the left neighbor
-if (m_isHungry[m] && (m_fork[n] == FREE)) {
- m_fork[m] = USED;
- m_fork[n] = USED;
- m_isHungry[m] = false;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
-#else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
-#endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
-}
-
-
-
-
-
-
- Q_ERROR();
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- BSP::displayPaused(1U);
- BSP::displayPaused(0U);
-
-
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// philo ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-m_isHungry[n] = true;
-BSP::displayPhilStat(n, HUNGRY);
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, THINKING);
-std::uint8_t m = left(n);
-
-// both forks of Phil[n] must be used
-Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
-m_fork[m] = FREE;
-m_fork[n] = FREE;
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- #ifndef DPP_HPP_
-#define DPP_HPP_
-
-$declare ${Shared}
-
-#ifdef QXK_HPP_
-
-namespace APP {
-
-extern QP::QXThread * const TH_XThread1;
-extern QP::QXThread * const TH_XThread2;
-extern QP::QXSemaphore TH_sema;
-extern QP::QXMutex TH_mutex;
-
-} // namespace APP
-
-#endif // QXK_HPP_
-
-#endif // DPP_HPP_
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-namespace { // unnamed namespace for local definitions with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// helper function to provide a randomized think time for Philos
-static inline QP::QTimeEvtCtr think_time() {
- return static_cast<QP::QTimeEvtCtr>((BSP::random() % BSP::TICKS_PER_SEC)
- + (BSP::TICKS_PER_SEC/2U));
-}
-
-// helper function to provide a randomized eat time for Philos
-static inline QP::QTimeEvtCtr eat_time() {
- return static_cast<QP::QTimeEvtCtr>((BSP::random() % BSP::TICKS_PER_SEC)
- + BSP::TICKS_PER_SEC);
-}
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-
-$declare ${AOs::Philo}
-
-$define ${Shared::AO_Philo[N_PHILO]}
-$define ${AOs::Philo}
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-$declare ${AOs::Table}
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-
-// helper function to provide the RIGHT neighbour of a Philo[n]
-static inline std::uint8_t right(std::uint8_t const n) {
- return static_cast<std::uint8_t>((n + (APP::N_PHILO - 1U)) % APP::N_PHILO);
-}
-
-// helper function to provide the LEFT neighbour of a Philo[n]
-static inline std::uint8_t left(std::uint8_t const n) {
- return static_cast<std::uint8_t>((n + 1U) % APP::N_PHILO);
-}
-
-static constexpr std::uint8_t FREE {0U};
-static constexpr std::uint8_t USED {1U};
-
-static constexpr char const * const THINKING {"thinking"};
-static constexpr char const * const HUNGRY {"hungry "};
-static constexpr char const * const EATING {"eating "};
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-$define ${Shared::AO_Table}
-$define ${AOs::Table}
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/main.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/main.cpp
deleted file mode 100644
index 509568b09..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/main.cpp
+++ /dev/null
@@ -1,44 +0,0 @@
-//============================================================================
-// APP example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-09
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//............................................................................
-int main() {
- QP::QF::init(); // initialize the framework and the underlying RT kernel
- BSP::init(); // initialize the BSP
- BSP::start(); // start the AOs/Threads
- return QP::QF::run(); // run the QF application
-}
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/philo.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/philo.cpp
deleted file mode 100644
index 79bc5f36e..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/philo.cpp
+++ /dev/null
@@ -1,264 +0,0 @@
-//$file${.::philo.cpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp.qm
-// File: ${.::philo.cpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::philo.cpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-namespace { // unnamed namespace for local definitions with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// helper function to provide a randomized think time for Philos
-static inline QP::QTimeEvtCtr think_time() {
- return static_cast((BSP::random() % BSP::TICKS_PER_SEC)
- + (BSP::TICKS_PER_SEC/2U));
-}
-
-// helper function to provide a randomized eat time for Philos
-static inline QP::QTimeEvtCtr eat_time() {
- return static_cast((BSP::random() % BSP::TICKS_PER_SEC)
- + BSP::TICKS_PER_SEC);
-}
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-
-//$declare${AOs::Philo} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Philo} ..............................................................
-class Philo : public QP::QActive {
-private:
- QP::QTimeEvt m_timeEvt;
- std::uint8_t m_id;
-
-public:
- static Philo inst[N_PHILO];
-
-public:
- Philo();
-
-protected:
- Q_STATE_DECL(initial);
- Q_STATE_DECL(thinking);
- Q_STATE_DECL(hungry);
- Q_STATE_DECL(eating);
-}; // class Philo
-
-} // namespace APP
-//$enddecl${AOs::Philo} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$skip${QP_VERSION} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-// Check for the minimum required QP version
-#if (QP_VERSION < 730U) || (QP_VERSION != ((QP_RELEASE^4294967295U) % 0x3E8U))
-#error qpcpp version 7.3.0 or higher required
-#endif
-//$endskip${QP_VERSION} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$define${Shared::AO_Philo[N_PHILO]} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::AO_Philo[N_PHILO]} ...............................................
-QP::QActive * const AO_Philo[N_PHILO] = {
- &Philo::inst[0],
- &Philo::inst[1],
- &Philo::inst[2],
- &Philo::inst[3],
- &Philo::inst[4]
-};
-
-} // namespace APP
-//$enddef${Shared::AO_Philo[N_PHILO]} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-//$define${AOs::Philo} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Philo} ..............................................................
-Philo Philo::inst[N_PHILO];
-
-//${AOs::Philo::Philo} .......................................................
-Philo::Philo()
- : QActive(Q_STATE_CAST(&initial)),
- m_timeEvt(this, TIMEOUT_SIG, 0U),
- m_id(0xFFU)
-{}
-
-//${AOs::Philo::SM} ..........................................................
-Q_STATE_DEF(Philo, initial) {
- //${AOs::Philo::SM::initial}
- Q_UNUSED_PAR(e);
-
- m_id = static_cast(this - &inst[0]);
-
- QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id], m_id);
- QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id].m_timeEvt, m_id);
-
- subscribe(EAT_SIG);
- subscribe(TEST_SIG);
-
- QS_FUN_DICTIONARY(&Philo::thinking);
- QS_FUN_DICTIONARY(&Philo::hungry);
- QS_FUN_DICTIONARY(&Philo::eating);
-
- return tran(&thinking);
-}
-
-//${AOs::Philo::SM::thinking} ................................................
-Q_STATE_DEF(Philo, thinking) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::thinking}
- case Q_ENTRY_SIG: {
- m_timeEvt.armX(think_time(), 0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking}
- case Q_EXIT_SIG: {
- m_timeEvt.disarm();
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking::TIMEOUT}
- case TIMEOUT_SIG: {
- status_ = tran(&hungry);
- break;
- }
- //${AOs::Philo::SM::thinking::EAT, DONE}
- case EAT_SIG: // intentionally fall through
- case DONE_SIG: {
- // EAT or DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking::TEST}
- case TEST_SIG: {
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Philo::SM::hungry} ..................................................
-Q_STATE_DEF(Philo, hungry) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::hungry}
- case Q_ENTRY_SIG: {
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, HUNGRY_SIG, m_id);
- #else
- TableEvt *pe = Q_NEW(TableEvt, HUNGRY_SIG);
- pe->philoId = m_id;
- #endif
- AO_Table->POST(pe, this);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::hungry::EAT}
- case EAT_SIG: {
- //${AOs::Philo::SM::hungry::EAT::[e->philoId==m_id]}
- if (Q_EVT_CAST(TableEvt)->philoId == m_id) {
- status_ = tran(&eating);
- }
- else {
- status_ = Q_RET_UNHANDLED;
- }
- break;
- }
- //${AOs::Philo::SM::hungry::DONE}
- case DONE_SIG: {
- // DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Philo::SM::eating} ..................................................
-Q_STATE_DEF(Philo, eating) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::eating}
- case Q_ENTRY_SIG: {
- m_timeEvt.armX(eat_time(), 0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::eating}
- case Q_EXIT_SIG: {
- m_timeEvt.disarm();
-
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, DONE_SIG, m_id);
- #else
- TableEvt *pe = Q_NEW(TableEvt, DONE_SIG);
- pe->philoId = m_id;
- #endif
- QP::QActive::PUBLISH(pe, this);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::eating::TIMEOUT}
- case TIMEOUT_SIG: {
- status_ = tran(&thinking);
- break;
- }
- //${AOs::Philo::SM::eating::EAT, DONE}
- case EAT_SIG: // intentionally fall through
- case DONE_SIG: {
- // EAT or DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-} // namespace APP
-//$enddef${AOs::Philo} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/README.txt
deleted file mode 100644
index 17af30f26..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/README.txt
+++ /dev/null
@@ -1,50 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size (for most embedded projects
-yyy should be 0, as the using the heap is not recommended).
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-The file startup_efm32pg1b.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.sct b/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.sct
deleted file mode 100644
index 794d15cc6..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Modified by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00020000 { ; load region size_region
- ER_IROM1 0x00000000 0x00020000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: assume STACK size 2048!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.uvoptx b/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.uvoptx
deleted file mode 100644
index 2ba0f3943..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.uvoptx
+++ /dev/null
@@ -1,1074 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- DLGUARM
-
-
-
- 0
- JL2CM3
- -U440060969 -O206 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC8000 -FD20000000 -FF0GECKOP2 -FL020000 -FS00 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=2939,415,3416,730,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
- 0
- 0
- 83
- 1
- 3412
- 0
- 0
- 0
- 0
- 0
- 1
- ..\bsp.cpp
-
- \\dpp_qk\../bsp.cpp\83
-
-
- 1
- 0
- 243
- 1
- 13720
- 0
- 0
- 0
- 0
- 0
- 1
- ..\..\table.cpp
-
- \\\../../table.cpp\243
-
-
- 2
- 0
- 120
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- ..\bsp.cpp
-
-
-
-
-
-
- 0
- 1
- QF::readySet_
-
-
-
-
- 1
- 0
- 0x3D28
- 1
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- JL2CM3
- -U440060969 -O206 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- DLGUARM
- /
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC8000 -FD20000000 -FF0GECKOP2 -FL020000 -FS00 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- DLGUARM
- /
-
-
- 0
- JL2CM3
- -U440060969 -O206 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC8000 -FD20000000 -FF0GECKOP2 -FL020000 -FS00 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\philo.cpp
- philo.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\..\table.cpp
- table.cpp
- 0
- 0
-
-
- 1
- 4
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
-
-
- efm32pg1b
- 1
- 0
- 0
- 0
-
- 2
- 5
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
- startup_efm32pg1b.s
- 0
- 0
-
-
- 2
- 6
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
- system_efm32pg1b.c
- 0
- 0
-
-
- 2
- 7
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
- efm32pg1b200f256gm48.h
- 0
- 0
-
-
- 2
- 8
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
- em_cmu.c
- 0
- 0
-
-
- 2
- 9
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
- em_emu.c
- 0
- 0
-
-
- 2
- 10
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
- em_gpio.c
- 0
- 0
-
-
- 2
- 11
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
- em_system.c
- 0
- 0
-
-
- 2
- 12
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
- em_usart.c
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 13
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qk\qk.cpp
- qk.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
- qk_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_64bit.cpp
- qs_64bit.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.uvprojx b/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.uvprojx
deleted file mode 100644
index 4eba12f88..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/armclang/dpp-qk.uvprojx
+++ /dev/null
@@ -1,1826 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
- 6190000::V6.19::ARMCLANG
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.3.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- dpp-qk
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\dpp-qk.bin .\dbg\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 1
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.3.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- dpp-qk
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\dpp-qk.bin .\rel\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
- 6190000::V6.19::ARMCLANG
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.3.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- dpp-qk
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\dpp-qk.bin .\spy\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 2
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- Q_SPY,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/bsp.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/qk/bsp.cpp
deleted file mode 100644
index 5c2ad7b3f..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/bsp.cpp
+++ /dev/null
@@ -1,559 +0,0 @@
-//============================================================================
-// Product: DPP example, EFM32-SLSTK3401A board, QK kernel
-// Last updated for version 7.3.2
-// Last updated on 2023-12-13
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "em_device.h" // the device specific header (SiLabs)
-#include "em_cmu.h" // Clock Management Unit (SiLabs)
-#include "em_gpio.h" // GPIO (SiLabs)
-#include "em_usart.h" // USART (SiLabs)
-// add other drivers if necessary...
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr GPIO_Port_TypeDef LED_PORT {gpioPortF};
-constexpr std::uint32_t LED0_PIN {4U};
-constexpr std::uint32_t LED1_PIN {5U};
-
-constexpr GPIO_Port_TypeDef PB_PORT {gpioPortF};
-constexpr std::uint32_t PB0_PIN {6U};
-constexpr std::uint32_t PB1_PIN {7U};
-
-static std::uint32_t l_rndSeed;
-
-#ifdef Q_SPY
-
- // QSpy source IDs
- static QP::QSpyId const l_SysTick_Handler = { 0U };
- static QP::QSpyId const l_GPIO_EVEN_IRQHandler = { 0U };
-
- static USART_TypeDef * const l_USART0 = ((USART_TypeDef *)(0x40010000UL));
-
- static QP::QSTimeCtr QS_tickTime_;
- static QP::QSTimeCtr QS_tickPeriod_;
-
- enum AppRecords { // application-specific trace records
- PHILO_STAT = QP::QS_USER,
- PAUSED_STAT,
- CONTEXT_SW,
- };
-
-#endif
-
-} // unnamed namespace
-
-//============================================================================
-// Error handler and ISRs...
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the error handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up both LEDs
- GPIO->P[LED_PORT].DOUT |= ((1U << LED0_PIN) | (1U << LED1_PIN));
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#else
- NVIC_SystemReset();
- for (;;) { // explicitly "no-return"
- }
-#endif
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QK_ISR_ENTRY(); // inform QK about entering an ISR
-
- QP::QTimeEvt::TICK_X(0U, &l_SysTick_Handler); // time events at rate 0
-
- // Perform the debouncing of buttons. The algorithm for debouncing
- // adapted from the book "Embedded Systems Dictionary" by Jack Ganssle
- // and Michael Barr, page 71.
- static struct {
- std::uint32_t depressed;
- std::uint32_t previous;
- } buttons = { 0U, 0U };
-
- std::uint32_t current = ~GPIO->P[PB_PORT].DIN; // read PB0 and BP1
- std::uint32_t tmp = buttons.depressed; // save the depressed buttons
- buttons.depressed |= (buttons.previous & current); // set depressed
- buttons.depressed &= (buttons.previous | current); // clear released
- buttons.previous = current; // update the history
- tmp ^= buttons.depressed; // changed debounced depressed
- current = buttons.depressed;
-
- if ((tmp & (1U << PB0_PIN)) != 0U) { // debounced PB0 state changed?
- if ((current & (1U << PB0_PIN)) != 0U) { // is PB0 depressed?
- static QP::QEvt const pauseEvt(APP::PAUSE_SIG);
- QP::QActive::PUBLISH(&pauseEvt, &l_SysTick_Handler);
- }
- else { // the button is released
- static QP::QEvt const serveEvt(APP::SERVE_SIG);
- QP::QActive::PUBLISH(&serveEvt, &l_SysTick_Handler);
- }
- }
-
-#ifdef Q_SPY
- tmp = SysTick->CTRL; // clear CTRL_COUNTFLAG
- QS_tickTime_ += QS_tickPeriod_; // account for the clock rollover
-#endif
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-//............................................................................
-// interrupt handler for testing preemptions
-void GPIO_EVEN_IRQHandler(void); // prototype
-void GPIO_EVEN_IRQHandler(void) {
- QK_ISR_ENTRY(); // inform QK about entering an ISR
-
- static QP::QEvt const testEvt(APP::TEST_SIG);
- APP::AO_Table->POST(&testEvt, &l_GPIO_EVEN_IRQHandler);
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-
-//............................................................................
-#ifdef Q_SPY
-// ISR for receiving bytes from the QSPY Back-End
-// NOTE: This ISR is "QF-unaware" meaning that it does not interact with
-// the QF/QK and is not disabled. Such ISRs don't need to call
-// QK_ISR_ENTRY/QK_ISR_EXIT and they cannot post or publish events.
-
-void USART0_RX_IRQHandler(void); // prototype
-void USART0_RX_IRQHandler(void) {
- // while RX FIFO NOT empty
- while ((l_USART0->STATUS & USART_STATUS_RXDATAV) != 0U) {
- std::uint8_t b = static_cast(l_USART0->RXDATA);
- QP::QS::rxPut(b);
- }
-
- QK_ARM_ERRATUM_838869();
-}
-#endif // Q_SPY
-
-//............................................................................
-#ifdef QF_ON_CONTEXT_SW
-// NOTE: the context-switch callback is called with interrupts DISABLED
-void QF_onContextSw(QP::QActive *prev, QP::QActive *next) {
- QS_BEGIN_INCRIT(CONTEXT_SW, 0U) // in critical section!
- QS_OBJ(prev);
- QS_OBJ(next);
- QS_END_INCRIT()
-}
-#endif // QF_ON_CONTEXT_SW
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QK
-
- // enable clock for to the peripherals used by this application...
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
-
- // configure the LEDs
- GPIO_PinModeSet(LED_PORT, LED0_PIN, gpioModePushPull, 0);
- GPIO_PinModeSet(LED_PORT, LED1_PIN, gpioModePushPull, 0);
- GPIO_PinOutClear(LED_PORT, LED0_PIN);
- GPIO_PinOutClear(LED_PORT, LED1_PIN);
-
- // configure the Buttons
- GPIO_PinModeSet(PB_PORT, PB0_PIN, gpioModeInputPull, 1);
- GPIO_PinModeSet(PB_PORT, PB1_PIN, gpioModeInputPull, 1);
-
- BSP::randomSeed(1234U);
-
- // initialize the QS software tracing...
- if (!QS_INIT(nullptr)) {
- Q_ERROR();
- }
-
- // dictionaries...
- QS_OBJ_DICTIONARY(&l_SysTick_Handler);
- QS_OBJ_DICTIONARY(&l_GPIO_EVEN_IRQHandler);
- QS_USR_DICTIONARY(PHILO_STAT);
- QS_USR_DICTIONARY(PAUSED_STAT);
- QS_USR_DICTIONARY(CONTEXT_SW);
-
- QS_ONLY(APP::produce_sig_dict());
-
- // setup the QS filters...
- QS_GLB_FILTER(QP::QS_ALL_RECORDS); // all records
- QS_GLB_FILTER(-QP::QS_QF_TICK); // exclude the clock tick
- QS_LOC_FILTER(-(APP::N_PHILO + 3U)); // exclude prio. of AO_Ticker0
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(APP::TableEvt) smlPoolSto[2*APP::N_PHILO];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // start AOs/threads...
- static QP::QEvt const *philoQueueSto[APP::N_PHILO][APP::N_PHILO];
- for (std::uint8_t n = 0U; n < APP::N_PHILO; ++n) {
- APP::AO_Philo[n]->start(
-
- // NOTE: set the preemption-threshold of all Philos to
- // the same level, so that they cannot preempt each other.
- Q_PRIO(n + 3U, APP::N_PHILO + 2U), // QF-prio/pre-thre.
-
- philoQueueSto[n], // event queue storage
- Q_DIM(philoQueueSto[n]), // queue length [events]
- nullptr, 0U); // no stack storage
- }
-
- static QP::QEvt const *tableQueueSto[APP::N_PHILO];
- APP::AO_Table->start(
- APP::N_PHILO + 7U, // QP prio. of the AO
- tableQueueSto, // event queue storage
- Q_DIM(tableQueueSto), // queue length [events]
- nullptr, 0U); // no stack storage
-}
-//............................................................................
-void displayPhilStat(std::uint8_t n, char const *stat) {
- Q_UNUSED_PAR(n);
-
- if (stat[0] == 'e') {
- GPIO->P[LED_PORT].DOUT |= (1U << LED0_PIN);
- }
- else {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED0_PIN);
- }
-
- // app-specific trace record...
- QS_BEGIN_ID(PHILO_STAT, APP::AO_Table->getPrio())
- QS_U8(1, n); // Philosopher number
- QS_STR(stat); // Philosopher status
- QS_END()
-}
-//............................................................................
-void displayPaused(std::uint8_t const paused) {
- if (paused != 0U) {
- GPIO->P[LED_PORT].DOUT |= (1U << LED0_PIN);
- }
- else {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED0_PIN);
- }
-
- // application-specific trace record
- QS_BEGIN_ID(PAUSED_STAT, APP::AO_Table->getPrio())
- QS_U8(1, paused); // Paused status
- QS_END()
-}
-//............................................................................
-void randomSeed(uint32_t const seed) {
- l_rndSeed = seed;
-}
-//............................................................................
-std::uint32_t random() { // a very cheap pseudo-random-number generator
- // Some floating point code is to exercise the VFP...
- float volatile x = 3.1415926F;
- x = x + 2.7182818F;
-
- QP::QSchedStatus lockStat = QP::QK::schedLock(APP::N_PHILO);
- // "Super-Duper" Linear Congruential Generator (LCG)
- // LCG(2^32, 3*7*11*13*23, 0, seed)
- std::uint32_t rnd = l_rndSeed * (3U*7U*11U*13U*23U);
- l_rndSeed = rnd; // set for the next time
- QP::QK::schedUnlock(lockStat);
-
- return (rnd >> 8U);
-}
-//............................................................................
-void ledOn() {
- GPIO->P[LED_PORT].DOUT |= (1U << LED1_PIN);
-}
-//............................................................................
-void ledOff() {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED1_PIN);
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-
-//============================================================================
-namespace QP {
-
-// QF callbacks --------------------------------------------------------------
-
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(USART0_RX_IRQn, 0U); // kernel unaware interrupt
- NVIC_SetPriority(GPIO_EVEN_IRQn, QF_AWARE_ISR_CMSIS_PRI + 0U);
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
- NVIC_EnableIRQ(GPIO_EVEN_IRQn);
-
-#ifdef Q_SPY
- NVIC_EnableIRQ(USART0_RX_IRQn); // UART0 interrupt used for QS-RX
-#endif
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QK::onIdle() {
- // toggle the User LED on and then off, see NOTE3
-// QF_INT_DISABLE();
-// GPIO->P[LED_PORT].DOUT |= (1U << LED1_PIN);
-// GPIO->P[LED_PORT].DOUT &= ~(1U << LED1_PIN);
-// QF_INT_ENABLE();
-
-#ifdef Q_SPY
- QF_INT_DISABLE();
- QS::rxParse(); // parse all the received bytes
- QF_INT_ENABLE();
-
- if ((l_USART0->STATUS & USART_STATUS_TXBL) != 0) { // is TXE empty?
- QF_INT_DISABLE();
- std::uint16_t b = QS::getByte();
- QF_INT_ENABLE();
-
- if (b != QS_EOD) { // not End-Of-Data?
- l_USART0->TXDATA = b; // put into the DR register
- }
- }
-#elif defined NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- __WFI(); // Wait-For-Interrupt
-#endif
-}
-
-//============================================================================
-// QS callbacks...
-#ifdef Q_SPY
-namespace QS {
-
-//............................................................................
-bool onStartup(void const *arg) {
- Q_UNUSED_PAR(arg);
-
- static std::uint8_t qsTxBuf[2*1024]; // buffer for QS-TX channel
- initBuf(qsTxBuf, sizeof(qsTxBuf));
-
- static std::uint8_t qsRxBuf[100]; // buffer for QS-RX channel
- rxInitBuf(qsRxBuf, sizeof(qsRxBuf));
-
- static USART_InitAsync_TypeDef init = {
- usartEnable, // Enable RX/TX when init completed
- 0, // Use current clock for configuring baudrate
- 115200, // 115200 bits/s
- usartOVS16, // 16x oversampling
- usartDatabits8, // 8 databits
- usartNoParity, // No parity
- usartStopbits1, // 1 stopbit
- 0, // Do not disable majority vote
- 0, // Not USART PRS input mode
- usartPrsRxCh0, // PRS channel 0
- 0, // Auto CS functionality enable/disable switch
- 0, // Auto CS Hold cycles
- 0 // Auto CS Setup cycles
- };
-
- // Enable peripheral clocks
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
-
- // To avoid false start, configure output as high
- GPIO_PinModeSet(gpioPortA, 0, gpioModePushPull, 1); // TX pin
- GPIO_PinModeSet(gpioPortA, 1, gpioModeInput, 0); // RX pin
-
- // Enable DK RS232/UART switch
- GPIO_PinModeSet(gpioPortA, 5, gpioModePushPull, 1);
- CMU_ClockEnable(cmuClock_USART0, true);
-
- // configure the UART for the desired baud rate, 8-N-1 operation
- init.enable = usartDisable;
- USART_InitAsync(l_USART0, &init);
-
- // enable pins at correct UART/USART location.
- l_USART0->ROUTEPEN = USART_ROUTEPEN_RXPEN | USART_ROUTEPEN_TXPEN;
- l_USART0->ROUTELOC0 = (l_USART0->ROUTELOC0 &
- ~(_USART_ROUTELOC0_TXLOC_MASK
- | _USART_ROUTELOC0_RXLOC_MASK));
-
- // Clear previous RX interrupts
- USART_IntClear(l_USART0, USART_IF_RXDATAV);
- NVIC_ClearPendingIRQ(USART0_RX_IRQn);
-
- // Enable RX interrupts
- USART_IntEnable(l_USART0, USART_IF_RXDATAV);
- // NOTE: do not enable the UART0 interrupt in the NVIC yet.
- // Wait till QF::onStartup()
-
- // Finally enable the UART
- USART_Enable(l_USART0, usartEnable);
-
- QS_tickPeriod_ = SystemCoreClock / BSP::TICKS_PER_SEC;
- QS_tickTime_ = QS_tickPeriod_; // to start the timestamp at zero
-
- return true; // return success
-}
-//............................................................................
-void onCleanup() {
-}
-//............................................................................
-QSTimeCtr onGetTime() { // NOTE: invoked with interrupts DISABLED
- if ((SysTick->CTRL & SysTick_CTRL_COUNTFLAG_Msk) == 0U) { // not set?
- return QS_tickTime_ - (QSTimeCtr)SysTick->VAL;
- }
- else { // the rollover occurred, but the SysTick_ISR did not run yet
- return QS_tickTime_ + QS_tickPeriod_ - (QSTimeCtr)SysTick->VAL;
- }
-}
-//............................................................................
-// NOTE:
-// No critical section in QS::onFlush() to avoid nesting of critical sections
-// in case QS::onFlush() is called from Q_onError().
-void onFlush() {
- for (;;) {
- std::uint16_t b = getByte();
- if (b != QS_EOD) {
- while ((l_USART0->STATUS & USART_STATUS_TXBL) == 0U) {
- }
- l_USART0->TXDATA = b;
- }
- else {
- break;
- }
- }
-}
-//............................................................................
-void onReset() {
- NVIC_SystemReset();
-}
-//............................................................................
-void onCommand(std::uint8_t cmdId, std::uint32_t param1,
- std::uint32_t param2, std::uint32_t param3)
-{
- Q_UNUSED_PAR(cmdId);
- Q_UNUSED_PAR(param1);
- Q_UNUSED_PAR(param2);
- Q_UNUSED_PAR(param3);
-}
-
-} // namespace QS
-#endif // Q_SPY
-//----------------------------------------------------------------------------
-
-} // namespace QP
-
-//============================================================================
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call the QK_ISR_ENTRY/
-// QK_ISR_ENTRY macros or any other QF/QK services. These ISRs are
-// "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QK services. In particular they
-// can NOT call the macros QK_ISR_ENTRY/QK_ISR_ENTRY. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/Makefile b/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/Makefile
deleted file mode 100644
index 1af21e40e..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/Makefile
+++ /dev/null
@@ -1,316 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EMF32-SLSTK3401A, QK kernel, GNU-ARM
-# Last Updated for Version: 7.3.0
-# Date of the Last Update: 2023-09-08
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools/releases
-#
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := dpp-qk
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qk/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qk \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/efm32pg1b \
- $(QPCPP)/3rd_party/efm32pg1b/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/efm32pg1b
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- startup_efm32pg1b.c \
- system_efm32pg1b.c \
- em_cmu.c \
- em_emu.c \
- em_gpio.c \
- em_usart.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- philo.cpp \
- table.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qk.cpp \
- qk_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := \
- -DQP_CONFIG \
- -DEFM32PG1B200F256GM48=1
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=vfp
-FLOAT_ABI := -mfloat-abi=softfp
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically, you should not need to change anything below this line
-
-# basic utilities (included in Qtools for Windows), see:
-# http://sourceforge.net/projects/qpc/files/Qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O1 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O1 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-.PHONY : clean
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/README.txt
deleted file mode 100644
index b4d4451a1..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/README.txt
+++ /dev/null
@@ -1,71 +0,0 @@
-About this Example
-==================
-This example can be built from the command prompt with the provided
-Makefile. The example can also be imported as a Makefile-based
-project into Eclipse-based IDEs.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-Also, the Makefile has been specifically designed to work as an external
-Makefile with the Eclipse CDT.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the EFM32PG1B200F256GM48 MCU used in this project
-is located in the "3rd_party" folder in the following location:
-
-qpc\3rd_party\efm32pg1b\gnu\startup_efm32pg1b.c
-
-The file startup_efm32pg1b.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/dpp-qk.ld b/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/dpp-qk.ld
deleted file mode 100644
index 2132b696a..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/dpp-qk.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EFM32-SLSTK3401A, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* https://state-machine.com
-* mailto:info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Pearl Gecko EFM32PG1B200F256GM48 */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/flash.bat b/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/flash.bat
deleted file mode 100644
index 23215d0ba..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/gnu/flash.bat
+++ /dev/null
@@ -1,49 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EFM32-SLSTK3401A board
-::
-:: NOTE: requires the J-Link commander (JLink.exe) from SEGGER, see:
-:: https://www.segger.com/j-link-commander.html
-::
-setlocal
-
-@echo off
-@echo Load a given binary file to the flash of EFM32-SLSTK3401A
-@echo usage: flash bin-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: Adjust the following symbol to the location of the
-:: JLink utility on your machine
-::
-if [%JLINK%] EQU [] set JLINK=%QTOOLS%\..\JLink
-if not exist "%JLINK%\JLink.exe" (
- @echo The JLink tool not found. Please adjust flash.bat
- @goto end
-)
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-:: generate the Jlink command file depending on the first parameter %1
-@echo si 1 >flash.jlink
-@echo speed 4000 >>flash.jlink
-@echo r >>flash.jlink
-@echo h >>flash.jlink
-@echo loadbin %1, 0 >>flash.jlink
-@echo exit >>flash.jlink
-
-@echo on
-%JLINK%\JLink.exe -device EFM32PG1B200F256GM48 flash.jlink
-@echo off
-
-@del flash.jlink
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/README.txt
deleted file mode 100644
index fb12fa8f7..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-============
-The startup code for the EFM32PG1B200F256GM48 MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\efm32pg1b\iar\startup_efm32pg1b.s
-
-The file startup_efm32pg1b.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.ewd b/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.ewd
deleted file mode 100644
index 801230fb9..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.ewp b/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.ewp
deleted file mode 100644
index 829cd8e2d..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.ewp
+++ /dev/null
@@ -1,3358 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\dpp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
- $PROJ_DIR$\..\..\philo.cpp
-
-
- $PROJ_DIR$\..\..\table.cpp
-
-
-
- efm32pg1b
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\iar\startup_efm32pg1b.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qk\qk.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qk\iar\qk_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.eww b/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.eww
deleted file mode 100644
index c261124af..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\dpp-qk.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.icf b/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.icf
deleted file mode 100644
index 0fdfc4b30..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qk/iar/dpp-qk.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK };
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qp_config.hpp b/examples/arm-cm/dpp_efm32-slstk3401a/qp_config.hpp
deleted file mode 100644
index e79c27399..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qp_config.hpp
+++ /dev/null
@@ -1,59 +0,0 @@
-//============================================================================
-// QP configuration file example
-// Last updated for version: 7.3.0
-// Last updated on: 2023-09-07
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef QP_CONFIG_HPP_
-#define QP_CONFIG_HPP_
-
-// NOTE:
-// The QP configuration takes effect only when the macro QP_CONFIG
-// is defined on the command-line to the compiler for all QP source files.
-
-// use event constructors for dynamic events
-#define QEVT_DYN_CTOR
-
-// for QK kernel:
-// use the FPUEH_IRQHandler() with IRQ number 33
-// for the QXK return-from-preemption handler
-#define QK_USE_IRQ_HANDLER FPUEH_IRQHandler
-#define QK_USE_IRQ_NUM 33
-
-// for QXK kernel:
-// use the FPUEH_IRQHandler() with IRQ number 33
-// for the QXK return-from-preemption handler
-#define QXK_USE_IRQ_HANDLER FPUEH_IRQHandler
-#define QXK_USE_IRQ_NUM 33
-
-#ifdef Q_SPY
-// for the Spy build configuration, enable the context-switch callback
-#define QF_ON_CONTEXT_SW
-#endif
-
-#endif // QP_CONFIG_HPP_
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/README.txt
deleted file mode 100644
index 17af30f26..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/README.txt
+++ /dev/null
@@ -1,50 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size (for most embedded projects
-yyy should be 0, as the using the heap is not recommended).
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-The file startup_efm32pg1b.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.sct b/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.sct
deleted file mode 100644
index 794d15cc6..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Modified by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00020000 { ; load region size_region
- ER_IROM1 0x00000000 0x00020000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: assume STACK size 2048!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.uvoptx b/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.uvoptx
deleted file mode 100644
index 028fcd9f3..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.uvoptx
+++ /dev/null
@@ -1,1047 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- DLGUARM
-
-
-
- 0
- JL2CM3
- -U440060969 -O206 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC8000 -FD20000000 -FF0GECKOP2 -FL020000 -FS00 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
- 0
- 0
- 356
- 1
- 2170
- 0
- 0
- 0
- 0
- 0
- 1
- ..\bsp.cpp
-
- \\dpp_qv\../bsp.cpp\356
-
-
-
-
- 0
- 1
- QActive::registry_
-
-
- 1
- 1
- QActive::maxPubSignal_
-
-
- 2
- 1
- QV::priv_
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- JL2CM3
- -U440060969 -O206 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- DLGUARM
- /
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC8000 -FD20000000 -FF0GECKOP2 -FL020000 -FS00 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- JL2CM3
- -U440060969 -O206 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(0) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC8000 -FD20000000 -FF0GECKOP2 -FL020000 -FS00 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\philo.cpp
- philo.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\..\table.cpp
- table.cpp
- 0
- 0
-
-
- 1
- 4
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
-
-
- efm32pg1b
- 1
- 0
- 0
- 0
-
- 2
- 5
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
- startup_efm32pg1b.s
- 0
- 0
-
-
- 2
- 6
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
- efm32pg1b200f256gm48.h
- 0
- 0
-
-
- 2
- 7
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
- em_gpio.c
- 0
- 0
-
-
- 2
- 8
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
- system_efm32pg1b.c
- 0
- 0
-
-
- 2
- 9
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
- em_system.c
- 0
- 0
-
-
- 2
- 10
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
- em_emu.c
- 0
- 0
-
-
- 2
- 11
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
- em_cmu.c
- 0
- 0
-
-
- 2
- 12
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
- em_usart.c
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 13
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qv\qv.cpp
- qv.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
- qv_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_64bit.cpp
- qs_64bit.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.uvprojx b/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.uvprojx
deleted file mode 100644
index 10e4d79ff..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/armclang/dpp-qv.uvprojx
+++ /dev/null
@@ -1,1823 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.0.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- dpp-qv
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\dpp-qv.bin .\dbg\dpp-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- QP_CONFIG,EFM32PG1B200F256GM48
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
- 5060183::V5.06 update 2 (build 183)::ARMCC
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.0.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- dpp-qv
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\dpp-qv.bin .\rel\dpp-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG,QP_CONFIG,EFM32PG1B200F256GM48
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.0.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- dpp-qv
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\dpp-qv.bin .\spy\dpp-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- Q_SPY,QP_CONFIG,EFM32PG1B200F256GM48
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/bsp.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/qv/bsp.cpp
deleted file mode 100644
index 9212cbe91..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/bsp.cpp
+++ /dev/null
@@ -1,555 +0,0 @@
-//============================================================================
-// Product: DPP example, EFM32-SLSTK3401A board, QV kernel
-// Last updated for version 7.3.2
-// Last updated on 2023-12-13
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "em_device.h" // the device specific header (SiLabs)
-#include "em_cmu.h" // Clock Management Unit (SiLabs)
-#include "em_gpio.h" // GPIO (SiLabs)
-#include "em_usart.h" // USART (SiLabs)
-// add other drivers if necessary...
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr GPIO_Port_TypeDef LED_PORT {gpioPortF};
-constexpr std::uint32_t LED0_PIN {4U};
-constexpr std::uint32_t LED1_PIN {5U};
-
-constexpr GPIO_Port_TypeDef PB_PORT {gpioPortF};
-constexpr std::uint32_t PB0_PIN {6U};
-constexpr std::uint32_t PB1_PIN {7U};
-
-static std::uint32_t l_rndSeed;
-
-#ifdef Q_SPY
-
- // QSpy source IDs
- QP::QSpyId const l_SysTick_Handler = { 0U };
- QP::QSpyId const l_GPIO_EVEN_IRQHandler = { 0U };
-
- static USART_TypeDef * const l_USART0 = ((USART_TypeDef *)(0x40010000UL));
-
- static QP::QSTimeCtr QS_tickTime_;
- static QP::QSTimeCtr QS_tickPeriod_;
-
- enum AppRecords { // application-specific trace records
- PHILO_STAT = QP::QS_USER,
- PAUSED_STAT,
- CONTEXT_SW,
- };
-
-#endif
-
-} // unnamed namespace
-
-//============================================================================
-// Error handler and ISRs...
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the error handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up both LEDs
- GPIO->P[LED_PORT].DOUT |= ((1U << LED0_PIN) | (1U << LED1_PIN));
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#else
- NVIC_SystemReset();
- for (;;) { // explicitly "no-return"
- }
-#endif
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
-
- QP::QTimeEvt::TICK_X(0U, &l_SysTick_Handler); // time events at rate 0
-
- // Perform the debouncing of buttons. The algorithm for debouncing
- // adapted from the book "Embedded Systems Dictionary" by Jack Ganssle
- // and Michael Barr, page 71.
- static struct {
- std::uint32_t depressed;
- std::uint32_t previous;
- } buttons = { 0U, 0U };
-
- std::uint32_t current = ~GPIO->P[PB_PORT].DIN; // read PB0 and BP1
- std::uint32_t tmp = buttons.depressed; // save the depressed buttons
- buttons.depressed |= (buttons.previous & current); // set depressed
- buttons.depressed &= (buttons.previous | current); // clear released
- buttons.previous = current; // update the history
- tmp ^= buttons.depressed; // changed debounced depressed
- current = buttons.depressed;
-
- if ((tmp & (1U << PB0_PIN)) != 0U) { // debounced PB0 state changed?
- if ((current & (1U << PB0_PIN)) != 0U) { // is PB0 depressed?
- static QP::QEvt const pauseEvt(APP::PAUSE_SIG);
- QP::QActive::PUBLISH(&pauseEvt, &l_SysTick_Handler);
- }
- else { // the button is released
- static QP::QEvt const serveEvt(APP::SERVE_SIG);
- QP::QActive::PUBLISH(&serveEvt, &l_SysTick_Handler);
- }
- }
-
-#ifdef Q_SPY
- tmp = SysTick->CTRL; // clear CTRL_COUNTFLAG
- QS_tickTime_ += QS_tickPeriod_; // account for the clock rollover
-#endif
-
- QV_ARM_ERRATUM_838869();
-}
-//............................................................................
-// interrupt handler for testing preemptions
-void GPIO_EVEN_IRQHandler(void); // prototype
-void GPIO_EVEN_IRQHandler(void) {
-
- static QP::QEvt const testEvt(APP::TEST_SIG);
- APP::AO_Table->POST(&testEvt, &l_GPIO_EVEN_IRQHandler);
-
- QV_ARM_ERRATUM_838869();
-}
-
-//............................................................................
-#ifdef Q_SPY
-// ISR for receiving bytes from the QSPY Back-End
-// NOTE: This ISR is "QF-unaware" meaning that it does not interact with
-// the QF/QV and is not disabled. Such ISRs cannot post or publish events.
-
-void USART0_RX_IRQHandler(void); // prototype
-void USART0_RX_IRQHandler(void) {
- // while RX FIFO NOT empty
- while ((l_USART0->STATUS & USART_STATUS_RXDATAV) != 0U) {
- std::uint8_t b = static_cast(l_USART0->RXDATA);
- QP::QS::rxPut(b);
- }
-
- QV_ARM_ERRATUM_838869();
-}
-#endif // Q_SPY
-
-//............................................................................
-#ifdef QF_ON_CONTEXT_SW
-// NOTE: the context-switch callback is called with interrupts DISABLED
-void QF_onContextSw(QP::QActive *prev, QP::QActive *next) {
- QS_BEGIN_INCRIT(CONTEXT_SW, 0U) // in critical section!
- QS_OBJ(prev);
- QS_OBJ(next);
- QS_END_INCRIT()
-}
-#endif // QF_ON_CONTEXT_SW
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QV
-
- // enable clock for to the peripherals used by this application...
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
-
- // configure the LEDs
- GPIO_PinModeSet(LED_PORT, LED0_PIN, gpioModePushPull, 0);
- GPIO_PinModeSet(LED_PORT, LED1_PIN, gpioModePushPull, 0);
- GPIO_PinOutClear(LED_PORT, LED0_PIN);
- GPIO_PinOutClear(LED_PORT, LED1_PIN);
-
- // configure the Buttons
- GPIO_PinModeSet(PB_PORT, PB0_PIN, gpioModeInputPull, 1);
- GPIO_PinModeSet(PB_PORT, PB1_PIN, gpioModeInputPull, 1);
-
- BSP::randomSeed(1234U);
-
- // initialize the QS software tracing...
- if (!QS_INIT(nullptr)) {
- Q_ERROR();
- }
-
- // dictionaries...
- QS_OBJ_DICTIONARY(&l_SysTick_Handler);
- QS_OBJ_DICTIONARY(&l_GPIO_EVEN_IRQHandler);
- QS_USR_DICTIONARY(PHILO_STAT);
- QS_USR_DICTIONARY(PAUSED_STAT);
- QS_USR_DICTIONARY(CONTEXT_SW);
-
- QS_ONLY(APP::produce_sig_dict());
-
- // setup the QS filters...
- QS_GLB_FILTER(QP::QS_ALL_RECORDS); // all records
- QS_GLB_FILTER(-QP::QS_QF_TICK); // exclude the clock tick
- QS_LOC_FILTER(-(APP::N_PHILO + 3U)); // exclude prio. of AO_Ticker0
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(APP::TableEvt) smlPoolSto[2*APP::N_PHILO];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // start AOs/threads...
- static QP::QEvt const *philoQueueSto[APP::N_PHILO][APP::N_PHILO];
- for (std::uint8_t n = 0U; n < APP::N_PHILO; ++n) {
- APP::AO_Philo[n]->start(
- n + 3U, // QF-prio/pthre. see NOTE1
- philoQueueSto[n], // event queue storage
- Q_DIM(philoQueueSto[n]), // queue length [events]
- nullptr, 0U); // no stack storage
- }
-
- static QP::QEvt const *tableQueueSto[APP::N_PHILO];
- APP::AO_Table->start(
- APP::N_PHILO + 7U, // QP prio. of the AO
- tableQueueSto, // event queue storage
- Q_DIM(tableQueueSto), // queue length [events]
- nullptr, 0U); // no stack storage
-}
-//............................................................................
-void displayPhilStat(std::uint8_t n, char const *stat) {
- Q_UNUSED_PAR(n);
-
- if (stat[0] == 'e') {
- GPIO->P[LED_PORT].DOUT |= (1U << LED0_PIN);
- }
- else {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED0_PIN);
- }
-
- // app-specific trace record...
- QS_BEGIN_ID(PHILO_STAT, APP::AO_Table->getPrio())
- QS_U8(1, n); // Philosopher number
- QS_STR(stat); // Philosopher status
- QS_END()
-}
-//............................................................................
-void displayPaused(std::uint8_t const paused) {
- if (paused != 0U) {
- GPIO->P[LED_PORT].DOUT |= (1U << LED0_PIN);
- }
- else {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED0_PIN);
- }
-
- // application-specific trace record
- QS_BEGIN_ID(PAUSED_STAT, APP::AO_Table->getPrio())
- QS_U8(1, paused); // Paused status
- QS_END()
-}
-//............................................................................
-void randomSeed(uint32_t const seed) {
- l_rndSeed = seed;
-}
-//............................................................................
-std::uint32_t random() { // a very cheap pseudo-random-number generator
- // Some floating point code is to exercise the VFP...
- float volatile x = 3.1415926F;
- x = x + 2.7182818F;
-
- // NOTE: no need to protect shared 'l_rndSeed' in the QV kernel
-
- // "Super-Duper" Linear Congruential Generator (LCG)
- // LCG(2^32, 3*7*11*13*23, 0, seed)
- std::uint32_t rnd = l_rndSeed * (3U*7U*11U*13U*23U);
- l_rndSeed = rnd; // set for the next time
-
- return (rnd >> 8U);
-}
-//............................................................................
-void ledOn() {
- GPIO->P[LED_PORT].DOUT |= (1U << LED1_PIN);
-}
-//............................................................................
-void ledOff() {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED1_PIN);
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-// namespace QP
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(USART0_RX_IRQn, 0U); // kernel unaware interrupt
- NVIC_SetPriority(GPIO_EVEN_IRQn, QF_AWARE_ISR_CMSIS_PRI + 0U);
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
- NVIC_EnableIRQ(GPIO_EVEN_IRQn);
-
-#ifdef Q_SPY
- NVIC_EnableIRQ(USART0_RX_IRQn); // UART0 interrupt used for QS-RX
-#endif
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QV::onIdle() { // CAUTION: called with interrupts DISABLED, see NOTE0
- // toggle the User LED on and then off, see NOTE3
-// GPIO->P[LED_PORT].DOUT |= (1U << LED1_PIN);
-// GPIO->P[LED_PORT].DOUT &= ~(1U << LED1_PIN);
-
-#ifdef Q_SPY
- // intgerrupts still disabled
- QS::rxParse(); // parse all the received bytes
- QF_INT_ENABLE();
-
- if ((l_USART0->STATUS & USART_STATUS_TXBL) != 0) { // is TXE empty?
- QF_INT_DISABLE();
- std::uint16_t b = QS::getByte();
- QF_INT_ENABLE();
-
- if (b != QS_EOD) { // not End-Of-Data?
- l_USART0->TXDATA = b; // put into the DR register
- }
- }
-#elif defined NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- QV_CPU_SLEEP(); // atomically go to sleep and enable interrupts
-#else
- QF_INT_ENABLE(); // just enable interrupts
-#endif
-}
-
-//============================================================================
-// QS callbacks...
-#ifdef Q_SPY
-namespace QS {
-
-//............................................................................
-bool onStartup(void const *arg) {
- Q_UNUSED_PAR(arg);
-
- static std::uint8_t qsTxBuf[2*1024]; // buffer for QS-TX channel
- initBuf(qsTxBuf, sizeof(qsTxBuf));
-
- static std::uint8_t qsRxBuf[100]; // buffer for QS-RX channel
- rxInitBuf(qsRxBuf, sizeof(qsRxBuf));
-
- static USART_InitAsync_TypeDef init = {
- usartEnable, // Enable RX/TX when init completed
- 0, // Use current clock for configuring baudrate
- 115200, // 115200 bits/s
- usartOVS16, // 16x oversampling
- usartDatabits8, // 8 databits
- usartNoParity, // No parity
- usartStopbits1, // 1 stopbit
- 0, // Do not disable majority vote
- 0, // Not USART PRS input mode
- usartPrsRxCh0, // PRS channel 0
- 0, // Auto CS functionality enable/disable switch
- 0, // Auto CS Hold cycles
- 0 // Auto CS Setup cycles
- };
-
- // Enable peripheral clocks
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
-
- // To avoid false start, configure output as high
- GPIO_PinModeSet(gpioPortA, 0, gpioModePushPull, 1); // TX pin
- GPIO_PinModeSet(gpioPortA, 1, gpioModeInput, 0); // RX pin
-
- // Enable DK RS232/UART switch
- GPIO_PinModeSet(gpioPortA, 5, gpioModePushPull, 1);
- CMU_ClockEnable(cmuClock_USART0, true);
-
- // configure the UART for the desired baud rate, 8-N-1 operation
- init.enable = usartDisable;
- USART_InitAsync(l_USART0, &init);
-
- // enable pins at correct UART/USART location.
- l_USART0->ROUTEPEN = USART_ROUTEPEN_RXPEN | USART_ROUTEPEN_TXPEN;
- l_USART0->ROUTELOC0 = (l_USART0->ROUTELOC0 &
- ~(_USART_ROUTELOC0_TXLOC_MASK
- | _USART_ROUTELOC0_RXLOC_MASK));
-
- // Clear previous RX interrupts
- USART_IntClear(l_USART0, USART_IF_RXDATAV);
- NVIC_ClearPendingIRQ(USART0_RX_IRQn);
-
- // Enable RX interrupts
- USART_IntEnable(l_USART0, USART_IF_RXDATAV);
- // NOTE: do not enable the UART0 interrupt in the NVIC yet.
- // Wait till QF_onStartup()
-
- // Finally enable the UART
- USART_Enable(l_USART0, usartEnable);
-
- QS_tickPeriod_ = SystemCoreClock / BSP::TICKS_PER_SEC;
- QS_tickTime_ = QS_tickPeriod_; // to start the timestamp at zero
-
- return true; // return success
-}
-//............................................................................
-void onCleanup() {
-}
-//............................................................................
-QSTimeCtr onGetTime() { // NOTE: invoked with interrupts DISABLED
- if ((SysTick->CTRL & SysTick_CTRL_COUNTFLAG_Msk) == 0U) { // not set?
- return QS_tickTime_ - (QSTimeCtr)SysTick->VAL;
- }
- else { // the rollover occurred, but the SysTick_ISR did not run yet
- return QS_tickTime_ + QS_tickPeriod_ - (QSTimeCtr)SysTick->VAL;
- }
-}
-//............................................................................
-// NOTE:
-// No critical section in QS::onFlush() to avoid nesting of critical sections
-// in case QS::onFlush() is called from Q_onError().
-void onFlush() {
- for (;;) {
- std::uint16_t b = getByte();
- if (b != QS_EOD) {
- while ((l_USART0->STATUS & USART_STATUS_TXBL) == 0U) {
- }
- l_USART0->TXDATA = b;
- }
- else {
- break;
- }
- }
-}
-//............................................................................
-void onReset() {
- NVIC_SystemReset();
-}
-//............................................................................
-void onCommand(std::uint8_t cmdId, std::uint32_t param1,
- std::uint32_t param2, std::uint32_t param3)
-{
- Q_UNUSED_PAR(cmdId);
- Q_UNUSED_PAR(param1);
- Q_UNUSED_PAR(param2);
- Q_UNUSED_PAR(param3);
-}
-
-} // namespace QS
-#endif // Q_SPY
-//----------------------------------------------------------------------------
-
-} // namespace QP
-
-//============================================================================
-// NOTE0:
-// The QV:onIdle() callback is called with interrupts disabled, because the
-// determination of the idle condition might change by any interrupt posting
-// an event. QV::onIdle() must internally enable interrupts, ideally
-// atomically with putting the CPU to the power-saving mode.
-//
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call any QF/QK services. These ISRs
-// are "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QV services. In particular they
-// can NOT call the macros QV_ISR_ENTRY/QV_ISR_ENTRY. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/Makefile b/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/Makefile
deleted file mode 100644
index ef900dc1d..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/Makefile
+++ /dev/null
@@ -1,316 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EMF32-SLSTK3401A, QV kernel, GNU-ARM
-# Last Updated for Version: 7.2.0
-# Date of the Last Update: 2022-12-14
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools/releases
-#
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := dpp-qv
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qv/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qv \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/efm32pg1b \
- $(QPCPP)/3rd_party/efm32pg1b/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/efm32pg1b
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- startup_efm32pg1b.c \
- system_efm32pg1b.c \
- em_cmu.c \
- em_emu.c \
- em_gpio.c \
- em_usart.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- philo.cpp \
- table.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qv.cpp \
- qv_port.cpp
-
-QP_ASMS := \
-
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DEFM32PG1B200F256GM48=1 \
- -DQF_ON_CONTEXT_SW
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=vfp
-FLOAT_ABI := -mfloat-abi=softfp
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically, you should not need to change anything below this line
-
-# basic utilities (included in Qtools for Windows), see:
-# http://sourceforge.net/projects/qpc/files/Qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O1 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O1 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-.PHONY : clean
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/README.txt
deleted file mode 100644
index b4d4451a1..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/README.txt
+++ /dev/null
@@ -1,71 +0,0 @@
-About this Example
-==================
-This example can be built from the command prompt with the provided
-Makefile. The example can also be imported as a Makefile-based
-project into Eclipse-based IDEs.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-Also, the Makefile has been specifically designed to work as an external
-Makefile with the Eclipse CDT.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the EFM32PG1B200F256GM48 MCU used in this project
-is located in the "3rd_party" folder in the following location:
-
-qpc\3rd_party\efm32pg1b\gnu\startup_efm32pg1b.c
-
-The file startup_efm32pg1b.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/dpp-qv.ld b/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/dpp-qv.ld
deleted file mode 100644
index 12002fb85..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/dpp-qv.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EFM32-SLSTK3401A, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* http://www.state-machine.com
-* mailto:info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Pearl Gecko EFM32PG1B200F256GM48 */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/flash.bat b/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/flash.bat
deleted file mode 100644
index 23215d0ba..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/gnu/flash.bat
+++ /dev/null
@@ -1,49 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EFM32-SLSTK3401A board
-::
-:: NOTE: requires the J-Link commander (JLink.exe) from SEGGER, see:
-:: https://www.segger.com/j-link-commander.html
-::
-setlocal
-
-@echo off
-@echo Load a given binary file to the flash of EFM32-SLSTK3401A
-@echo usage: flash bin-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: Adjust the following symbol to the location of the
-:: JLink utility on your machine
-::
-if [%JLINK%] EQU [] set JLINK=%QTOOLS%\..\JLink
-if not exist "%JLINK%\JLink.exe" (
- @echo The JLink tool not found. Please adjust flash.bat
- @goto end
-)
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-:: generate the Jlink command file depending on the first parameter %1
-@echo si 1 >flash.jlink
-@echo speed 4000 >>flash.jlink
-@echo r >>flash.jlink
-@echo h >>flash.jlink
-@echo loadbin %1, 0 >>flash.jlink
-@echo exit >>flash.jlink
-
-@echo on
-%JLINK%\JLink.exe -device EFM32PG1B200F256GM48 flash.jlink
-@echo off
-
-@del flash.jlink
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/README.txt
deleted file mode 100644
index fb12fa8f7..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-============
-The startup code for the EFM32PG1B200F256GM48 MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\efm32pg1b\iar\startup_efm32pg1b.s
-
-The file startup_efm32pg1b.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.ewd b/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.ewd
deleted file mode 100644
index cb16c8880..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.ewp b/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.ewp
deleted file mode 100644
index 2aad0cdcb..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.ewp
+++ /dev/null
@@ -1,3358 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\dpp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
- $PROJ_DIR$\..\..\philo.cpp
-
-
- $PROJ_DIR$\..\..\table.cpp
-
-
-
- efm32pg1b
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\iar\startup_efm32pg1b.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qv\qv.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qv\iar\qv_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.eww b/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.eww
deleted file mode 100644
index b96f3f620..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\dpp-qv.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.icf b/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.icf
deleted file mode 100644
index 0fdfc4b30..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qv/iar/dpp-qv.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK };
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/dpp.py b/examples/arm-cm/dpp_efm32-slstk3401a/qview/dpp.py
deleted file mode 100644
index 60c1805b9..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qview/dpp.py
+++ /dev/null
@@ -1,103 +0,0 @@
-# This is an example of QView customization for a specific application
-# (DPP in this case). This example animates the Phil images on the
-# QView canvas. Additionally, there is a button in the middle of the screen,
-# which, when clicked once pauses the DPP ("forks" are not being served).
-# A second click on the button, "un-pauses" the DPP ("forks" are served
-# to all hungry Philosophers).
-#
-# This version of the DPP customization uses the application-specific
-# trace record QS_USER_00 (PHILO_STAT) produced when the status of
-# a Philo changes.
-
-class DPP:
- def __init__(self):
-
- # add commands to the Custom menu...
- QView.custom_menu.add_command(label="Custom command",
- command=self.cust_command)
-
- # configure the custom QView.canvas...
- QView.show_canvas() # make the canvas visible
- QView.canvas.configure(width=400, height=260)
-
- # tuple of activity images (correspond to self._philo_state)
- self._act_img = (
- PhotoImage(file=HOME_DIR + "/img/thinking.gif"),
- PhotoImage(file=HOME_DIR + "/img/hungry.gif"),
- PhotoImage(file=HOME_DIR + "/img/eating.gif"),
- )
- # tuple of philo canvas images (correspond to self._philo_obj)
- self._philo_img = (\
- QView.canvas.create_image(190, 57, image=self._act_img[0]),
- QView.canvas.create_image(273, 100, image=self._act_img[0]),
- QView.canvas.create_image(237, 185, image=self._act_img[0]),
- QView.canvas.create_image(146, 185, image=self._act_img[0]),
- QView.canvas.create_image(107, 100, image=self._act_img[0])
- )
-
- # button images for UP and DOWN
- self.img_UP = PhotoImage(file=HOME_DIR + "/img/BTN_UP.gif")
- self.img_DWN = PhotoImage(file=HOME_DIR + "/img/BTN_DWN.gif")
-
- # images of a button for pause/serve
- self.btn = QView.canvas.create_image(200, 120, image=self.img_UP)
- QView.canvas.tag_bind(self.btn, "", self.cust_pause)
-
- # request target reset on startup...
- # NOTE: Normally, for an embedded application you would like
- # to start with resetting the Target, to start clean with
- # Qs dictionaries, etc.
- reset_target()
-
- # on_reset() callback
- def on_reset(self):
- # clear the lists
- self._philo_obj = [0, 0, 0, 0, 0]
- self._philo_state = [0, 0, 0]
-
- # on_run() callback
- def on_run(self):
- glb_filter("QS_USER_00")
-
- # NOTE: the names of objects for current_obj() must match
- # the QS Object Dictionaries produced by the application.
- current_obj(OBJ_AO, "Table::inst")
-
- # turn lists into tuples for better performance
- self._philo_obj = tuple(self._philo_obj)
- self._philo_state = tuple(self._philo_state)
-
-
- # example of a custom command
- def cust_command(self):
- command(1, 12345)
-
- # example of a custom interaction with a canvas object (pause/serve)
- def cust_pause(self, event):
- if QView.canvas.itemcget(self.btn, "image") != str(self.img_UP):
- QView.canvas.itemconfig(self.btn, image=self.img_UP)
- post("SERVE_SIG")
- QView.print_text("Table SERVING")
- else:
- QView.canvas.itemconfig(self.btn, image=self.img_DWN)
- post("PAUSE_SIG")
- QView.print_text("Table PAUSED")
-
- # Intercept the QS_USER_00 application-specific trace record.
- # This record has the following structure (see bsp.c:displayPhilStat()):
- # Seq-Num, Record-ID, Timestamp, format-byte, Philo-num,
- # format-byte, Zero-terminated string (status)
- def QS_USER_00(self, packet):
- # unpack: Timestamp->data[0], Philo-num->data[1], status->data[3]
- data = qunpack("xxTxBxZ", packet)
- i = data[1]
- j = ("t", "h", "e").index(data[2][0]) # the first letter
-
- # animate the given philo image according to its activity
- QView.canvas.itemconfig(self._philo_img[i], image=self._act_img[j])
-
- # print a message to the text view
- QView.print_text("%010d Philo %1d is %s"%(data[0], i, data[2]))
-
-#=============================================================================
-QView.customize(DPP()) # set the QView customization
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/dpp1.py b/examples/arm-cm/dpp_efm32-slstk3401a/qview/dpp1.py
deleted file mode 100644
index 5958ac265..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qview/dpp1.py
+++ /dev/null
@@ -1,147 +0,0 @@
-# This is an example of QView customization for a specific application
-# (DPP in this case). This example animates the Phil images on the
-# QView canvas. Additionally, there is a button in the middle of the screen,
-# which, when clicked once pauses the DPP ("forks" are not being served).
-# A second click on the button, "un-pauses" the DPP ("forks" are served
-# to all hungry Philosophers).
-#
-# This version of the DPP customization uses the predefined QS_QEP_TRAN
-# trace record, which provides information about the state transitions of
-# the Dining Philosophers. The example also demonstrates how to intercept
-# the QS "dictionary" records QS_OBJ_DICT and QS_FUN_DICT to extract the
-# information about the addresses of the Philosopher objects and the states
-# of their state machines.
-
-class DPP:
- def __init__(self):
-
- # add commands to the Custom menu...
- QView.custom_menu.add_command(label="Custom command",
- command=self.cust_command)
-
- # configure the custom QView.canvas...
- QView.show_canvas() # make the canvas visible
- QView.canvas.configure(width=400, height=260)
-
- # tuple of activity images (correspond to self._philo_state)
- self._act_img = (
- PhotoImage(file=HOME_DIR + "/img/thinking.gif"),
- PhotoImage(file=HOME_DIR + "/img/hungry.gif"),
- PhotoImage(file=HOME_DIR + "/img/eating.gif"),
- )
- # tuple of philo canvas images (correspond to self._philo_obj)
- self._philo_img = (\
- QView.canvas.create_image(190, 57, image=self._act_img[0]),
- QView.canvas.create_image(273, 100, image=self._act_img[0]),
- QView.canvas.create_image(237, 185, image=self._act_img[0]),
- QView.canvas.create_image(146, 185, image=self._act_img[0]),
- QView.canvas.create_image(107, 100, image=self._act_img[0])
- )
-
- # button images for UP and DOWN
- self.img_UP = PhotoImage(file=HOME_DIR + "/img/BTN_UP.gif")
- self.img_DWN = PhotoImage(file=HOME_DIR + "/img/BTN_DWN.gif")
-
- # images of a button for pause/serve
- self.btn = QView.canvas.create_image(200, 120, image=self.img_UP)
- QView.canvas.tag_bind(self.btn, "", self.cust_pause)
-
- # request target reset on startup...
- # NOTE: Normally, for an embedded application you would like
- # to start with resetting the Target, to start clean with
- # Qs dictionaries, etc.
- reset_target()
-
-
- # on_reset() callback invoked when Target-reset packet is received
- # NOTE: the QS dictionaries are not known at this time yet, so
- # this callback shouild generally not set filters or current objects
- def on_reset(self):
- # (re)set the lists
- self._philo_obj = [0, 0, 0, 0, 0]
- self._philo_state = [0, 0, 0]
-
- # on_run() callback invoked when the QF_RUN packet is received
- # NOTE: the QS dictionaries are typically known at this time yet, so
- # this callback can set filters or current objects
- def on_run(self):
- glb_filter("QS_QEP_TRAN")
-
- # NOTE: the names of objects for current_obj() must match
- # the QS Object Dictionaries produced by the application.
- current_obj(OBJ_AO, "Table::inst")
-
- # turn lists into tuples for better performance
- self._philo_obj = tuple(self._philo_obj)
- self._philo_state = tuple(self._philo_state)
-
-
- # example of a custom command
- def cust_command(self):
- command(1, 12345)
-
- # example of a custom interaction with a canvas object (pause/serve)
- def cust_pause(self, event):
- if QView.canvas.itemcget(self.btn, "image") != str(self.img_UP):
- QView.canvas.itemconfig(self.btn, image=self.img_UP)
- post("SERVE_SIG")
- QView.print_text("Table SERVING")
- else:
- QView.canvas.itemconfig(self.btn, image=self.img_DWN)
- post("PAUSE_SIG")
- QView.print_text("Table PAUSED")
-
- # Intercept the QS_OBJ_DICT predefined trace record.
- # This record has the following structure:
- # Seq-Num, Record-ID, Object-ptr, Zero-terminated string
- def QS_OBJ_DICT(self, packet):
- data = qunpack("xxOZ", packet)
- try:
- # NOTE: the names of objects must match the QS Object Dictionaries
- # produced by the application.
- i = ("Philo::inst[0]",
- "Philo::inst[1]",
- "Philo::inst[2]",
- "Philo::inst[3]",
- "Philo::inst[4]").index(data[1])
- self._philo_obj[i] = data[0]
- except:
- pass # dictionary for a different object
-
- # Intercept the QS_FUN_DICT predefined trace record.
- # This record has the following structure:
- # Seq-Num, Record-ID, Function-ptr, Zero-terminated string
- def QS_FUN_DICT(self, packet):
- data = qunpack("xxFZ", packet)
- try:
- # NOTE: the names of states must match the QS Object Dictionaries
- # produced by the application.
- j = ("Philo::thinking",
- "Philo::hungry",
- "Philo::eating").index(data[1])
- self._philo_state[j] = data[0]
- except:
- pass # dictionary for a different state
-
- # Intercept the QS_QEP_TRAN predefined trace record.
- # This record has the following structure (see qep_hsm.c):
- # Seq-Num, Record-ID, Timestamp, Signal, Object-ptr,
- # Function-ptr (source state), Function-ptr (new active state)
- def QS_QEP_TRAN(self, packet):
- data = qunpack("xxTSOFF", packet)
- try:
- i = self._philo_obj.index(data[2])
- j = self._philo_state.index(data[4])
-
- # animate the given philo image according to its activity
- QView.canvas.itemconfig(self._philo_img[i],
- image=self._act_img[j])
- # print a message to the text view
- QView.print_text("%010d Philo %d is %s"\
- %(data[0], i, ("thinking", "hungry", "eating")[j]))
- except:
- pass # state-entry in a different object
-
-#=============================================================================
-# instantiate the DPP class and set it as the QView customization
-QView.customize(DPP())
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/BTN_DWN.gif b/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/BTN_DWN.gif
deleted file mode 100644
index 36d8c7907..000000000
Binary files a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/BTN_DWN.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/BTN_UP.gif b/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/BTN_UP.gif
deleted file mode 100644
index 3246ff982..000000000
Binary files a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/BTN_UP.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/eating.gif b/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/eating.gif
deleted file mode 100644
index 632b9d23a..000000000
Binary files a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/eating.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/hungry.gif b/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/hungry.gif
deleted file mode 100644
index dc144db97..000000000
Binary files a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/hungry.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/thinking.gif b/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/thinking.gif
deleted file mode 100644
index ec684ee5a..000000000
Binary files a/examples/arm-cm/dpp_efm32-slstk3401a/qview/img/thinking.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/qview-dpp.bat b/examples/arm-cm/dpp_efm32-slstk3401a/qview/qview-dpp.bat
deleted file mode 100644
index b36e43d6b..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qview/qview-dpp.bat
+++ /dev/null
@@ -1,8 +0,0 @@
-@setlocal
-
-if "%QTOOLS%"=="" (
- set QTOOLS=C:\qp\qtools
-)
-python3 %QTOOLS%\qview\qview.py dpp.py
-
-@endlocal
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qview/qview-dpp1.bat b/examples/arm-cm/dpp_efm32-slstk3401a/qview/qview-dpp1.bat
deleted file mode 100644
index 8bdb9ce53..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qview/qview-dpp1.bat
+++ /dev/null
@@ -1,8 +0,0 @@
-@setlocal
-
-if "%QTOOLS%"=="" (
- set QTOOLS=C:\qp\qtools
-)
-python3 %QTOOLS%\qview\qview.py dpp1.py
-
-@endlocal
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/README.txt
deleted file mode 100644
index 17af30f26..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/README.txt
+++ /dev/null
@@ -1,50 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size (for most embedded projects
-yyy should be 0, as the using the heap is not recommended).
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-The file startup_efm32pg1b.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.sct b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.sct
deleted file mode 100644
index 794d15cc6..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Modified by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00020000 { ; load region size_region
- ER_IROM1 0x00000000 0x00020000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: assume STACK size 2048!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.uvoptx b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.uvoptx
deleted file mode 100644
index 0784f806b..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.uvoptx
+++ /dev/null
@@ -1,1031 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=2459,615,2936,930,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- DLGUARM
-
-
-
- 0
- JL2CM3
- -U440060969 -O78 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight SW-DP") -D00(2BA01477) -L00(4) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- UL2CM3
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
-
-
-
-
- 0
- 0
- 371
- 1
- 3860
- 0
- 0
- 0
- 0
- 0
- 1
- ..\bsp.cpp
-
- \\dpp_qxk\../bsp.cpp\371
-
-
- 1
- 0
- 144
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
-
-
-
-
- 0
- 1
- QXK_priv_
-
-
- 1
- 1
- QActive::registry_[11]
-
-
-
-
- 1
- 2
- 0x20000100
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
- BIN\UL2CM3.DLL
-
-
-
- 0
- UL2CM3
- -U -O206 -S0 -C0 -P00 -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
-
-
- 0
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 0
- 1
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 3
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 4
-
-
-
-
-
-
-
-
-
-
- Segger\JL2CM3.dll
-
-
-
- 0
- JL2CM3
- -U440060969 -O14 -S2 -ZTIFSpeedSel5000 -A0 -C0 -JU1 -JI127.0.0.1 -JP0 -RST0 -N00("ARM CoreSight JTAG-DP") -D00(4BA00477) -L00(4) -TO18 -TC10000000 -TP21 -TDS8007 -TDT0 -TDC1F -TIEFFFFFFFF -TIP8 -TB1 -TFE0 -FO7 -FD20000000 -FC8000 -FN1 -FF0GECKOP2.FLM -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM)
-
-
- 0
- UL2CM3
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
-
-
-
-
- 0
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\philo.cpp
- philo.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\..\table.cpp
- table.cpp
- 0
- 0
-
-
- 1
- 4
- 8
- 0
- 0
- 0
- ..\xthread1.cpp
- xthread1.cpp
- 0
- 0
-
-
- 1
- 5
- 8
- 0
- 0
- 0
- ..\xthread2.cpp
- xthread2.cpp
- 0
- 0
-
-
- 1
- 6
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
-
-
- efm32pg1b
- 0
- 0
- 0
- 0
-
- 2
- 7
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
- startup_efm32pg1b.s
- 0
- 0
-
-
- 2
- 8
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
- efm32pg1b200f256gm48.h
- 0
- 0
-
-
- 2
- 9
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
- em_gpio.c
- 0
- 0
-
-
- 2
- 10
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
- system_efm32pg1b.c
- 0
- 0
-
-
- 2
- 11
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
- em_system.c
- 0
- 0
-
-
- 2
- 12
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
- em_emu.c
- 0
- 0
-
-
- 2
- 13
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
- em_cmu.c
- 0
- 0
-
-
- 2
- 14
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
- em_usart.c
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk.cpp
- qxk.cpp
- 0
- 0
-
-
- 3
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
- qxk_mutex.cpp
- 0
- 0
-
-
- 3
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
- qxk_sema.cpp
- 0
- 0
-
-
- 3
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
- qxk_xthr.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
- qxk_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 32
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 33
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_64bit.cpp
- qs_64bit.cpp
- 0
- 0
-
-
- 5
- 34
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 35
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 36
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.uvprojx b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.uvprojx
deleted file mode 100644
index 162ad671f..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/armclang/dpp-qxk.uvprojx
+++ /dev/null
@@ -1,1898 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.0.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- dpp-qxk
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\dpp-qxk.bin .\dbg\dpp-qxk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 1
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 1
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qxk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qxk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- xthread1.cpp
- 8
- ..\xthread1.cpp
-
-
- xthread2.cpp
- 8
- ..\xthread2.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qxk.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk.cpp
-
-
- qxk_mutex.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- qxk_sema.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- qxk_xthr.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
-
- QP_port
-
-
- qxk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
- 5060183::V5.06 update 2 (build 183)::ARMCC
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.0.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- dpp-qxk
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\dpp-qxk.bin .\rel\dpp-qxk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qxk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qxk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- xthread1.cpp
- 8
- ..\xthread1.cpp
-
-
- xthread2.cpp
- 8
- ..\xthread2.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qxk.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk.cpp
-
-
- qxk_mutex.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- qxk_sema.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- qxk_xthr.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
-
- QP_port
-
-
- qxk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- EFM32PG1B200F256GM48
- Silicon Labs
- SiliconLabs.GeckoPlatform_EFM32PG1B_DFP.4.0.0
- https://www.silabs.com/documents/public/cmsis-packs/
- IRAM(0x20000000,0x00008000) IROM(0x00000000,0x00020000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC8000 -FN1 -FF0GECKOP2 -FS00 -FL020000 -FP0($$Device:EFM32PG1B200F256GM48$Flash\GECKOP2.FLM))
- 0
- $$Device:EFM32PG1B200F256GM48$Device\EFM32PG1B\Include\em_device.h
-
-
-
-
-
-
-
-
-
- $$Device:EFM32PG1B200F256GM48$SVD\EFM32PG1B\EFM32PG1B200F256GM48.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- dpp-qxk
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\dpp-qxk.bin .\spy\dpp-qxk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x20000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x20000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- Q_SPY,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qxk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\efm32pg1b
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qxk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- xthread1.cpp
- 8
- ..\xthread1.cpp
-
-
- xthread2.cpp
- 8
- ..\xthread2.cpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- efm32pg1b
-
-
- startup_efm32pg1b.s
- 2
- ..\..\..\..\..\3rd_party\efm32pg1b\arm\startup_efm32pg1b.s
-
-
- efm32pg1b200f256gm48.h
- 5
- ..\..\..\..\..\3rd_party\efm32pg1b\efm32pg1b200f256gm48.h
-
-
- em_gpio.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- system_efm32pg1b.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
- em_system.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_system.c
-
-
- em_emu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- em_cmu.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- em_usart.c
- 1
- ..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qxk.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk.cpp
-
-
- qxk_mutex.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- qxk_sema.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- qxk_xthr.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
-
- QP_port
-
-
- qxk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/bsp.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/bsp.cpp
deleted file mode 100644
index b5a00df01..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/bsp.cpp
+++ /dev/null
@@ -1,574 +0,0 @@
-//============================================================================
-// Product: DPP example, EFM32-SLSTK3401A board, QXK kernel
-// Last updated for version 7.3.2
-// Last updated on 2023-12-13
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "em_device.h" // the device specific header (SiLabs)
-#include "em_cmu.h" // Clock Management Unit (SiLabs)
-#include "em_gpio.h" // GPIO (SiLabs)
-#include "em_usart.h" // USART (SiLabs)
-// add other drivers if necessary...
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr GPIO_Port_TypeDef LED_PORT {gpioPortF};
-constexpr std::uint32_t LED0_PIN {4U};
-constexpr std::uint32_t LED1_PIN {5U};
-
-constexpr GPIO_Port_TypeDef PB_PORT {gpioPortF};
-constexpr std::uint32_t PB0_PIN {6U};
-constexpr std::uint32_t PB1_PIN {7U};
-
-static std::uint32_t l_rndSeed;
-
-#ifdef Q_SPY
-
- // QSpy source IDs
- QP::QSpyId const l_SysTick_Handler = { 0U };
- QP::QSpyId const l_GPIO_EVEN_IRQHandler = { 0U };
-
- static USART_TypeDef * const l_USART0 = ((USART_TypeDef *)(0x40010000UL));
-
- static QP::QSTimeCtr QS_tickTime_;
- static QP::QSTimeCtr QS_tickPeriod_;
-
- enum AppRecords { // application-specific trace records
- PHILO_STAT = QP::QS_USER,
- PAUSED_STAT,
- CONTEXT_SW,
- };
-
-#endif
-
-} // unnamed namespace
-
-//============================================================================
-// Error handler and ISRs...
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the error handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up both LEDs
- GPIO->P[LED_PORT].DOUT |= ((1U << LED0_PIN) | (1U << LED1_PIN));
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#else
- NVIC_SystemReset();
- for (;;) { // explicitly "no-return"
- }
-#endif
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QXK_ISR_ENTRY(); // inform QXK about entering an ISR
-
- QP::QTimeEvt::TICK_X(0U, &l_SysTick_Handler); // time events at rate 0
-
- // Perform the debouncing of buttons. The algorithm for debouncing
- // adapted from the book "Embedded Systems Dictionary" by Jack Ganssle
- // and Michael Barr, page 71.
- static struct {
- std::uint32_t depressed;
- std::uint32_t previous;
- } buttons = { 0U, 0U };
-
- std::uint32_t current = ~GPIO->P[PB_PORT].DIN; // read PB0 and BP1
- std::uint32_t tmp = buttons.depressed; // save the depressed buttons
- buttons.depressed |= (buttons.previous & current); // set depressed
- buttons.depressed &= (buttons.previous | current); // clear released
- buttons.previous = current; // update the history
- tmp ^= buttons.depressed; // changed debounced depressed
- current = buttons.depressed;
-
- if ((tmp & (1U << PB0_PIN)) != 0U) { // debounced PB0 state changed?
- if ((current & (1U << PB0_PIN)) != 0U) { // is PB0 depressed?
- static QP::QEvt const pauseEvt(APP::PAUSE_SIG);
- QP::QActive::PUBLISH(&pauseEvt, &l_SysTick_Handler);
- }
- else { // the button is released
- static QP::QEvt const serveEvt(APP::SERVE_SIG);
- QP::QActive::PUBLISH(&serveEvt, &l_SysTick_Handler);
- }
- }
-
-#ifdef Q_SPY
- tmp = SysTick->CTRL; // clear CTRL_COUNTFLAG
- QS_tickTime_ += QS_tickPeriod_; // account for the clock rollover
-#endif
-
- QXK_ISR_EXIT(); // inform QXK about exiting an ISR
-}
-//............................................................................
-// interrupt handler for testing preemptions
-void GPIO_EVEN_IRQHandler(void); // prototype
-void GPIO_EVEN_IRQHandler(void) {
- QXK_ISR_ENTRY(); // inform QXK about entering an ISR
-
- static QP::QEvt const testEvt(APP::TEST_SIG);
- APP::AO_Table->POST(&testEvt, &l_GPIO_EVEN_IRQHandler);
-
- QXK_ISR_EXIT(); // inform QXK about exiting an ISR
-}
-
-//............................................................................
-#ifdef Q_SPY
-// ISR for receiving bytes from the QSPY Back-End
-// NOTE: This ISR is "QF-unaware" meaning that it does not interact with
-// the QF/QXK and is not disabled. Such ISRs don't need to call
-// QXK_ISR_ENTRY/QXK_ISR_EXIT and they cannot post or publish events.
-
-void USART0_RX_IRQHandler(void); // prototype
-void USART0_RX_IRQHandler(void) {
- // while RX FIFO NOT empty
- while ((l_USART0->STATUS & USART_STATUS_RXDATAV) != 0U) {
- std::uint8_t b = static_cast(l_USART0->RXDATA);
- QP::QS::rxPut(b);
- }
-
- QXK_ARM_ERRATUM_838869();
-}
-#endif // Q_SPY
-
-//............................................................................
-#ifdef QF_ON_CONTEXT_SW
-// NOTE: the context-switch callback is called with interrupts DISABLED
-void QF_onContextSw(QP::QActive *prev, QP::QActive *next) {
- Q_UNUSED_PAR(prev);
- Q_UNUSED_PAR(next);
-
- QS_BEGIN_INCRIT(CONTEXT_SW, 0U) // in critical section!
- QS_OBJ(prev);
- QS_OBJ(next);
- QS_END_INCRIT()
-}
-#endif // QF_ON_CONTEXT_SW
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QXK
-
- // enable clock for to the peripherals used by this application...
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
-
- // configure the LEDs
- GPIO_PinModeSet(LED_PORT, LED0_PIN, gpioModePushPull, 0);
- GPIO_PinModeSet(LED_PORT, LED1_PIN, gpioModePushPull, 0);
- GPIO_PinOutClear(LED_PORT, LED0_PIN);
- GPIO_PinOutClear(LED_PORT, LED1_PIN);
-
- // configure the Buttons
- GPIO_PinModeSet(PB_PORT, PB0_PIN, gpioModeInputPull, 1);
- GPIO_PinModeSet(PB_PORT, PB1_PIN, gpioModeInputPull, 1);
-
- BSP::randomSeed(1234U);
-
- // initialize the QS software tracing...
- if (!QS_INIT(nullptr)) {
- Q_ERROR();
- }
-
- // dictionaries...
- QS_OBJ_DICTIONARY(&l_SysTick_Handler);
- QS_OBJ_DICTIONARY(&l_GPIO_EVEN_IRQHandler);
- QS_USR_DICTIONARY(PHILO_STAT);
- QS_USR_DICTIONARY(PAUSED_STAT);
- QS_USR_DICTIONARY(CONTEXT_SW);
-
- QS_ONLY(APP::produce_sig_dict());
-
- // setup the QS filters...
- QS_GLB_FILTER(QP::QS_ALL_RECORDS); // all records
- QS_GLB_FILTER(-QP::QS_QF_TICK); // exclude the clock tick
- QS_LOC_FILTER(-(APP::N_PHILO + 3U)); // exclude prio. of AO_Ticker0
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(APP::TableEvt) smlPoolSto[2*APP::N_PHILO];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // start AOs/threads...
- static QP::QEvt const *xThread1QueueSto[5];
- static uint64_t xThread1StackSto[64];
- APP::TH_XThread1->start(
- 1U, // QP priority of the thread
- xThread1QueueSto, // event queue storage
- Q_DIM(xThread1QueueSto), // event length [events]
- &xThread1StackSto[0], // stack storage
- sizeof(xThread1StackSto)); // stack size [bytes]
-
- static QP::QEvt const *philoQueueSto[APP::N_PHILO][APP::N_PHILO];
- for (std::uint8_t n = 0U; n < APP::N_PHILO; ++n) {
- APP::AO_Philo[n]->start(
- n + 3U, // QF-prio/pthre. see NOTE1
- philoQueueSto[n], // event queue storage
- Q_DIM(philoQueueSto[n]), // queue length [events]
- nullptr, 0U); // no stack storage
- }
-
- static QP::QEvt const *xThread2QueueSto[5];
- static uint64_t xThread2StackSto[64];
- APP::TH_XThread2->start(
- APP::N_PHILO + 5U, // QP priority of the thread
- xThread2QueueSto, // event queue storage
- Q_DIM(xThread2QueueSto), // event length [events]
- &xThread2StackSto[0], // stack storage
- sizeof(xThread2StackSto)); // stack size [bytes]
-
- static QP::QEvt const *tableQueueSto[APP::N_PHILO];
- APP::AO_Table->start(
- APP::N_PHILO + 7U, // QP prio. of the AO
- tableQueueSto, // event queue storage
- Q_DIM(tableQueueSto), // queue length [events]
- nullptr, 0U); // no stack storage
-}
-//............................................................................
-void displayPhilStat(std::uint8_t n, char const *stat) {
- Q_UNUSED_PAR(n);
-
- if (stat[0] == 'e') {
- GPIO->P[LED_PORT].DOUT |= (1U << LED0_PIN);
- }
- else {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED0_PIN);
- }
-
- // app-specific trace record...
- QS_BEGIN_ID(PHILO_STAT, APP::AO_Table->getPrio())
- QS_U8(1, n); // Philosopher number
- QS_STR(stat); // Philosopher status
- QS_END()
-}
-//............................................................................
-void displayPaused(std::uint8_t const paused) {
- if (paused != 0U) {
- GPIO->P[LED_PORT].DOUT |= (1U << LED0_PIN);
- }
- else {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED0_PIN);
- }
-
- // application-specific trace record
- QS_BEGIN_ID(PAUSED_STAT, APP::AO_Table->getPrio())
- QS_U8(1, paused); // Paused status
- QS_END()
-}
-//............................................................................
-void randomSeed(uint32_t const seed) {
- l_rndSeed = seed;
-}
-//............................................................................
-std::uint32_t random() { // a very cheap pseudo-random-number generator
- // Some floating point code is to exercise the VFP...
- float volatile x = 3.1415926F;
- x = x + 2.7182818F;
-
- QP::QSchedStatus lockStat = QP::QXK::schedLock(APP::N_PHILO);
- // "Super-Duper" Linear Congruential Generator (LCG)
- // LCG(2^32, 3*7*11*13*23, 0, seed)
- std::uint32_t rnd = l_rndSeed * (3U*7U*11U*13U*23U);
- l_rndSeed = rnd; // set for the next time
- QP::QXK::schedUnlock(lockStat);
-
- return (rnd >> 8U);
-}
-//............................................................................
-void ledOn() {
- GPIO->P[LED_PORT].DOUT |= (1U << LED1_PIN);
-}
-//............................................................................
-void ledOff() {
- GPIO->P[LED_PORT].DOUT &= ~(1U << LED1_PIN);
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-// namespace QP
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(USART0_RX_IRQn, 0U); // kernel unaware interrupt
- NVIC_SetPriority(GPIO_EVEN_IRQn, QF_AWARE_ISR_CMSIS_PRI + 0U);
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
- NVIC_EnableIRQ(GPIO_EVEN_IRQn);
-
-#ifdef Q_SPY
- NVIC_EnableIRQ(USART0_RX_IRQn); // UART0 interrupt used for QS-RX
-#endif
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QXK::onIdle() {
- // toggle the User LED on and then off, see NOTE3
-// QF_INT_DISABLE();
-// GPIO->P[LED_PORT].DOUT |= (1U << LED1_PIN);
-// GPIO->P[LED_PORT].DOUT &= ~(1U << LED1_PIN);
-// QF_INT_ENABLE();
-
-#ifdef Q_SPY
- QF_INT_DISABLE();
- QS::rxParse(); // parse all the received bytes
- QF_INT_ENABLE();
-
- if ((l_USART0->STATUS & USART_STATUS_TXBL) != 0) { // is TXE empty?
- QF_INT_DISABLE();
- std::uint16_t b = QS::getByte();
- QF_INT_ENABLE();
-
- if (b != QS_EOD) { // not End-Of-Data?
- l_USART0->TXDATA = b; // put into the DR register
- }
- }
-#elif defined NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- __WFI(); // Wait-For-Interrupt
-#endif
-}
-
-//============================================================================
-// QS callbacks...
-#ifdef Q_SPY
-namespace QS {
-
-//............................................................................
-bool onStartup(void const *arg) {
- Q_UNUSED_PAR(arg);
-
- static std::uint8_t qsTxBuf[2*1024]; // buffer for QS-TX channel
- initBuf(qsTxBuf, sizeof(qsTxBuf));
-
- static std::uint8_t qsRxBuf[100]; // buffer for QS-RX channel
- rxInitBuf(qsRxBuf, sizeof(qsRxBuf));
-
- static USART_InitAsync_TypeDef init = {
- usartEnable, // Enable RX/TX when init completed
- 0, // Use current clock for configuring baudrate
- 115200, // 115200 bits/s
- usartOVS16, // 16x oversampling
- usartDatabits8, // 8 databits
- usartNoParity, // No parity
- usartStopbits1, // 1 stopbit
- 0, // Do not disable majority vote
- 0, // Not USART PRS input mode
- usartPrsRxCh0, // PRS channel 0
- 0, // Auto CS functionality enable/disable switch
- 0, // Auto CS Hold cycles
- 0 // Auto CS Setup cycles
- };
-
- // Enable peripheral clocks
- CMU_ClockEnable(cmuClock_HFPER, true);
- CMU_ClockEnable(cmuClock_GPIO, true);
-
- // To avoid false start, configure output as high
- GPIO_PinModeSet(gpioPortA, 0, gpioModePushPull, 1); // TX pin
- GPIO_PinModeSet(gpioPortA, 1, gpioModeInput, 0); // RX pin
-
- // Enable DK RS232/UART switch
- GPIO_PinModeSet(gpioPortA, 5, gpioModePushPull, 1);
- CMU_ClockEnable(cmuClock_USART0, true);
-
- // configure the UART for the desired baud rate, 8-N-1 operation
- init.enable = usartDisable;
- USART_InitAsync(l_USART0, &init);
-
- // enable pins at correct UART/USART location.
- l_USART0->ROUTEPEN = USART_ROUTEPEN_RXPEN | USART_ROUTEPEN_TXPEN;
- l_USART0->ROUTELOC0 = (l_USART0->ROUTELOC0 &
- ~(_USART_ROUTELOC0_TXLOC_MASK
- | _USART_ROUTELOC0_RXLOC_MASK));
-
- // Clear previous RX interrupts
- USART_IntClear(l_USART0, USART_IF_RXDATAV);
- NVIC_ClearPendingIRQ(USART0_RX_IRQn);
-
- // Enable RX interrupts
- USART_IntEnable(l_USART0, USART_IF_RXDATAV);
- // NOTE: do not enable the UART0 interrupt in the NVIC yet.
- // Wait till QF_onStartup()
-
- // Finally enable the UART
- USART_Enable(l_USART0, usartEnable);
-
- QS_tickPeriod_ = SystemCoreClock / BSP::TICKS_PER_SEC;
- QS_tickTime_ = QS_tickPeriod_; // to start the timestamp at zero
-
- return true; // return success
-}
-//............................................................................
-void onCleanup() {
-}
-//............................................................................
-QSTimeCtr onGetTime() { // NOTE: invoked with interrupts DISABLED
- if ((SysTick->CTRL & SysTick_CTRL_COUNTFLAG_Msk) == 0U) { // not set?
- return QS_tickTime_ - (QSTimeCtr)SysTick->VAL;
- }
- else { // the rollover occurred, but the SysTick_ISR did not run yet
- return QS_tickTime_ + QS_tickPeriod_ - (QSTimeCtr)SysTick->VAL;
- }
-}
-//............................................................................
-// NOTE:
-// No critical section in QS::onFlush() to avoid nesting of critical sections
-// in case QS::onFlush() is called from Q_onError().
-void onFlush() {
- for (;;) {
- std::uint16_t b = getByte();
- if (b != QS_EOD) {
- while ((l_USART0->STATUS & USART_STATUS_TXBL) == 0U) {
- }
- l_USART0->TXDATA = b;
- }
- else {
- break;
- }
- }
-}
-//............................................................................
-void onReset() {
- NVIC_SystemReset();
-}
-//............................................................................
-void onCommand(std::uint8_t cmdId, std::uint32_t param1,
- std::uint32_t param2, std::uint32_t param3)
-{
- Q_UNUSED_PAR(cmdId);
- Q_UNUSED_PAR(param1);
- Q_UNUSED_PAR(param2);
- Q_UNUSED_PAR(param3);
-}
-
-} // namespace QS
-#endif // Q_SPY
-//----------------------------------------------------------------------------
-
-} // namespace QP
-
-//============================================================================
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call the QXK_ISR_ENTRY/
-// QXK_ISR_ENTRY macros or any other QF/QXK services. These ISRs are
-// "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QXK services. In particular they
-// can NOT call the macros QXK_ISR_ENTRY/QXK_ISR_ENTRY. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/Makefile b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/Makefile
deleted file mode 100644
index 98b1a4bc6..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/Makefile
+++ /dev/null
@@ -1,325 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EMF32-SLSTK3401A, QXK kernel, GNU-ARM
-# Last Updated for Version: 7.3.0
-# Date of the Last Update: 2023-09-07
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := dpp-qxk
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qxk/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qxk \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/efm32pg1b \
- $(QPCPP)/3rd_party/efm32pg1b/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/efm32pg1b
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- startup_efm32pg1b.c \
- system_efm32pg1b.c \
- em_cmu.c \
- em_emu.c \
- em_gpio.c \
- em_usart.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- philo.cpp \
- table.cpp \
- xthread1.cpp \
- xthread2.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qxk.cpp \
- qxk_mutex.cpp \
- qxk_sema.cpp \
- qxk_xthr.cpp \
- qxk_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DEFM32PG1B200F256GM48=1 \
- -DQF_ON_CONTEXT_SW \
- -DQK_USE_IRQ_NUM=33 \
- -DQK_USE_IRQ_HANDLER=FPUEH_IRQHandler
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=vfp
-FLOAT_ABI := -mfloat-abi=softfp
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-##############################################################################
-# Typically you should not need to change anything below this line
-
-# basic utilities (included in QTools for Windows), see:
-# https://www.state-machine.com/qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-.PHONY : run norun flash clean show
-
-ifeq ($(MAKECMDGOALS),norun)
-all : $(TARGET_BIN)
-norun : all
-else
-all : $(TARGET_BIN) run
-endif
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/README.txt
deleted file mode 100644
index 1814d84d5..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/README.txt
+++ /dev/null
@@ -1,72 +0,0 @@
-About this Example
-==================
-This example can be built from the command prompt with the provided
-Makefile. The example can also be imported as a Makefile-based
-project into Eclipse-based IDEs.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-Also, the Makefile has been specifically designed to work as an external
-Makefile with the Eclipse CDT.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the EFM32PG1B200F256GM48 MCU used in this project
-is located in the "3rd_party" folder in the following location:
-
-qpc\3rd_party\efm32pg1b\gnu\startup_efm32pg1b.c
-
-The file startup_efm32pg1b.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/dpp-qxk.ld b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/dpp-qxk.ld
deleted file mode 100644
index 12002fb85..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/dpp-qxk.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EFM32-SLSTK3401A, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* http://www.state-machine.com
-* mailto:info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Pearl Gecko EFM32PG1B200F256GM48 */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/flash.bat b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/flash.bat
deleted file mode 100644
index 23215d0ba..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/gnu/flash.bat
+++ /dev/null
@@ -1,49 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EFM32-SLSTK3401A board
-::
-:: NOTE: requires the J-Link commander (JLink.exe) from SEGGER, see:
-:: https://www.segger.com/j-link-commander.html
-::
-setlocal
-
-@echo off
-@echo Load a given binary file to the flash of EFM32-SLSTK3401A
-@echo usage: flash bin-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: Adjust the following symbol to the location of the
-:: JLink utility on your machine
-::
-if [%JLINK%] EQU [] set JLINK=%QTOOLS%\..\JLink
-if not exist "%JLINK%\JLink.exe" (
- @echo The JLink tool not found. Please adjust flash.bat
- @goto end
-)
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-:: generate the Jlink command file depending on the first parameter %1
-@echo si 1 >flash.jlink
-@echo speed 4000 >>flash.jlink
-@echo r >>flash.jlink
-@echo h >>flash.jlink
-@echo loadbin %1, 0 >>flash.jlink
-@echo exit >>flash.jlink
-
-@echo on
-%JLINK%\JLink.exe -device EFM32PG1B200F256GM48 flash.jlink
-@echo off
-
-@del flash.jlink
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/README.txt b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/README.txt
deleted file mode 100644
index fb12fa8f7..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-============
-The startup code for the EFM32PG1B200F256GM48 MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\efm32pg1b\iar\startup_efm32pg1b.s
-
-The file startup_efm32pg1b.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.ewd b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.ewd
deleted file mode 100644
index f4f024be8..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.ewp b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.ewp
deleted file mode 100644
index aad605126..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.ewp
+++ /dev/null
@@ -1,3376 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\dpp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
- $PROJ_DIR$\..\..\philo.cpp
-
-
- $PROJ_DIR$\..\..\table.cpp
-
-
- $PROJ_DIR$\..\xthread1.cpp
-
-
- $PROJ_DIR$\..\xthread2.cpp
-
-
-
- efm32pg1b
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_cmu.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_emu.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_gpio.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\em_usart.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\iar\startup_efm32pg1b.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\efm32pg1b\system_efm32pg1b.c
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qxk\iar\qxk_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.eww b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.eww
deleted file mode 100644
index 38808ca3f..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\dpp-qxk.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.icf b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.icf
deleted file mode 100644
index 0fdfc4b30..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/iar/dpp-qxk.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK };
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/xthread1.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/xthread1.cpp
deleted file mode 100644
index f394c2661..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/xthread1.cpp
+++ /dev/null
@@ -1,103 +0,0 @@
-//============================================================================
-// QXThread example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-12
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-//Q_DEFINE_THIS_FILE
-} // unnamed namespace
-
-//----------------------------------------------------------------------------
-namespace APP {
-
-class XThread1 : public QP::QXThread {
-private:
- // NOTE: data needed by this thread should be members of
- // the thread class. That way they are in the memory region
- // accessible from this thread.
- std::uint8_t m_foo;
-
-public:
- static XThread1 inst;
- XThread1();
-
-private:
- static void run(QP::QXThread * const thr);
-}; // class XThread1
-
-//............................................................................
-QP::QXThread * const TH_XThread1 = &XThread1::inst;
-
-XThread1 XThread1::inst;
-
-XThread1::XThread1()
- : QXThread(&run)
-{}
-
-//............................................................................
-void XThread1::run(QP::QXThread * const thr) {
- // downcast the generic thr pointer to the specific thread
- auto me = static_cast(thr);
-
- QS_OBJ_DICTIONARY(TH_XThread1);
- QS_OBJ_DICTIONARY(TH_XThread1->getTimeEvt());
-
- // subscribe to the EAT signal (from the application)
- me->subscribe(APP::EAT_SIG);
-
- for (;;) {
- QP::QEvt const *e = me->queueGet(BSP::TICKS_PER_SEC/4U);
- if (e) {
- TH_sema.signal(); // signal Thread2
- QP::QF::gc(e); // must explicitly recycle the received event!
- }
-
- TH_mutex.lock(QP::QXTHREAD_NO_TIMEOUT); // lock the mutex
- BSP::ledOn();
- if (TH_mutex.tryLock()) { // exercise the mutex
- // some floating point code to exercise the VFP...
- float volatile x = 1.4142135F;
- x = x * 1.4142135F;
- QP::QXThread::delay(10U); // BLOCK while holding a mutex
- TH_mutex.unlock();
- }
- TH_mutex.unlock();
- BSP::ledOff();
- }
-}
-
-} // namespace APP
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/xthread2.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/qxk/xthread2.cpp
deleted file mode 100644
index 7ba1da8f1..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/qxk/xthread2.cpp
+++ /dev/null
@@ -1,110 +0,0 @@
-//============================================================================
-// QXThread example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-12
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-//Q_DEFINE_THIS_FILE
-} // unnamed namespace
-
-//----------------------------------------------------------------------------
-namespace APP {
-
-//............................................................................
-QP::QXSemaphore TH_sema;
-QP::QXMutex TH_mutex;
-
-//............................................................................
-class XThread2 : public QP::QXThread {
-private:
- // NOTE: data needed by this thread should be members of
- // the thread class. That way they are in the memory region
- // accessible from this thread.
- std::uint8_t m_foo;
-
-public:
- static XThread2 inst;
- XThread2();
-
-private:
- static void run(QP::QXThread * const thr);
-}; // class XThread2
-
-//............................................................................
-QP::QXThread * const TH_XThread2 = &XThread2::inst;
-
-XThread2 XThread2::inst;
-
-XThread2::XThread2()
- : QXThread(&run)
-{}
-
-//............................................................................
-void XThread2::run(QP::QXThread * const thr) {
- // downcast the generic thr pointer to the specific thread
- //auto me = static_cast(thr);
-
- QS_OBJ_DICTIONARY(TH_XThread2);
- QS_OBJ_DICTIONARY(TH_XThread2->getTimeEvt());
- QS_OBJ_DICTIONARY(&TH_sema);
- QS_OBJ_DICTIONARY(&TH_mutex);
-
- // initialize the semaphore before using it
- // NOTE: Here the semaphore is initialized in the highest-priority thread
- // that uses it. Alternatively, the semaphore can be initialized
- // before any thread runs.
- TH_sema.init(0U, // count==0 (signaling semaphore)
- 1U); // max_count==1 (binary semaphore)
-
- // initialize the mutex before using it
- // NOTE: Here the mutex is initialized in the highest-priority thread
- // that uses it. Alternatively, the mutex can be initialized
- // before any thread runs.
- TH_mutex.init(APP::N_PHILO + 6U); // priority-ceiling mutex
- //l_mutex.init(0U); // alternatively: priority-ceiling NOT used
-
- for (;;) {
- // wait on a semaphore (BLOCK indefinitely)
- TH_sema.wait();
-
- TH_mutex.lock(QP::QXTHREAD_NO_TIMEOUT); // lock the mutex
- QP::QXThread::delay(5U); // wait more (BLOCK)
- TH_mutex.unlock();
- }
-}
-
-} // namespace APP
diff --git a/examples/arm-cm/dpp_efm32-slstk3401a/table.cpp b/examples/arm-cm/dpp_efm32-slstk3401a/table.cpp
deleted file mode 100644
index d3a672ecc..000000000
--- a/examples/arm-cm/dpp_efm32-slstk3401a/table.cpp
+++ /dev/null
@@ -1,348 +0,0 @@
-//$file${.::table.cpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp.qm
-// File: ${.::table.cpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::table.cpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//$declare${AOs::Table} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Table} ..............................................................
-class Table : public QP::QActive {
-private:
- std::uint8_t m_fork[N_PHILO];
- bool m_isHungry[N_PHILO];
-
-public:
- static Table inst;
-
-public:
- Table();
-
-protected:
- Q_STATE_DECL(initial);
- Q_STATE_DECL(active);
- Q_STATE_DECL(serving);
- Q_STATE_DECL(paused);
-}; // class Table
-
-} // namespace APP
-//$enddecl${AOs::Table} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-
-// helper function to provide the RIGHT neighbour of a Philo[n]
-static inline std::uint8_t right(std::uint8_t const n) {
- return static_cast((n + (APP::N_PHILO - 1U)) % APP::N_PHILO);
-}
-
-// helper function to provide the LEFT neighbour of a Philo[n]
-static inline std::uint8_t left(std::uint8_t const n) {
- return static_cast((n + 1U) % APP::N_PHILO);
-}
-
-static constexpr std::uint8_t FREE {0U};
-static constexpr std::uint8_t USED {1U};
-
-static constexpr char const * const THINKING {"thinking"};
-static constexpr char const * const HUNGRY {"hungry "};
-static constexpr char const * const EATING {"eating "};
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-//$skip${QP_VERSION} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-// Check for the minimum required QP version
-#if (QP_VERSION < 730U) || (QP_VERSION != ((QP_RELEASE^4294967295U) % 0x3E8U))
-#error qpcpp version 7.3.0 or higher required
-#endif
-//$endskip${QP_VERSION} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$define${Shared::AO_Table} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::AO_Table} ........................................................
-QP::QActive * const AO_Table = &Table::inst;
-
-} // namespace APP
-//$enddef${Shared::AO_Table} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-//$define${AOs::Table} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Table} ..............................................................
-Table Table::inst;
-
-//${AOs::Table::Table} .......................................................
-Table::Table()
- : QActive(Q_STATE_CAST(&initial))
-{
- for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
- }
-}
-
-//${AOs::Table::SM} ..........................................................
-Q_STATE_DEF(Table, initial) {
- //${AOs::Table::SM::initial}
- Q_UNUSED_PAR(e);
-
- QS_OBJ_DICTIONARY(&Table::inst);
-
- subscribe(DONE_SIG);
- subscribe(PAUSE_SIG);
- subscribe(SERVE_SIG);
- subscribe(TEST_SIG);
-
- for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, THINKING);
- }
-
- QS_FUN_DICTIONARY(&Table::active);
- QS_FUN_DICTIONARY(&Table::serving);
- QS_FUN_DICTIONARY(&Table::paused);
-
- return tran(&serving);
-}
-
-//${AOs::Table::SM::active} ..................................................
-Q_STATE_DEF(Table, active) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Table::SM::active::TEST}
- case TEST_SIG: {
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::EAT}
- case EAT_SIG: {
- Q_ERROR();
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Table::SM::active::serving} .........................................
-Q_STATE_DEF(Table, serving) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Table::SM::active::serving}
- case Q_ENTRY_SIG: {
- // give permissions to eat...
- for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- if (m_isHungry[n]
- && (m_fork[left(n)] == FREE)
- && (m_fork[n] == FREE))
- {
- m_fork[left(n)] = USED;
- m_fork[n] = USED;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *te = Q_NEW(TableEvt, EAT_SIG, n);
- #else
- TableEvt *te = Q_NEW(TableEvt, EAT_SIG);
- te->philoId = n;
- #endif
- QP::QActive::PUBLISH(te, this);
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, EATING);
- }
- }
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::serving::HUNGRY}
- case HUNGRY_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // phil ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- BSP::displayPhilStat(n, HUNGRY);
- std::uint8_t m = left(n);
- //${AOs::Table::SM::active::serving::HUNGRY::[bothfree]}
- if ((m_fork[m] == FREE) && (m_fork[n] == FREE)) {
- m_fork[m] = USED;
- m_fork[n] = USED;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, n);
- #else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = n;
- #endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(n, EATING);
- status_ = Q_RET_HANDLED;
- }
- //${AOs::Table::SM::active::serving::HUNGRY::[else]}
- else {
- m_isHungry[n] = true;
- status_ = Q_RET_HANDLED;
- }
- break;
- }
- //${AOs::Table::SM::active::serving::DONE}
- case DONE_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // phil ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- BSP::displayPhilStat(n, THINKING);
- std::uint8_t m = left(n);
-
- // both forks of Phil[n] must be used
- Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
- m_fork[m] = FREE;
- m_fork[n] = FREE;
- m = right(n); // check the right neighbor
-
- if (m_isHungry[m] && (m_fork[m] == FREE)) {
- m_fork[n] = USED;
- m_fork[m] = USED;
- m_isHungry[m] = false;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
- #else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
- #endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
- }
- m = left(n); // check the left neighbor
- n = left(m); // left fork of the left neighbor
- if (m_isHungry[m] && (m_fork[n] == FREE)) {
- m_fork[m] = USED;
- m_fork[n] = USED;
- m_isHungry[m] = false;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
- #else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
- #endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
- }
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::serving::EAT}
- case EAT_SIG: {
- Q_ERROR();
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::serving::PAUSE}
- case PAUSE_SIG: {
- status_ = tran(&paused);
- break;
- }
- default: {
- status_ = super(&active);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Table::SM::active::paused} ..........................................
-Q_STATE_DEF(Table, paused) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Table::SM::active::paused}
- case Q_ENTRY_SIG: {
- BSP::displayPaused(1U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::paused}
- case Q_EXIT_SIG: {
- BSP::displayPaused(0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::paused::SERVE}
- case SERVE_SIG: {
- status_ = tran(&serving);
- break;
- }
- //${AOs::Table::SM::active::paused::HUNGRY}
- case HUNGRY_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // philo ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- m_isHungry[n] = true;
- BSP::displayPhilStat(n, HUNGRY);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::paused::DONE}
- case DONE_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // phil ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- BSP::displayPhilStat(n, THINKING);
- std::uint8_t m = left(n);
-
- // both forks of Phil[n] must be used
- Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
- m_fork[m] = FREE;
- m_fork[n] = FREE;
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&active);
- break;
- }
- }
- return status_;
-}
-
-} // namespace APP
-//$enddef${AOs::Table} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/README.md b/examples/arm-cm/dpp_ek-tm4c123gxl/README.md
deleted file mode 100644
index 30842bae9..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/README.md
+++ /dev/null
@@ -1,5 +0,0 @@
-![STM32 EFM32-SLSTK3401A](../../../doxygen/images/bd_EK-TM4C123GXL.jpg)
-
-Documentation for this example is available in the QP/C Manual at:
-
-- https://www.state-machine.com/qpcpp/arm-cm_dpp_ek-tm4c123gxl.html
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/bsp.hpp b/examples/arm-cm/dpp_ek-tm4c123gxl/bsp.hpp
deleted file mode 100644
index 82ed115d9..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/bsp.hpp
+++ /dev/null
@@ -1,58 +0,0 @@
-//============================================================================
-// Product: DPP example
-// Last Updated for Version: 7.3.0
-// Date of the Last Update: 2023-08-12
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef BSP_HPP_
-#define BSP_HPP_
-
-namespace BSP {
-
-constexpr std::uint32_t TICKS_PER_SEC {100};
-
-void init();
-void start();
-void displayPaused(std::uint8_t const paused);
-void displayPhilStat(std::uint8_t const n, char const *stat);
-void terminate(std::int16_t const result);
-
-void randomSeed(std::uint32_t const seed); // random seed
-std::uint32_t random(); // pseudo-random generator
-
-// for testing...
-void ledOn();
-void ledOff();
-
-extern QP::QTicker *AO_Ticker0;
-
-} // namespace BSP
-
-#endif // BSP_HPP_
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/dpp.hpp b/examples/arm-cm/dpp_ek-tm4c123gxl/dpp.hpp
deleted file mode 100644
index 5172c9a52..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/dpp.hpp
+++ /dev/null
@@ -1,111 +0,0 @@
-//$file${.::dpp.hpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp.qm
-// File: ${.::dpp.hpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::dpp.hpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#ifndef DPP_HPP_
-#define DPP_HPP_
-
-//$declare${Shared} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::AppSignals} ......................................................
-enum AppSignals : QP::QSignal {
- EAT_SIG = QP::Q_USER_SIG, // published by Table to let a Philo eat
- DONE_SIG, // published by Philo when done eating
- PAUSE_SIG, // published by BSP to pause the application
- SERVE_SIG, // published by BSP to serve re-start serving forks
- TEST_SIG, // published by BSP to test the application
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG, // posted by time event to Philo
- HUNGRY_SIG, // posted by hungry Philo to Table
- MAX_SIG // the last signal
-};
-
-//${Shared::produce_sig_dict} ................................................
-#ifdef Q_SPY
-inline void produce_sig_dict() {
- QS_SIG_DICTIONARY(EAT_SIG, nullptr);
- QS_SIG_DICTIONARY(DONE_SIG, nullptr);
- QS_SIG_DICTIONARY(PAUSE_SIG, nullptr);
- QS_SIG_DICTIONARY(SERVE_SIG, nullptr);
- QS_SIG_DICTIONARY(TEST_SIG, nullptr);
-
- QS_SIG_DICTIONARY(TIMEOUT_SIG, nullptr);
- QS_SIG_DICTIONARY(HUNGRY_SIG, nullptr);
-}
-#endif // def Q_SPY
-
-//${Shared::N_PHILO} .........................................................
-constexpr std::uint8_t N_PHILO {5};
-
-//${Shared::TableEvt} ........................................................
-class TableEvt : public QP::QEvt {
-public:
- std::uint8_t philoId;
-
-public:
- constexpr TableEvt(
- QP::QSignal sig,
- std::uint8_t id)
- : QEvt(sig),
- philoId(id)
- {}
-
-#ifdef QEVT_DYN_CTOR
- TableEvt(std::uint8_t id)
- : QEvt(QP::QEvt::DYNAMIC),
- philoId(id)
- {}
-#endif // def QEVT_DYN_CTOR
-}; // class TableEvt
-
-//${Shared::AO_Philo[N_PHILO]} ...............................................
-extern QP::QActive * const AO_Philo[N_PHILO];
-
-//${Shared::AO_Table} ........................................................
-extern QP::QActive * const AO_Table;
-
-} // namespace APP
-//$enddecl${Shared} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-#ifdef QXK_HPP_
-
-namespace APP {
-
-extern QP::QXThread * const TH_XThread1;
-extern QP::QXThread * const TH_XThread2;
-extern QP::QXSemaphore TH_sema;
-extern QP::QXMutex TH_mutex;
-
-} // namespace APP
-
-#endif // QXK_HPP_
-
-#endif // DPP_HPP_
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/dpp.qm b/examples/arm-cm/dpp_ek-tm4c123gxl/dpp.qm
deleted file mode 100644
index 1de2b108f..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/dpp.qm
+++ /dev/null
@@ -1,528 +0,0 @@
-
-
- Dining Philosopher Problem example application
-
-
-
-
-
-
- : QP::QSignal {
- EAT_SIG = QP::Q_USER_SIG, // published by Table to let a Philo eat
- DONE_SIG, // published by Philo when done eating
- PAUSE_SIG, // published by BSP to pause the application
- SERVE_SIG, // published by BSP to serve re-start serving forks
- TEST_SIG, // published by BSP to test the application
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG, // posted by time event to Philo
- HUNGRY_SIG, // posted by hungry Philo to Table
- MAX_SIG // the last signal
-};
-
-
-
- QS_SIG_DICTIONARY(EAT_SIG, nullptr);
-QS_SIG_DICTIONARY(DONE_SIG, nullptr);
-QS_SIG_DICTIONARY(PAUSE_SIG, nullptr);
-QS_SIG_DICTIONARY(SERVE_SIG, nullptr);
-QS_SIG_DICTIONARY(TEST_SIG, nullptr);
-
-QS_SIG_DICTIONARY(TIMEOUT_SIG, nullptr);
-QS_SIG_DICTIONARY(HUNGRY_SIG, nullptr);
-
-
-
- {5};
-
-
-
-
-
-
-
-
-
-
-
- : QEvt(sig),
- philoId(id)
-
-
-
-
-
- : QEvt(QP::QEvt::DYNAMIC),
- philoId(id)
-
-
-
-
- = {
- &Philo::inst[0],
- &Philo::inst[1],
- &Philo::inst[2],
- &Philo::inst[3],
- &Philo::inst[4]
-};
-
-
-
- = &Table::inst;
-
-
-
-
-
-
- The Philo AO and the N_PHILO instances
-
-
-
-
-
-
-
-
- : QActive(Q_STATE_CAST(&initial)),
- m_timeEvt(this, TIMEOUT_SIG, 0U),
- m_id(0xFFU)
-
-
-
-
-
- Q_UNUSED_PAR(e);
-
-m_id = static_cast<std::uint8_t>(this - &inst[0]);
-
-QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id], m_id);
-QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id].m_timeEvt, m_id);
-
-subscribe(EAT_SIG);
-subscribe(TEST_SIG);
-
-
-
-
-
-
- m_timeEvt.armX(think_time(), 0U);
- m_timeEvt.disarm();
-
-
-
-
-
-
-
-
- // EAT or DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- #ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, HUNGRY_SIG, m_id);
-#else
-TableEvt *pe = Q_NEW(TableEvt, HUNGRY_SIG);
-pe->philoId = m_id;
-#endif
-AO_Table->POST(pe, this);
-
-
-
-
- Q_EVT_CAST(TableEvt)->philoId == m_id
-
-
-
-
-
-
-
-
-
-
- // DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
- m_timeEvt.armX(eat_time(), 0U);
- m_timeEvt.disarm();
-
-#ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, DONE_SIG, m_id);
-#else
-TableEvt *pe = Q_NEW(TableEvt, DONE_SIG);
-pe->philoId = m_id;
-#endif
-QP::QActive::PUBLISH(pe, this);
-
-
-
-
-
-
-
-
- // EAT or DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- : QActive(Q_STATE_CAST(&initial))
-
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
-}
-
-
-
-
-
- Q_UNUSED_PAR(e);
-
-QS_OBJ_DICTIONARY(&Table::inst);
-
-subscribe(DONE_SIG);
-subscribe(PAUSE_SIG);
-subscribe(SERVE_SIG);
-subscribe(TEST_SIG);
-
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, THINKING);
-}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Q_ERROR();
-
-
-
-
-
-
- // give permissions to eat...
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- if (m_isHungry[n]
- && (m_fork[left(n)] == FREE)
- && (m_fork[n] == FREE))
- {
- m_fork[left(n)] = USED;
- m_fork[n] = USED;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *te = Q_NEW(TableEvt, EAT_SIG, n);
-#else
- TableEvt *te = Q_NEW(TableEvt, EAT_SIG);
- te->philoId = n;
-#endif
- QP::QActive::PUBLISH(te, this);
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, EATING);
- }
-}
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, HUNGRY);
-std::uint8_t m = left(n);
-
-
- (m_fork[m] == FREE) && (m_fork[n] == FREE)
- m_fork[m] = USED;
-m_fork[n] = USED;
-#ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, n);
-#else
-TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
-pe->philoId = n;
-#endif
-QP::QActive::PUBLISH(pe, this);
-BSP::displayPhilStat(n, EATING);
-
-
-
-
-
-
- else
- m_isHungry[n] = true;
-
-
-
-
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, THINKING);
-std::uint8_t m = left(n);
-
-// both forks of Phil[n] must be used
-Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
-m_fork[m] = FREE;
-m_fork[n] = FREE;
-m = right(n); // check the right neighbor
-
-if (m_isHungry[m] && (m_fork[m] == FREE)) {
- m_fork[n] = USED;
- m_fork[m] = USED;
- m_isHungry[m] = false;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
-#else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
-#endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
-}
-m = left(n); // check the left neighbor
-n = left(m); // left fork of the left neighbor
-if (m_isHungry[m] && (m_fork[n] == FREE)) {
- m_fork[m] = USED;
- m_fork[n] = USED;
- m_isHungry[m] = false;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
-#else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
-#endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
-}
-
-
-
-
-
-
- Q_ERROR();
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- BSP::displayPaused(1U);
- BSP::displayPaused(0U);
-
-
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// philo ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-m_isHungry[n] = true;
-BSP::displayPhilStat(n, HUNGRY);
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, THINKING);
-std::uint8_t m = left(n);
-
-// both forks of Phil[n] must be used
-Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
-m_fork[m] = FREE;
-m_fork[n] = FREE;
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- #ifndef DPP_HPP_
-#define DPP_HPP_
-
-$declare ${Shared}
-
-#ifdef QXK_HPP_
-
-namespace APP {
-
-extern QP::QXThread * const TH_XThread1;
-extern QP::QXThread * const TH_XThread2;
-extern QP::QXSemaphore TH_sema;
-extern QP::QXMutex TH_mutex;
-
-} // namespace APP
-
-#endif // QXK_HPP_
-
-#endif // DPP_HPP_
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-namespace { // unnamed namespace for local definitions with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// helper function to provide a randomized think time for Philos
-static inline QP::QTimeEvtCtr think_time() {
- return static_cast<QP::QTimeEvtCtr>((BSP::random() % BSP::TICKS_PER_SEC)
- + (BSP::TICKS_PER_SEC/2U));
-}
-
-// helper function to provide a randomized eat time for Philos
-static inline QP::QTimeEvtCtr eat_time() {
- return static_cast<QP::QTimeEvtCtr>((BSP::random() % BSP::TICKS_PER_SEC)
- + BSP::TICKS_PER_SEC);
-}
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-
-$declare ${AOs::Philo}
-
-$define ${Shared::AO_Philo[N_PHILO]}
-$define ${AOs::Philo}
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-$declare ${AOs::Table}
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-
-// helper function to provide the RIGHT neighbour of a Philo[n]
-static inline std::uint8_t right(std::uint8_t const n) {
- return static_cast<std::uint8_t>((n + (APP::N_PHILO - 1U)) % APP::N_PHILO);
-}
-
-// helper function to provide the LEFT neighbour of a Philo[n]
-static inline std::uint8_t left(std::uint8_t const n) {
- return static_cast<std::uint8_t>((n + 1U) % APP::N_PHILO);
-}
-
-static constexpr std::uint8_t FREE {0U};
-static constexpr std::uint8_t USED {1U};
-
-static constexpr char const * const THINKING {"thinking"};
-static constexpr char const * const HUNGRY {"hungry "};
-static constexpr char const * const EATING {"eating "};
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-$define ${Shared::AO_Table}
-$define ${AOs::Table}
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/README.txt
deleted file mode 100644
index f4869b162..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/README.txt
+++ /dev/null
@@ -1,30 +0,0 @@
-About this Example
-==================
-This directory contains the facilities for "linting" the application with
-PC-Lint-Plus.
-
-To "lint" the application, invoke the batch "lin.bat" without parameters.
-Optionally, you can supply the parameter -dQ_SPY to include the QS
-instrumentation in the "linting" process.
-
-The output from the "linting" is saved in the file "lin_out.log".
-
-***
-NOTE: You need to adjust the symbol PCLP_DIR at the top of the lin.bat
-file, to point to the directory where PC-Lint-Plus is installed on your
-machine.
-***
-
-
-The PC-Lint-Plus Options File
-=============================
-The "options.lnt" file specifies the linting options. You might need
-to modify this file to suit your needs.
-
-
-****
-NOTE: The purpose of this example is NOT to find problems with the
-supporting 3rd-party code, which every non-trivial embedded system needs.
-Rather, the purpose of this particular example is to check YOUR application
-level code, such as state machines.
-****
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/lin.bat b/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/lin.bat
deleted file mode 100644
index 4cbefe73c..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/lin.bat
+++ /dev/null
@@ -1,73 +0,0 @@
-@echo off
-:: ===========================================================================
-:: Product: QP/C++ build script for PC-Lint-Plus
-:: Last Updated for Version: 6.8.0
-:: Date of the Last Update: 2020-01-26
-::
-:: Q u a n t u m L e a P s
-:: ------------------------
-:: Modern Embedded Software
-::
-:: Copyright (C) 2005-2020 Quantum Leaps, LLC. All rights reserved.
-::
-:: This program is open source software: you can redistribute it and/or
-:: modify it under the terms of the GNU General Public License as published
-:: by the Free Software Foundation, either version 3 of the License, or
-:: (at your option) any later version.
-::
-:: Alternatively, this program may be distributed and modified under the
-:: terms of Quantum Leaps commercial licenses, which expressly supersede
-:: the GNU General Public License and are specifically designed for
-:: licensees interested in retaining the proprietary status of their code.
-::
-:: This program is distributed in the hope that it will be useful,
-:: but WITHOUT ANY WARRANTY; without even the implied warranty of
-:: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-:: GNU General Public License for more details.
-::
-:: You should have received a copy of the GNU General Public License
-:: along with this program. If not, see .
-::
-:: Contact information:
-::
-::
-:: ===========================================================================
-@setlocal
-
-:: usage of lin.bat
-@echo Usage: lin [16bit] [-d...] [files...]
-@echo examples:
-@echo lin ..\table.cpp : use 32bit CPU (default) for linting ..\table.cpp
-@echo lin 16bit -dQ_SPY ..\philo.cpp : use 16bit CPU and define Q_SPY for linting ..\philo.cpp
-@echo lin ..\philo.cpp ..\table.cpp : use 32bit CPU for linting ..\philo.c and ..\table.cpp
-@echo.
-
-:: NOTE: adjust to for your installation directory of PC-Lint-Plus
-@set PCLP=C:\tools\lint-plus\windows\pclp32.exe
-
-if NOT exist "%PCLP%" (
- @echo The PC-Lint-Plus toolset not found. Please adjust lin.bat
- @goto end
-)
-
-:: set the QP/C++ directory
-set QPCPP=..\..\..\..
-set QPCPP_LINT=%QPCPP%\ports\lint-plus
-
-if "%1"=="16bit" (
- set LINTFLAGS=%QPCPP_LINT%\std.lnt -i%QPCPP_LINT%\16bit options.lnt %2 %3 %4 %5 %6 %7 %8
- @echo 16bit CPU
-) else (
- set LINTFLAGS=%QPCPP_LINT%\std.lnt -i%QPCPP_LINT%\32bit options.lnt %1 %2 %3 %4 %6 %7 %8
- @echo 32bit CPU (default)
-)
-
-:: cleanup
-@del *.log
-
-
-:: linting -------------------------------------------------------------------
-%PCLP% -os(lint_out.log) %LINTFLAGS%
-
-:end
-@endlocal
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/options.lnt b/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/options.lnt
deleted file mode 100644
index 6093417a3..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/lint-plus/options.lnt
+++ /dev/null
@@ -1,64 +0,0 @@
-//////////////////////////////////////////////////////////////////////////////
-// Product: PC-Lint-Plus options for linting QP/C++ applications
-// Last updated for version 6.8.0
-// Last updated on 2020-01-27
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005-2020 Quantum Leaps. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-////////////////////////////////////////////////////////////////////////////
-
-/////////////////////////////////////////////////////////////////////////////
-// general options
--unit_check // perform only subset check (suppresses Global Wrapup)
--max_threads=1 // suppress message "no '-max_threads=N' option"
-//-vf // print names of all source files (for debugging linting)
-
-// include directories
--i.. // application includes
--i%QPCPP%\include // QP/C++ public includes
--i%QPCPP_LINT% // QP/C++ lint "port"
--i%QPCPP_LINT%\qk // QP/C++ lint "port" to QK
-
-// standards
-%QPCPP_LINT%\au-autosar.lnt // AUTOSAR-C++:2014
-%QPCPP_LINT%\au-ds.lnt // Dan Saks recommendations
-//-strong(AXJ) // Strong type checking
-
-// size/alignment options (included from %QPCPP_LINT%\??bit\)
-cpu.lnt // for the chosen CPU
-
-/////////////////////////////////////////////////////////////////////////////
-// QP/C++ options for clients
-qpcpp.lnt // QP/C++ options
-
-/////////////////////////////////////////////////////////////////////////////
-// additional suppression rules for building this application
-
-// underlying type for enums is always 'int'
-+fei
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/main.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/main.cpp
deleted file mode 100644
index 509568b09..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/main.cpp
+++ /dev/null
@@ -1,44 +0,0 @@
-//============================================================================
-// APP example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-09
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//............................................................................
-int main() {
- QP::QF::init(); // initialize the framework and the underlying RT kernel
- BSP::init(); // initialize the BSP
- BSP::start(); // start the AOs/Threads
- return QP::QF::run(); // run the QF application
-}
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/philo.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/philo.cpp
deleted file mode 100644
index 79bc5f36e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/philo.cpp
+++ /dev/null
@@ -1,264 +0,0 @@
-//$file${.::philo.cpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp.qm
-// File: ${.::philo.cpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::philo.cpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-namespace { // unnamed namespace for local definitions with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// helper function to provide a randomized think time for Philos
-static inline QP::QTimeEvtCtr think_time() {
- return static_cast((BSP::random() % BSP::TICKS_PER_SEC)
- + (BSP::TICKS_PER_SEC/2U));
-}
-
-// helper function to provide a randomized eat time for Philos
-static inline QP::QTimeEvtCtr eat_time() {
- return static_cast((BSP::random() % BSP::TICKS_PER_SEC)
- + BSP::TICKS_PER_SEC);
-}
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-
-//$declare${AOs::Philo} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Philo} ..............................................................
-class Philo : public QP::QActive {
-private:
- QP::QTimeEvt m_timeEvt;
- std::uint8_t m_id;
-
-public:
- static Philo inst[N_PHILO];
-
-public:
- Philo();
-
-protected:
- Q_STATE_DECL(initial);
- Q_STATE_DECL(thinking);
- Q_STATE_DECL(hungry);
- Q_STATE_DECL(eating);
-}; // class Philo
-
-} // namespace APP
-//$enddecl${AOs::Philo} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$skip${QP_VERSION} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-// Check for the minimum required QP version
-#if (QP_VERSION < 730U) || (QP_VERSION != ((QP_RELEASE^4294967295U) % 0x3E8U))
-#error qpcpp version 7.3.0 or higher required
-#endif
-//$endskip${QP_VERSION} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$define${Shared::AO_Philo[N_PHILO]} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::AO_Philo[N_PHILO]} ...............................................
-QP::QActive * const AO_Philo[N_PHILO] = {
- &Philo::inst[0],
- &Philo::inst[1],
- &Philo::inst[2],
- &Philo::inst[3],
- &Philo::inst[4]
-};
-
-} // namespace APP
-//$enddef${Shared::AO_Philo[N_PHILO]} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-//$define${AOs::Philo} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Philo} ..............................................................
-Philo Philo::inst[N_PHILO];
-
-//${AOs::Philo::Philo} .......................................................
-Philo::Philo()
- : QActive(Q_STATE_CAST(&initial)),
- m_timeEvt(this, TIMEOUT_SIG, 0U),
- m_id(0xFFU)
-{}
-
-//${AOs::Philo::SM} ..........................................................
-Q_STATE_DEF(Philo, initial) {
- //${AOs::Philo::SM::initial}
- Q_UNUSED_PAR(e);
-
- m_id = static_cast(this - &inst[0]);
-
- QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id], m_id);
- QS_OBJ_ARR_DICTIONARY(&Philo::inst[m_id].m_timeEvt, m_id);
-
- subscribe(EAT_SIG);
- subscribe(TEST_SIG);
-
- QS_FUN_DICTIONARY(&Philo::thinking);
- QS_FUN_DICTIONARY(&Philo::hungry);
- QS_FUN_DICTIONARY(&Philo::eating);
-
- return tran(&thinking);
-}
-
-//${AOs::Philo::SM::thinking} ................................................
-Q_STATE_DEF(Philo, thinking) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::thinking}
- case Q_ENTRY_SIG: {
- m_timeEvt.armX(think_time(), 0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking}
- case Q_EXIT_SIG: {
- m_timeEvt.disarm();
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking::TIMEOUT}
- case TIMEOUT_SIG: {
- status_ = tran(&hungry);
- break;
- }
- //${AOs::Philo::SM::thinking::EAT, DONE}
- case EAT_SIG: // intentionally fall through
- case DONE_SIG: {
- // EAT or DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking::TEST}
- case TEST_SIG: {
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Philo::SM::hungry} ..................................................
-Q_STATE_DEF(Philo, hungry) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::hungry}
- case Q_ENTRY_SIG: {
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, HUNGRY_SIG, m_id);
- #else
- TableEvt *pe = Q_NEW(TableEvt, HUNGRY_SIG);
- pe->philoId = m_id;
- #endif
- AO_Table->POST(pe, this);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::hungry::EAT}
- case EAT_SIG: {
- //${AOs::Philo::SM::hungry::EAT::[e->philoId==m_id]}
- if (Q_EVT_CAST(TableEvt)->philoId == m_id) {
- status_ = tran(&eating);
- }
- else {
- status_ = Q_RET_UNHANDLED;
- }
- break;
- }
- //${AOs::Philo::SM::hungry::DONE}
- case DONE_SIG: {
- // DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Philo::SM::eating} ..................................................
-Q_STATE_DEF(Philo, eating) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::eating}
- case Q_ENTRY_SIG: {
- m_timeEvt.armX(eat_time(), 0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::eating}
- case Q_EXIT_SIG: {
- m_timeEvt.disarm();
-
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, DONE_SIG, m_id);
- #else
- TableEvt *pe = Q_NEW(TableEvt, DONE_SIG);
- pe->philoId = m_id;
- #endif
- QP::QActive::PUBLISH(pe, this);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::eating::TIMEOUT}
- case TIMEOUT_SIG: {
- status_ = tran(&thinking);
- break;
- }
- //${AOs::Philo::SM::eating::EAT, DONE}
- case EAT_SIG: // intentionally fall through
- case DONE_SIG: {
- // EAT or DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-} // namespace APP
-//$enddef${AOs::Philo} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/README.txt
deleted file mode 100644
index 03fe7046e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/README.txt
+++ /dev/null
@@ -1,60 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-***
-NOTE: This example requires installing the following Software Pack
-in the Keil uVision: Keil::TM4C_DFP.
-***
-
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP/C framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size.
-
-***
-NOTE:
-C++ programs seem not to tolerate heap size of 0. Therefore it is
-recommended to set the Heap_Size symbol to a minimal value of 16.
-***
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.sct b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.sct
deleted file mode 100644
index fda39c74a..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Modified by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00040000 { ; load region size_region
- ER_IROM1 0x00000000 0x00040000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: 2048 assumeed STACK size!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.uvoptx b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.uvoptx
deleted file mode 100644
index 6152c0174..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.uvoptx
+++ /dev/null
@@ -1,994 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- DLGUARM
- ÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÈ`»
-´ª¤ô
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\..\philo.cpp
- philo.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\table.cpp
- table.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 4
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
- 1
- 5
- 5
- 0
- 0
- 0
- ..\..\dpp.hpp
- dpp.hpp
- 0
- 0
-
-
- 1
- 6
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
-
-
- ek-tm4c123gxl
- 1
- 0
- 0
- 0
-
- 2
- 7
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
- system_TM4C123GH6PM.c
- 0
- 0
-
-
- 2
- 8
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
- TM4C123GH6PM.h
- 0
- 0
-
-
- 2
- 9
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
- startup_TM4C123GH6PM.s
- 0
- 0
-
-
- 2
- 10
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
- gpio.h
- 0
- 0
-
-
- 2
- 11
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
- rom.h
- 0
- 0
-
-
- 2
- 12
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
- sysctl.h
- 0
- 0
-
-
- 2
- 13
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
- system_TM4C123GH6PM.h
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qk\qk.cpp
- qk.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
- qk_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.uvprojx b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.uvprojx
deleted file mode 100644
index fe11b126e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/armclang/dpp-qk.uvprojx
+++ /dev/null
@@ -1,1823 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- dpp-qk
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\dpp-qk.bin .\dbg\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 2
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- QF_ON_CONTEXT_SW
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- dpp-qk
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\dpp-qk.bin .\rel\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- NDEBUG,QF_ON_CONTEXT_SW
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- dpp-qk
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\dpp-qk.bin .\spy\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- Q_SPY,QF_ON_CONTEXT_SW
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/bsp.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/bsp.cpp
deleted file mode 100644
index f185a0c7a..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/bsp.cpp
+++ /dev/null
@@ -1,544 +0,0 @@
-//============================================================================
-// Product: DPP example, EK-TM4C123GXL board, QK kernel
-// Last updated for version 7.3.2
-// Last updated on 2023-12-13
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "TM4C123GH6PM.h" // the device specific header (TI)
-#include "rom.h" // the built-in ROM functions (TI)
-#include "sysctl.h" // system control driver (TI)
-#include "gpio.h" // GPIO driver (TI)
-// add other drivers if necessary...
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr std::uint32_t LED_RED {1U << 1U};
-constexpr std::uint32_t LED_GREEN {1U << 3U};
-constexpr std::uint32_t LED_BLUE {1U << 2U};
-
-constexpr std::uint32_t BTN_SW1 {1U << 4U};
-constexpr std::uint32_t BTN_SW2 {1U << 0U};
-
-static std::uint32_t l_rndSeed;
-
-#ifdef Q_SPY
-
- // QSpy source IDs
- QP::QSpyId const l_SysTick_Handler = { 0U };
- QP::QSpyId const l_GPIOPortA_IRQHandler = { 0U };
-
- constexpr std::uint32_t UART_BAUD_RATE {115200U};
- constexpr std::uint32_t UART_FR_TXFE {1U << 7U};
- constexpr std::uint32_t UART_FR_RXFE {1U << 4U};
- constexpr std::uint32_t UART_TXFIFO_DEPTH {16U};
-
- enum AppRecords { // application-specific trace records
- PHILO_STAT = QP::QS_USER,
- PAUSED_STAT,
- CONTEXT_SW,
- };
-
-#endif
-
-} // unnamed namespace
-
-//============================================================================
-// Error handler and ISRs...
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int const id) {
- // NOTE: this implementation of the error handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up all LEDs
- GPIOF_AHB->DATA_Bits[LED_GREEN | LED_RED | LED_BLUE] = 0xFFU;
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#else
- NVIC_SystemReset();
- for (;;) { // explicitly "no-return"
- }
-#endif
-}
-//............................................................................
-void assert_failed(char const * const module, int const id); // prototype
-void assert_failed(char const * const module, int const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QK_ISR_ENTRY(); // inform QK about entering an ISR
-
- QP::QTimeEvt::TICK_X(0U, &l_SysTick_Handler); // time events at rate 0
-
- // Perform the debouncing of buttons. The algorithm for debouncing
- // adapted from the book "Embedded Systems Dictionary" by Jack Ganssle
- // and Michael Barr, page 71.
- static struct {
- std::uint32_t depressed;
- std::uint32_t previous;
- } buttons = { 0U, 0U };
-
- std::uint32_t current = ~GPIOF_AHB->DATA_Bits[BTN_SW1 | BTN_SW2];
- std::uint32_t tmp = buttons.depressed; // save the depressed buttons
- buttons.depressed |= (buttons.previous & current); // set depressed
- buttons.depressed &= (buttons.previous | current); // clear released
- buttons.previous = current; // update the history
- tmp ^= buttons.depressed; // changed debounced depressed
- current = buttons.depressed;
-
- if ((tmp & BTN_SW1) != 0U) { // debounced SW1 state changed?
- if ((current & BTN_SW1) != 0U) { // is SW1 depressed?
- static QP::QEvt const pauseEvt(APP::PAUSE_SIG);
- QP::QActive::PUBLISH(&pauseEvt, &l_SysTick_Handler);
- }
- else { // the button is released
- static QP::QEvt const serveEvt(APP::SERVE_SIG);
- QP::QActive::PUBLISH(&serveEvt, &l_SysTick_Handler);
- }
- }
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-//............................................................................
-// interrupt handler for testing preemptions
-void GPIOPortA_IRQHandler(void); // prototype
-void GPIOPortA_IRQHandler(void) {
- QK_ISR_ENTRY(); // inform QK about entering an ISR
-
- static QP::QEvt const testEvt(APP::TEST_SIG);
- APP::AO_Table->POST(&testEvt, &l_GPIOPortA_IRQHandler);
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-
-//............................................................................
-#ifdef Q_SPY
-// ISR for receiving bytes from the QSPY Back-End
-// NOTE: This ISR is "QF-unaware" meaning that it does not interact with
-// the QF/QK and is not disabled. Such ISRs don't need to call
-// QK_ISR_ENTRY/QK_ISR_EXIT and they cannot post or publish events.
-
-void UART0_IRQHandler(void); // prototype
-void UART0_IRQHandler(void) {
- uint32_t status = UART0->RIS; // get the raw interrupt status
- UART0->ICR = status; // clear the asserted interrupts
-
- while ((UART0->FR & UART_FR_RXFE) == 0U) { // while RX FIFO NOT empty
- std::uint8_t b = static_cast(UART0->DR);
- QP::QS::rxPut(b);
- }
-
- QK_ARM_ERRATUM_838869();
-}
-#endif // Q_SPY
-
-//............................................................................
-#ifdef QF_ON_CONTEXT_SW
-// NOTE: the context-switch callback is called with interrupts DISABLED
-void QF_onContextSw(QP::QActive *prev, QP::QActive *next) {
- QS_BEGIN_INCRIT(CONTEXT_SW, 0U) // in critical section!
- QS_OBJ(prev);
- QS_OBJ(next);
- QS_END_INCRIT()
-}
-#endif // QF_ON_CONTEXT_SW
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QK
-
- // enable clock for to the peripherals used by this application...
- SYSCTL->RCGCGPIO |= (1U << 5U); // enable Run mode for GPIOF
- SYSCTL->GPIOHBCTL |= (1U << 5U); // enable AHB for GPIOF
- __ISB();
- __DSB();
-
- // configure LEDs (digital output)
- GPIOF_AHB->DIR |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DEN |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DATA_Bits[LED_RED | LED_BLUE | LED_GREEN] = 0U;
-
- // configure switches...
-
- // unlock access to the SW2 pin because it is PROTECTED
- GPIOF_AHB->LOCK = 0x4C4F434BU; // unlock GPIOCR register for SW2
- // commit the write (cast const away)
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x01U;
-
- GPIOF_AHB->DIR &= ~(BTN_SW1 | BTN_SW2); // input
- GPIOF_AHB->DEN |= (BTN_SW1 | BTN_SW2); // digital enable
- GPIOF_AHB->PUR |= (BTN_SW1 | BTN_SW2); // pull-up resistor enable
-
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x00U;
- GPIOF_AHB->LOCK = 0x0; // lock GPIOCR register for SW2
-
- BSP::randomSeed(1234U);
-
- // initialize the QS software tracing...
- if (!QS_INIT(nullptr)) {
- Q_ERROR();
- }
-
- // dictionaries...
- QS_OBJ_DICTIONARY(&l_SysTick_Handler);
- QS_OBJ_DICTIONARY(&l_GPIOPortA_IRQHandler);
- QS_USR_DICTIONARY(PHILO_STAT);
- QS_USR_DICTIONARY(PAUSED_STAT);
- QS_USR_DICTIONARY(CONTEXT_SW);
-
- QS_ONLY(APP::produce_sig_dict());
-
- // setup the QS filters...
- QS_GLB_FILTER(QP::QS_ALL_RECORDS); // all records
- QS_GLB_FILTER(-QP::QS_QF_TICK); // exclude the clock tick
- QS_LOC_FILTER(-(APP::N_PHILO + 3U)); // exclude prio. of AO_Ticker0
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(APP::TableEvt) smlPoolSto[2*APP::N_PHILO];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // start AOs/threads...
- static QP::QEvt const *philoQueueSto[APP::N_PHILO][APP::N_PHILO];
- for (std::uint8_t n = 0U; n < APP::N_PHILO; ++n) {
- APP::AO_Philo[n]->start(
-
- // NOTE: set the preemption-threshold of all Philos to
- // the same level, so that they cannot preempt each other.
- Q_PRIO(n + 3U, APP::N_PHILO + 2U), // QF-prio/pre-thre.
-
- philoQueueSto[n], // event queue storage
- Q_DIM(philoQueueSto[n]), // queue length [events]
- nullptr, 0U); // no stack storage
- }
-
- static QP::QEvt const *tableQueueSto[APP::N_PHILO];
- APP::AO_Table->start(
- APP::N_PHILO + 7U, // QP prio. of the AO
- tableQueueSto, // event queue storage
- Q_DIM(tableQueueSto), // queue length [events]
- nullptr, 0U); // no stack storage
-}
-//............................................................................
-void displayPhilStat(std::uint8_t n, char const *stat) {
- Q_UNUSED_PAR(n);
-
- GPIOF_AHB->DATA_Bits[LED_GREEN] = ((stat[0] == 'e') ? LED_GREEN : 0U);
-
- // app-specific trace record...
- QS_BEGIN_ID(PHILO_STAT, APP::AO_Table->getPrio())
- QS_U8(1, n); // Philosopher number
- QS_STR(stat); // Philosopher status
- QS_END()
-}
-//............................................................................
-void displayPaused(std::uint8_t const paused) {
- GPIOF_AHB->DATA_Bits[LED_BLUE] = ((paused != 0U) ? LED_BLUE : 0U);
-
- // application-specific trace record
- QS_BEGIN_ID(PAUSED_STAT, APP::AO_Table->getPrio())
- QS_U8(1, paused); // Paused status
- QS_END()
-}
-//............................................................................
-void randomSeed(uint32_t const seed) {
- l_rndSeed = seed;
-}
-//............................................................................
-std::uint32_t random() { // a very cheap pseudo-random-number generator
- // Some floating point code is to exercise the VFP...
- float volatile x = 3.1415926F;
- x = x + 2.7182818F;
-
- QP::QSchedStatus lockStat = QP::QK::schedLock(APP::N_PHILO);
- // "Super-Duper" Linear Congruential Generator (LCG)
- // LCG(2^32, 3*7*11*13*23, 0, seed)
- std::uint32_t rnd = l_rndSeed * (3U*7U*11U*13U*23U);
- l_rndSeed = rnd; // set for the next time
- QP::QK::schedUnlock(lockStat);
-
- return (rnd >> 8U);
-}
-//............................................................................
-void ledOn() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0xFFU;
-}
-//............................................................................
-void ledOff() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0x00U;
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-// namespace QP
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(UART0_IRQn, 0U); // kernel unaware interrupt
- NVIC_SetPriority(GPIOA_IRQn, QF_AWARE_ISR_CMSIS_PRI + 0U);
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
- NVIC_EnableIRQ(GPIOA_IRQn);
-
-#ifdef Q_SPY
- NVIC_EnableIRQ(UART0_IRQn); // UART interrupt used for QS-RX
-#endif
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QK::onIdle() {
- // toggle the User LED on and then off, see NOTE3
- QF_INT_DISABLE();
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0xFFU; // turn the Blue LED on
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0U; // turn the Blue LED off
- QF_INT_ENABLE();
-
- // Some floating point code is to exercise the VFP...
- float volatile x = 1.73205F;
- x = x * 1.73205F;
-
-#ifdef Q_SPY
- QF_INT_DISABLE();
- QS::rxParse(); // parse all the received bytes
- QF_INT_ENABLE();
- QF_CRIT_EXIT_NOP();
-
- QF_INT_DISABLE();
- if ((UART0->FR & UART_FR_TXFE) != 0U) { // TX done?
- std::uint16_t fifo = UART_TXFIFO_DEPTH; // max bytes we can accept
-
- // try to get next contiguous block to transmit
- std::uint8_t const *block = QS::getBlock(&fifo);
-
- while (fifo-- != 0U) { // any bytes in the block?
- UART0->DR = *block++; // put into the FIFO
- }
- }
- QF_INT_ENABLE();
-#elif defined NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- __WFI(); // Wait-For-Interrupt
-#endif
-}
-
-//============================================================================
-// QS callbacks...
-#ifdef Q_SPY
-namespace QS {
-
-//............................................................................
-bool onStartup(void const *arg) {
- Q_UNUSED_PAR(arg);
-
- static std::uint8_t qsTxBuf[2*1024]; // buffer for QS-TX channel
- initBuf(qsTxBuf, sizeof(qsTxBuf));
-
- static std::uint8_t qsRxBuf[100]; // buffer for QS-RX channel
- rxInitBuf(qsRxBuf, sizeof(qsRxBuf));
-
- // enable clock for UART0 and GPIOA (used by UART0 pins)
- SYSCTL->RCGCUART |= (1U << 0U); // enable Run mode for UART0
- SYSCTL->RCGCGPIO |= (1U << 0U); // enable Run mode for GPIOA
-
- // configure UART0 pins for UART operation
- std::uint32_t tmp = (1U << 0U) | (1U << 1U);
- GPIOA->DIR &= ~tmp;
- GPIOA->SLR &= ~tmp;
- GPIOA->ODR &= ~tmp;
- GPIOA->PUR &= ~tmp;
- GPIOA->PDR &= ~tmp;
- GPIOA->AMSEL &= ~tmp; // disable analog function on the pins
- GPIOA->AFSEL |= tmp; // enable ALT function on the pins
- GPIOA->DEN |= tmp; // enable digital I/O on the pins
- GPIOA->PCTL &= ~0x00U;
- GPIOA->PCTL |= 0x11U;
-
- // configure the UART for the desired baud rate, 8-N-1 operation
- tmp = (((SystemCoreClock * 8U) / UART_BAUD_RATE) + 1U) / 2U;
- UART0->IBRD = tmp / 64U;
- UART0->FBRD = tmp % 64U;
- UART0->LCRH = (0x3U << 5U); // configure 8-N-1 operation
- UART0->LCRH |= (0x1U << 4U); // enable FIFOs
- UART0->CTL = (1U << 0U) // UART enable
- | (1U << 8U) // UART TX enable
- | (1U << 9U); // UART RX enable
-
- // configure UART interrupts (for the RX channel)
- UART0->IM |= (1U << 4U) | (1U << 6U); // enable RX and RX-TO interrupt
- UART0->IFLS |= (0x2U << 2U); // interrupt on RX FIFO half-full
- // NOTE: do not enable the UART0 interrupt yet. Wait till QF_onStartup()
-
- // configure TIMER5 to produce QS time stamp
- SYSCTL->RCGCTIMER |= (1U << 5U); // enable run mode for Timer5
- TIMER5->CTL = 0U; // disable Timer1 output
- TIMER5->CFG = 0x0U; // 32-bit configuration
- TIMER5->TAMR = (1U << 4U) | 0x02U; // up-counting periodic mode
- TIMER5->TAILR= 0xFFFFFFFFU; // timer interval
- TIMER5->ICR = 0x1U; // TimerA timeout flag bit clears
- TIMER5->CTL |= (1U << 0U); // enable TimerA module
-
- return true; // return success
-}
-//............................................................................
-void onCleanup() {
-}
-//............................................................................
-QSTimeCtr onGetTime() { // NOTE: invoked with interrupts DISABLED
- return TIMER5->TAV;
-}
-//............................................................................
-// NOTE:
-// No critical section in QS::onFlush() to avoid nesting of critical sections
-// in case QS::onFlush() is called from Q_onError().
-void onFlush() {
- for (;;) {
- std::uint16_t b = getByte();
- if (b != QS_EOD) {
- while ((UART0->FR & UART_FR_TXFE) == 0U) { // while TXE not empty
- }
- UART0->DR = b; // put into the DR register
- }
- else {
- break;
- }
- }
-}
-//............................................................................
-void onReset() {
- NVIC_SystemReset();
-}
-//............................................................................
-// callback function to execute a user command
-void onCommand(std::uint8_t cmdId, std::uint32_t param1,
- std::uint32_t param2, std::uint32_t param3)
-{
- Q_UNUSED_PAR(cmdId);
- Q_UNUSED_PAR(param1);
- Q_UNUSED_PAR(param2);
- Q_UNUSED_PAR(param3);
-}
-
-} // namespace QS
-#endif // Q_SPY
-//----------------------------------------------------------------------------
-
-} // namespace QP
-
-//============================================================================
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call the QK_ISR_ENTRY/
-// QK_ISR_ENTRY macros or any other QF/QK services. These ISRs are
-// "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QK services. In particular they
-// can NOT call the macros QK_ISR_ENTRY/QK_ISR_ENTRY. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.ccsproject b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.ccsproject
deleted file mode 100644
index e057df002..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.ccsproject
+++ /dev/null
@@ -1,5 +0,0 @@
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.cproject b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.cproject
deleted file mode 100644
index c3caf8100..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.cproject
+++ /dev/null
@@ -1,318 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.project b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.project
deleted file mode 100644
index bdf5667f9..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/.project
+++ /dev/null
@@ -1,100 +0,0 @@
-
-
- dpp-qk
-
-
-
-
-
- org.eclipse.cdt.managedbuilder.core.genmakebuilder
-
-
-
-
- org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder
- full,incremental,
-
-
-
-
-
- com.ti.ccstudio.core.ccsNature
- org.eclipse.cdt.core.cnature
- org.eclipse.cdt.managedbuilder.core.managedBuildNature
- org.eclipse.cdt.core.ccnature
- org.eclipse.cdt.managedbuilder.core.ScannerConfigNature
-
-
-
- QK
- 2
- PARENT-5-PROJECT_LOC/src/qk
-
-
- QP
- 2
- PARENT-5-PROJECT_LOC/src/qf
-
-
- QP_port
- 2
- PARENT-5-PROJECT_LOC/ports/arm-cm/qk/gnu
-
-
- QS
- 2
- PARENT-5-PROJECT_LOC/src/qs
-
-
- TM4C123GH6PM.h
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/TM4C123GH6PM.h
-
-
- bsp.cpp
- 1
- PARENT-1-PROJECT_LOC/bsp.cpp
-
-
- main.cpp
- 1
- PARENT-2-PROJECT_LOC/main.cpp
-
-
- philo.cpp
- 1
- PARENT-2-PROJECT_LOC/philo.cpp
-
-
- qp_config.hpp
- 1
- PARENT-2-PROJECT_LOC/qp_config.hpp
-
-
- startup_TM4C123GH6PM.c
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/gnu/startup_TM4C123GH6PM.c
-
-
- system_TM4C123GH6PM.c
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/system_TM4C123GH6PM.c
-
-
- system_TM4C123GH6PM.h
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/system_TM4C123GH6PM.h
-
-
- table.cpp
- 1
- PARENT-2-PROJECT_LOC/table.cpp
-
-
-
-
- CG_TOOL_GPP
- $%7BCG_TOOL_ROOT%7D/bin/arm-none-eabi-g++
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/Makefile b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/Makefile
deleted file mode 100644
index a2761cdd9..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/Makefile
+++ /dev/null
@@ -1,310 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EK-TM4C123GXL, QK kernel, GNU-ARM
-# Last Updated for Version: 7.3.3
-# Date of the Last Update: 2024-01-29
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := dpp-qk
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qk/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qk \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/ek-tm4c123gxl \
- $(QPCPP)/3rd_party/ek-tm4c123gxl/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/ek-tm4c123gxl
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_TM4C123GH6PM.c \
- startup_TM4C123GH6PM.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- philo.cpp \
- table.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qk.cpp \
- qk_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DQP_CONFIG
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=fpv4-sp-d16
-FLOAT_ABI := -mfloat-abi=hard
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically you should not need to change anything below this line
-
-# basic utilities (included in QTools for Windows), see:
-# https://www.state-machine.com/qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-.PHONY : clean show
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/README.txt
deleted file mode 100644
index ab8e99e8f..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/README.txt
+++ /dev/null
@@ -1,79 +0,0 @@
-About this Example
-==================
-This example can be built in two different ways:
-- from the command prompt with the provided Makefile.
-- from the TI Code Composer Studio with the provided CCS project.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-The CCS Project
-===============
-This directory contains also the CCS project which can be imported to the
-CCS (Code Composer Studio) IDE based on Eclipse. To import the project,
-use the section "General -> Existing Project into Workspace" and select this
-directory as the "root directory". For example, the "Select root directory"
-might be: C:\qp-dev\qpc\examples\arm-cm\dpp_ek-tm4c123gxl\qxk\gnu
-
-Once you press "Browse", the project (dpp-qk, dpp-qv, or dpp-qxk) should
-become visible. Click on "Select All" and then "Finish".
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\gcc\startup_TM4C123GH6PM.c
-
-The file startup_TM4C123GH6PM.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/dpp-qk.ld b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/dpp-qk.ld
deleted file mode 100644
index 5139ce62b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/dpp-qk.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EK-TM4C123GXL, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* Web : http://www.state-machine.com
-* Email: info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Tiva TM4C123GH6PM */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/flash.bat b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/flash.bat
deleted file mode 100644
index cb2a3886e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/gnu/flash.bat
+++ /dev/null
@@ -1,33 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EK-TM4C123GXL
-::
-:: NOTE: requires the LMFlash programmer (included in QTools for Windows)
-::
-@echo off
-setlocal
-
-@echo Load a given binary file to the flash of EK-TM4C123GXL
-@echo usage: flash binary-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: The following symbol LMFLASH assumes that LMFlash.exe can
-:: be found on the PATH. You might need to adjust this symbol to the
-:: location of the LMFlash utility on your machine
-::
-set LMFLASH=LMFlash.exe
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-%LMFLASH% -q ek-tm4c123gxl -e -v -r %1
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/README.txt
deleted file mode 100644
index a0a244154..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C++ framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C++ stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-------------
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.ewd b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.ewd
deleted file mode 100644
index 143fc5398..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.ewp b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.ewp
deleted file mode 100644
index 176a5d37b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.ewp
+++ /dev/null
@@ -1,3347 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 1
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 1
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\dpp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
- $PROJ_DIR$\..\..\philo.cpp
-
-
- $PROJ_DIR$\..\..\table.cpp
-
-
-
- ek-tm4c123gxl
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qk\qk.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qk\iar\qk_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.eww b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.eww
deleted file mode 100644
index c261124af..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\dpp-qk.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.icf b/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.icf
deleted file mode 100644
index c6b24e1c6..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qk/iar/dpp-qk.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK }; /* <== Quantum Leaps */
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qp_config.hpp b/examples/arm-cm/dpp_ek-tm4c123gxl/qp_config.hpp
deleted file mode 100644
index 57e38bd99..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qp_config.hpp
+++ /dev/null
@@ -1,271 +0,0 @@
-//============================================================================
-// QP configuration file (QXK on ARM Cortex-M)
-// Last updated for version: 7.3.0
-// Last updated on: 2023-10-30
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef QP_CONFIG_HPP_
-#define QP_CONFIG_HPP_
-
-//-------- <<< Use Configuration Wizard in Context Menu >>> -----------------
-
-// NOTE: Requires command-line macro: QP_CONFIG
-// This qp_config.h header file is activated only when the macro
-// QP_CONFIG is defined on the command-line to the compiler
-// -------------------------------------------
-
-// QP API compatibility version (QP_API_VERSION)
-// <0=> 0 (Maximum compatibility)
-// <580=>580 (QP 5.8.0 or newer)
-// <660=>660 (QP 6.6.0 or newer)
-// <691=>691 (QP 6.9.1 or newer)
-// <700=>700 (QP 7.0.0 or newer)
-// <9999=>9999 (Latest only)
-// QP API backwards compatibility with the QP/C API version.
-// Lower QP_API_VERSION values enable backwards compatibility
-// with lower (older) QP API versions.
-// For example, QP_API_VERSION==691 will enable the compatibility
-// layer with QP version 6.9.1 and newer, but not older than 6.9.1.
-// QP_API_VERSION==0 enables the maximum currently supported
-// backwards compatibility. Conversely, QP_API_VERSION==9999 means
-// that no backwards compatibility layer should be enabled.
-// Default: 0 (All supported)
-#define QP_API_VERSION 0
-
-//..........................................................................
-// QP Functional Safety (FuSa) Subsystem (Q_UNSAFE)
-// The QP FuSa Subsystem consists of the following facilities:
-// - Software assertions as a recommended technique
-// (called Failure Assertion Programming (FAP) in IEC 61508)
-// - Software Self-Monitoring (SSM), which encompasses such techniques:
-// * Duplicate Inverse Storage for critical variables
-// * Memory Markers for critical objects (e.g., events)
-// * Hard-limits for all loops
-// * Memory Isolation by means of Memory Protection Unit (MPU)
-
-// Disable QP FuSa in development
-// Disable assertions and other self monitoring features
-// in development build configurations (NDEBUG undefined).
-// VIOLATES functional safety standards. NOT recommended !!!
-//#ifndef NDEBUG
-//#define Q_UNSAFE
-//#endif
-//
-
-// Disable QP FuSa in production release
-// Disable assertions and other self monitoring features
-// in the release build configurations (NDEBUG defined).
-// VIOLATES functional safety standards. NOT recommended !!!
-//#ifdef NDEBUG
-//#define Q_UNSAFE
-//#endif
-//
-
-//
-
-//..........................................................................
-// QEP Event Processor
-// Events and state machines.
-
-// Event signal size (Q_SIGNAL_SIZE)
-// <1U=>1
-// <2U=>2 (default)
-// <4U=>4
-// Size of the QEvt signal for QEP/QF [bytes]
-// Default: 2
-#define Q_SIGNAL_SIZE 2U
-
-//
-
-//..........................................................................
-// QF Framework
-// Active Object framework
-
-// Maximum # Active Objects (QF_MAX_ACTIVE) <1-64>
-// Maximum # Active Objects in the system <1..64>
-// Default: 32
-#define QF_MAX_ACTIVE 32U
-
-// Maximum # event pools (QF_MAX_EPOOL)
-// <0=>0 no event pools
-// <1=>1 <2=>2 <3=>3 (default) <4=>4 <5=>5
-// <6=>6 <7=>7 <8=>8 <9=>9 <10=>10 <11=>11
-// <12=>12 <13=>13 <14=>14 <15=>15
-// Maximum # Event Pools <1..15>
-// Default: 3
-#define QF_MAX_EPOOL 3U
-
-// Maximum # clock tick rates (QF_MAX_TICK_RATE)
-// <0=>0 no time events
-// <1=>1 (default) <2=>2 <3=>3 <4=>4 <5=>5
-// <6=>6 <7=>7 <8=>8 <9=>9 <10=>10 <11=>11
-// <12=>12 <13=>13 <14=>14 <15=>15
-// Maximum # clock tick rates for time events <1..15>
-// Default: 1
-#define QF_MAX_TICK_RATE 1U
-
-// Dynamic Event Constructor (QEVT_DYN_CTOR)
-// Dynamic Event Constructor (RAII)
-//#define QEVT_DYN_CTOR
-//
-
-// Active Object stop API (QACTIVE_CAN_STOP)
-// Enable Active Object stop API (Not recommended)
-//#define QACTIVE_CAN_STOP
-//
-
-// Event size (QF_EVENT_SIZ_SIZE)
-// <1U=>1
-// <2U=>2 (default)
-// <4U=>4
-// Size of the dynamic events for QF [bytes]
-// Default: 2 (64K bytes maximum event size)
-#define QF_EVENT_SIZ_SIZE 2U
-
-// Time event counter size (QF_TIMEEVT_CTR_SIZE)
-// <1U=>1
-// <2U=>2
-// <4U=>4 (default)
-// Size of the QTimeEvt counter [bytes]
-// Default: 4 (2^32 dynamic range)
-#define QF_TIMEEVT_CTR_SIZE 4U
-
-// Event queue counter size (QF_EQUEUE_CTR_SIZE)
-// <1U=>1 (default)
-// <2U=>2
-// <4U=>4
-// Size of event queue counter [bytes]
-// Default: 1 (255 events maximum in a queue)
-#define QF_EQUEUE_CTR_SIZE 1U
-
-// Memory pool counter size (QF_MPOOL_CTR_SIZE)
-// <1U=>1
-// <2U=>2 (default)
-// <4U=>4
-// Size of memory pool counter [bytes]
-// Default: 2 (64K blocks maximum in a pool)
-#define QF_MPOOL_CTR_SIZE 2U
-
-// Memory block size (QF_MPOOL_SIZ_SIZE)
-// <1U=>1
-// <2U=>2 (default)
-// <4U=>4
-// Size of memory pool block [bytes]
-// Default: 2 (64K bytes maximum block size)
-#define QF_MPOOL_SIZ_SIZE 2U
-
-//
-
-//..........................................................................
-// QS Software Tracing
-// Target-resident component of QP/Spy software tracing system
-// (tracing instrumentation and command-input).
-
-// NOTE: Requires command-line macro: Q_SPY
-// The QS software tracing instrumenation is activated only when
-// the macro Q_SPY is defined on the command-line to the compiler.
-// Typically, Q_SPY is defined only in the "spy" build configuration.
-
-// QS timestamp size (QS_TIME_SIZE)
-// <1U=>1
-// <2U=>2
-// <4U=>4 (default)
-// Size of the timestamp in QS [bytes]
-// Default: 4 (2^32 dynamic range)
-#define QS_TIME_SIZE 4U
-
-// Object pointer size (QS_OBJ_PTR_SIZE)
-// <2U=>2
-// <4U=>4 (default)
-// <8U=>8
-// Size of object pointer for QS [bytes]
-// Default: 4 (4G address space)
-#define QS_OBJ_PTR_SIZE 4U
-
-// Function pointer size (QS_FUN_PTR_SIZE)
-// <2U=>2
-// <4U=>4 (default)
-// <8U=>8
-// Size of function pointer for QS [bytes]
-// Default: 4 (4G address space)
-#define QS_FUN_PTR_SIZE 4U
-
-// QS buffer counter size (QS_CTR_SIZE)
-// <1U=>1
-// <2U=>2 (default)
-// <4U=>4
-// Size of the counter in the internal QS buffer [bytes]
-// Default: 2 (64K bytes in QS buffer)
-#define QS_CTR_SIZE 2U
-
-//
-
-//..........................................................................
-// QXK Preemptive Dual-Mode Kernel
-// Preemptive non-blocking/blocking RTOS kernel.
-
-// Context switch callback (QF_ON_CONTEXT_SW)
-
-// Context switch callback WITHOUT QS
-// Enable context switch callback QF_onContextSw()
-// When Q_SPY is undefined.
-//#ifndef Q_SPY
-//#define QF_ON_CONTEXT_SW
-//#endif
-//
-
-// Context switch callback WITH QS
-// Enable context switch callback QF_onContextSw()
-// When Q_SPY is defined.
-//#ifdef Q_SPY
-//#define QF_ON_CONTEXT_SW
-//#endif
-//
-
-//
-
-// MPU memory isolation (QF_MEM_ISOLATE)
-// Enable memory isolation (requires MPU)
-// NOTE: implies QF_ON_CONTEXT_SW.
-//#define QF_MEM_ISOLATE
-//
-
-// Use IRQ handler for QXK return-from-preemption
-// Enable this option only if the NMI handler is used in the project.
-// If enabled, provide the otherwise unused IRQ number (QXK_USE_IRQ_NUM)
-// and the corresponding IRQ handler name (QXK_USE_IRQ_HANDLER)
-// in the "Text Editor" mode.
-//#define QXK_USE_IRQ_NUM 31
-//#define QXK_USE_IRQ_HANDLER Reserved31_IRQHandler
-//
-
-//
-
-//------------- <<< end of configuration section >>> -----------------------
-
-#endif // QP_CONFIG_HPP_
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/README.txt
deleted file mode 100644
index 03fe7046e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/README.txt
+++ /dev/null
@@ -1,60 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-***
-NOTE: This example requires installing the following Software Pack
-in the Keil uVision: Keil::TM4C_DFP.
-***
-
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP/C framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size.
-
-***
-NOTE:
-C++ programs seem not to tolerate heap size of 0. Therefore it is
-recommended to set the Heap_Size symbol to a minimal value of 16.
-***
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.sct b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.sct
deleted file mode 100644
index 458d5506e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Adapted by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00040000 { ; load region size_region
- ER_IROM1 0x00000000 0x00040000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: assume STACK size 2048!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.uvoptx b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.uvoptx
deleted file mode 100644
index 7ee1da438..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.uvoptx
+++ /dev/null
@@ -1,994 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- DLGUARM
- ÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÈ`»
-´ª¤ô
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\philo.cpp
- philo.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\..\table.cpp
- table.cpp
- 0
- 0
-
-
- 1
- 4
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
- 1
- 5
- 5
- 0
- 0
- 0
- ..\..\dpp.hpp
- dpp.hpp
- 0
- 0
-
-
- 1
- 6
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
-
-
- ek-tm4c123gxl
- 1
- 0
- 0
- 0
-
- 2
- 7
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
- system_TM4C123GH6PM.c
- 0
- 0
-
-
- 2
- 8
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
- TM4C123GH6PM.h
- 0
- 0
-
-
- 2
- 9
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
- startup_TM4C123GH6PM.s
- 0
- 0
-
-
- 2
- 10
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
- gpio.h
- 0
- 0
-
-
- 2
- 11
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
- rom.h
- 0
- 0
-
-
- 2
- 12
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
- sysctl.h
- 0
- 0
-
-
- 2
- 13
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
- system_TM4C123GH6PM.h
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qv\qv.cpp
- qv.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
- qv_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.uvprojx b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.uvprojx
deleted file mode 100644
index 2f389e38f..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/armclang/dpp-qv.uvprojx
+++ /dev/null
@@ -1,1823 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- dpp-qv
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\dpp-qv.bin .\dbg\dpp-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 1
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
-
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\dpp-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- dpp-qv
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\dpp-qv.bin .\rel\dpp-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- NDEBUG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\dpp-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- dpp-qv
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\dpp-qv.bin .\spy\dpp-qv.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4096
-
- 1
- BIN\UL2CM3.DLL
- "" ()
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 2
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- Q_SPY
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qv\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\dpp-qv.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qv.cpp
- 8
- ..\..\..\..\..\src\qv\qv.cpp
-
-
-
-
- QP_port
-
-
- qv_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qv\armclang\qv_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/bsp.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/bsp.cpp
deleted file mode 100644
index fe7c45396..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/bsp.cpp
+++ /dev/null
@@ -1,537 +0,0 @@
-//============================================================================
-// Product: DPP example, EK-TM4C123GXL board, QV kernel
-// Last updated for version 7.3.2
-// Last updated on 2023-12-13
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "TM4C123GH6PM.h" // the device specific header (TI)
-#include "rom.h" // the built-in ROM functions (TI)
-#include "sysctl.h" // system control driver (TI)
-#include "gpio.h" // GPIO driver (TI)
-// add other drivers if necessary...
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr std::uint32_t LED_RED {1U << 1U};
-constexpr std::uint32_t LED_GREEN {1U << 3U};
-constexpr std::uint32_t LED_BLUE {1U << 2U};
-
-constexpr std::uint32_t BTN_SW1 {1U << 4U};
-constexpr std::uint32_t BTN_SW2 {1U << 0U};
-
-static std::uint32_t l_rndSeed;
-
-#ifdef Q_SPY
-
- // QSpy source IDs
- QP::QSpyId const l_SysTick_Handler = { 0U };
- QP::QSpyId const l_GPIOPortA_IRQHandler = { 0U };
-
- constexpr std::uint32_t UART_BAUD_RATE {115200U};
- constexpr std::uint32_t UART_FR_TXFE {1U << 7U};
- constexpr std::uint32_t UART_FR_RXFE {1U << 4U};
- constexpr std::uint32_t UART_TXFIFO_DEPTH {16U};
-
- enum AppRecords { // application-specific trace records
- PHILO_STAT = QP::QS_USER,
- PAUSED_STAT,
- CONTEXT_SW,
- };
-
-#endif
-
-} // unnamed namespace
-
-//============================================================================
-// Error handler and ISRs...
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the error handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up all LEDs
- GPIOF_AHB->DATA_Bits[LED_GREEN | LED_RED | LED_BLUE] = 0xFFU;
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#else
- NVIC_SystemReset();
- for (;;) { // explicitly "no-return"
- }
-#endif
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
-
- QP::QTimeEvt::TICK_X(0U, &l_SysTick_Handler); // time events at rate 0
-
- // Perform the debouncing of buttons. The algorithm for debouncing
- // adapted from the book "Embedded Systems Dictionary" by Jack Ganssle
- // and Michael Barr, page 71.
- static struct {
- std::uint32_t depressed;
- std::uint32_t previous;
- } buttons = { 0U, 0U };
-
- std::uint32_t current = ~GPIOF_AHB->DATA_Bits[BTN_SW1 | BTN_SW2];
- std::uint32_t tmp = buttons.depressed; // save the depressed buttons
- buttons.depressed |= (buttons.previous & current); // set depressed
- buttons.depressed &= (buttons.previous | current); // clear released
- buttons.previous = current; // update the history
- tmp ^= buttons.depressed; // changed debounced depressed
- current = buttons.depressed;
-
- if ((tmp & BTN_SW1) != 0U) { // debounced SW1 state changed?
- if ((current & BTN_SW1) != 0U) { // is SW1 depressed?
- static QP::QEvt const pauseEvt(APP::PAUSE_SIG);
- QP::QActive::PUBLISH(&pauseEvt, &l_SysTick_Handler);
- }
- else { // the button is released
- static QP::QEvt const serveEvt(APP::SERVE_SIG);
- QP::QActive::PUBLISH(&serveEvt, &l_SysTick_Handler);
- }
- }
-
- QV_ARM_ERRATUM_838869();
-}
-//............................................................................
-// interrupt handler for testing preemptions
-void GPIOPortA_IRQHandler(void); // prototype
-void GPIOPortA_IRQHandler(void) {
-
- APP::AO_Table->POST(Q_NEW(QP::QEvt, APP::MAX_PUB_SIG),
- &l_GPIOPortA_IRQHandler);
-
- QV_ARM_ERRATUM_838869();
-}
-
-//............................................................................
-#ifdef Q_SPY
-// ISR for receiving bytes from the QSPY Back-End
-// NOTE: This ISR is "QF-unaware" meaning that it does not interact with
-// the QF/QV and is not disabled. Such ISRs cannot post or publish events.
-
-void UART0_IRQHandler(void); // prototype
-void UART0_IRQHandler(void) {
- uint32_t status = UART0->RIS; // get the raw interrupt status
- UART0->ICR = status; // clear the asserted interrupts
-
- while ((UART0->FR & UART_FR_RXFE) == 0U) { // while RX FIFO NOT empty
- std::uint8_t b = static_cast(UART0->DR);
- QP::QS::rxPut(b);
- }
-
- QV_ARM_ERRATUM_838869();
-}
-#endif // Q_SPY
-
-//............................................................................
-#ifdef QF_ON_CONTEXT_SW
-// NOTE: the context-switch callback is called with interrupts DISABLED
-void QF_onContextSw(QP::QActive *prev, QP::QActive *next) {
- QS_BEGIN_INCRIT(CONTEXT_SW, 0U) // in critical section!
- QS_OBJ(prev);
- QS_OBJ(next);
- QS_END_INCRIT()
-}
-#endif // QF_ON_CONTEXT_SW
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QV
-
- // enable clock for to the peripherals used by this application...
- SYSCTL->RCGCGPIO |= (1U << 5U); // enable Run mode for GPIOF
- SYSCTL->GPIOHBCTL |= (1U << 5U); // enable AHB for GPIOF
- __ISB();
- __DSB();
-
- // configure LEDs (digital output)
- GPIOF_AHB->DIR |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DEN |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DATA_Bits[LED_RED | LED_BLUE | LED_GREEN] = 0U;
-
- // configure switches...
-
- // unlock access to the SW2 pin because it is PROTECTED
- GPIOF_AHB->LOCK = 0x4C4F434BU; // unlock GPIOCR register for SW2
- // commit the write (cast const away)
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x01U;
-
- GPIOF_AHB->DIR &= ~(BTN_SW1 | BTN_SW2); // input
- GPIOF_AHB->DEN |= (BTN_SW1 | BTN_SW2); // digital enable
- GPIOF_AHB->PUR |= (BTN_SW1 | BTN_SW2); // pull-up resistor enable
-
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x00U;
- GPIOF_AHB->LOCK = 0x0; // lock GPIOCR register for SW2
-
- BSP::randomSeed(1234U);
-
- // initialize the QS software tracing...
- if (!QS_INIT(nullptr)) {
- Q_ERROR();
- }
-
- // dictionaries...
- QS_OBJ_DICTIONARY(&l_SysTick_Handler);
- QS_OBJ_DICTIONARY(&l_GPIOPortA_IRQHandler);
- QS_USR_DICTIONARY(PHILO_STAT);
- QS_USR_DICTIONARY(PAUSED_STAT);
- QS_USR_DICTIONARY(CONTEXT_SW);
-
- QS_ONLY(APP::produce_sig_dict());
-
- // setup the QS filters...
- QS_GLB_FILTER(QP::QS_ALL_RECORDS); // all records
- QS_GLB_FILTER(-QP::QS_QF_TICK); // exclude the clock tick
- QS_LOC_FILTER(-(APP::N_PHILO + 3U)); // exclude prio. of AO_Ticker0
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(APP::TableEvt) smlPoolSto[2*APP::N_PHILO];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // start AOs/threads...
- static QP::QEvt const *philoQueueSto[APP::N_PHILO][APP::N_PHILO];
- for (std::uint8_t n = 0U; n < APP::N_PHILO; ++n) {
- APP::AO_Philo[n]->start(
- n + 3U, // QF-prio/pthre. see NOTE1
- philoQueueSto[n], // event queue storage
- Q_DIM(philoQueueSto[n]), // queue length [events]
- nullptr, 0U); // no stack storage
- }
-
- static QP::QEvt const *tableQueueSto[APP::N_PHILO];
- APP::AO_Table->start(
- APP::N_PHILO + 7U, // QP prio. of the AO
- tableQueueSto, // event queue storage
- Q_DIM(tableQueueSto), // queue length [events]
- nullptr, 0U); // no stack storage
-}
-//............................................................................
-void displayPhilStat(std::uint8_t n, char const *stat) {
- Q_UNUSED_PAR(n);
-
- GPIOF_AHB->DATA_Bits[LED_GREEN] = ((stat[0] == 'e') ? LED_GREEN : 0U);
-
- // app-specific trace record...
- QS_BEGIN_ID(PHILO_STAT, APP::AO_Table->getPrio())
- QS_U8(1, n); // Philosopher number
- QS_STR(stat); // Philosopher status
- QS_END()
-}
-//............................................................................
-void displayPaused(std::uint8_t const paused) {
- GPIOF_AHB->DATA_Bits[LED_BLUE] = ((paused != 0U) ? LED_BLUE : 0U);
-
- // application-specific trace record
- QS_BEGIN_ID(PAUSED_STAT, APP::AO_Table->getPrio())
- QS_U8(1, paused); // Paused status
- QS_END()
-}
-//............................................................................
-void randomSeed(uint32_t const seed) {
- l_rndSeed = seed;
-}
-//............................................................................
-std::uint32_t random() { // a very cheap pseudo-random-number generator
- // Some floating point code is to exercise the VFP...
- float volatile x = 3.1415926F;
- x = x + 2.7182818F;
-
- // NOTE: no need to protect shared 'l_rndSeed' in the QV kernel
-
- // "Super-Duper" Linear Congruential Generator (LCG)
- // LCG(2^32, 3*7*11*13*23, 0, seed)
- std::uint32_t rnd = l_rndSeed * (3U*7U*11U*13U*23U);
- l_rndSeed = rnd; // set for the next time
-
- return (rnd >> 8U);
-}
-//............................................................................
-void ledOn() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0xFFU;
-}
-//............................................................................
-void ledOff() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0x00U;
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-// namespace QP
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(UART0_IRQn, 0U); // kernel unaware interrupt
- NVIC_SetPriority(GPIOA_IRQn, QF_AWARE_ISR_CMSIS_PRI + 0U);
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
- NVIC_EnableIRQ(GPIOA_IRQn);
-
-#ifdef Q_SPY
- NVIC_EnableIRQ(UART0_IRQn); // UART interrupt used for QS-RX
-#endif
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QV::onIdle() { // CAUTION: called with interrupts DISABLED, see NOTE0
- // toggle the User LED on and then off, see NOTE3
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0xFFU; // turn the Blue LED on
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0U; // turn the Blue LED off
-
-#ifdef Q_SPY
- // intgerrupts still disabled
- QS::rxParse(); // parse all the received bytes
- QF_INT_ENABLE();
-
- if ((UART0->FR & UART_FR_TXFE) != 0U) { // TX done?
- std::uint16_t fifo = UART_TXFIFO_DEPTH; // max bytes we can accept
-
- QF_INT_DISABLE();
- std::uint8_t const *block = QS::getBlock(&fifo);
- QF_INT_ENABLE();
-
- while (fifo-- != 0U) { // any bytes in the block?
- UART0->DR = *block++; // put into the FIFO
- }
- }
-#elif defined NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- QV_CPU_SLEEP(); // atomically go to sleep and enable interrupts
-#else
- QF_INT_ENABLE(); // just enable interrupts
-#endif
-}
-
-//============================================================================
-// QS callbacks...
-#ifdef Q_SPY
-namespace QS {
-
-//............................................................................
-bool onStartup(void const *arg) {
- Q_UNUSED_PAR(arg);
-
- static std::uint8_t qsTxBuf[2*1024]; // buffer for QS-TX channel
- initBuf(qsTxBuf, sizeof(qsTxBuf));
-
- static std::uint8_t qsRxBuf[100]; // buffer for QS-RX channel
- rxInitBuf(qsRxBuf, sizeof(qsRxBuf));
-
- // enable clock for UART0 and GPIOA (used by UART0 pins)
- SYSCTL->RCGCUART |= (1U << 0U); // enable Run mode for UART0
- SYSCTL->RCGCGPIO |= (1U << 0U); // enable Run mode for GPIOA
-
- // configure UART0 pins for UART operation
- uint32_t tmp = (1U << 0U) | (1U << 1U);
- GPIOA->DIR &= ~tmp;
- GPIOA->SLR &= ~tmp;
- GPIOA->ODR &= ~tmp;
- GPIOA->PUR &= ~tmp;
- GPIOA->PDR &= ~tmp;
- GPIOA->AMSEL &= ~tmp; // disable analog function on the pins
- GPIOA->AFSEL |= tmp; // enable ALT function on the pins
- GPIOA->DEN |= tmp; // enable digital I/O on the pins
- GPIOA->PCTL &= ~0x00U;
- GPIOA->PCTL |= 0x11U;
-
- // configure the UART for the desired baud rate, 8-N-1 operation
- tmp = (((SystemCoreClock * 8U) / UART_BAUD_RATE) + 1U) / 2U;
- UART0->IBRD = tmp / 64U;
- UART0->FBRD = tmp % 64U;
- UART0->LCRH = (0x3U << 5U); // configure 8-N-1 operation
- UART0->LCRH |= (0x1U << 4U); // enable FIFOs
- UART0->CTL = (1U << 0U) // UART enable
- | (1U << 8U) // UART TX enable
- | (1U << 9U); // UART RX enable
-
- // configure UART interrupts (for the RX channel)
- UART0->IM |= (1U << 4U) | (1U << 6U); // enable RX and RX-TO interrupt
- UART0->IFLS |= (0x2U << 2U); // interrupt on RX FIFO half-full
- // NOTE: do not enable the UART0 interrupt yet. Wait till QF_onStartup()
-
- // configure TIMER5 to produce QS time stamp
- SYSCTL->RCGCTIMER |= (1U << 5U); // enable run mode for Timer5
- TIMER5->CTL = 0U; // disable Timer1 output
- TIMER5->CFG = 0x0U; // 32-bit configuration
- TIMER5->TAMR = (1U << 4U) | 0x02U; // up-counting periodic mode
- TIMER5->TAILR= 0xFFFFFFFFU; // timer interval
- TIMER5->ICR = 0x1U; // TimerA timeout flag bit clears
- TIMER5->CTL |= (1U << 0U); // enable TimerA module
-
- return true; // return success
-}
-//............................................................................
-void onCleanup() {
-}
-//............................................................................
-QSTimeCtr onGetTime() { // NOTE: invoked with interrupts DISABLED
- return TIMER5->TAV;
-}
-//............................................................................
-// NOTE:
-// No critical section in QS::onFlush() to avoid nesting of critical sections
-// in case QS::onFlush() is called from Q_onError().
-void onFlush() {
- for (;;) {
- std::uint16_t b = getByte();
- if (b != QS_EOD) {
- while ((UART0->FR & UART_FR_TXFE) == 0U) { // while TXE not empty
- }
- UART0->DR = b; // put into the DR register
- }
- else {
- break;
- }
- }
-}
-//............................................................................
-//! callback function to reset the target (to be implemented in the BSP)
-void onReset() {
- NVIC_SystemReset();
-}
-//............................................................................
-// callback function to execute a user command
-void onCommand(std::uint8_t cmdId, std::uint32_t param1,
- std::uint32_t param2, std::uint32_t param3)
-{
- Q_UNUSED_PAR(cmdId);
- Q_UNUSED_PAR(param1);
- Q_UNUSED_PAR(param2);
- Q_UNUSED_PAR(param3);
-}
-
-} // namespace QS
-#endif // Q_SPY
-//----------------------------------------------------------------------------
-
-} // namespace QP
-
-//============================================================================
-// NOTE0:
-// The QV:onIdle() callback is called with interrupts disabled, because the
-// determination of the idle condition might change by any interrupt posting
-// an event. QV::onIdle() must internally enable interrupts, ideally
-// atomically with putting the CPU to the power-saving mode.
-//
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call any QF/QK services. These ISRs
-// are "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QK services. In particular they
-// can NOT call the macros QK_ISR_ENTRY/QK_ISR_ENTRY. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.ccsproject b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.ccsproject
deleted file mode 100644
index e057df002..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.ccsproject
+++ /dev/null
@@ -1,5 +0,0 @@
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.cproject b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.cproject
deleted file mode 100644
index cee30abac..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.cproject
+++ /dev/null
@@ -1,318 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.project b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.project
deleted file mode 100644
index ad4e29a95..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/.project
+++ /dev/null
@@ -1,100 +0,0 @@
-
-
- dpp-qv
-
-
-
-
-
- org.eclipse.cdt.managedbuilder.core.genmakebuilder
-
-
-
-
- org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder
- full,incremental,
-
-
-
-
-
- com.ti.ccstudio.core.ccsNature
- org.eclipse.cdt.core.cnature
- org.eclipse.cdt.managedbuilder.core.managedBuildNature
- org.eclipse.cdt.core.ccnature
- org.eclipse.cdt.managedbuilder.core.ScannerConfigNature
-
-
-
- QV
- 2
- PARENT-5-PROJECT_LOC/src/qv
-
-
- QP
- 2
- PARENT-5-PROJECT_LOC/src/qf
-
-
- QP_port
- 2
- PARENT-5-PROJECT_LOC/ports/arm-cm/qv/gnu
-
-
- QS
- 2
- PARENT-5-PROJECT_LOC/src/qs
-
-
- TM4C123GH6PM.h
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/TM4C123GH6PM.h
-
-
- bsp.cpp
- 1
- PARENT-1-PROJECT_LOC/bsp.cpp
-
-
- main.cpp
- 1
- PARENT-2-PROJECT_LOC/main.cpp
-
-
- philo.cpp
- 1
- PARENT-2-PROJECT_LOC/philo.cpp
-
-
- qp_config.hpp
- 1
- PARENT-2-PROJECT_LOC/qp_config.hpp
-
-
- startup_TM4C123GH6PM.c
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/gnu/startup_TM4C123GH6PM.c
-
-
- system_TM4C123GH6PM.c
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/system_TM4C123GH6PM.c
-
-
- system_TM4C123GH6PM.h
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/system_TM4C123GH6PM.h
-
-
- table.cpp
- 1
- PARENT-2-PROJECT_LOC/table.cpp
-
-
-
-
- CG_TOOL_GPP
- $%7BCG_TOOL_ROOT%7D/bin/arm-none-eabi-g++
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/Makefile b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/Makefile
deleted file mode 100644
index 8b4533de5..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/Makefile
+++ /dev/null
@@ -1,310 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EK-TM4C123GXL, QV kernel, GNU-ARM
-# Last Updated for Version: 7.3.3
-# Date of the Last Update: 2024-01-29
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := dpp-qv
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qv/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qv \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/ek-tm4c123gxl \
- $(QPCPP)/3rd_party/ek-tm4c123gxl/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/ek-tm4c123gxl
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_TM4C123GH6PM.c \
- startup_TM4C123GH6PM.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- philo.cpp \
- table.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qv.cpp \
- qv_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DQP_CONFIG
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=fpv4-sp-d16
-FLOAT_ABI := -mfloat-abi=hard
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically you should not need to change anything below this line
-
-# basic utilities (included in QTools for Windows), see:
-# https://www.state-machine.com/qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-.PHONY : clean show
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/README.txt
deleted file mode 100644
index ab8e99e8f..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/README.txt
+++ /dev/null
@@ -1,79 +0,0 @@
-About this Example
-==================
-This example can be built in two different ways:
-- from the command prompt with the provided Makefile.
-- from the TI Code Composer Studio with the provided CCS project.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-The CCS Project
-===============
-This directory contains also the CCS project which can be imported to the
-CCS (Code Composer Studio) IDE based on Eclipse. To import the project,
-use the section "General -> Existing Project into Workspace" and select this
-directory as the "root directory". For example, the "Select root directory"
-might be: C:\qp-dev\qpc\examples\arm-cm\dpp_ek-tm4c123gxl\qxk\gnu
-
-Once you press "Browse", the project (dpp-qk, dpp-qv, or dpp-qxk) should
-become visible. Click on "Select All" and then "Finish".
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\gcc\startup_TM4C123GH6PM.c
-
-The file startup_TM4C123GH6PM.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/dpp-qv.ld b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/dpp-qv.ld
deleted file mode 100644
index 5139ce62b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/dpp-qv.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EK-TM4C123GXL, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* Web : http://www.state-machine.com
-* Email: info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Tiva TM4C123GH6PM */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/flash.bat b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/flash.bat
deleted file mode 100644
index cb2a3886e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/gnu/flash.bat
+++ /dev/null
@@ -1,33 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EK-TM4C123GXL
-::
-:: NOTE: requires the LMFlash programmer (included in QTools for Windows)
-::
-@echo off
-setlocal
-
-@echo Load a given binary file to the flash of EK-TM4C123GXL
-@echo usage: flash binary-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: The following symbol LMFLASH assumes that LMFlash.exe can
-:: be found on the PATH. You might need to adjust this symbol to the
-:: location of the LMFlash utility on your machine
-::
-set LMFLASH=LMFlash.exe
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-%LMFLASH% -q ek-tm4c123gxl -e -v -r %1
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/README.txt
deleted file mode 100644
index b4203fb7b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-------------
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.ewd b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.ewd
deleted file mode 100644
index 143fc5398..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.ewp b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.ewp
deleted file mode 100644
index f790d766c..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.ewp
+++ /dev/null
@@ -1,3347 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 1
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 1
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\dpp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
- $PROJ_DIR$\..\..\philo.cpp
-
-
- $PROJ_DIR$\..\..\table.cpp
-
-
-
- ek-tm4c123gxl
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qv\qv.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qv\iar\qv_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.eww b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.eww
deleted file mode 100644
index b96f3f620..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\dpp-qv.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.icf b/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.icf
deleted file mode 100644
index c6b24e1c6..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qv/iar/dpp-qv.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK }; /* <== Quantum Leaps */
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/dpp.py b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/dpp.py
deleted file mode 100644
index b0ea9f830..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/dpp.py
+++ /dev/null
@@ -1,103 +0,0 @@
-# This is an example of QView customization for a specific application
-# (DPP in this case). This example animates the Phil images on the
-# QView canvas. Additionally, there is a button in the middle of the screen,
-# which, when clicked once pauses the DPP ("forks" are not being served).
-# A second click on the button, "un-pauses" the DPP ("forks" are served
-# to all hungry Philosophers).
-#
-# This version of the DPP customization uses the application-specific
-# packet QS_USER_00 (PHILO_STAT) produced when the status of a Philo changes.
-#
-
-class DPP:
- def __init__(self):
-
- # add commands to the Custom menu...
- QView.custom_menu.add_command(label="Custom command",
- command=self.cust_command)
-
- # configure the custom QView.canvas...
- QView.show_canvas() # make the canvas visible
- QView.canvas.configure(width=400, height=260)
-
- # tuple of activity images (correspond to self._philo_state)
- self._act_img = (
- PhotoImage(file=HOME_DIR + "/img/thinking.gif"),
- PhotoImage(file=HOME_DIR + "/img/hungry.gif"),
- PhotoImage(file=HOME_DIR + "/img/eating.gif"),
- )
- # tuple of philo canvas images (correspond to self._philo_obj)
- self._philo_img = (\
- QView.canvas.create_image(190, 57, image=self._act_img[0]),
- QView.canvas.create_image(273, 100, image=self._act_img[0]),
- QView.canvas.create_image(237, 185, image=self._act_img[0]),
- QView.canvas.create_image(146, 185, image=self._act_img[0]),
- QView.canvas.create_image(107, 100, image=self._act_img[0])
- )
-
- # button images for UP and DOWN
- self.img_UP = PhotoImage(file=HOME_DIR + "/img/BTN_UP.gif")
- self.img_DWN = PhotoImage(file=HOME_DIR + "/img/BTN_DWN.gif")
-
- # images of a button for pause/serve
- self.btn = QView.canvas.create_image(200, 120, image=self.img_UP)
- QView.canvas.tag_bind(self.btn, "", self.cust_pause)
-
- # request target reset on startup...
- # NOTE: Normally, for an embedded application you would like
- # to start with resetting the Target, to start clean with
- # Qs dictionaries, etc.
- reset_target()
-
- # on_reset() callback
- def on_reset(self):
- # clear the lists
- self._philo_obj = [0, 0, 0, 0, 0]
- self._philo_state = [0, 0, 0]
-
- # on_run() callback
- def on_run(self):
- glb_filter("QS_USER_00")
-
- # NOTE: the name of object for current_obj() must match the
- # QS Object Dictionaries produced by the application.
- current_obj(OBJ_AO, "Table::inst")
-
- # turn lists into tuples for better performance
- self._philo_obj = tuple(self._philo_obj)
- self._philo_state = tuple(self._philo_state)
-
-
- # example of a custom command
- def cust_command(self):
- command(1, 12345)
-
- # example of a custom interaction with a canvas object (pause/serve)
- def cust_pause(self, event):
- if QView.canvas.itemcget(self.btn, "image") != str(self.img_UP):
- QView.canvas.itemconfig(self.btn, image=self.img_UP)
- post("SERVE_SIG")
- QView.print_text("Table SERVING")
- else:
- QView.canvas.itemconfig(self.btn, image=self.img_DWN)
- post("PAUSE_SIG")
- QView.print_text("Table PAUSED")
-
- # intercept the QS_USER_00 application-specific packet
- # this packet has the following structure (see bsp.c:displayPhilStat()):
- # record-ID, seq-num, Timestamp, format-byte, Philo-num,
- # format-bye, Zero-terminated string (status)
- def QS_USER_00(self, packet):
- # unpack: Timestamp->data[0], Philo-num->data[1], status->data[3]
- data = qunpack("xxTxBxZ", packet)
- i = data[1]
- j = ("t", "h", "e").index(data[2][0]) # the first letter
-
- # animate the given philo image according to its activity
- QView.canvas.itemconfig(self._philo_img[i], image=self._act_img[j])
-
- # print a message to the text view
- QView.print_text("%010d Philo %1d is %s"%(data[0], i, data[2]))
-
-#=============================================================================
-QView.customize(DPP()) # set the QView customization
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/dpp1.py b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/dpp1.py
deleted file mode 100644
index 20d0412c8..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/dpp1.py
+++ /dev/null
@@ -1,147 +0,0 @@
-# This is an example of QView customization for a specific application
-# (DPP in this case). This example animates the Phil images on the
-# QView canvas. Additionally, there is a button in the middle of the screen,
-# which, when clicked once pauses the DPP ("forks" are not being served).
-# A second click on the button, "un-pauses" the DPP ("forks" are served
-# to all hungry Philosophers).
-#
-# This version of the DPP customization uses the standard QS_QEP_STATE_ENTRY
-# packet, which provides information about the current states of the dining
-# Philosophers. The example also demonstrates how to intercept the QS
-# "dictionary" records QS_OBJ_DICT and QS_FUN_DICT to extract the information
-# about the addresses of the Philosopher objects and the states of their
-# state machines.
-#
-
-class DPP:
- def __init__(self):
-
- # add commands to the Custom menu...
- QView.custom_menu.add_command(label="Custom command",
- command=self.cust_command)
-
- # configure the custom QView.canvas...
- QView.show_canvas() # make the canvas visible
- QView.canvas.configure(width=400, height=260)
-
- # tuple of activity images (correspond to self._philo_state)
- self._act_img = (
- PhotoImage(file=HOME_DIR + "/img/thinking.gif"),
- PhotoImage(file=HOME_DIR + "/img/hungry.gif"),
- PhotoImage(file=HOME_DIR + "/img/eating.gif"),
- )
- # tuple of philo canvas images (correspond to self._philo_obj)
- self._philo_img = (\
- QView.canvas.create_image(190, 57, image=self._act_img[0]),
- QView.canvas.create_image(273, 100, image=self._act_img[0]),
- QView.canvas.create_image(237, 185, image=self._act_img[0]),
- QView.canvas.create_image(146, 185, image=self._act_img[0]),
- QView.canvas.create_image(107, 100, image=self._act_img[0])
- )
-
- # button images for UP and DOWN
- self.img_UP = PhotoImage(file=HOME_DIR + "/img/BTN_UP.gif")
- self.img_DWN = PhotoImage(file=HOME_DIR + "/img/BTN_DWN.gif")
-
- # images of a button for pause/serve
- self.btn = QView.canvas.create_image(200, 120, image=self.img_UP)
- QView.canvas.tag_bind(self.btn, "", self.cust_pause)
-
- # request target reset on startup...
- # NOTE: Normally, for an embedded application you would like
- # to start with resetting the Target, to start clean with
- # Qs dictionaries, etc.
- reset_target()
-
- # on_reset() callback invoked when Target-reset packet is received
- # NOTE: the QS dictionaries are not known at this time yet, so
- # this callback shouild generally not set filters or current objects
- def on_reset(self):
- # (re)set the lists
- self._philo_obj = [0, 0, 0, 0, 0]
- self._philo_state = [0, 0, 0]
-
- # on_run() callback invoked when the QF_RUN packet is received
- # NOTE: the QS dictionaries are typically known at this time yet, so
- # this callback can set filters or current objects
- def on_run(self):
- glb_filter("QS_QEP_TRAN")
-
- # NOTE: the name of object for current_obj() must match the
- # QS Object Dictionaries produced by the application.
- current_obj(OBJ_AO, "Table::inst")
-
- # turn lists into tuples for better performance
- self._philo_obj = tuple(self._philo_obj)
- self._philo_state = tuple(self._philo_state)
-
-
- # example of a custom command
- def cust_command(self):
- command(1, 12345)
-
- # example of a custom interaction with a canvas object (pause/serve)
- def cust_pause(self, event):
- if QView.canvas.itemcget(self.btn, "image") != str(self.img_UP):
- QView.canvas.itemconfig(self.btn, image=self.img_UP)
- post("SERVE_SIG")
- QView.print_text("Table SERVING")
- else:
- QView.canvas.itemconfig(self.btn, image=self.img_DWN)
- post("PAUSE_SIG")
- QView.print_text("Table PAUSED")
-
- # intercept the QS_OBJ_DICT stadard packet
- # this packet has the following structure:
- # record-ID, seq-num, Object-ptr, Zero-terminated string
- def QS_OBJ_DICT(self, packet):
- data = qunpack("xxOZ", packet)
- try:
- # NOTE: the names of objects must match the QS Object Dictionaries
- # produced by the application.
- i = ("Philo::inst[0]",
- "Philo::inst[1]",
- "Philo::inst[2]",
- "Philo::inst[3]",
- "Philo::inst[4]").index(data[1])
- self._philo_obj[i] = data[0]
- except:
- pass # dictionary for a different object
-
- # intercept the QS_FUN_DICT stadard packet
- # this packet has the following structure:
- # record-ID, seq-num, Function-ptr, Zero-terminated string
- def QS_FUN_DICT(self, packet):
- data = qunpack("xxFZ", packet)
- try:
- # NOTE: the names of states must match the QS Object Dictionaries
- # produced by the application.
- j = ("Philo::thinking",
- "Philo::hungry",
- "Philo::eating").index(data[1])
- self._philo_state[j] = data[0]
- except:
- pass # dictionary for a different state
-
- # intercept the QS_QEP_TRAN stadard packet
- # this packet has the following structure:
- # record-ID, seq-num, Timestamp, Signal, Object-ptr,
- # Function-ptr (source state), Function-ptr (new active state)
- def QS_QEP_TRAN(self, packet):
- data = qunpack("xxTSOFF", packet)
- try:
- i = self._philo_obj.index(data[2])
- j = self._philo_state.index(data[4])
-
- # animate the given philo image according to its activity
- QView.canvas.itemconfig(self._philo_img[i],
- image=self._act_img[j])
- # print a message to the text view
- QView.print_text("%010d Philo %d is %s"\
- %(data[0], i, ("thinking", "hungry", "eating")[j]))
- except:
- pass # state-entry in a different object
-
-#=============================================================================
-# instantiate the DPP class and set it as the QView customization
-QView.customize(DPP())
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/BTN_DWN.gif b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/BTN_DWN.gif
deleted file mode 100644
index 36d8c7907..000000000
Binary files a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/BTN_DWN.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/BTN_UP.gif b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/BTN_UP.gif
deleted file mode 100644
index 3246ff982..000000000
Binary files a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/BTN_UP.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/eating.gif b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/eating.gif
deleted file mode 100644
index 632b9d23a..000000000
Binary files a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/eating.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/hungry.gif b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/hungry.gif
deleted file mode 100644
index dc144db97..000000000
Binary files a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/hungry.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/thinking.gif b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/thinking.gif
deleted file mode 100644
index ec684ee5a..000000000
Binary files a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/img/thinking.gif and /dev/null differ
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/qview-dpp.bat b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/qview-dpp.bat
deleted file mode 100644
index b36e43d6b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/qview-dpp.bat
+++ /dev/null
@@ -1,8 +0,0 @@
-@setlocal
-
-if "%QTOOLS%"=="" (
- set QTOOLS=C:\qp\qtools
-)
-python3 %QTOOLS%\qview\qview.py dpp.py
-
-@endlocal
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/qview-dpp1.bat b/examples/arm-cm/dpp_ek-tm4c123gxl/qview/qview-dpp1.bat
deleted file mode 100644
index 8bdb9ce53..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qview/qview-dpp1.bat
+++ /dev/null
@@ -1,8 +0,0 @@
-@setlocal
-
-if "%QTOOLS%"=="" (
- set QTOOLS=C:\qp\qtools
-)
-python3 %QTOOLS%\qview\qview.py dpp1.py
-
-@endlocal
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/README.txt
deleted file mode 100644
index 03fe7046e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/README.txt
+++ /dev/null
@@ -1,60 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the uVision IDE together with
-the MDK-ARM toolchain.
-
-***
-NOTE: This example requires installing the following Software Pack
-in the Keil uVision: Keil::TM4C_DFP.
-***
-
-
-uVision Project File
-====================
-The MDK-ARM uVision project file provided with this example uses
-relative paths to the QP/C framework location (includes, port, and
-libraries. These relative paths must be modified when the project
-is moved to different relative location.
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the
-command-line options for the ARM assembler (see the Asm tab in
-the "Options for Target" dialog box in uVision). Specifically,
-you should define symbols: Stack_Size=xxx Heap_Size=yyy, where
-xxx represents a numerical value of stack size and yyy the
-numerical value of the heap size.
-
-***
-NOTE:
-C++ programs seem not to tolerate heap size of 0. Therefore it is
-recommended to set the Heap_Size symbol to a minimal value of 16.
-***
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
-
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.sct b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.sct
deleted file mode 100644
index fda39c74a..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Modified by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00040000 { ; load region size_region
- ER_IROM1 0x00000000 0x00040000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: 2048 assumeed STACK size!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.uvoptx b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.uvoptx
deleted file mode 100644
index a1b48444b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.uvoptx
+++ /dev/null
@@ -1,1118 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4623 -S4 -FO61
-
-
-
-
- 0
- 0
- 94
- 1
- 3368
- 0
- 0
- 0
- 0
- 0
- 1
- ..\bsp.cpp
-
- \\dpp_qxk\../bsp.cpp\94
-
-
- 1
- 0
- 264
- 1
- 19370
- 0
- 0
- 0
- 0
- 0
- 1
- ..\bsp.cpp
-
- \\dpp_qxk\../bsp.cpp\264
-
-
-
-
- 0
- 1
- TH_XThread1
-
-
-
-
- 1
- 2
- 0x200002a4
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- DLGUARM
- ÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÈ`»
-´ª¤ô
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\philo.cpp
- philo.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\..\table.cpp
- table.cpp
- 0
- 0
-
-
- 1
- 4
- 8
- 0
- 0
- 0
- ..\xthread1.cpp
- xthread1.cpp
- 0
- 0
-
-
- 1
- 5
- 8
- 0
- 0
- 0
- ..\xthread2.cpp
- xthread2.cpp
- 0
- 0
-
-
- 1
- 6
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
- 1
- 7
- 5
- 0
- 0
- 0
- ..\..\dpp.hpp
- dpp.hpp
- 0
- 0
-
-
- 1
- 8
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
- 1
- 9
- 5
- 0
- 0
- 0
- ..\..\qp_config.hpp
- qp_config.hpp
- 0
- 0
-
-
-
-
- ek-tm4c123gxl
- 1
- 0
- 0
- 0
-
- 2
- 10
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
- system_TM4C123GH6PM.c
- 0
- 0
-
-
- 2
- 11
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
- TM4C123GH6PM.h
- 0
- 0
-
-
- 2
- 12
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
- startup_TM4C123GH6PM.s
- 0
- 0
-
-
- 2
- 13
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
- gpio.h
- 0
- 0
-
-
- 2
- 14
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
- rom.h
- 0
- 0
-
-
- 2
- 15
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
- sysctl.h
- 0
- 0
-
-
- 2
- 16
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
- system_TM4C123GH6PM.h
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk.cpp
- qxk.cpp
- 0
- 0
-
-
- 3
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
- qxk_mutex.cpp
- 0
- 0
-
-
- 3
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
- qxk_sema.cpp
- 0
- 0
-
-
- 3
- 32
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
- qxk_xthr.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 33
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
- qxk_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 34
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 35
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_64bit.cpp
- qs_64bit.cpp
- 0
- 0
-
-
- 5
- 36
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 37
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 38
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.uvprojx b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.uvprojx
deleted file mode 100644
index cd9d609b2..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/armclang/dpp-qxk.uvprojx
+++ /dev/null
@@ -1,1931 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
- 6190000::V6.19::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- dpp-qxk
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\dpp-qxk.bin .\dbg\dpp-qxk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 1
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qxk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- .\dpp-qxk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- xthread1.cpp
- 8
- ..\xthread1.cpp
-
-
- xthread2.cpp
- 8
- ..\xthread2.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- qp_config.hpp
- 5
- ..\..\qp_config.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qxk.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk.cpp
-
-
- qxk_mutex.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- qxk_sema.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- qxk_xthr.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
-
- QP_port
-
-
- qxk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
- 6190000::V6.19::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- dpp-qxk
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\dpp-qxk.bin .\rel\dpp-qxk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 7
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
-
- NDEBUG,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qxk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 1
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qxk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- xthread1.cpp
- 8
- ..\xthread1.cpp
-
-
- xthread2.cpp
- 8
- ..\xthread2.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- qp_config.hpp
- 5
- ..\..\qp_config.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qxk.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk.cpp
-
-
- qxk_mutex.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- qxk_sema.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- qxk_xthr.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
-
- QP_port
-
-
- qxk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
- 6190000::V6.19::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- dpp-qxk
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\dpp-qxk.bin .\spy\dpp-qxk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 2
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -Wno-c++98-compat -Wno-non-virtual-dtor -Wno-padded
- Q_SPY,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qxk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 1
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
-
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- xthread1.cpp
- 8
- ..\xthread1.cpp
-
-
- xthread2.cpp
- 8
- ..\xthread2.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
- qp_config.hpp
- 5
- ..\..\qp_config.hpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qxk.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk.cpp
-
-
- qxk_mutex.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- qxk_sema.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- qxk_xthr.cpp
- 8
- ..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
-
- QP_port
-
-
- qxk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qxk\armclang\qxk_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_64bit.cpp
- 8
- ..\..\..\..\..\src\qs\qs_64bit.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/bsp.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/bsp.cpp
deleted file mode 100644
index 9543cf045..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/bsp.cpp
+++ /dev/null
@@ -1,556 +0,0 @@
-//============================================================================
-// Product: DPP example, EK-TM4C123GXL board, QXK kernel
-// Last updated for version 7.3.2
-// Last updated on 2023-12-13
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "TM4C123GH6PM.h" // the device specific header (TI)
-#include "rom.h" // the built-in ROM functions (TI)
-#include "sysctl.h" // system control driver (TI)
-#include "gpio.h" // GPIO driver (TI)
-// add other drivers if necessary...
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr std::uint32_t LED_RED {1U << 1U};
-constexpr std::uint32_t LED_GREEN {1U << 3U};
-constexpr std::uint32_t LED_BLUE {1U << 2U};
-
-constexpr std::uint32_t BTN_SW1 {1U << 4U};
-constexpr std::uint32_t BTN_SW2 {1U << 0U};
-
-static std::uint32_t l_rndSeed;
-
-#ifdef Q_SPY
-
- // QSpy source IDs
- QP::QSpyId const l_SysTick_Handler = { 0U };
- QP::QSpyId const l_GPIOPortA_IRQHandler = { 0U };
-
- constexpr std::uint32_t UART_BAUD_RATE {115200U};
- constexpr std::uint32_t UART_FR_TXFE {1U << 7U};
- constexpr std::uint32_t UART_FR_RXFE {1U << 4U};
- constexpr std::uint32_t UART_TXFIFO_DEPTH {16U};
-
- enum AppRecords { // application-specific trace records
- PHILO_STAT = QP::QS_USER,
- CONTEXT_SW,
- PAUSED_STAT,
- };
-
-#endif
-
-} // unnamed namespace
-
-//============================================================================
-// Error handler and ISRs...
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the error handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up all LEDs
- GPIOF_AHB->DATA_Bits[LED_GREEN | LED_RED | LED_BLUE] = 0xFFU;
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#else
- NVIC_SystemReset();
- for (;;) { // explicitly "no-return"
- }
-#endif
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QXK_ISR_ENTRY(); // inform QXK about entering an ISR
-
- QP::QTimeEvt::TICK_X(0U, &l_SysTick_Handler); // time events at rate 0
-
- // Perform the debouncing of buttons. The algorithm for debouncing
- // adapted from the book "Embedded Systems Dictionary" by Jack Ganssle
- // and Michael Barr, page 71.
- static struct {
- std::uint32_t depressed;
- std::uint32_t previous;
- } buttons = { 0U, 0U };
-
- std::uint32_t current = ~GPIOF_AHB->DATA_Bits[BTN_SW1 | BTN_SW2];
- std::uint32_t tmp = buttons.depressed; // save the depressed buttons
- buttons.depressed |= (buttons.previous & current); // set depressed
- buttons.depressed &= (buttons.previous | current); // clear released
- buttons.previous = current; // update the history
- tmp ^= buttons.depressed; // changed debounced depressed
- current = buttons.depressed;
-
- if ((tmp & BTN_SW1) != 0U) { // debounced SW1 state changed?
- if ((current & BTN_SW1) != 0U) { // is SW1 depressed?
- static QP::QEvt const pauseEvt(APP::PAUSE_SIG);
- QP::QActive::PUBLISH(&pauseEvt, &l_SysTick_Handler);
- }
- else { // the button is released
- static QP::QEvt const serveEvt(APP::SERVE_SIG);
- QP::QActive::PUBLISH(&serveEvt, &l_SysTick_Handler);
- }
- }
-
- QXK_ISR_EXIT(); // inform QXK about exiting an ISR
-}
-//............................................................................
-// interrupt handler for testing preemptions
-void GPIOPortA_IRQHandler(void); // prototype
-void GPIOPortA_IRQHandler(void) {
- QXK_ISR_ENTRY(); // inform QXK about entering an ISR
-
- static QP::QEvt const testEvt(APP::TEST_SIG);
- APP::AO_Table->POST(&testEvt, &l_GPIOPortA_IRQHandler);
-
- QXK_ISR_EXIT(); // inform QXK about exiting an ISR
-}
-
-//............................................................................
-#ifdef Q_SPY
-// ISR for receiving bytes from the QSPY Back-End
-// NOTE: This ISR is "QF-unaware" meaning that it does not interact with
-// the QF/QXK and is not disabled. Such ISRs don't need to call
-// QXK_ISR_ENTRY/QXK_ISR_EXIT and they cannot post or publish events.
-
-void UART0_IRQHandler(void); // prototype
-void UART0_IRQHandler(void) {
- uint32_t status = UART0->RIS; // get the raw interrupt status
- UART0->ICR = status; // clear the asserted interrupts
-
- while ((UART0->FR & UART_FR_RXFE) == 0U) { // while RX FIFO NOT empty
- std::uint8_t b = static_cast(UART0->DR);
- QP::QS::rxPut(b);
- }
-
- QXK_ARM_ERRATUM_838869();
-}
-#endif // Q_SPY
-
-//............................................................................
-#ifdef QF_ON_CONTEXT_SW
-// NOTE: the context-switch callback is called with interrupts DISABLED
-void QF_onContextSw(QP::QActive *prev, QP::QActive *next) {
- QS_BEGIN_INCRIT(CONTEXT_SW, 0U) // in critical section!
- QS_OBJ(prev);
- QS_OBJ(next);
- QS_END_INCRIT()
-}
-#endif // QF_ON_CONTEXT_SW
-
-} // extern "C"
-
-
-//============================================================================
-namespace BSP {
-
-void init() {
- // Configure the MPU to prevent NULL-pointer dereferencing ...
- MPU->RBAR = 0x0U // base address (NULL)
- | MPU_RBAR_VALID_Msk // valid region
- | (MPU_RBAR_REGION_Msk & 7U); // region #7
- MPU->RASR = (7U << MPU_RASR_SIZE_Pos) // 2^(7+1) region
- | (0x0U << MPU_RASR_AP_Pos) // no-access region
- | MPU_RASR_ENABLE_Msk; // region enable
- MPU->CTRL = MPU_CTRL_PRIVDEFENA_Msk // enable background region
- | MPU_CTRL_ENABLE_Msk; // enable the MPU
- __ISB();
- __DSB();
-
- // enable the MemManage_Handler for MPU exception
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QXK
-
- // enable clock for to the peripherals used by this application...
- SYSCTL->RCGCGPIO |= (1U << 5U); // enable Run mode for GPIOF
- SYSCTL->GPIOHBCTL |= (1U << 5U); // enable AHB for GPIOF
- __ISB();
- __DSB();
-
- // configure LEDs (digital output)
- GPIOF_AHB->DIR |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DEN |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DATA_Bits[LED_RED | LED_BLUE | LED_GREEN] = 0U;
-
- // configure switches...
-
- // unlock access to the SW2 pin because it is PROTECTED
- GPIOF_AHB->LOCK = 0x4C4F434BU; // unlock GPIOCR register for SW2
- // commit the write (cast const away)
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x01U;
-
- GPIOF_AHB->DIR &= ~(BTN_SW1 | BTN_SW2); // input
- GPIOF_AHB->DEN |= (BTN_SW1 | BTN_SW2); // digital enable
- GPIOF_AHB->PUR |= (BTN_SW1 | BTN_SW2); // pull-up resistor enable
-
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x00U;
- GPIOF_AHB->LOCK = 0x0; // lock GPIOCR register for SW2
-
- BSP::randomSeed(1234U);
-
- // initialize the QS software tracing...
- if (!QS_INIT(nullptr)) {
- Q_ERROR();
- }
-
- // dictionaries...
- QS_OBJ_DICTIONARY(&l_SysTick_Handler);
- QS_OBJ_DICTIONARY(&l_GPIOPortA_IRQHandler);
- QS_USR_DICTIONARY(PHILO_STAT);
- QS_USR_DICTIONARY(PAUSED_STAT);
- QS_USR_DICTIONARY(CONTEXT_SW);
-
- QS_ONLY(APP::produce_sig_dict());
-
- // setup the QS filters...
- QS_GLB_FILTER(QP::QS_ALL_RECORDS); // all records
- QS_GLB_FILTER(-QP::QS_QF_TICK); // exclude the clock tick
- QS_LOC_FILTER(-(APP::N_PHILO + 3U)); // exclude prio. of AO_Ticker0
-}
-//............................................................................
-void start() {
- // initialize event pools
- static QF_MPOOL_EL(APP::TableEvt) smlPoolSto[2*APP::N_PHILO];
- QP::QF::poolInit(smlPoolSto, sizeof(smlPoolSto), sizeof(smlPoolSto[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // start AOs/threads...
- static QP::QEvt const *xThread1QueueSto[5];
- static uint64_t xThread1StackSto[64];
- APP::TH_XThread1->start(
- 1U, // QP priority of the thread
- xThread1QueueSto, // event queue storage
- Q_DIM(xThread1QueueSto), // event length [events]
- &xThread1StackSto[0], // stack storage
- sizeof(xThread1StackSto)); // stack size [bytes]
-
- static QP::QEvt const *philoQueueSto[APP::N_PHILO][APP::N_PHILO];
- for (std::uint8_t n = 0U; n < APP::N_PHILO; ++n) {
- APP::AO_Philo[n]->start(
- n + 3U, // QF-prio/pthre. see NOTE1
- philoQueueSto[n], // event queue storage
- Q_DIM(philoQueueSto[n]), // queue length [events]
- nullptr, 0U); // no stack storage
- }
-
- static QP::QEvt const *xThread2QueueSto[5];
- static uint64_t xThread2StackSto[64];
- APP::TH_XThread2->start(
- APP::N_PHILO + 5U, // QP priority of the thread
- xThread2QueueSto, // event queue storage
- Q_DIM(xThread2QueueSto), // event length [events]
- &xThread2StackSto[0], // stack storage
- sizeof(xThread2StackSto)); // stack size [bytes]
-
- static QP::QEvt const *tableQueueSto[APP::N_PHILO];
- APP::AO_Table->start(
- APP::N_PHILO + 7U, // QP prio. of the AO
- tableQueueSto, // event queue storage
- Q_DIM(tableQueueSto), // queue length [events]
- nullptr, 0U); // no stack storage
-}
-//............................................................................
-void displayPhilStat(std::uint8_t n, char const *stat) {
- Q_UNUSED_PAR(n);
-
- GPIOF_AHB->DATA_Bits[LED_GREEN] = ((stat[0] == 'e') ? LED_GREEN : 0U);
-
- // app-specific trace record...
- QS_BEGIN_ID(PHILO_STAT, APP::AO_Table->getPrio())
- QS_U8(1, n); // Philosopher number
- QS_STR(stat); // Philosopher status
- QS_END()
-}
-//............................................................................
-void displayPaused(std::uint8_t const paused) {
- GPIOF_AHB->DATA_Bits[LED_BLUE] = ((paused != 0U) ? LED_BLUE : 0U);
-
- // application-specific trace record
- QS_BEGIN_ID(PAUSED_STAT, APP::AO_Table->getPrio())
- QS_U8(1, paused); // Paused status
- QS_END()
-}
-//............................................................................
-void randomSeed(uint32_t const seed) {
- l_rndSeed = seed;
-}
-//............................................................................
-std::uint32_t random() { // a very cheap pseudo-random-number generator
- // Some floating point code is to exercise the VFP...
- float volatile x = 3.1415926F;
- x = x + 2.7182818F;
-
- QP::QSchedStatus lockStat = QP::QXK::schedLock(APP::N_PHILO);
- // "Super-Duper" Linear Congruential Generator (LCG)
- // LCG(2^32, 3*7*11*13*23, 0, seed)
- std::uint32_t rnd = l_rndSeed * (3U*7U*11U*13U*23U);
- l_rndSeed = rnd; // set for the next time
- QP::QXK::schedUnlock(lockStat);
-
- return (rnd >> 8U);
-}
-//............................................................................
-void ledOn() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0xFFU;
-}
-//............................................................................
-void ledOff() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0x00U;
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-// namespace QP
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(UART0_IRQn, 0U); // kernel unaware interrupt
- NVIC_SetPriority(GPIOA_IRQn, QF_AWARE_ISR_CMSIS_PRI + 0U);
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
- NVIC_EnableIRQ(GPIOA_IRQn);
-
-#ifdef Q_SPY
- NVIC_EnableIRQ(UART0_IRQn); // UART interrupt used for QS-RX
-#endif
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QXK::onIdle() {
- // toggle the User LED on and then off, see NOTE3
- QF_INT_DISABLE();
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0xFFU; // turn the Blue LED on
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0U; // turn the Blue LED off
- QF_INT_ENABLE();
-
- // Some floating point code is to exercise the VFP...
- float volatile x = 1.73205F;
- x = x * 1.73205F;
-
-#ifdef Q_SPY
- QF_INT_DISABLE();
- QS::rxParse(); // parse all the received bytes
- QF_INT_ENABLE();
-
- if ((UART0->FR & UART_FR_TXFE) != 0U) { // TX done?
- std::uint16_t fifo = UART_TXFIFO_DEPTH; // max bytes we can accept
-
- // try to get next contiguous block to transmit
- QF_INT_DISABLE();
- std::uint8_t const *block = QS::getBlock(&fifo);
- QF_INT_ENABLE();
-
- while (fifo-- != 0U) { // any bytes in the block?
- UART0->DR = *block++; // put into the FIFO
- }
- }
-#elif defined NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- __WFI(); // Wait-For-Interrupt
-#endif
-}
-
-//============================================================================
-// QS callbacks...
-#ifdef Q_SPY
-namespace QS {
-
-//............................................................................
-bool onStartup(void const *arg) {
- Q_UNUSED_PAR(arg);
-
- static std::uint8_t qsTxBuf[2*1024]; // buffer for QS-TX channel
- initBuf(qsTxBuf, sizeof(qsTxBuf));
-
- static std::uint8_t qsRxBuf[100]; // buffer for QS-RX channel
- rxInitBuf(qsRxBuf, sizeof(qsRxBuf));
-
- // enable clock for UART0 and GPIOA (used by UART0 pins)
- SYSCTL->RCGCUART |= (1U << 0U); // enable Run mode for UART0
- SYSCTL->RCGCGPIO |= (1U << 0U); // enable Run mode for GPIOA
-
- // configure UART0 pins for UART operation
- uint32_t tmp = (1U << 0U) | (1U << 1U);
- GPIOA->DIR &= ~tmp;
- GPIOA->SLR &= ~tmp;
- GPIOA->ODR &= ~tmp;
- GPIOA->PUR &= ~tmp;
- GPIOA->PDR &= ~tmp;
- GPIOA->AMSEL &= ~tmp; // disable analog function on the pins
- GPIOA->AFSEL |= tmp; // enable ALT function on the pins
- GPIOA->DEN |= tmp; // enable digital I/O on the pins
- GPIOA->PCTL &= ~0x00U;
- GPIOA->PCTL |= 0x11U;
-
- // configure the UART for the desired baud rate, 8-N-1 operation
- tmp = (((SystemCoreClock * 8U) / UART_BAUD_RATE) + 1U) / 2U;
- UART0->IBRD = tmp / 64U;
- UART0->FBRD = tmp % 64U;
- UART0->LCRH = (0x3U << 5U); // configure 8-N-1 operation
- UART0->LCRH |= (0x1U << 4U); // enable FIFOs
- UART0->CTL = (1U << 0U) // UART enable
- | (1U << 8U) // UART TX enable
- | (1U << 9U); // UART RX enable
-
- // configure UART interrupts (for the RX channel)
- UART0->IM |= (1U << 4U) | (1U << 6U); // enable RX and RX-TO interrupt
- UART0->IFLS |= (0x2U << 2U); // interrupt on RX FIFO half-full
- // NOTE: do not enable the UART0 interrupt yet. Wait till QF_onStartup()
-
- // configure TIMER5 to produce QS time stamp
- SYSCTL->RCGCTIMER |= (1U << 5U); // enable run mode for Timer5
- TIMER5->CTL = 0U; // disable Timer1 output
- TIMER5->CFG = 0x0U; // 32-bit configuration
- TIMER5->TAMR = (1U << 4U) | 0x02U; // up-counting periodic mode
- TIMER5->TAILR= 0xFFFFFFFFU; // timer interval
- TIMER5->ICR = 0x1U; // TimerA timeout flag bit clears
- TIMER5->CTL |= (1U << 0U); // enable TimerA module
-
- return true; // return success
-}
-//............................................................................
-void onCleanup() {
-}
-//............................................................................
-QSTimeCtr onGetTime() { // NOTE: invoked with interrupts DISABLED
- return TIMER5->TAV;
-}
-//............................................................................
-// NOTE:
-// No critical section in QS::onFlush() to avoid nesting of critical sections
-// in case QS::onFlush() is called from Q_onError().
-void onFlush() {
- for (;;) {
- std::uint16_t b = getByte();
- if (b != QS_EOD) {
- while ((UART0->FR & UART_FR_TXFE) == 0U) { // while TXE not empty
- }
- UART0->DR = b;
- }
- else {
- break;
- }
- }
-}
-//............................................................................
-void onReset() {
- NVIC_SystemReset();
-}
-//............................................................................
-void onCommand(std::uint8_t cmdId, std::uint32_t param1,
- std::uint32_t param2, std::uint32_t param3)
-{
- Q_UNUSED_PAR(cmdId);
- Q_UNUSED_PAR(param1);
- Q_UNUSED_PAR(param2);
- Q_UNUSED_PAR(param3);
-}
-
-} // namespace QS
-#endif // Q_SPY
-//----------------------------------------------------------------------------
-
-} // namespace QP
-
-//============================================================================
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call the QK_ISR_ENTRY/
-// QXK_ISR_ENTRY macros or any other QF/QXK services. These ISRs are
-// "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QXK services. In particular they
-// can NOT call the macros QXK_ISR_ENTRY/QXK_ISR_ENTRY. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.ccsproject b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.ccsproject
deleted file mode 100644
index e057df002..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.ccsproject
+++ /dev/null
@@ -1,5 +0,0 @@
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.cproject b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.cproject
deleted file mode 100644
index 8dfdffe66..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.cproject
+++ /dev/null
@@ -1,318 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.project b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.project
deleted file mode 100644
index 260dc4f8a..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/.project
+++ /dev/null
@@ -1,110 +0,0 @@
-
-
- dpp-qxk
-
-
-
-
-
- org.eclipse.cdt.managedbuilder.core.genmakebuilder
-
-
-
-
- org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder
- full,incremental,
-
-
-
-
-
- com.ti.ccstudio.core.ccsNature
- org.eclipse.cdt.core.cnature
- org.eclipse.cdt.managedbuilder.core.managedBuildNature
- org.eclipse.cdt.core.ccnature
- org.eclipse.cdt.managedbuilder.core.ScannerConfigNature
-
-
-
- QP
- 2
- PARENT-5-PROJECT_LOC/src/qf
-
-
- QP_port
- 2
- PARENT-5-PROJECT_LOC/ports/arm-cm/qxk/gnu
-
-
- QS
- 2
- PARENT-5-PROJECT_LOC/src/qs
-
-
- QXK
- 2
- PARENT-5-PROJECT_LOC/src/qxk
-
-
- TM4C123GH6PM.h
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/TM4C123GH6PM.h
-
-
- bsp.cpp
- 1
- PARENT-1-PROJECT_LOC/bsp.cpp
-
-
- main.cpp
- 1
- PARENT-2-PROJECT_LOC/main.cpp
-
-
- philo.cpp
- 1
- PARENT-2-PROJECT_LOC/philo.cpp
-
-
- qp_config.hpp
- 1
- PARENT-2-PROJECT_LOC/qp_config.hpp
-
-
- startup_TM4C123GH6PM.c
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/gnu/startup_TM4C123GH6PM.c
-
-
- system_TM4C123GH6PM.c
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/system_TM4C123GH6PM.c
-
-
- system_TM4C123GH6PM.h
- 1
- PARENT-5-PROJECT_LOC/3rd_party/ek-tm4c123gxl/system_TM4C123GH6PM.h
-
-
- table.cpp
- 1
- PARENT-2-PROJECT_LOC/table.cpp
-
-
- xthread1.cpp
- 1
- PARENT-1-PROJECT_LOC/xthread1.cpp
-
-
- xthread2.cpp
- 1
- PARENT-1-PROJECT_LOC/xthread2.cpp
-
-
-
-
- CG_TOOL_GPP
- $%7BCG_TOOL_ROOT%7D/bin/arm-none-eabi-g++
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/Makefile b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/Makefile
deleted file mode 100644
index ce1c593cc..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/Makefile
+++ /dev/null
@@ -1,315 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EK-TM4C123GXL, QXK kernel, GNU-ARM
-# Last Updated for Version: 7.3.3
-# Date of the Last Update: 2024-01-29
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := dpp-qxk
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qxk/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qxk \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/ek-tm4c123gxl \
- $(QPCPP)/3rd_party/ek-tm4c123gxl/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/ek-tm4c123gxl
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_TM4C123GH6PM.c \
- startup_TM4C123GH6PM.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- philo.cpp \
- table.cpp \
- xthread1.cpp \
- xthread2.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qxk.cpp \
- qxk_mutex.cpp \
- qxk_sema.cpp \
- qxk_xthr.cpp \
- qxk_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DQP_CONFIG
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=fpv4-sp-d16
-FLOAT_ABI := -mfloat-abi=hard
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically you should not need to change anything below this line
-
-# basic utilities (included in QTools for Windows), see:
-# https://www.state-machine.com/qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-.PHONY : clean show
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/README.txt
deleted file mode 100644
index ab8e99e8f..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/README.txt
+++ /dev/null
@@ -1,79 +0,0 @@
-About this Example
-==================
-This example can be built in two different ways:
-- from the command prompt with the provided Makefile.
-- from the TI Code Composer Studio with the provided CCS project.
-
-
-The Makefile
-============
-The provided Makefile should be easy to adapt for your own projects.
-It contains three build configurations: Debug (default), Release, and
-Spy.
-
-The various build configurations are built as follows:
-
-make
-make CONF=rel
-make CONF=spy
-
-make clean
-make CONF=rel clean
-make CONF=spy clean
-
-***
-NOTE:
-The installation folder of the GNU-ARM toolset on YOUR machine needs
-to be adjusted in the provided Makefile, by editing the symbol: GNU_ARM.
-As described in the comment for this symbol, the GNU-ARM toolset is taken
-from: http://gnutoolchains.com/arm-eabi
-
-It is highly recommended to use the same GNU-ARM distribution, especially
-for ARM Cortex-M4F projects, due to the support for the hardware FPU
-(float-abi=hard).
-***
-
-The CCS Project
-===============
-This directory contains also the CCS project which can be imported to the
-CCS (Code Composer Studio) IDE based on Eclipse. To import the project,
-use the section "General -> Existing Project into Workspace" and select this
-directory as the "root directory". For example, the "Select root directory"
-might be: C:\qp-dev\qpc\examples\arm-cm\dpp_ek-tm4c123gxl\qxk\gnu
-
-Once you press "Browse", the project (dpp-qk, dpp-qv, or dpp-qxk) should
-become visible. Click on "Select All" and then "Finish".
-
-
-Adjusting Stack and Heap Sizes
-==============================
-The stack and heap sizes are determined in this project by the GCC linker
-script (.ld file), which provides a template of the recommended GCC linker
-script for QP applications.
-
-
-Startup Code
-============
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\gcc\startup_TM4C123GH6PM.c
-
-The file startup_TM4C123GH6PM.c provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/dpp-qxk.ld b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/dpp-qxk.ld
deleted file mode 100644
index 5139ce62b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/dpp-qxk.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EK-TM4C123GXL, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* Web : http://www.state-machine.com
-* Email: info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Tiva TM4C123GH6PM */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/flash.bat b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/flash.bat
deleted file mode 100644
index cb2a3886e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/gnu/flash.bat
+++ /dev/null
@@ -1,33 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EK-TM4C123GXL
-::
-:: NOTE: requires the LMFlash programmer (included in QTools for Windows)
-::
-@echo off
-setlocal
-
-@echo Load a given binary file to the flash of EK-TM4C123GXL
-@echo usage: flash binary-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: The following symbol LMFLASH assumes that LMFlash.exe can
-:: be found on the PATH. You might need to adjust this symbol to the
-:: location of the LMFlash utility on your machine
-::
-set LMFLASH=LMFlash.exe
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-%LMFLASH% -q ek-tm4c123gxl -e -v -r %1
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/README.txt
deleted file mode 100644
index a0a244154..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/README.txt
+++ /dev/null
@@ -1,53 +0,0 @@
-About this Example
-==================
-This example demonstrates how to use the IAR EWARM IDE to build
-a QP application.
-
-
-IAR Project File
-----------------
-The IAR EWARM project file provided with this example uses relative paths
-to the QP/C++ framework location (includes, port, and libraries. These
-relative paths must be modified when the project is moved to different
-relative location.
-
-
-Stack Size and Heap Size
-------------------------
-In this project, the size of the C++ stack and heap are determined in
-the linker script blinky-qk.icf (see the next section).
-
-
-Linker Script
--------------
-The IAR linker script provides a template of the recommended linker script
-for QP applications. This file needs to be customized to set the
-application-specific sizes of the Stack and Heap. This file can be edited
-from the IAR EWARM IDE via the Project Options/Linker settings.
-
-
-Startup Code
-------------
-The startup code for the TM4C123GH6PM MCU used in this project is
-located in the "3rd_party" folder in the following location:
-
-3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-The file startup_TM4C123GH6PM.s provides a template of the recommended
-startup for QP applications and should be easily customizable for other
-ARM Cortex-M microcontrollers.
-
-The startup file typically does not need to be modified or adapted for
-applications. It provides only weak definitions of all exception and
-interrupt handlers, as well as the assert_failed() function.
-
-The weak function assert_failed() defined in this file might be re-defined
-in the application to customize it for the application-specific error-
-handling policy.
-
-***
-NOTE: The function assert_failed() typically should NOT use the stack,
-because stack might be corrupted by the time this function is called.
-Also, assert_failed() is intended to handle catastrophic errors and
-should NOT return.
-***
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.ewd b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.ewd
deleted file mode 100644
index 143fc5398..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.ewp b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.ewp
deleted file mode 100644
index 1bab8a102..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.ewp
+++ /dev/null
@@ -1,3362 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 1
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\dpp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
- $PROJ_DIR$\..\..\philo.cpp
-
-
- $PROJ_DIR$\..\..\table.cpp
-
-
- $PROJ_DIR$\..\xthread1.cpp
-
-
- $PROJ_DIR$\..\xthread2.cpp
-
-
-
- ek-tm4c123gxl
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk_mutex.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk_sema.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qxk\qxk_xthr.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qxk\iar\qxk_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.eww b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.eww
deleted file mode 100644
index 38808ca3f..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\dpp-qxk.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.icf b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.icf
deleted file mode 100644
index c6b24e1c6..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/iar/dpp-qxk.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK }; /* <== Quantum Leaps */
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/xthread1.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/xthread1.cpp
deleted file mode 100644
index f394c2661..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/xthread1.cpp
+++ /dev/null
@@ -1,103 +0,0 @@
-//============================================================================
-// QXThread example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-12
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-//Q_DEFINE_THIS_FILE
-} // unnamed namespace
-
-//----------------------------------------------------------------------------
-namespace APP {
-
-class XThread1 : public QP::QXThread {
-private:
- // NOTE: data needed by this thread should be members of
- // the thread class. That way they are in the memory region
- // accessible from this thread.
- std::uint8_t m_foo;
-
-public:
- static XThread1 inst;
- XThread1();
-
-private:
- static void run(QP::QXThread * const thr);
-}; // class XThread1
-
-//............................................................................
-QP::QXThread * const TH_XThread1 = &XThread1::inst;
-
-XThread1 XThread1::inst;
-
-XThread1::XThread1()
- : QXThread(&run)
-{}
-
-//............................................................................
-void XThread1::run(QP::QXThread * const thr) {
- // downcast the generic thr pointer to the specific thread
- auto me = static_cast(thr);
-
- QS_OBJ_DICTIONARY(TH_XThread1);
- QS_OBJ_DICTIONARY(TH_XThread1->getTimeEvt());
-
- // subscribe to the EAT signal (from the application)
- me->subscribe(APP::EAT_SIG);
-
- for (;;) {
- QP::QEvt const *e = me->queueGet(BSP::TICKS_PER_SEC/4U);
- if (e) {
- TH_sema.signal(); // signal Thread2
- QP::QF::gc(e); // must explicitly recycle the received event!
- }
-
- TH_mutex.lock(QP::QXTHREAD_NO_TIMEOUT); // lock the mutex
- BSP::ledOn();
- if (TH_mutex.tryLock()) { // exercise the mutex
- // some floating point code to exercise the VFP...
- float volatile x = 1.4142135F;
- x = x * 1.4142135F;
- QP::QXThread::delay(10U); // BLOCK while holding a mutex
- TH_mutex.unlock();
- }
- TH_mutex.unlock();
- BSP::ledOff();
- }
-}
-
-} // namespace APP
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/xthread2.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/xthread2.cpp
deleted file mode 100644
index 7ba1da8f1..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/qxk/xthread2.cpp
+++ /dev/null
@@ -1,110 +0,0 @@
-//============================================================================
-// QXThread example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-12
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-//Q_DEFINE_THIS_FILE
-} // unnamed namespace
-
-//----------------------------------------------------------------------------
-namespace APP {
-
-//............................................................................
-QP::QXSemaphore TH_sema;
-QP::QXMutex TH_mutex;
-
-//............................................................................
-class XThread2 : public QP::QXThread {
-private:
- // NOTE: data needed by this thread should be members of
- // the thread class. That way they are in the memory region
- // accessible from this thread.
- std::uint8_t m_foo;
-
-public:
- static XThread2 inst;
- XThread2();
-
-private:
- static void run(QP::QXThread * const thr);
-}; // class XThread2
-
-//............................................................................
-QP::QXThread * const TH_XThread2 = &XThread2::inst;
-
-XThread2 XThread2::inst;
-
-XThread2::XThread2()
- : QXThread(&run)
-{}
-
-//............................................................................
-void XThread2::run(QP::QXThread * const thr) {
- // downcast the generic thr pointer to the specific thread
- //auto me = static_cast(thr);
-
- QS_OBJ_DICTIONARY(TH_XThread2);
- QS_OBJ_DICTIONARY(TH_XThread2->getTimeEvt());
- QS_OBJ_DICTIONARY(&TH_sema);
- QS_OBJ_DICTIONARY(&TH_mutex);
-
- // initialize the semaphore before using it
- // NOTE: Here the semaphore is initialized in the highest-priority thread
- // that uses it. Alternatively, the semaphore can be initialized
- // before any thread runs.
- TH_sema.init(0U, // count==0 (signaling semaphore)
- 1U); // max_count==1 (binary semaphore)
-
- // initialize the mutex before using it
- // NOTE: Here the mutex is initialized in the highest-priority thread
- // that uses it. Alternatively, the mutex can be initialized
- // before any thread runs.
- TH_mutex.init(APP::N_PHILO + 6U); // priority-ceiling mutex
- //l_mutex.init(0U); // alternatively: priority-ceiling NOT used
-
- for (;;) {
- // wait on a semaphore (BLOCK indefinitely)
- TH_sema.wait();
-
- TH_mutex.lock(QP::QXTHREAD_NO_TIMEOUT); // lock the mutex
- QP::QXThread::delay(5U); // wait more (BLOCK)
- TH_mutex.unlock();
- }
-}
-
-} // namespace APP
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl/table.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl/table.cpp
deleted file mode 100644
index d3a672ecc..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl/table.cpp
+++ /dev/null
@@ -1,348 +0,0 @@
-//$file${.::table.cpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp.qm
-// File: ${.::table.cpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::table.cpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//$declare${AOs::Table} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Table} ..............................................................
-class Table : public QP::QActive {
-private:
- std::uint8_t m_fork[N_PHILO];
- bool m_isHungry[N_PHILO];
-
-public:
- static Table inst;
-
-public:
- Table();
-
-protected:
- Q_STATE_DECL(initial);
- Q_STATE_DECL(active);
- Q_STATE_DECL(serving);
- Q_STATE_DECL(paused);
-}; // class Table
-
-} // namespace APP
-//$enddecl${AOs::Table} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-
-// helper function to provide the RIGHT neighbour of a Philo[n]
-static inline std::uint8_t right(std::uint8_t const n) {
- return static_cast((n + (APP::N_PHILO - 1U)) % APP::N_PHILO);
-}
-
-// helper function to provide the LEFT neighbour of a Philo[n]
-static inline std::uint8_t left(std::uint8_t const n) {
- return static_cast((n + 1U) % APP::N_PHILO);
-}
-
-static constexpr std::uint8_t FREE {0U};
-static constexpr std::uint8_t USED {1U};
-
-static constexpr char const * const THINKING {"thinking"};
-static constexpr char const * const HUNGRY {"hungry "};
-static constexpr char const * const EATING {"eating "};
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-//$skip${QP_VERSION} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-// Check for the minimum required QP version
-#if (QP_VERSION < 730U) || (QP_VERSION != ((QP_RELEASE^4294967295U) % 0x3E8U))
-#error qpcpp version 7.3.0 or higher required
-#endif
-//$endskip${QP_VERSION} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$define${Shared::AO_Table} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::AO_Table} ........................................................
-QP::QActive * const AO_Table = &Table::inst;
-
-} // namespace APP
-//$enddef${Shared::AO_Table} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-//$define${AOs::Table} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Table} ..............................................................
-Table Table::inst;
-
-//${AOs::Table::Table} .......................................................
-Table::Table()
- : QActive(Q_STATE_CAST(&initial))
-{
- for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
- }
-}
-
-//${AOs::Table::SM} ..........................................................
-Q_STATE_DEF(Table, initial) {
- //${AOs::Table::SM::initial}
- Q_UNUSED_PAR(e);
-
- QS_OBJ_DICTIONARY(&Table::inst);
-
- subscribe(DONE_SIG);
- subscribe(PAUSE_SIG);
- subscribe(SERVE_SIG);
- subscribe(TEST_SIG);
-
- for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, THINKING);
- }
-
- QS_FUN_DICTIONARY(&Table::active);
- QS_FUN_DICTIONARY(&Table::serving);
- QS_FUN_DICTIONARY(&Table::paused);
-
- return tran(&serving);
-}
-
-//${AOs::Table::SM::active} ..................................................
-Q_STATE_DEF(Table, active) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Table::SM::active::TEST}
- case TEST_SIG: {
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::EAT}
- case EAT_SIG: {
- Q_ERROR();
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Table::SM::active::serving} .........................................
-Q_STATE_DEF(Table, serving) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Table::SM::active::serving}
- case Q_ENTRY_SIG: {
- // give permissions to eat...
- for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- if (m_isHungry[n]
- && (m_fork[left(n)] == FREE)
- && (m_fork[n] == FREE))
- {
- m_fork[left(n)] = USED;
- m_fork[n] = USED;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *te = Q_NEW(TableEvt, EAT_SIG, n);
- #else
- TableEvt *te = Q_NEW(TableEvt, EAT_SIG);
- te->philoId = n;
- #endif
- QP::QActive::PUBLISH(te, this);
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, EATING);
- }
- }
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::serving::HUNGRY}
- case HUNGRY_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // phil ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- BSP::displayPhilStat(n, HUNGRY);
- std::uint8_t m = left(n);
- //${AOs::Table::SM::active::serving::HUNGRY::[bothfree]}
- if ((m_fork[m] == FREE) && (m_fork[n] == FREE)) {
- m_fork[m] = USED;
- m_fork[n] = USED;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, n);
- #else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = n;
- #endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(n, EATING);
- status_ = Q_RET_HANDLED;
- }
- //${AOs::Table::SM::active::serving::HUNGRY::[else]}
- else {
- m_isHungry[n] = true;
- status_ = Q_RET_HANDLED;
- }
- break;
- }
- //${AOs::Table::SM::active::serving::DONE}
- case DONE_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // phil ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- BSP::displayPhilStat(n, THINKING);
- std::uint8_t m = left(n);
-
- // both forks of Phil[n] must be used
- Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
- m_fork[m] = FREE;
- m_fork[n] = FREE;
- m = right(n); // check the right neighbor
-
- if (m_isHungry[m] && (m_fork[m] == FREE)) {
- m_fork[n] = USED;
- m_fork[m] = USED;
- m_isHungry[m] = false;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
- #else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
- #endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
- }
- m = left(n); // check the left neighbor
- n = left(m); // left fork of the left neighbor
- if (m_isHungry[m] && (m_fork[n] == FREE)) {
- m_fork[m] = USED;
- m_fork[n] = USED;
- m_isHungry[m] = false;
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
- #else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
- #endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
- }
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::serving::EAT}
- case EAT_SIG: {
- Q_ERROR();
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::serving::PAUSE}
- case PAUSE_SIG: {
- status_ = tran(&paused);
- break;
- }
- default: {
- status_ = super(&active);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Table::SM::active::paused} ..........................................
-Q_STATE_DEF(Table, paused) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Table::SM::active::paused}
- case Q_ENTRY_SIG: {
- BSP::displayPaused(1U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::paused}
- case Q_EXIT_SIG: {
- BSP::displayPaused(0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::paused::SERVE}
- case SERVE_SIG: {
- status_ = tran(&serving);
- break;
- }
- //${AOs::Table::SM::active::paused::HUNGRY}
- case HUNGRY_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // philo ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- m_isHungry[n] = true;
- BSP::displayPhilStat(n, HUNGRY);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Table::SM::active::paused::DONE}
- case DONE_SIG: {
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
- // phil ID must be in range and he must be not hungry
- Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
- BSP::displayPhilStat(n, THINKING);
- std::uint8_t m = left(n);
-
- // both forks of Phil[n] must be used
- Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
- m_fork[m] = FREE;
- m_fork[n] = FREE;
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&active);
- break;
- }
- }
- return status_;
-}
-
-} // namespace APP
-//$enddef${AOs::Table} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/bsp.hpp b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/bsp.hpp
deleted file mode 100644
index 87c7885c4..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/bsp.hpp
+++ /dev/null
@@ -1,61 +0,0 @@
-//============================================================================
-// Product: DPP example
-// Last Updated for Version: 7.3.0
-// Date of the Last Update: 2023-08-12
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef BSP_HPP_
-#define BSP_HPP_
-
-#include // for placement new
-
-namespace BSP {
-
-constexpr std::uint32_t TICKS_PER_SEC {100};
-
-void init();
-void start();
-void displayPaused(std::uint8_t const paused);
-void displayPhilStat(std::uint8_t const n, char const *stat);
-void terminate(std::int16_t const result);
-
-void randomSeed(std::uint32_t const seed); // random seed
-std::uint32_t random(); // pseudo-random generator
-
-// for testing...
-void wait4SW1();
-void ledOn();
-void ledOff();
-
-extern QP::QTicker *AO_Ticker0;
-
-} // namespace BSP
-
-#endif // BSP_HPP_
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/dpp.hpp b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/dpp.hpp
deleted file mode 100644
index 2b234a00b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/dpp.hpp
+++ /dev/null
@@ -1,152 +0,0 @@
-//$file${.::dpp.hpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp_mpu.qm
-// File: ${.::dpp.hpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::dpp.hpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#ifndef DPP_HPP_
-#define DPP_HPP_
-
-//$declare${Shared} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::AppSignals} ......................................................
-enum AppSignals : QP::QSignal {
- EAT_SIG = QP::Q_USER_SIG, // published by Table to let a Philo eat
- DONE_SIG, // published by Philo when done eating
- PAUSE_SIG, // published by BSP to pause the application
- SERVE_SIG, // published by BSP to serve re-start serving forks
- TEST_SIG, // published by BSP to test the application
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG, // posted by time event to Philo
- HUNGRY_SIG, // posted by hungry Philo to Table
- MAX_SIG // the last signal
-};
-
-//${Shared::produce_sig_dict} ................................................
-#ifdef Q_SPY
-inline void produce_sig_dict() {
- QS_SIG_DICTIONARY(EAT_SIG, nullptr);
- QS_SIG_DICTIONARY(DONE_SIG, nullptr);
- QS_SIG_DICTIONARY(PAUSE_SIG, nullptr);
- QS_SIG_DICTIONARY(SERVE_SIG, nullptr);
- QS_SIG_DICTIONARY(TEST_SIG, nullptr);
-
- QS_SIG_DICTIONARY(TIMEOUT_SIG, nullptr);
- QS_SIG_DICTIONARY(HUNGRY_SIG, nullptr);
-}
-#endif // def Q_SPY
-
-//${Shared::N_PHILO} .........................................................
-constexpr std::uint8_t N_PHILO {5};
-
-//${Shared::TableEvt} ........................................................
-class TableEvt : public QP::QEvt {
-public:
- std::uint8_t philoId;
-
-public:
- constexpr TableEvt(
- QP::QSignal sig,
- std::uint8_t id)
- : QEvt(sig),
- philoId(id)
- {}
-
-#ifdef QEVT_DYN_CTOR
- TableEvt(std::uint8_t id)
- : QEvt(QP::QEvt::DYNAMIC),
- philoId(id)
- {}
-#endif // def QEVT_DYN_CTOR
-}; // class TableEvt
-
-//${Shared::AO_Philo[N_PHILO]} ...............................................
-extern QP::QActive * const AO_Philo[N_PHILO];
-
-//${Shared::Philo_ctor} ......................................................
-void Philo_ctor(
- std::uint_fast8_t const id,
- std::uint8_t * const sto,
- std::uint32_t const size,
- void const * const mpu = nullptr);
-
-//${Shared::AO_Table} ........................................................
-extern QP::QActive * const AO_Table;
-
-//${Shared::Table_ctor} ......................................................
-void Table_ctor(
- std::uint8_t * const sto,
- std::uint32_t const size,
- void const * const mpu = nullptr);
-
-} // namespace APP
-//$enddecl${Shared} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-#ifdef QXK_HPP_
-//$declare${Shared-TH} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared-TH::TH_XThread1} ..................................................
-extern QP::QXThread * const TH_XThread1;
-
-//${Shared-TH::XThread1_ctor} ................................................
-void XThread1_ctor(
- std::uint8_t * const sto,
- std::uint32_t const size,
- void const * const mpu = nullptr);
-
-//${Shared-TH::TH_XThread2} ..................................................
-extern QP::QXThread * const TH_XThread2;
-
-//${Shared-TH::XThread2_ctor} ................................................
-void XThread2_ctor(
- std::uint8_t * const sto,
- std::uint32_t const size,
- void const * const mpu = nullptr);
-
-//${Shared-TH::TH_sema} ......................................................
-// NOTE: kernel objects can be allocated outside any memory regions
-// accessible to the threads.
-extern QP::QXSemaphore TH_sema;
-
-//${Shared-TH::TH_mutex} .....................................................
-// NOTE: kernel objects can be allocated outside any memory regions
-// accessible to the threads.
-extern QP::QXMutex TH_mutex;
-
-//${Shared-TH::TH_obj_dict} ..................................................
-#ifdef Q_SPY
-void TH_obj_dict();
-#endif // def Q_SPY
-
-} // namespace APP
-//$enddecl${Shared-TH} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#endif // QXK_HPP_
-
-#endif // DPP_HPP_
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/dpp_mpu.qm b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/dpp_mpu.qm
deleted file mode 100644
index 01304932c..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/dpp_mpu.qm
+++ /dev/null
@@ -1,728 +0,0 @@
-
-
- Dining Philosopher Problem example with MPU isolation
-
-
-
-
-
-
- : QP::QSignal {
- EAT_SIG = QP::Q_USER_SIG, // published by Table to let a Philo eat
- DONE_SIG, // published by Philo when done eating
- PAUSE_SIG, // published by BSP to pause the application
- SERVE_SIG, // published by BSP to serve re-start serving forks
- TEST_SIG, // published by BSP to test the application
- MAX_PUB_SIG, // the last published signal
-
- TIMEOUT_SIG, // posted by time event to Philo
- HUNGRY_SIG, // posted by hungry Philo to Table
- MAX_SIG // the last signal
-};
-
-
-
- QS_SIG_DICTIONARY(EAT_SIG, nullptr);
-QS_SIG_DICTIONARY(DONE_SIG, nullptr);
-QS_SIG_DICTIONARY(PAUSE_SIG, nullptr);
-QS_SIG_DICTIONARY(SERVE_SIG, nullptr);
-QS_SIG_DICTIONARY(TEST_SIG, nullptr);
-
-QS_SIG_DICTIONARY(TIMEOUT_SIG, nullptr);
-QS_SIG_DICTIONARY(HUNGRY_SIG, nullptr);
-
-
-
- {5};
-
-
-
-
-
-
-
-
-
-
-
- : QEvt(sig),
- philoId(id)
-
-
-
-
-
- : QEvt(QP::QEvt::DYNAMIC),
- philoId(id)
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Q_REQUIRE(sizeof(Philo) <= size);
-
-// run the constructor through placemen new()
-auto me = new(sto) Philo(id);
-me->setThread(mpu);
-
-
-
-
-
-
-
-
-
-
-
- Q_REQUIRE(sizeof(Table) <= size);
-
-// run the constructor through placemen new()
-auto me = new(sto) Table();
-me->setThread(mpu);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Q_REQUIRE(sizeof(XThread1) <= size);
-
-// run the constructor through placement new()
-auto me = new(sto) XThread1();
-me->setThread(mpu);
-
-
-
-
-
-
-
-
-
-
-
- Q_REQUIRE(sizeof(XThread2) <= size);
-
-// run the constructor through placement new()
-auto me = new(sto) XThread2();
-me->setThread(mpu);
-
-
-
- // NOTE: kernel objects can be allocated outside any memory regions
-// accessible to the threads.
-
-
-
- // NOTE: kernel objects can be allocated outside any memory regions
-// accessible to the threads.
-
-
-
- QS_OBJ_DICTIONARY(TH_XThread1);
-QS_OBJ_DICTIONARY(TH_XThread1->getTimeEvt());
-
-QS_OBJ_DICTIONARY(TH_XThread2);
-QS_OBJ_DICTIONARY(TH_XThread2->getTimeEvt());
-QS_OBJ_DICTIONARY(&TH_sema);
-QS_OBJ_DICTIONARY(&TH_mutex);
-
-
-
-
-
-
- The Philo AO and the N_PHILO instances
-
-
-
-
-
-
-
-
- : QActive(Q_STATE_CAST(&Philo::initial)),
- m_timeEvt(this, TIMEOUT_SIG, 0U),
- m_id(static_cast<std::uint8_t>(id))
-
-
-
-
-
- Q_UNUSED_PAR(e);
-
-#ifdef Q_SPY
-Philo *Philo_inst = this;
-QS_OBJ_ARR_DICTIONARY(Philo_inst, m_id);
-QS_OBJ_ARR_DICTIONARY(&Philo_inst->m_timeEvt, m_id);
-#endif
-
-subscribe(EAT_SIG);
-subscribe(TEST_SIG);
-
-
-
-
-
-
- m_timeEvt.armX(think_time(), 0U);
- (void)m_timeEvt.disarm();
-
-
-
-
-
-
-
-
- // EAT or DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- #ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, HUNGRY_SIG, m_id);
-#else
-TableEvt *pe = Q_NEW(TableEvt, HUNGRY_SIG);
-pe->philoId = m_id;
-#endif
-AO_Table->POST(pe, this);
-
-
-
-
- Q_EVT_CAST(TableEvt)->philoId == m_id
-
-
-
-
-
-
-
-
-
-
- // DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
- m_timeEvt.armX(eat_time(), 0U);
- #ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, DONE_SIG, m_id);
-#else
-TableEvt *pe = Q_NEW(TableEvt, DONE_SIG);
-pe->philoId = m_id;
-#endif
-QP::QActive::PUBLISH(pe, this);
-(void)m_timeEvt.disarm();
-
-
-
-
-
-
-
-
- // EAT or DONE must be for other Philos than this one
-Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- : QActive(Q_STATE_CAST(&Table::initial))
-
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
-}
-
-
-
-
-
- Q_UNUSED_PAR(e);
-
-#ifdef Q_SPY
-Table *Table_inst = this;
-QS_OBJ_DICTIONARY(Table_inst);
-#endif
-
-subscribe(DONE_SIG);
-subscribe(PAUSE_SIG);
-subscribe(SERVE_SIG);
-subscribe(TEST_SIG);
-
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- m_fork[n] = FREE;
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, THINKING);
-}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- Q_ERROR();
-
-
-
-
-
-
- // give permissions to eat...
-for (std::uint8_t n = 0U; n < N_PHILO; ++n) {
- if (m_isHungry[n]
- && (m_fork[left(n)] == FREE)
- && (m_fork[n] == FREE))
- {
- m_fork[left(n)] = USED;
- m_fork[n] = USED;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, n);
-#else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = n;
-#endif
- QP::QActive::PUBLISH(pe, this);
- m_isHungry[n] = false;
- BSP::displayPhilStat(n, EATING);
- }
-}
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, HUNGRY);
-std::uint8_t m = left(n);
-
-
- (m_fork[m] == FREE) && (m_fork[n] == FREE)
- m_fork[m] = USED;
-m_fork[n] = USED;
-
-#ifdef QEVT_DYN_CTOR
-TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, n);
-#else
-TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
-pe->philoId = n;
-#endif
-QP::QActive::PUBLISH(pe, this);
-BSP::displayPhilStat(n, EATING);
-
-
-
-
-
-
- else
- m_isHungry[n] = true;
-
-
-
-
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, THINKING);
-std::uint8_t m = left(n);
-
-// both forks of Phil[n] must be used
-Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
-m_fork[m] = FREE;
-m_fork[n] = FREE;
-m = right(n); // check the right neighbor
-
-if (m_isHungry[m] && (m_fork[m] == FREE)) {
- m_fork[n] = USED;
- m_fork[m] = USED;
- m_isHungry[m] = false;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
-#else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
-#endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
-}
-m = left(n); // check the left neighbor
-n = left(m); // left fork of the left neighbor
-if (m_isHungry[m] && (m_fork[n] == FREE)) {
- m_fork[m] = USED;
- m_fork[n] = USED;
- m_isHungry[m] = false;
-#ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, EAT_SIG, m);
-#else
- TableEvt *pe = Q_NEW(TableEvt, EAT_SIG);
- pe->philoId = m;
-#endif
- QP::QActive::PUBLISH(pe, this);
- BSP::displayPhilStat(m, EATING);
-}
-
-
-
-
-
-
- Q_ERROR();
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- BSP::displayPaused(1U);
- BSP::displayPaused(0U);
-
-
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// philo ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-m_isHungry[n] = true;
-BSP::displayPhilStat(n, HUNGRY);
-
-
-
-
-
-
- std::uint8_t n = Q_EVT_CAST(TableEvt)->philoId;
-
-// phil ID must be in range and he must be not hungry
-Q_ASSERT((n < N_PHILO) && (!m_isHungry[n]));
-
-BSP::displayPhilStat(n, THINKING);
-std::uint8_t m = left(n);
-
-// both forks of Phil[n] must be used
-Q_ASSERT((m_fork[n] == USED) && (m_fork[m] == USED));
-
-m_fork[m] = FREE;
-m_fork[n] = FREE;
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- // NOTE: data needed by this thread should be members of
-// the thread class. That way they are in the memory region
-// accessible from this thread.
-
-
-
- : QXThread(&run)
-
-
-
-
-
- // downcast the generic thr pointer to the specific thread
-auto me = static_cast<XThread1 *>(thr);
-
-// subscribe to the EAT signal (from the application)
-me->subscribe(APP::EAT_SIG);
-
-for (;;) {
- QP::QEvt const *e = me->queueGet(BSP::TICKS_PER_SEC/4U);
- if (e) {
- TH_sema.signal(); // signal Thread2
- QP::QF::gc(e); // must explicitly recycle the received event!
- }
-
- TH_mutex.lock(QP::QXTHREAD_NO_TIMEOUT); // lock the mutex
- BSP::ledOn();
- if (TH_mutex.tryLock()) { // exercise the mutex
- // some floating point code to exercise the VFP...
- float volatile x = 1.4142135F;
- x = x * 1.4142135F;
- QP::QXThread::delay(10U); // BLOCK while holding a mutex
- TH_mutex.unlock();
- }
- TH_mutex.unlock();
- BSP::ledOff();
-}
-
-
-
-
-
-
- // NOTE: data needed by this thread should be members of
-// the thread class. That way they are in the memory region
-// accessible from this thread.
-
-
-
- : QXThread(&run)
-
-
-
-
-
- // downcast the generic thr pointer to the specific thread
-//auto me = static_cast<XThread2 *>(thr);
-
-// initialize the semaphore before using it
-// NOTE: Here the semaphore is initialized in the highest-priority thread
-// that uses it. Alternatively, the semaphore can be initialized
-// before any thread runs.
-TH_sema.init(0U, // count==0 (signaling semaphore)
- 1U); // max_count==1 (binary semaphore)
-
-// initialize the mutex before using it
-// NOTE: Here the mutex is initialized in the highest-priority thread
-// that uses it. Alternatively, the mutex can be initialized
-// before any thread runs.
-TH_mutex.init(APP::N_PHILO + 6U); // priority-ceiling mutex
-//l_mutex.init(0U); // alternatively: priority-ceiling NOT used
-
-for (;;) {
- // wait on a semaphore (BLOCK indefinitely)
- TH_sema.wait();
-
- TH_mutex.lock(QP::QXTHREAD_NO_TIMEOUT); // lock the mutex
- QP::QXThread::delay(5U); // wait more (BLOCK)
- TH_mutex.unlock();
-}
-
-
-
-
-
-
-
- #ifndef DPP_HPP_
-#define DPP_HPP_
-
-$declare ${Shared}
-
-#ifdef QXK_HPP_
-$declare ${Shared-TH}
-#endif // QXK_HPP_
-
-#endif // DPP_HPP_
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-$declare ${AOs::Philo}
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-
-// helper function to provide a randomized think time for Philos
-static inline QP::QTimeEvtCtr think_time() {
- return static_cast<QP::QTimeEvtCtr>((BSP::random() % BSP::TICKS_PER_SEC)
- + (BSP::TICKS_PER_SEC/2U));
-}
-
-// helper function to provide a randomized eat time for Philos
-static inline QP::QTimeEvtCtr eat_time() {
- return static_cast<QP::QTimeEvtCtr>((BSP::random() % BSP::TICKS_PER_SEC)
- + BSP::TICKS_PER_SEC);
-}
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-
-$define ${Shared::Philo_ctor}
-
-$define ${AOs::Philo}
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-$declare ${AOs::Table}
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-
-// helper function to provide the RIGHT neighbor of a Philo[n]
-static inline std::uint8_t right(std::uint8_t const n) {
- return static_cast<std::uint8_t>((n + (APP::N_PHILO - 1U)) % APP::N_PHILO);
-}
-
-// helper function to provide the LEFT neighbor of a Philo[n]
-static inline std::uint8_t left(std::uint8_t const n) {
- return static_cast<std::uint8_t>((n + 1U) % APP::N_PHILO);
-}
-
-static constexpr std::uint8_t FREE {0U};
-static constexpr std::uint8_t USED {1U};
-
-static constexpr char const * const THINKING {"thinking"};
-static constexpr char const * const HUNGRY {"hungry "};
-static constexpr char const * const EATING {"eating "};
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-
-$define ${Shared::Table_ctor}
-
-$define ${AOs::Table}
-
-
-
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-} // unnamed namespace
-//----------------------------------------------------------------------------
-$define ${Shared-TH::TH_sema}
-$define ${Shared-TH::TH_mutex}
-
-$declare ${XThreads::XThread1}
-$define ${Shared-TH::XThread1_ctor}
-$define ${Shared-TH::TH_obj_dict}
-$define ${XThreads::XThread1}
-
-
-
- #include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-} // unnamed namespace
-
-//----------------------------------------------------------------------------
-$declare ${XThreads::XThread2}
-$define ${Shared-TH::XThread2_ctor}
-$define ${XThreads::XThread2}
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/README.txt b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/README.txt
deleted file mode 100644
index f4869b162..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/README.txt
+++ /dev/null
@@ -1,30 +0,0 @@
-About this Example
-==================
-This directory contains the facilities for "linting" the application with
-PC-Lint-Plus.
-
-To "lint" the application, invoke the batch "lin.bat" without parameters.
-Optionally, you can supply the parameter -dQ_SPY to include the QS
-instrumentation in the "linting" process.
-
-The output from the "linting" is saved in the file "lin_out.log".
-
-***
-NOTE: You need to adjust the symbol PCLP_DIR at the top of the lin.bat
-file, to point to the directory where PC-Lint-Plus is installed on your
-machine.
-***
-
-
-The PC-Lint-Plus Options File
-=============================
-The "options.lnt" file specifies the linting options. You might need
-to modify this file to suit your needs.
-
-
-****
-NOTE: The purpose of this example is NOT to find problems with the
-supporting 3rd-party code, which every non-trivial embedded system needs.
-Rather, the purpose of this particular example is to check YOUR application
-level code, such as state machines.
-****
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/lin.bat b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/lin.bat
deleted file mode 100644
index 4cbefe73c..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/lin.bat
+++ /dev/null
@@ -1,73 +0,0 @@
-@echo off
-:: ===========================================================================
-:: Product: QP/C++ build script for PC-Lint-Plus
-:: Last Updated for Version: 6.8.0
-:: Date of the Last Update: 2020-01-26
-::
-:: Q u a n t u m L e a P s
-:: ------------------------
-:: Modern Embedded Software
-::
-:: Copyright (C) 2005-2020 Quantum Leaps, LLC. All rights reserved.
-::
-:: This program is open source software: you can redistribute it and/or
-:: modify it under the terms of the GNU General Public License as published
-:: by the Free Software Foundation, either version 3 of the License, or
-:: (at your option) any later version.
-::
-:: Alternatively, this program may be distributed and modified under the
-:: terms of Quantum Leaps commercial licenses, which expressly supersede
-:: the GNU General Public License and are specifically designed for
-:: licensees interested in retaining the proprietary status of their code.
-::
-:: This program is distributed in the hope that it will be useful,
-:: but WITHOUT ANY WARRANTY; without even the implied warranty of
-:: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-:: GNU General Public License for more details.
-::
-:: You should have received a copy of the GNU General Public License
-:: along with this program. If not, see .
-::
-:: Contact information:
-::
-::
-:: ===========================================================================
-@setlocal
-
-:: usage of lin.bat
-@echo Usage: lin [16bit] [-d...] [files...]
-@echo examples:
-@echo lin ..\table.cpp : use 32bit CPU (default) for linting ..\table.cpp
-@echo lin 16bit -dQ_SPY ..\philo.cpp : use 16bit CPU and define Q_SPY for linting ..\philo.cpp
-@echo lin ..\philo.cpp ..\table.cpp : use 32bit CPU for linting ..\philo.c and ..\table.cpp
-@echo.
-
-:: NOTE: adjust to for your installation directory of PC-Lint-Plus
-@set PCLP=C:\tools\lint-plus\windows\pclp32.exe
-
-if NOT exist "%PCLP%" (
- @echo The PC-Lint-Plus toolset not found. Please adjust lin.bat
- @goto end
-)
-
-:: set the QP/C++ directory
-set QPCPP=..\..\..\..
-set QPCPP_LINT=%QPCPP%\ports\lint-plus
-
-if "%1"=="16bit" (
- set LINTFLAGS=%QPCPP_LINT%\std.lnt -i%QPCPP_LINT%\16bit options.lnt %2 %3 %4 %5 %6 %7 %8
- @echo 16bit CPU
-) else (
- set LINTFLAGS=%QPCPP_LINT%\std.lnt -i%QPCPP_LINT%\32bit options.lnt %1 %2 %3 %4 %6 %7 %8
- @echo 32bit CPU (default)
-)
-
-:: cleanup
-@del *.log
-
-
-:: linting -------------------------------------------------------------------
-%PCLP% -os(lint_out.log) %LINTFLAGS%
-
-:end
-@endlocal
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/options.lnt b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/options.lnt
deleted file mode 100644
index 6093417a3..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/lint-plus/options.lnt
+++ /dev/null
@@ -1,64 +0,0 @@
-//////////////////////////////////////////////////////////////////////////////
-// Product: PC-Lint-Plus options for linting QP/C++ applications
-// Last updated for version 6.8.0
-// Last updated on 2020-01-27
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005-2020 Quantum Leaps. All rights reserved.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-////////////////////////////////////////////////////////////////////////////
-
-/////////////////////////////////////////////////////////////////////////////
-// general options
--unit_check // perform only subset check (suppresses Global Wrapup)
--max_threads=1 // suppress message "no '-max_threads=N' option"
-//-vf // print names of all source files (for debugging linting)
-
-// include directories
--i.. // application includes
--i%QPCPP%\include // QP/C++ public includes
--i%QPCPP_LINT% // QP/C++ lint "port"
--i%QPCPP_LINT%\qk // QP/C++ lint "port" to QK
-
-// standards
-%QPCPP_LINT%\au-autosar.lnt // AUTOSAR-C++:2014
-%QPCPP_LINT%\au-ds.lnt // Dan Saks recommendations
-//-strong(AXJ) // Strong type checking
-
-// size/alignment options (included from %QPCPP_LINT%\??bit\)
-cpu.lnt // for the chosen CPU
-
-/////////////////////////////////////////////////////////////////////////////
-// QP/C++ options for clients
-qpcpp.lnt // QP/C++ options
-
-/////////////////////////////////////////////////////////////////////////////
-// additional suppression rules for building this application
-
-// underlying type for enums is always 'int'
-+fei
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/main.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/main.cpp
deleted file mode 100644
index 509568b09..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/main.cpp
+++ /dev/null
@@ -1,44 +0,0 @@
-//============================================================================
-// APP example
-// Last updated for version 7.3.0
-// Last updated on 2023-08-09
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//............................................................................
-int main() {
- QP::QF::init(); // initialize the framework and the underlying RT kernel
- BSP::init(); // initialize the BSP
- BSP::start(); // start the AOs/Threads
- return QP::QF::run(); // run the QF application
-}
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/philo.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/philo.cpp
deleted file mode 100644
index 9f476c6df..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/philo.cpp
+++ /dev/null
@@ -1,266 +0,0 @@
-//$file${.::philo.cpp} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-//
-// Model: dpp_mpu.qm
-// File: ${.::philo.cpp}
-//
-// This code has been generated by QM 5.3.0 .
-// DO NOT EDIT THIS FILE MANUALLY. All your changes will be lost.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later
-//
-// This generated code is open source software: you can redistribute it under
-// the terms of the GNU General Public License as published by the Free
-// Software Foundation.
-//
-// This code is distributed in the hope that it will be useful, but WITHOUT
-// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
-// more details.
-//
-// NOTE:
-// Alternatively, this generated code may be distributed under the terms
-// of Quantum Leaps commercial licenses, which expressly supersede the GNU
-// General Public License and are specifically designed for licensees
-// interested in retaining the proprietary status of their code.
-//
-// Contact information:
-//
-//
-//
-//$endhead${.::philo.cpp} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-//$declare${AOs::Philo} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Philo} ..............................................................
-class Philo : public QP::QActive {
-private:
- QP::QTimeEvt m_timeEvt;
- std::uint8_t m_id;
-
-public:
- Philo(std::uint_fast8_t const id);
-
-protected:
- Q_STATE_DECL(initial);
- Q_STATE_DECL(thinking);
- Q_STATE_DECL(hungry);
- Q_STATE_DECL(eating);
-}; // class Philo
-
-} // namespace APP
-//$enddecl${AOs::Philo} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//----------------------------------------------------------------------------
-// unnamed namespace for local definitions with internal linkage
-namespace {
-Q_DEFINE_THIS_FILE
-
-// helper function to provide a randomized think time for Philos
-static inline QP::QTimeEvtCtr think_time() {
- return static_cast((BSP::random() % BSP::TICKS_PER_SEC)
- + (BSP::TICKS_PER_SEC/2U));
-}
-
-// helper function to provide a randomized eat time for Philos
-static inline QP::QTimeEvtCtr eat_time() {
- return static_cast((BSP::random() % BSP::TICKS_PER_SEC)
- + BSP::TICKS_PER_SEC);
-}
-
-} // unnamed namespace
-//----------------------------------------------------------------------------
-
-//$skip${QP_VERSION} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-// Check for the minimum required QP version
-#if (QP_VERSION < 730U) || (QP_VERSION != ((QP_RELEASE^4294967295U) % 0x3E8U))
-#error qpcpp version 7.3.0 or higher required
-#endif
-//$endskip${QP_VERSION} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$define${Shared::Philo_ctor} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${Shared::Philo_ctor} ......................................................
-void Philo_ctor(
- std::uint_fast8_t const id,
- std::uint8_t * const sto,
- std::uint32_t const size,
- void const * const mpu)
-{
- Q_REQUIRE(sizeof(Philo) <= size);
-
- // run the constructor through placemen new()
- auto me = new(sto) Philo(id);
- me->setThread(mpu);
-}
-
-} // namespace APP
-//$enddef${Shared::Philo_ctor} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-
-//$define${AOs::Philo} vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv
-namespace APP {
-
-//${AOs::Philo} ..............................................................
-
-//${AOs::Philo::Philo} .......................................................
-Philo::Philo(std::uint_fast8_t const id)
- : QActive(Q_STATE_CAST(&Philo::initial)),
- m_timeEvt(this, TIMEOUT_SIG, 0U),
- m_id(static_cast(id))
-{}
-
-//${AOs::Philo::SM} ..........................................................
-Q_STATE_DEF(Philo, initial) {
- //${AOs::Philo::SM::initial}
- Q_UNUSED_PAR(e);
-
- #ifdef Q_SPY
- Philo *Philo_inst = this;
- QS_OBJ_ARR_DICTIONARY(Philo_inst, m_id);
- QS_OBJ_ARR_DICTIONARY(&Philo_inst->m_timeEvt, m_id);
- #endif
-
- subscribe(EAT_SIG);
- subscribe(TEST_SIG);
-
- QS_FUN_DICTIONARY(&Philo::thinking);
- QS_FUN_DICTIONARY(&Philo::hungry);
- QS_FUN_DICTIONARY(&Philo::eating);
-
- return tran(&thinking);
-}
-
-//${AOs::Philo::SM::thinking} ................................................
-Q_STATE_DEF(Philo, thinking) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::thinking}
- case Q_ENTRY_SIG: {
- m_timeEvt.armX(think_time(), 0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking}
- case Q_EXIT_SIG: {
- (void)m_timeEvt.disarm();
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking::TIMEOUT}
- case TIMEOUT_SIG: {
- status_ = tran(&hungry);
- break;
- }
- //${AOs::Philo::SM::thinking::EAT, DONE}
- case EAT_SIG: // intentionally fall through
- case DONE_SIG: {
- // EAT or DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::thinking::TEST}
- case TEST_SIG: {
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Philo::SM::hungry} ..................................................
-Q_STATE_DEF(Philo, hungry) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::hungry}
- case Q_ENTRY_SIG: {
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, HUNGRY_SIG, m_id);
- #else
- TableEvt *pe = Q_NEW(TableEvt, HUNGRY_SIG);
- pe->philoId = m_id;
- #endif
- AO_Table->POST(pe, this);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::hungry::EAT}
- case EAT_SIG: {
- //${AOs::Philo::SM::hungry::EAT::[e->philoId==m_id]}
- if (Q_EVT_CAST(TableEvt)->philoId == m_id) {
- status_ = tran(&eating);
- }
- else {
- status_ = Q_RET_UNHANDLED;
- }
- break;
- }
- //${AOs::Philo::SM::hungry::DONE}
- case DONE_SIG: {
- // DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-//${AOs::Philo::SM::eating} ..................................................
-Q_STATE_DEF(Philo, eating) {
- QP::QState status_;
- switch (e->sig) {
- //${AOs::Philo::SM::eating}
- case Q_ENTRY_SIG: {
- m_timeEvt.armX(eat_time(), 0U);
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::eating}
- case Q_EXIT_SIG: {
- #ifdef QEVT_DYN_CTOR
- TableEvt const *pe = Q_NEW(TableEvt, DONE_SIG, m_id);
- #else
- TableEvt *pe = Q_NEW(TableEvt, DONE_SIG);
- pe->philoId = m_id;
- #endif
- QP::QActive::PUBLISH(pe, this);
- (void)m_timeEvt.disarm();
- status_ = Q_RET_HANDLED;
- break;
- }
- //${AOs::Philo::SM::eating::TIMEOUT}
- case TIMEOUT_SIG: {
- status_ = tran(&thinking);
- break;
- }
- //${AOs::Philo::SM::eating::EAT, DONE}
- case EAT_SIG: // intentionally fall through
- case DONE_SIG: {
- // EAT or DONE must be for other Philos than this one
- Q_ASSERT(Q_EVT_CAST(TableEvt)->philoId != m_id);
- status_ = Q_RET_HANDLED;
- break;
- }
- default: {
- status_ = super(&top);
- break;
- }
- }
- return status_;
-}
-
-} // namespace APP
-//$enddef${AOs::Philo} ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.sct b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.sct
deleted file mode 100644
index fda39c74a..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Modified by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00040000 { ; load region size_region
- ER_IROM1 0x00000000 0x00040000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: 2048 assumeed STACK size!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.uvoptx b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.uvoptx
deleted file mode 100644
index 5749477cf..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.uvoptx
+++ /dev/null
@@ -1,994 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\dbg\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 1
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\rel\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- DLGUARM
- ÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÌÈ`»
-´ª¤ô
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=-1,-1,-1,-1,0)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E10259B -O4622 -S4 -FO61
-
-
- 0
- UL2CM3
- -O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
-
- 12000000
-
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 65535
- 0
- 0
- 0
-
-
- 79
- 66
- 8
- .\spy\
-
-
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 1
- 0
- 0
- 0
- 0
-
-
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
-
-
- 1
- 0
- 0
-
- 4
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 1
- 0
- 1
- 0
- 1
- 1
- 0
- 0
- 1
- 0
- 0
- 19
-
-
-
-
-
-
-
-
-
-
- BIN\lmidk-agdi.dll
-
-
-
- 0
- ARMRTXEVENTFLAGS
- -L70 -Z18 -C0 -M0 -T1
-
-
- 0
- UL2CM3
- UL2CM3(-O207 -S0 -C0 -FO7 -FN1 -FC1000 -FD20000000 -FF0TM4C123_256 -FL040000 -FS00 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM)
-
-
- 0
- DLGTARM
- (1010=-1,-1,-1,-1,0)(1007=-1,-1,-1,-1,0)(1008=-1,-1,-1,-1,0)(1009=-1,-1,-1,-1,0)(1012=2720,915,3197,1230,1)
-
-
- 0
- ARMDBGFLAGS
-
-
-
- 0
- lmidk-agdi
- -U0E2006F4 -O4622 -S4 -FO61
-
-
-
-
-
- 1
- 2
- 0x20000200
- 0
-
-
-
-
- 2
- 0
- 0x400
- 0
-
-
-
- 0
-
-
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
-
-
-
- 0
- 0
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- Applicatioin
- 1
- 0
- 0
- 0
-
- 1
- 1
- 8
- 0
- 0
- 0
- ..\..\philo.cpp
- philo.cpp
- 0
- 0
-
-
- 1
- 2
- 8
- 0
- 0
- 0
- ..\..\table.cpp
- table.cpp
- 0
- 0
-
-
- 1
- 3
- 8
- 0
- 0
- 0
- ..\bsp.cpp
- bsp.cpp
- 0
- 0
-
-
- 1
- 4
- 5
- 0
- 0
- 0
- ..\..\bsp.hpp
- bsp.hpp
- 0
- 0
-
-
- 1
- 5
- 5
- 0
- 0
- 0
- ..\..\dpp.hpp
- dpp.hpp
- 0
- 0
-
-
- 1
- 6
- 8
- 0
- 0
- 0
- ..\..\main.cpp
- main.cpp
- 0
- 0
-
-
-
-
- ek-tm4c123gxl
- 1
- 0
- 0
- 0
-
- 2
- 7
- 1
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
- system_TM4C123GH6PM.c
- 0
- 0
-
-
- 2
- 8
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
- TM4C123GH6PM.h
- 0
- 0
-
-
- 2
- 9
- 2
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
- startup_TM4C123GH6PM.s
- 0
- 0
-
-
- 2
- 10
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
- gpio.h
- 0
- 0
-
-
- 2
- 11
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
- rom.h
- 0
- 0
-
-
- 2
- 12
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
- sysctl.h
- 0
- 0
-
-
- 2
- 13
- 5
- 0
- 0
- 0
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
- system_TM4C123GH6PM.h
- 0
- 0
-
-
-
-
- QP
- 1
- 0
- 0
- 0
-
- 3
- 14
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_hsm.cpp
- qep_hsm.cpp
- 0
- 0
-
-
- 3
- 15
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qep_msm.cpp
- qep_msm.cpp
- 0
- 0
-
-
- 3
- 16
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_act.cpp
- qf_act.cpp
- 0
- 0
-
-
- 3
- 17
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_actq.cpp
- qf_actq.cpp
- 0
- 0
-
-
- 3
- 18
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_defer.cpp
- qf_defer.cpp
- 0
- 0
-
-
- 3
- 19
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_dyn.cpp
- qf_dyn.cpp
- 0
- 0
-
-
- 3
- 20
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_mem.cpp
- qf_mem.cpp
- 0
- 0
-
-
- 3
- 21
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_ps.cpp
- qf_ps.cpp
- 0
- 0
-
-
- 3
- 22
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qact.cpp
- qf_qact.cpp
- 0
- 0
-
-
- 3
- 23
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qeq.cpp
- qf_qeq.cpp
- 0
- 0
-
-
- 3
- 24
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_qmact.cpp
- qf_qmact.cpp
- 0
- 0
-
-
- 3
- 25
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qf\qf_time.cpp
- qf_time.cpp
- 0
- 0
-
-
- 3
- 26
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qk\qk.cpp
- qk.cpp
- 0
- 0
-
-
-
-
- QP_port
- 1
- 0
- 0
- 0
-
- 4
- 27
- 8
- 0
- 0
- 0
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
- qk_port.cpp
- 0
- 0
-
-
-
-
- QS
- 1
- 0
- 0
- 0
-
- 5
- 28
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs.cpp
- qs.cpp
- 0
- 0
-
-
- 5
- 29
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_fp.cpp
- qs_fp.cpp
- 0
- 0
-
-
- 5
- 30
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qs_rx.cpp
- qs_rx.cpp
- 0
- 0
-
-
- 5
- 31
- 8
- 0
- 0
- 0
- ..\..\..\..\..\src\qs\qstamp.cpp
- qstamp.cpp
- 0
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.uvprojx b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.uvprojx
deleted file mode 100644
index 71837979a..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/armclang/dpp-qk.uvprojx
+++ /dev/null
@@ -1,1826 +0,0 @@
-
-
-
- 2.1
-
- ### uVision Project, (C) Keil Software
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
- 6160000::V6.16::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\dbg\
- dpp-qk
- 1
- 0
- 0
- 1
- 1
- .\dbg\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\dbg\qstamp.o del .\dbg\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\dbg\dpp-qk.bin .\dbg\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 1
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-rel
- 0x4
- ARM-ADS
- 6190000::V6.19::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\rel\
- dpp-qk
- 1
- 0
- 0
- 0
- 0
- .\rel\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\rel\qstamp.o del .\rel\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\rel\dpp-qk.bin .\rel\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 5
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- NDEBUG,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- 0
- 0
- 0
- 0
- 0
- 0
- 2
- 2
- 2
- 2
- 11
-
-
- 1
-
-
-
- 2
- 0
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
- 0
- 0
- 0
- 0
- 0
- 2
-
-
-
-
-
-
-
-
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 2
- 0
-
-
-
-
-
-
-
-
-
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
- dpp-spy
- 0x4
- ARM-ADS
- 6190000::V6.19::ARMCLANG
- 1
-
-
- TM4C123GH6PM
- Texas Instruments
- Keil.TM4C_DFP.1.1.0
- http://www.keil.com/pack/
- IROM(0x00000000,0x040000) IRAM(0x20000000,0x008000) CPUTYPE("Cortex-M4") FPU2 CLOCK(12000000) ELITTLE
-
-
- UL2CM3(-S0 -C0 -P0 -FD20000000 -FC1000 -FN1 -FF0TM4C123_256 -FS00 -FL040000 -FP0($$Device:TM4C123GH6PM$Flash\TM4C123_256.FLM))
- 0
- $$Device:TM4C123GH6PM$Device\Include\TM4C123\TM4C123.h
-
-
-
-
-
-
-
-
-
- $$Device:TM4C123GH6PM$SVD\TM4C123\TM4C123GH6PM.svd
- 0
- 0
-
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
-
- .\spy\
- dpp-qk
- 1
- 0
- 0
- 1
- 1
- .\spy\
- 1
- 0
- 0
-
- 0
- 0
-
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- cmd /c "if exist .\spy\qstamp.o del .\spy\qstamp.o"
-
- 0
- 0
- 0
- 0
-
-
- 1
- 0
- fromelf --bin --output .\spy\dpp-qk.bin .\spy\dpp-qk.axf
-
- 0
- 0
- 0
- 0
-
- 1
-
-
-
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 3
-
-
- 1
-
-
- SARMCM3.DLL
- -MPU
- DCM.DLL
- -pCM4
- SARMCM3.DLL
- -MPU
- TCM.DLL
- -pCM4
-
-
-
- 1
- 0
- 0
- 0
- 16
-
-
-
-
- 1
- 0
- 0
- 1
- 1
- 4097
-
- 1
- BIN\UL2CM3.DLL
-
-
-
-
-
- 0
-
-
-
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 1
- 1
- 0
- 0
- 0
- 0
- 0
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 1
- 0
- 0
- "Cortex-M4"
-
- 0
- 0
- 0
- 1
- 1
- 0
- 0
- 2
- 0
- 0
- 0
- 0
- 0
- 8
- 0
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 1
- 0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 1
- 0x0
- 0x40000
-
-
- 0
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x0
-
-
- 1
- 0x0
- 0x40000
-
-
- 1
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x0
- 0x0
-
-
- 0
- 0x20000000
- 0x8000
-
-
- 0
- 0x0
- 0x0
-
-
-
-
-
- 0
- 2
- 0
- 0
- 1
- 0
- 0
- 0
- 0
- 0
- 3
- 0
- 1
- 0
- 0
- 0
- 3
- 3
- 0
- 0
- 0
- 0
- 0
-
- -fno-exceptions
- Q_SPY,QP_CONFIG
-
- ..\..;..\..\..\..\..\include;..\..\..\..\..\ports\arm-cm\qk\armclang;..\..\..\..\..\3rd_party\CMSIS\Include;..\..\..\..\..\3rd_party\ek-tm4c123gxl
-
-
-
- 1
- 0
- 0
- 0
- 0
- 0
- 0
- 1
- 0
- 4
-
-
- Stack_Size=2048 Heap_Size=16
-
-
-
-
-
- 0
- 0
- 0
- 0
- 1
- 0
- 0x00000000
- 0x20000000
-
- dpp-qk.sct
-
-
- --entry Reset_Handler
-
-
-
-
-
-
-
- Applicatioin
-
-
- philo.cpp
- 8
- ..\..\philo.cpp
-
-
- table.cpp
- 8
- ..\..\table.cpp
-
-
- bsp.cpp
- 8
- ..\bsp.cpp
-
-
- bsp.hpp
- 5
- ..\..\bsp.hpp
-
-
- dpp.hpp
- 5
- ..\..\dpp.hpp
-
-
- main.cpp
- 8
- ..\..\main.cpp
-
-
-
-
- ek-tm4c123gxl
-
-
- system_TM4C123GH6PM.c
- 1
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
- startup_TM4C123GH6PM.s
- 2
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\arm\startup_TM4C123GH6PM.s
-
-
- gpio.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\gpio.h
-
-
- rom.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\rom.h
-
-
- sysctl.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\sysctl.h
-
-
- system_TM4C123GH6PM.h
- 5
- ..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
-
-
- QP
-
-
- qep_hsm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- qep_msm.cpp
- 8
- ..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- qf_act.cpp
- 8
- ..\..\..\..\..\src\qf\qf_act.cpp
-
-
- qf_actq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- qf_defer.cpp
- 8
- ..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- qf_dyn.cpp
- 8
- ..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- qf_mem.cpp
- 8
- ..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- qf_ps.cpp
- 8
- ..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- qf_qact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- qf_qeq.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- qf_qmact.cpp
- 8
- ..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- qf_time.cpp
- 8
- ..\..\..\..\..\src\qf\qf_time.cpp
-
-
- qk.cpp
- 8
- ..\..\..\..\..\src\qk\qk.cpp
-
-
-
-
- QP_port
-
-
- qk_port.cpp
- 8
- ..\..\..\..\..\ports\arm-cm\qk\armclang\qk_port.cpp
-
-
-
-
- QS
-
-
- qs.cpp
- 8
- ..\..\..\..\..\src\qs\qs.cpp
-
-
- qs_fp.cpp
- 8
- ..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- qs_rx.cpp
- 8
- ..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- qstamp.cpp
- 8
- ..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/bsp.cpp b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/bsp.cpp
deleted file mode 100644
index 2011b99ed..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/bsp.cpp
+++ /dev/null
@@ -1,874 +0,0 @@
-//============================================================================
-// Product: DPP example, EK-TM4C123GXL board, QK kernel, MPU isolation
-// Last updated for version 7.3.2
-// Last updated on 2023-12-13
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC.
-//
-// This program is open source software: you can redistribute it and/or
-// modify it under the terms of the GNU General Public License as published
-// by the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// Alternatively, this program may be distributed and modified under the
-// terms of Quantum Leaps commercial licenses, which expressly supersede
-// the GNU General Public License and are specifically designed for
-// licensees interested in retaining the proprietary status of their code.
-//
-// This program is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU General Public License for more details.
-//
-// You should have received a copy of the GNU General Public License
-// along with this program. If not, see .
-//
-// Contact information:
-//
-//
-//============================================================================
-#include "qpcpp.hpp" // QP/C++ real-time embedded framework
-#include "dpp.hpp" // DPP Application interface
-#include "bsp.hpp" // Board Support Package
-
-#include "TM4C123GH6PM.h" // the device specific header (TI)
-#include "rom.h" // the built-in ROM functions (TI)
-#include "sysctl.h" // system control driver (TI)
-#include "gpio.h" // GPIO driver (TI)
-// add other drivers if necessary...
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-Q_DEFINE_THIS_FILE
-
-// Local-scope objects -------------------------------------------------------
-constexpr std::uint32_t LED_RED {1U << 1U};
-constexpr std::uint32_t LED_GREEN {1U << 3U};
-constexpr std::uint32_t LED_BLUE {1U << 2U};
-
-constexpr std::uint32_t BTN_SW1 {1U << 4U};
-constexpr std::uint32_t BTN_SW2 {1U << 0U};
-
-#ifdef Q_SPY
-
- // QSpy source IDs
- QP::QSpyId const l_SysTick_Handler = { 0U };
- QP::QSpyId const l_GPIOPortA_IRQHandler = { 0U };
-
- constexpr std::uint32_t UART_BAUD_RATE {115200U};
- constexpr std::uint32_t UART_FR_TXFE {1U << 7U};
- constexpr std::uint32_t UART_FR_RXFE {1U << 4U};
- constexpr std::uint32_t UART_TXFIFO_DEPTH {16U};
-
- enum AppRecords { // application-specific trace records
- PHILO_STAT = QP::QS_USER,
- PAUSED_STAT,
- };
-
-#endif
-
-//----------------------------------------------------------------------------
-// MPU storage and settings...
-struct MPU_Region {
- std::uint32_t RBAR;
- std::uint32_t RASR;
-};
-
-} // unnamed namespace
-
-//============================================================================
-// Error handler and ISRs...
-extern "C" {
-
-Q_NORETURN Q_onError(char const * const module, int_t const id) {
- // NOTE: this implementation of the error handler is intended only
- // for debugging and MUST be changed for deployment of the application
- // (assuming that you ship your production code with assertions enabled).
- Q_UNUSED_PAR(module);
- Q_UNUSED_PAR(id);
- QS_ASSERTION(module, id, 10000U);
-
-#ifndef NDEBUG
- // light up all LEDs
- GPIOF_AHB->DATA_Bits[LED_GREEN | LED_RED | LED_BLUE] = 0xFFU;
- // for debugging, hang on in an endless loop...
- for (;;) {
- }
-#else
- NVIC_SystemReset();
- for (;;) { // explicitly "no-return"
- }
-#endif
-}
-//............................................................................
-void assert_failed(char const * const module, int_t const id); // prototype
-void assert_failed(char const * const module, int_t const id) {
- Q_onError(module, id);
-}
-
-// ISRs used in the application ==============================================
-
-void SysTick_Handler(void); // prototype
-void SysTick_Handler(void) {
- QK_ISR_ENTRY(); // inform QXK about entering an ISR
-
- QP::QTimeEvt::TICK_X(0U, &l_SysTick_Handler); // time events at rate 0
-
- // Perform the debouncing of buttons. The algorithm for debouncing
- // adapted from the book "Embedded Systems Dictionary" by Jack Ganssle
- // and Michael Barr, page 71.
- static struct {
- std::uint32_t depressed;
- std::uint32_t previous;
- } buttons = { 0U, 0U };
-
- QF_INT_DISABLE();
- QF_MEM_SYS();
-
- std::uint32_t current = ~GPIOF_AHB->DATA_Bits[BTN_SW1 | BTN_SW2];
- std::uint32_t tmp = buttons.depressed; // save the depressed buttons
- buttons.depressed |= (buttons.previous & current); // set depressed
- buttons.depressed &= (buttons.previous | current); // clear released
- buttons.previous = current; // update the history
- tmp ^= buttons.depressed; // changed debounced depressed
- current = buttons.depressed;
-
- QF_MEM_APP();
- QF_INT_ENABLE();
-
- if ((tmp & BTN_SW1) != 0U) { // debounced SW1 state changed?
- if ((current & BTN_SW1) != 0U) { // is SW1 depressed?
- static QP::QEvt const pauseEvt(APP::PAUSE_SIG);
- QP::QActive::PUBLISH(&pauseEvt, &l_SysTick_Handler);
- }
- else { // the button is released
- static QP::QEvt const serveEvt(APP::SERVE_SIG);
- QP::QActive::PUBLISH(&serveEvt, &l_SysTick_Handler);
- }
- }
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-//............................................................................
-// interrupt handler for testing preemptions
-void GPIOPortA_IRQHandler(void); // prototype
-void GPIOPortA_IRQHandler(void) {
- QK_ISR_ENTRY(); // inform QK about entering an ISR
-
- static QP::QEvt const testEvt(APP::TEST_SIG);
- APP::AO_Table->POST(&testEvt, &l_GPIOPortA_IRQHandler);
-
- QK_ISR_EXIT(); // inform QK about exiting an ISR
-}
-
-//............................................................................
-#ifdef Q_SPY
-// ISR for receiving bytes from the QSPY Back-End
-// NOTE: This ISR is "QF-unaware" meaning that it does not interact with
-// the QF/QK and is not disabled. Such ISRs don't need to call
-// QK_ISR_ENTRY/QK_ISR_EXIT and they cannot post or publish events.
-
-void UART0_IRQHandler(void); // prototype
-void UART0_IRQHandler(void) {
- QF_MEM_SYS();
-
- uint32_t status = UART0->RIS; // get the raw interrupt status
- UART0->ICR = status; // clear the asserted interrupts
-
- while ((UART0->FR & UART_FR_RXFE) == 0U) { // while RX FIFO NOT empty
- std::uint8_t b = static_cast(UART0->DR);
- QP::QS::rxPut(b);
- }
-
- QK_ARM_ERRATUM_838869();
-}
-#endif // Q_SPY
-
-#ifdef QF_MEM_ISOLATE
-//............................................................................
-__attribute__(( used ))
-void QF_onMemSys(void) {
- MPU->CTRL = MPU_CTRL_ENABLE_Msk // enable the MPU
- | MPU_CTRL_PRIVDEFENA_Msk; // enable background region
- __ISB();
- __DSB();
-}
-//............................................................................
-__attribute__(( used ))
-void QF_onMemApp() {
- MPU->CTRL = MPU_CTRL_ENABLE_Msk; // enable the MPU
- // but do NOT enable background region
- __ISB();
- __DSB();
-}
-//............................................................................
-#ifdef QF_ON_CONTEXT_SW
-// NOTE: the context-switch callback is called with interrupts DISABLED
-void QF_onContextSw(QP::QActive *prev, QP::QActive *next) {
- if (next != nullptr) {
- MPU->CTRL = 0U; // disable the MPU
-
- MPU_Region const * const region =
- static_cast(next->getThread());
- MPU->RBAR = region[0].RBAR;
- MPU->RASR = region[0].RASR;
- MPU->RBAR = region[1].RBAR;
- MPU->RASR = region[1].RASR;
- MPU->RBAR = region[2].RBAR;
- MPU->RASR = region[2].RASR;
-
- MPU->CTRL = MPU_CTRL_ENABLE_Msk // enable the MPU
- | MPU_CTRL_PRIVDEFENA_Msk; // enable background region
- __ISB();
- __DSB();
- }
-}
-#endif // QF_ON_CONTEXT_SW
-#endif // QF_MEM_ISOLATE
-
-} // extern "C"
-
-//============================================================================
-namespace { // unnamed namespace for local stuff with internal linkage
-
-// Stack .....................................................................
-// NOTE
-// The main stack size (provided here as power of 2), MUST match the actual
-// stack size defined in the linker-script/startup-code.
-constexpr std::uint32_t STACK_SIZE_POW2 {11U};
-
-// Table AO...................................................................
-// size of Table instance, as power-of-2
-constexpr std::uint32_t TABLE_SIZE_POW2 {6};
-
-__attribute__((aligned((1U << TABLE_SIZE_POW2))))
-static std::uint8_t Table_sto[1U << TABLE_SIZE_POW2];
-
-#ifdef QF_MEM_ISOLATE
-static MPU_Region const MPU_Table[3] = {
- { reinterpret_cast(Table_sto) + 0x10U,//---- region #0
- ((TABLE_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { GPIOF_AHB_BASE + 0x11U, //---- region #1
- ((9U - 1U) << MPU_RASR_SIZE_Pos) // 2^9=512B size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (0U << MPU_RASR_C_Pos) // C=0
- + (1U << MPU_RASR_B_Pos) // B=1
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { 0U + 0x12U, //---- region #2
- 0U },
-};
-#endif
-
-// Philo AOs..................................................................
-// size of Philo instance, as power-of-2
-constexpr std::uint32_t PHILO_SIZE_POW2 {6};
-
-__attribute__((aligned((1U << PHILO_SIZE_POW2))))
-static std::uint8_t Philo_sto[APP::N_PHILO][1U << PHILO_SIZE_POW2];
-
-constexpr std::uint32_t PHILO_SHARED_SIZE_POW2 {5U};
-__attribute__((aligned((1U << PHILO_SHARED_SIZE_POW2))))
-static union {
- std::uint32_t rnd_seed;
- std::uint8_t byteso[1U << PHILO_SHARED_SIZE_POW2];
-} Philo_shared_sto;
-
-#ifdef QF_MEM_ISOLATE
-static MPU_Region const MPU_Philo[APP::N_PHILO][3] = {
- {{ reinterpret_cast(Philo_sto[0]) + 0x10U,//---- region #0
- ((PHILO_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { reinterpret_cast(&Philo_shared_sto) + 0x11U,//---- region #1
- ((PHILO_SHARED_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { 0U + 0x12U, //---- region #2
- 0U }},
- {{ reinterpret_cast(Philo_sto[1]) + 0x10U,//---- region #0
- ((PHILO_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { reinterpret_cast(&Philo_shared_sto) + 0x11U,//---- region #1
- ((PHILO_SHARED_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { 0U + 0x12U, //---- region #2
- 0U }},
- {{ reinterpret_cast(Philo_sto[2]) + 0x10U,//---- region #0
- ((PHILO_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { reinterpret_cast(&Philo_shared_sto) + 0x11U,//---- region #1
- ((PHILO_SHARED_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { 0U + 0x12U, //---- region #2
- 0U }},
- {{ reinterpret_cast(Philo_sto[3]) + 0x10U,//---- region #0
- ((PHILO_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { reinterpret_cast(&Philo_shared_sto) + 0x11U,//---- region #1
- ((PHILO_SHARED_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { 0U + 0x12U, //---- region #2
- 0U }},
- {{ reinterpret_cast(Philo_sto[4]) + 0x10U,//---- region #0
- ((PHILO_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { reinterpret_cast(&Philo_shared_sto) + 0x11U,//---- region #1
- ((PHILO_SHARED_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk }, // region enable
- { 0U + 0x12U, //---- region #2
- 0U }},
-};
-#endif
-
-// Shared Event-pools.........................................................
-constexpr std::uint32_t EPOOLS_SIZE_POW2 {8U};
-
-__attribute__((aligned((1U << EPOOLS_SIZE_POW2))))
-static struct EPools {
- QF_MPOOL_EL(APP::TableEvt) smlPool[2*APP::N_PHILO];
- // ... other pools
-} EPools_sto;
-static_assert(sizeof(EPools_sto) <= (1U << EPOOLS_SIZE_POW2),
- "Insufficient storage for Event Pools");
-
-//............................................................................
-#ifdef QF_MEM_ISOLATE
-static void TM4C123GXL_MPU_setup() {
-
- SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk;
-
- MPU->CTRL = 0U; // disable the MPU
-
- // region #7: NULL-pointer protection region
- MPU->RBAR = 0x00000000U + 0x17U; // base address + region #7
- MPU->RASR = ((8U - 1U) << MPU_RASR_SIZE_Pos) // 2^8=256B size
- + (0U << MPU_RASR_AP_Pos) // PA:na/UA:na
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (0U << MPU_RASR_S_Pos) // S=0
- + (0U << MPU_RASR_C_Pos) // C=0
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk; // region enable
-
- // region #6: stack region
- MPU->RBAR = 0x20000000U + 0x16U; // base address + region #6
- MPU->RASR = ((STACK_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk; // region enable
-
- // region #5: ROM region for TM4C123GXL, whole 256K
- MPU->RBAR = 0x00000000U + 0x15U; // base address + region #5
- MPU->RASR = ((18U - 1U) << MPU_RASR_SIZE_Pos) // 2^18=256K size
- + (6U << MPU_RASR_AP_Pos) // PA:ro/UA:ro
- + (0U << MPU_RASR_XN_Pos) // XN=0
- + (0U << MPU_RASR_S_Pos) // S=0
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk; // region enable
-
- // region #4: Event-pools region
- MPU->RBAR = reinterpret_cast(&EPools_sto) + 0x14U;// region #4
- MPU->RASR = ((EPOOLS_SIZE_POW2 - 1U) << MPU_RASR_SIZE_Pos) // size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk; // region enable
-
-#ifdef Q_SPY
- // region #3: QS-filters region
- MPU->RBAR = reinterpret_cast(&QP::QS::filt_) + 0x13U;// region #3
- MPU->RASR = ((5U - 1U) << MPU_RASR_SIZE_Pos) // 2^5=32B size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (1U << MPU_RASR_XN_Pos) // XN=1
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk; // region enable
-#endif
-
- // region #0: temporary 4G region for the initial transient
- MPU->RBAR = 0x00000000U + 0x10U; // base address + region #0
- MPU->RASR = ((32U - 1U) << MPU_RASR_SIZE_Pos) // 2^32=4G size
- + (3U << MPU_RASR_AP_Pos) // PA:rw/UA:rw
- + (0U << MPU_RASR_XN_Pos) // XN=0
- + (1U << MPU_RASR_S_Pos) // S=1
- + (1U << MPU_RASR_C_Pos) // C=1
- + (0U << MPU_RASR_B_Pos) // B=0
- + (0U << MPU_RASR_TEX_Pos) // TEX=0
- + MPU_RASR_ENABLE_Msk; // region enable
-
- MPU->CTRL = MPU_CTRL_ENABLE_Msk; // enable the MPU
- // but do NOT enable background region
- __ISB();
- __DSB();
-}
-#endif
-
-} // unnamed namespace
-
-//============================================================================
-namespace APP {
-
-// "opaque" pointer to AO
-QP::QActive * const AO_Table = reinterpret_cast(Table_sto);
-
-QP::QActive * const AO_Philo[APP::N_PHILO] = {
- reinterpret_cast(Philo_sto[0]), // "opaque" pointer
- reinterpret_cast(Philo_sto[1]), // "opaque" pointer
- reinterpret_cast(Philo_sto[2]), // "opaque" pointer
- reinterpret_cast(Philo_sto[3]), // "opaque" pointer
- reinterpret_cast(Philo_sto[4]), // "opaque" pointer
-};
-
-} // namespace APP
-
-//============================================================================
-namespace BSP {
-
-void init() {
-#ifdef QF_MEM_ISOLATE
- // setup the MPU
- TM4C123GXL_MPU_setup();
-#endif
-
- // NOTE: SystemInit() has been already called from the startup code
- // but SystemCoreClock needs to be updated
- SystemCoreClockUpdate();
-
- // NOTE: The VFP (hardware Floating Point) unit is configured by QK
-
- // enable clock for to the peripherals used by this application...
- SYSCTL->RCGCGPIO |= (1U << 5U); // enable Run mode for GPIOF
- SYSCTL->GPIOHBCTL |= (1U << 5U); // enable AHB for GPIOF
- __ISB();
- __DSB();
-
- // configure LEDs (digital output)
- GPIOF_AHB->DIR |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DEN |= (LED_RED | LED_BLUE | LED_GREEN);
- GPIOF_AHB->DATA_Bits[LED_RED | LED_BLUE | LED_GREEN] = 0U;
-
- // configure switches...
-
- // unlock access to the SW2 pin because it is PROTECTED
- GPIOF_AHB->LOCK = 0x4C4F434BU; // unlock GPIOCR register for SW2
- // commit the write (cast const away)
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x01U;
-
- GPIOF_AHB->DIR &= ~(BTN_SW1 | BTN_SW2); // input
- GPIOF_AHB->DEN |= (BTN_SW1 | BTN_SW2); // digital enable
- GPIOF_AHB->PUR |= (BTN_SW1 | BTN_SW2); // pull-up resistor enable
-
- *(uint32_t volatile *)&GPIOF_AHB->CR = 0x00U;
- GPIOF_AHB->LOCK = 0x0; // lock GPIOCR register for SW2
-
- BSP::randomSeed(1234U);
-
- // initialize the QS software tracing...
- if (!QS_INIT(nullptr)) {
- Q_ERROR();
- }
-
- // dictionaries...
- QS_OBJ_DICTIONARY(&l_SysTick_Handler);
- QS_OBJ_DICTIONARY(&l_GPIOPortA_IRQHandler);
- QS_USR_DICTIONARY(PHILO_STAT);
- QS_USR_DICTIONARY(PAUSED_STAT);
-
- QS_ONLY(APP::produce_sig_dict());
-
- // setup the QS filters...
- QS_GLB_FILTER(QP::QS_ALL_RECORDS); // all records
- QS_GLB_FILTER(-QP::QS_QF_TICK); // exclude the clock tick
- QS_LOC_FILTER(-(APP::N_PHILO + 3U)); // exclude prio. of AO_Ticker0
-}
-//............................................................................
-void start() {
- // initialize event pools
- QP::QF::poolInit(EPools_sto.smlPool,
- sizeof(EPools_sto.smlPool),
- sizeof(EPools_sto.smlPool[0]));
-
- // initialize publish-subscribe
- static QP::QSubscrList subscrSto[APP::MAX_PUB_SIG];
- QP::QActive::psInit(subscrSto, Q_DIM(subscrSto));
-
- // instantiate and start AOs/threads...
-
- static QP::QEvt const *philoQueueSto[APP::N_PHILO][10];
- for (std::uint8_t n = 0U; n < APP::N_PHILO; ++n) {
-#ifdef QF_MEM_ISOLATE
- APP::Philo_ctor(n, Philo_sto[n], sizeof(Philo_sto[n]), MPU_Philo[n]);
-#else
- APP::Philo_ctor(n, Philo_sto[n], sizeof(Philo_sto[n]));
-#endif
- APP::AO_Philo[n]->start(
-
- // NOTE: set the preemption-threshold of all Philos to
- // the same level, so that they cannot preempt each other.
- Q_PRIO(n + 3U, APP::N_PHILO + 2U), // QF-prio/pre-thre.
-
- philoQueueSto[n], // event queue storage
- Q_DIM(philoQueueSto[n]), // queue length [events]
- nullptr, 0U); // no stack storage
- }
-
- static QP::QEvt const *tableQueueSto[APP::N_PHILO];
-#ifdef QF_MEM_ISOLATE
- APP::Table_ctor(Table_sto, sizeof(Table_sto), MPU_Table);
-#else
- APP::Table_ctor(Table_sto, sizeof(Table_sto));
-#endif
- APP::AO_Table->start(
- APP::N_PHILO + 7U, // QP prio. of the AO
- tableQueueSto, // event queue storage
- Q_DIM(tableQueueSto), // queue length [events]
- nullptr, 0U); // no stack storage
-}
-//............................................................................
-void displayPhilStat(std::uint8_t n, char const *stat) {
- Q_UNUSED_PAR(n);
-
- GPIOF_AHB->DATA_Bits[LED_GREEN] = ((stat[0] == 'e') ? LED_GREEN : 0U);
-
- // app-specific trace record...
- QS_BEGIN_ID(PHILO_STAT, APP::AO_Table->getPrio())
- QS_U8(1, n); // Philosopher number
- QS_STR(stat); // Philosopher status
- QS_END()
-}
-//............................................................................
-void displayPaused(std::uint8_t const paused) {
- GPIOF_AHB->DATA_Bits[LED_BLUE] = ((paused != 0U) ? LED_BLUE : 0U);
-
- // application-specific trace record
- QS_BEGIN_ID(PAUSED_STAT, APP::AO_Table->getPrio())
- QS_U8(1, paused); // Paused status
- QS_END()
-}
-//............................................................................
-void randomSeed(std::uint32_t seed) {
- Philo_shared_sto.rnd_seed = seed;
-}
-//............................................................................
-std::uint32_t random() { // a very cheap pseudo-random-number generator
- // Some floating point code is to exercise the VFP...
- float volatile x = 3.1415926F;
- x = x + 2.7182818F;
-
- QP::QSchedStatus lockStat = QP::QK::schedLock(APP::N_PHILO);
- // "Super-Duper" Linear Congruential Generator (LCG)
- // LCG(2^32, 3*7*11*13*23, 0, seed)
- //
- std::uint32_t rnd = Philo_shared_sto.rnd_seed * (3U*7U*11U*13U*23U);
- Philo_shared_sto.rnd_seed = rnd; // set for the next time
- QP::QK::schedUnlock(lockStat);
-
- return (rnd >> 8U);
-}
-//............................................................................
-void ledOn() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0xFFU;
-}
-//............................................................................
-void ledOff() {
- GPIOF_AHB->DATA_Bits[LED_RED] = 0x00U;
-}
-//............................................................................
-void terminate(int16_t result) {
- Q_UNUSED_PAR(result);
-}
-
-} // namespace BSP
-
-//============================================================================
-// namespace QP
-namespace QP {
-
-// QF callbacks...
-void QF::onStartup() {
- // set up the SysTick timer to fire at BSP::TICKS_PER_SEC rate
- SysTick_Config(SystemCoreClock / BSP::TICKS_PER_SEC);
-
- // assign all priority bits for preemption-prio. and none to sub-prio.
- NVIC_SetPriorityGrouping(0U);
-
- // set priorities of ALL ISRs used in the system, see NOTE1
- NVIC_SetPriority(UART0_IRQn, 0U); // kernel unaware interrupt
- NVIC_SetPriority(GPIOA_IRQn, QF_AWARE_ISR_CMSIS_PRI + 0U);
- NVIC_SetPriority(SysTick_IRQn, QF_AWARE_ISR_CMSIS_PRI + 1U);
- // ...
-
- // enable IRQs...
- NVIC_EnableIRQ(GPIOA_IRQn);
-
-#ifdef Q_SPY
- NVIC_EnableIRQ(UART0_IRQn); // UART interrupt used for QS-RX
-#endif
-}
-//............................................................................
-void QF::onCleanup() {
-}
-//............................................................................
-void QK::onIdle() {
-
- // toggle the User LED on and then off, see NOTE3
- QF_INT_DISABLE();
- QF_MEM_SYS();
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0xFFU; // turn the Blue LED on
- GPIOF_AHB->DATA_Bits[LED_BLUE] = 0U; // turn the Blue LED off
- QF_MEM_APP();
- QF_INT_ENABLE();
-
- // Some floating point code is to exercise the VFP...
- float volatile x = 1.73205F;
- x = x * 1.73205F;
-
-#ifdef Q_SPY
- QF_INT_DISABLE();
- QF_MEM_SYS();
- QS::rxParse(); // parse all the received bytes
- QF_MEM_APP();
- QF_INT_ENABLE();
- QF_CRIT_EXIT_NOP();
-
- QF_INT_DISABLE();
- QF_MEM_SYS();
- if ((UART0->FR & UART_FR_TXFE) != 0U) { // TX done?
- std::uint16_t fifo = UART_TXFIFO_DEPTH; // max bytes we can accept
-
- // try to get next contiguous block to transmit
- std::uint8_t const *block = QS::getBlock(&fifo);
-
- while (fifo-- != 0U) { // any bytes in the block?
- UART0->DR = *block++; // put into the FIFO
- }
- }
- QF_MEM_APP();
- QF_INT_ENABLE();
-#elif defined NDEBUG
- // Put the CPU and peripherals to the low-power mode.
- // you might need to customize the clock management for your application,
- // see the datasheet for your particular Cortex-M MCU.
- //
- __WFI(); // Wait-For-Interrupt
-#endif
-}
-
-//============================================================================
-// QS facilities...
-#ifdef Q_SPY
-namespace QS {
-
-#ifdef QF_MEM_ISOLATE
-// Shared QS filters...
-__attribute__((aligned(32)))
-Filter filt_;
-#endif
-
-//............................................................................
-bool onStartup(void const *arg) {
- Q_UNUSED_PAR(arg);
-
- static std::uint8_t qsTxBuf[2*1024]; // buffer for QS transmit channel
- initBuf(qsTxBuf, sizeof(qsTxBuf));
-
- static std::uint8_t qsRxBuf[100]; // buffer for QS receive channel
- rxInitBuf(qsRxBuf, sizeof(qsRxBuf));
-
- // enable clock for UART0 and GPIOA (used by UART0 pins)
- SYSCTL->RCGCUART |= (1U << 0U); // enable Run mode for UART0
- SYSCTL->RCGCGPIO |= (1U << 0U); // enable Run mode for GPIOA
-
- // configure UART0 pins for UART operation
- uint32_t tmp = (1U << 0U) | (1U << 1U);
- GPIOA->DIR &= ~tmp;
- GPIOA->SLR &= ~tmp;
- GPIOA->ODR &= ~tmp;
- GPIOA->PUR &= ~tmp;
- GPIOA->PDR &= ~tmp;
- GPIOA->AMSEL &= ~tmp; // disable analog function on the pins
- GPIOA->AFSEL |= tmp; // enable ALT function on the pins
- GPIOA->DEN |= tmp; // enable digital I/O on the pins
- GPIOA->PCTL &= ~0x00U;
- GPIOA->PCTL |= 0x11U;
-
- // configure the UART for the desired baud rate, 8-N-1 operation
- tmp = (((SystemCoreClock * 8U) / UART_BAUD_RATE) + 1U) / 2U;
- UART0->IBRD = tmp / 64U;
- UART0->FBRD = tmp % 64U;
- UART0->LCRH = (0x3U << 5U); // configure 8-N-1 operation
- UART0->LCRH |= (0x1U << 4U); // enable FIFOs
- UART0->CTL = (1U << 0U) // UART enable
- | (1U << 8U) // UART TX enable
- | (1U << 9U); // UART RX enable
-
- // configure UART interrupts (for the RX channel)
- UART0->IM |= (1U << 4U) | (1U << 6U); // enable RX and RX-TO interrupt
- UART0->IFLS |= (0x2U << 2U); // interrupt on RX FIFO half-full
- // NOTE: do not enable the UART0 interrupt yet. Wait till QF_onStartup()
-
- // configure TIMER5 to produce QS time stamp
- SYSCTL->RCGCTIMER |= (1U << 5U); // enable run mode for Timer5
- TIMER5->CTL = 0U; // disable Timer1 output
- TIMER5->CFG = 0x0U; // 32-bit configuration
- TIMER5->TAMR = (1U << 4U) | 0x02U; // up-counting periodic mode
- TIMER5->TAILR= 0xFFFFFFFFU; // timer interval
- TIMER5->ICR = 0x1U; // TimerA timeout flag bit clears
- TIMER5->CTL |= (1U << 0U); // enable TimerA module
-
- return true; // return success
-}
-//............................................................................
-void onCleanup() {
-}
-//............................................................................
-QSTimeCtr onGetTime() { // NOTE: invoked with interrupts DISABLED
- return TIMER5->TAV;
-}
-//............................................................................
-// NOTE:
-// No critical section in QS::onFlush() to avoid nesting of critical sections
-// in case QS::onFlush() is called from Q_onError().
-void onFlush() {
- for (;;) {
- std::uint16_t b = getByte();
- if (b != QS_EOD) {
- while ((UART0->FR & UART_FR_TXFE) == 0U) { // while TXE not empty
- }
- UART0->DR = b; // put into the DR register
- }
- else {
- break;
- }
- }
-}
-//............................................................................
-void onReset() {
- NVIC_SystemReset();
-}
-//............................................................................
-void onCommand(std::uint8_t cmdId, std::uint32_t param1,
- std::uint32_t param2, std::uint32_t param3)
-{
- Q_UNUSED_PAR(cmdId);
- Q_UNUSED_PAR(param1);
- Q_UNUSED_PAR(param2);
- Q_UNUSED_PAR(param3);
-}
-
-} // namespace QS
-#endif // Q_SPY
-//----------------------------------------------------------------------------
-
-} // namespace QP
-
-//============================================================================
-// NOTE1:
-// The QF_AWARE_ISR_CMSIS_PRI constant from the QF port specifies the highest
-// ISR priority that is disabled by the QF framework. The value is suitable
-// for the NVIC_SetPriority() CMSIS function.
-//
-// Only ISRs prioritized at or below the QF_AWARE_ISR_CMSIS_PRI level (i.e.,
-// with the numerical values of priorities equal or higher than
-// QF_AWARE_ISR_CMSIS_PRI) are allowed to call the QK_ISR_ENTRY/
-// QK_ISR_ENTRY macros or any other QF/QK services. These ISRs are
-// "QF-aware".
-//
-// Conversely, any ISRs prioritized above the QF_AWARE_ISR_CMSIS_PRI priority
-// level (i.e., with the numerical values of priorities less than
-// QF_AWARE_ISR_CMSIS_PRI) are never disabled and are not aware of the kernel.
-// Such "QF-unaware" ISRs cannot call ANY QF/QK services. In particular they
-// can NOT call the macros QK_ISR_ENTRY/QK_ISR_ENTRY. The only mechanism
-// by which a "QF-unaware" ISR can communicate with the QF framework is by
-// triggering a "QF-aware" ISR, which can post/publish events.
-//
-// NOTE2:
-// The User LED is used to visualize the idle loop activity. The brightness
-// of the LED is proportional to the frequency of the idle loop.
-// Please note that the LED is toggled with interrupts locked, so no interrupt
-// execution time contributes to the brightness of the User LED.
-//
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/Makefile b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/Makefile
deleted file mode 100644
index a2761cdd9..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/Makefile
+++ /dev/null
@@ -1,310 +0,0 @@
-##############################################################################
-# Product: Makefile for QP/C++ on EK-TM4C123GXL, QK kernel, GNU-ARM
-# Last Updated for Version: 7.3.3
-# Date of the Last Update: 2024-01-29
-#
-# Q u a n t u m L e a P s
-# ------------------------
-# Modern Embedded Software
-#
-# Copyright (C) 2005 Quantum Leaps, LLC.
-#
-# This program is open source software: you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as published
-# by the Free Software Foundation, either version 3 of the License, or
-# (at your option) any later version.
-#
-# Alternatively, this program may be distributed and modified under the
-# terms of Quantum Leaps commercial licenses, which expressly supersede
-# the GNU General Public License and are specifically designed for
-# licensees interested in retaining the proprietary status of their code.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with this program. If not, see .
-#
-# Contact information:
-#
-#
-##############################################################################
-# examples of invoking this Makefile:
-# building configurations: Debug (default), Release, and Spy
-# make
-# make CONF=rel
-# make CONF=spy
-#
-# cleaning configurations: Debug (default), Release, and Spy
-# make clean
-# make CONF=rel clean
-# make CONF=spy clean
-#
-# NOTE:
-# To use this Makefile on Windows, you will need the GNU make utility, which
-# is included in the Qtools collection for Windows, see:
-# https://github.com/QuantumLeaps/qtools
-
-#-----------------------------------------------------------------------------
-# project name
-#
-PROJECT := dpp-qk
-
-#-----------------------------------------------------------------------------
-# project directories
-#
-
-# location of the QP/C++ framework (if not provided in an environment var.)
-ifeq ($(QPCPP),)
-QPCPP := ../../../../..
-endif
-
-# QP port used in this project
-QP_PORT_DIR := $(QPCPP)/ports/arm-cm/qk/gnu
-
-# list of all source directories used by this project
-VPATH = \
- .. \
- ../.. \
- $(QPCPP)/src/qf \
- $(QPCPP)/src/qk \
- $(QPCPP)/src/qs \
- $(QP_PORT_DIR) \
- $(QPCPP)/3rd_party/ek-tm4c123gxl \
- $(QPCPP)/3rd_party/ek-tm4c123gxl/gnu
-
-# list of all include directories needed by this project
-INCLUDES = \
- -I../.. \
- -I$(QPCPP)/include \
- -I$(QP_PORT_DIR) \
- -I$(QPCPP)/3rd_party/CMSIS/Include \
- -I$(QPCPP)/3rd_party/ek-tm4c123gxl
-
-#-----------------------------------------------------------------------------
-# files
-#
-
-# assembler source files
-ASM_SRCS :=
-
-# C source files
-C_SRCS := \
- system_TM4C123GH6PM.c \
- startup_TM4C123GH6PM.c
-
-# C++ source files
-CPP_SRCS := \
- bsp.cpp \
- main.cpp \
- philo.cpp \
- table.cpp
-
-OUTPUT := $(PROJECT)
-LD_SCRIPT := $(PROJECT).ld
-
-QP_SRCS := \
- qep_hsm.cpp \
- qep_msm.cpp \
- qf_act.cpp \
- qf_actq.cpp \
- qf_defer.cpp \
- qf_dyn.cpp \
- qf_mem.cpp \
- qf_ps.cpp \
- qf_qact.cpp \
- qf_qeq.cpp \
- qf_qmact.cpp \
- qf_time.cpp \
- qk.cpp \
- qk_port.cpp
-
-QP_ASMS :=
-
-QS_SRCS := \
- qs.cpp \
- qs_rx.cpp \
- qs_fp.cpp
-
-LIB_DIRS :=
-LIBS :=
-
-# defines
-DEFINES := -DQP_CONFIG
-
-# ARM CPU, ARCH, FPU, and Float-ABI types...
-# ARM_CPU: [cortex-m0 | cortex-m0plus | cortex-m1 | cortex-m3 | cortex-m4]
-# ARM_FPU: [ | vfp]
-# FLOAT_ABI: [ | soft | softfp | hard]
-#
-ARM_CPU := -mcpu=cortex-m4
-ARM_FPU := -mfpu=fpv4-sp-d16
-FLOAT_ABI := -mfloat-abi=hard
-
-#-----------------------------------------------------------------------------
-# GNU-ARM toolset (NOTE: You need to adjust to your machine)
-# see https://developer.arm.com/open-source/gnu-toolchain/gnu-rm/downloads
-#
-ifeq ($(GNU_ARM),)
-GNU_ARM := $(QTOOLS)/gnu_arm-none-eabi
-endif
-
-# make sure that the GNU-ARM toolset exists...
-ifeq ("$(wildcard $(GNU_ARM))","")
-$(error GNU_ARM toolset not found. Please adjust the Makefile)
-endif
-
-CC := $(GNU_ARM)/bin/arm-none-eabi-gcc
-CPP := $(GNU_ARM)/bin/arm-none-eabi-g++
-AS := $(GNU_ARM)/bin/arm-none-eabi-as
-LINK := $(GNU_ARM)/bin/arm-none-eabi-g++
-BIN := $(GNU_ARM)/bin/arm-none-eabi-objcopy
-
-
-##############################################################################
-# Typically you should not need to change anything below this line
-
-# basic utilities (included in QTools for Windows), see:
-# https://www.state-machine.com/qtools
-
-MKDIR := mkdir
-RM := rm
-
-#-----------------------------------------------------------------------------
-# build options for various configurations for ARM Cortex-M
-#
-
-# combine all the sources...
-CPP_SRCS += $(QP_SRCS)
-ASM_SRCS += $(QP_ASMS)
-
-ifeq (rel, $(CONF)) # Release configuration ..................................
-
-BIN_DIR := rel
-
-ASFLAGS = $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-CPPFLAGS = -c $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O2 $(INCLUDES) $(DEFINES) -DNDEBUG
-
-else ifeq (spy, $(CONF)) # Spy configuration ................................
-
-BIN_DIR := spy
-
-CPP_SRCS += $(QS_SRCS)
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES) -DQ_SPY
-
-else # default Debug configuration ..........................................
-
-BIN_DIR := dbg
-
-ASFLAGS = -g $(ARM_CPU) $(ARM_FPU) $(ASM_CPU) $(ASM_FPU)
-
-CFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections \
- -O $(INCLUDES) $(DEFINES)
-
-CPPFLAGS = -c -g $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb -Wall \
- -ffunction-sections -fdata-sections -fno-rtti -fno-exceptions \
- -O $(INCLUDES) $(DEFINES)
-
-endif # ......................................................................
-
-
-LINKFLAGS = -T$(LD_SCRIPT) $(ARM_CPU) $(ARM_FPU) $(FLOAT_ABI) -mthumb \
- -specs=nosys.specs -specs=nano.specs \
- -Wl,-Map,$(BIN_DIR)/$(OUTPUT).map,--cref,--gc-sections $(LIB_DIRS)
-
-
-ASM_OBJS := $(patsubst %.s,%.o, $(notdir $(ASM_SRCS)))
-C_OBJS := $(patsubst %.c,%.o, $(notdir $(C_SRCS)))
-CPP_OBJS := $(patsubst %.cpp,%.o,$(notdir $(CPP_SRCS)))
-
-TARGET_BIN := $(BIN_DIR)/$(OUTPUT).bin
-TARGET_ELF := $(BIN_DIR)/$(OUTPUT).elf
-ASM_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(ASM_OBJS))
-C_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(C_OBJS))
-C_DEPS_EXT := $(patsubst %.o, %.d, $(C_OBJS_EXT))
-CPP_OBJS_EXT := $(addprefix $(BIN_DIR)/, $(CPP_OBJS))
-CPP_DEPS_EXT := $(patsubst %.o, %.d, $(CPP_OBJS_EXT))
-
-# create $(BIN_DIR) if it does not exist
-ifeq ("$(wildcard $(BIN_DIR))","")
-$(shell $(MKDIR) $(BIN_DIR))
-endif
-
-#-----------------------------------------------------------------------------
-# rules
-#
-
-all: $(TARGET_BIN)
-#all: $(TARGET_ELF)
-
-$(TARGET_BIN): $(TARGET_ELF)
- $(BIN) -O binary $< $@
-
-$(TARGET_ELF) : $(ASM_OBJS_EXT) $(C_OBJS_EXT) $(CPP_OBJS_EXT)
- $(CPP) $(CPPFLAGS) $(QPCPP)/src/qs/qstamp.cpp -o $(BIN_DIR)/qstamp.o
- $(LINK) $(LINKFLAGS) -o $@ $^ $(BIN_DIR)/qstamp.o $(LIBS)
-
-$(BIN_DIR)/%.d : %.c
- $(CC) -MM -MT $(@:.d=.o) $(CFLAGS) $< > $@
-
-$(BIN_DIR)/%.d : %.cpp
- $(CPP) -MM -MT $(@:.d=.o) $(CPPFLAGS) $< > $@
-
-$(BIN_DIR)/%.o : %.s
- $(AS) $(ASFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.c
- $(CC) $(CFLAGS) $< -o $@
-
-$(BIN_DIR)/%.o : %.cpp
- $(CPP) $(CPPFLAGS) $< -o $@
-
-.PHONY : clean show
-
-# include dependency files only if our goal depends on their existence
-ifneq ($(MAKECMDGOALS),clean)
- ifneq ($(MAKECMDGOALS),show)
--include $(C_DEPS_EXT) $(CPP_DEPS_EXT)
- endif
-endif
-
-
-clean:
- -$(RM) $(BIN_DIR)/*.o \
- $(BIN_DIR)/*.d \
- $(BIN_DIR)/*.bin \
- $(BIN_DIR)/*.elf \
- $(BIN_DIR)/*.map
-
-show:
- @echo PROJECT = $(PROJECT)
- @echo CONF = $(CONF)
- @echo DEFINES = $(DEFINES)
- @echo ASM_FPU = $(ASM_FPU)
- @echo ASM_SRCS = $(ASM_SRCS)
- @echo C_SRCS = $(C_SRCS)
- @echo CPP_SRCS = $(CPP_SRCS)
- @echo ASM_OBJS_EXT = $(ASM_OBJS_EXT)
- @echo C_OBJS_EXT = $(C_OBJS_EXT)
- @echo C_DEPS_EXT = $(C_DEPS_EXT)
- @echo CPP_DEPS_EXT = $(CPP_DEPS_EXT)
- @echo TARGET_ELF = $(TARGET_ELF)
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/dpp-qk.ld b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/dpp-qk.ld
deleted file mode 100644
index 5139ce62b..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/dpp-qk.ld
+++ /dev/null
@@ -1,139 +0,0 @@
-/*****************************************************************************
-* Product: Linker script for EK-TM4C123GXL, GNU-ARM linker
-* Last Updated for Version: 5.9.8
-* Date of the Last Update: 2017-09-13
-*
-* Q u a n t u m L e a P s
-* ---------------------------
-* innovating embedded systems
-*
-* Copyright (C) Quantum Leaps, LLC. All rights reserved.
-*
-* This program is open source software: you can redistribute it and/or
-* modify it under the terms of the GNU General Public License as published
-* by the Free Software Foundation, either version 3 of the License, or
-* (at your option) any later version.
-*
-* Alternatively, this program may be distributed and modified under the
-* terms of Quantum Leaps commercial licenses, which expressly supersede
-* the GNU General Public License and are specifically designed for
-* licensees interested in retaining the proprietary status of their code.
-*
-* This program is distributed in the hope that it will be useful,
-* but WITHOUT ANY WARRANTY; without even the implied warranty of
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-* GNU General Public License for more details.
-*
-* You should have received a copy of the GNU General Public License
-* along with this program. If not, see .
-*
-* Contact information:
-* Web : http://www.state-machine.com
-* Email: info@state-machine.com
-*****************************************************************************/
-OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
-OUTPUT_ARCH(arm)
-ENTRY(Reset_Handler) /* entry Point */
-
-MEMORY { /* memory map of Tiva TM4C123GH6PM */
- ROM (rx) : ORIGIN = 0x00000000, LENGTH = 256K
- RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
-}
-
-/* The size of the stack used by the application. NOTE: you need to adjust */
-STACK_SIZE = 2048;
-
-/* The size of the heap used by the application. NOTE: you need to adjust */
-HEAP_SIZE = 0;
-
-SECTIONS {
-
- .isr_vector : { /* the vector table goes FIRST into ROM */
- KEEP(*(.isr_vector)) /* vector table */
- . = ALIGN(4);
- } >ROM
-
- .text : { /* code and constants */
- . = ALIGN(4);
- *(.text) /* .text sections (code) */
- *(.text*) /* .text* sections (code) */
- *(.rodata) /* .rodata sections (constants, strings, etc.) */
- *(.rodata*) /* .rodata* sections (constants, strings, etc.) */
-
- KEEP (*(.init))
- KEEP (*(.fini))
-
- . = ALIGN(4);
- } >ROM
-
- .preinit_array : {
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP (*(.preinit_array*))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- } >ROM
-
- .init_array : {
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP (*(SORT(.init_array.*)))
- KEEP (*(.init_array*))
- PROVIDE_HIDDEN (__init_array_end = .);
- } >ROM
-
- .fini_array : {
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP (*(.fini_array*))
- KEEP (*(SORT(.fini_array.*)))
- PROVIDE_HIDDEN (__fini_array_end = .);
- } >ROM
-
- _etext = .; /* global symbols at end of code */
-
- .stack : {
- __stack_start__ = .;
- . = . + STACK_SIZE;
- . = ALIGN(4);
- __stack_end__ = .;
- } >RAM
-
- .data : AT (_etext) {
- __data_load = LOADADDR (.data);
- __data_start = .;
- *(.data) /* .data sections */
- *(.data*) /* .data* sections */
- . = ALIGN(4);
- __data_end__ = .;
- _edata = __data_end__;
- } >RAM
-
- .bss : {
- __bss_start__ = .;
- *(.bss)
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- _ebss = .; /* define a global symbol at bss end */
- __bss_end__ = .;
- } >RAM
-
- __exidx_start = .;
- .ARM.exidx : { *(.ARM.exidx* .gnu.linkonce.armexidx.*) } >RAM
- __exidx_end = .;
-
- PROVIDE ( end = _ebss );
- PROVIDE ( _end = _ebss );
- PROVIDE ( __end__ = _ebss );
-
- .heap : {
- __heap_start__ = .;
- . = . + HEAP_SIZE;
- . = ALIGN(4);
- __heap_end__ = .;
- } >RAM
-
- /* Remove information from the standard libraries */
- /DISCARD/ : {
- libc.a ( * )
- libm.a ( * )
- libgcc.a ( * )
- }
-}
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/flash.bat b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/flash.bat
deleted file mode 100644
index cb2a3886e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/gnu/flash.bat
+++ /dev/null
@@ -1,33 +0,0 @@
-::============================================================================
-:: Batch file to program the flash of EK-TM4C123GXL
-::
-:: NOTE: requires the LMFlash programmer (included in QTools for Windows)
-::
-@echo off
-setlocal
-
-@echo Load a given binary file to the flash of EK-TM4C123GXL
-@echo usage: flash binary-file
-@echo example: flash dbg\blinky-qk.bin
-
-::----------------------------------------------------------------------------
-:: NOTE: The following symbol LMFLASH assumes that LMFlash.exe can
-:: be found on the PATH. You might need to adjust this symbol to the
-:: location of the LMFlash utility on your machine
-::
-set LMFLASH=LMFlash.exe
-
-if ["%~1"]==[""] (
- @echo The binary file missing
- @goto end
-)
-if not exist %~s1 (
- @echo The binary file '%1' does not exist
- @goto end
-)
-
-%LMFLASH% -q ek-tm4c123gxl -e -v -r %1
-
-:end
-
-endlocal
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.ewd b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.ewd
deleted file mode 100644
index fbdad60c0..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.ewd
+++ /dev/null
@@ -1,4654 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- C-SPY
- 2
-
- 32
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 0
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 0
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- C-SPY
- 2
-
- 32
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ARMSIM_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
- CADI_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
- CMSISDAP_ID
- 2
-
- 4
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- GDBSERVER_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
-
-
-
- IJET_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- JLINK_ID
- 2
-
- 16
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- LMIFTDI_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
- NULINK_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
- PEMICRO_ID
- 2
-
- 3
- 1
- 1
-
-
-
-
-
-
-
- STLINK_ID
- 2
-
- 8
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- THIRDPARTY_ID
- 2
-
- 0
- 1
- 1
-
-
-
-
-
-
-
- TIFET_ID
- 2
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- XDS100_ID
- 2
-
- 9
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\CMX\CmxTinyArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\embOS\embOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\FreeRtos\FreeRtosArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\Mbed\MbedArmPlugin2.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\OpenRTOS\OpenRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SafeRTOS\SafeRTOSPlugin.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\SMX\smxAwareIarArm9BE.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\ThreadX\ThreadXArmPlugin.ENU.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-286-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-II\uCOS-II-KA-CSpy.ewplugin
- 0
-
-
- $TOOLKIT_DIR$\plugins\rtos\uCOS-III\uCOS-III-KA-CSpy.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\Orti\Orti.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\TargetAccessServer\TargetAccessServer.ENU.ewplugin
- 0
-
-
- $EW_DIR$\common\plugins\uCProbe\uCProbePlugin.ENU.ewplugin
- 0
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.ewp b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.ewp
deleted file mode 100644
index e71f06806..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.ewp
+++ /dev/null
@@ -1,3349 +0,0 @@
-
-
- 3
-
- Debug
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Release
-
- ARM
-
- 0
-
- General
- 3
-
- 35
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 0
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 0
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 0
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Spy
-
- ARM
-
- 1
-
- General
- 3
-
- 35
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ICCARM
- 2
-
- 37
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- AARM
- 2
-
- 11
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- OBJCOPY
- 0
-
- 1
- 1
- 1
-
-
-
-
-
-
-
-
- CUSTOM
- 3
-
-
-
- 0
- inputOutputBased
-
-
-
- BUILDACTION
- 1
-
- cmd /c "if exist $OBJ_DIR$\qstamp.o del $OBJ_DIR$\qstamp.o"
-
-
-
-
- ILINK
- 0
-
- 27
- 1
- 1
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- IARCHIVE
- 0
-
- 0
- 1
- 1
-
-
-
-
-
-
- Coder
- 0
-
-
-
-
- Application
-
- $PROJ_DIR$\..\bsp.cpp
-
-
- $PROJ_DIR$\..\..\bsp.hpp
-
-
- $PROJ_DIR$\..\..\dpp.hpp
-
-
- $PROJ_DIR$\..\..\main.cpp
-
-
- $PROJ_DIR$\..\..\philo.cpp
-
-
- $PROJ_DIR$\..\..\table.cpp
-
-
-
- ek-tm4c123gxl
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\iar\startup_TM4C123GH6PM.s
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.c
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\system_TM4C123GH6PM.h
-
-
- $PROJ_DIR$\..\..\..\..\..\3rd_party\ek-tm4c123gxl\TM4C123GH6PM.h
-
-
-
- QP
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_hsm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qep_msm.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_act.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_actq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_defer.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_dyn.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_mem.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_ps.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qeq.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_qmact.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qf\qf_time.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qk\qk.cpp
-
-
-
- QP_port
-
- $PROJ_DIR$\..\..\..\..\..\ports\arm-cm\qk\iar\qk_port.cpp
-
-
-
- QS
-
- Debug
- Release
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_fp.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qs_rx.cpp
-
-
- $PROJ_DIR$\..\..\..\..\..\src\qs\qstamp.cpp
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.eww b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.eww
deleted file mode 100644
index c261124af..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.eww
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
- $WS_DIR$\dpp-qk.ewp
-
-
-
-
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.icf b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.icf
deleted file mode 100644
index c6b24e1c6..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qk/iar/dpp-qk.icf
+++ /dev/null
@@ -1,29 +0,0 @@
-/*###ICF### Section handled by ICF editor, don't touch! ****/
-/*-Editor annotation file-*/
-/* IcfEditorFile="$TOOLKIT_DIR$\config\ide\IcfEditor\cortex_v1_0.xml" */
-/*-Specials-*/
-define symbol __ICFEDIT_intvec_start__ = 0x00000000;
-/*-Memory Regions-*/
-define symbol __ICFEDIT_region_ROM_start__ = 0x00000000;
-define symbol __ICFEDIT_region_ROM_end__ = 0x0003FFFF;
-define symbol __ICFEDIT_region_RAM_start__ = 0x20000000;
-define symbol __ICFEDIT_region_RAM_end__ = 0x20007FFF;
-/*-Sizes-*/
-define symbol __ICFEDIT_size_cstack__ = 2048;
-define symbol __ICFEDIT_size_heap__ = 0;
-/**** End of ICF editor section. ###ICF###*/
-
-define memory mem with size = 4G;
-define region ROM_region = mem:[from __ICFEDIT_region_ROM_start__ to __ICFEDIT_region_ROM_end__];
-define region RAM_region = mem:[from __ICFEDIT_region_RAM_start__ to __ICFEDIT_region_RAM_end__];
-
-define block CSTACK with alignment = 8, size = __ICFEDIT_size_cstack__ { };
-define block HEAP with alignment = 8, size = __ICFEDIT_size_heap__ { };
-
-initialize by copy { readwrite };
-do not initialize { section .noinit };
-
-place at address mem:__ICFEDIT_intvec_start__ { readonly section .intvec };
-place in ROM_region { readonly };
-place at start of RAM_region {block CSTACK }; /* <== Quantum Leaps */
-place in RAM_region { readwrite, block HEAP };
\ No newline at end of file
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qp_config.hpp b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qp_config.hpp
deleted file mode 100644
index 6d234d0a1..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qp_config.hpp
+++ /dev/null
@@ -1,57 +0,0 @@
-//============================================================================
-// QP configuration file example
-// Last updated for version: 7.3.0
-// Last updated on: 2023-09-09
-//
-// Q u a n t u m L e a P s
-// ------------------------
-// Modern Embedded Software
-//
-// Copyright (C) 2005 Quantum Leaps, LLC. All rights reserved.
-//
-// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-QL-commercial
-//
-// This software is dual-licensed under the terms of the open source GNU
-// General Public License version 3 (or any later version), or alternatively,
-// under the terms of one of the closed source Quantum Leaps commercial
-// licenses.
-//
-// The terms of the open source GNU General Public License version 3
-// can be found at:
-//
-// The terms of the closed source Quantum Leaps commercial licenses
-// can be found at:
-//
-// Redistributions in source code must retain this top-level comment block.
-// Plagiarizing this software to sidestep the license obligations is illegal.
-//
-// Contact information:
-//
-//
-//============================================================================
-#ifndef QP_CONFIG_HPP_
-#define QP_CONFIG_HPP_
-
-// NOTE:
-// The QP configuration takes effect only when the macro QP_CONFIG
-// is defined on the command-line to the compiler for all QP source files.
-
-// use memory isolation (MPU)
-#define QF_MEM_ISOLATE
-
-// use event constructors for dynamic events
-//#define QEVT_DYN_CTOR
-
-// for QK kernel:
-// use the QEI1_IRQHandler() with IRQ number 38
-// for the QK return-from-preemption handler
-#define QK_USE_IRQ_NUM 38
-#define QK_USE_IRQ_HANDLER QEI1_IRQHandler
-
-// for QXK kernel:
-// use the QEI1_IRQHandler() with IRQ number 38
-// for the QXK return-from-preemption handler
-#define QXK_USE_IRQ_NUM 38
-#define QXK_USE_IRQ_HANDLER QEI1_IRQHandler
-
-#endif // QP_CONFIG_HPP_
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qv/armclang/dpp-qv.sct b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qv/armclang/dpp-qv.sct
deleted file mode 100644
index 458d5506e..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qv/armclang/dpp-qv.sct
+++ /dev/null
@@ -1,23 +0,0 @@
-; *************************************************************
-; *** Scatter-Loading Description File generated by uVision ***
-;
-; Adapted by Quantum Leaps:
-; added STACK as the first section in RW_STACK
-; *************************************************************
-
-LR_IROM1 0x00000000 0x00040000 { ; load region size_region
- ER_IROM1 0x00000000 0x00040000 { ; load address = execution address
- *.o (RESET, +First)
- *(InRoot$$Sections)
- .ANY (+RO)
- .ANY (+XO)
- }
-
- RW_STACK 0x20000000 { ; <== Quantum Leaps
- * (STACK, +First)
- }
- RW_IRAM1 +0 (0x00008000 - 2048) { ; NOTE: assume STACK size 2048!
- .ANY (+RW +ZI)
- }
-}
-
diff --git a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qv/armclang/dpp-qv.uvoptx b/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qv/armclang/dpp-qv.uvoptx
deleted file mode 100644
index 4a6ab23be..000000000
--- a/examples/arm-cm/dpp_ek-tm4c123gxl_mpu/qv/armclang/dpp-qv.uvoptx
+++ /dev/null
@@ -1,1107 +0,0 @@
-
-
-
- 1.0
-
- ### uVision Project, (C) Keil Software
-
-
- *.c
- *.s*; *.src; *.a*
- *.obj; *.o
- *.lib
- *.txt; *.h; *.inc; *.md
- *.plm
- *.cpp
- 0
-
-
-
- 0
- 0
-
-
-
- dpp-dbg
- 0x4
- ARM-ADS
-
- 12000000
-
-