Developing with ARM Cortex-M
Standard Level - 4 daysview dates and locations
Project-ready training for product development based on platforms incorporating ARM® microcontroller IP (New and updated to include ARM Cortex®-M7)
This course is designed for engineers developing software for platforms based around any of the ARM Cortex-M Series processors. The course includes an introduction to the ARM product range and supporting IP, the processor core, programmers' model, instruction set and debug architecture. It includes a number of worked examples and hands-on CMSIS compliant exercises to reinforce the training material. It also includes content on the very latest ARMv7-M Series cores including the M7.
Who should attend?
Software engineers writing application and system software for platforms using any of the ARM Cortex-M processor cores, including M0, M0+, M3, M4 , M7.
- Some knowledge of embedded systems
- Basic awareness of ARM is useful but not essential
- Knowledge of programming in C
- Experience of assembler programming is not required but would be beneficial
This class is based on source training material developed by ARM themselves, augmented with supplemental content and labs developed by Doulos. Doulos is a global ARM Approved Training Center.
The majority of the course content and sessions are relevant and of value for engineers developing products using platforms based on any of the current M Series family. In public class delivery contexts, the specific agenda followed may vary from that indicated below dependent on the focus and interests of the course participants attending that event. Upon registration, course participants will be asked to indicate which specific M Series core they are focusing on, which will steer the class agenda to some degree.
Note the course includes a valuable comparison of capabilities and application variance between different members of the M Series family which will be of benefit to evaluators as well as those preparing for project.For private team-based training for software developers, the course can be focused entirely on a specific M Series core. The course descriptions for these courses can be found below:
- ARM Cortex-M0 Software Design
- ARM Cortex-M0+ Software Design
- ARM Cortex-M3/M4 Software Design
- ARM Cortex-M7 Software Design
For private team based training for system designers and integrators, there are also course options available:
- ARM Cortex-M0 SoC Design
- ARM Cortex-M0+ SoC Design
- ARM Cortex-M3/M4 SoC Design
- ARM Cortex-M7 SoC Design
The following is representative of the public class agenda followed which includes participants requiring content covering M7 capability as well as M4, M3 and M0.
Introduction to ARMARM as a company • Processor portfolio • Supported architectures • Processor profiles
Cortex-M OverviewBlock diagram • Architectural features • Instruction set • Programmer's model • Memory map • Memory interfaces • Caches • Exception handing • Memory protection • Power management • Implementation options
Tools Overview for ARM MicrocontrollersKeil MDK • ULINK/DSTREAM debug adapters • Development boards • DS-5
Cortex-M Programmers' ModelData types • Core registers • Modes, privileges and stack • Exceptions • Instruction set overview
Assembly ProgrammingData processing instructions • Load/Store instructions • Flow control • Miscellaneous instructions
ARMv7-M Exception HandlingException Model • Interrupts • Writing the vector table and interrupt handlers • Internal exceptions and RTOS support • Fault exception
ARMv7-M Memory ModelMemory address space • Memory types and attributes • Alignment and endianness • Barriers
Understanding BarriersData memory barrier • Data synchronization barrier • Instruction synchronization barrier • Barrier applications examples
Embedded Software DevelopmentDefault compilation behavior • System startup • Tailoring the image memory map to a device • Post startup initialization • Tailoring the C library to a device • Building and debugging an image
ARMv7-M Compiler Hints & TipsBasic Compilation • Compiler optimisations • Coding considerations • Mixing C/C++ and assembly • Local and global data issues
ARMv7-M Linker and Libraries Hints & TipsLinking basics • System and user libraries • Veneers • Stack issues • Linker optimisations and diagnostics • ARM supplied libraries
ARMv7-M SynchronizationIntroduction to synchronization and semaphores • Exclusive accesses • Bit-banding
Extensions (M4/M7)DSP • Floating Point
ARMv7-M DebugCoresight and debug access port DAP • Debug event and reset • Flash patch and breakpoint unit (FPB) • Data watch point and trace unit (DWT) • Instrumentation trace macrocell (ITM) • Embedded trace macrocell (ETM) • Trace port interface unit (TPIU)
Appendix (Selectively covered depending on time budget)
CMSIS OverviewCMSIS-Core • CMSIS-DSP • CMSIS-RTOS • CMSIS-SVD • CMSIS-DAP
ARMv7-M Memory ProtectionMemory protection overview • Regions overview • Regions overlapping • Setting up the MPU
Cortex-M Level 1 Sub-Systems (M7)Caches • Tightly coupled memory (TCM) • System considerations
Introduction to AMBA ProtocolsAXI • AHB • APB
ExercisesOur hands-on exercises are provided as a self contained virtual machine that can easily be taken away by the students by the end of the class. Our virtual machine works on most operating systems and features a full pre-configured embedded development environment based in industry de-facto standards such as GNU tools and Eclipse. The laboratories work both on pre-installed instruction set simulators and microcontroller development boards. Currently, project files support the STM32 and FRDM boards. Infineon and Texas Instrument boards are currently supported by the tool suite but project files are to be added in the near future.
The exercises cover a large spectrum of topics; Starting with assembly programming, data transfers, data processing, flow control, digital signal processing. Exception handling with the implementation priority schemes and pre-emption. Mixing C and assembly to provide a semi-hosted solution.
Board support list
- ST NUCLEO STM32F411E (inc. labs)
- ST NUCLEO STM32F103RB (inc. labs)
- NXP FRDM-KL46Z (inc. labs)
- NXP FRDM-KL25Z (inc. labs)
- TI LM4F120XL
- Infineon XMC4500
ARM® and Cortex® are registered trade marks of ARM Holdings Plc.
|May 2nd, 2017||Munich, DE||Enquire|
|June 5th, 2017||San Jose, CA||Enquire|
|June 26th, 2017||Ringwood, UK||Enquire|
|July 11th, 2017||Munich, DE||Enquire|
|October 23rd, 2017||San Jose, CA||Enquire|
|October 30th, 2017||Ringwood, UK||Enquire|
|November 7th, 2017||Munich, DE||Enquire|
|indicates CONFIRMED TO RUN courses.|
Looking for team-based training, or other locations?
Complete an on-line form and a Doulos representative will get back to you »Back to top