5 STM32CubeMX tools

5.1 External Tools

This panel is accessible from the home page. It provides an overview of the tools relevant for the STM32 product portfolio (see Figure 356):

../../../../_images/image711.webp

5.2 Compare Projects

This new feature is designed to enable the comparison of two projects, based on the same or on different microcontrollers. This tool allows users to efficiently analyze and correlate similarities and differences in IP configurations and project structure between two projects.

5.2.1 User interface of the Compare Projects tool

The user can activate this function from the Tools panel by clicking the Compare Projects field (see Figure 357), or from the home page (see Figure 358) by clicking ACCESS TO COMPARE PROJECT under Other services (even before creating any project).

Figure 357. Reaching Compare Project from the Tools panel

  • Two main panels, named Project 1 and Project 2.

    • Each field contains a “Browse” button from where we can load the desired .ioc file.

    • The check box “Use Current project” in the first panel is to use the opened project in STM32CubeMX instead of loading a saved one in the local device.

  • Three check boxes, named Project 1, Project 2, and “Show differences only”:

    • Once the second project is loaded, the Project 1 and Project 2 check boxes are checked systematically, indicating that the output table contains all the parameters of Project 1 and Project 2 (whether they are different or not).

    • If the user wants to see only the parameters that are different between the two projects, it can check “Show differences only”.

  • Refresh button: once clicked, it performs an instantiated comparison. • Export button: allows users to save or transfer the result of the comparison to an external file in Excel format.

Figure 359. User interface of the Compare Projects tool

../../../../_images/image720.webp
  1. Load the first project from the local device (Figure 360).

    • Once the first .ioc is loaded, a popup appears to indicate the need to upload the second .ioc.

  2. Load the second project (Figure 361).

    • After uploading the second .ioc file, the output is displayed in the UI (Figure 362).

    • If the user uploads the same .ioc file (having the same path) into the two fields, a popup appears to indicate that it is irrelevant to perform a comparison (Figure 363).

    • If the two projects have the same structure and the user checks “Show differences only”, only the headers of the respective tables “Target”, “Peripherals & Middleware”, and “Project Settings” are shown, no data are displayed (Figure 364).

../../../../_images/image723.webp
  1. Load a project from local and start comparing it as the current project (Project 1).

  2. Compare a newly created project (after configuration), even unsaved, with a saved project, see Figure 365.

  3. Compare a currently open project with itself (the popup blocking the comparison of two similar projects does not appear), see Figure 366:

    1. Load a the first project saved on the local as the current project (current project automatically ticked and the configuration can be modified after loading)

    2. Load the same project file from the local in the Project 2 field.

Figure 365. Compare the current non saved project with another project

../../../../_images/image732.webp

5.2.3 The output of the comparison

After starting the comparison, the following elements are added to the UI:

Target table ( Figure 367): provides a comparison of the parameters used in each project. It clearly shows differences in:

  • Part numbers

  • Number of IOs

  • Package types

  • Core configurations

  • Available flash memory sizes

The Target table is composed of 3 column:

  • Structure: a listing of the MCU parameters.

  • Project 1: the values corresponding to the MCU parameters of the first project.

  • Project 2: the values corresponding to the MCU parameters of the second project.

The user has the option to:

  • Side-by-side comparison: showing data from both projects simultaneously.

  • Individual inspection: inspect each file separately by selecting the Project 1 or Project 2 checkbox.

  • Focus on differences: exclusively view the differences between 2 projects by checking ‘Show differences only’.

The Target table offers a quick and straightforward overview of key differences between the two projects. It represents an invaluable tool for project migrations and initial hardware evaluations.

Peripherals & Middleware table ( Figure 368): displays the differences and similarities in the configuration of each peripheral or middleware used in the two projects (the subparameters and the corresponding values).

The data are presented by lines. It is composed of the following columns:

  • Category name

  • IP name

  • Mode

  • Parameters settings

  • Project 1

  • Project 2

The table includes a highlighting feature, which uses color coding to visually differentiate parameters:

  • Specific parameters for project 1 are marked in blue color

  • Specific parameters for project 2 are marked in pink color

  • The common parameters for the two projects are marked in black color

All peripheral categories are displayed collectively, with the option of sorting in alphabetical order.

Project Settings table ( Figure 369), helping the users to know the software environment required for each project, and to determine the necessary tools for ensuring project compatibility and facilitating migration. The table contains information about the firmware package used for each MCU and about the toolchain used for building each project.

It is composed of three columns:

  • Settings:

  • CustomerFirmwarePackage

  • FirmewarePackage

  • ProjectStructure

  • TargetToolchain

  • Project 1

  • Project 2

../../../../_images/image484.webp

5.2.4 Saving the comparison result of the two projects

In the user interface of the “Compare Projects” tool, there is an Export button that allows users to save the result of the comparison in an external Excel file.

By clicking the Export button, a window named Save appears to allow the user to choose a name for the resulting file and save it ( Figure 370).

The available format:

  • The result is exported into three sheets in an Excel format (Figure 371).

  • Each sheet represents a table (Target, Peripherals & Middleware, Projects Settings).

If the user wants to get only the differences in the exported file, they should click on “Show differences only”.

Figure 370. Choosing the Excel format to save the comparison result

../../../../_images/image741.webp

Figure 372. Comparison result in Excel format - Peripherals and middleware

../../../../_images/image745.webp

5.3 Power Consumption Calculator view

For an ever-growing number of embedded systems applications, power consumption is a major concern. To help minimizing it, STM32CubeMX offers the Power Consumption Calculator tab (see Figure 374), which, given a microcontroller, a battery model and a user-defined power sequence, provides the following results:

  • Average current consumption

Power consumption values can be taken from the datasheet or interpolated from a user specified bus or core frequency.

  • Battery life

  • Average DMIPs

DMIPs values are directly taken from the MCU datasheet and are neither interpolated nor extrapolated.

  • Maximum ambient temperature (TAMAX)

According to the chip internal power consumption, the package type, and a maximum junction temperature of 105 °C, the tool computes the maximum ambient temperature to ensure good operating conditions.

Current T AMAX implementation does not account for I/O consumption. For an accurate estimate, I/O consumption must be specified using the Additional Consumption field. The formula for I/O dynamic current consumption is specified in the microcontroller datasheet.

The Power Consumption Calculator view allows developers to visualize an estimate of the embedded application consumption and lower it further at each power sequence step:

  • make use of low power modes when available

  • adjust clock sources and frequencies based on the step requirements • enable only the peripherals necessary for each phase.

For each step the user can choose V BUS as possible power source instead of the battery, impact battery life. If power consumption measurements are available at different voltage levels, STM32CubeMX also proposes a choice of voltage values (see Figure 377).

