µOS++ IIIe Reference 7.0.0
The third edition of µOS++, a POSIX inspired open source framework, written in C++
Loading...
Searching...
No Matches
trace-itm.cpp
Go to the documentation of this file.
1/*
2 * This file is part of the µOS++ distribution.
3 * (https://github.com/micro-os-plus)
4 * Copyright (c) 2015 Liviu Ionescu.
5 *
6 * Permission is hereby granted, free of charge, to any person
7 * obtaining a copy of this software and associated documentation
8 * files (the "Software"), to deal in the Software without
9 * restriction, including without limitation the rights to use,
10 * copy, modify, merge, publish, distribute, sublicense, and/or
11 * sell copies of the Software, and to permit persons to whom
12 * the Software is furnished to do so, subject to the following
13 * conditions:
14 *
15 * The above copyright notice and this permission notice shall be
16 * included in all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
20 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
21 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
22 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
23 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
24 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
25 * OTHER DEALINGS IN THE SOFTWARE.
26 */
27
28#if defined(__clang__)
29#pragma clang diagnostic ignored "-Wempty-translation-unit"
30#endif
31
32// ----------------------------------------------------------------------------
33
34#if defined(__ARM_EABI__)
35
36// ----------------------------------------------------------------------------
37
38#if defined(TRACE)
39
40#include <cmsis-plus/os-app-config.h>
41
42#if defined(OS_USE_TRACE_ITM)
43
45
46// TODO: Find a better way to include the ITM definitions (including
47// the entire vendor header is averkill).
48#include <cmsis_device.h>
49
50// ----------------------------------------------------------------------------
51
52namespace os
53{
54 namespace trace
55 {
56 // ------------------------------------------------------------------------
57
58 void
59 initialize (void)
60 {
61 // For ITM no inits required.
62 // The debug registers are set the JTAG software.
63 }
64
65 // ----------------------------------------------------------------------
66
67#if defined(__ARM_ARCH_7M__) || defined(__ARM_ARCH_7EM__)
68
69 // ITM is the ARM standard mechanism, running over SWD/SWO on Cortex-M3/M4
70 // devices, and is the recommended setting, if available.
71 //
72 // The JLink probe and the GDB server fully support SWD/SWO
73 // and the JLink Debugging plug-in enables it by default.
74 // The current OpenOCD does not include support to parse the SWO stream,
75 // so this configuration will not work on OpenOCD (will not crash, but
76 // nothing will be displayed in the output console).
77
78#if !defined(OS_INTEGER_TRACE_ITM_STIMULUS_PORT)
79#define OS_INTEGER_TRACE_ITM_STIMULUS_PORT (0)
80#endif
81
82 ssize_t
83 write (const void* buf, std::size_t nbyte)
84 {
85 if (buf == nullptr || nbyte == 0)
86 {
87 return 0;
88 }
89
90 const char* cbuf = (const char*) buf;
91
92 for (size_t i = 0; i < nbyte; i++)
93 {
94 // Check if ITM or the stimulus port are not enabled.
95 if (((ITM->TCR & ITM_TCR_ITMENA_Msk) == 0)
96 || ((ITM->TER & (1UL << OS_INTEGER_TRACE_ITM_STIMULUS_PORT))
97 == 0))
98 {
99 // Return the number of sent characters (may be 0).
100 return (ssize_t) i;
101 }
102
103 // Wait until STIMx is ready...
104 while (ITM->PORT[OS_INTEGER_TRACE_ITM_STIMULUS_PORT].u32 == 0)
105 ;
106 // then send data, one byte at a time
108 (uint8_t) (*cbuf++);
109 }
110
111 // All characters successfully sent.
112 return (ssize_t) nbyte;
113 }
114
115#else
116
117#error "ITM available only on ARCH 7M"
118
119#endif /* defined(__ARM_ARCH_7M__) || defined(__ARM_ARCH_7EM__) */
120
121 } /* namespace trace */
122} /* namespace os */
123
124#endif /* defined(OS_USE_TRACE_ITM) */
125#endif /* defined(TRACE) */
126
127// ----------------------------------------------------------------------------
128
129#endif /* defined(__ARM_EABI__) */
#define OS_INTEGER_TRACE_ITM_STIMULUS_PORT
Define the ITM stimulus port used for the trace messages.
void initialize(void)
Definition trace.cpp:50
ssize_t write(const void *buf, std::size_t nbyte)
Write the given number of bytes to the trace output channel.
Definition trace.cpp:60
System namespace.