

Embedded

FA2025 • 2025-09-15

## **Embedded 101: Fundamentals**

Adarsh and Minh

### **Adarsh Krishnan**

- SIGPwny Helper + Embedded Lead
- CS + Philosophy, Info/Math minors
- Involved with Embedded since eCTF 2024
- Fact: I help lead the Creative Writing Club at UIUC



## Minh Duong

- Previous SIGPwny President
- BS-MCS program (last semester)
- Involved in SIGPwny's eCTF team since 2023
- Fun fact: I just paid \$50 to cheese a CSAW challenge yesterday



## **Announcements**

- Fall CTF 2025 is in less than a week!
  - Register now to get a free electronic badge! <a href="https://sigpwny.com/fallctf">https://sigpwny.com/fallctf</a>
  - Sunday September 21st, 12pm
  - CIF 3039
- We are using an ESP32 chip, which has Wi-Fi capabilities built-in!
  - Full color 160x120 display!!
  - Piezo buzzer!!!
  - Joystick!!!!
  - Buttons!!!!!



## Microcontrollers



## Microcontrollers (MCU)

- MCUs glues everything together
  - Peripherals are useless without some control logic to transform inputs into outputs
- MCUs are fully packaged (System-on-a-Chip)
  - Includes CPU core(s), RAM (memory), flash storage
- Typically lightweight and power-efficient for most embedded systems
  - Megabytes of RAM as opposed to gigabytes on your laptop
  - MUCH slower than your laptop (instructions executed at a much slower rate)