An additional option, the transition checker, is available for STM32L0, STM32L1, STM32L4, STM32L4+, STM32G0, STM32G4, STM32H7 and STM32WB series. When enabled, the transition checker detects invalid transitions within the currently configured sequence. It ensures that only possible transitions are proposed to the user when a new step is added.

5.3.1 Building a power consumption sequence

The default starting view is shown in Figure 374.

Figure 374. Power Consumption Calculator default view

../../../../_images/image4890.webp

Selecting a VDD value

From this view and when multiple choices are available, the user must select a V DD value.

Selecting a battery model (optional)

Optionally, the user can select a battery model. This can also be done once the power consumption sequence is configured.

The user can select a predefined battery or choose to specify a new battery that best matches its application (see Figure 375).

Figure 375. Battery selection

../../../../_images/image4900.webp

Power sequence default view

The user can now proceed and build a power sequence.

Managing sequence steps

Steps can be reorganized within a sequence ( Add new, Delete a step, Duplicate a step, move Up or Down in the sequence) using the set of Step buttons (see Figure 376).

The user can undo or redo the last configuration actions by clicking the Undo button in the Power Consumption Calculator view or the Undo icon from the main toolbar

Figure 376. Step management functions

../../../../_images/image491.webp

Adding a step

There are two ways to add a new step:

  • Click Add in the Power Consumption panel. The New Step window opens with empty step settings.

  • Or, select a step from the sequence table and click Duplicate. A New Step window opens duplicating the step settings (see Figure 377).

Figure 377. Power consumption sequence: New Step default view

Editing a step

To edit a step, double-click it in the sequence table, this opens the Edit Step window.

Moving a step

By default, a new step is added at the end of a sequence. Click the step in the sequence table to select it and use the Up and Down buttons to move it elsewhere in the sequence. Deleting a step

Select the step to be deleted and click the Delete button.

Using the transition checker

Not all transitions between power modes are possible. The Power Consumption Calculator power menu proposes a transition checker to detect invalid transitions or restrict the sequence configuration to only valid transitions.

Enabling the transition checker option prior to sequence configuration ensures that the user will be able to select only valid transition steps.

Enabling the transition checker option on an already configured sequence will highlight the sequence with a green frame if all transitions are valid (see Figure 378), or in fuchsia if at least one transition is invalid (fuchsia frame with description of invalid step highlighted in fuchsia, see Figure 379). In the latter case, the user can click the Show log button to find out how to solve the transition issue (see Figure 380).

Figure 378. Enabling the transition checker option on an already configured sequence - All transitions valid

../../../../_images/image754.webp

5.3.2 Configuring a step in the power sequence

The step configuration is performed from the Edit Step and New Step windows. The graphical interface guides the user by forcing a predefined order for setting parameters.

Their naming may differ according to the selected MCU series. For details on each parameter, refer to glossary in Section 5.3.4 and to Appendix C, or to the electrical characteristics section of the datasheet.

The parameters are set automatically by the tool when there is only one possible value (in this case, the parameter cannot be modified and is grayed out). The tool proposes only the configuration choices relevant to the selected MCU.

To configure a new step:

  1. Click Add or Duplicate to open the New step window or double-click a step from the sequence table to open the Edit step window.

  2. Within the open step window, select in the following order:

  • The Power Mode

    Changing the Power Mode resets the whole step configuration.

  • The Peripherals


Peripherals can be selected/deselected at any time after the Power Mode is configured.

  • The Power scale


The power scale corresponds to the power consumption range (STM32L1) or the power scale (STM32F4).

Changing the Power Mode or the Power Consumption Range discards all subsequent configurations.

  • The Memory Fetch Type


  • The VDD value if multiple choices available

  • The voltage source (battery or VBUS)

  • A Clock Configuration


Changing the Clock Configuration resets the frequency choices further down.

  • When multiple choices are available, the CPU Frequency (STM32F4) and the AHB Bus Frequency/CPU Frequency(STM32L1) or, for active modes, a user specified frequency. In this case, the consumption value will be interpolated (see Using interpolation).

  1. Optionally set

    • A step duration (1 ms is the default value)

    • An additional consumption value (expressed in mA) to reflect, for example, external components used by the application (external regulator, external pull-up, LEDs or other displays). This value added to the microcontroller power consumption will impact the step overall power consumption.

  2. Once the configuration is complete, the Add button becomes active. Click it to create the step and add it to the sequence table.

Using interpolation

For steps configured for active modes (Run, Sleep), frequency interpolation is supported by selecting CPU frequency as User Defined and entering a frequency in Hz (see Figure 381).

Figure 381. Interpolated power consumption

../../../../_images/image496.webp

Importing pinout

Figure 382 illustrates the example of the ADC configuration in the Pinout view: clicking Enable IPs from Pinout in the Power Consumption Calculator view selects the ADC peripheral and GPIO A ( Figure 383).

The Enable IPs from Pinout button allows the user to automatically select the peripherals that have been configured in the Pinout view.

../../../../_images/image758.webp

Selecting/deselecting all peripherals

Clicking Enable All IPs allows the user to select all peripherals at once.

Clicking Disable All IPs removes them as contributors to the consumption.

Figure 383. Power Consumption Calculator configuration window:

ADC enabled using import pinout

../../../../_images/image498.webp

5.3.3 Managing user-defined power sequence and reviewing results

The configuration of a power sequence leads to an update of the Power Consumption Calculator view (see Figure 384):

  • The sequence table shows all steps and step parameters values. A category column indicates whether the consumption values are taken from the datasheet or are interpolated.

  • The sequence chart area shows different views of the power sequence according to a display type (e.g. plot all steps, plot low power versus run modes)

  • The results summary provides the total sequence time, the maximum ambient temperature (TAMAX), plus an estimate of the average power consumption, DMIPS, and battery lifetime provided a valid battery configuration has been selected.

Figure 384. Power Consumption Calculator view after sequence building

../../../../_images/image499.webp

Managing the whole sequence (load, save and compare)

From the power menu (see Figure 385), the current sequence can be saved, deleted or compared to a previously saved sequence that will be displayed in a dedicated popup window.

Figure 385. Sequence table management functions

../../../../_images/image500.webp

Managing the results charts and display options

In the Display area, select the type of chart to display (e.g. sequence steps, pie charts, consumption per peripherals). You can also click External Display to open the charts in dedicated windows (see Figure 386).

Right-click on the chart to access the contextual menus: Properties, Copy, Save as png picture file, Print, Zoom menus, and Auto Range to reset to the original view before zoom operations. Zooming can also be achieved by mouse selecting from left to right a zone in the chart and Zoom reset by clicking the chart and dragging the mouse to the left.

