1. Memory mapping[edit | edit source]
The table below gives an overview of the BSEC OTP memory mapping with useful information in the context of this Wiki reading.
OTP words 0 to 31 are called lower OTP and words 32 to 95 are called upper OTP.
Further information for the words and fields that are not explicitly described here can be found in the reference
manual.
OTP word | Bit field (size) | Name | Description |
---|---|---|---|
0 | 31-7 (25 bits) | reserved | |
5, 3 (2 bits) | is closed |
| |
6, 4, 2-0 (5 bits) | reserved | ||
1-2 | - | - | See the reference manual |
3 | 31-30 (2 bits) | HSE value |
|
29-27 (3 bits) | primary boot source |
| |
26-24 (3 bits) | secondary boot source |
| |
23-16 (8 bits) | boot source disable | If different from zero each bit disables a boot source
| |
15 (1 bit) | data cache disabling |
| |
14-7 (8 bits) | UART instances disabling | If different from zero then each bit disables an UART instance
| |
6 (1 bit) | USB DP pullup disabling |
| |
5 (1 bit) | PLL disabling |
| |
4-3 (2 bits) | SD card memory interface |
| |
2-1 (2 bits) | e•MMC™ memory interface |
| |
0 (1 bit) | QSPI non default AFmux |
| |
4 | 31-0 (32 bits) | monotonic counter | This is an anti rollback monotonic counter : on closed devices, the ROM code checks that it is less or equal to the one stored in the loaded image header.
|
5-7 | 31-28 (4 bits) | AFmux configuration - port1[3:0] | Bank id
|
27-24 (4 bits) | AFmux configuration - pin1[3:0] | Pin id | |
23-20 (4 bits) | AFmux configuration - afmux1[3:0] | AFmux value | |
19-16 (4 bits) | AFmux configuration - mode1[3:0] | Pin mode
| |
15-12 (4 bits) | AFmux configuration - port0[3:0] | Bank id
| |
11-8 (4 bits) | AFmux configuration - pin0[3:0] | Pin id | |
7-4 (4 bits) | AFmux configuration - afmux0[3:0] | AFmux value | |
3-0 (4 bits) | AFmux configuration - mode0[3:0] | Pin mode
| |
8 | 31-0 (32 bits) | reserved | |
9 | 31 (1 bit) | nand param stored in otp | FMC NAND parameters storage flag
Notes:
|
30-29 (2 bits) | nand page size[1:0] | FMC or serial NAND page size
Note: this parameter is part of NAND parameters bank1. | |
28-27 (2 bits) | nand block size[1:0] | FMC or serial NAND block size
Note: this parameter is part of NAND parameters bank1. | |
26-19 (8 bits) | nand block nb[7:0] | FMC or serial NAND number of blocks in unit of 256 blocks (nb blocks = N * 256) | |
18 (1 bit) | fmc nand width | FMC NAND width
Note: this parameter is part of NAND parameters bank1. | |
17-15 (3 bits) | fmc ecc bit nb[2:0] | FMC NAND number of ECC bits
Note: this parameter is part of NAND parameters bank1. | |
14 (1 bit) | spinand needs plane select | Serial NAND needs plane select
Note: this parameter is part of NAND parameters bank1. | |
13-8 (6 bits) | reserved | ||
7 (1 bit) | FSBL decryption priority |
| |
6 (1 bit) | SSP success |
| |
5 (1 bit) | SSP request |
| |
4 (1 bit) | eMMC 128KB boot partition support |
| |
3 (1 bit) | disable ddr power optim | Disable DDR PLL switch off sequence
| |
2 (1 bit) | disable HSE bypass detection |
| |
1 (1 bit) | disable HSE frequency autodetection |
| |
0 (1 bit) | disable ROM code traces |
| |
10 | 31-18 (14 bits) | reserved | |
17-16 (2 bits) | nand page size[1:0] | NAND parameters bank2 : FMC or serial NAND page size
| |
15-14 (2 bits) | nand block size[1:0] | NAND parameters bank2 : FMC or serial NAND block size
| |
13-6 (8 bits) | nand block nb[7:0] | NAND parameters bank2 : FMC or serial NAND number of blocks in unit of 256 blocks (nb blocks = N * 256) | |
5 (1 bit) | fmc nand width | NAND parameters bank2 : FMC NAND width
| |
4-2 (3 bits) | fmc ecc bit nb[2:0] | NAND parameters bank2 : FMC NAND number of ECC bits
| |
1 (1 bit) | spinand needs plane select | NAND parameters bank2 : serial NAND needs plane select
| |
0 (1 bit) | NAND configuration distribution | Distribution of NAND parameters bank1 and bank2.
| |
11-21 | - | - | See the reference manual |
22 | 31-8 (24 bits) | reserved | |
7-0 (8 bits) | signing key id monotonic counter | This is an key revocation monotonic counter used by the ROM to checks that it is less or equal to the active signing key id stored in the loaded image header.
| |
23 | - | - | See the reference manual |
24 | 31-0 (32 bits) | PKHTH[31:0] | The Public Key Hashes Table Hash (PKHTH) is the SHA256 hash of the 8 SHA256 hashes of the 8 ECDSA public keys usable for the Secure boot |
25 | 31-0 (32 bits) | PKHTH[63:32] | |
26 | 31-0 (32 bits) | PKHTH[95:64] | |
27 | 31-0 (32 bits) | PKHTH[128:96] | |
28 | 31-0 (32 bits) | PKHTH[159:128] | |
29 | 31-0 (32 bits) | PKHTH[191:160] | |
30 | 31-0 (32 bits) | PKHTH[223:192] | |
31 | 31-0 (32 bits) | PKHTH[255:224] | |
32-55 | - | - | See the reference manual |
56 | 31-0 (32 bits) | rma unlock passwd | Password required for RMA unlock request |
57 | 31-0 | mac1[47:16] | ETH MAC addresses for STMicroelectronics boards |
58 | 15-0 | mac1[15:0] | |
31-16 | mac2[47:32] | ||
59 | 31-0 | mac2[31:0] | |
60-91 | - | - | See the reference manual |
92 | 31-0 (32 bits) | EDMK[31:0] | The Encryption Decryption Master Key (EDMK) is used in combination with the derivation constant stored in the header file to derive the FSBL decryption key. |
93 | 31-0 (32 bits) | EDMK[63:32] | |
94 | 31-0 (32 bits) | EDMK[95:64] | |
95 | 31-0 (32 bits) | EDMK[128:96] |