Embedded Systems Software Design
Embedded Systems Software Design
Core modules from this course are available as part of our embedded boot camp: Embedded Systems Hardware Design Boot Camp for the Zynq UltraScale+ MPSoC
This course is available as private training only.
COURSE CODE: EMBD-SW
This course introduces the concepts, tools, and techniques required for software design and development for the Zynq System on a Chip (SoC), Zynq UltraScale+ MPSoC, and the Versal adaptive SoC architectures using the Vitis unified software platform.
The focus is on:
- Reviewing the basics of Vitis tool use
- Customizing board support packages (BSPs) for resource access and management of the AMD Xilinx Standalone library
- Utilizing device drivers effectively
- Developing software applications for the available processors
- Debugging and integrating user applications
- Employing best practices to enable good design decisions
3-Day Instructor-led Course | Price USD | Training Credits |
---|---|---|
Hosted Online - $600/day | $1800 | 18 |
In-Person Public Registration - $600/day | $1800 | 18 |
Private Training | Learn More | Learn More |
Coaching | Learn More | Learn More |
Printed Course Book (A PDF book is included in the course fee)
Cannot be purchased without registration. | $200 | 2 |
Scheduled Classes
No Scheduled Sessions - Contact Us to ask about setting one up!
3 Days
Be the first to know. Sign up for our newsletter.
Who should attend:
Software design engineers interested in system design and implementation and software application development and debugging using the AMD Xilinx Standalone library.
Software Tools
- Vivado Design Suite
- Vitis unified software platform
Hardware
- Architectures: Zynq-7000 SoC (Cortex-A9 processor) and Zynq UltraScale+ MPSoC (Cortex-A53 and Cortex-R5 processor)
- Demo board: Zynq UltraScale+ MPSoC ZCU104 or Versal ACAP VCK190 board*
* This course focuses on the Zynq-7000 SoC and the Zynq UltraScale+ MPSoC architectures.
Skills Gained
After completing this comprehensive training, you will know how to:
- Implement an effective software design environment for an AMD Xilinx embedded system using the AMD Xilinx software development tools
- Write a basic user application (under Standalone or Linux) using the Vitis unified software platform and run it on an embedded system
- Use AMD Xilinx debugger tools to troubleshoot user applications
- Apply software techniques to improve operability
- Maintain and update software projects with changing hardware
Course Outline
Day 1 | Day 2 | Day 3 |
---|---|---|
Overview of Embedded Software Development Overview of the process for building a user application. {Lecture} Embedded UltraFast Design Methodology Outlines the different elements that comprise the Embedded Design Methodology. {Lecture, Demo} Zynq-7000 SoC Architecture Overview Overview of the Zynq-7000 SoC architecture. {Lecture, Demo, Lab} Zynq UltraScale+ MPSoC Architecture Overview Overview of the Zynq UltraScale+ MPSoC architecture. {Lecture, Demo, Lab} Zynq UltraScale+ MPSoC Software Environments Describes the software development environments for Zynq UltraScale+ MPSoCs. {Lecture} Driving the Vitis Software Development Tool Introduces the basic behaviors required to drive the Vitis tool to generate a debuggable C/C++ application. {Lecture, Demo, Lab} System Debugger Describes the basics of actually running a debugger and illustrates the most commonly used debugging commands. {Lecture, Lab} | Standalone Software Platform Development and Coding Support Covers the various software components, or layers, supplied by AMD that aid in the creation of low-level software and includes a discussion on drivers, domains, operating systems, and libraries. Also covers the basic services (libraries) available when coding in the Standalone environment. {Lecture, Demo, Lab} FAT File System for Standalone Introduces the FAT file system (FFS) from the Standalone/Bare-metal library. The FFS provides drivers and utilities for effectively converting a region of memory into a file system. {Lecture, Lab} Using Linker Scripts Overview of the purpose and typical use of a linker script. {Lecture, Lab} Introduction to Interrupts Introduces the concept of interrupts, basic terminology, and generic implementation. {Lecture} Software Interrupts: Writing Describes many of the considerations that a software coder must take into account when supporting interrupts. {Lecture, Lab} | Operating Systems: Introduction and Concepts Introduces the concept of the operating system and provides a simplified view into the generic way that operating systems work. {Lecture} Linux: A High-Level Introduction Introduces the Linux operating system, a brief history, and how to use it. {Lecture} Linux Software Application Development Overview Highlights important parts of the underlying Linux system as it pertains to applications. {Lecture, Demo, Lab} Driving the PetaLinux Tool Introduces the basic concepts required to build an application using the PetaLinux tool. {Lab} Building a Linux Application in the Vitis IDE Provides an introduction to using the Vitis IDE tool for Linux software development. {Lecture, Demo} Booting Overview Describes the main points to how booting a processor is handled for Zynq SoC devices and MicroBlaze processors. {Lecture, Lab} Software Profiling Overview Introduces the purpose and techniques for profiling a user application. {Lecture, Demo, Lab} Understanding Device Drivers Explains the concept of a device driver and how it is used by embedded systems. {Lecture, Demo} Custom Device Drivers Describes how to successfully write a custom device driver. {Lecture, Lab} Debugging Using Cross-Triggering Illustrates how hardware-software cross-triggering techniques can uncover issues. {Lecture, Lab} |
Please note: The instructor may change the content order to provide a better learning experience.
Prerequisites:
- C or C++ programming experience, including general debugging techniques
- Conceptual understanding of embedded processing systems, including device drivers, interrupt routines, writing and modifying scripts, user applications, and boot loader operation