## 2.1.11 AHB/APB bridges (APB)

The two AHB/APB bridges, APB1 and APB2, provide full synchronous connections between the AHB and the two APB buses, allowing flexible selection of the peripheral frequency.

Refer to the device datasheets for more details on APB1 and APB2 maximum frequencies, and to *Table 1* for the address mapping of AHB and APB peripherals.

After each device reset, all peripheral clocks are disabled (except for the SRAM and Flash memory interface). Before using a peripheral you have to enable its clock in the RCC\_AHBxENR or RCC\_APBxENR register.

Note:

When a 16- or an 8-bit access is performed on an APB register, the access is transformed into a 32-bit access: the bridge duplicates the 16- or 8-bit data to feed the 32-bit vector.

## 2.2 Memory organization

Program memory, data memory, registers and I/O ports are organized within the same linear 4 Gbyte address space.

The bytes are coded in memory in little endian format. The lowest numbered byte in a word is considered the word's least significant byte and the highest numbered byte, the word's most significant.

For the detailed mapping of peripheral registers, please refer to the related chapters.

The addressable memory space is divided into 8 main blocks, each of 512 MB.

All the memory areas that are not allocated to on-chip memories and peripherals are considered "Reserved"). Refer to the memory map figure in the product datasheet.

## 2.3 Memory map

See the datasheet corresponding to your device for a comprehensive diagram of the memory map. *Table 1* gives the boundary addresses of the peripherals available in all STM32F4xx devices.

Table 1. STM32F4xx register boundary addresses

| Boundary address          | Peripheral                                                                                                                          | Bus  | Register map                                                                                  |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------|
| 0xA000 0000 - 0xA000 0FFF | FSMC control register<br>(STM32F405xx/07xx<br>and<br>STM32F415xx/17xx)/<br>FMC control register<br>(STM32F42xxx and<br>STM32F43xxx) | AHB3 | Section 36.6.9: FSMC register map on page 1600<br>Section 37.8: FMC register map on page 1680 |



Table 1. STM32F4xx register boundary addresses (continued)

| Boundary address          | Peripheral               | Bus   | Register map                                        |
|---------------------------|--------------------------|-------|-----------------------------------------------------|
| 0x5006 0800 - 0x5006 0BFF | RNG                      |       | Section 24.4.4: RNG register map on page 771        |
| 0x5006 0400 - 0x5006 07FF | HASH                     |       | Section 25.4.9: HASH register map on page 795       |
| 0x5006 0000 - 0x5006 03FF | CRYP                     | AHB2  | Section 23.6.13: CRYP register map on page 763      |
| 0x5005 0000 - 0x5005 03FF | DCMI                     |       | Section 15.8.12: DCMI register map on page 478      |
| 0x5000 0000 - 0x5003 FFFF | USB OTG FS               |       | Section 34.16.6: OTG_FS register map on page 1326   |
| 0x4004 0000 - 0x4007 FFFF | USB OTG HS               |       | Section 35.12.6: OTG_HS register map on page 1472   |
| 0x4002 B000 - 0x4002 BBFF | DMA2D                    |       | Section 11.5: DMA2D registers on page 352           |
| 0x4002 8000 - 0x4002 93FF | ETHERNET MAC             |       | Section 33.8.5: Ethernet register maps on page 1236 |
| 0x4002 6400 - 0x4002 67FF | DMA2                     |       | Continue 40 F 44. DAMA register man on 225          |
| 0x4002 6000 - 0x4002 63FF | DMA1                     |       | Section 10.5.11: DMA register map on page 335       |
| 0x4002 4000 - 0x4002 4FFF | BKPSRAM                  |       |                                                     |
| 0x4002 3C00 - 0x4002 3FFF | Flash interface register |       | Section 3.9: Flash interface registers              |
| 0x4002 3800 - 0x4002 3BFF | RCC                      |       | Section 7.3.24: RCC register map on page 265        |
| 0x4002 3000 - 0x4002 33FF | CRC                      | ALIDA | Section 4.4.4: CRC register map on page 115         |
| 0x4002 2800 - 0x4002 2BFF | GPIOK                    | AHB1  | Section 8.4.11: GPIO register map on page 287       |
| 0x4002 2400 - 0x4002 27FF | GPIOJ                    |       |                                                     |
| 0x4002 2000 - 0x4002 23FF | GPIOI                    |       | Section 8.4.11: GPIO register map on page 287       |
| 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 6800 - 0x4001 6BFF | LCD-TFT                  | A DDC | Section 16.7.26: LTDC register map on page 512      |
| 0x4001 5800 - 0x4001 5BFF | SAI1                     | APB2  | Section 29.17.9: SAI register map on page 963       |
| 0x4001 5400 - 0x4001 57FF | SPI6                     | ADDO  | Section 28.5.10: SPI register map on page 925       |
| 0x4001 5000 - 0x4001 53FF | SPI5                     | APB2  |                                                     |



RM0090 Rev 19 65/1751

Table 1. STM32F4xx register boundary addresses (continued)

