• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..--

example_build/11-Mar-2024-1,227956

inc/11-Mar-2024-1,242872

src/11-Mar-2024-2,9581,712

readme_threadx.txtD11-Mar-20248.1 KiB242174

readme_threadx.txt

1                Microsoft's Azure RTOS ThreadX for Cortex-M7
2
3                    Using the Green Hills Software Tools
4
51. Open the ThreadX Project Workspace
6
7In order to build the ThreadX library and the ThreadX demonstration first load
8the Azure RTOS Workspace azure_rtos_workspace.gpj, which is located inside the
9"example_build" directory.
10
11
122. Building the ThreadX run-time Library
13
14Building the ThreadX library is easy; simply select the MULTI project file
15tx.gpj and then select the build button. You should now observe the
16compilation and assembly of the ThreadX library. This project build produces
17the ThreadX library file tx.a.
18
19
203. Demonstration System
21
22The ThreadX demonstration is designed to execute under the MULTI environment
23on the Green Hills Cortex-M7 simulator. The instructions that follow describe
24how to get the ThreadX evaluation running under the MULTI Cortex-M7 simulation
25environment.
26
27Building the demonstration is easy; simply select the MULTI project file
28sample_threadx.gpj. At this point, select the "Project Build" button and observe
29the compilation, assembly, and linkage of the ThreadX demonstration application.
30
31After the demonstration is built, invoke the  MULTI ARM simulator by selecting
32the simulator connection from within the sample_threadx.con connection file.
33Once connected to the simulator, select the "Debug" button. You should now
34observe the main function of sample_threadx.c.
35
36You are now ready to execute the ThreadX demonstration system. Select
37breakpoints and data watches to observe the execution of the sample_threadx.c
38application.
39
40
414. EventAnalyzer Demonstration
42
43To build a demonstration system that also logs events for the MULTI EventAnalyzer,
44perform the same steps as the regular demo, except build the ThreadX library with
45txe.gpj file and use the sample_threadx_el.gpj build file to build the demonstration.
46The resulting image will log all system events, which can then be displayed by the
47MULTI EventAnalyzer.
48
49
505. System Initialization
51
52The system entry point using the Green Hills tools is at the label _start.
53This is defined within the crt0.arm file supplied by Green Hills. In addition,
54this is where all static and global preset C variable initialization
55processing is called from.
56
57After the Green Hills startup function returns, ThreadX initialization is
58called. The main initialization function is _tx_initialize_low_level and
59is located in the file tx_initialize_low_level.arm. This function is responsible
60for setting up various system data structures, interrupt vectors, and the
61periodic timer interrupt source of ThreadX.
62
63In addition, _tx_initialize_low_level determines where the first available
64RAM memory address is located. This address is supplied to tx_application_define.
65
66By default, the first available RAM memory address is assumed to start at the
67beginning of the ThreadX section .free_mem. If changes are made to the
68sample_threadx.ld file, the .free_mem section should remain the last allocated
69section in the main RAM area. The starting address of this section is passed
70to tx_application_define.
71
72
736. Register Usage and Stack Frames
74
75The following defines the saved context stack frames for context switches
76that occur as a result of interrupt handling or from thread-level API calls.
77All suspended threads have the same stack frame in the Cortex-M7 version of
78ThreadX. The top of the suspended thread's stack is pointed to by
79tx_thread_stack_ptr in the associated thread control block TX_THREAD.
80
81
82Non-FPU Stack Frame:
83
84    Stack Offset    Stack Contents
85
86    0x00            LR          Interrupted LR (LR at time of PENDSV)
87    0x04            r4          Software stacked GP registers
88    0x08            r5
89    0x0C            r6
90    0x10            r7
91    0x14            r8
92    0x18            r9
93    0x1C            r10
94    0x20            r11
95    0x24            r0          Hardware stacked registers
96    0x28            r1
97    0x2C            r2
98    0x30            r3
99    0x34            r12
100    0x38            lr
101    0x3C            pc
102    0x40            xPSR
103
104FPU Stack Frame (only interrupted thread with FPU enabled):
105
106    Stack Offset    Stack Contents
107
108    0x00            LR          Interrupted LR (LR at time of PENDSV)
109    0x04            s16         Software stacked FPU registers
110    0x08            s17
111    0x0C            s18
112    0x10            s19
113    0x14            s20
114    0x18            s21
115    0x1C            s22
116    0x20            s23
117    0x24            s24
118    0x28            s25
119    0x2C            s26
120    0x30            s27
121    0x34            s28
122    0x38            s29
123    0x3C            s30
124    0x40            s31
125    0x44            r4          Software stacked registers
126    0x48            r5
127    0x4C            r6
128    0x50            r7
129    0x54            r8
130    0x58            r9
131    0x5C            r10
132    0x60            r11
133    0x64            r0          Hardware stacked registers
134    0x68            r1
135    0x6C            r2
136    0x70            r3
137    0x74            r12
138    0x78            lr
139    0x7C            pc
140    0x80            xPSR
141    0x84            s0          Hardware stacked FPU registers
142    0x88            s1
143    0x8C            s2
144    0x90            s3
145    0x94            s4
146    0x98            s5
147    0x9C            s6
148    0xA0            s7
149    0xA4            s8
150    0xA8            s9
151    0xAC            s10
152    0xB0            s11
153    0xB4            s12
154    0xB8            s13
155    0xBC            s14
156    0xC0            s15
157    0xC4            fpscr
158
159
1607. Improving Performance
161
162The distribution version of ThreadX is built without any compiler
163optimizations. This makes it easy to debug because you can trace or set
164breakpoints inside of ThreadX itself. Of course, this costs some
165performance. To make ThreadX run faster, you can change the tx.gpj project
166to disable debug information and enable the desired optimizations.
167
168In addition, you can eliminate the ThreadX basic API error checking by
169compiling your application code with the symbol TX_DISABLE_ERROR_CHECKING
170defined before tx_api.h is included.
171
172
1738. Interrupt Handling
174
175ThreadX provides complete and high-performance interrupt handling for Cortex-M7
176targets. There are a certain set of requirements that are defined in the
177following sub-sections:
178
179
1808.1  Vector Area
181
182The Cortex-M7 vectors start at the label __tx_vectors. The application may modify
183the vector area according to its needs.
184
185
1868.2 Managed Interrupts
187
188A ThreadX managed interrupt is defined below. By following these conventions, the
189application ISR is then allowed access to various ThreadX services from the ISR.
190Here is the standard template for managed ISRs in ThreadX:
191
192
193        .globl  __tx_IntHandler
194__tx_IntHandler:
195        PUSH    {lr}
196        BL      _tx_thread_context_save
197
198            /* Do interrupt handler work here */
199
200        B       _tx_thread_context_restore
201
202
2039. FPU Support
204
205By default, FPU support is disabled for each thread. If saving the context of the FPU registers
206is needed, the ThreadX library should be re-built with TX_ENABLE_FPU_SUPPORT defined. In addition,
207the following API call must be made from the context of the application thread - before
208the FPU usage:
209
210void    tx_thread_fpu_enable(void);
211
212After this API is called in the application, FPU registers will be saved/restored for this thread if it
213is preempted via an interrupt. All other suspension of the this thread will not require the FPU registers
214to be saved/restored.
215
216To disable FPU register context saving, simply call the following API:
217
218void    tx_thread_fpu_disable(void);
219
220
221
22210. Revision History
223
224For generic code revision information, please refer to the readme_threadx_generic.txt
225file, which is included in your distribution. The following details the revision
226information associated with this specific port of ThreadX:
227
22804-02-2021  Release 6.1.6 changes:
229            tx_port.h                           Updated macro definition
230
23103-02-2021  The following files were changed/added for version 6.1.5:
232            tx_thread_schedule.s            Added low power feature
233
23405/19/2020  Initial ThreadX version of Cortex-M7/Green Hills port.
235
236
237Copyright(c) 1996-2020 Microsoft Corporation
238
239
240https://azure.com/rtos
241
242