class: title, smokescreen, shelf, bottom, no-footer background-image: url(images/2019-12-13-12-58-54.png) # 181U Spring 2020 ### Introduction to STM32 --- layout: true .footer[ - Geoffrey Brown, 2020 - 181U ] <style> h1 { border-bottom: 8px solid rgb(32,67,143); border-radius: 2px; width: 90%; } .smokescreen h1 { border-bottom: none; } .small.remark-slide-content.compact {font-size:1.2rem} .smaller.remark-slide-content.compact {font-size:1.1rem} .small-code.remark-slide-content.compact code {font-size:1.0rem} .very-small-code.remark-slide-content.compact code {font-size:0.9rem} .line-numbers{ /* Set "line-numbers-counter" to 0 */ counter-reset: line-numbers-counter; } .line-numbers .remark-code-line::before { /* Increment "line-numbers-counter" by 1 */ counter-increment: line-numbers-counter; content: counter(line-numbers-counter); text-align: right; width: 20px; border-right: 1px solid #aaa; display: inline-block; margin-right: 10px; padding: 0 5px; } </style> --- class: compact # Agenda data:image/s3,"s3://crabby-images/586dd/586ddda197cc386b0ea36b76ad3f03f3d11c4edd" alt="" * What's a microcontroller ? * ARM Embedded Processors * STM32L4 Processor * Nucleo board Intel i9 Coffee Lake data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/d7a09/d7a09aeec0a8e827b63a158830bc0be8e1ac683c" alt="" --- class: compact # Microcontroller data:image/s3,"s3://crabby-images/68a4f/68a4f5e64ca5f00eccca41348ca6cf288da47a15" alt="8051 Block Diagram" * Self-contained processor on a chip * Desktop processors require an army of other parts * Extremely low cost -- pennies to a few dollars * 8-bit,16-bit, 32-bit are typical sizes * Most common 8-bit -- 8051 (designed in 1980), used in mice, keyboards, etc. * Most common 32-bit -- ARM Cortex-M[0-4] * Typically have common I/O devices built-in --- class: compact # STM32 Family data:image/s3,"s3://crabby-images/034ce/034ced2376c21c4c095e893c9c025c6e41b3e549" alt="" * STM32F0x -- Cortex-M0 based, very low power, up to 40Mhz * F1, L1, F2 -- Cortex-M3 based (L1 is low power, up to 72Mhz * F3 -- Cortex-M4 based, 72 Mhz, floating point unit * F4 - Cortex-M4 based 250MHz, floating point unit * L4 -- Cortex-M4 based, extremely low power, 80Mhz data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/b7bf9/b7bf90060c41270d9e4377d36bbecd59e905da10" alt="" --- class: compact, col-2 # Bit Tag * Weight (without harness) 0.64g * Dimensions 22x9x6mm * Runtime (depends on mode, limited by battery to 5000 hours) * Bit/sec storage 239 hours * Cnt/minute 2395 hours * Cnt/4 minutes 5000 hours * Battery capacity 5.5mAh * Average current 1uA * CPU STM32L432KC * Accelerometer ADXL362 * Clock +/-3ppm * data:image/s3,"s3://crabby-images/62ff3/62ff3b46eb572611efaa1ff74f909c622706804d" alt="" data:image/s3,"s3://crabby-images/f7ca3/f7ca3e39ba40eedca282512c9745a9fcbd00025c" alt="" --- class: compact, col-2 # Cortex-M4 * There are many many Cortex-M4 based processors from many silicon providers including * Analog Devices * Cypress * Infineon * Maxim * Microchip * NXP * Silicon Labs * STM * Texas Instruments * ... * The core functionality is defined by ARM * CPU and Instruction Set * Debug hardware * Interrupt controller * The Compiler and binary tool chain is the same across manufacturers * **The I/O devices are manufacturer specific** --- class: compact # STM32L432 data:image/s3,"s3://crabby-images/6baea/6baea641e7027fa619b9d0c6d3fb0d5ef81fd32b" alt="" * Core Processor is Cortex-M4 * Huge number of communication interfaces * USB * Serial Audio * 2x I2C * 3x USARTs * ... * ADC (analog to digital converter) * 2x DAC (digital to analog converter) * Extreme low power mode * --- class: compact # Microcontroller I/O (input/output) data:image/s3,"s3://crabby-images/2181a/2181a3cd2ffb5c57492b33d3faddc5b71f5ebae4" alt="" Key Hardware Concepts are * Memory-mapped I/O * Interrupts * DMA Key Hardware Components are * Timers * A/D and D/A converters * Communication Interfaces * Serial ports * I2C busses * SPI busses --- class: compact # Reality is a bit more complicated data:image/s3,"s3://crabby-images/b0621/b0621bd937b54b03f999afa76d15094b048724e3" alt="" data:image/s3,"s3://crabby-images/9dc11/9dc11e86a1f48ce8e65f57318f6355cc4b7c3a9e" alt="" data:image/s3,"s3://crabby-images/1663e/1663e9efece03b6d19508b67facf1bf85a2201b8" alt="" --- class: compact # C Memory Model (Simplified) data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/d3c3b/d3c3bddb756589f110e33150126784fb1d6d7e5e" alt="" --- class: compact # Programming Model data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/ac144/ac1444bc4d32081aced018b9b638db5f65b08516" alt="" --- class: small-code,compact,hljs-tomorrow-night-eighties,line-numbers # C/Assembly Example ```C int counter; int counterInc(void) { return counter++; } ``` ```Assembly counterInc : 0 024B ldr r3, .L2 @ r3 = &counter 2 1868 ldr r0, [r3] @ r0=*((int*)r3) 4 421C adds r2, r0, 1 @ r2=r0+1 6 1A60 str r2, [r3] @ *((int *) r3) = r2 8 7047 bx lr @ return , value in r0 a C046 . align 2 @ choose next 4 byte address .L2: c 00000000 .word counter @ &counter will be stored here ``` --- class: compact # Memory Mapped I/O data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/f7097/f7097422ff31486f095b37249cf80407639ea8fd" alt="" --- class: small-code,compact,hljs-tomorrow-night-eighties,line-numbers # Memory Access Instructions At the machine instruction level, this interface is completely hidden. The Cortex-M0 (and most processors) has only two basic memory access instructions. Load, which reads from “memory” address (pointer) ```C ldr r1, [r2] % r1 = *r2 ``` and Store, which writes to a “memory” address: ```C str r1, [r2] % *r2 = r1 ``` --- class: compact # Cortex Memory Map data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/98509/9850997a2556122e836912780f77488a1fd6858a" alt="" --- class: compact # STM32L432 Memory Map data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/02c5e/02c5eaa968457cebf8184d8a29e4911a5c0bceba" alt="" --- class: compact # Serial Communications Topology data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/d5e90/d5e90ff4c6f6f22d13e0527d2b0caa8b76f053c6" alt="" --- class: compact # Serial Communications Protocol data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/1558a/1558a00943b14d495845f19d9105842b4953d459" alt="" --- class: compact # UART Device Model data:image/s3,"s3://crabby-images/ba58d/ba58dfd4e9a8ec96a0f88478ce3459883b1d738b" alt="" data:image/s3,"s3://crabby-images/3d749/3d749d8f09fec629e566940da9a68f7d463d79d9" alt="" --- class: compact # STM32L432 Peripheral Memory Map data:image/s3,"s3://crabby-images/8a335/8a3352a7308656a3c21788f94ec8834a31a7ff98" alt="" --- class: small-code,compact,hljs-tomorrow-night-eighties,line-numbers # UART Interface ```C typedef struct { ... configuration registers, etc. __IO uint32_t ISR; /* USART Interrupt and Status Register */ ... __IO uint16_t RDR; /* USART Receive Data Register */ ... __IO uint16_t TDR; /* USART Transmit Data Register */ ... } USART_TypeDef; ``` --- class: small-code,compact,hljs-tomorrow-night-eighties,line-numbers # UART Access Routines ```C void USART_SendData(USART_TypeDef* USARTx, uint16_t Data){ while (!(USARTx->ISR & USART_FLAG_TXE)); USARTx->TDR = (Data & (uint16_t)0x01FF); } ``` ```C uint16_t USART_ReceiveData(USART_TypeDef* USARTx){ while (!(USARTx->ISR & USART_FLAG_RXNE)); return (uint16_t)(USARTx->RDR & (uint16_t)0x01FF); } ``` --- class: compact # ARM Toolchain data:image/s3,"s3://crabby-images/3381c/3381c5d68d92935bc3eab5cd22f652c7d8b6d3b4" alt="") data:image/s3,"s3://crabby-images/cd2a2/cd2a26ac54ff6c323f75c7dfbb8abd7311c4d992" alt="" --- class: compact # ARM Binutils * Binutils are processor specific programs used to build and manipulate binary programs * Binary Program Creation * as : assembler * ld : linker * objcopy : Format change * Analysis/Debug * objdump : disassembler * nm : list symbols * gdb : debugger * Other * size : report section sizes * strings : report all strings in binary --- class: compact # Nucleo Development Boards data:image/s3,"s3://crabby-images/55f5d/55f5d197e25d7ee0cae475476729305bb9040bb3" alt="" data:image/s3,"s3://crabby-images/9dc11/9dc11e86a1f48ce8e65f57318f6355cc4b7c3a9e" alt="" data:image/s3,"s3://crabby-images/c561c/c561c2b926ea5e8c393e68c731f98ca70794e29f" alt="" --- class: compact # Summary * Microcontrollers * stm32l432 * cortex-m4 * programming model * memory-mapped I/O * serial port example * ARM toolchain * Nucleo board