| Boundary address          | Peripheral         | Bus  | Register map                                                                                                                                                                  |
|---------------------------|--------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4001 4800 - 0x4001 4BFF | TIM11              | APB2 | Section 19.5.12: TIM10/11/13/14 register map on page 694                                                                                                                      |
| 0x4001 4400 - 0x4001 47FF | TIM10              |      |                                                                                                                                                                               |
| 0x4001 4000 - 0x4001 43FF | TIM9               |      | Section 19.4.13: TIM9/12 register map on page 684                                                                                                                             |
| 0x4001 3C00 - 0x4001 3FFF | EXTI               |      | Section 12.3.7: EXTI register map on page 387                                                                                                                                 |
| 0x4001 3800 - 0x4001 3BFF | SYSCFG             |      | Section 9.2.8: SYSCFG register maps for STM32F405xx/07xx and STM32F415xx/17xx on page 294 and Section 9.3.8: SYSCFG register maps for STM32F42xxx and STM32F43xxx on page 301 |
| 0x4001 3400 - 0x4001 37FF | SPI4               | APB2 | Section 28.5.10: SPI register map on page 925                                                                                                                                 |
| 0x4001 3000 - 0x4001 33FF | SPI1               | APB2 | Section 28.5.10: SPI register map on page 925                                                                                                                                 |
| 0x4001 2C00 - 0x4001 2FFF | SDIO               |      | Section 31.9.16: SDIO register map on page 1074                                                                                                                               |
| 0x4001 2000 - 0x4001 23FF | ADC1 - ADC2 - ADC3 |      | Section 13.13.18: ADC register map on page 430                                                                                                                                |
| 0x4001 1400 - 0x4001 17FF | USART6             |      | Section 30.6.8: USART register map on page 1018                                                                                                                               |
| 0x4001 1000 - 0x4001 13FF | USART1             |      |                                                                                                                                                                               |
| 0x4001 0400 - 0x4001 07FF | TIM8               |      | Section 17.4.21: TIM1 and TIM8 register map on page 587                                                                                                                       |
| 0x4001 0000 - 0x4001 03FF | TIM1               |      |                                                                                                                                                                               |
| 0x4000 7C00 - 0x4000 7FFF | UART8              | APB1 | Section 30.6.8: USART register map on page 1018                                                                                                                               |
| 0x4000 7800 - 0x4000 7BFF | UART7              |      |                                                                                                                                                                               |



Table 1. STM32F4xx register boundary addresses (continued)

| Boundary address          | Peripheral          | Bus  | Register map                                             |
|---------------------------|---------------------|------|----------------------------------------------------------|
| 0x4000 7400 - 0x4000 77FF | DAC                 |      | Section 14.5.15: DAC register map on page 453            |
| 0x4000 7000 - 0x4000 73FF | PWR                 |      | Section 5.6: PWR register map on page 149                |
| 0x4000 6800 - 0x4000 6BFF | CAN2                |      | Section 32.9.5: bxCAN register map on page 1118          |
| 0x4000 6400 - 0x4000 67FF | CAN1                |      |                                                          |
| 0x4000 5C00 - 0x4000 5FFF | I2C3                |      | Section 27.6.11: I2C register map on page 872            |
| 0x4000 5800 - 0x4000 5BFF | I2C2                |      |                                                          |
| 0x4000 5400 - 0x4000 57FF | I2C1                |      |                                                          |
| 0x4000 5000 - 0x4000 53FF | UART5               |      |                                                          |
| 0x4000 4C00 - 0x4000 4FFF | UART4               |      | Section 20.6.9: USART register man on page 1019          |
| 0x4000 4800 - 0x4000 4BFF | USART3              |      | Section 30.6.8: USART register map on page 1010          |
| 0x4000 4400 - 0x4000 47FF | USART2              |      |                                                          |
| 0x4000 4000 - 0x4000 43FF | I2S3ext             |      |                                                          |
| 0x4000 3C00 - 0x4000 3FFF | SPI3 / I2S3         | APB1 | Section 29 5 10: SPI register man on page 025            |
| 0x4000 3800 - 0x4000 3BFF | SPI2 / I2S2         |      | Section 28.5.10: SPI register map on page 925            |
| 0x4000 3400 - 0x4000 37FF | I2S2ext             |      |                                                          |
| 0x4000 3000 - 0x4000 33FF | IWDG                |      | Section 21.4.5: IWDG register map on page 712            |
| 0x4000 2C00 - 0x4000 2FFF | WWDG                |      | Section 22.6.4: WWDG register map on page 719            |
| 0x4000 2800 - 0x4000 2BFF | RTC & BKP Registers |      | Section 26.6.21: RTC register map on page 836            |
| 0x4000 2000 - 0x4000 23FF | TIM14               |      | Section 19.5.12: TIM10/11/13/14 register map on page 694 |
| 0x4000 1C00 - 0x4000 1FFF | TIM13               |      |                                                          |
| 0x4000 1800 - 0x4000 1BFF | TIM12               |      | Section 19.4.13: TIM9/12 register map on page 684        |
| 0x4000 1400 - 0x4000 17FF | TIM7                |      | Section 20.4.9: TIM6 and TIM7 register map on page 707   |
| 0x4000 1000 - 0x4000 13FF | TIM6                |      |                                                          |
| 0x4000 0C00 - 0x4000 0FFF | TIM5                |      | Section 18.4.21: TIMx register map on page 648           |
| 0x4000 0800 - 0x4000 0BFF | TIM4                |      |                                                          |
| 0x4000 0400 - 0x4000 07FF | TIM3                |      |                                                          |
| 0x4000 0000 - 0x4000 03FF | TIM2                |      |                                                          |



RM0090 Rev 19 67/1751