]> begriffs open source - cmsis-freertos/blob - ARM.CMSIS-FreeRTOS.pdsc
Identified problems fixed
[cmsis-freertos] / ARM.CMSIS-FreeRTOS.pdsc
1 <?xml version="1.0" encoding="utf-8"?>
2
3 <package schemaVersion="1.4" xmlns:xs="http://www.w3.org/2001/XMLSchema-instance" xs:noNamespaceSchemaLocation="PACK.xsd">
4   <vendor>ARM</vendor>
5   <name>CMSIS-FreeRTOS</name>
6   <description>Bundle of FreeRTOS for Cortex-M and Cortex-A</description>
7   <url>http://www.keil.com/pack/</url>
8   <license>License/license.txt</license>
9
10   <releases>
11     <release version="10.2.0-RC1">
12       FreeRTOS 10.2.0
13       Maintenance for CMSIS 5.5.1:
14       - Updated to CMSIS API 2.1.3
15       - Updated Arm standard C library interface
16       - Added configuration for the Event Recorder
17       - Added TrustZone example for Armv8M using RTOS2 API
18       - Enhanced FreeRTOS component viewer
19       - Corrected osDelayUntil execution duration
20       - Corrected SysTick_Handler execution when kernel is not started
21       - Corrected critical section for osKernelGetSysTimerCount
22     </release>
23     <release version="10.0.1" date="2018-02-20">
24       FreeRTOS 10.0.0
25       Maintenance for CMSIS 5.3.0:
26        - Added queue registry support to CMSIS:RTOS2:FreeRTOS component.
27        - Updated CMSIS-FreeRTOS component view to display queue, mutex and semaphore objects.
28        - Updated to CMSIS RTOS2 API 2.1.2 and OS Tick API 1.0.1.
29        - Fixed context switch response latency for API calls from ISR.
30     </release>
31     <release version="9.1.0" date="2017-08-11">
32       FreeRTOS 9.0.0
33       Maintenance release for CMSIS 5.1.0:
34       - Added support for ARM Compiler 6
35       - Updated Cortex-A example to use IRQ Controller component
36       - Corrected stack size allocation in RTOS2 osThreadNew function
37       - Added support for OS Tick component
38       - Added documentation for configuration options (native/CMSIS-RTOS2)
39       - Debug event TaskIncrementTick level set to Detail
40     </release>
41     <release version="9.0.0" date="2017-03-13">
42       Initial release version:
43       - native FreeRTOS component (RTOS: Variant=FreeRTOS)
44       - CMSIS-RTOS FreeRTOS for Cortex-M and Cortex-A9 (CMSIS:RTOS:FreeRTOS, CMSIS:RTOS2:FreeRTOS)
45     </release>
46   </releases>
47
48   <requirements>
49     <packages>
50       <package vendor="ARM" name="CMSIS" version="5.3.0-0"/>
51     </packages>
52   </requirements>
53
54   <conditions>
55     <condition id="ARMCC6">
56       <accept Tcompiler="ARMCC" Toptions="AC6"/>
57       <accept Tcompiler="ARMCC" Toptions="AC6LTO"/>
58     </condition>
59     <condition id="ARMCC">
60       <require Tcompiler="ARMCC" Toptions="AC5"/>
61     </condition>
62     <condition id="GCC">
63       <require Tcompiler="GCC"/>
64     </condition>
65     <condition id="IAR">
66       <require Tcompiler="IAR"/>
67     </condition>
68
69     <condition id="ARMCC GCC">
70       <accept condition="ARMCC"/>
71       <accept condition="GCC"/>
72     </condition>
73     <condition id="ARMCC6 GCC">
74       <accept condition="ARMCC6"/>
75       <accept condition="GCC"/>
76     </condition>
77     <condition id="ARMCC GCC IAR">
78       <accept condition="ARMCC"/>
79       <accept condition="GCC"/>
80       <accept condition="IAR"/>
81     </condition>
82     <condition id="ARMCC6 GCC IAR">
83       <accept condition="ARMCC6"/>
84       <accept condition="GCC"/>
85       <accept condition="IAR"/>
86     </condition>
87     <condition id="ARMCC ARMCC6 GCC IAR">
88       <accept condition="ARMCC"/>
89       <accept condition="ARMCC6"/>
90       <accept condition="GCC"/>
91       <accept condition="IAR"/>
92     </condition>
93
94     <condition id="CM0">
95       <description>Cortex-M0 or Cortex-M0+ or SC000 processor based device</description>
96       <accept Dcore="Cortex-M0"/>
97       <accept Dcore="Cortex-M0+"/>
98       <accept Dcore="SC000"/>
99     </condition>
100
101     <condition id="CM3">
102       <description>Cortex-M3 or SC300 processor based device</description>
103       <accept Dcore="Cortex-M3"/>
104       <accept Dcore="SC300"/>
105     </condition>
106
107     <condition id="CM4">
108       <description>Cortex-M4 processor based device</description>
109       <require Dcore="Cortex-M4" Dfpu="NO_FPU"/>
110     </condition>
111
112     <condition id="CM4_FP">
113       <description>Cortex-M4 processor based device using Floating Point Unit</description>
114       <require Dcore="Cortex-M4" Dfpu="FPU"/>
115     </condition>
116
117     <condition id="CM7">
118       <description>Cortex-M7 processor based device</description>
119       <require Dcore="Cortex-M7" Dfpu="NO_FPU"/>
120     </condition>
121
122     <condition id="CM7_FP">
123       <description>Cortex-M7 processor based device using Floating Point Unit</description>
124       <accept Dcore="Cortex-M7" Dfpu="SP_FPU"/>
125       <accept Dcore="Cortex-M7" Dfpu="DP_FPU"/>
126     </condition>
127
128     <condition id="CM7_SP">
129       <description>Cortex-M7 processor based device using Floating Point Unit (SP)</description>
130       <require Dcore="Cortex-M7" Dfpu="SP_FPU"/>
131     </condition>
132
133     <condition id="CM7_DP">
134       <description>Cortex-M7 processor based device using Floating Point Unit (DP)</description>
135       <require Dcore="Cortex-M7" Dfpu="DP_FPU"/>
136     </condition>
137
138     <condition id="CM33">
139       <description>Cortex-M33 processor based device</description>
140       <accept Dcore="Cortex-M33"/>
141     </condition>
142
143     <condition id="CM33_NoTZ">
144       <description>Cortex-M33 processor based device without TrustZone</description>
145       <require condition="CM33"/>
146       <require Dtz="NO_TZ"/>
147     </condition>
148
149     <condition id="CM33_TZ">
150       <description>Cortex-M33 processor based device with TrustZone</description>
151       <require condition="CM33"/>
152       <require Dtz="TZ"/>
153     </condition>
154
155     <condition id="CA9_DP">
156       <description>Cortex-A9 processor based device using Floating Point Unit (DP)</description>
157       <require Dcore="Cortex-A9" Dfpu="DP_FPU"/>
158     </condition>
159
160     <condition id="CoreM">
161       <description>Cortex-M processor based device</description>
162       <accept condition="CM0"/>
163       <accept condition="CM3"/>
164       <accept condition="CM4"/>
165       <accept condition="CM4_FP"/>
166       <accept condition="CM7"/>
167       <accept condition="CM7_FP"/>
168       <accept condition="CM33"/>
169     </condition>
170
171     <condition id="CoreM_v6_v7">
172       <description>Cortex-M v6 and v7 processor based device</description>
173       <accept condition="CM0"/>
174       <accept condition="CM3"/>
175       <accept condition="CM4"/>
176       <accept condition="CM4_FP"/>
177       <accept condition="CM7"/>
178       <accept condition="CM7_FP"/>
179     </condition>
180
181     <condition id="CoreM_v8">
182       <description>Cortex-M v8 processor based device</description>
183       <accept condition="CM33"/>
184       <accept condition="CM33_NoTZ"/>
185       <accept condition="CM33_TZ"/>
186     </condition>
187
188     <condition id="CoreA">
189       <description>Cortex-A processor based device</description>
190       <accept condition="CA9_DP"/>
191     </condition>
192
193     <!-- ARMCC compiler -->
194     <condition id="CM0_ARMCC">
195       <description>Cortex-M0 or Cortex-M0+ or SC000 processor based device for the ARM Compiler 5</description>
196       <require condition="CM0"/>
197       <require condition="ARMCC"/>
198     </condition>
199
200     <condition id="CM3_ARMCC">
201       <description>Cortex-M3 or SC300 processor based device for the ARM Compiler 5</description>
202       <require condition="CM3"/>
203       <require condition="ARMCC"/>
204     </condition>
205
206     <condition id="CM4_ARMCC">
207       <description>Cortex-M4 processor based device for the ARM Compiler 5</description>
208       <require condition="CM4"/>
209       <require condition="ARMCC"/>
210     </condition>
211     <condition id="CM4_FP_ARMCC">
212       <description>Cortex-M4 processor based device using Floating Point Unit for the ARM Compiler 5</description>
213       <require condition="CM4_FP"/>
214       <require condition="ARMCC"/>
215     </condition>
216
217     <condition id="CM7_ARMCC">
218       <description>Cortex-M7 processor based device for the ARM Compiler 5</description>
219       <require condition="CM7"/>
220       <require condition="ARMCC"/>
221     </condition>
222     <condition id="CM7_SP_ARMCC">
223       <description>Cortex-M7 processor based device using Floating Point Unit (SP) for the ARM Compiler 5</description>
224       <require condition="CM7_SP"/>
225       <require condition="ARMCC"/>
226     </condition>
227     <condition id="CM7_DP_ARMCC">
228       <description>Cortex-M7 processor based device using Floating Point Unit (DP) for the ARM Compiler 5</description>
229       <require condition="CM7_DP"/>
230       <require condition="ARMCC"/>
231     </condition>
232
233     <condition id="CA9_DP_ARMCC">
234       <description>Cortex-A9 processor based device for the ARM Compiler 5</description>
235       <require condition="CA9_DP"/>
236       <require condition="ARMCC"/>
237     </condition>
238
239     <!-- ARMCC6 compiler -->
240     <condition id="CM0_ARMCC6">
241       <description>Cortex-M0 or Cortex-M0+ or SC000 processor based device for the ARM Compiler 6</description>
242       <require condition="CM0"/>
243       <require condition="ARMCC6"/>
244     </condition>
245
246     <condition id="CM3_ARMCC6">
247       <description>Cortex-M3 or SC300 processor based device for the ARM Compiler 6</description>
248       <require condition="CM3"/>
249       <require condition="ARMCC6"/>
250     </condition>
251
252     <condition id="CM4_ARMCC6">
253       <description>Cortex-M4 processor based device for the ARM Compiler 6</description>
254       <require condition="CM4"/>
255       <require condition="ARMCC6"/>
256     </condition>
257     <condition id="CM4_FP_ARMCC6">
258       <description>Cortex-M4 processor based device using Floating Point Unit for the ARM Compiler 6</description>
259       <require condition="CM4_FP"/>
260       <require condition="ARMCC6"/>
261     </condition>
262
263     <condition id="CM7_ARMCC6">
264       <description>Cortex-M7 processor based device for the ARM Compiler 6</description>
265       <require condition="CM7"/>
266       <require condition="ARMCC6"/>
267     </condition>
268     <condition id="CM7_SP_ARMCC6">
269       <description>Cortex-M7 processor based device using Floating Point Unit (SP) for the ARM Compiler 6</description>
270       <require condition="CM7_SP"/>
271       <require condition="ARMCC6"/>
272     </condition>
273     <condition id="CM7_DP_ARMCC6">
274       <description>Cortex-M7 processor based device using Floating Point Unit (DP) for the ARM Compiler 6</description>
275       <require condition="CM7_DP"/>
276       <require condition="ARMCC6"/>
277     </condition>
278
279     <condition id="CM33_ARMCC6">
280       <description>Cortex-M33 processor based device for the ARM Compiler 6</description>
281       <require condition="CM33"/>
282       <require condition="ARMCC6"/>
283     </condition>
284     <condition id="CM33_NoTZ_ARMCC6">
285       <description>Cortex-M33 processor based device without TrustZone for the ARM Compiler 6</description>
286       <require condition="CM33_NoTZ"/>
287       <require condition="ARMCC6"/>
288     </condition>
289     <condition id="CM33_TZ_ARMCC6">
290       <description>Cortex-M33 processor based device with TrustZone for the ARM Compiler 6</description>
291       <require condition="CM33_TZ"/>
292       <require condition="ARMCC6"/>
293     </condition>
294
295     <condition id="CA9_DP_ARMCC6">
296       <description>Cortex-A9 processor based device for the ARM Compiler 6</description>
297       <require condition="CA9_DP"/>
298       <require condition="ARMCC6"/>
299     </condition>
300
301     <!-- GCC compiler -->
302     <condition id="CM0_GCC">
303       <description>Cortex-M0 or Cortex-M0+ or SC000 processor based device for the GCC Compiler</description>
304       <require condition="CM0"/>
305       <require condition="GCC"/>
306     </condition>
307
308     <condition id="CM3_GCC">
309       <description>Cortex-M3 or SC300 processor based device for the GCC Compiler</description>
310       <require condition="CM3"/>
311       <require condition="GCC"/>
312     </condition>
313
314     <condition id="CM4_GCC">
315       <description>Cortex-M4 processor based device for the GCC Compiler</description>
316       <require condition="CM4"/>
317       <require condition="GCC"/>
318     </condition>
319     <condition id="CM4_FP_GCC">
320       <description>Cortex-M4 processor based device using Floating Point Unit for the GCC Compiler</description>
321       <require condition="CM4_FP"/>
322       <require condition="GCC"/>
323     </condition>
324
325     <condition id="CM7_GCC">
326       <description>Cortex-M7 processor based device for the GCC Compiler</description>
327       <require condition="CM7"/>
328       <require condition="GCC"/>
329     </condition>
330     <condition id="CM7_SP_GCC">
331       <description>Cortex-M7 processor based device using Floating Point Unit (SP) for the GCC Compiler</description>
332       <require condition="CM7_SP"/>
333       <require condition="GCC"/>
334     </condition>
335     <condition id="CM7_DP_GCC">
336       <description>Cortex-M7 processor based device using Floating Point Unit (DP) for the GCC Compiler</description>
337       <require condition="CM7_DP"/>
338       <require condition="GCC"/>
339     </condition>
340
341     <condition id="CM33_GCC">
342       <description>Cortex-M33 processor based device for the GCC Compiler</description>
343       <require condition="CM33"/>
344       <require condition="GCC"/>
345     </condition>
346     <condition id="CM33_NoTZ_GCC">
347       <description>Cortex-M33 processor based device without TrustZone for the GCC Compiler</description>
348       <require condition="CM33_NoTZ"/>
349       <require condition="GCC"/>
350     </condition>
351     <condition id="CM33_TZ_GCC">
352       <description>Cortex-M33 processor based device with TrustZone for the GCC Compiler</description>
353       <require condition="CM33_TZ"/>
354       <require condition="GCC"/>
355     </condition>
356
357     <condition id="CA9_DP_GCC">
358       <description>Cortex-A9 processor based device for the GCC Compiler</description>
359       <require condition="CA9_DP"/>
360       <require condition="GCC"/>
361     </condition>
362
363     <!-- IAR compiler -->
364     <condition id="CM0_IAR">
365       <description>Cortex-M0 or Cortex-M0+ or SC000 processor based device for the IAR Compiler</description>
366       <require condition="CM0"/>
367       <require condition="IAR"/>
368     </condition>
369
370     <condition id="CM3_IAR">
371       <description>Cortex-M3 or SC300 processor based device for the IAR Compiler</description>
372       <require condition="CM3"/>
373       <require condition="IAR"/>
374     </condition>
375
376     <condition id="CM4_IAR">
377       <description>Cortex-M4 processor based device for the IAR Compiler</description>
378       <require condition="CM4"/>
379       <require condition="IAR"/>
380     </condition>
381     <condition id="CM4_FP_IAR">
382       <description>Cortex-M4 processor based device using Floating Point Unit for the IAR Compiler</description>
383       <require condition="CM4_FP"/>
384       <require condition="IAR"/>
385     </condition>
386
387     <condition id="CM7_IAR">
388       <description>Cortex-M7 processor based device for the IAR Compiler</description>
389       <require condition="CM7"/>
390       <require condition="IAR"/>
391     </condition>
392     <condition id="CM7_SP_IAR">
393       <description>Cortex-M7 processor based device using Floating Point Unit (SP) for the IAR Compiler</description>
394       <require condition="CM7_SP"/>
395       <require condition="IAR"/>
396     </condition>
397     <condition id="CM7_DP_IAR">
398       <description>Cortex-M7 processor based device using Floating Point Unit (DP) for the IAR Compiler</description>
399       <require condition="CM7_DP"/>
400       <require condition="IAR"/>
401     </condition>
402
403     <condition id="CM33_IAR">
404       <description>Cortex-M33 processor based device for the IAR Compiler</description>
405       <require condition="CM33"/>
406       <require condition="IAR"/>
407     </condition>
408     <condition id="CM33_NoTZ_IAR">
409       <description>Cortex-M33 processor based device without TrustZone for the IAR Compiler</description>
410       <require condition="CM33_NoTZ"/>
411       <require condition="IAR"/>
412     </condition>
413     <condition id="CM33_TZ_IAR">
414       <description>Cortex-M33 processor based device with TrustZone for the IAR Compiler</description>
415       <require condition="CM33_TZ"/>
416       <require condition="IAR"/>
417     </condition>
418
419     <condition id="CA9_DP_IAR">
420       <description>Cortex-A9 processor based device for the IAR Compiler</description>
421       <require condition="CA9_DP"/>
422       <require condition="IAR"/>
423     </condition>
424
425     <condition id="CMSIS RTOS2 FreeRTOS">
426       <require Cclass="CMSIS" Cgroup="RTOS2" Csub="FreeRTOS"/>
427     </condition>
428
429     <condition id="FreeRTOS Port Cortex-A">
430       <require condition="ARMCC ARMCC6 GCC IAR"/>
431       <require condition="CoreA"/>
432     </condition>
433     <condition id="FreeRTOS Port Cortex-M">
434       <require condition="ARMCC ARMCC6 GCC IAR"/>
435       <require condition="CoreM_v6_v7"/>
436     </condition>
437     <condition id="FreeRTOS Port Cortex-M v8">
438       <require condition="ARMCC6 GCC IAR"/>
439       <require condition="CoreM_v8"/>
440     </condition>
441
442
443     <condition id="FreeRTOS">
444       <!-- All existing FreeRTOS ports for Cortex combined -->
445       <accept condition="FreeRTOS Port Cortex-A"/>
446       <accept condition="FreeRTOS Port Cortex-M"/>
447       <accept condition="FreeRTOS Port Cortex-M v8"/>
448     </condition>
449
450     <condition id="FreeRTOS CM">
451       <accept condition="FreeRTOS Port Cortex-M"/>
452       <accept condition="FreeRTOS Port Cortex-M v8"/>
453
454       <require Cclass="Device" Cgroup="Startup"/>
455       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config"/>
456       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Heap"/>
457     </condition>
458
459     <condition id="FreeRTOS MPU CM3 CM4">
460       <require condition="ARMCC6 GCC"/>
461       <accept  condition="CM3"/>
462       <accept  condition="CM4"/>
463
464       <require Cclass="Device" Cgroup="Startup"/>
465       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config"/>
466       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Heap"/>
467       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Event Groups"/>
468       <accept  Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Message Buffer"/>
469       <accept  Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Stream Buffer"/>
470       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Timers"/>
471     </condition>
472
473     <condition id="FreeRTOS MPU CM4_FP">
474       <require condition="ARMCC ARMCC6 GCC IAR"/>
475       <require condition="CM4_FP"/>
476
477       <require Cclass="Device" Cgroup="Startup"/>
478       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config"/>
479       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Heap"/>
480       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Event Groups"/>
481       <accept  Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Message Buffer"/>
482       <accept  Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Stream Buffer"/>
483       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Timers"/>
484     </condition>
485
486     <condition id="FreeRTOS TZ">
487       <require condition="ARMCC6 GCC IAR"/>
488       <require condition="CM33_TZ"/>
489
490       <require Cclass="Device" Cgroup="Startup"/>
491       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config"/>
492       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Heap"/>
493     </condition>
494
495     <condition id="FreeRTOS TZ MPU">
496       <require condition="ARMCC6 GCC IAR"/>
497       <require condition="CM33_TZ"/>
498
499       <require Cclass="Device" Cgroup="Startup"/>
500       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config"/>
501       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Heap"/>
502       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Event Groups"/>
503       <accept  Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Message Buffer"/>
504       <accept  Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Stream Buffer"/>
505       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Timers"/>
506     </condition>
507
508     <condition id="FreeRTOS CA">
509       <require condition="ARMCC ARMCC6 GCC IAR"/>
510       <require condition="CoreA"/>
511
512       <require Cclass="Device" Cgroup="Startup"/>
513       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config"/>
514       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Heap"/>
515     </condition>
516
517     <condition id="FreeRTOS Core">
518       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Core"/>
519     </condition>
520
521     <condition id="FreeRTOS TrustZone">
522       <require condition="CM33_TZ"/>
523       <!-- TrustZone Secure Context is a standalone component -->
524       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config"/>
525       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Core"/>
526       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Coroutines"/>
527       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Heap"/>
528       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Event Groups"/>
529       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Message Buffer"/>
530       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Stream Buffer"/>
531       <deny Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Timers"/>
532     </condition>
533
534     <condition id="FreeRTOS RTOS2 Core">
535       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Event Groups"/>
536       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Timers"/>
537       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Core"/>
538       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config" Cvariant="CMSIS RTOS2"/>
539     </condition>
540
541     <condition id="FreeRTOS RTOS2 CortexM">
542       <require condition="CoreM"/>
543       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Event Groups"/>
544       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Timers"/>
545       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Core"/>
546       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config" Cvariant="CMSIS RTOS2"/>
547     </condition>
548
549     <condition id="FreeRTOS RTOS2 CortexA">
550       <require condition="CoreA"/>
551       <require Cclass="Device" Cgroup="IRQ Controller"/>
552       <require Cclass="Device" Cgroup="OS Tick"/>
553       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Event Groups"/>
554       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Timers"/>
555       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Core"/>
556       <require Cclass="RTOS" Cbundle="FreeRTOS" Cgroup="Config" Cvariant="CMSIS RTOS2"/>
557     </condition>
558
559   </conditions>
560
561   <components>
562     <!-- CMSIS-RTOS FreeRTOS component -->
563     <component Cclass="CMSIS" Cgroup="RTOS" Csub="FreeRTOS" Cversion="10.2.0" Capiversion="1.0.0" condition="FreeRTOS RTOS2 Core">
564       <description>CMSIS-RTOS implementation for Cortex-M based on FreeRTOS</description>
565       <RTE_Components_h>
566         #define RTE_CMSIS_RTOS                  /* CMSIS-RTOS */
567         #define RTE_CMSIS_RTOS_FreeRTOS         /* CMSIS-RTOS FreeRTOS */
568       </RTE_Components_h>
569       <files>
570         <file category="header" name="CMSIS/RTOS2/FreeRTOS/Include1/cmsis_os.h"/>
571         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/cmsis_os1.c"/>
572       </files>
573     </component>
574
575     <!-- CMSIS-RTOS2 FreeRTOS component -->
576     <component Cclass="CMSIS" Cgroup="RTOS2" Csub="FreeRTOS" Cversion="10.2.0" Capiversion="2.1.3" condition="FreeRTOS RTOS2 CortexM">
577       <description>CMSIS-RTOS2 implementation for Cortex-M based on FreeRTOS</description>
578       <RTE_Components_h>
579         #define RTE_CMSIS_RTOS2                 /* CMSIS-RTOS2 */
580         #define RTE_CMSIS_RTOS2_FreeRTOS        /* CMSIS-RTOS2 FreeRTOS */
581       </RTE_Components_h>
582       <files>
583         <file category="doc"    name="CMSIS/Documentation/General/html/index.html"/>
584         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/cmsis_os2.c"/>
585         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/ARM/clib_arm.c" condition="ARMCC"/>
586         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/ARM/clib_arm.c" condition="ARMCC6"/>
587
588         <!-- OS Tick (SysTick) -->
589         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/os_systick.c"/>
590       </files>
591     </component>
592
593     <component Cclass="CMSIS" Cgroup="RTOS2" Csub="FreeRTOS" Cversion="10.2.0" Capiversion="2.1.3" condition="FreeRTOS RTOS2 CortexA">
594       <description>CMSIS-RTOS2 implementation for Cortex-A based on FreeRTOS</description>
595       <RTE_Components_h>
596         #define RTE_CMSIS_RTOS2                 /* CMSIS-RTOS2 */
597         #define RTE_CMSIS_RTOS2_FreeRTOS        /* CMSIS-RTOS2 FreeRTOS */
598       </RTE_Components_h>
599       <files>
600         <file category="doc"    name="CMSIS/Documentation/General/html/index.html"/>
601         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/cmsis_os2.c"/>
602         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/ARM/clib_arm.c" condition="ARMCC"/>
603         <file category="source" name="CMSIS/RTOS2/FreeRTOS/Source/ARM/clib_arm.c" condition="ARMCC6"/>
604
605         <file category="source" attr="config" name="CMSIS/RTOS2/FreeRTOS/Source/handlers.c" version="9.1.0"/>
606       </files>
607     </component>
608
609     <bundle Cbundle="FreeRTOS" Cclass="RTOS" Cversion="10.2.0" condition="FreeRTOS">
610       <description>FreeRTOS Real Time Kernel</description>
611       <doc>https://www.freertos.org/Documentation/FreeRTOS_Reference_Manual_V10.0.0.pdf</doc>
612
613       <component Cgroup="Core" Cvariant="Cortex-M" isDefaultVariant="true" condition="FreeRTOS CM">
614         <description>Core API (Kernel, Tasks, Semaphores, Mutexes, Queues) for Cortex-M</description>
615         <RTE_Components_h>
616           #define RTE_RTOS_FreeRTOS_CORE          /* RTOS FreeRTOS Core */
617         </RTE_Components_h>
618         <files>
619           <file category="include" name="Source/include/"/>
620
621           <file category="header"  name="Source/include/FreeRTOS.h"/>
622           <file category="header"  name="Source/include/queue.h"/>
623           <file category="header"  name="Source/include/semphr.h"/>
624           <file category="header"  name="Source/include/task.h"/>
625
626           <file category="source"  name="Source/list.c"/>
627           <file category="source"  name="Source/queue.c"/>
628           <file category="source"  name="Source/tasks.c"/>
629
630           <file category="include"   condition="CM0_ARMCC"    name="Source/portable/RVDS/ARM_CM0/"/>
631           <file category="source"    condition="CM0_ARMCC"    name="Source/portable/RVDS/ARM_CM0/port.c"/>
632           <file category="include"   condition="CM3_ARMCC"    name="Source/portable/RVDS/ARM_CM3/"/>
633           <file category="source"    condition="CM3_ARMCC"    name="Source/portable/RVDS/ARM_CM3/port.c"/>
634           <file category="include"   condition="CM4_ARMCC"    name="Source/portable/RVDS/ARM_CM3/"/>
635           <file category="source"    condition="CM4_ARMCC"    name="Source/portable/RVDS/ARM_CM3/port.c"/>
636           <file category="include"   condition="CM4_FP_ARMCC" name="Source/portable/RVDS/ARM_CM4F/"/>
637           <file category="source"    condition="CM4_FP_ARMCC" name="Source/portable/RVDS/ARM_CM4F/port.c"/>
638           <file category="include"   condition="CM7_ARMCC"    name="Source/portable/RVDS/ARM_CM3/"/>
639           <file category="source"    condition="CM7_ARMCC"    name="Source/portable/RVDS/ARM_CM3/port.c"/>
640           <file category="include"   condition="CM7_DP_ARMCC" name="Source/portable/RVDS/ARM_CM7/r0p1/"/>
641           <file category="source"    condition="CM7_DP_ARMCC" name="Source/portable/RVDS/ARM_CM7/r0p1/port.c"/>
642           <file category="include"   condition="CM7_SP_ARMCC" name="Source/portable/RVDS/ARM_CM7/r0p1/"/>
643           <file category="source"    condition="CM7_SP_ARMCC" name="Source/portable/RVDS/ARM_CM7/r0p1/port.c"/>
644
645           <file category="include"   condition="CM0_ARMCC6"    name="Source/portable/GCC/ARM_CM0/"/>
646           <file category="source"    condition="CM0_ARMCC6"    name="Source/portable/GCC/ARM_CM0/port.c"/>
647           <file category="include"   condition="CM3_ARMCC6"    name="Source/portable/GCC/ARM_CM3/"/>
648           <file category="source"    condition="CM3_ARMCC6"    name="Source/portable/GCC/ARM_CM3/port.c"/>
649           <file category="include"   condition="CM4_ARMCC6"    name="Source/portable/GCC/ARM_CM3/"/>
650           <file category="source"    condition="CM4_ARMCC6"    name="Source/portable/GCC/ARM_CM3/port.c"/>
651           <file category="include"   condition="CM4_FP_ARMCC6" name="Source/portable/GCC/ARM_CM4F/"/>
652           <file category="source"    condition="CM4_FP_ARMCC6" name="Source/portable/GCC/ARM_CM4F/port.c"/>
653           <file category="include"   condition="CM7_ARMCC6"    name="Source/portable/GCC/ARM_CM3/"/>
654           <file category="source"    condition="CM7_ARMCC6"    name="Source/portable/GCC/ARM_CM3/port.c"/>
655           <file category="include"   condition="CM7_DP_ARMCC6" name="Source/portable/GCC/ARM_CM7/r0p1/"/>
656           <file category="source"    condition="CM7_DP_ARMCC6" name="Source/portable/GCC/ARM_CM7/r0p1/port.c"/>
657           <file category="include"   condition="CM7_SP_ARMCC6" name="Source/portable/GCC/ARM_CM7/r0p1/"/>
658           <file category="source"    condition="CM7_SP_ARMCC6" name="Source/portable/GCC/ARM_CM7/r0p1/port.c"/>
659           <file category="include"   condition="CM33_ARMCC6"   name="Source/portable/GCC/ARM_CM33_NTZ/non_secure/"/>
660           <file category="source"    condition="CM33_ARMCC6"   name="Source/portable/GCC/ARM_CM33_NTZ/non_secure/port.c"/>
661           <file category="source"    condition="CM33_ARMCC6"   name="Source/portable/GCC/ARM_CM33_NTZ/non_secure/portasm.c"/>
662
663           <file category="include"   condition="CM0_GCC"    name="Source/portable/GCC/ARM_CM0/"/>
664           <file category="source"    condition="CM0_GCC"    name="Source/portable/GCC/ARM_CM0/port.c"/>
665           <file category="include"   condition="CM3_GCC"    name="Source/portable/GCC/ARM_CM3/"/>
666           <file category="source"    condition="CM3_GCC"    name="Source/portable/GCC/ARM_CM3/port.c"/>
667           <file category="include"   condition="CM4_GCC"    name="Source/portable/GCC/ARM_CM3/"/>
668           <file category="source"    condition="CM4_GCC"    name="Source/portable/GCC/ARM_CM3/port.c"/>
669           <file category="include"   condition="CM4_FP_GCC" name="Source/portable/GCC/ARM_CM4F/"/>
670           <file category="source"    condition="CM4_FP_GCC" name="Source/portable/GCC/ARM_CM4F/port.c"/>
671           <file category="include"   condition="CM7_GCC"    name="Source/portable/GCC/ARM_CM3/"/>
672           <file category="source"    condition="CM7_GCC"    name="Source/portable/GCC/ARM_CM3/port.c"/>
673           <file category="include"   condition="CM7_DP_GCC" name="Source/portable/GCC/ARM_CM7/r0p1/"/>
674           <file category="source"    condition="CM7_DP_GCC" name="Source/portable/GCC/ARM_CM7/r0p1/port.c"/>
675           <file category="include"   condition="CM7_SP_GCC" name="Source/portable/GCC/ARM_CM7/r0p1/"/>
676           <file category="source"    condition="CM7_SP_GCC" name="Source/portable/GCC/ARM_CM7/r0p1/port.c"/>
677           <file category="include"   condition="CM33_GCC"   name="Source/portable/GCC/ARM_CM33_NTZ/non_secure/"/>
678           <file category="source"    condition="CM33_GCC"   name="Source/portable/GCC/ARM_CM33_NTZ/non_secure/port.c"/>
679           <file category="source"    condition="CM33_GCC"   name="Source/portable/GCC/ARM_CM33_NTZ/non_secure/portasm.c"/>
680
681           <file category="include"   condition="CM0_IAR"    name="Source/portable/IAR/ARM_CM0/"/>
682           <file category="source"    condition="CM0_IAR"    name="Source/portable/IAR/ARM_CM0/port.c"/>
683           <file category="include"   condition="CM3_IAR"    name="Source/portable/IAR/ARM_CM3/"/>
684           <file category="source"    condition="CM3_IAR"    name="Source/portable/IAR/ARM_CM3/port.c"/>
685           <file category="include"   condition="CM4_IAR"    name="Source/portable/IAR/ARM_CM3/"/>
686           <file category="source"    condition="CM4_IAR"    name="Source/portable/IAR/ARM_CM3/port.c"/>
687           <file category="include"   condition="CM4_FP_IAR" name="Source/portable/IAR/ARM_CM4F/"/>
688           <file category="source"    condition="CM4_FP_IAR" name="Source/portable/IAR/ARM_CM4F/port.c"/>
689           <file category="include"   condition="CM7_IAR"    name="Source/portable/IAR/ARM_CM3/"/>
690           <file category="source"    condition="CM7_IAR"    name="Source/portable/IAR/ARM_CM3/port.c"/>
691           <file category="include"   condition="CM7_DP_IAR" name="Source/portable/IAR/ARM_CM7/r0p1/"/>
692           <file category="source"    condition="CM7_DP_IAR" name="Source/portable/IAR/ARM_CM7/r0p1/port.c"/>
693           <file category="include"   condition="CM7_SP_IAR" name="Source/portable/IAR/ARM_CM7/r0p1/"/>
694           <file category="source"    condition="CM7_SP_IAR" name="Source/portable/IAR/ARM_CM7/r0p1/port.c"/>
695           <file category="include"   condition="CM33_IAR"   name="Source/portable/IAR/ARM_CM33_NTZ/non_secure/"/>
696           <file category="source"    condition="CM33_IAR"   name="Source/portable/IAR/ARM_CM33_NTZ/non_secure/port.c"/>
697           <file category="source"    condition="CM33_IAR"   name="Source/portable/IAR/ARM_CM33_NTZ/non_secure/portasm.s"/>
698
699           <file category="include" name="CMSIS/RTOS2/FreeRTOS/Include/"/>
700           <file category="source"  name="CMSIS/RTOS2/FreeRTOS/Source/freertos_evr.c"/>
701           <file category="other"   name="CMSIS/RTOS2/FreeRTOS/FreeRTOS.scvd"/>
702         </files>
703       </component>
704
705       <component Cgroup="Core" Cvariant="Cortex-M MPU" condition="FreeRTOS MPU CM3 CM4">
706         <description>Core API (Kernel, Tasks, Semaphores, Mutexes, Queues) for Cortex-M using MPU</description>
707         <RTE_Components_h>
708           #define RTE_RTOS_FreeRTOS_CORE          /* RTOS FreeRTOS Core */
709           #define RTE_RTOS_FreeRTOS_CORE_MPU      /* RTOS FreeRTOS Core with MPU support */
710         </RTE_Components_h>
711         <files>
712           <file category="include" name="Source/include/"/>
713
714           <file category="header"  name="Source/include/FreeRTOS.h"/>
715           <file category="header"  name="Source/include/queue.h"/>
716           <file category="header"  name="Source/include/semphr.h"/>
717           <file category="header"  name="Source/include/task.h"/>
718
719           <file category="source"  name="Source/list.c"/>
720           <file category="source"  name="Source/queue.c"/>
721           <file category="source"  name="Source/tasks.c"/>
722           <file category="source"  name="Source/portable/Common/mpu_wrappers.c"/>
723
724           <file category="include" condition="ARMCC6 GCC" name="Source/portable/GCC/ARM_CM3_MPU/"/>
725           <file category="source"  condition="ARMCC6 GCC" name="Source/portable/GCC/ARM_CM3_MPU/port.c"/>
726
727           <file category="include" name="CMSIS/RTOS2/FreeRTOS/Include/"/>
728           <file category="source"  name="CMSIS/RTOS2/FreeRTOS/Source/freertos_evr.c"/>
729           <file category="other"   name="CMSIS/RTOS2/FreeRTOS/FreeRTOS.scvd"/>
730         </files>
731       </component>
732
733
734       <component Cgroup="Core" Cvariant="Cortex-M MPU" condition="FreeRTOS MPU CM4_FP">
735         <description>Core API (Kernel, Tasks, Semaphores, Mutexes, Queues) for Cortex-M using MPU</description>
736         <RTE_Components_h>
737           #define RTE_RTOS_FreeRTOS_CORE          /* RTOS FreeRTOS Core */
738           #define RTE_RTOS_FreeRTOS_CORE_MPU      /* RTOS FreeRTOS Core with MPU support */
739         </RTE_Components_h>
740         <files>
741           <file category="include" name="Source/include/"/>
742
743           <file category="header"  name="Source/include/FreeRTOS.h"/>
744           <file category="header"  name="Source/include/queue.h"/>
745           <file category="header"  name="Source/include/semphr.h"/>
746           <file category="header"  name="Source/include/task.h"/>
747
748           <file category="source"  name="Source/list.c"/>
749           <file category="source"  name="Source/queue.c"/>
750           <file category="source"  name="Source/tasks.c"/>
751           <file category="source"  name="Source/portable/Common/mpu_wrappers.c"/>
752
753           <file category="include"   condition="ARMCC"  name="Source/portable/RVDS/ARM_CM4_MPU/"/>
754           <file category="source"    condition="ARMCC"  name="Source/portable/RVDS/ARM_CM4_MPU/port.c"/>
755
756           <file category="include"   condition="ARMCC6" name="Source/portable/GCC/ARM_CM4_MPU/"/>
757           <file category="source"    condition="ARMCC6" name="Source/portable/GCC/ARM_CM4_MPU/port.c"/>
758
759           <file category="include"   condition="GCC"    name="Source/portable/GCC/ARM_CM4_MPU/"/>
760           <file category="source"    condition="GCC"    name="Source/portable/GCC/ARM_CM4_MPU/port.c"/>
761
762           <file category="include"   condition="IAR"    name="Source/portable/IAR/ARM_CM4F_MPU/"/>
763           <file category="source"    condition="IAR"    name="Source/portable/IAR/ARM_CM4F_MPU/port.c"/>
764           <file category="sourceAsm" condition="IAR"    name="Source/portable/IAR/ARM_CM4F_MPU/portasm.s"/>
765
766           <file category="include" name="CMSIS/RTOS2/FreeRTOS/Include/"/>
767           <file category="source"  name="CMSIS/RTOS2/FreeRTOS/Source/freertos_evr.c"/>
768           <file category="other"   name="CMSIS/RTOS2/FreeRTOS/FreeRTOS.scvd"/>
769         </files>
770       </component>
771
772
773       <component Cgroup="Core" Cvariant="Cortex-M Non-Secure" condition="FreeRTOS TZ">
774         <description>Core API (Kernel, Tasks, Semaphores, Mutexes, Queues) for Cortex-M using Non-Secure Domain (TrustZone)</description>
775         <RTE_Components_h>
776           #define RTE_RTOS_FreeRTOS_CORE          /* RTOS FreeRTOS Core */
777           #define RTE_RTOS_FreeRTOS_CORE_TZ_NS    /* RTOS FreeRTOS Core with TrustZone Non-Secure Domain */
778         </RTE_Components_h>
779         <files>
780           <file category="include" name="Source/include/"/>
781
782           <file category="header"  name="Source/include/FreeRTOS.h"/>
783           <file category="header"  name="Source/include/queue.h"/>
784           <file category="header"  name="Source/include/semphr.h"/>
785           <file category="header"  name="Source/include/task.h"/>
786
787           <file category="source"  name="Source/list.c"/>
788           <file category="source"  name="Source/queue.c"/>
789           <file category="source"  name="Source/tasks.c"/>
790
791           <file category="include"   condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/"/>
792           <file category="include"   condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/non_secure/"/>
793           <file category="source"    condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/non_secure/port.c"/>
794           <file category="source"    condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/non_secure/portasm.c"/>
795
796           <file category="include"   condition="GCC"    name="Source/portable/GCC/ARM_CM33/secure/"/>
797           <file category="include"   condition="GCC"    name="Source/portable/GCC/ARM_CM33/non_secure/"/>
798           <file category="source"    condition="GCC"    name="Source/portable/GCC/ARM_CM33/non_secure/port.c"/>
799           <file category="source"    condition="GCC"    name="Source/portable/GCC/ARM_CM33/non_secure/portasm.c"/>
800
801           <file category="include"   condition="IAR"    name="Source/portable/IAR/ARM_CM33/secure/"/>
802           <file category="include"   condition="IAR"    name="Source/portable/IAR/ARM_CM33/non_secure/"/>
803           <file category="source"    condition="IAR"    name="Source/portable/IAR/ARM_CM33/non_secure/port.c"/>
804           <file category="sourceAsm" condition="IAR"    name="Source/portable/IAR/ARM_CM33/non_secure/portasm.s"/>
805
806           <file category="include" name="CMSIS/RTOS2/FreeRTOS/Include/"/>
807           <file category="source"  name="CMSIS/RTOS2/FreeRTOS/Source/freertos_evr.c"/>
808           <file category="other"   name="CMSIS/RTOS2/FreeRTOS/FreeRTOS.scvd"/>
809         </files>
810       </component>
811
812
813       <component Cgroup="Core" Cvariant="Cortex-M Non-Secure MPU" condition="FreeRTOS TZ MPU">
814         <description>Core API (Kernel, Tasks, Semaphores, Mutexes, Queues) for Cortex-M using Non-Secure Domain (TrustZone) and MPU</description>
815         <RTE_Components_h>
816           #define RTE_RTOS_FreeRTOS_CORE          /* RTOS FreeRTOS Core */
817           #define RTE_RTOS_FreeRTOS_CORE_MPU      /* RTOS FreeRTOS Core with MPU support */
818           #define RTE_RTOS_FreeRTOS_CORE_TZ_NS    /* RTOS FreeRTOS Core with TrustZone Non-Secure Domain */
819         </RTE_Components_h>
820         <files>
821           <file category="include" name="Source/include/"/>
822
823           <file category="header"  name="Source/include/FreeRTOS.h"/>
824           <file category="header"  name="Source/include/queue.h"/>
825           <file category="header"  name="Source/include/semphr.h"/>
826           <file category="header"  name="Source/include/task.h"/>
827
828           <file category="source"  name="Source/list.c"/>
829           <file category="source"  name="Source/queue.c"/>
830           <file category="source"  name="Source/tasks.c"/>
831           <file category="source"  name="Source/portable/Common/mpu_wrappers.c"/>
832
833           <file category="include"   condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/"/>
834           <file category="include"   condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/non_secure/"/>
835           <file category="source"    condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/non_secure/port.c"/>
836           <file category="source"    condition="ARMCC6" name="Source/portable/GCC/ARM_CM33/non_secure/portasm.c"/>
837
838           <file category="include"   condition="GCC"    name="Source/portable/GCC/ARM_CM33/secure/"/>
839           <file category="include"   condition="GCC"    name="Source/portable/GCC/ARM_CM33/non_secure/"/>
840           <file category="source"    condition="GCC"    name="Source/portable/GCC/ARM_CM33/non_secure/port.c"/>
841           <file category="source"    condition="GCC"    name="Source/portable/GCC/ARM_CM33/non_secure/portasm.c"/>
842
843           <file category="include"   condition="IAR"    name="Source/portable/IAR/ARM_CM33/secure/"/>
844           <file category="include"   condition="IAR"    name="Source/portable/IAR/ARM_CM33/non_secure/"/>
845           <file category="source"    condition="IAR"    name="Source/portable/IAR/ARM_CM33/non_secure/port.c"/>
846           <file category="sourceAsm" condition="IAR"    name="Source/portable/IAR/ARM_CM33/non_secure/portasm.s"/>
847
848           <file category="include" name="CMSIS/RTOS2/FreeRTOS/Include/"/>
849           <file category="source"  name="CMSIS/RTOS2/FreeRTOS/Source/freertos_evr.c"/>
850           <file category="other"   name="CMSIS/RTOS2/FreeRTOS/FreeRTOS.scvd"/>
851         </files>
852       </component>
853
854       <component Cgroup="Core" Cvariant="Cortex-A" isDefaultVariant="true" condition="FreeRTOS CA">
855         <description>Core API (Kernel, Tasks, Semaphores, Mutexes, Queues) for Cortex-M</description>
856         <RTE_Components_h>
857           #define RTE_RTOS_FreeRTOS_CORE          /* RTOS FreeRTOS Core */
858         </RTE_Components_h>
859         <files>
860           <file category="include" name="Source/include/"/>
861
862           <file category="header"  name="Source/include/FreeRTOS.h"/>
863           <file category="header"  name="Source/include/queue.h"/>
864           <file category="header"  name="Source/include/semphr.h"/>
865           <file category="header"  name="Source/include/task.h"/>
866
867           <file category="source"  name="Source/list.c"/>
868           <file category="source"  name="Source/queue.c"/>
869           <file category="source"  name="Source/tasks.c"/>
870
871           <file category="include"   condition="ARMCC"  name="Source/portable/RVDS/ARM_CA9/"/>
872           <file category="source"    condition="ARMCC"  name="Source/portable/RVDS/ARM_CA9/port.c"/>
873           <file category="sourceAsm" condition="ARMCC"  name="Source/portable/RVDS/ARM_CA9/portASM.s"/>
874
875           <file category="include"   condition="ARMCC6" name="Source/portable/GCC/ARM_CA9/"/>
876           <file category="source"    condition="ARMCC6" name="Source/portable/GCC/ARM_CA9/port.c"/>
877           <file category="sourceAsm" condition="ARMCC6" name="Source/portable/GCC/ARM_CA9/portASM.S"/>
878
879           <file category="include"   condition="GCC"    name="Source/portable/GCC/ARM_CA9/"/>
880           <file category="source"    condition="GCC"    name="Source/portable/GCC/ARM_CA9/port.c"/>
881           <file category="sourceAsm" condition="GCC"    name="Source/portable/GCC/ARM_CA9/portASM.S"/>
882
883           <file category="include"   condition="IAR"    name="Source/portable/IAR/ARM_CA9/"/>
884           <file category="source"    condition="IAR"    name="Source/portable/IAR/ARM_CA9/port.c"/>
885           <file category="sourceAsm" condition="IAR"    name="Source/portable/IAR/ARM_CA9/portASM.s"/>
886
887           <file category="include" name="CMSIS/RTOS2/FreeRTOS/Include/"/>
888           <file category="source"  name="CMSIS/RTOS2/FreeRTOS/Source/freertos_evr.c"/>
889           <file category="other"   name="CMSIS/RTOS2/FreeRTOS/FreeRTOS.scvd"/>
890         </files>
891       </component>
892
893       <component Cgroup="Config" Cvariant="CMSIS RTOS2" condition="CMSIS RTOS2 FreeRTOS">
894         <description>FreeRTOS CMSIS-RTOS2 API configuration file</description>
895         <RTE_Components_h>
896           #define RTE_RTOS_FreeRTOS_CONFIG_RTOS2  /* RTOS FreeRTOS Config for CMSIS RTOS2 API */
897         </RTE_Components_h>
898         <files>
899           <file category="doc"    name="CMSIS/Documentation/General/html/cre_freertos_proj.html#cmsis_freertos_config"/>
900           <file category="header" attr="config" name="CMSIS/RTOS2/FreeRTOS/Config/ARMCM/FreeRTOSConfig.h" version="10.2.0" condition="CoreM"/>
901           <file category="header" attr="config" name="CMSIS/RTOS2/FreeRTOS/Config/ARMCA/FreeRTOSConfig.h" version="10.2.0" condition="CoreA"/>
902         </files>
903       </component>
904
905       <component Cgroup="Config" Cvariant="FreeRTOS" condition="FreeRTOS Core">
906         <description>FreeRTOS API configuration file</description>
907         <RTE_Components_h>
908           #define RTE_RTOS_FreeRTOS_CONFIG        /* RTOS FreeRTOS Config for FreeRTOS API */
909         </RTE_Components_h>
910         <files>
911           <file category="doc"    name="CMSIS/Documentation/General/html/cre_freertos_proj.html#native_freertos_config"/>
912           <file category="header" attr="config" name="Config/ARMCM/FreeRTOSConfig.h" version="10.2.0" condition="CoreM"/>
913           <file category="header" attr="config" name="Config/ARMCA/FreeRTOSConfig.h" version="10.2.0" condition="CoreA"/>
914         </files>
915       </component>
916
917       <component Cgroup="Coroutines" condition="FreeRTOS Core">
918         <description>Co-routine API</description>
919         <RTE_Components_h>
920           #define RTE_RTOS_FreeRTOS_COROUTINE     /* RTOS FreeRTOS Co-routines */
921         </RTE_Components_h>
922         <files>
923           <file category="header" name="Source/include/croutine.h"/>
924           <file category="source" name="Source/croutine.c"/>
925         </files>
926       </component>
927
928       <component Cgroup="Event Groups" condition="FreeRTOS Core">
929         <description>Event Group API</description>
930         <RTE_Components_h>
931           #define RTE_RTOS_FreeRTOS_EVENTGROUPS   /* RTOS FreeRTOS Event Groups */
932         </RTE_Components_h>
933         <files>
934           <file category="header" name="Source/include/event_groups.h"/>
935           <file category="source" name="Source/event_groups.c"/>
936         </files>
937       </component>
938
939       <component Cgroup="Heap" Cvariant="Heap_1" condition="FreeRTOS Core">
940         <description>Very simple, does not permit memory to be freed.</description>
941         <RTE_Components_h>
942           #define RTE_RTOS_FreeRTOS_HEAP_1        /* RTOS FreeRTOS Heap 1 */
943         </RTE_Components_h>
944         <files>
945           <file category="source" name="Source/portable/MemMang/heap_1.c"/>
946           <file category="doc"    name="http://www.freertos.org/a00111.html"/>
947         </files>
948       </component>
949
950       <component Cgroup="Heap" Cvariant="Heap_2" condition="FreeRTOS Core">
951         <description>Permits memory to be freed, but not does coalescence adjacent free memory blocks.</description>
952         <RTE_Components_h>
953           #define RTE_RTOS_FreeRTOS_HEAP_2        /* RTOS FreeRTOS Heap 2 */
954         </RTE_Components_h>
955         <files>
956           <file category="source" name="Source/portable/MemMang/heap_2.c"/>
957           <file category="doc"    name="http://www.freertos.org/a00111.html"/>
958         </files>
959       </component>
960
961       <component Cgroup="Heap" Cvariant="Heap_3" condition="FreeRTOS Core">
962         <description>Wraps the standard malloc() and free() for thread safety.</description>
963         <RTE_Components_h>
964           #define RTE_RTOS_FreeRTOS_HEAP_3        /* RTOS FreeRTOS Heap 3 */
965         </RTE_Components_h>
966         <files>
967           <file category="source" name="Source/portable/MemMang/heap_3.c"/>
968           <file category="doc"    name="http://www.freertos.org/a00111.html"/>
969         </files>
970       </component>
971
972       <component Cgroup="Heap" Cvariant="Heap_4" condition="FreeRTOS Core" isDefaultVariant="true">
973         <description>Coalescences adjacent free memory blocks to avoid fragmentation. Includes absolute address placement option.</description>
974         <RTE_Components_h>
975           #define RTE_RTOS_FreeRTOS_HEAP_4        /* RTOS FreeRTOS Heap 4 */
976         </RTE_Components_h>
977         <files>
978           <file category="source" name="Source/portable/MemMang/heap_4.c"/>
979           <file category="doc"    name="http://www.freertos.org/a00111.html"/>
980         </files>
981       </component>
982
983       <component Cgroup="Heap" Cvariant="Heap_5" condition="FreeRTOS Core">
984         <description>Same as Heap_4, with the ability to span the heap across multiple non-adjacent memory areas.</description>
985         <RTE_Components_h>
986           #define RTE_RTOS_FreeRTOS_HEAP_5        /* RTOS FreeRTOS Heap 5 */
987         </RTE_Components_h>
988         <files>
989           <file category="source" name="Source/portable/MemMang/heap_5.c"/>
990           <file category="doc"    name="http://www.freertos.org/a00111.html"/>
991         </files>
992       </component>
993
994       <component Cgroup="Message Buffer" condition="FreeRTOS Core">
995         <description>Message Buffer API</description>
996         <RTE_Components_h>
997           #define RTE_RTOS_FreeRTOS_MESSAGE_BUFFER /* RTOS FreeRTOS Message Buffers */
998         </RTE_Components_h>
999         <files>
1000           <file category="header" name="Source/include/message_buffer.h"/>
1001           <file category="source" name="Source/stream_buffer.c"/>
1002         </files>
1003       </component>
1004
1005       <component Cgroup="Stream Buffer" condition="FreeRTOS Core">
1006         <description>Stream Buffer API</description>
1007         <RTE_Components_h>
1008           #define RTE_RTOS_FreeRTOS_STREAM_BUFFER /* RTOS FreeRTOS Stream Buffers */
1009         </RTE_Components_h>
1010         <files>
1011           <file category="header" name="Source/include/stream_buffer.h"/>
1012           <file category="source" name="Source/stream_buffer.c"/>
1013         </files>
1014       </component>
1015
1016       <component Cgroup="Timers" condition="FreeRTOS Core">
1017         <description>Timer API</description>
1018         <RTE_Components_h>
1019           #define RTE_RTOS_FreeRTOS_TIMERS        /* RTOS FreeRTOS Timers */
1020         </RTE_Components_h>
1021         <files>
1022           <file category="header" name="Source/include/timers.h"/>
1023           <file category="source" name="Source/timers.c"/>
1024         </files>
1025       </component>
1026
1027       <component Cgroup="TrustZone" condition="FreeRTOS TrustZone">
1028         <description>TrustZone Secure Context API</description>
1029         <RTE_Components_h>
1030           #define RTE_RTOS_FreeRTOS_TZ
1031         </RTE_Components_h>
1032         <files>
1033           <file category="header" attr="config" name="CMSIS/RTOS2/FreeRTOS/Config/ARMCM_TZ/FreeRTOSConfig.h" version="10.2.0"/>
1034
1035           <file category="header"    condition="CM33_TZ_ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/secure_port_macros.h"/>
1036           <file category="include"   condition="CM33_TZ_ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/"/>
1037           <file category="source"    condition="CM33_TZ_ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/secure_context.c"/>
1038           <file category="source"    condition="CM33_TZ_ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/secure_context_port.c"/>
1039           <file category="source"    condition="CM33_TZ_ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/secure_heap.c"/>
1040           <file category="source"    condition="CM33_TZ_ARMCC6" name="Source/portable/GCC/ARM_CM33/secure/secure_init.c"/>
1041
1042           <file category="header"    condition="CM33_TZ_GCC"    name="Source/portable/GCC/ARM_CM33/secure/secure_port_macros.h"/>
1043           <file category="include"   condition="CM33_TZ_GCC"    name="Source/portable/GCC/ARM_CM33/secure/"/>
1044           <file category="source"    condition="CM33_TZ_GCC"    name="Source/portable/GCC/ARM_CM33/secure/secure_context.c"/>
1045           <file category="source"    condition="CM33_TZ_GCC"    name="Source/portable/GCC/ARM_CM33/secure/secure_context_port.c"/>
1046           <file category="source"    condition="CM33_TZ_GCC"    name="Source/portable/GCC/ARM_CM33/secure/secure_heap.c"/>
1047           <file category="source"    condition="CM33_TZ_GCC"    name="Source/portable/GCC/ARM_CM33/secure/secure_init.c"/>
1048
1049           <file category="header"    condition="CM33_TZ_IAR"    name="Source/portable/IAR/ARM_CM33/secure/secure_port_macros.h"/>
1050           <file category="include"   condition="CM33_TZ_IAR"    name="Source/portable/IAR/ARM_CM33/secure/"/>
1051           <file category="source"    condition="CM33_TZ_IAR"    name="Source/portable/IAR/ARM_CM33/secure/secure_context.c"/>
1052           <file category="source"    condition="CM33_TZ_IAR"    name="Source/portable/IAR/ARM_CM33/secure/secure_context_port.c"/>
1053           <file category="sourceAsm" condition="CM33_TZ_IAR"    name="Source/portable/IAR/ARM_CM33/secure/secure_context_port_asm.s"/>
1054           <file category="source"    condition="CM33_TZ_IAR"    name="Source/portable/IAR/ARM_CM33/secure/secure_heap.c"/>
1055           <file category="source"    condition="CM33_TZ_IAR"    name="Source/portable/IAR/ARM_CM33/secure/secure_init.c"/>
1056         </files>
1057       </component>
1058     </bundle>
1059   </components>
1060
1061   <examples>
1062     <example name="CMSIS-RTOS2 FreeRTOS Blinky" doc="Abstract.txt" folder="CMSIS/RTOS2/FreeRTOS/Examples/Blinky">
1063       <description>CMSIS-RTOS2 Blinky example using FreeRTOS</description>
1064       <board name="uVision Simulator" vendor="Keil"/>
1065       <project>
1066         <environment name="uv" load="Blinky.uvprojx"/>
1067       </project>
1068       <attributes>
1069         <component Cclass="CMSIS" Cgroup="CORE"/>
1070         <component Cclass="CMSIS" Cgroup="RTOS2"/>
1071         <component Cclass="Device" Cgroup="Startup"/>
1072         <category>Getting Started</category>
1073       </attributes>
1074     </example>
1075
1076     <example name="CMSIS-RTOS2 FreeRTOS Blinky CA9 (AC5)" doc="Abstract.txt" folder="CMSIS/RTOS2/FreeRTOS/Examples/Blinky_CA9">
1077       <description>CMSIS-RTOS2 Blinky example using FreeRTOS for Cortex-A9 (ARM Compiler 5)</description>
1078       <board name="Fixed Virtual Platform" vendor="ARM"/>
1079       <project>
1080         <environment name="ds5" load=".project"/>
1081       </project>
1082       <attributes>
1083         <component Cclass="CMSIS" Cgroup="CORE"/>
1084         <component Cclass="CMSIS" Cgroup="RTOS2"/>
1085         <component Cclass="Device" Cgroup="Startup"/>
1086         <category>Getting Started</category>
1087       </attributes>
1088     </example>
1089
1090     <example name="CMSIS-RTOS2 FreeRTOS Blinky CA9 (AC6)" doc="Abstract.txt" folder="CMSIS/RTOS2/FreeRTOS/Examples/Blinky_CA9_AC6">
1091       <description>CMSIS-RTOS2 Blinky example using FreeRTOS for Cortex-A9 (ARM Compiler 6)</description>
1092       <board name="Fixed Virtual Platform" vendor="ARM"/>
1093       <project>
1094         <environment name="ds5" load=".project"/>
1095       </project>
1096       <attributes>
1097         <component Cclass="CMSIS" Cgroup="CORE"/>
1098         <component Cclass="CMSIS" Cgroup="RTOS2"/>
1099         <component Cclass="Device" Cgroup="Startup"/>
1100         <category>Getting Started</category>
1101       </attributes>
1102     </example>
1103
1104     <example name="Native FreeRTOS Blinky" doc="Abstract.txt" folder="CMSIS/RTOS2/FreeRTOS/Examples/Native_Blinky">
1105       <description>Blinky example using FreeRTOS natively</description>
1106       <board name="uVision Simulator" vendor="Keil"/>
1107       <project>
1108         <environment name="uv" load="Blinky.uvprojx"/>
1109       </project>
1110       <attributes>
1111         <component Cclass="CMSIS" Cgroup="CORE"/>
1112         <component Cclass="CMSIS" Cgroup="RTOS2"/>
1113         <component Cclass="Device" Cgroup="Startup"/>
1114         <category>Getting Started</category>
1115       </attributes>
1116     </example>
1117
1118     <example name="TrustZone for ARMv8-M" doc="NonSecure/Abstract.txt" folder="CMSIS/RTOS2/FreeRTOS/Examples/TrustZone">
1119       <description>CMSIS-RTOS2 example with secure/non-secure thread context management using FreeRTOS</description>
1120       <board name="uVision Simulator" vendor="Keil"/>
1121       <project>
1122         <environment name="uv" load="TrustZone.uvmpw"/>
1123       </project>
1124       <attributes>
1125         <component Cclass="CMSIS" Cgroup="CORE"/>
1126         <component Cclass="CMSIS" Cgroup="RTOS2"/>
1127         <component Cclass="Device" Cgroup="Startup"/>
1128         <category>Getting Started</category>
1129       </attributes>
1130     </example>
1131   </examples>
1132 </package>