Figure 386. Power Consumption: Peripherals consumption chart

../../../../_images/image499.webp

Overview of the Results summary area

This area provides the following information (see Figure 387):

  • Total sequence time, as the sum of the sequence steps durations.

  • Average consumption, as the sum of each step consumption weighed by the step duration.

  • The average DMIPS (Dhrystone million instructions per second) based on Dhrystone benchmark, highlighting the CPU performance for the defined sequence.

  • Battery life estimation for the selected battery model, based on the average power consumption and the battery self-discharge.

  • TAMAX: highest maximum ambient temperature value found during the sequence.

Figure 387. Description of the Results area

../../../../_images/image501.webp

5.3.4 Power sequence step parameters glossary

The parameters that characterize power sequence steps are the following (refer to Appendix C: STM32 microcontrollers power consumption parameters for more details):

  • Power modes

To save energy, it is recommended to switch the microcontroller operating mode from running mode, where a maximum power is required, to a low-power mode requiring limited resources.

  • VCORE range (STM32L1) or Power scale (STM32F4)

These parameters are set by software to control the power supply range for digital peripherals.

  • Memory Fetch Type

This field proposes the possible memory locations for application C code execution. It can be either RAM, FLASH or FLASH with ART ON or OFF (only for families that feature a proprietary Adaptive real-time (ART) memory accelerator which increases the program execution speed when executing from flash memory).

The performance achieved thanks to the ART accelerator is equivalent to 0 wait state program execution from flash memory. In terms of power consumption, it is equivalent to program execution from RAM. In addition, STM32CubeMX uses the same selection choice to cover both settings, RAM and flash memory with ART ON.

  • Clock Configuration

This operation sets the AHB bus frequency or the CPU frequency that will be used for computing the microcontroller power consumption. When there is only one possible choice, the frequencies are automatically configured.

The clock configuration drop-down list allows to configure the application clocks:

  • the internal or external oscillator sources: MSI, HSI, LSI, HSE or LSE

  • the oscillator frequency

  • other determining parameters, among them PLL ON, LSE Bypass, AHB prescaler value, LCD with duty

  • Peripherals

The peripheral list shows the peripherals available for the selected power mode. The power consumption is given assuming that peripherals are only clocked (e.g. not in use by a running program). Each peripheral can be enabled or disabled, their individual power consumption is displayed in a tooltip. An overall consumption due to peripheral analog and digital parts is provided in the step Results area (see Figure 388).

Figure 388. Overall peripheral consumption

  • none (Disable All)

  • some (using peripheral dedicated checkbox)

  • all (Activate All)


  • or all from the previously defined pinout configuration (Import Pinout).

    Only the selected and enabled peripherals are taken into account when computing the power consumption.

  • Step duration

The user can change the default step duration value. When building a sequence, the user can either create steps according to the application actual power sequence or define them as a percentage spent in each mode. For example, if an application spends 30% in Run mode, 20% in Sleep and 50% in Stop, the user must configure a 3-step sequence consisting in 30 ms in Run, 20 ms in Sleep and 50 ms in Stop.

  • Additional consumption

This field allows entering an additional consumption resulting from specific user configuration (e.g. MCU providing power supply to other connected devices).

5.3.5 Battery glossary

  • Capacity (mAh)

Amount of energy that can be delivered in a single battery discharge.

  • Self-discharge (% / month)

This percentage, over a specified period, represents the loss of battery capacity when the battery is not used (open-circuit conditions), as a result of internal leakage.

  • Nominal voltage (V)

Voltage supplied by a fully charged battery.

  • Max. continuous current (mA)

This current corresponds to the maximum current that can be delivered during the battery lifetime period without damaging the battery.

  • Max. pulse current (mA)

This is the maximum pulse current that can be delivered exceptionally, for instance when the application is switched on during the starting phase.

5.3.6 SMPS feature

Some microcontrollers (e.g. STM32L496xxxxP) allow the user to connect an external switched mode power supply (SMPS) to further reduce power consumption.

For such microcontrollers, the Power Consumption Calculator tool offers the following features:

  • Selection of SMPS for the current project

From the left panel, check the Use SMPS box to use SMPS (see Figure 389). By default, ST SMPS model is used.

  • Selection of another SMPS model by clicking the Change button

This opens the SMPS database management window in which the user can add a new SMPS model (see Figure 390). The user can then select a different SMPS model for the current sequence (see Figure 391, Figure 392 and Figure 393)

  • Check for invalid SMPS transitions in the current sequence by enabling the SMPS checker

To do this, select the checkbox to enable the checker and click the Help button to open the reference state diagram (see Figure 394).

  • Configuration of SMPS mode for each step (see Figure 395)

If the SMPS checker is enabled, only the SMPS modes valid for the current step are proposed.

Figure 389. Selecting SMPS for the current project

../../../../_images/image5030.webp

Figure 390. SMPS database - Adding new SMPS models

../../../../_images/image767.webp

Figure 392. Current project configuration updated with new SMPS model

../../../../_images/image771.webp

Figure 394. SMPS transition checker and state diagram helper window

../../../../_images/image1099.webp

Figure 395. Configuring the SMPS mode for each step

../../../../_images/image5090.webp

5.3.7 Bluetooth Low-Energy ® /ZigBee ® support (STM32WB series only)

The Power Consumption tool allows the user to take into account the consumption related to the RF peripheral and corresponding Bluetooth Low-Energy functional mode, combined with the usage of the SMPS feature.

Figure 397. RF Bluetooth Low-Energy mode configuration (STM32WB series only)

../../../../_images/image5120.webp

5.3.8 Sub-GHz support (STM32WL series only)

Sub-GHz usage can be enabled from the left panel and configured to reflect the application relevant settings. For each new step enabling ZigBee, the peripheral consumption part is updated accordingly (see Figure 399).

../../../../_images/image779.webp

5.3.9 Example feature (STM32MPUs and STM32H7 dual-core only)

Under the section Sequence Examples, the PCC tool allows to access examples: each of them comes with an explanatory slide set and a ready-made sequence to load in PCC (see Figure 400).

Figure 400. Power Consumption Calculator - Example set

Figure 402. Power Consumption Calculator - Example sequence new selection

../../../../_images/image5160.webp

Note: The examples are provided for a given part number and may require adjustments when used for a different part number. Also, after loading, it is recommended to edit each step and check settings.

5.4 DDR Suite (STM32MPUs only)

DDR SDRAMs are complex high speed devices that need careful PCB design.

The STM32MP15 devices support the following DDR types:

  • LPDDR2

  • LPDDR3

  • DDR3 / DDR3L

They are specified by the JEDEC standard (standardization of interfaces, commands, timings, packages and ballout).

