# STM32F407 구조 및 기능



한국산업기술대학교 메카트로닉스공학과 마이크로컴퓨터구조 담당교수: 남윤석

# STM32F407 외형

: 176pin (44\*4)



마이<u>크로컴퓨터 구조 STM32F407의 구조와 기능</u>

# ST사의 Cortex-M 기반 MCU

#### ●ST사의 Cortex-M 기반 MCU의 종류 1

- STM32F0 시리즈: Cortex-M0 기반, 저가/저성능
- STM32F1 시리즈: Cortex-M3 기반, 일반적인 용도, 많이 사용
- STM32F2 시리즈: Cortex-M3 기반, F1 시리즈보다 고속
- STM32F3 시리즈: Cortex-M4 기반
- STM32F4 시리즈: Cortex-M4 기반, F3 시리즈보다 고속, 많이 사용
- STM32F7 시리즈: Cortex-M7 기반, F4 시리즈보다 고속
- STM32H7 시리즈: Cortex-M7 기반, 가장 고속임
- STM32L0 시리즈: Cortex-M0+ 기반, 저전력(Low power)
- STM32L1 시리즈: Cortex-M3 기반, 저전력
- STM32L4 시리즈: Cortex-M4 기반, 저전력

# ST사의 Cortex-M 기반 MCU

#### ●ST사의 Cortex-M 기반 MCU의 종류 2



TFT LCD

controller

**BAM** (Batch

**Acquisition Mode)** 

MPI

DSI

| 마이크로컴퓨터 구조                                                   | 조        |               |                  |               |      |                              |        |                      |             | STM32F407             |
|--------------------------------------------------------------|----------|---------------|------------------|---------------|------|------------------------------|--------|----------------------|-------------|-----------------------|
| STM32F4                                                      | 시리크      | 4: Cort       | ex-l             | M4 >          | 기빈   | 의고                           | 성능     | MC                   | U 종         | 류                     |
|                                                              |          |               |                  |               |      |                              |        |                      |             |                       |
| Cortex-M4<br>(DSP + FPU)<br>Up to 180MHz                     | Lines    | STM32F4       | F <sub>CPU</sub> | Flash         | RAM  | Ethernet<br>I/F<br>IEEE 1588 | Camera | SDRAM<br>I/F         | SAI<br>I/F  | Chrom-ART             |
| • ART                                                        | Lines    | Product       | (MHz)            | (bytes)       | (KB) | 2x CAN                       | I/F    | Dual<br>Quad-<br>SPI | SPDIF<br>RX | Grphic<br>Accelerator |
|                                                              |          | STM32F469 180 | 180              | 512K<br>to 2M | 384  | •                            |        | •                    | •           |                       |
| Accelerator™                                                 |          |               | 100              |               | 304  | •                            |        | •                    |             | •                     |
| enabling 0 wait<br>state executing<br>from internal<br>Flash | Advanced | STM32F429     | 180              | 512K<br>to 2M | 256  | •                            | •      | •                    | •           | •                     |
|                                                              |          | STM32F427     | 180              | 1 to          | 256  | •                            |        | •                    | •           |                       |

2M

256K

to

512K

512K

to 1M

512K

to 1M

Flash

(KB)

256 to

512

64 to

128

128 to

512

256

128

192

192

**RAM** 

(KB)

128

32

96

**STOP** 

current

(μA)

Down

to 12

Down

to 6

Down

to 10

**RUN** 

current

(µA/MHz)

Down to

100

Down to

89

Down to

128

Small package

(mm)

Down to

3.034x3.22

Down to

2.553x2.579

Down to 3x3

STM32F427

STM32F446

STM32F407

STM32F405

STM32F4

**Access line** 

STM32F411

STM32F410

STM32F401

Foundation

Line

Access

180

180

168

168

**F**CPU

(MHz)

100

100

84

Up to 2x USB2.0 OTG FS/HS

USART, SPI, PC

PS + audio PLL

16- and 32-biy

• Up to 3x 12-bit

ADC (0.41 μs) Up to 2x 12-bit

