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

..--

CMSIS/03-Aug-2024-63,12935,451

zephyr/03-Aug-2024-43

CMakeLists.txtD03-Aug-202424 21

LICENSE.txtD03-Aug-202411.1 KiB202169

README.mdD03-Aug-202411.7 KiB142101

README.md

1# CMSIS Version 5
2
3[![Version](https://img.shields.io/github/v/release/arm-software/CMSIS_5)](https://github.com/ARM-software/CMSIS_5/releases/latest) [![License](https://img.shields.io/github/license/arm-software/CMSIS_5)](https://arm-software.github.io/CMSIS_5/General/html/LICENSE.txt)
4
5The branch *master* of this GitHub repository contains ![Version](https://img.shields.io/github/v/release/arm-software/CMSIS_5?display_name=release&label=%20&sort=semver).
6The [documentation](http://arm-software.github.io/CMSIS_5/General/html/index.html) is available under http://arm-software.github.io/CMSIS_5/General/html/index.html
7
8Use [Issues](https://github.com/ARM-software/CMSIS_5#issues-and-labels) to provide feedback and report problems for CMSIS Version 5.
9
10**Note:** The branch *develop* of this GitHub repository reflects our current state of development and is constantly updated. It gives our users and partners contiguous access to the CMSIS development. It allows you to review the work and provide feedback or create pull requests for contributions.
11
12A [pre-built documentation](https://arm-software.github.io/CMSIS_5/develop/General/html/index.html) is updated from time to time, but may be also generated using the instructions under [Generate CMSIS Pack for Release](https://github.com/ARM-software/CMSIS_5#generate-cmsis-pack-for-release).
13
14## Overview of CMSIS Components
15
16The following is an list of all CMSIS components that are available.
17
18| CMSIS-... | Target Processors   | Description  |
19|:----------|:--------------------|:-------------|
20|[Core(M)](http://arm-software.github.io/CMSIS_5/Core/html/index.html)  | All Cortex-M, SecurCore | Standardized API for the Cortex-M processor core and peripherals. Includes intrinsic functions for Cortex-M4/M7/M33/M35P SIMD instructions.|
21|[Core(A)](http://arm-software.github.io/CMSIS_5/Core_A/html/index.html)| Cortex-A5/A7/A9 | API and basic run-time system for the Cortex-A5/A7/A9 processor core and peripherals.|
22|[Driver](http://arm-software.github.io/CMSIS_5/Driver/html/index.html) | All Cortex-M, SecurCore | Generic peripheral driver interfaces for middleware. Connects microcontroller peripherals with middleware that implements for example communication stacks, file systems, or graphic user interfaces.|
23|[DSP](http://arm-software.github.io/CMSIS_5/DSP/html/index.html)       | All Cortex-M | DSP library collection with over 60 Functions for various data types: fixed-point (fractional q7, q15, q31) and single precision floating-point (32-bit). Implementations optimized for the SIMD instruction set are available for Cortex-M4/M7/M33/M35P.|
24|[NN](http://arm-software.github.io/CMSIS_5/NN/html/index.html)        | All Cortex-M | Collection of efficient neural network kernels developed to maximize the performance and minimize the memory footprint on Cortex-M processor cores.|
25|[RTOS v1](http://arm-software.github.io/CMSIS_5/RTOS/html/index.html) | Cortex-M0/M0+/M3/M4/M7 | Common API for real-time operating systems along with a reference implementation based on RTX. It enables software components that can work across multiple RTOS systems.|
26|[RTOS v2](http://arm-software.github.io/CMSIS_5/RTOS2/html/index.html)| All Cortex-M, Cortex-A5/A7/A9 | Extends CMSIS-RTOS v1 with Armv8-M support, dynamic object creation, provisions for multi-core systems, binary compatible interface. |
27|[Pack](http://arm-software.github.io/CMSIS_5/Pack/html/index.html)    | All Cortex-M, SecurCore, Cortex-A5/A7/A9 | Describes a delivery mechanism for software components, device parameters, and evaluation board support. It simplifies software re-use and product life-cycle management (PLM). <br/>Is part of the [Open CMSIS Pack project](https://www.open-cmsis-pack.org). |
28|[Build](http://arm-software.github.io/CMSIS_5/Build/html/index.html)  | All Cortex-M, SecurCore, Cortex-A5/A7/A9 | A set of tools, software frameworks, and work flows that improve productivity, for example with Continuous Integration (CI) support.<br/>Is replaced with the [CMSIS-Toolbox](https://github.com/Open-CMSIS-Pack/devtools/tree/main/tools). |
29|[SVD](http://arm-software.github.io/CMSIS_5/SVD/html/index.html)      | All Cortex-M, SecurCore | Peripheral description of a device that can be used to create peripheral awareness in debuggers or CMSIS-Core header files.|
30|[DAP](http://arm-software.github.io/CMSIS_5/DAP/html/index.html)      | All Cortex | Firmware for a debug unit that interfaces to the CoreSight Debug Access Port. |
31|[Zone](http://arm-software.github.io/CMSIS_5/Zone/html/index.html)    | All Cortex-M | Defines methods to describe system resources and to partition these resources into multiple projects and execution areas. |
32
33## Implemented Enhancements
34 - CMSIS-Pack generation with [shell script template](https://arm-software.github.io/CMSIS_5/Pack/html/bash_script.html) for Windows and Linux
35 - CMSIS-Pack: [Git workflow](https://arm-software.github.io/CMSIS_5/Pack/html/element_repository.html) via Eclipse menu *Window - Preferences - CMSIS Packs - Manage Local Repositories* and [MDK](http://www.keil.com/support/man/docs/uv4/uv4_ca_packinst_repo.htm)
36 - [CMSIS-Zone release 1.0](https://arm-software.github.io/CMSIS_5/Zone/html/index.html) with support for multi-processor, TrustZone, and MPU configuration
37 - Support for Armv8.1M Architecture and Cortex-M55 (release in March 2020)
38 - CMSIS-DSP is fully ported to SIMD for Cortex-M family (Armv8.1-M)  and Cortex-A & Cortex-R with NEON, using the same APIs.
39
40## Further Planned Enhancements
41 - CMSIS-Pack:
42   - System Description SDF Format: describe more complex debug topologies than with a Debug Description in a tool agnostic way
43   - CPDSC project file format: allows project templates that are agnostic of an IDE
44   - Minimize need for IDE specific settings: CMSIS-Pack supports IDE specific parameters. Analyze and minimize
45 - CMSIS-Build: command-line driven make system for CMSIS-Pack based projects (to support CI tests)
46
47For further details see also the [Slides of the Embedded World CMSIS Partner Meeting](https://github.com/ARM-software/CMSIS_5/blob/develop/CMSIS_Review_Meeting_2020.pdf).
48
49## Other related GitHub repositories
50
51| Repository                  | Description                                               |
52|:--------------------------- |:--------------------------------------------------------- |
53| [cmsis-pack-eclipse](https://github.com/ARM-software/cmsis-pack-eclipse)    |  CMSIS-Pack Management for Eclipse reference implementation Pack support  |
54| [CMSIS-FreeRTOS](https://github.com/arm-software/CMSIS-FreeRTOS)            | CMSIS-RTOS adoption of FreeRTOS                                                      |
55| [CMSIS-Driver](https://github.com/arm-software/CMSIS-Driver)                | Generic MCU driver implementations and templates for Ethernet MAC/PHY and Flash.  |
56| [CMSIS-Driver_Validation](https://github.com/ARM-software/CMSIS-Driver_Validation) | CMSIS-Driver Validation can be used to verify CMSIS-Driver in a user system |
57| [CMSIS-Zone](https://github.com/ARM-software/CMSIS-Zone)                    | CMSIS-Zone Utility along with example projects and FreeMarker templates         |
58| [NXP_LPC](https://github.com/ARM-software/NXP_LPC)                          | CMSIS Driver Implementations for the NXP LPC Microcontroller Series       |
59| [mdk-packs](https://github.com/mdk-packs)                                   | IoT cloud connectors as trail implementations for MDK (help us to make it generic)|
60| [trustedfirmware.org](https://www.trustedfirmware.org/)                     | Arm Trusted Firmware provides a reference implementation of secure world software for Armv8-A and Armv8-M.|
61
62
63## Directory Structure
64
65| Directory            | Content                                                   |
66|:-------------------- |:--------------------------------------------------------- |
67| CMSIS/Core           | CMSIS-Core(M) related files (for release)                 |
68| CMSIS/Core_A         | CMSIS-Core(A) related files (for release)                 |
69| CMSIS/CoreValidation | Validation for Core(M) and Core(A) (NOT part of release)  |
70| CMSIS/DAP            | CMSIS-DAP related files and examples                      |
71| CMSIS/Driver         | CMSIS-Driver API headers and template files               |
72| CMSIS/DSP            | CMSIS-DSP related files                                   |
73| CMSIS/NN             | CMSIS-NN related files                                    |
74| CMSIS/RTOS           | RTOS v1 related files (for Cortex-M)                      |
75| CMSIS/RTOS2          | RTOS v2 related files (for Cortex-M & Armv8-M)            |
76| CMSIS/Pack           | CMSIS-Pack examples and tutorials                         |
77| CMSIS/DoxyGen        | Source of the documentation                               |
78| CMSIS/Utilities      | Utility programs                                          |
79
80## Generate CMSIS Pack for Release
81
82This GitHub development repository lacks pre-built libraries of various software components (RTOS, RTOS2).
83In order to generate a full pack one needs to have the build environment available to build these libraries.
84This causes some sort of inconvenience. Hence the pre-built libraries may be moved out into separate pack(s)
85in the future.
86
87To build a complete CMSIS pack for installation the following additional tools are required:
88 - **doxygen.exe**    Version: 1.8.6 (Documentation Generator)
89 - **mscgen.exe**     Version: 0.20  (Message Sequence Chart Converter)
90 - **7z.exe (7-Zip)** Version: 16.02 (File Archiver)
91
92Using these tools, you can generate on a Windows PC:
93 - **CMSIS Documentation** using the batch file **gen_doc.sh** (located in ./CMSIS/Doxygen).
94 - **CMSIS Software Pack** using the batch file **gen_pack.sh** (located in ./CMSIS/Utilities).
95   The bash script does not generate the documentation. The pre-built libraries for RTX4 and RTX5
96   are not included within this repository.
97
98The file ./CMSIS/DoxyGen/How2Doc.txt describes the rules for creating API documentation.
99
100## License
101
102Arm CMSIS is licensed under Apache 2.0.
103
104## Contributions and Pull Requests
105
106Contributions are accepted under Apache 2.0. Only submit contributions where you have authored all of the code.
107
108### Issues and Labels
109
110Please feel free to raise an [issue on GitHub](https://github.com/ARM-software/CMSIS_5/issues)
111to report misbehavior (i.e. bugs) or start discussions about enhancements. This
112is your best way to interact directly with the maintenance team and the community.
113We encourage you to append implementation suggestions as this helps to decrease the
114workload of the very limited maintenance team.
115
116We will be monitoring and responding to issues as best we can.
117Please attempt to avoid filing duplicates of open or closed items when possible.
118In the spirit of openness we will be tagging issues with the following:
119
120- **bug** – We consider this issue to be a bug that will be investigated.
121
122- **wontfix** - We appreciate this issue but decided not to change the current behavior.
123
124- **enhancement** – Denotes something that will be implemented soon.
125
126- **future** - Denotes something not yet schedule for implementation.
127
128- **out-of-scope** - We consider this issue loosely related to CMSIS. It might by implemented outside of CMSIS. Let us know about your work.
129
130- **question** – We have further questions to this issue. Please review and provide feedback.
131
132- **documentation** - This issue is a documentation flaw that will be improved in future.
133
134- **review** - This issue is under review. Please be patient.
135
136- **DONE** - We consider this issue as resolved - please review and close it. In case of no further activity this issues will be closed after a week.
137
138- **duplicate** - This issue is already addressed elsewhere, see comment with provided references.
139
140- **Important Information** - We provide essential information regarding planned or resolved major enhancements.
141
142