STM32CubeMX has been extended to provide an exhaustive tool suite for the DDR subsystem. It proposes the following key features.

  • Configuration of DDR controller and PHY registers is managed automatically based on reduced set of editable parameters.

  • DDR testing is offered based on a rich list. Tests go from basic to stress. User can also develop its own tests.

DDR configuration is accessible like the other peripherals in the Pinout & Configuration view: clicking the DDR from the component panel opens the mode and configuration panels.

DDR Test suite testing and tuning features are available from the Tools view.

The DDR suite relies on two important concepts:

  • the DDR timings as key inputs for the configuration of the DDR Controller and PHY

  • the tuning of DDR signals to compensate board design imperfections.

5.4.1 DDR configuration

STM32CubeMX allows to set DDR system parameters and JEDEC core timings. The timing parameters are available in the DDR datasheet.

DDR type, width, and density

The DDR type, width, and density parameters must be set to proceed with the DDR configuration. This can be done in the Mode panel after selecting the DDR in the Pinout & Configuration view. See Figure 403 for an example of LPDDR2 settings.

Figure 403. DDR pinout and configuration settings

Note: Contexts for DDR IP cannot be changed, DDR is tied to “Cortex-A7 nonsecure” identified as “Cortex-A7 NS” in the tool. DDR configuration

Clicking on a parameter will show additional details in the DDR configuration footer. - The DDR frequency is taken from the ‘Clock configuration’ tab, it cannot be changed in the DDR configuration.

  • The ‘Relaxed Timing’ mode is used during bring-up phase for trying relaxed key DDR timings value (one tCK added to tRC, tRCD and tRP timings)

  • Other parameters must be retrieved from the user DDR datasheet. • Some parameters are read-only: they are for information only and depend on the DDR type.

Clicking “generate code” automatically computes the DDR node of the device tree (DDR Controller and DDR PHY registers values) based on these parameters.

DDR3 configuration

For DDR3, the configuration is made easier with the selection of a Speed Bin Grade combination, instead of manually editing timing parameters.

Figure 404. DDR3 configuration

5.4.2 Connection to the target and DDR register loading

To manage DDR tests and tuning, STM32CubeMX must establish a connection with the target and more specifically with U-Boot SPL using the DDR interactive protocol:

  • the DDR interactive protocol is only available in the Basic boot scheme U-Boot SPL binary and supported over the UART4 peripheral instance

  • when U-Boot SPL detects a connection to STM32CubeMX on UART4, it stops its initialization process and accepts commands from STM32CubeMX.

There are two connection options:

  1. the U-Boot SPL binary is available in flash memory

  2. the U-Boot SPL needs to be loaded in SYSRAM because the DDR has not yet been tested nor tuned (and, consequently, is not fully functional yet).

Prerequisites

  • Installation of ST-Link USB driver to perform firmware upgrades: for Windows, latest version of STSW-LINK009, for Linux, use STSW-LINK007. Both can be downloaded from www.st.com.

  • Installation of STM32CubeProgrammer (for SYSRAM loading only): installer can be downloaded from www.st.com.

Connection to the target

The COM port must be selected to connect to the target, as indicated in Figure 405.

Figure 405. DDR Suite - Connection to target

../../../../_images/image5210.webp

Output/Log messages

STM32CubeMX outputs DDR suite related activity logs (see Figure 407) and interactive protocol communication logs (see Figure 408). They are displayed by enabling outputs from the Window menu.

../../../../_images/image790.webp

DDR register loading (optional)

Once connected in DDR interactive mode, the current DDR configuration can be loaded in

SYSRAM.

5.4.3 DDR testing

Prerequisites

To proceed with DDR testing:

  • The DDR suite must be in connected state

  • The DDR configuration must be available in memory, either with the U-Boot SPL (with DDR register file in Device Tree) or in the DDR registers (see Section 5.4.2).

DDR test list

DDR tests are part of the U-Boot SPL (see Figure 410).

Figure 410. DDR test list from U-Boot SPL

  • On STM32MP15, DDR base address is 0xC0000000 (as an example, DDR size for 4 Gbits is 0x20000000). • Loop: number of test iterations before verdict. Same test is repeated [Loop] times. Verdict OK if all tests are OK, KO otherwise.

  • Size: the byte size of the region to test. It must be a multiple of 4 (read/writes are performed on 32-bit unsigned integers), with minimal value equal to 4, and up to DDR size.

  • Pattern: the 32-bit pattern to be used for read / write operations.

The DDR Suite embeds an auto-correction feature preventing users to specify wrong values.

All tests are performed with Data cache disabled and Instruction cache enabled.

DDR test results

The test verdict is reported by the U-Boot SPL: the parameters used for the tests are recalled, along with Pass/Fail status and results details (see Figure 411). The test history is available in the output and Logs panels (see Figure 412).

../../../../_images/image797.webp

5.5 STM32CubeMX Memory Management Tool

The Memory Management Tool (MMT) displays the memory map and defines memory attributes applied in user projects opened/created in STM32CubeMX.

The tool is located in the “Tools” tab. It allows the user to declare memory regions (referred to as application regions or AppReg) at application level.

The HW constraints related to TrustZone, Memory Protection Unit, and the memory granularity are handled by MMT and made transparent to the user, so that the focus can be put on the memory regions. A linker file is generated according to the application regions declared and configured by the user.

The MMT key features are:

  • Memory map display

  • Application regions management

  • Linker file generation

MMT interacts with peripherals starting from the moment the user enters its interface:

  • Checks their settings

  • Updates other peripherals involved in memory map configuration The peripherals are updated only when the first toggle button is ON.

Figure 413. Regions settings to peripherals ON

../../../../_images/image802.webp

Figure 416. Recommendation for the configuration of MMT

../../../../_images/image804.webp

5.5.1 STM32H5, STM32U3, STM32U5, STM32WBA5, STM32WBA5M,

and STM32WBA6 with TrustZone activated

Feature: MMT usage, pinout, and configuration user interface

When the first toggle button is ON (see Figure 413), SAU, GTZC, Cortex-M33 (MPU), and FLASH configurations are under MMT control: their modes and parameters become read-only.

../../../../_images/image806.webp

Feature: MMT usage and linker script

../../../../_images/image1104.webp

MS81244V1

Linker files contents are generated as the MMT is used.

For the following features: SAU, GTZC, Cortex-M33 MPU, and FLASH, the memory handle is not under MMT control, so the user can update their setting.

Figure 418. MMT view

Figure 419. Start a project

Region information

Clicking on a particular region in the Application Regions column shows the associated details on the left hand side.

You can choose to hide the name of the reserved region, or hide the Secure/Non Secure indication close to the region name (the secure/nonsecure indication is indicated by the color).

