Flash Layout for Off-Chip OAD

This section will describe the method for placing images in internal and external flash when using off-chip OAD.

Internal flash refers to the flash memory inside the CC13xx or CC26xx and external flash refers to an external SPI flash memory connected to the CC13xx or CC26xx via SPI.

See requirements below for off-chip OAD.

Requirements and Constraints for Off-chip OAD

In order to perform an Off-chip OAD the target system must have:

  • An off-chip flash storage as large as the application size + one external flash page to store the external flash image header. (default example will use 1MB of external flash)

  • A serial connection (SPI) is used to communicate with the off-chip flash component.

  • Free GPIO pins to interface to the external memory (i.e. 4 wires for SPI)

The following software limitations exist on the external flash:
  • Only the secondary slot is stored on the external flash.

  • The OAD images’ headers shall be stored in the first 1 MBytes of the external flash addressable space.

  • The total size of the stored images should not exceed 4 GBytes.

Note

Off-chip OAD using the BLE5-Stack has only be tested using a 1 MBytes external flash. The out-of-the-box software do not allow larger external flash size.

Internal Flash Memory Layout

The internal flash of the device contains the active user application and MCUboot. Off-chip OAD maximizes the available flash space to the user application because of its ability to store the incoming image in external flash during the download process.

Note

When using security, the BIM may use a second page depending on the page size of the device. Consult the BIM’s linker file for more information.

../_images/ditaa-0fe585d78dbb21bdb49696374885c61add8cee34.png

The user application pictured above is responsible for the following:

  • Implementing the protocol stack specific implementation of the OAD transport

  • Finding a suitable location in external flash for the image and storing its image header in the table.

External Flash Memory Layout

The off-chip flash memory on the CC13xx or CC26xx LaunchPad contains the secondary slot of the user applications. The memory map layout of the external flash is defined in flash_map_backend.h. The size of the image in external flash can be determined once the image header vector is sent over the air.

The application will round up as necessary according to the equation below:

\textrm{numExtFlashPages} = \frac{imageLen + (imageLen \bmod EFL\_PAGE\_SIZE)}{EFL\_PAGE\_SIZE}

The memory partition of the application for Off-chip OAD is depicted in below.

../_images/ditaa-591bc8f42dd9f762ccb68ff27b5bc1dc53683650.png

Warning

The convention is that image header sector 0 is reserved for the Factory Image. This region should be reserved for known good images as the BIM will revert to the factory image if there are no acceptable images in internal or external flash (user section).