STM32Fx Microcontroller Custom Bootloader Development
Learn fundamentals of Bootloader Development for your ARM Cortex Mx based STM32Fx Microcontroller
What you’ll learn
Write your own custom bootloader for your STM32Fx microcontroller and test
Host Bootloader Communication implementation
Custom Bootloader command packets
Different boot modes of the STM32 Microcontroller
Boot loader flash handling implementation : Sector Erase/Program/Mass erase
Boot loader options bytes(OB) Program handling implementation
Boot loader Flash sector protection status handling implementation
Boot loader In application programming implementation (IAP)
Vector table relocation of ARM cortex Mx processor
STM32Fx based board is needed if you want to test the code developed
Basic ‘C’ Programming Knowledge is required but not mandatory
Get started with Micro-controller Bootloader Development.
This course will be suitable for beginners in the domain of embedded systems and programming.
This course is all about learning to develop a custom BootLoader for ARM CORTEX Mx powered STM32Fx microcontroller.
In this course, I will guide you through a step-by-step procedures to develop your own BootLoader and we will explore many things related to BootLoader programming.
The BootLoader we are going to develop in this course will have the following features
1) It can do in-application programming(IAP). You can use the BootLoader to flash a given application binary
2) Read microcontroller-specific data
3) Flash related configurations like setting up read and write protections for different sectors
4) Flash sector erase
5) Mass erase of the user flash
6) Read and display the protection status of the flash memory
7) Jump to the specified address to execute the code
Along with custom BootLoader development, you will also understand
1) The different memory organization of a microcontroller
2) Memory aliasing and different boot modes of STM32
3) How MCU boots after power-up
4) Vector table mapping and vector table relocation use case of arm cortex mx processor.
5) Difference between In-system programming(ISP) and in-application programming(IAP)
6) Custom boot loader design flow chart
7) Host and Boot loader communication method
8) Implementation of different boot loader commands
You can also extend this BootLoader by giving the following features once you complete the course
1) Encrypt and Decrypt the firmware sent by the host using AES
2) Over-the-air programming by interfacing WIFI or Zigbee Modules
Hardware used in this course:
In this course, STM32F446RE Nucleo board is used.
If you have any other board based on the STM32 microcontroller then also you can use the codes developed in the course with no or minor changes.
1) KEIL-MDK-5 for WINDOWS
2) OpenSTM32 SystemWorkbench for (WINDOWS/LINUX/MAC OS)
Learning order of FastBit Embedded Brain Academy Courses,
If you are a beginner in the field of embedded systems, then you can take our courses in the below-mentioned order.
This is just a recommendation from the instructor for beginners.
1) Microcontroller Embedded C Programming: absolute beginners(Embedded C)
2) Embedded Systems Programming on ARM Cortex-M3/M4 Processor(ARM Cortex M4 Processor specific)
3) Mastering Microcontroller with Embedded Driver Development(MCU1)
4) Mastering Microcontroller: TIMERS, PWM, CAN, RTC,LOW POWER(MCU2)
5) Embedded System Design using UML State Machines(State machine)
6) Mastering RTOS: Hands-on FreeRTOS and STM32Fx with Debugging(RTOS)
7) ARM Cortex M Microcontroller DMA Programming Demystified(DMA)
8) STM32Fx Microcontroller Custom Bootloader Development(Bootloader)
9) Embedded Linux Step by Step using Beaglebone Black(Linux)
10) Linux device driver programming using Beaglebone Black(LDD1)
Who this course is for:
- Students in the field of Microcontroller and Embedded Systems
- Professionals working in the field of Embedded systems
Created by FastBit Embedded Brain Academy, Kiran Nayak
Last updated 8/2022
Size: 3.23 GB