Figure 422. Region information

../../../../_images/image826.webp

Code generation configuration

The application regions settings can be applied to peripherals on the left of the screen. The concerned peripherals are shown on the associated tooltip. This can impact their availability on the pinout screen configuration.

Figure 423. Tooltip

../../../../_images/image547.webp

Apply Application Regions settings to linker files

When this button is on, the linker scripts for the secure and non secure applications are generated, taking into account the configuration.

Figure 426. Linker files update

  • For our example, we need half of the available 128 Mbytes.

  • Press the “+” button, set a name for the region (for instance: MyExternalRAM), and put 64 MB for its size.

Figure 431. Memory assignment

../../../../_images/image5530.webp

Configuring a memory region using the left panel

With the left panel (see Figure 432) you can adjust items such as starting position and size. In this example, the added region must be adjusted: we want it to be allocated to the non secure project, and to start in the middle of the RAM. By adjusting those values, the expected results appear (see Figure 433). The color is now pink (nonsecure), and the region starts in the middle of the RAM (OctoSPI1).

Figure 432. Left panel configuration

../../../../_images/image555.webp

Setting up a middleware memory location

The application needs ThreadX. Go back to the “Pinout & Configuration” tab. Choose ThreadX, then use the Use Dynamic Allocation under Memory Configuration.

Figure 434. Middleware memory allocation

  • Go to the Pinout & Configuration tab

  • Enable ICACHE, select the Memory address remap tick box

  • Select a region and set the memory size to 64 Mbytes

  • Change the Remap address to 0x9000 0000

Figure 436. Remapping the memory

../../../../_images/image5580.webp
  • Go back to the MMT tab. Region 0x9000 0000 is named with Remapped, with the amount of RAM previously selected.

Figure 437. Remapped region is renamed

../../../../_images/image5590.webp
  • There is also a Remap – External RAM(OCTOSPI1) added at address 0x0000 0000.

Figure 438. Remapped start address

../../../../_images/image5600.webp
  • Add a new region named “MyRemappedRAM” at that address.

Figure 439. New region remapped

../../../../_images/image852.webp

Code generation

  • Go to the project manager, set a name to your project, Choose CubeIDE as a toolchain and press GENERATE CODE

  • Navigate to the generated Secure Project and open the linker definition file. Under the Memories definition you will see the defined memories with their start address and

length. This file shows only the secure regions in green. Open the nonsecure linker file and check the same location for the memory regions allocated to the nonsecure area.

Figure 442. Memory map in linker file

../../../../_images/image564.webp

5.5.3 STM32H7 single core and STM32U5 without TrustZone activated

Feature: MMT usage, pinout, and configuration user interface

When the first toggle button is ON, Cortex-M33 (MPU for STM32U5) and Cortex-M7 (MPU for STM32H7) are under MMT control (see, respectively, Figure 443 and Figure 444): modes and parameters become read-only.

The middle panel (see, respectively, Figure 445 and Figure 446 for STM32U5 and STM32H7) represents the memory, split into two columns: the left one is the memory seen by the core(s), the right one the memory set-up for the application.

For the new project created under STM32CubeMX the tool creates the default application region to generate a valid project.

Figure 443. MMT usage (STM32U5)

../../../../_images/image565.webp

Figure 444. MMT usage (STM32H7 single core)

../../../../_images/image863.webp

FMC impact on MMT

When activating FMC and SDRAM Bank1, a tab mapping (see Figure 448) is displayed, with three options:

  1. Default mapping (see Figure 449): MMT initializes as default position of SDRAM Bank1, SDRAM Bank2, and NOR PSRAM (default viewer of MMT)

  2. NOR/PSRAM bank and SDRAM Bank1/2 are swapped: MMT swaps the position of SDRAM Bank1 and NOR PSRAM Bank1 (see Figure 450 and Figure 451)

  3. SDRAM Bank2 remapped on FMC Bank2 and still accessible at default mapping: MMT updates the position of SDRAM Bank1 to be remapped on position of FMC Bank2 (see Figure 452 and Figure 453)

../../../../_images/image867.webp ../../../../_images/image870.webp ../../../../_images/image874.webp

Figure 453. After remapping

../../../../_images/image577.webp

ETH impact on MMT for STM32H7 single core

An example of MMT configuration of the ETH IP on the STM32H723VETx MCU

  1. Activate the IP ETH:

    • MMT creates three application regions within the MMT view.

    • To change the start address and the size of each region, update the ETH parameters.

  2. Press the radio button “Apply Application region Settings to Peripherals ON”, ETH will be partially under MMT control.

  3. Press the Generate Code button to generate code for both applications.

    • Apply Application Regions settings to linker files:

  4. When this button is on, the linker scripts are generated, considering the configuration.

  5. After the code generation, navigate to the generated folder:

    • Open the linker definition file.

    • Under the Memories definition you can see the memories with their start address and length, according to the configuration made in STM32CubeMX.

Figure 454. ETH MMT regions

../../../../_images/image880.webp

Figure 455. ETH configuration for STM32H723VETx MCU

../../../../_images/image885.webp

5.5.4 STM32WBxx

Feature: MMT usage, pinout, and configuration user interface

When the first toggle button is ON, Cortex-M33 is under MMT control: its modes and parameters become read-only (see Figure 457).

This example is based on an STM32WB5x MCU, so the list must contain only stm32wb5x_x binaries. The button “Refresh” is used to refresh the binaries list version in the repository of STM32Cube firmware (see Figure 459).

../../../../_images/image890.webp

Figure 459. MMT configuration for STM32WB5x

5.5.5 STM32H7 Dual-core without Trust Zone activated

Feature: MMT usage, pinout, and user interface configuration

When the first toggle button is ON, Cortex-M7_BOOT (MPU) and Cortex-M7_APPLI (MPU) are under MMT control: their modes and parameters become read-only.

../../../../_images/image887.webp

Figure 460. Cortex_M7 mode and configuration

../../../../_images/image902.webp

Feature: MMT usage and linker script

When the two radio buttons are activated, the memory management parameters are available, and the linker file content is generated according to the configuration of application regions.

  • First configuration:

../../../../_images/image905.webp
  • Second configuration:

User interface

Figure 462. Default settings

Region information

Clicking on a particular region in the Application Regions column shows the associated details on the left hand side.

STM32CubeMX automatically adds a 4 Gbytes region for the system core, even if you are not planning to use the MMT.

An example of MMT configuration of the OPENAMP Middleware on the STM32H755XIH6TR MCU

Below are the steps for configuring the MMT with OPENAMP activated on the STM32H755XIH6TR MCU.

  1. Choose a supported MCU.

Figure 463. Choose an STM32H7 dual-core product

