Every time that I’m free, I will be posting some
interesting tutorials on CloudX, Microchip PIC and most especially STM32.
Recently I discovered about Embedded Linux and its applications which I will
also write tutorials about later. Migrating from Microchip PIC or ATMEL
processors to Cortex M is almost like you’re starting embedded systems all
over again because you will have to learn the selected MCU datasheet, reference
manual, firmware library, the pin mapping and the peripherals. Though learning
will be a bit faster since you’ve been writing embedded codes before. It took me
about a week to fully understand the complete Cortex-M architecture and the
Standard Peripheral Library (SPL) which will be discussed later in this tutorial.
I wrote my first ARM®-based 32-bit MCU tutorial “Programming STM32 on Linux” on medium.com showing how to program
the microcontroller on Linux Distros without depending on any IDE. This tutorial is not for
people completely new to the C language or embedded
programming. I
assume you have a decent knowledge of C and are not new to most fundamental
concepts of digital electronics and MCU programming irrespective of the
manufacturer.
Most
new microcontrollers are nowadays based on the ARM architecture and specifically
on the popular Cortex-M3 and Cortex-M4 processors. Using ARM Cortex-M3 and
Cortex-M4 processors based devices today is straightforward since a wide range
of development tools, debug utilities, and many example projects are available.
However, writing efficient applications could require in-depth knowledge about
the hardware architecture and the software model. It gives insight into popular
software development tools along with extensive programming examples that are
based on the Cortex Microcontroller Software Interface Standard (CMSIS).
With the term ARM, it refer to both a multitude of families of Reduced Instruction Set
Computing (RISC)
architectures and several families of complete cores which are the building blocks of CPUs produced by many
microcontroller manufacturers or vendors like STMicroelectronics, Analog Devices, Atmel, Cypress, EnergyMicro, Freescale, Fujitsu,
Holtek, Infineon, Microsemi, Milandr, NXP, Samsung, Silicon Laboratories, Texas
Instrument, and Toshiba. ARM does
not make microcontrollers. ARM designs processors and various components that
silicon designers need and licenses these designs to various silicon design
companies including microcontroller vendors. When dealing with ARM based processors, a lot of
confusion may arise due to the fact that there are many different ARM architecture revisions
(ARMv6, ATMv6-M, ARMv7-M, ARMv7-A, and so on) and many core architectures, which are in
turn based on an ARM architecture revision. For the sake of clarity, for example, a processor based on
the Cortex-M3 and Cortex-M4 core is designed on the ARMv7-M architecture. Both are high-performance processors that are
designed for microcontrollers while the Cortex-M0, Cortex-M0+, and the Cortex-M1
processors are based on ARMv6-M, which has a smaller instruction set.
I don’t want to spend much time on the introduction, you can find books that would explain in details all you need to know about the
Cortex-M series. I will quickly take us through what you need to know on how to create
your first hello world project by blinking an LED.
In this tutorial series, I will be using Atollic TrueStudio for STM32 IDE, which
I promised to write about when I wrote my first STM32 Linux tutorial on medium.
I have tried different STM32 IDE in which most are not free, I also prefer
Coocox but the developers have stopped improving and supporting the software. I
prefer to code on Atollic Truestudio ever since it was acquired by ST
Microelectronics and has been fully improved on with a lot of features supporting
all STM32 devices and development boards, built on Eclipse, CDT, Highly
optimizing C/C++ compiler, code editor and review, Build/Memory Analyzer, Stack
Analyzer, Single and multi-core Debug, Project Management, Hard Fault Analysis,
Version Control for Git, Trace & Profiling, Bug Tracking, RTOS-aware Debug.
Inputs, outputs, and peripherals accesses
Almost
all microcontrollers have various Input/Output (I/O) interfaces and peripherals
such as timers, Real-time Clock (RTC), and so on. For microcontroller products
based on the ARM_ Cortex_-M3, and M4 processors, as well as common interface
peripherals such as GPIO, SPI, UART, I2C, you can also find many advanced interface
peripherals like USB, CAN, Ethernet, and analogue interfaces like ADCs (Analog
to Digital Converters) and DACs (Digital to Analog Converters).
Understanding the STM32 Libraries.
There
are basically two libraries (SPL and HAL) developed for STM32 MCUs while Cortex
Microcontroller Software Interface Standard (CMSIS) is a hardware abstraction
layer for all ARM Cortex-M devices developed to allow microcontroller and software vendors
to use a consistent software infrastructure to develop
software solutions for Cortex_-M microcontrollers. It means you don’t need to worry about
compatibility issues across different Cortex-M manufacturers.
This two libraries, Standard Library Peripheral (SPL)
and Hardware Abstraction Layer (HAL) which are the old and new library
respectively. It was developed by ST to make project development faster for
programmers. Actually, you can also program STM32 using embedded OS for
multitasking purpose without having to bother about the hardware. I will
also post tutorials on using my favourite RTOS API driver called ChibiOS
developed by Giovanni, though there are many other good embedded OS like the popular FreeRTOS, embOS
etc,
To
be able to code any STM32, you will need to download the specific datasheet and
reference manuals. In most of my tutorials, I advise you to use the SPL which
will allow you to have deep understanding on how the peripherals really works,
although there are many tutorials and books on the internet that shows more on
how to use HAL for project development. Many RTOS drivers also support HAL. If
you have enough time, you can also learn to use both libraries.
All
this libraries are created to make programmers life easier, all you need to do
is to learn how to use the library, there are also a lot of documentations and
sample codes, and you also need to learn the ST microcontroller architecture
which you want to use. I recommend you search on google for UM0427 User
manual to understand and know how to use the SPL ARM®-based
32-bit MCU STM32F101xx and STM32F103xx firmware library properly.
Step and Step Guide to build your first Project
For
this project, I have chosen to use STM32F103C8T6, it’s one of the popular Cortex-M3
device. I intentionally selected this MCU because it’s the cheapest you can
find in the market, it cost about $2 but sold around 1500 Naira in the Nigeria
market, the board comes in different PCB colors, The blue PCB color is
referred to as “Blue Pill”, the black PCB as “Black Pill” and the Red PCB as “Red
Pill”. I have used the blue pill and black pill board, the only difference in
the PCB is that the blue pill has a 5v pinout which makes it very easy to
quickly get it into any of your microcontroller project unlike the black pill that
will still require an external 3.3v regulator.
Blue Pill |
Black Pill |
This
is the breakdown of the name:
• STM32 (STMicroelectronics
platform)
• F1 (device family)
• 03 (subdivision of the
device family)
• C8T6 (physical
manifestation affecting amount of SRAM, flash memory, and so on)
I
strongly recommend you go through the datasheet to get full feature details on
the pins assignments etc. The MCU is a Medium-density performance line ARM®-based
32-bit MCU with 64 or 128 KB Flash, USB, CAN, 7 timers, 2 ADCs, 9 com. Interfaces.
Features
·
4 x 16-bit GPIO Ports
(most are 5-volt tolerant)
3 x USART (Universal Synchronous/Asynchronous Receiver/ Transmitter)
3 x USART (Universal Synchronous/Asynchronous Receiver/ Transmitter)
·
2 x I2C controllers
·
2 x SPI controllers
·
2 x ADC (Analog Digital
Converter)
·
2 x DMA (Direct Memory
Address controllers)
·
4 x timers
·
watch dog timers
·
1 x USB controller
·
1 x CAN controller
·
1 x CRC generator
·
20K static RAM
·
64K (or 128K) FLASH
memory
·
ARM Cortex M3 CPU, max 72
MHz clock
STLINK V2
The next important
piece of hardware is a programming adapter and debugger. Fortunately, these are
also very economically priced. These can be found on the local market or online
stores like Hub360 in Nigeria for about $5 US approximately N1500 in Naira.
Most auctions
will include four detachable wires to connect the unit to your STM32 device.
Try to buy a unit that includes these unless you already have a cable. The USB
programmer is usable from Windows, Raspberry Pi, Linux, and MacOS.
Programming STM32F103C8
I assumed you’ve
downloaded Atollic TrueStudio IDE and you’ve setup your project, you can drop a
comment if you want me to write a tutorial on how to setup the IDE and create a
project.
The Black
pill has an on-board LED which the negative pin is connected through a resistor to
PB12 and its positive pin is connected to the MCU 3.3v. Using the Blue pill
board, the on-board LED ground is connected through a resistor to PC13 while
its positive pin is connected to the MCU 3.3v.
You can either use the Blue or the Black pill because the same processor is being used in both PCBs and they are almost the same size too only the extra 5v input pin differ.
To create new
project, Click on New -> C
Project, type in your Project Name and under the Project
Type select Embedded C Project
and click Next, In Target, type
STM32F103C8
and select the MCU and then click Next, Under Debug Mode,
select the ST-LINK and then Finish.
I will write and explain the blinking LED code below using the Standard
Peripheral Library.
Navigate to src folder under the new project folder created and
open main.c, delete all the initialized code that appears in the editor and then copy and paste this code below into it.
#include "stm32f10x.h"
void Delay()
{
for(uint16_t i=0; i<1000; i++) for(uint16_t j=0; j<1000; j++);
}
void GPIO_Setup(void)
{
GPIO_InitTypeDef GPIOx;
// Enables the High Speed APB (APB2) peripheral clock
// PORTB Enabled
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
//configures the operating mode for the selected pins as
Push-Pull Output
GPIOx.GPIO_Mode = GPIO_Mode_Out_PP;
//configure the speed for the selected pins
GPIOx.GPIO_Speed = GPIO_Speed_2MHz;
// selects the GPIO pins to configure. Multiple-pin
configuration can be
// performed by using the ‘|’ operator.
// configure pin 12 of PORTB
GPIOx.GPIO_Pin = GPIO_Pin_12;
//Initialisess
the GPIOx peripheral according to the specified parameters
GPIO_Init(GPIOB, &GPIOx);
}
/**
**===========================================================================
**
** Abstract: main program to blink LED on PB12
**
**===========================================================================
*/
int main(void)
{
GPIO_Setup(); // call the GPIO pin setup function
while(1)
{
GPIO_SetBits(GPIOB, GPIO_Pin_12); //Off the LED
since the negative pin is connected to PB12
// You can also use GPIO_WriteBit(GPIOB, GPIO_Pin_12, SET);
Delay();
GPIO_ResetBits(GPIOB, GPIO_Pin_12); //On the LED
since the negative pin is connected to PB12
// You can also use GPIO_WriteBit(GPIOB, GPIO_Pin_12, RESET);
Delay();
}
}
We can now
build our code by clicking on the Build icon at the upper part of the IDE, once
our code compiles successfully, ensure your STLINK is connected to the Serial
Wire Debug (SWD) pin of the board and then click on the debug icon.
STLINK ---- Black/Blue Pill
3.3V 3.3V
SWDIO DIO
SWCLK CLK
GND GND