controller (except

Low voltage 1.7

to 3.6V

SDIO

DAC

generator

# STM32F40xxx 제품 구성

|                                              |                      | Tab                        | le 2. STM32F40                                                    | 5xx and STM3 | 2F407xx: featu | res and periph | eral co | ınts |       |        |             |      |
|----------------------------------------------|----------------------|----------------------------|-------------------------------------------------------------------|--------------|----------------|----------------|---------|------|-------|--------|-------------|------|
| Perip                                        | herals               | STM32F405RG                | F405RG STM32F405OG STM32F405VG STM32F405ZG STM32F405OE STM32F407V |              |                |                |         |      | STM32 | F407Zx | STM32F407lx |      |
| Flash mer<br>Kbytes                          | mory in              | 1024 512 512 1024 512 1024 |                                                                   |              |                |                |         |      |       |        | 512         | 1024 |
| SRAM in                                      | System               |                            |                                                                   |              | 192(112+       | 16+64)         |         |      |       |        |             |      |
| Kbytes                                       | Backup               |                            |                                                                   |              | 4              |                |         |      |       |        |             |      |
| FSMC memory controller No Yes <sup>(1)</sup> |                      |                            |                                                                   |              |                |                |         |      |       |        |             |      |
| Ethernet                                     |                      |                            |                                                                   | No           |                |                | Yes     |      |       |        |             |      |
|                                              | General-<br>purpose  |                            |                                                                   |              | 10             |                |         |      |       |        |             |      |
|                                              | Advanced<br>-control |                            |                                                                   |              | 2              |                |         |      |       |        |             |      |
| Timers                                       | Basic                | 2                          |                                                                   |              |                |                |         |      |       |        |             |      |
|                                              | IWDG                 | Yes                        |                                                                   |              |                |                |         |      |       |        |             |      |
|                                              | WWDG                 | Yes                        |                                                                   |              |                |                |         |      |       |        |             |      |
|                                              | RTC                  |                            |                                                                   |              | Yes            | 5              |         |      |       |        |             |      |
| Random n                                     |                      |                            | Yes                                                               |              |                |                |         |      |       |        |             |      |

STM32F407의 구조와 기능

Yes

114

24

LQFP144

3/2 (full duplex)(2)

3

4/2

Yes

Yes

2

Yes

3

Yes

168 MHz

1.8 to 3.6 V(3)

Ambient temperatures: -40 to +85 °C /-40 to +105 °C

Junction temperature: -40 to + 125 °C

72

13

WLCSP90

82

16

LQFP100

114

24

LQFP144

No

82

16

LQFP100

72

13

WLCSP90

STM32F407lx

140

24

UFBGA176

LQFP176

| STM32F40xxx | 제품 | 구성 |
|-------------|----|----|

| STM32F40xxx | 제 | 품 | 구성 |  |
|-------------|---|---|----|--|
|             |   |   |    |  |

| STM32F40xxx | 제 | 품 | 구 | 성 |
|-------------|---|---|---|---|
|-------------|---|---|---|---|

| STM32F40xxx | 제품 | 구성 |
|-------------|----|----|
|             |    |    |

| STM32F40xxx | 제품 | イな |
|-------------|----|----|
|             |    |    |

| STM32F40xxx | 제품 | 十分 |
|-------------|----|----|
|             |    | -  |

Communi

interfaces

cation

**GPIOs** 

12-bit ADC

12-bit DAC

frequency

Operating temperatures

Package

SPI / I2S

USART/

OTG FS

OTG HS

UART

USB

USB

CAN

SDIO

Camera interface

Number of channels

Number of channels

Maximum CPU

Operating voltage

 $I^2C$ 

| STM32F40xxx | 제품 | イな |
|-------------|----|----|
|             |    |    |

| 1           | <del> </del> | †           |             | †           |             | t           | · ·         | T |
|-------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|---|
| Peripherals | STM32F405RG  | STM32F405OG | STM32F405VG | STM32F405ZG | STM32F4050E | STM32F407Vx | STM32F407Zk | d |

51

16

LQFP64

마이크로컴퓨터 구조

#### STM32F407IG Features

- > Frequency up to 168MHz
- > 210 **DMIPS**
- **▶ 1 Mbyte of Flash memory**
- ➤ 128 Kbyte SRAM
- > SRAM, NOR, NAND Memory Controller(FSMC)
- ➤ Operating voltage: 1.8~3.6V
- > 140 GPIOs (PortA/B/C/D/E/F/G/H \*16pin, PortI \* 12pins)
- > 3 x 12-bit A/D 24channels
- > 2 x 12-bit D/A Converters
- **➤** General-purpose DMA
- **>** Up to 17 timers (IC/OC/PWM)
- ≥ 3 x I<sub>2</sub>C interface
- > 4 x USART / 2 x UART
- > Up to 3 x SPIs
- $\geq$  2 x CAN Interface
- > SDIO
- **> USB 2.0**
- > Ethernet MAC

- \* STM32F407IG모델명의 의미
- STM32 : ARM based 32bit MCU
- F : General-purpose
- 4: Cortex-M4 기반
- 407: 168 MHz CPU, 210 DMIPS,
- Up to 1 Mbyte Flash, Ethernet
- MAC, Camera interface
- I : 176pins
- G: 1Mbyte of Flash memory

#### STM32F407IG Block Diagram



마이크로컴퓨터 구조

#### STM32F407IG 구성요소 소개

#### (1)Cortex-M4 프로세서

- (1) Cortex-M4 168MHz with FPU
- ② 디버깅 구성 요소(JTAG & SW, ETM)
- ③ NVIC(Nested Vector Interrupt Controller: 중첩 벡터 인터럽트 컨트롤러)
- **4 MPU (Memory Protection Unit)**

#### (2) 버스(Bus) 인터페이스 및 버스 매트릭스

: MCU 내의 각종 데이터 전달을 위한 부분으로 I(Instruction)-Bus,

D(Data)-Bus, S(System)-Bus, Bus matrix, AHB-bus, APB-bus

#### (3) FMC, 내장 플래시 메모리 및 SRAM

- Flexible Static Memory Controller (FSMC)
- -지원 모드: PC Card, SRAM, PSRAM, NOR Flash, NAND Flash
- Flash memory: 프로그램과 데이터의 저장(최대 1MB)
- SRAM : 데이터 저장(128KB (112 + 16 KB))

#### STM32F407IG 구성요소 소개

#### (4) 카메라 인터페이스, USB OTG FS

- 카메라 인터페이스 (x 1)
- USB OTG (on-the-go) FS (x 1)
- (5) Ethernet MAC, USB OTG HS, DMA, LCD-TFT, Chrom-ART DMA2D
- Ethernet MAC : IEEE-802.3-2002 규격
- USB OTG HS: USB OTG high-speed device/host/OTG 1개
- DMA (Direct memory Access Controller): 주변장치와 메모리간, 또는 메모리와 메모리간의 고속 데이터 전송
- Chrom-ART DMA2D :그래픽 가속기
- (6) 전원(Power), 전원공급 감시부 (Power Supply Supervision)
- 전원 :  $2V\sim3.6V$  범위의 외부전원 VDD를 입력 받아 내장된 전압 레귤레이터를 통해 1.2V의 전원을 MCU의 내부에 공급
- 전원공급 감시부 : 외부 전원이 정해진 전압 범위 내에서 제대로 공급되는지의 여부를 감시, POR(Power on reset)과 PDR(Power down reset), PVD(Programmable voltage detector)로 구성

마이<u>크로컴퓨터 구조 STM32F407</u>의 구조와 기능

#### STM32F407IG 구성요소소개

#### (7) 클럭 발생부

시스템 클럭은 외부의 오실레이터의 입력 신호또는 내부의 RC 오실레이터 신호를 이용하여 생성

#### (8), (9) 주변장치

- GPIO(범용 입출력): GPIOA ~GPIOI
- EXTI (External interrupt/event controller)
- 타이머 : TIM1 ~ TIM14
- AD 변환기 : ADC1 ~ ADC3
- DA 변환기 : DAC1 ~ DAC2
- USART: USART1 ~ USART3, USART6
- UART : UART4, UART5
- · SPI, I℃ 등
- CAN: CAN1, CAN2
- USB: USB 2.0 FS, USB 2.0 HS
- Ethernet MAC 10/100

#### STM32F407IG 구성요소소개

- ●주변장치의 동작속도
- GPIO: 최대 180MHz, AHB1 버스 사용
- •그 외의 주변장치: APB2, APB1 버스에 연결
  - -APB2 버스 및 버스에 연결된 주변장치: 90MHz
  - -APB1 버스 및 버스에 연결된 주변장치: 45MHz
- 핀 구성
- LQFP형: 64(16\*4), 100(25\*4), 144(36\*4), <u>176민(44\*4)</u> 패키지

# STM32F407IG Pin Description

|        | F          | Pin r   | numb    | er         |         |                                                      |          |              |            |                                                          |                                    |
|--------|------------|---------|---------|------------|---------|------------------------------------------------------|----------|--------------|------------|----------------------------------------------------------|------------------------------------|
| LQFP64 | WLCSP90    | LQFP100 | LQFP144 | UFBGA176   | LQFP176 | Pin name<br>(function after<br>reset) <sup>(1)</sup> | Pin type | I/Ostructure | Notes      | Alternate functions                                      | Additional functions               |
| -      | -          | 1       | 1       | A2         | 1       | PE2                                                  | I/O      | FT           |            | TRACECLK/ FSMC_A23 /<br>ETH_MII_TXD3 /<br>EVENTOUT       |                                    |
| -      | -          | 2       | 2       | <b>A</b> 1 | 2       | PE3                                                  | I/O      | FT           |            | TRACED0/FSMC_A19 /<br>EVENTOUT                           |                                    |
| -      | -          | 3       | 3       | B1         | 3       | PE4                                                  | I/O      | FT           |            | TRACED1/FSMC_A20 /<br>DCMI_D4/ EVENTOUT                  |                                    |
| -      | -          | 4       | 4       | B2         | 4       | PE5                                                  | I/O      | FT           |            | TRACED2 / FSMC_A21 /<br>TIM9_CH1 / DCMI_D6 /<br>EVENTOUT |                                    |
| -      | -          | 5       | 5       | вз         | 5       | PE6                                                  | I/O      | FT           |            | TRACED3 / FSMC_A22 /<br>TIM9_CH2 / DCMI_D7 /<br>EVENTOUT |                                    |
| 1      | A10        | 6       | 6       | C1         | 6       | V <sub>BAT</sub>                                     | s        |              |            |                                                          |                                    |
| -      | -          | -       | ,       | D2         | 7       | PI8                                                  | I/O      | FT           | (2)(<br>3) | EVENTOUT                                                 | RTC_TAMP1,<br>RTC_TAMP2,<br>RTC_TS |
| 2      | <b>A</b> 9 | 7       | 7       | D1         | 8       | PC13                                                 | I/O      | FT           | (2)<br>(3) | EVENTOUT                                                 | RTC_OUT,<br>RTC_TAMP1,<br>RTC_TS   |
| 3      | B10        | 8       | 8       | E1         | 9       | PC14/OSC32_IN<br>(PC14)                              | I/O      | FT           | (2)(<br>3) | EVENTOUT                                                 | OSC32_IN <sup>(4)</sup>            |
| 4      | B9         | 9       | 9       | F1         | 10      | PC15/<br>OSC32_OUT<br>(PC15)                         | I/O      | FT           | (2)(<br>3) | EVENTOUT                                                 | OSC32_OUT <sup>(4)</sup>           |
| -      | -          | -       | _       | D3         | 11      | PI9                                                  | I/O      | FT           |            | CAN1_RX / EVENTOUT                                       |                                    |
| -      | -          | _       | -       | E3         | 12      | PI10                                                 | I/O      | FT           |            | ETH_MII_RX_ER /<br>EVENTOUT                              |                                    |
| -      | -          | -       | -       | E4         | 13      | PI11                                                 | I/O      | FT           |            | OTG_HS_ULPI_DIR /<br>EVENTOUT                            |                                    |
|        | _          | -       | _       | F2         | 14      | V <sub>SS</sub>                                      | S        |              |            |                                                          |                                    |
| _      | _          | -       | -       | F3         | 15      | $V_{DD}$                                             | S        |              |            |                                                          |                                    |
| -      | -          | -       | 10      | E2         | 16      | PF0                                                  | I/O      | FT           |            | FSMC_A0 / I2C2_SDA /<br>EVENTOUT                         |                                    |

| -  | -   | -  | 11 | НЗ         | 17 | PF1                  | I/O | FT      |     | FSMC_A1 / I2C2_SCL /<br>EVENTOUT                                          |                        |
|----|-----|----|----|------------|----|----------------------|-----|---------|-----|---------------------------------------------------------------------------|------------------------|
| -  | -   | -  | 12 | H2         | 18 | PF2                  | I/O | FT      |     | FSMC_A2 / I2C2_SMBA /<br>EVENTOUT                                         |                        |
| -  | -   | -  | 13 | J2         | 19 | PF3                  | I/O | FT      | (4) | FSMC_A3/EVENTOUT                                                          | ADC3_IN9               |
| -  | -   | -  | 14 | J3         | 20 | PF4                  | I/O | FT      | (4) | FSMC_A4/EVENTOUT                                                          | ADC3_IN14              |
| -  | -   | -  | 15 | <b>K</b> 3 | 21 | PF5                  | I/O | FT      | (4) | FSMC_A5/EVENTOUT                                                          | ADC3_IN15              |
| -  | C9  | 10 | 16 | G2         | 22 | V <sub>SS</sub>      | s   |         |     |                                                                           |                        |
| -  | B8  | 11 | 17 | G3         | 23 | $V_{DD}$             | S   |         |     |                                                                           |                        |
| -  | -   | -  | 18 | K2         | 24 | PF6                  | I/O | FT      | (4) | TIM10_CH1 /<br>FSMC_NIORD/<br>EVENTOUT                                    | ADC3_IN4               |
| -  | -   | -  | 19 | K1         | 25 | PF7                  | I/O | FT      | (4) | TIM11_CH1/FSMC_NREG<br>/ EVENTOUT                                         | ADC3_IN5               |
| -  | -   | -  | 20 | L3         | 26 | PF8                  | I/O | FT      | (4) | TIM13_CH1 /<br>FSMC_NIOWR/<br>EVENTOUT                                    | ADC3_IN6               |
| -  | -   | -  | 21 | L2         | 27 | PF9                  | I/O | FT      | (4) | TIM14_CH1 / FSMC_CD/<br>EVENTOUT                                          | ADC3_IN7               |
| -  | -   | -  | 22 | L1         | 28 | PF10                 | I/O | FT      | (4) | FSMC_INTR/ EVENTOUT                                                       | ADC3_IN8               |
| 5  | F10 | 12 | 23 | G1         | 29 | PH0/OSC_IN<br>(PH0)  | I/O | FT      |     | EVENTOUT                                                                  | OSC_IN <sup>(4)</sup>  |
| 6  | F9  | 13 | 24 | Н1         | 30 | PH1/OSC_OUT<br>(PH1) | I/O | FT      |     | EVENTOUT                                                                  | OSC_OUT <sup>(4)</sup> |
| 7  | G10 | 14 | 25 | J1         | 31 | NRST                 | I/O | RS<br>T |     |                                                                           |                        |
| 8  | E10 | 15 | 26 | M2         | 32 | PC0                  | I/O | FT      | (4) | OTG_HS_ULPI_STP/<br>EVENTOUT                                              | ADC123_IN10            |
| 9  | -   | 16 | 27 | МЗ         | 33 | PC1                  | I/O | FT      | (4) | ETH_MDC/ EVENTOUT                                                         | ADC123_IN11            |
| 10 | D10 | 17 | 28 | M4         | 34 | PC2                  | I/O | FT      | (4) | SPI2_MISO /<br>OTG_HS_ULPI_DIR /<br>ETH_MII_TXD2<br>/I2S2ext_SD/ EVENTOUT | ADC123_IN12            |

|    |     |    |    |    |    |                   |     |    |     |                                                                                          | 51N1321 407 =   T I I I       |
|----|-----|----|----|----|----|-------------------|-----|----|-----|------------------------------------------------------------------------------------------|-------------------------------|
| 11 | E9  | 18 | 29 | M5 | 35 | PC3               | I/O | FT | (4) | SPI2_MOSI / I2S2_SD /<br>OTG_HS_ULPI_NXT /<br>ETH_MII_TX_CLK/<br>EVENTOUT                | ADC123_IN13                   |
| -  | -   | 19 | 30 | G3 | 36 | $V_{DD}$          | s   |    |     |                                                                                          |                               |
| 12 | H10 | 20 | 31 | M1 | 37 | V <sub>SSA</sub>  | s   |    |     |                                                                                          |                               |
| -  | -   | -  | -  | N1 | -  | $V_{REF-}$        | s   |    |     |                                                                                          |                               |
| -  | -   | 21 | 32 | P1 | 38 | V <sub>REF+</sub> | s   |    |     |                                                                                          |                               |
| 13 | G9  | 22 | 33 | R1 | 39 | $V_{DDA}$         | s   |    |     |                                                                                          |                               |
| 14 | C10 | 23 | 34 | N3 | 40 | PA0/WKUP<br>(PA0) | I/O | FT | (5) | USART2_CTS/ UART4_TX/ ETH_MII_CRS / TIM2_CH1_ETR/ TIM5_CH1 / TIM8_ETR/ EVENTOUT          | ADC123_IN0/WKUP <sup>(4</sup> |
| 15 | F8  | 24 | 35 | N2 | 41 | PA1               | I/O | FT | (4) | USART2_RTS / UART4_RX/ ETH_RMII_REF_CLK / ETH_MII_RX_CLK / TIM5_CH2 / TIM2_CH2/ EVENTOUT | ADC123_IN1                    |
| 16 | J10 | 25 | 36 | P2 | 42 | PA2               | I/O | FT | (4) | USART2_TX/TIM5_CH3 /<br>TIM9_CH1 / TIM2_CH3 /<br>ETH_MDIO/ EVENTOUT                      | ADC123_IN2                    |
| -  | -   | -  | -  | F4 | 43 | PH2               | I/O | FT |     | ETH_MII_CRS/EVENTOU<br>T                                                                 |                               |
| -  | -   | -  | -  | G4 | 44 | PH3               | I/O | FT |     | ETH_MII_COL/EVENTOU<br>T                                                                 |                               |
| -  | -   | -  | -  | H4 | 45 | PH4               | I/O | FT |     | I2C2_SCL /<br>OTG_HS_ULPI_NXT/<br>EVENTOUT                                               |                               |
| -  | -   | -  | -  | J4 | 46 | PH5               | I/O | FT |     | I2C2_SDA/ EVENTOUT                                                                       |                               |

| 17 | Н9 | 26 | 37 | R2 | 47 | PA3             | I/O | FT  | (4) | USART2_RX/TIM5_CH4 /<br>TIM9_CH2 / TIM2_CH4 /<br>OTG_HS_ULPI_D0 /<br>ETH_MII_COL/<br>EVENTOUT                   | ADC123_IN3             |
|----|----|----|----|----|----|-----------------|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------|------------------------|
| 18 | E5 | 27 | 38 | -  | -  | V <sub>SS</sub> | S   |     |     |                                                                                                                 |                        |
|    | D9 |    |    | L4 | 48 | BYPASS_REG      | 1   | FT  |     |                                                                                                                 |                        |
| 19 | E4 | 28 | 39 | K4 | 49 | $V_{DD}$        | S   |     |     |                                                                                                                 |                        |
| 20 | J9 | 29 | 40 | N4 | 50 | PA4             | I/O | тта | (4) | SPI1_NSS / SPI3_NSS /<br>USART2_CK /<br>DCMI_HSYNC /<br>OTG_HS_SOF/I2S3_WS/<br>EVENTOUT                         | ADC12_IN4<br>/DAC_OUT1 |
| 21 | G8 | 30 | 41 | P4 | 51 | PA5             | I/O | тта | (4) | SPI1_SCK/ OTG_HS_ULPI_CK / TIM2_CH1_ETR/ TIM8_CH1N/ EVENTOUT                                                    | ADC12_IN5/DAC_OU<br>T2 |
| 22 | Н8 | 31 | 42 | Р3 | 52 | PA6             | I/O | FT  | (4) | SPI1_MISO /<br>TIM8_BKIN/TIM13_CH1 /<br>DCMI_PIXCLK /<br>TIM3_CH1 / TIM1_BKIN/<br>EVENTOUT                      | ADC12_IN6              |
| 23 | J8 | 32 | 43 | R3 | 53 | PA7             | I/O | FT  | (4) | SPI1_MOSI/ TIM8_CH1N<br>/ TIM14_CH1/TIM3_CH2/<br>ETH_MII_RX_DV /<br>TIM1_CH1N /<br>ETH_RMII_CRS_DV/<br>EVENTOUT | ADC12_IN7              |
| 24 | -  | 33 | 44 | N5 | 54 | PC4             | I/O | FT  | (4) | ETH_RMII_RX_D0 /<br>ETH_MII_RX_D0/<br>EVENTOUT                                                                  | ADC12_IN14             |
| 25 | -  | 34 | 45 | P5 | 55 | PC5             | I/O | FT  | (4) | ETH_RMII_RX_D1 /<br>ETH_MII_RX_D1/<br>EVENTOUT                                                                  | ADC12_IN15             |
| 26 | G7 | 35 | 46 | R5 | 56 | PB0             | I/O | FT  | (4) | TIM3_CH3 / TIM8_CH2N/<br>OTG_HS_ULPI_D1/<br>ETH_MII_RXD2 /<br>TIM1_CH2N/ EVENTOUT                               | ADC12_IN8              |

| 27 | Н7 | 36 | 47 | R4  | 57 | PB1                | I/O | FT | (4) | TIM3_CH4 / TIM8_CH3N/<br>OTG_HS_ULPI_D2/<br>ETH_MII_RXD3 /<br>TIM1_CH3N/ EVENTOUT | ADC12_IN9 |
|----|----|----|----|-----|----|--------------------|-----|----|-----|-----------------------------------------------------------------------------------|-----------|
| 28 | J7 | 37 | 48 | M6  | 58 | PB2/BOOT1<br>(PB2) | I/O | FT |     | EVENTOUT                                                                          |           |
| -  | -  | -  | 49 | R6  | 59 | PF11               | I/O | FT |     | DCMI_D12/ EVENTOUT                                                                |           |
| -  | -  | -  | 50 | P6  | 60 | PF12               | I/O | FT |     | FSMC_A6/ EVENTOUT                                                                 |           |
| -  | -  | -  | 51 | M8  | 61 | V <sub>SS</sub>    | s   |    |     |                                                                                   |           |
| -  | -  | -  | 52 | N8  | 62 | V <sub>DD</sub>    | s   |    |     |                                                                                   |           |
| -  | -  | -  | 53 | N6  | 63 | PF13               | I/O | FT |     | FSMC_A7/ EVENTOUT                                                                 |           |
| -  | -  | -  | 54 | R7  | 64 | PF14               | I/O | FT |     | FSMC_A8/ EVENTOUT                                                                 |           |
| -  | -  | -  | 55 | P7  | 65 | PF15               | I/O | FT |     | FSMC_A9/ EVENTOUT                                                                 |           |
| -  | -  | -  | 56 | N7  | 66 | PG0                | I/O | FT |     | FSMC_A10/ EVENTOUT                                                                |           |
| -  | -  | -  | 57 | M7  | 67 | PG1                | I/O | FT |     | FSMC_A11/ EVENTOUT                                                                |           |
| -  | G6 | 38 | 58 | R8  | 68 | PE7                | I/O | FT |     | FSMC_D4/TIM1_ETR/<br>EVENTOUT                                                     |           |
| -  | Н6 | 39 | 59 | P8  | 69 | PE8                | I/O | FT |     | FSMC_D5/ TIM1_CH1N/<br>EVENTOUT                                                   |           |
| -  | J6 | 40 | 60 | P9  | 70 | PE9                | I/O | FT |     | FSMC_D6/TIM1_CH1/<br>EVENTOUT                                                     |           |
| -  | -  | -  | 61 | М9  | 71 | V <sub>SS</sub>    | s   |    |     |                                                                                   |           |
| -  | -  | -  | 62 | N9  | 72 | V <sub>DD</sub>    | s   |    |     |                                                                                   |           |
| -  | F6 | 41 | 63 | R9  | 73 | PE10               | I/O | FT |     | FSMC_D7/TIM1_CH2N/<br>EVENTOUT                                                    |           |
| -  | J5 | 42 | 64 | P10 | 74 | PE11               | I/O | FT |     | FSMC_D8/TIM1_CH2/<br>EVENTOUT                                                     |           |
| -  | H5 | 43 | 65 | R10 | 75 | PE12               | I/O | FT |     | FSMC_D9/TIM1_CH3N/<br>EVENTOUT                                                    |           |
| -  | G5 | 44 | 66 | N11 | 76 | PE13               | I/O | FT |     | FSMC_D10/TIM1_CH3/<br>EVENTOUT                                                    |           |

| -  | F5 | 45 | 67 | P11 | 77 | PE14               | I/O | FT |    | FSMC_D11/TIM1_CH4/<br>EVENTOUT                                                                              |  |
|----|----|----|----|-----|----|--------------------|-----|----|----|-------------------------------------------------------------------------------------------------------------|--|
| -  | G4 | 46 | 68 | R11 | 78 | PE15               | I/O | FT |    | FSMC_D12/TIM1_BKIN/<br>EVENTOUT                                                                             |  |
| 29 | H4 | 47 | 69 | R12 | 79 | PB10               | I/O | FT |    | SPI2_SCK / I2S2_CK /<br>I2C2_SCL / USART3_TX /<br>OTG_HS_ULPI_D3 /<br>ETH_MII_RX_ER /<br>TIM2_CH3/ EVENTOUT |  |
| 30 | J4 | 48 | 70 | R13 | 80 | PB11               | I/O | FT |    | I2C2_SDA/USART3_RX/ OTG_HS_ULPI_D4 / ETH_RMII_TX_EN/ ETH_MII_TX_EN / TIM2_CH4/ EVENTOUT                     |  |
| 31 | F4 | 49 | 71 | M10 | 81 | V <sub>CAP_1</sub> | s   |    |    |                                                                                                             |  |
| 32 | -  | 50 | 72 | N10 | 82 | V <sub>DD</sub>    | S   |    |    |                                                                                                             |  |
| -  | -  | -  | -  | M11 | 83 | PH6                | I/O | FT | 12 | 2C2_SMBA / TIM12_CH1<br>/ ETH_MII_RXD2/<br>EVENTOUT                                                         |  |
| -  | -  | -  | -  | N12 | 84 | PH7                | I/O | FT |    | I2C3_SCL /<br>ETH_MII_RXD3/<br>EVENTOUT                                                                     |  |
| -  | -  | -  | -  | M12 | 85 | PH8                | I/O | FT |    | I2C3_SDA /<br>DCMI_HSYNC/<br>EVENTOUT                                                                       |  |
| -  | -  | -  | -  | M13 | 86 | PH9                | I/O | FT |    | I2C3_SMBA /<br>TIM12_CH2/ DCMI_D0/<br>EVENTOUT                                                              |  |
| -  | -  | -  | -  | L13 | 87 | PH10               | I/O | FT |    | TIM5_CH1 / DCMI_D1/<br>EVENTOUT                                                                             |  |
| -  | -  | -  | -  | L12 | 88 | PH11               | I/O | FT |    | TIM5_CH2 / DCMI_D2/<br>EVENTOUT                                                                             |  |
| -  | -  | _  | _  | K12 | 89 | PH12               | I/O | FT |    | TIM5_CH3 / DCMI_D3/<br>EVENTOUT                                                                             |  |
| -  | -  | -  | -  | H12 | 90 | V <sub>SS</sub>    | s   |    |    |                                                                                                             |  |
| -  | -  | -  | -  | J12 | 91 | V <sub>DD</sub>    | s   |    |    |                                                                                                             |  |

| 33 | J3 | 51 | 73 | P12 | 92  | PB12 | I/O | FT | SPI2_NSS / I2S2_WS / I2C2_SMBA/ USART3_CK/ TIM1_BKIN / CAN2_RX / OTG_HS_ULPI_D5/ ETH_RMII_TXD0 / ETH_MII_TXD0/ OTG_HS_ID/ EVENTOUT |             |
|----|----|----|----|-----|-----|------|-----|----|------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 34 | J1 | 52 | 74 | P13 | 93  | PB13 | I/O | FT | SPI2_SCK / I2S2_CK / USART3_CTS/ TIM1_CH1N /CAN2_TX / OTG_HS_ULPI_D6 / ETH_RMII_TXD1 / ETH_MII_TXD1/ EVENTOUT                      | OTG_HS_VBUS |
| 35 | J2 | 53 | 75 | R14 | 94  | PB14 | I/O | FT | SPI2_MISO/ TIM1_CH2N / TIM12_CH1 / OTG_HS_DM/ USART3_RTS / TIM8_CH2N/I2S2ext_SD/ EVENTOUT                                          |             |
| 36 | H1 | 54 | 76 | R15 | 95  | PB15 | I/O | FT | SPI2_MOSI / I2S2_SD/<br>TIM1_CH3N / TIM8_CH3N                                                                                      | RTC_REFIN   |
| -  | H2 | 55 | 77 | P15 | 96  | PD8  | I/O | FT | FSMC_D13 /<br>USART3_TX/ EVENTOUT                                                                                                  |             |
| -  | НЗ | 56 | 78 | P14 | 97  | PD9  | I/O | FT | FSMC_D14 /<br>USART3_RX/ EVENTOUT                                                                                                  |             |
| -  | G3 | 57 | 79 | N15 | 98  | PD10 | I/O | FT | FSMC_D15 /<br>USART3_CK/ EVENTOUT                                                                                                  |             |
| -  | G1 | 58 | 80 | N14 | 99  | PD11 | I/O | FT | FSMC_CLE /<br>FSMC_A16/USART3_CT<br>S/ EVENTOUT                                                                                    |             |
| -  | G2 | 59 | 81 | N13 | 100 | PD12 | I/O | FT | FSMC_ALE/<br>FSMC_A17/TIM4_CH1 /<br>USART3_RTS/<br>EVENTOUT                                                                        |             |

| -  | -  | 60 | 82 | M15 | 101 | PD13            | I/O | FT | FSMC_A18/TIM4_CH2/<br>EVENTOUT                                       |
|----|----|----|----|-----|-----|-----------------|-----|----|----------------------------------------------------------------------|
| -  | -  | -  | 83 | -   | 102 | V <sub>SS</sub> | s   |    |                                                                      |
| -  | -  | -  | 84 | J13 | 103 | $V_{DD}$        | s   |    |                                                                      |
| -  | F2 | 61 | 85 | M14 | 104 | PD14            | I/O | FT | FSMC_D0/TIM4_CH3/<br>EVENTOUT/ EVENTOUT                              |
| -  | F1 | 62 | 86 | L14 | 105 | PD15            | I/O | FT | FSMC_D1/TIM4_CH4/<br>EVENTOUT                                        |
| -  | -  | -  | 87 | L15 | 106 | PG2             | I/O | FT | FSMC_A12/ EVENTOUT                                                   |
| -  | -  | -  | 88 | K15 | 107 | PG3             | I/O | FT | FSMC_A13/ EVENTOUT                                                   |
| -  | -  | -  | 89 | K14 | 108 | PG4             | I/O | FT | FSMC_A14/ EVENTOUT                                                   |
| -  | -  | -  | 90 | K13 | 109 | PG5             | I/O | FT | FSMC_A15/ EVENTOUT                                                   |
| -  | -  | -  | 91 | J15 | 110 | PG6             | I/O | FT | FSMC_INT2/ EVENTOUT                                                  |
| -  | -  | -  | 92 | J14 | 111 | PG7             | I/O | FT | FSMC_INT3<br>/USART6_CK/<br>EVENTOUT                                 |
| -  | -  | -  | 93 | H14 | 112 | PG8             | I/O | FT | USART6_RTS / ETH_PPS_OUT/ EVENTOUT                                   |
| -  | -  | -  | 94 | G12 | 113 | V <sub>SS</sub> | s   |    |                                                                      |
| -  | -  | -  | 95 | H13 | 114 | V <sub>DD</sub> | s   |    |                                                                      |
| 37 | F3 | 63 | 96 | H15 | 115 | PC6             | I/O | FT | I2S2_MCK / TIM8_CH1/SDIO_D6 / USART6_TX / DCMI_D0/TIM3_CH1/ EVENTOUT |
| 38 | E1 | 64 | 97 | G15 | 116 | PC7             | I/O | FT | I2S3_MCK / TIM8_CH2/SDIO_D7 / USART6_RX / DCMI_D1/TIM3_CH2/ EVENTOUT |
| 39 | E2 | 65 | 98 | G14 | 117 | PC8             | I/O | FT | TIM8_CH3/SDIO_D0<br>/TIM3_CH3/ USART6_CK<br>/ DCMI_D2/ EVENTOUT      |

|    |    |    |     |     |     |                      |     |    |  |                                                                                       | 31N13217073   <b>11</b> 378 |
|----|----|----|-----|-----|-----|----------------------|-----|----|--|---------------------------------------------------------------------------------------|-----------------------------|
| 40 | E3 | 66 | 99  | F14 | 118 | PC9                  | I/O | FT |  | I2S_CKIN/ MCO2 /<br>TIM8_CH4/SDIO_D1 /<br>/I2C3_SDA / DCMI_D3 /<br>TIM3_CH4/ EVENTOUT |                             |
| 41 | D1 | 67 | 100 | F15 | 119 | PA8                  | I/O | FT |  | MCO1 / USART1_CK/<br>TIM1_CH1/ I2C3_SCL/<br>OTG_FS_SOF/<br>EVENTOUT                   |                             |
| 42 | D2 | 68 | 101 | E15 | 120 | PA9                  | I/O | FT |  | USART1_TX/TIM1_CH2/<br>I2C3_SMBA / DCMI_D0/<br>EVENTOUT                               | OTG_FS_VBUS                 |
| 43 | D3 | 69 | 102 | D15 | 121 | PA10                 | I/O | FT |  | USART1_RX/TIM1_CH3/<br>OTG_FS_ID/DCMI_D1/<br>EVENTOUT                                 |                             |
| 44 | C1 | 70 | 103 | C15 | 122 | PA11                 | I/O | FT |  | USART1_CTS/CAN1_RX<br>/TIM1_CH4/<br>OTG_FS_DM/<br>EVENTOUT                            |                             |
| 45 | C2 | 71 | 104 | B15 | 123 | PA12                 | I/O | FT |  | USART1_RTS / CAN1_TX/ TIM1_ETR/ OTG_FS_DP/ EVENTOUT                                   |                             |
| 46 | D4 | 72 | 105 | A15 | 124 | PA13<br>(JTMS-SWDIO) | I/O | FT |  | JTMS-SWDIO/<br>EVENTOUT                                                               |                             |
| 47 | B1 | 73 | 106 | F13 | 125 | V <sub>CAP_2</sub>   | s   |    |  |                                                                                       |                             |
| -  | E7 | 74 | 107 | F12 | 126 | V <sub>SS</sub>      | s   |    |  |                                                                                       |                             |
| 48 | E6 | 75 | 108 | G13 | 127 | V <sub>DD</sub>      | s   |    |  |                                                                                       |                             |
| -  | -  | -  | -   | E12 | 128 | PH13                 | I/O | FT |  | TIM8_CH1N / CAN1_TX/<br>EVENTOUT                                                      |                             |
| -  | _  | -  | -   | E13 | 129 | PH14                 | I/O | FT |  | TIM8_CH2N / DCMI_D4/<br>EVENTOUT                                                      |                             |
| -  | -  | -  | -   | D13 | 130 | PH15                 | I/O | FT |  | TIM8_CH3N / DCMI_D11/<br>EVENTOUT                                                     |                             |
| -  | СЗ | -  | -   | E14 | 131 | PI0                  | I/O | FT |  | TIM5_CH4 / SPI2_NSS /<br>I2S2_WS / DCMI_D13/<br>EVENTOUT                              |                             |

|    | B2 | -  | -   | D14 | 132 | PI1                  | I/O | FT | SPI2_SCK / I2S2_CK /<br>DCMI_D8/ EVENTOUT                                         |  |
|----|----|----|-----|-----|-----|----------------------|-----|----|-----------------------------------------------------------------------------------|--|
| -  | -  | -  | -   | C14 | 133 | PI2                  | I/O | FT | TIM8_CH4 /SPI2_MISO /<br>DCMI_D9 / I2S2ext_SD/<br>EVENTOUT                        |  |
| -  | -  | -  | 1   | C13 | 134 | PI3                  | I/O | FT | TIM8_ETR / SPI2_MOSI /<br>I2S2_SD / DCMI_D10/<br>EVENTOUT                         |  |
| -  | -  | -  | -   | D9  | 135 | V <sub>SS</sub>      | s   |    |                                                                                   |  |
| -  | -  | -  | -   | C9  | 136 | $V_{DD}$             | s   |    |                                                                                   |  |
| 49 | A2 | 76 | 109 | A14 | 137 | PA14<br>(JTCK/SWCLK) | I/O | FT | JTCK-SWCLK/<br>EVENTOUT                                                           |  |
| 50 | В3 | 77 | 110 | A13 | 138 | PA15<br>(JTDI)       | I/O | FT | JTDI/ SPI3_NSS/<br>I2S3_WS/TIM2_CH1_ET<br>R / SPI1_NSS /<br>EVENTOUT              |  |
| 51 | D5 | 78 | 111 | B14 | 139 | PC10                 | I/O | FT | SPI3_SCK / I2S3_CK/<br>UART4_TX/SDIO_D2 /<br>DCMI_D8 / USART3_TX/<br>EVENTOUT     |  |
| 52 | C4 | 79 | 112 | B13 | 140 | PC11                 | I/O | FT | UART4_RX/ SPI3_MISO /<br>SDIO_D3 /<br>DCMI_D4/USART3_RX /<br>I2S3ext_SD/ EVENTOUT |  |
| 53 | АЗ | 80 | 113 | A12 | 141 | PC12                 | I/O | FT | UART5_TX/SDIO_CK /<br>DCMI_D9 / SPI3_MOSI<br>/I2S3_SD / USART3_CK/<br>EVENTOUT    |  |
| -  | D6 | 81 | 114 | B12 | 142 | PD0                  | I/O | FT | FSMC_D2/CAN1_RX/<br>EVENTOUT                                                      |  |
| _  | C5 | 82 | 115 | C12 | 143 | PD1                  | I/O | FT | FSMC_D3 / CAN1_TX/<br>EVENTOUT                                                    |  |
| 54 | B4 | 83 | 116 | D12 | 144 | PD2                  | I/O | FT | TIM3_ETR/UART5_RX/<br>SDIO_CMD / DCMI_D11/<br>EVENTOUT                            |  |

| JI VI <u>—</u> | 工台市        | LI T |     |            |     |                 |     |    | S1M32F40/의 구소과 기능                                            |
|----------------|------------|------|-----|------------|-----|-----------------|-----|----|--------------------------------------------------------------|
| -              | -          | 84   | 117 | D11        | 145 | PD3             | I/O | FT | FSMC_CLK/<br>USART2_CTS/<br>EVENTOUT                         |
| -              | A4         | 85   | 118 | D10        | 146 | PD4             | I/O | FT | FSMC_NOE/<br>USART2_RTS/<br>EVENTOUT                         |
| -              | C6         | 86   | 119 | C11        | 147 | PD5             | I/O | FT | FSMC_NWE/USART2_TX / EVENTOUT                                |
| -              | -          | -    | 120 | D8         | 148 | V <sub>SS</sub> | s   |    |                                                              |
| -              | -          | -    | 121 | C8         | 149 | $V_{DD}$        | s   |    |                                                              |
| -              | B5         | 87   | 122 | B11        | 150 | PD6             | I/O | FT | FSMC_NWAIT/<br>USART2_RX/ EVENTOUT                           |
| -              | <b>A</b> 5 | 88   | 123 | A11        | 151 | PD7             | I/O | FT | USART2_CK/FSMC_NE1/<br>FSMC_NCE2/<br>EVENTOUT                |
| -              | -          | -    | 124 | C10        | 152 | PG9             | I/O | FT | USART6_RX / FSMC_NE2/FSMC_NCE3 / EVENTOUT                    |
| -              | -          | -    | 125 | B10        | 153 | PG10            | I/O | FT | FSMC_NCE4_1/<br>FSMC_NE3/ EVENTOUT                           |
| -              | -          | -    | 126 | B9         | 154 | PG11            | I/O | FT | FSMC_NCE4_2 / ETH_MII_TX_EN/ ETH_RMII_TX_EN/ EVENTOUT        |
| -              | -          | -    | 127 | B8         | 155 | PG12            | I/O | FT | FSMC_NE4 /<br>USART6_RTS/<br>EVENTOUT                        |
| _              | -          | -    | 128 | <b>A</b> 8 | 156 | PG13            | I/O | FT | FSMC_A24 / USART6_CTS /ETH_MII_TXD0/ ETH_RMII_TXD0/ EVENTOUT |
| -              | -          | -    | 129 | A7         | 157 | PG14            | I/O | FT | FSMC_A25 / USART6_TX /ETH_MII_TXD1/ ETH_RMII_TXD1/ EVENTOUT  |

|    | l도컴뷰       |    | '소  |            |     |                            |     |    |                                                                                                                   | STM32F407의 구소와 기능 |
|----|------------|----|-----|------------|-----|----------------------------|-----|----|-------------------------------------------------------------------------------------------------------------------|-------------------|
| -  | E8         | -  | 130 | D7         | 158 | V <sub>SS</sub>            | S   |    |                                                                                                                   |                   |
| -  | F7         | -  | 131 | C7         | 159 | V <sub>DD</sub>            | s   |    |                                                                                                                   |                   |
| -  | -          | -  | 132 | В7         | 160 | PG15                       | I/O | FT | USART6_CTS /<br>DCMI_D13/ EVENTOUT                                                                                |                   |
| 55 | В6         | 89 | 133 | A10        | 161 | PB3<br>(JTDO/<br>TRACESWO) | I/O | FT | JTDO/ TRACESWO/<br>SPI3_SCK / I2S3_CK /<br>TIM2_CH2 / SPI1_SCK/<br>EVENTOUT                                       |                   |
| 56 | <b>A</b> 6 | 90 | 134 | <b>A</b> 9 | 162 | PB4<br>(NJTRST)            | I/O | FT | NJTRST/ SPI3_MISO /<br>TIM3_CH1 / SPI1_MISO /<br>I2S3ext_SD/ EVENTOUT                                             |                   |
| 57 | D7         | 91 | 135 | <b>A</b> 6 | 163 | PB5                        | I/O | FT | I2C1_SMBA/ CAN2_RX / OTG_HS_ULPI_D7 / ETH_PPS_OUT/TIM3_CH 2 / SPI1_MOSI/ SPI3_MOSI / DCMI_D10 / I2S3_SD/ EVENTOUT |                   |
| 58 | C7         | 92 | 136 | B6         | 164 | PB6                        | I/O | FT | I2C1_SCL/ TIM4_CH1 / CAN2_TX / DCMI_D5/USART1_TX/ EVENTOUT                                                        |                   |
| 59 | В7         | 93 | 137 | B5         | 165 | PB7                        | I/O | FT | I2C1_SDA / FSMC_NL /<br>DCMI_VSYNC /<br>USART1_RX/ TIM4_CH2/<br>EVENTOUT                                          |                   |
| 60 | A7         | 94 | 138 | D6         | 166 | ВООТ0                      | I   | В  |                                                                                                                   | V <sub>PP</sub>   |
| 61 | D8         | 95 | 139 | <b>A</b> 5 | 167 | PB8                        | I/O | FT | TIM4_CH3/SDIO_D4/<br>TIM10_CH1 / DCMI_D6 /<br>ETH_MII_TXD3 /<br>I2C1_SCL/ CAN1_RX/<br>EVENTOUT                    |                   |
| 62 | C8         | 96 | 140 | B4         | 168 | PB9                        | I/O | FT | SPI2_NSS/ I2S2_WS /<br>TIM4_CH4/ TIM11_CH1/<br>SDIO_D5 / DCMI_D7 /<br>I2C1_SDA / CAN1_TX/<br>EVENTOUT             |                   |

| -  | -  | 97      | 141 | A4 | 169 | PE0             | I/O | FT | TIM4_ETR / FSMC_NBL0<br>/ DCMI_D2/ EVENTOUT |  |
|----|----|---------|-----|----|-----|-----------------|-----|----|---------------------------------------------|--|
| -  | -  | 98      | 142 | A3 | 170 | PE1             | I/O | FT | FSMC_NBL1 / DCMI_D3/<br>EVENTOUT            |  |
| 63 | -  | 99      | -   | D5 | -   | V <sub>SS</sub> | S   |    |                                             |  |
| -  | A8 | -       | 143 | C6 | 171 | PDR_ON          | 1   | FT |                                             |  |
| 64 | A1 | 10<br>0 | 144 | C5 | 172 | V <sub>DD</sub> | s   |    |                                             |  |
| -  | -  | -       | -   | D4 | 173 | PI4             | I/O | FT | TIM8_BKIN / DCMI_D5/<br>EVENTOUT            |  |
| -  | 1  | -       | -   | C4 | 174 | PI5             | I/O | FT | TIM8_CH1 /<br>DCMI_VSYNC/<br>EVENTOUT       |  |
| -  | -  | -       | -   | C3 | 175 | PI6             | I/O | FT | TIM8_CH2 / DCMI_D6/<br>EVENTOUT             |  |
| -  | -  | -       | -   | C2 | 176 | PI7             | I/O | FT | TIM8_CH3 / DCMI_D7/<br>EVENTOUT             |  |

# STM32F407IG 메모리 및 버스 구조



<그림>STM32F시리즈의 버스 및 버스 매트릭스의 구조

# STM32F407IG 메모리및 버스 구조

#### (1) 버스 매트릭스(Bus Matrix)

- 역할: 프로세서와 디버그 인터페이스를 외부버스와 연결하고, I-bus, D-bus, S-bus, PPB 등의 버스와 연결해 줌. 여러 버스간의 접근 순서를 조정
- 접근 순서 조정 규칙: 특별한 충돌이 없는 한 먼저 요청한 버스가 먼저 접근이 되는 라운드-로빈(Round-robin) 방법을 사용
- ●구성요소: 8개의 마스터와 8개의 슬레이브
- 8개의 마스터
- Cortex-M4 with FPU core <u>I-bus</u>, <u>D-bus</u> and <u>S-bus</u>
- DMA1 memory bus
- DMA2 memory bus
- DMA2 peripheral bus
- Ethernet DMA bus
- USB OTG HS DMA bus
- 7개의 슬레이브
- Internal Flash memory I-Code bus
- Internal Flash memory D-Code bus

마이크로컴퓨터 구조

STM32F407의 구조와 기능

#### STM32F407IG 메모리 및 버스 구조

- Main internal SRAM1 (112 KB)
- Auxiliary internal SRAM2 (16 KB)
- AHB1 peripherals including AHB to APB bridges and APB peripherals
- AHB2 peripherals
- FSMC
- (2) I-bus: 명령어(Instruction)용 버스
- (3) D-bus: 데이터(Data) 입출력용 버스
- (4) S-bus: 시스템 버스
- (5) DMA(Direct Memory Access) bus
- DMA-P1, DMA-MEM1, DMA-P2, DMA-MEM2 등의 DMA 버스
- DMA 버스 및 DMA 기능을 이용하면 프로세서의 코어를 거치지 않고도 메모리와 주변장치들 간의 데이터 이동이 가능
- (6) AHB/APB 브리지 및 APB bus
- AHB/APB 브리지: AHB 프로토콜을 APB 프로토콜로 변경해 주는 장치

#### STM32F407IG Memory Map 1

● 메모리-맵 입출력(Memory-mapped I/O, MMIO)

32MB Bit band alias

1MB Bit band region

32MB Bit band alias

Bit band region

1MB

0x43FFFFFF

0x42000000

0x400FFFFF

0x40000000

0x23FFFFFF

0x22000000

0x200FFFFF

0x20000000



#### STM32F407IG Memory Map 2-1



### STM32F407IG Memory Map 2-2



| Bus       | Boundary address          | Peripheral                     |
|-----------|---------------------------|--------------------------------|
|           | 0xE00F FFFF - 0xFFFF FFFF | Reserved                       |
| Cortex-M4 | 0xE000 0000 - 0xE00F FFFF | Cortex-M4 internal peripherals |
|           | 0xA000 1000 - 0xDFFF FFFF | Reserved                       |
|           | 0xA000 0000 - 0xA000 0FFF | FSMC control register          |
|           | 0x9000 0000 - 0x9FFF FFFF | FSMC bank 4                    |
| AHB3      | 0x8000 0000 - 0x8FFF FFFF | FSMC bank 3                    |
|           | 0x7000 0000 - 0x7FFF FFFF | FSMC bank 2                    |
|           | 0x6000 0000 - 0x6FFF FFFF | FSMC bank 1                    |
|           | 0x5006 0C00- 0x5FFF FFFF  | Reserved                       |
|           | 0x5006 0800 - 0x5006 0BFF | RNG                            |
| AHB2      | 0x5005 0400 - 0x5006 07FF | Reserved                       |
|           | 0x5005 0000 - 0x5005 03FF | DCMI                           |
|           | 0x5004 0000- 0x5004 FFFF  | Reserved                       |
|           | 0x5000 0000 - 0x5003 FFFF | USB OTG FS                     |
|           | 0x4008 0000- 0x4FFF FFFF  | Reserved                       |

| Bus   | Boundary address          | Peripheral               |
|-------|---------------------------|--------------------------|
|       | 0x4004 0000 - 0x4007 FFFF | USB OTG HS               |
|       | 0x4002 9400 - 0x4003 FFFF | Reserved                 |
|       | 0x4002 9000 - 0x4002 93FF |                          |
|       | 0x4002 8C00 - 0x4002 8FFF | 1                        |
|       | 0x4002 8800 - 0x4002 8BFF | ETHERNET MAC             |
|       | 0x4002 8400 - 0x4002 87FF | 1                        |
|       | 0x4002 8000 - 0x4002 83FF | 1                        |
|       | 0x4002 6800 - 0x4002 7FFF | Reserved                 |
|       | 0x4002 6400 - 0x4002 67FF | DMA2                     |
|       | 0x4002 6000 - 0x4002 63FF | DMA1                     |
|       | 0x4002 5000 - 0x4002 5FFF | Reserved                 |
|       | 0x4002 4000 - 0x4002 4FFF | BKPSRAM                  |
| ALID4 | 0x4002 3C00 - 0x4002 3FFF | Flash interface register |
| AHB1  | 0x4002 3800 - 0x4002 3BFF | RCC                      |
|       | 0x4002 3400 - 0x4002 37FF | Reserved                 |
|       | 0x4002 3000 - 0x4002 33FF | CRC                      |
|       | 0x4002 2400 - 0x4002 2FFF | Reserved                 |
|       | 0x4002 2000 - 0x4002 23FF | GPIOI                    |
|       | 0x4002 1C00 - 0x4002 1FFF | GPIOH                    |
|       | 0x4002 1800 - 0x4002 1BFF | GPIOG                    |
|       | 0x4002 1400 - 0x4002 17FF | GPIOF                    |
|       | 0x4002 1000 - 0x4002 13FF | GPIOE                    |
|       | 0x4002 0C00 - 0x4002 0FFF | GPIOD                    |
|       | 0x4002 0800 - 0x4002 0BFF | GPIOC                    |
|       | 0x4002 0400 - 0x4002 07FF | GPIOB                    |
|       | 0x4002 0000 - 0x4002 03FF | GPIOA                    |
|       | 0x4001 5800- 0x4001 FFFF  | Reserved                 |

| Bus  | Boundary address          | Peripheral         |
|------|---------------------------|--------------------|
|      | 0x4001 4C00 - 0x4001 57FF | Reserved           |
|      | 0x4001 4800 - 0x4001 4BFF | TIM11              |
|      | 0x4001 4400 - 0x4001 47FF | TIM10              |
|      | 0x4001 4000 - 0x4001 43FF | TIM9               |
|      | 0x4001 3C00 - 0x4001 3FFF | EXTI               |
|      | 0x4001 3800 - 0x4001 3BFF | SYSCFG             |
|      | 0x4001 3400 - 0x4001 37FF | Reserved           |
|      | 0x4001 3000 - 0x4001 33FF | SPI1               |
| APB2 | 0x4001 2C00 - 0x4001 2FFF | SDIO               |
|      | 0x4001 2400 - 0x4001 2BFF | Reserved           |
|      | 0x4001 2000 - 0x4001 23FF | ADC1 - ADC2 - ADC3 |
|      | 0x4001 1800 - 0x4001 1FFF | Reserved           |
|      | 0x4001 1400 - 0x4001 17FF | USART6             |
|      | 0x4001 1000 - 0x4001 13FF | USART1             |
|      | 0x4001 0800 - 0x4001 0FFF | Reserved           |
|      | 0x4001 0400 - 0x4001 07FF | TIM8               |
|      | 0x4001 0000 - 0x4001 03FF | TIM1               |
|      | 0x4000 7800- 0x4000 FFFF  | Reserved           |

| Bus  | Boundary address          | Peripheral          |
|------|---------------------------|---------------------|
|      | 0x4000 7800 - 0x4000 7FFF | Reserved            |
|      | 0x4000 7400 - 0x4000 77FF | DAC                 |
|      | 0x4000 7000 - 0x4000 73FF | PWR                 |
|      | 0x4000 6C00 - 0x4000 6FFF | Reserved            |
|      | 0x4000 6800 - 0x4000 6BFF | CAN2                |
|      | 0x4000 6400 - 0x4000 67FF | CAN1                |
|      | 0x4000 6000 - 0x4000 63FF | Reserved            |
|      | 0x4000 5C00 - 0x4000 5FFF | I2C3                |
|      | 0x4000 5800 - 0x4000 5BFF | I2C2                |
|      | 0x4000 5400 - 0x4000 57FF | I2C1                |
|      | 0x4000 5000 - 0x4000 53FF | UART5               |
|      | 0x4000 4C00 - 0x4000 4FFF | UART4               |
|      | 0x4000 4800 - 0x4000 4BFF | USART3              |
|      | 0x4000 4400 - 0x4000 47FF | USART2              |
|      | 0x4000 4000 - 0x4000 43FF | I2S3ext             |
| APB1 | 0x4000 3C00 - 0x4000 3FFF | SPI3 / I2S3         |
|      | 0x4000 3800 - 0x4000 3BFF | SPI2 / I2S2         |
|      | 0x4000 3400 - 0x4000 37FF | I2S2ext             |
|      | 0x4000 3000 - 0x4000 33FF | IWDG                |
|      | 0x4000 2C00 - 0x4000 2FFF | WWDG                |
|      | 0x4000 2800 - 0x4000 2BFF | RTC & BKP Registers |
|      | 0x4000 2400 - 0x4000 27FF | Reserved            |
|      | 0x4000 2000 - 0x4000 23FF | TIM14               |
|      | 0x4000 1C00 - 0x4000 1FFF | TIM13               |
|      | 0x4000 1800 - 0x4000 1BFF | TIM12               |
|      | 0x4000 1400 - 0x4000 17FF | TIM7                |
|      | 0x4000 1000 - 0x4000 13FF | TIM6                |
|      | 0x4000 0C00 - 0x4000 0FFF | TIM5                |
|      | 0x4000 0800 - 0x4000 0BFF | TIM4                |
|      | 0x4000 0400 - 0x4000 07FF | TIM3                |
|      | 0x4000 0000 - 0x4000 03FF | TIM2                |

# STM32F407IG Memory Map 4 (Peripheral 관리 Registers

Table 2. STM32F4xx register boundary addresses

| Boundary address          | Peripheral               | Bus        | Register map                                        |
|---------------------------|--------------------------|------------|-----------------------------------------------------|
| 0xA000 0000 - 0xA000 0FFF | FSMC control register    | AHB3       | Section 32.6.9: FSMC register map on page 1373      |
| 0x5006 0800 - 0x5006 0BFF | RNG                      |            | Section 21.4.4: RNG register map on page 598        |
| 0x5006 0400 - 0x5006 07FF | HASH                     |            | Section 22.4.9: HASH register map on page 622       |
| 0x5006 0000 - 0x5006 03FF | CRYP                     | AHB2       | Section 20.6.13: CRYP register map on page 591      |
| 0x5005 0000 - 0x5005 03FF | DCMI                     | / ti 1.5.2 | Section 13.8.12: DCMI register map on page 351      |
| 0x5000 0000 - 0x5003 FFFF | USB OTG FS               |            | Section 30.16.6: OTG_FS register map on page 1106   |
| 0x4004 0000 - 0x4007 FFFF | USB OTG HS               |            | Section 31.12.6: OTG_HS register map on page 1248   |
| 0x4002 9000 - 0x4002 93FF |                          |            |                                                     |
| 0x4002 8C00 - 0x4002 8FFF |                          |            |                                                     |
| 0x4002 8800 - 0x4002 8BFF | ETHERNET MAC             |            | Section 29.8.5: Ethernet register maps on page 1017 |
| 0x4002 8400 - 0x4002 87FF |                          |            | page 1511                                           |
| 0x4002 8000 - 0x4002 83FF |                          |            |                                                     |
| 0x4002 6400 - 0x4002 67FF | DMA2                     |            | Continuo C 111 DMA register man en page 245         |
| 0x4002 6000 - 0x4002 63FF | DMA1                     |            | Section 9.5.11: DMA register map on page 245        |
| 0x4002 4000 - 0x4002 4FFF | BKPSRAM                  |            |                                                     |
| 0x4002 3C00 - 0x4002 3FFF | Flash interface register |            | Section 3.8: Flash interface registers              |
| 0x4002 3800 - 0x4002 3BFF | RCC                      |            | Section 6.3.32: RCC register map on page 181        |
| 0x4002 3000 - 0x4002 33FF | CRC                      | AHB1       | Section 4.4.4: CRC register map on page 88          |
| 0x4002 2000 - 0x4002 23FF | GPIOI                    |            |                                                     |
| 0x4002 1C00 - 0x4002 1FFF | GPIOH                    |            |                                                     |
| 0x4002 1800 - 0x4002 1BFF | GPIOG                    |            |                                                     |
| 0x4002 1400 - 0x4002 17FF | GPIOF                    |            |                                                     |
| 0x4002 1000 - 0x4002 13FF | GPIOE                    |            | Section 7.4.11: GPIO register map on page 203       |
| 0x4002 0C00 - 0x4002 0FFF | GPIOD                    |            |                                                     |
| 0x4002 0800 - 0x4002 0BFF | GPIOC                    |            |                                                     |
| 0x4002 0400 - 0x4002 07FF | GPIOB                    |            |                                                     |
| 0x4002 0000 - 0x4002 03FF | GPIOA                    |            |                                                     |
| 0x4001 5400 - 0x4001 57FF | SPI6                     | APB2       | Section 27.5.10: SPI register map on page 845       |
| 0x4001 5000 - 0x4001 53FF | SPI5                     | AFD2       | Section 27.5.10. SET register map on page 645       |
| 0x4001 4800 - 0x4001 4BFF | TIM11                    |            | Section 16.6.11: TIM10/11/13/14 register map on     |
| 0x4001 4400 - 0x4001 47FF | TIM10                    |            | page 524                                            |
| 0x4001 4000 - 0x4001 43FF | TIM9                     | APB2       | Section 16.5.14: TIM9/12 register map on page 514   |
| 0x4001 3C00 - 0x4001 3FFF | EXTI                     |            | Section 10.3.7: EXTI register map on page 262       |
| 0x4001 3800 - 0x4001 3BFF | SYSCFG                   |            | Section 7.2.8: SYSCFG register maps on page 157     |
| 0x4001 3400 - 0x4001 37FF | SPI4                     | APB2       | Section 27.5.10: SPI register map on page 845       |

# STM32F407IG Memory Map 4 (Peripheral 관리 Registers

Table 2. STM32F4xx register boundary addresses (continued)

| 0x44001 3000 - 0x44001 33FF   SPI1     0x44001 2000 - 0x44001 23FF   ADC1 - ADC2 - ADC3     0x44001 12000 - 0x44001 12FF   ADC1 - ADC2 - ADC3     0x44001 1400 - 0x44001 13FF   USART6     0x44001 0x04001 13FF   USART6     0x44001 0x04001 0x04000 | Boundary address          | Peripheral          | Bus   | Register map                                    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|---------------------|-------|-------------------------------------------------|
| Section 1.1.3.18: ADC register map on page 307                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4001 3000 - 0x4001 33FF | SPI1                |       | Section 27.5.10: SPI register map on page 845   |
| 0x4001 1400 - 0x4001 17FF         USART6           0x4001 1000 - 0x4001 13FF         USART1           0x4001 0400 - 0x4001 03FF         TIM8           0x4001 0000 - 0x4001 03FF         TIM1           0x4001 0000 - 0x4001 03FF         UART8           0x4000 7600 - 0x4000 7FFF         UART7           0x4000 7900 - 0x4000 78FF         DAC           0x4000 7000 - 0x4000 73FF         DAC           0x4000 7000 - 0x4000 73FF         PWR           0x4000 6800 - 0x4000 68FF         CAN2           0x4000 500 - 0x4000 5FFF         I2C2           0x4000 500 - 0x4000 5FFF         I2C3           0x4000 500 - 0x4000 5FFF         I2C1           0x4000 400 - 0x4000 4FFF         USART3           0x4000 400 - 0x4000 4FFF         I2S3ext           0x4000 500 - 0x4000 3FFF         I2S3ext           0x4000 300 - 0x4000 3FFF         I2S2ext           0x4000 300 - 0x4000 3FF         I2S2ext           0x4000 300 - 0x4000 3FF         IVDIS           0x4000 300 - 0x4000 3FF         IVDIS           0x400                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x4001 2C00 - 0x4001 2FFF | SDIO                |       | Section 28.9.16: SDIO register map on page 901  |
| Section 26.6.8: USART register map on page 793                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4001 2000 - 0x4001 23FF | ADC1 - ADC2 - ADC3  |       | Section 11.13.18: ADC register map on page 307  |
| 0x4001 1000 - 0x4001 13FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4001 1400 - 0x4001 17FF | USART6              | APB2  | Section 26.6.9: USART register man on page 703  |
| National Color                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4001 1000 - 0x4001 13FF | USART1              |       | Cection 20.0.0. COATT Tegister map on page 750  |
| 0x4000 7C00 - 0x4000 7FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4001 0400 - 0x4001 07FF | TIM8                |       | Section 14.4.21: TIM1&TIM8 register map on      |
| Ox4000 7800 - 0x4000 7BFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4001 0000 - 0x4001 03FF | TIM1                |       | page 420                                        |
| 0x4000 7800 - 0x4000 7FFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 7C00 - 0x4000 7FFF | UART8               | APR1  | Section 26.6.8: LISART register man on page 703 |
| Ox4000 7000 - 0x4000 73FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 7800 - 0x4000 7BFF | UART7               | AI D1 | Cection 20.0.0. COATT Tegister map on page 750  |
| Ox4000 6800 - 0x4000 6BFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 7400 - 0x4000 77FF | DAC                 |       | Section 12.5.15: DAC register map on page 329   |
| Ox4000 6400 - Ox4000 67FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 7000 - 0x4000 73FF | PWR                 |       | Section 5.5: PWR register map on page 109       |
| 0x4000 6400 - 0x4000 5FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x4000 6800 - 0x4000 6BFF | CAN2                |       | Section 24.0.5: bvCAN register man on page 705  |
| Ox4000 5800 - Ox4000 5BFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 6400 - 0x4000 67FF | CAN1                |       | Cection 24.5.5. DXC/AV register map on page 705 |
| Ox4000 5400 - Ox4000 57FF   I2C1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x4000 5C00 - 0x4000 5FFF | I2C3                |       |                                                 |
| Ox4000 5000 - Ox4000 53FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 5800 - 0x4000 5BFF | I2C2                |       | Section 25.6.11: I2C register map on page 741   |
| 0x4000 4C00 - 0x4000 4FFF         UART4           0x4000 4800 - 0x4000 4BFF         USART3           0x4000 4400 - 0x4000 4FFF         USART2           0x4000 3C00 - 0x4000 4FFF         USART2           0x4000 3C00 - 0x4000 3FFF         SPI3 / I2S3           0x4000 3800 - 0x4000 3BFF         SPI2 / I2S2           0x4000 3000 - 0x4000 3FF         IWDG           0x4000 2C00 - 0x4000 2FFF         WWDG           0x4000 2C00 - 0x4000 2FFF         WWDG           0x4000 2C00 - 0x4000 2FFF         TIM14           0x4000 1C00 - 0x4000 1FFF         TIM13           0x4000 1C00 - 0x4000 1FFF         TIM12           0x4000 1400 - 0x4000 1FFF         TIM7           0x4000 1000 - 0x4000 1FFF         TIM6           0x4000 0c00 - 0x4000 0FFF         TIM6           0x4000 0c00 - 0x4000 0FFF         TIM5           0x4000 0c00 - 0x4000 0cr         TIM5 <t< td=""><td>0x4000 5400 - 0x4000 57FF</td><td>I2C1</td><td></td><td></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x4000 5400 - 0x4000 57FF | I2C1                |       |                                                 |
| Ox4000 4800 - 0x4000 4BFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 5000 - 0x4000 53FF | UART5               |       |                                                 |
| 0x4000 4800 - 0x4000 4BFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 4C00 - 0x4000 4FFF | UART4               |       | Section 26.6 P. USADT register man on page 702  |
| 0x4000 4000 - 0x4000 43FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 4800 - 0x4000 4BFF | USART3              |       | Gection 20.0.8. COAM Tegister map on page 793   |
| 0x4000 3C00 - 0x4000 3FFF         SPI3 / I2S3           0x4000 3800 - 0x4000 3BFF         SPI2 / I2S2           0x4000 3400 - 0x4000 3FF         I2S2ext           0x4000 3000 - 0x4000 3FF         IWDG           0x4000 2C00 - 0x4000 2FFF         WWDG           0x4000 2800 - 0x4000 2FF         RTC & BKP Registers           0x4000 2000 - 0x4000 2FF         TIM14           0x4000 1C00 - 0x4000 1FFF         TIM13           0x4000 1800 - 0x4000 1FFF         TIM7           0x4000 1400 - 0x4000 17FF         TIM6           0x4000 0C00 - 0x4000 0FFF         TIM5           0x4000 0800 - 0x4000 0FFF         TIM5           0x4000 0800 - 0x4000 0FFF         TIM4           0x4000 0400 - 0x4000 0FFF         TIM5           0x4000 0800 - 0x4000 0FFF         TIM5           0x4000 0400 - 0x4000 0FFF         TIM4           0x4000 0400 - 0x4000 0FF         TIM4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0x4000 4400 - 0x4000 47FF | USART2              |       |                                                 |
| Section 27.5.10: SPI register map on page 845                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x4000 4000 - 0x4000 43FF | I2S3ext             |       |                                                 |
| 0x4000 3800 - 0x4000 3BFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 3C00 - 0x4000 3FFF | SPI3 / I2S3         |       | Section 27.5.10: SPI register man on page 845   |
| 0x4000 3000 - 0x4000 33FF         IWDG           0x4000 2C00 - 0x4000 2FFF         WWDG           0x4000 2800 - 0x4000 2BFF         RTC & BKP Registers           0x4000 2000 - 0x4000 23FF         TIM14           0x4000 1C00 - 0x4000 1FFF         TIM13           0x4000 1800 - 0x4000 1BFF         TIM7           0x4000 1000 - 0x4000 17FF         TIM6           0x4000 0C00 - 0x4000 0FFF         TIM5           0x4000 0800 - 0x4000 0FFF         TIM5           0x4000 0400 - 0x4000 0FFF         TIM4           0x4000 0400 - 0x4000 0FFF         TIM5           0x4000 0400 - 0x4000 0FFF         TIM4           0x4000 0400 - 0x4000 0FFF         TIM3    Section 18.4.5: IWDG register map on page 547  Section 19.6.4: WWDG register map on page 524  Section 19.6.4: WWDG register map on page 524  Section 19.6.4: WWDG register map on page 524  Section 16.6.11: TIM10/11/13/14 register map on page 524  Section 16.5.14: TIM9/12 register map on page 524  Section 17.4.9: TIM6&TIM7 register map on page 535  Section 17.4.9: TIM6&TIM7 register map on page 536  Section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x4000 3800 - 0x4000 3BFF | SPI2 / I2S2         | APB1  | Cection 27.5. To. Of 7 register map on page 045 |
| 0x4000 2C00 - 0x4000 2FFF         WWDG           0x4000 2800 - 0x4000 2BFF         RTC & BKP Registers           0x4000 2000 - 0x4000 23FF         TIM14           0x4000 1C00 - 0x4000 1FFF         TIM13           0x4000 1800 - 0x4000 1BFF         TIM12           0x4000 1000 - 0x4000 17FF         TIM6           0x4000 0C00 - 0x4000 0FF         TIM5           0x4000 0800 - 0x4000 0FF         TIM5           0x4000 0400 - 0x4000 07FF         TIM4           0x4000 0400 - 0x4000 07FF         TIM4           0x4000 0400 - 0x4000 07FF         TIM3    Section 19.6.4: WWDG register map on page 547  Section 23.6.21: RTC register map on page 662  Section 16.6.11: TIM10/11/13/14 register map on page 524  Section 16.5.14: TIM9/12 register map on page 514  Section 17.4.9: TIM6&TIM7 register map on page 535  Section 17.4.9: TIM6&TIM7 register map on page 480  Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x4000 3400 - 0x4000 37FF | I2S2ext             |       |                                                 |
| 0x4000 2800 - 0x4000 2BFF         RTC & BKP Registers           0x4000 2000 - 0x4000 23FF         TIM14           0x4000 1C00 - 0x4000 1FFF         TIM13           0x4000 1800 - 0x4000 1BFF         TIM12           0x4000 1400 - 0x4000 17FF         TIM7           0x4000 1000 - 0x4000 13FF         TIM6           0x4000 0C00 - 0x4000 0FFF         TIM5           0x4000 0800 - 0x4000 0FFF         TIM4           0x4000 0400 - 0x4000 07FF         TIM3    Section 23.6.21: RTC register map on page 662  Section 16.6.11: TIM10/11/13/14 register map on page 524  Section 16.5.14: TIM9/12 register map on page 524  Section 17.4.9: TIM6&TIM7 register map on page 535  Section 17.4.9: TIM6&TIM7 register map on page 535  Section 15.4.21: TIMx register map on page 480  Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0x4000 3000 - 0x4000 33FF | IWDG                |       | Section 18.4.5: IWDG register map on page 540   |
| 0x4000 2000 - 0x4000 23FF         TIM14           0x4000 1C00 - 0x4000 1FFF         TIM13           0x4000 1800 - 0x4000 1BFF         TIM12           0x4000 1400 - 0x4000 17FF         TIM7           0x4000 1000 - 0x4000 13FF         TIM6           0x4000 0C00 - 0x4000 0FFF         TIM5           0x4000 0800 - 0x4000 0FFF         TIM4           0x4000 0400 - 0x4000 07FF         TIM3    Section 16.6.11: TIM10/11/13/14 register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x4000 2C00 - 0x4000 2FFF | WWDG                |       | Section 19.6.4: WWDG register map on page 547   |
| 0x4000 1C00 - 0x4000 1FFF         TIM13         page 524           0x4000 1800 - 0x4000 1BFF         TIM12         Section 16.5.14: TIM9/12 register map on page 514           0x4000 1400 - 0x4000 17FF         TIM7         Section 17.4.9: TIM6&TIM7 register map on page 535           0x4000 0C00 - 0x4000 0FFF         TIM5         Section 17.4.9: TIM6&TIM7 register map on page 535           0x4000 0800 - 0x4000 0FFF         TIM4         Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x4000 2800 - 0x4000 2BFF | RTC & BKP Registers |       | Section 23.6.21: RTC register map on page 662   |
| 0x4000 1800 - 0x4000 1BFF         TIM12         Section 16.5.14: TIM9/12 register map on page 514           0x4000 1400 - 0x4000 17FF         TIM7         Section 17.4.9: TIM6&TIM7 register map on page 535           0x4000 0C00 - 0x4000 0FFF         TIM5         Section 17.4.9: TIM6&TIM7 register map on page 535           0x4000 0800 - 0x4000 0FFF         TIM4         Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x4000 2000 - 0x4000 23FF | TIM14               |       | Section 16.6.11: TIM10/11/13/14 register map on |
| 0x4000 1800 - 0x4000 18FF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x4000 1C00 - 0x4000 1FFF | TIM13               |       | page 524                                        |
| 0x4000 1000 - 0x4000 13FF TIM6  0x4000 0C00 - 0x4000 0FFF TIM5  0x4000 0800 - 0x4000 0BFF TIM4  0x4000 0400 - 0x4000 07FF TIM3  Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4000 1800 - 0x4000 1BFF | TIM12               |       |                                                 |
| 0x4000 0C00 - 0x4000 0FFF TIM5 0x4000 0800 - 0x4000 0BFF TIM4 0x4000 0400 - 0x4000 07FF TIM3  Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x4000 1400 - 0x4000 17FF | TIM7                |       | Section 17.4.9: TIM6&TIM7 register map on       |
| 0x4000 0800 - 0x4000 0BFF TIM4 Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x4000 1000 - 0x4000 13FF | TIM6                |       | page 535                                        |
| 0x4000 0400 - 0x4000 07FF TIM3 Section 15.4.21: TIMx register map on page 480                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x4000 0C00 - 0x4000 0FFF | TIM5                |       |                                                 |
| 0x4000 0400 - 0x4000 07FF TIM3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4000 0800 - 0x4000 0BFF | TIM4                |       | Section 15.4.21 · TIMy register man on page 490 |
| 0x4000 0000 - 0x4000 03FF TIM2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0x4000 0400 - 0x4000 07FF | ТІМЗ                |       | Gection 15.4.21. Timx register map on page 460  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0x4000 0000 - 0x4000 03FF | TIM2                |       |                                                 |

#### STM32F407IG Embedded Flash memory

Figure 3. Flash memory Interface connection inside system architecture



#### STM32F407IG Embedded Flash memory

#### Flash module organization (STM32F40x and STM32F41x)

| Block       | Name      | Block base addresses      | Size       |
|-------------|-----------|---------------------------|------------|
|             | Sector 0  | 0x0800 0000 - 0x0800 3FFF | 16 Kbytes  |
|             | Sector 1  | 0x0800 4000 - 0x0800 7FFF | 16 Kbytes  |
|             | Sector 2  | 0x0800 8000 - 0x0800 BFFF | 16 Kbytes  |
|             | Sector 3  | 0x0800 C000 - 0x0800 FFFF | 16 Kbytes  |
|             | Sector 4  | 0x0801 0000 - 0x0801 FFFF | 64 Kbytes  |
| Main memory | Sector 5  | 0x0802 0000 - 0x0803 FFFF | 128 Kbytes |
|             | Sector 6  | 0x0804 0000 - 0x0805 FFFF | 128 Kbytes |
|             |           |                           |            |
|             |           |                           |            |
|             | Sector 11 | 0x080E 0000 - 0x080F FFFF | 128 Kbytes |
| System      | memory    | 0x1FFF 0000 - 0x1FFF 77FF | 30 Kbytes  |
| OTF         | area      | 0x1FFF 7800 - 0x1FFF 7A0F | 528 bytes  |
| Optio       | n bytes   | 0x1FFF C000 - 0x1FFF C00F | 16 bytes   |

- •Main memory
- -16Kbytes 4 sectors
- -64Kbytes 1 sectors
- -128Kbytes 7 sectors
- All 1Mbyte로 구성됨
- •System Memory:
  - Boot Loader Program 이 들어 있음.
  - •OTP(One time
- Programmable):한번 기록할수 있는 메모리
- 영역
  •Option bytes
- •Option bytes •Flash Area를 읽기/쓰
  - 기 방지 설정
- -BOR(Brown Out Reset) Level 설정
- -Watchdog 설정

#### STM32F407IG Embedded Flash memory

#### 3.8.1 Flash access control register (FLASH\_ACR)

The Flash access control register is used to enable/disable the acceleration features and control the Flash memory access time according to CPU frequency.

Address offset: 0x00

Reset value: 0x0000 0000

Access: no wait state, word, half-word and byte access

|   | 31       | 30       | 29 | 28    | 27    | 26   | 25   | 24     | 23       | 22 | 21       | 20 | 19 | 18 | 17      | 16 |
|---|----------|----------|----|-------|-------|------|------|--------|----------|----|----------|----|----|----|---------|----|
| Γ | Reserved |          |    |       |       |      |      |        |          |    |          |    |    |    |         |    |
|   | 15       | 14       | 13 | 12    | 11    | 10   | 9    | 8      | 7        | 6  | 5        | 4  | 3  | 2  | 1       | 0  |
| Γ |          | Reserved |    | DCRST | ICRST | DCEN | ICEN | PRFTEN | Descried |    |          |    |    | I  | LATENCY | ,  |
|   |          | neserveu |    | rw    | w     | rw   | rw   | rw     |          |    | Reserved | ı  |    | rw | rw      | rw |

Bits 31:11 Reserved, must be kept cleared.

Bit 12 DCRST: Data cache reset

0: Data cache is not reset

1: Data cache is reset

This bit can be written only when the D cache is disabled.

Bit 11 ICRST: Instruction cache reset

0: Instruction cache is not reset

Instruction cache is reset

This bit can be written only when the I cache is disabled.

마이크로컴퓨터 구조 STM32F407의 구조와 기능

#### STM32F407IG Embedded Flash memory

#### Bit 10 DCEN: Data cache enable

0: Data cache is disabled

Data cache is enabled

#### Bit 9 ICEN: Instruction cache enable

Instruction cache is disabled

Instruction cache is enabled

#### Bit 8 PRFTEN: Prefetch enable

Prefetch is disabled

Prefetch is enabled

Bits 7:3 Reserved, must be kept cleared.

#### Bits 2:0 LATENCY: Latency

These bits represent the ratio of the CPU clock period to the Flash memory access time.

000: Zero wait state

001: One wait state

010: Two wait states

011: Three wait states

100: Four wait states

101: Five wait states

110: Six wait states

111: Seven wait states

마이크로컴퓨터 구조

#### STM32F407IG Power Control

Figure 21. Power supply scheme



- ●전원공급부
- •외부 전원 V<sub>nn</sub>: 1.8V~3.6V
- •내장 레귤레이터 (Voltage Regulator)
- :1.2V로 변환하여 내부
- •외부 전원  $V_{nn}$ 가 공급 되지 않을 때: 백업 레 지스터(BKP register), 리얼타임 클럭(RTC) 등은 배터리 전원  $V_{BAT}$

MS19911V 2

#### STM32F407IG Power Control

- ●전원공급 감시부
- •POR(Power-On Reset) 및 PDR(Power-Down Reset) : 공급전원  $V_{DD}/V_{DDA}$ 가 미리 정해진 허용범위(PDR/POR)를 넘을 경우, 외부의 리셋회로의 동작 상관없이 MCU는 리셋 모드 유지
- •PVD(Programmable voltage detector :프로그램 가능한 전압 검출기) : 공급전원 VDD/VDDA를 PVD의 threshold값 VPVD와 비교하여 크거나 작아지는 경우 인터럽트를 발생(인터럽트 서비스 루틴에서는 경고 메시지를 발생시키거나 MCU가 필요한 안전 조치를 실행)



# STM32F407IG 저전력모드

- (1)Run mode(동작 모드)
- 시스템 리셋이나 파워 리셋 후에 MCU는 디폴트로 Run mode로 동작
- 하게 되며, 외부 인터럽트의 발생을 기다리는 때와 같이 CPU가 계속
- 동작할 필요가 없는 경우에는 전력 소모를 줄이기 위해 저전력 모드로 전환이 가능
- (2)Low power mode(저전력 모드)
- ① Sleep mode(슬립 모드)
- CPU의 클럭만 정지
- •모든 주변장치는 동작하고 있으며 인터럽트나 이벤트가 발생하면 CPU를 wake up
- ② Stop mode(정지 모드)
- 1.2V 영역의 모든 클럭 정지(SRAM과 레지스터의 데이터는 보존)
- Stop mode 탈출방법: GPIO를 통하여 발생하는 16개의 EXTI 등
- ③ Standby mode(대기모드)
- 1.2V 영역의 모든 클럭 정지 (백업 영역내의 레지스터와 백업 SRAM 을 제외한 모든 SRAM과 레지스터의 데이터는 지워짐)
- Standby mode 탈출방법: external reset(NRST) 등

#### STM32F407IG Reset

- 종류: 시스템 리셋, 전원 리셋 및 백업 영역 리셋
- ① 시스템 리셋 (System reset)
- 시스템 리셋이 발생되는 경우: 5가지
- External reset 핀에 로우(low) 신호(NRST)가 입력
- 윈도우 워치독 리셋 (WWDG reset) 의 발생
- •독립 워치독 리셋 (IWDG reset)의 발생
- 소프트웨어 리셋의 발생
- 저전압 리셋의 발생



마이크로컴퓨터 구조 STM32F407의 구조와 기능

#### STM32F407IG Reset

#### ② 전원 리셋 (Power reset)

- 백업 영역을 제외한 모든 레지스터를 리셋(초기)값으로 설정
- 전원 리셋이 발생되는 경우
- 파워-온/파워-다운(POR/PDR) 리셋의 발생
- 대기 모드에서 빠져 나올때
- ③ 백업 영역 리셋 (Backup domain reset)
- 백업 영역만 리셋
- 백업 영역 리셋이 발생하는 경우
- 백업 영역 제어 레지스터( $RCC\_BDCR$ )의 BDRST 비트의 설정시에 발생하는 소프트웨어 리셋
- $V_{DD}$  또는  $V_{RAT}$ 의 전원이 OFF된 후에 ON되는 경우



절차(세 방법중 하나) OSC 25(or8)MHz **PLL** 

**MUX** 

**SYSCLK 168MHz** 

•PLL: Phase Lock Loop, MCU의 내부 clock 주파수를 외부 source clock의 정수 배로 변환

- ●시스템 클럭(SYSCLK: 최대 168MHz) 발생 소스
- ① 16MHz의 HSI RC(HSI):내부
- ② PLL(PLLCLK):



- ●시스템 클럭(SYSCLK) 용도
- : AHB 프리스케일러를 거쳐 AHB 버스, APB 버스, 타이머, AD 변환 기 등 MCU 내부의 여러 장치의 구동용 클럭으로 사용
- ✓SYSCLK을 이용하지 않은 주변장치
- : USB OTG HS clock(60MHz), I2C clock, Ethernet MAC clocks (TX,

**RX** and **RMII**)



●리얼타임 클럭(RTCCLK) 발생 소스

: 4-26MHz의 HSE OSC, 32.768KHz의 LSE OSC, 32KHz의 LSI RC



●HSE/LSE OSC의 외부 입력 방법



동작

플래시 메모리가 부트영역으로 선택됨

시스템 메모리가 부트영역으로 선택됨

내장 SRAM이 부트영역으로 선택됨

모드로 동작이 가능

**BOOT0** 

0

부트 모드 선택핀

**BOOT1** 

 $\mathbf{X}$ 

0

1

●부트 모드 종류

셋시에, 사용할 부트 모드를 선택

: Main Flash memory, System memory, Embedded SRAM

에서 BOOT 핀의 값을 읽어서 이에 대응되는 모드를 부팅

부트 모드

**Main Flash memory** 

System memory

**Embedded SRAM** 

●BOOT0 및 BOOT1 핀의 설정에 따라 전원 공급(Power On)이나 리

●MCU는 리셋 동작 후의 4번째 시스템 클럭(SYSCLK)의 상승 에지

●전원 공급 전이나 리셋 스위치를 누르기 전에 BOOT 핀을 미리 원하

는 모드에 맞게 설정해 주면 전원을 ON이나 리셋 시에 원하는 부트

STM32F407IG Boot mode

#### STM32F407IG Boot mode

- ●Main Flash Memory 모드
- •부트 메모리 영역(0x0000.0000)에 메인 플래시 메모리가 앨리어스 (alias)됨(메인 플래시 메모리의 시작 주소(0x0800.0000)가 부트 메모리 영역에 쓰여짐)
- •이 모드로 부팅을 하면 플래시 메모리내에 저장된 프로그램 실행됨

  System Memory 모드
- •부트 메모리 영역(0x0000.0000)에 시스템 메모리가 앨리어스(alias)됨(시스템 메모리의 시작 주소(0x1FFF. F000)가 부트 메모리 영역에 쓰여짐)
- •이 모드로 부팅을 하면 시스템 메모리내에 저장된 프로그램인 내장 부트로더(Embedded boot loader)가 실행됨
- ●Embedded SRAM 모드
- •이 모드로 부팅할 때는 어플리케이션 초기화 코드(application initialization code)에서 NVIC의 예외 테이블(exception table)과 오프셋(offset) 레지스터를 이용하여 SRAM내에 있는 벡터 테이블을 재배치(relocate)해주는 것이 필요

마이크로컴퓨터 구조 STM32F407의 구조와 기능

#### STM32F407IG Boot mode

#### ➤내장 부트 로더 (Embedded boot loader)

- ① 시스템 메모리 내에 있는 프로그램으로, 이를 이용하면 PC에서 사용자가 작성한 프로그램을 플래시 메모리에 다운로드 가능
- ② 내장 부트로더를 이용한 프로그램 다운로드 과정
- <u>시스템 메모리</u> 모드를 선택하고 부팅한 후에, PC에서 사용자가 작성한 프로그램을 Cortex-M의 USART1 포트(또는 미리 정해진 다른 시리얼 포트)를 통하여 다운로드(즉, 플래시 메모리가 재프로그램)
- ③ 사용할 수 있는 시리얼 포트
- USART1 (PA9/PA10), USART3 (PB10/11 and PC10/11), CAN2 (PB5/13), USB OTG FS (PA11/12)
- ④ 내장 부트로더는 칩의 제조시에 시스템 메모리 내에 미리 프로그램되어 공급됨

#### STM32F407IG Interrupt



마이크로컴퓨터 구조 STM32F407의 구조와 기능

#### (3) 인터럽트의 처리 과정

| 1. 인터럽트 요청<br>신호의검출 | CPU는 모든 명령 사이클에 한번씩 또는 모든 머신 사이클에 한번씩 지정된 순간에 인터럽트를 샘플링하여 주변장치의 인 |
|---------------------|-------------------------------------------------------------------|
| 선모의 선물              | 터럽트요청을 검출                                                         |

2. 인터럽트 우선순 위 제어 및 CPU가 인터럽트를 허용할 수 있는 조건이 만족되는지를 판단하고 우선순위를 결정하여 인터럽트를 허용

3. 인터럽트 처리루 CPU가 인터럽트를 요청한 주변장치에 대응하는 인터럽트 서 틴의 시작 번지 확 비스 루틴의 시작번지를 확인. 시작번지는 벡터테이블에 지정 인 되어 있음.

4. 복귀주소 및 레지스터를 저장

CPU가 나중에 인터럽트 서비스 루틴을 종료하고 되돌아 올수 있도록 return address (현재의 PC 값)를 stack에 저장하고, 마이크로프로세서에 따라서는 현재의 CPU내의 중요레지스터 값을 자동으로 stack에 저장하는 것도 있음. 또한, 대부분의 경우 하나의 인터럽트가 서비스되고 있는 동안에는 다른 인터럽트가 허용되지 못하도록 일시적으로 인터럽트 금지 상태로설정.

마이크로컴퓨터 구조 STM32F407의 구조와 기능

#### (3) 인터럽트의 처리 과정(계속)

5. 인터럽트 서비스 루틴을 실행

CPU가 해당 인터럽트 서비스 루틴으로 점프하여 프로그램을 실행. 만약, 현재의 인터럽트 서비스 루틴이 실행되는 동안에 어떤 인터럽트를 허용하도록 하려면 여기서 그 인터럽트 설정을 새로 해주어야 함.

6. 인터럽트 서비스 루 틴 종료후 원래의 주프 로그램으로 복귀 CPU가 인터럽트 서비스 루틴의 실행중에 return 명령을 만나면 stack에서 return address를 되찾아 PC에 로드함으로써 원래의 위치로 되돌아옴. 이때 return address와 함께 레지스터를 저장하는 방식이면 이 레지스터들의 값도 되 찾으며, 일시적으로 인터럽트 금지 상태로 설정되었던 것 도 원상태로 되돌려 짐.

STM32F407의 구조와 기능

### STM32F407IG Interrupt & Exception

#### ●인터럽트 벡터 테이블

| Position | Priority | Type of priority | Acronym       | Description                                                                                    | Address                      |
|----------|----------|------------------|---------------|------------------------------------------------------------------------------------------------|------------------------------|
|          | -        | -                | -             | Reserved                                                                                       | 0x0000 0000                  |
|          | -3       | fixed            | Reset         | Reset                                                                                          | 0x0000 0004                  |
|          | -2       | fixed            | NMI           | Non maskable interrupt. The RCC<br>Clock Security System (CSS) is linked<br>to the NMI vector. | 0x0000 0008                  |
|          | -1       | fixed            | HardFault     | All class of fault                                                                             | 0x0000 000C                  |
|          | 0        | settable         | MemManage     | Memory management                                                                              | 0x0000 0010                  |
|          | 1        | settable         | BusFault      | Pre-fetch fault, memory access fault                                                           | 0x0000 0014                  |
|          | 2        | settable         | UsageFault    | Undefined instruction or illegal state                                                         | 0x0000 0018                  |
|          | -        | -                | -             | Reserved                                                                                       | 0x0000 001C - 0x0000<br>002B |
|          | 3        | settable         | SVCall        | System service call via SWI instruction                                                        | 0x0000 002C                  |
|          | 4        | settable         | Debug Monitor | Debug Monitor                                                                                  | 0x0000 0030                  |
|          | -        | -                | -             | Reserved                                                                                       | 0x0000 0034                  |
|          | 5        | settable         | PendSV        | Pendable request for system service                                                            | 0x0000 0038                  |
|          | 6        | settable         | SysTick       | System tick timer                                                                              | 0x0000 003C                  |

| 0  | 7  | settable | WWDG         | Window Watchdog interrupt                             | 0x0000 0040 |
|----|----|----------|--------------|-------------------------------------------------------|-------------|
| 1  | 8  | settable | PVD          | PVD through EXTI line detection interrupt             | 0x0000 0044 |
| 2  | 9  | settable | TAMP_STAMP   | Tamper and TimeStamp interrupts through the EXTI line | 0x0000 0048 |
| 3  | 10 | settable | RTC_WKUP     | RTC Wakeup interrupt through the EXTI line            | 0x0000 004C |
| 4  | 11 | settable | FLASH        | Flash global interrupt                                | 0x0000 0050 |
| 5  | 12 | settable | RCC          | RCC global interrupt                                  | 0x0000 0054 |
| 6  | 13 | settable | EXTI0        | EXTI Line0 interrupt                                  | 0x0000 0058 |
| 7  | 14 | settable | EXTI1        | EXTI Line1 interrupt                                  | 0x0000 005C |
| 8  | 15 | settable | EXTI2        | EXTI Line2 interrupt                                  | 0x0000 0060 |
| 9  | 16 | settable | EXTI3        | EXTI Line3 interrupt                                  | 0x0000 0064 |
| 10 | 17 | settable | EXTI4        | EXTI Line4 interrupt                                  | 0x0000 0068 |
| 11 | 18 | settable | DMA1_Stream0 | DMA1 Stream0 global interrupt                         | 0x0000 006C |
| 12 | 19 | settable | DMA1_Stream1 | DMA1 Stream1 global interrupt                         | 0x0000 0070 |
| 13 | 20 | settable | DMA1_Stream2 | DMA1 Stream2 global interrupt                         | 0x0000 0074 |
| 14 | 21 | settable | DMA1_Stream3 | DMA1 Stream3 global interrupt                         | 0x0000 0078 |
| 15 | 22 | settable | DMA1_Stream4 | DMA1 Stream4 global interrupt                         | 0x0000 007C |

| Position | Priority | Type of priority | Acronym            | Description                                                           | Address     |
|----------|----------|------------------|--------------------|-----------------------------------------------------------------------|-------------|
| 16       | 23       | settable         | DMA1_Stream5       | DMA1 Stream5 global interrupt                                         | 0x0000 0080 |
| 17       | 24       | settable         | DMA1_Stream6       | DMA1 Stream6 global interrupt                                         | 0x0000 0084 |
| 18       | 25       | settable         | ADC                | ADC1, ADC2 and ADC3 global<br>interrupts                              | 0x0000 0088 |
| 19       | 26       | settable         | CAN1_TX            | CAN1 TX interrupts                                                    | 0x0000 008C |
| 20       | 27       | settable         | CAN1_RX0           | CAN1 RX0 interrupts                                                   | 0x0000 0090 |
| 21       | 28       | settable         | CAN1_RX1           | CAN1 RX1 interrupt                                                    | 0x0000 0094 |
| 22       | 29       | settable         | CAN1_SCE           | CAN1 SCE interrupt                                                    | 0x0000 0098 |
| 23       | 30       | settable         | EXTI9_5            | EXTI Line[9:5] interrupts                                             | 0x0000 009C |
| 24       | 31       | settable         | TIM1_BRK_TIM9      | TIM1 Break interrupt and TIM9 global interrupt                        | 0x0000 00A0 |
| 25       | 32       | settable         | TIM1_UP_TIM10      | TIM1 Update interrupt and TIM10 global interrupt                      | 0x0000 00A4 |
| 26       | 33       | settable         | TIM1_TRG_COM_TIM11 | TIM1 Trigger and Commutation<br>interrupts and TIM11 global interrupt | 0x0000 00A8 |
| 27       | 34       | settable         | TIM1_CC            | TIM1 Capture Compare interrupt                                        | 0x0000 00AC |
| 28       | 35       | settable         | TIM2               | TIM2 global interrupt                                                 | 0x0000 00B0 |

| 29 | 36 | settable | TIM3           | TIM3 global interrupt                                  | 0x0000 00B4 |
|----|----|----------|----------------|--------------------------------------------------------|-------------|
| 30 | 37 | settable | TIM4           | TIM4 global interrupt                                  | 0x0000 00B8 |
| 31 | 38 | settable | I2C1_EV        | I <sup>2</sup> C1 event interrupt                      | 0x0000 00BC |
| 32 | 39 | settable | I2C1_ER        | I <sup>2</sup> C1 error interrupt                      | 0x0000 00C0 |
| 33 | 40 | settable | I2C2_EV        | I <sup>2</sup> C2 event interrupt                      | 0x0000 00C4 |
| 34 | 41 | settable | I2C2_ER        | I <sup>2</sup> C2 error interrupt                      | 0x0000 00C8 |
| 35 | 42 | settable | SPI1           | SPI1 global interrupt                                  | 0x0000 00CC |
| 36 | 43 | settable | SPI2           | SPI2 global interrupt                                  | 0x0000 00D0 |
| 37 | 44 | settable | USART1         | USART1 global interrupt                                | 0x0000 00D4 |
| 38 | 45 | settable | USART2         | USART2 global interrupt                                | 0x0000 00D8 |
| 39 | 46 | settable | USART3         | USART3 global interrupt                                | 0x0000 00DC |
| 40 | 47 | settable | EXTI15_10      | EXTI Line[15:10] interrupts                            | 0x0000 00E0 |
| 41 | 48 | settable | RTC_Alarm      | RTC Alarms (A and B) through EXTI<br>line interrupt    | 0x0000 00E4 |
| 42 | 49 | settable | OTG_FS WKUP    | USB On-The-Go FS Wakeup through<br>EXTI line interrupt | 0x0000 00E8 |
| 43 | 50 | settable | TIM8_BRK_TIM12 | TIM8 Break interrupt and TIM12<br>global interrupt     | 0x0000 00EC |

| Position | Priority | Type of priority | Acronym            | Description                                                           | Address     |
|----------|----------|------------------|--------------------|-----------------------------------------------------------------------|-------------|
| 44       | 51       | settable         | TIM8_UP_TIM13      | TIM8 Update interrupt and TIM13 global interrupt                      | 0x0000 00F0 |
| 45       | 52       | settable         | TIM8_TRG_COM_TIM14 | TIM8 Trigger and Commutation<br>interrupts and TIM14 global interrupt | 0x0000 00F4 |
| 46       | 53       | settable         | TIM8_CC            | TIM8 Capture Compare interrupt                                        | 0x0000 00F8 |
| 47       | 54       | settable         | DMA1_Stream7       | DMA1 Stream7 global interrupt                                         | 0x0000 00FC |
| 48       | 55       | settable         | FSMC               | FSMC global interrupt                                                 | 0x0000 0100 |
| 49       | 56       | settable         | SDIO               | SDIO global interrupt                                                 | 0x0000 0104 |
| 50       | 57       | settable         | TIM5               | TIM5 global interrupt                                                 | 0x0000 0108 |
| 51       | 58       | settable         | SPI3               | SPI3 global interrupt                                                 | 0x0000 010C |
| 52       | 59       | settable         | UART4              | UART4 global interrupt                                                | 0x0000 0110 |
| 53       | 60       | settable         | UART5              | UART5 global interrupt                                                | 0x0000 0114 |
| 54       | 61       | settable         | TIM6_DAC           | TIM6 global interrupt,<br>DAC1 and DAC2 underrun error<br>interrupts  | 0x0000 0118 |
| 55       | 62       | settable         | TIM7               | TIM7 global interrupt                                                 | 0x0000 011C |
| 56       | 63       | settable         | DMA2_Stream0       | DMA2 Stream0 global interrupt                                         | 0x0000 0120 |

|    | l I |          |              |                                             |             |
|----|-----|----------|--------------|---------------------------------------------|-------------|
| 57 | 64  | settable | DMA2_Stream1 | DMA2 Stream1 global interrupt               | 0x0000 0124 |
| 58 | 65  | settable | DMA2_Stream2 | DMA2 Stream2 global interrupt               | 0x0000 0128 |
| 59 | 66  | settable | DMA2_Stream3 | DMA2 Stream3 global interrupt               | 0x0000 012C |
| 60 | 67  | settable | DMA2_Stream4 | DMA2 Stream4 global interrupt               | 0x0000 0130 |
| 61 | 68  | settable | ETH          | Ethernet global interrupt                   | 0x0000 0134 |
| 62 | 69  | settable | ETH_WKUP     | Ethernet Wakeup through EXTI line interrupt | 0x0000 0138 |
| 63 | 70  | settable | CAN2_TX      | CAN2 TX interrupts                          | 0x0000 013C |
| 64 | 71  | settable | CAN2_RX0     | CAN2 RX0 interrupts                         | 0x0000 0140 |
| 65 | 72  | settable | CAN2_RX1     | CAN2 RX1 interrupt                          | 0x0000 0144 |
| 66 | 73  | settable | CAN2_SCE     | CAN2 SCE interrupt                          | 0x0000 0148 |
| 67 | 74  | settable | OTG_FS       | USB On The Go FS global interrupt           | 0x0000 014C |
| 68 | 75  | settable | DMA2_Stream5 | DMA2 Stream5 global interrupt               | 0x0000 0150 |
| 69 | 76  | settable | DMA2_Stream6 | DMA2 Stream6 global interrupt               | 0x0000 0154 |
| 70 | 77  | settable | DMA2_Stream7 | DMA2 Stream7 global interrupt               | 0x0000 0158 |
| 71 | 78  | settable | USART6       | USART6 global interrupt                     | 0x0000 015C |
| 72 | 79  | settable | I2C3_EV      | I <sup>2</sup> C3 event interrupt           | 0x0000 0160 |
| 73 | 80  | settable | I2C3_ER      | I <sup>2</sup> C3 error interrupt           | 0x0000 0164 |

| Position | Priority | Type of priority | Acronym        | Description                                       | Address     |
|----------|----------|------------------|----------------|---------------------------------------------------|-------------|
| 74       | 81       | settable         | OTG_HS_EP1_OUT | USB On The Go HS End Point 1 Out global interrupt | 0x0000 0168 |
| 75       | 82       | settable         | OTG_HS_EP1_IN  | USB On The Go HS End Point 1 In global interrupt  | 0x0000 016C |
| 76       | 83       | settable         | OTG_HS_WKUP    | USB On The Go HS Wakeup through<br>EXTI interrupt | 0x0000 0170 |
| 77       | 84       | settable         | OTG_HS         | USB On The Go HS global interrupt                 | 0x0000 0174 |
| 78       | 85       | settable         | DCMI           | DCMI global interrupt                             | 0x0000 0178 |
| 79       | 86       | settable         | CRYP           | CRYP crypto global interrupt                      | 0x0000 017C |
| 80       | 87       | settable         | HASH_RNG       | Hash and Rng global interrupt                     | 0x0000 0180 |
| 81       | 88       | settable         | FPU            | FPU global interrupt                              | 0x0000 0184 |

마이크로컴퓨터 구조 STM32F407의 구조와 기능

#### STM32F407IG Interrupt & Exception

#### •NVIC (Nested Vectored Interrupt Controller)

- STM32F4 시리즈의 모든 시스템 예외와 외부 인터럽트는 NVIC에 서 처리
- NVIC는 구조적으로 Cortex-M4 프로세서와 밀접하게 상호 연결되어 있으므로 빠르고 효율적인 인터럽트의 처리가 가능
- STM32F40x의 NVIC의 특징
- 82개의 마스크 가능한(maskable) 인터럽트 채널
- Cortex-M4 프로세서로부터 입력되는 16개의 인터럽트 채널
- 16 단계의 우선순위 설정이 가능 (인터럽트의 우선순위 설정에는 4 비트를 이용함)
- 빠른 인터럽트 처리 시간
- STMI32F의 NVIC는 시리즈에 따라, 모델에 따라 지원하는 인터럽 트 채널의 개수가 차이가 날뿐, 기본적인 특징이나 동작은 기본적으로 동일

### STM32F407 FSMC(Flexible static Memory Controller)



#### STM32F407 A/D Converter



- -12bit ADC
- Conversion time up to 6 Msps(Interleave Triple ADC mode를 사용할 경우)
- DMA 설정 가능
- Input Voltage Range = 0 ~3.3V



#### STM32F407 D/A Converter



#### STM32F407 DMA(Direct memory access) Controller

System implementation of the two DMA controllers (STM32F405xx/07xx and STM32F415xx/17xx)



CPU를 사용 하지 않고 데이 터를 옮겨 주는 역할, CPU의 부하를 줄여준다.

### **Operating Sequence Of DMA**

**DMA** 

2. Execute program

**FLASH CPU** Configure **SRAM DMA PERI** 

> 2. Move data from Peripheral to SRAM

#### STM32F407 Timer

#### General-purpose timer block diagram



| Timer Main Features

- 16bit or 32bit up, down, up/down auto reload counter
- Input Capture
- Output Compare
- PWM generation
- One-pulse mode
- Supports Incremental encoder

#### STM32F407 SPI(Serial Peripheral Interface)



| Signal<br>Name | Alternative Names     | 설명                        |
|----------------|-----------------------|---------------------------|
| SCLK           | SCK, CLK              | Serial Clock              |
| MOSI           | SDI, DI, SI           | Master Output Slave Input |
| MISO           | SDO, DO, SO           | Slave Output Master Input |
| SS             | nCS, CS, nSS, STE, CE | Slave Select, Chip Enable |

#### **SPI Features**

- 시리얼 하드웨어 프로토콜 의 한 종류
- 동시 양방향 통신 가능
- 주로 센서나 메모리 인터페이스에 사용
- MAX 42MHz로 데이터 전 송 가능

#### ■ STM32F407 based Micro-Computer(실습키트 구조)