../../../../_images/image598.webp
  1. Click on the Start Project button, then choose Yes on the “Memory Protection Unit for Cortex-M7” dialog box.

Figure 464. Region 0 added

../../../../_images/image1133.webp

Note: STM32CubeMX applies the default configuration, then adds a 4 Gbytes region called “Region 0” under the Cortex_M7 parameters. The new parameters can be checked using the Pinout and Configuration tab.

  1. Select “Tools” in the toolbar

    • Choose Memory Management.

    • Activate the Memory Management Tool support by clicking the button “Apply Application Regions Settings to Peripherals”.

Figure 465. Activate Memory Management support

Figure 466. Default setting for new application region

../../../../_images/image1135.webp
  1. Add a new region by pressing the “+” button that appears in the white space when hovering with the mouse.

../../../../_images/image920.webp
  1. Select “Context sharing (M7, M4)”, automatically another region is created with the same name, start address, and size.

../../../../_images/image921.webp
  1. Select the Project Manager tab.

  2. Give a name to the project and press the Generate Code button.

  3. OPENAMP activation

    • Configure the NVIC1 and 2 and select their related HSEM global interrupts. – Activate the Middleware OPENAMP_M4.

    • MMT creates two application regions for each core. The Master regions are defined by attribute mode.

Figure 468. Configure NVIC1 and NVIC2, and select their HSEM global interrupt

../../../../_images/image924.webp

Figure 470. OPENAMP_M4 parameters settings

../../../../_images/image928.webp
  1. Press the Generate Code button to generate the code for both applications.

Apply Application Regions settings to linker files

Figure 472. Linker files update (stm32h755xxx_flash_cm4.icf)

  • If disabled, it automatically chooses the configured memory along with the associated driver and sets the execution memory location in the linker file.

  • If enabled, the two regions and corresponding ‘export symbol’ must be added in the generated linker file.

After the code generation, navigate to the generated folder to check the linker file updates.

Example of MMT configuration of the ETH on STM32H755XIH6TR MCU

  1. Activate the IP ETH: MMT creates three application regions for each core. To change the start address and the size of each region, update the ETH parameters.

Figure 474. Configuration of ETH IP

../../../../_images/image937.webp
  1. Press the radio button “Apply Application region Settings to Peripherals ON”, ETH will be partially under MMT control.

  2. Press the Generate Code button to generate code for both applications.

Figure 476. IP configuration

  1. When this button is on, the linker scripts for the CM7 project and CM4 project are generated, considering the configuration.

  2. After the code generation, navigate to the generated folder:

    • Under the CM7 Project, open the linker definition file.

    • Under the Memories definition you can see the defined memories with their start address and length, according to the configuration made in STM32CubeMX.

Figure 477. Defined memories under the linker file (Cortex-M7)

../../../../_images/image943.webp

Feature: MMT usage, pinout, and configuration user interface

When the first toggle button is ON, Cortex-M7_BOOT (MPU) and Cortex-M7_APPLI (MPU) are under MMT control: their modes and parameters become read-only.

../../../../_images/image945.webp ../../../../_images/image947.webp

User interface

Figure 480. Default settings

Region information

Clicking on a particular region in the Application Regions column shows the associated details on the left hand side.

STM32CubeMX automatically adds a 4-Gbyte region for the system core, even if you are not planning to use the MMT.

  1. Choose a supported MCU (the following example is based on STM32H7R3A8I6).

Figure 481. Choose an STM32H7R product

../../../../_images/image619.webp
  1. Click on the Start Project button, then choose “Yes” on the “Memory Protection Unit for Cortex-M7” dialog box.

../../../../_images/image621.webp
  1. Select the Tools tab:

    1. Choose Memory Management

    2. Activate the Memory Management Tool support by clicking on “Apply Application

Regions Settings to Peripherals”

Figure 484. Activate Memory Management support

../../../../_images/image622.webp
  1. Select the Project Manager tab

  2. Give a name to the project and press the Generate Code button: a warning message is displayed.

  1. Select the Pinout and configuration tab

  2. Enable XSPI1 for the boot context and choose the ‘Single SPI’ mode

Figure 486. Configure the XSPI

../../../../_images/image624.webp
  1. Activate the Middleware EXTMEM_MANAGER for the boot context:

> MMT solves the issue

> Press the Generate Code button to generate code for both applications. The overlap message does not appear any longer.

Figure 487. EXT_MEM_MANAGER

../../../../_images/image625.webp

Code generation configuration

The application regions settings can be applied to peripherals on the left-hand side of the screen. The concerned peripherals are shown on the associated tooltip. This can impact their availability on the pinout screen configuration.

Figure 488. Tooltip

../../../../_images/image627.webp

Apply Application Regions settings to linker files

When this button is on, the linker scripts for the Boot project and Appli project are generated, taking into account the configuration.

Figure 490. Linker files update

../../../../_images/image630.webp ../../../../_images/image629.webp

EXTMEM_MANAGER when using H7Rx/H7Sx

The middleware can be used with the “Select boot code generation” disabled or enabled.

If disabled, MMT automatically chooses the configured memory along with the associated driver, and sets the execution memory location in the linker file. This is the most straightforward way of configuring an external memory.

If enabled, by activating the “Select boot code generation” you can choose “Execute in Place” or “Load and Run”

  • Execute in Place chooses and configures the memory zones

  • Load and Run lets the user choose source, destination memory, and addresses to jump to. The configuration is translated into the linker file. The user must provide the source and destination addresses.

Figure 492. EXTMEM_MANAGER “Select boot code generation” disabled

../../../../_images/image973.webp
  • Under the boot Project, open the linker definition file. • Under the Memories definition you can see the defined memories with their start address and length, according to the configuration made in STM32CubeMX.

Figure 497. Linker files

  • ECC_ON_SRAM:

    • Linked to the AXI SRAM4 region on the MMT

    • When value is “disable” or “no update”, the AXI SRAM4 region size is set to 72 KB

    • When value is set to “enable” the AXI SRAM4 region is removed

  • DTCM_AXI_SHARED:

    • Linked to the AXI SRAM3 region on the MMT

    • When set to 0 or 3, the AXI SRAM3 region size is set to 128 KB, and the size of region named DTCM is set to 64 KB

    • When set to 1, the AXI SRAM3 region size is set to 64 KB, and the size of region named DTCM is set to 128 KB

    • When set to 2, the AXI SRAM3 region is removed, and the size of region named DTCM is set to 192 KB

  • ITCM_AXI_SHARED:

    • Linked to the AXI SRAM1 region on the MMT

    • When set to 0 or 3, the AXI SRAM1 region size is set to 128 KB

    • When set to 1, the AXI SRAM1 region size is set to 64 KB

    • When set to 2, the AXI SRAM1 region size is removed