- Specific-purpose instead of general purpose (it's cheaper!)



## Parts of a CPU (e.g. M1)



#### Unified memory architecture

High bandwidth, low latency Apple-designed package Accessible to entire SoC

### Parts of an MCU

- CPU cores
- RAM
- Peripherals
  - UART
  - Timers
  - TRNG
  - I<sup>2</sup>C
  - etc.



## **Pins**





## Memory (RAM vs Flash)

- Memory is represented as bytes each byte has a memory address!
- A memory address looks like 0xFFFFFFF
- Random Access Memory (RAM)
  - Volatile memory CPU has access to
- Flash Memory
  - Non-volatile memory that persists without power supply



## Peripherals



### **Sensors and Actuators**

- Sensor converts a physical phenomenon into an electrical signal
  - Thermometers
  - Cameras
  - Infrared Receiver
- Actuator converts an electrical signal into a physical phenomenon
  - Motors
  - Solenoids
  - Infrared Transmitters
- Transducers can be either a sensor and/or actuator
  - Infrared transceivers can both transmit and receive



## **Integrated Circuits (ICs)**

- Semiconductor that integrates collections of electronic circuits
  - Transistors, resistors, capacitors, diodes
- Control CPU functions of embedded systems
  - Retrieve and decode instructions from memory
  - Use instructions to perform computations for memory and I/O devices





## General Purpose Input/Output (GPIO)

- Most peripherals have reserved pins
- If you need to control pins directly, GPIO allows you to control the state of pins (e.g. on or off)
- Unused by default, purpose defined and implemented by developer





## **Embedded Communication**



## How do Peripherals Communicate?

- Each part of an embedded device needs to communicate with each other
  - MCU to peripherals
  - MCU to another MCU
  - MCU to the world

- We use wire **protocols** to standardize these communications



## **Communication with Protocols**

- There are many different protocols, each with their own advantages/disadvantages
  - I<sup>2</sup>C allows a host device to communicate to MANY guest devices using only two wires
  - UART allows one-to-one communication using two wires, but is much easier to implement
  - SPI uses four wires but offers much faster data rates, which is good for flash chips where streams of data needs to be read or written



## **UART Step-by-step**



**TX** - Transmitter

RX - Receiver

**GND** - Ground



## **UART Step-by-step**



Baud Rate - Number of bits per second that can be transmitted by channel





- 8 data bits
- No parity
- 1 stop bit
- Baud rate of 115200 or 9600



https://www.rohde-schwarz.com/us/products/test-and-measurement/essentials-test-equipment/digital-oscilloscopes/understanding-uart 254524.html

## **UART Demo**



## Software and Firmware



## Software vs Firmware

- Software programs run by computer
- Typically managed by operating systems
  - Lots of overhead
  - Provides system security

- Firmware = <u>soft</u>ware for <u>hard</u>ware
- Firmware can be run with full "bare-metal" access
  - No OS managing code
- More efficient for embedded but potentially less safe



## **How does Firmware Control Peripherals?**

- Microcontrollers usually come with built-in peripherals
  - UART peripheral
  - I<sup>2</sup>C peripheral
  - TRNG peripheral
- Peripherals are mapped to reserved memory addresses
- Software can control peripherals by reading/writing values to these memory addresses



## **Datasheets**



MSPM0L2228, MSPM0L2227 MSPM0L1228, MSPM0L1227 SLASF94A – MAY 2024 – REVISED OCTOBER 2024

#### **Table of Contents**

| 1 Features                           | 1  | 8.8 Events                                 | 72 |
|--------------------------------------|----|--------------------------------------------|----|
| 2 Applications                       | 2  | 8.9 Memory                                 | 73 |
| 3 Description                        | 2  | 8.10 Flash Memory                          | 76 |
| 4 Functional Block Diagram           | 4  | 8.11 SRAM                                  | 77 |
| 5 Device Comparison                  | 6  | 8.12 GPIO                                  | 77 |
| 5.1 Device Comparison Chart          | 6  | 8.13 IOMUX                                 | 77 |
| 6 Pin Configuration and Functions    | 7  | 8.14 ADC                                   | 77 |
| 6.1 Pin Diagrams                     | 7  | 8.15 Temperature Sensor                    | 78 |
| 6.2 Pin Attributes                   | 12 | 8.16 LFSS                                  | 78 |
| 6.3 Signal Descriptions              | 29 | 8.17 VREF                                  | 79 |
| 6.4 Connections for Unused Pins      | 41 | 8.18 COMP                                  | 79 |
| 7 Specifications                     | 42 | 8.19 TRNG                                  | 80 |
| 7.1 Absolute Maximum Ratings         | 42 | 8.20 AESADV                                | 80 |
| 7.2 ESD Ratings                      | 42 | 8.21 Keystore                              | 80 |
| 7.3 Recommended Operating Conditions | 42 | 8.22 CRC                                   | 81 |
| 7.4 Thermal Information              |    | 8.23 UART                                  | 81 |
| 7.5 Supply Current Characteristics   | 45 | 8.24 I2C                                   | 81 |
| 7.6 Power Supply Sequencing          | 46 | 8.25 SPI                                   | 82 |
| 7.7 VBat Characteristics             |    | 8.26 IWDT                                  | 82 |
| 7.8 Flash Memory Characteristics     | 48 | 8.27 WWDT                                  | 82 |
| 7.9 Timing Characteristics           | 49 | 8.28 RTC A                                 | 82 |
| 7.10 Clock Specifications            | 49 | 8.29 Timers (TIMx)                         | 83 |
| 7.11 Digital IO                      |    | 8.30 LCD                                   | 85 |
| 7.12 Analog Mux VBOOST               |    | 8.31 Device Analog Connections             | 86 |
| 7.13 ADC                             |    | 8.32 Input/Output Diagrams                 | 87 |
| 7.14 Temperature Sensor              | 55 | 8.33 Serial Wire Debug Interface           |    |
| 7.15 VREF                            | 57 | 8.34 Bootstrap Loader (BSL)                | 88 |
| 7.16 Comparator (COMP)               | 58 | 8.35 Device Factory Constants              |    |
| 7.17 LCD                             |    | 8.36 Identification.                       | 89 |
| 7.18 I2C                             | 61 | 9 Applications, Implementation, and Layout | 90 |
| 7.19 SPI                             | 62 | 9.1 Typical Application                    |    |
| 7.20 UART                            | 64 | 10 Device and Documentation Support        | 92 |
| 7.21 TIMx                            | 64 | 10.1 Getting Started and Next Steps        | 92 |
| 7.22 TRNG                            | 64 | 10.2 Device Nomenclature                   | 92 |
| 7.23 Emulation and Debug             | 65 | 10.3 Tools and Software                    | 93 |
| 8 Detailed Description               | 66 | 10.4 Documentation Support                 | 93 |
| 8.1 Functional Block Diagram         | 66 | 10.5 Support Resources                     | 94 |
| 8.2 CPU                              | 67 | 10.6 Trademarks                            | 94 |
| 8.3 Operating Modes                  | 68 | 10.7 Electrostatic Discharge Caution       | 94 |
| 8.4 Security                         | 70 | 10.8 Glossary                              | 94 |
| 8.5 Power Management Unit (PMU)      | 71 | 11 Revision History                        | 94 |
| 8.6 Clock Module (CKM)               | 71 | 12 Mechanical, Packaging, and Orderable    |    |
| 8.7 DMA                              |    | Information                                | 95 |



## **Datasheets**

| Table 8-4. Memory Organization | <b>Table</b> | 8-4. | Memory | Organ | ization |
|--------------------------------|--------------|------|--------|-------|---------|
|--------------------------------|--------------|------|--------|-------|---------|

| MEMORY REGION       | SUBREGION            | MSP0L1227, MSPM0L2227                             | MSPM0L1228, MSPM0L2228                             |
|---------------------|----------------------|---------------------------------------------------|----------------------------------------------------|
|                     | MAIN ECC Corrected   | 64KB <sup>(1)</sup><br>0x0000.0000 to 0x0000.FFFF | 128KB <sup>(1)</sup><br>0x0000.0000 to 0x0001.FFFF |
| Code (Flash Bank 0) | MAIN ECC Uncorrected | 0x0040.0000 to 0x0040.FFFF                        | 0x0040.0000 to 0x0041.FFFF                         |
|                     | Flash ECC code       | 0x0080.0000 to 0x0080.FFFF                        | 0x0080.0000 to 0x0081.FFFF                         |
| Code (Floob Bonk 1) | MAIN ECC Corrected   | 64KB <sup>(1)</sup><br>0x0001.0000 to 0x0001.FFFF | 128KB <sup>(1)</sup><br>0x0002.0000 to 0x0003.FFFF |
| Code (Flash Bank 1) | MAIN ECC Uncorrected | 0x0041.0000 to 0x0041.FFFF                        | 0x0042.0000 to 0x0043.FFFF                         |
|                     | Flash ECC code       | 0x0081.0000 to 0x0081.FFFF                        | 0x0082.0000 to 0x0083.FFFF                         |
|                     | SRAM "ECC Checked"   | 32KB<br>0x2000.0000 to 0x2000.7FFF                | 32KB<br>0x2000.0000 to 0x2000.7FFF                 |
| SDAM (SDAM)         | Parity checked       | 0x2010.0000 to 0x2010.7FFF                        | 0x2010.0000 to 0x2010.7FFF                         |
| SRAM (SRAM)         | Un-checked           | 0x2020.0000 to 0x2020.7FFF                        | 0x2020.0000 to 0x2020.7FFF                         |
|                     | ECC/parity code      | 0x2030.0000 to 0x2030.7FFF                        | 0x2030.0000 to 0x2030.7FFF                         |

## **Datasheets**

**Table 8-5. Peripherals Summary** 

| PERIPHERAL NAME  ADC0  COMP0  VREF  LCD  WWDT0  TIMG0  TIMG4  TIMG5  TIMG8  LFSS (SPM, TIO)  RTC_A  IWDT  GPIOA  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1 | BASE ADDRESS       0x40004000       0x40008000       0x40030000       0x40070000       0x40080000       0x40084000       0x4008C000 | Та |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|----|
| COMP0  VREF  LCD  WWDT0  TIMG0  TIMG4  TIMG5  TIMG8  LFSS (SPM, TIO)  RTC_A  IWDT  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1                               | 0x40008000<br>0x40030000<br>0x40070000<br>0x40080000<br>0x40084000                                                                  |    |
| VREF  LCD  WWDT0  TIMG0  TIMG4  TIMG5  TIMG8  LFSS (SPM, TIO)  RTC_A  IWDT  GPIOA  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1                               | 0x40030000<br>0x40070000<br>0x40080000<br>0x40084000                                                                                |    |
| LCD  WWDT0  TIMG0  TIMG4  TIMG5  TIMG8  LFSS (SPM, TIO)  RTC_A  IWDT  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1                                            | 0x40070000<br>0x40080000<br>0x40084000                                                                                              |    |
| WWDT0 TIMG0 TIMG4 TIMG5 TIMG8 LFSS (SPM, TIO) RTC_A IWDT GPIOA GPIOB GPIOC KEYSTORE SYSCTL DEBUGSS EVENT NVM I2C0 I2C1                                                                  | 0x40080000<br>0x40084000                                                                                                            |    |
| TIMG0 TIMG4 TIMG5 TIMG8 LFSS (SPM, TIO) RTC_A IWDT GPIOA GPIOA GPIOB GPIOC KEYSTORE SYSCTL DEBUGSS EVENT NVM I2C0 I2C1                                                                  | 0x40084000                                                                                                                          | -  |
| TIMG4 TIMG5 TIMG8 LFSS (SPM, TIO) RTC_A IWDT GPIOA GPIOB GPIOC KEYSTORE SYSCTL DEBUGSS EVENT NVM I2C0 I2C1                                                                              |                                                                                                                                     |    |
| TIMG5 TIMG8  LFSS (SPM, TIO)  RTC_A  IWDT  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1                                                                       | 0x4008C000                                                                                                                          | -  |
| TIMG8  LFSS (SPM, TIO)  RTC_A  IWDT  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1                                                                             |                                                                                                                                     |    |
| LFSS (SPM, TIO)  RTC_A  IWDT  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1                                                                                    | 0x4008E000                                                                                                                          |    |
| RTC_A  IWDT  GPIOA  GPIOB  GPIOC  KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  I2C0  I2C1                                                                                                     | 0x40090000                                                                                                                          |    |
| IWDT GPIOA GPIOB GPIOC KEYSTORE SYSCTL DEBUGSS EVENT NVM 12C0 12C1                                                                                                                      | 0x40094000                                                                                                                          |    |
| GPIOA GPIOB GPIOC KEYSTORE SYSCTL DEBUGSS EVENT NVM 12C0 12C1                                                                                                                           | 0x40095100                                                                                                                          |    |
| GPIOB GPIOC KEYSTORE SYSCTL DEBUGSS EVENT NVM 12C0 12C1                                                                                                                                 | 0x40095300                                                                                                                          | 8  |
| GPIOC KEYSTORE SYSCTL DEBUGSS EVENT NVM 12C0 12C1                                                                                                                                       | 0x400A0000                                                                                                                          | 8  |
| KEYSTORE  SYSCTL  DEBUGSS  EVENT  NVM  12C0  12C1                                                                                                                                       | 0x400A2000                                                                                                                          |    |
| SYSCTL DEBUGSS EVENT NVM 12C0 12C1                                                                                                                                                      | 0x400A4000                                                                                                                          |    |
| DEBUGSS  EVENT  NVM  I2C0  I2C1                                                                                                                                                         | 0x400AC000                                                                                                                          |    |
| EVENT  NVM  I2C0  I2C1                                                                                                                                                                  | 0x400AF000                                                                                                                          |    |
| NVM<br>I2C0<br>I2C1                                                                                                                                                                     | 0x400C7000                                                                                                                          |    |
| I2C0<br>I2C1                                                                                                                                                                            | 0x400C9000                                                                                                                          |    |
| I2C1                                                                                                                                                                                    | 0x400CD000                                                                                                                          |    |
| 1000-00                                                                                                                                                                                 | 0x400F0000                                                                                                                          |    |
|                                                                                                                                                                                         | 0x400F2000                                                                                                                          |    |
| I2C2                                                                                                                                                                                    | 0x400F4000                                                                                                                          |    |
| UART2                                                                                                                                                                                   | 0x40100000                                                                                                                          |    |
| UART3                                                                                                                                                                                   | 0x40102000                                                                                                                          |    |
| UART4                                                                                                                                                                                   | 0x40104000                                                                                                                          |    |
| UART0                                                                                                                                                                                   | 0x40108000                                                                                                                          |    |
| UARI1                                                                                                                                                                                   |                                                                                                                                     |    |



UART www.ti.com

#### 21.3 UART Registers

Table 21-12 lists the memory-mapped registers for the UART registers. All register offset addresses not listed in Table 21-12 should be considered as reserved locations and the register contents should not be modified.

Table 21-12. UART Registers

| Offset | Acronym | Register Name                     | Group   | Section |
|--------|---------|-----------------------------------|---------|---------|
| 800h   | PWREN   | Power enable                      |         | Go      |
| 804h   | RSTCTL  | Reset Control                     |         | Go      |
| 808h   | CLKCFG  | Peripheral Clock Configuration Re | egister | Go      |
| 814h   | STAT    | Status Register                   |         | Go      |
| 1000h  | CLKDIV  | Clock Divider                     |         | Go      |
| 1008h  | CLKSEL  | Clock Select for Ultra Low Power  |         | Go      |

#### 21.3.35 TXDATA (Offset = 1120h) [Reset = 00000000h]

TXDATA is shown in Figure 21-50 and described in Table 21-48.

Return to the Summary Table.

UART Transmit Data Register. This register is the transmit data register (the interface to the FIFOs). For transmitted data, if the FIFO is enabled, data written to this location is pushed onto the transmit FIFO. If the is disabled, data is stored in the transmitter holding register (the bottom word of the transmit FIFO). A write this register initiates a transmission from the UART.

#### Figure 21-50. TXDATA

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19   | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3    | 2 |
|----|----|----|----|----|----|----|----|----|----|----|-----|------|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|------|---|
|    |    |    |    |    |    |    |    |    |    | R  | ESE | RVE  | D  |    |    |    |    |    |    |    |    |   |   |   |   |   | DA  | ΛTΑ  |   |
|    |    |    |    |    |    |    |    |    |    |    | R/W | /-0h |    |    |    |    |    |    |    |    |    |   |   |   |   |   | R/V | √-0h |   |

#### Table 21-48. TXDATA Field Descriptions

| Bit  | Field    | Туре | Reset | Description                                                                                                                                                      |
|------|----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8 | RESERVED | R/W  | 0h    |                                                                                                                                                                  |
| 7-0  | DATA     | R/W  | 0h    | Data Transmitted or Received Data that is to be transmitted via UART is written to this field. When read, this field contains the that was received by the UART. |

### **Datasheets in Action!**

```
char my string[] = "Hello, world!";
for (unsigned int i = 0; i < 13; i++) {
    // checks if UART is ready to send
    if (*0x40001030 & (1 << 5)) {
        return E OVERFLOW;
    *0x40001034 = my_string[i];
```

Manipulating peripherals is just reading and writing fields/values to some defined memory addresses!



## **HALs and Embedded SDKs**

- "Hardware Abstraction Layers" (HALs) are libraries which make interfacing with the hardware easier
  - Abstracts technical details away to make software development better
- Manufacturers will create "Software Development Kits" (SDKs) to assist developers with writing firmware
  - SDKs are more to be used by software and application code
  - Will often include HALs for specific device and additional code, such as code to control external peripherals, such as displays or LEDs



### Would You Rather?

```
char my_string[] = "Hello, world!";
                                     char my_string[] = "Hello, world!";
for (unsigned int i = 0; i < 13;
                                     uart0_write(my_string);
i++) {
   if (*0x40001030 & (1 << 5)) {
       return E_OVERFLOW;
   *0x40001034 = my_string[i];
```



## **Next Meetings**

### **2025-09-22** • Next Monday

- Embedded 102: Microcontroller Programming
- Learn how to program a microcontroller!
- We will have microcontrollers available for you to program:
  - UART peripheral to print "Hello, world!" to a console
  - GPIO peripheral to trigger an LED



# Meeting content can be found at sigpwny.com/meetings.