Figure 499. ECC_ON_SRAM enabled and DTCM_AXI_SHARED set to 2

../../../../_images/image637.webp

ETH impact on MMT when using H7RS/H7SX

An example of MMT configuration of the ETH IP on the STM32H7R3A8Ix MCU

  1. Activate the IP ETH:

    • MMT creates three application regions for each context.

    • To change the start address and the size of each region, update the ETH parameters.

  2. Press the radio button “Apply Application region Settings to Peripherals ON”, ETH will be partially under MMT control.

  3. Press the Generate Code button to generate code for both applications.

    • Apply Application Regions settings to linker files:

  4. When this button is on, the linker scripts are generated, considering the configuration.

  5. After the code generation, navigate to the generated folder:

    • Open the linker definition file.

    • Under the Memories definition you can see the memories with their start address and length, according to the configuration made in STM32CubeMX.

Figure 500. ETH MMT regions for STM32H7R3A8Ix

../../../../_images/image638.webp

Figure 501. ETH configuration for STM32H7R3A8Ix

../../../../_images/image985.webp

Figure 503. Defined memory regions under the linker file of the application context

../../../../_images/image990.webp

Feature: MMT usage, pinout, and configuration user interface

When the first toggle button is ON, Cortex-M0+ (MPU) is under MMT control: its modes and parameters become read-only (see Figure 504).

Apply Application Regions settings to linker files

When this button is on, the linker scripts for the project are generated, considering the configuration.

  • The REGION_ROM is a default code region used in linker.

  • The linker file copies the STM32Cube firmware linkers files and only MMT region is updated or added.

  • OTA tag is not managed by MMT and usually exists in the linker file.

Figure 506. Linker files update

../../../../_images/image644.webp

Impact on STM32WB09 RADIO

When this IP is activated, a reserved region “Blue Core Config” calculated by value of CFG_NUM_RADIO_TASKS, which varies from 1 to 128, is added.

Figure 507. Impact on RADIO (STM32WB09)

../../../../_images/image997.webp

MMT usage, pinout, and configuration of the user interface

MMT interaction with peripherals starts from the moment the user enters their interfaces:

  • Checks their settings

  • Updates other peripherals involved in the memory map configuration

The peripherals are updated only when the first toggle button is “ON” in the panel Memory Management (under STM32CubeMx Tools).

../../../../_images/image1000.webp

Feature under MMT control for secure and nonsecure domains

When the first toggle button is ON, the following features are controlled by MMT (their modes and parameters become read-only):

  • CORTEXM55-FSBL (MPU)

  • CORTEXM55_S (MPU)

  • CORTEXM55_NS (MPU)

  • SAU

  • RIF (RISAF panel)

Figure 508. Feature under MMT control (secure and nonsecure domains)

../../../../_images/image649.webp

Feature under MMT control for secure domains

When the first toggle button is ON the following features are controlled by MMT (their modes and parameters become read-only):

  • CORTEXM55-FSBL (MPU)

  • CORTEXM55_S (MPU)

  • RIF (RISAF panel)

Figure 509. Feature under MMT control (secure domains only)

../../../../_images/image650.webp

Application regions for secure and nonsecure domains

Only FSBL, CORTEX_M55_S, and CORTEX_M55_NS contexts are managed by the MMT. Each context has its own application region.

In the memory layout the CORTEX_M55_S and CORTEX_M55_NS use the same column for application regions.

Figure 510. Memory layout for secure and nonsecure domains

../../../../_images/image651.webp

Application regions for secure domains

Only FSBL and CORTEX_M55_S contexts are managed by the MMT. Each context has its own application region.

Figure 511. Memory layout for secure domains

../../../../_images/image652.webp

Description of the memory layout in STM32CubeMX user interface

The memory is split in three columns:

  1. The left one is the memory seen by the core(s)

  2. The middle one is the memory set-up for the application in FSBL context

  3. The right one is the memory set-up for the application in the Context Appli

For the new project under STM32CubeMX, the tool creates the default application region to generate a valid project.

Region information

Clicking on a particular region in the Application Regions column shows the associated details on the left-hand side.

Figure 512. Details about the clicked region in the FSBL context

Figure 513. Regions designation for secure and nonsecure domains

../../../../_images/image1019.webp

Example of using MMT with STM32N6 products

  1. Choose an MCU that supports the MMT feature (the following example is based on STM32N657Z0HxQ).

Figure 515. Project creation with an STM32N6 product

../../../../_images/image663.webp
  1. Choose the project structure, then initiate the project creation by clicking Start Project. Upon display of the TrustZone feature available dialog box, specify the domain configuration as Secure and Non-Secure domains before confirming with OK (Figure 516). Choose the second option if you intend to work exclusively within secure domains (Figure 517). STM32CubeMX applies the default configuration (RAM and FLASH regions are created in the MMT view).

Figure 516. Choosing the project structure (secure and nonsecure domains)

../../../../_images/image665.webp
  1. Configure the MMT

    1. Click on the Tools tab

    2. Choose Memory Management panel

    3. Activate the Memory Management Tool support by clicking on “Apply Application

Regions Settings to Peripherals”

Figure 518. MMT configuration (secure and nonsecure domains)

../../../../_images/image6670.webp
  1. Select the Project Manager tab

  2. Give a name to the project and press the Generate Code button

Changes in RIF resulting from MMT activation

By selecting “Apply Application region Settings to Peripherals ON,” the RISAF feature (located in RIF panel) is put partially under MMT.

The RAM and flash memory regions are configured with the same security, read/write, and privilege parameters. They are represented as a single RISAF region in the view corresponding to RISAF 2 (CPU AXI RAM0).

Figure 520. Mapping between MMT regions and RISAF memory configurations

../../../../_images/image1035.webp

Configuration of memory regions in RISAF2 (CPU AXI RAM0) tab (region 2)

Under the RISAF2 (CPU AXI RAM0) tab, region 2 has two groups of settings:

  • Fixed fields (grayed out): Region ID, Region Name, Start address Offset, Region size, and Filtering are read-only and cannot be modified.

  • Controllable fields (editable): The security and access parameters (Secure, Read, Write, and Privilege) are editable and are updated by the (MMT).

The values that MMT can set for the Read, Write, or Privilege fields are 2 (00000010b) and 0 (00000000b).

Figure 521. Setting up the memory region of RISAF2 (CPU AXI RAM0) tab

../../../../_images/image672.webp

Setting up memory subregions for RISAF 2 (CPU AXI RAM0) region 2

The Sub-Region A has two groups of settings:

  • Fixed fields (grayed out): RISAF Region ID, SubRegion name, Start address Offset, Region size, SubRegion CID (fixed to 1) are read-only and cannot be modified.

  • Controllable fields (editable): the security and access parameters (Secure, Read, Write, and Privilege are editable and are updated by the MMT.

Figure 522. Setting up memory subregions of RISAF 2 (CPU AXI RAM0) tab

Figure 523. Setting up memory regions of RISAF1 (TCM) tab

  • D-TCM is set to SYSCFG_DTCM_256K

  • I-TCM is set to SYSCFG_ITCM_256K

When adding a 256 KB application region that overlaps the ITCM and DTCM ranges:

  • The configuration of RISAF1 (TCM) remains consistent for its allocated portion.

  • Any memory belonging to that region above 0x340020000 is automatically redirected

(or split) and configured under RISAF7 (FLEXRAM). This segment starts at 0x340020000 and is treated as the beginning 0x00000000 offset of the RISAF7 region.

Figure 526. Setting up memory regions of RISAF1 (TCM) and RISAF7 (FLEXRAM) tabs

  • D-TCM to SYSCFG_DTCM_256K, I-TCM to SYSCFG_ITCM_64K, or

  • D-TCM: SYSCFG_DTCM_256K, I-TCM: SYSCFG_ITCM_128K, or

  • D-TCM: SYSCFG_DTCM_256K, I-TCM: SYSCFG_ITCM_256K

a warning appears, indicating that the flash memory region overlaps with the memory area reserved to FLEXRAM.

Figure 527. Overlap with FLEXRAM

  • Region 1: start address 0x34200000, size 1792 KB in FSBL (S) context

  • Region 2: start address 0x24200000, size 1792 KB in Appli NS context

Figure 528. Configurations of the application regions on the MMT view

  • Two RISAF regions in RISAF4 (secure region, nonsecure region), see Figure 529

  • Two RISAF regions in RISAF5 (secure region, nonsecure region), see Figure 530

  • Two RISAF regions in RISAF6 (CPU master), see Figure 531

Figure 529. Setting up memory regions of RISAF4 (NPU master 0)

  • When the IP CACHEAXI is enabled, MMT must remove the address range shown in the figures below.

../../../../_images/image1064.webp
  • Add application region in CACHEAXI range (CACHEAXI must be disabled)

../../../../_images/image1075.webp
  • MMT add in RISAF 8(CACHEAXI) the regions with start offset like in MMT view RISAF9(VENCRAM):

  • When the IP VENC is enabled MMT must delete the range illustrated in the figure below.

Figure 536. VENC enable

../../../../_images/image1189.webp
  • Adding application region in VENCRAM range(user should disable VENC when it is activated)

Figure 538. Adding regions in VERCRAM

../../../../_images/image1097.webp
  • MMT add the regions in RISAF9 (VENCRAM) with start offset like in MMT view.

On RISAF14(FMC) tab the available FMC (Flexible Memory Controller) ranges include:

  • FMC Bank 1

  • FMC SDRAM Bank 1

  • FMC SDRAM Bank 2

Configuration:

  • Configure the FMC IP

  • Add application regions in FMC ranges

Figure 540. Configurations of FMC added regions in MMT view

../../../../_images/image7070.webp

EXTMEM_MANAGER

Code generation configuration

  • The application regions settings can be applied to peripherals on the left-hand side of the screen. The concerned peripherals are shown on the associated tooltip.

  • The MMT configuration may impact their availability on the pinout screen configuration.

  • The EXTMEM_MANAGER can be used with the “Select boot code generation” parameter enabled or disabled.

    • If disabled, MMT automatically chooses the configured memory along with the associated driver and sets the execution memory location in the linker file. This is the most straightforward way of configuring an external memory.

    • If enabled, by activating the “Select boot code generation” you can choose “Execute in Place” or “Load and Run”

Figure 542. EXTMEM_MANAGER in the MMT view

  1. Go to the Pinout and Configuration tab

  2. Enable XSPI1 for the FSBL context and choose “Single SPI” mode

  3. Activate the middleware EXTMEM_MANAGER in the FSBL context

  4. Activate XSPIM and XSPI instances (XSPI1/2/3) Figure 543. Setting up the XSPI feature

../../../../_images/image7090.webp

Figure 544. Setting Select boot code generation parameter for EXTMEM_MANAGER

  1. Execute In Place (Figure 545) chooses and configures the memory zones.

  2. Load and Run (Figure 547) lets the user choose source, destination memory, and addresses to jump to.The configuration is translated into the linker file. The user must provide the source and destination address.

Figure 545. Selection of the boot system - Execute In Place

../../../../_images/image711.webp

Figure 546. Configuration of the MMT view after enabling XIP

../../../../_images/image1107.webp

Figure 548. Configuration of MMT view after choosing Load and Run as boot system

  1. Navigate to the generated project folder.

  2. In the boot Project directory, open the linker definition file (usually an .ld or .icf file).

  3. In the Memories definition section you can review the memory blocks (start addresses and lengths) that reflect your configuration settings.

Figure 549. Defined linker script for XIP

  • For secure domains:

  • Activate the ETH: MMT creates three application regions for each context Figure 551. ETH MMT regions for STM32N647L0HxQ

../../../../_images/image717.webp
  • Update the start address and the size of each region, update the ETH parameters.

  • Press the radio button “Apply Application region Settings to Peripherals ON”, to make ETH partially under MMT control (Figure 552).

  • Press the Generate Code button to generate code for both applications.

  • Apply Application Regions settings to linker files:

Figure 552. MMT view after adding ETH memory regions

  • Open the linker definition file.

Figure 553. ETH linker file (fully secure domain only)

../../../../_images/image7190.webp

Figure 554. ETH MMT regions (secure domains only)

../../../../_images/image1199.webp
  • Under the Memory definition you can see the memory parts with their start address and length, according to the configuration made in STM32CubeMX. If an application region overlaps an ETH region a warning is displayed in the MMT log.

Figure 555. Warning in case of overlap between application and ETH regions

../../../../_images/image720.webp
  • The default parameters are used for the secure context, but if the selected context is nonsecure, other nonsecure parameters are displayed.

Impact of configuring the ETH memory regions with ETH on RISAF panels

Figure 556. RISAF 3 (CPU AXI RAM1) memory regions

../../../../_images/image723.webp

5.5.9 Notification MMT/boot path (STM32H7RS and STM32H5)

After the activation of boot path and MMT, all regions of MMT are deleted and replaced by the regions of Boot path in Appli context.

In this example, we use the boot path OEM-iRoT for STM32H7RS and for STM32H5.

Figure 559. MMT/boot path (STM32H7RS)

../../../../_images/image724.webp
  • Open the linker files STM32H7S3I8KX_OEMiROT_Appli_app.ld or