Flexible static memory controller (FSMC) RM0440
520/2126 RM0440 Rev 4
19.6  NOR Flash/PSRAM controller
The FMC generates the appropriate signal timings to drive the following types of memories:
• Asynchronous SRAM, FRAM and ROM
–8 bits
– 16 bits
• PSRAM (CellularRAM™)
– Asynchronous mode
– Burst mode for synchronous accesses
– Multiplexed or non-multiplexed
• NOR Flash memory
– Asynchronous mode 
– Burst mode for synchronous accesses
– Multiplexed or non-multiplexed
The FMC outputs a unique chip select signal, NE[4:1], per bank. All the other signals 
(addresses, data and control) are shared.
The FMC supports a wide range of devices through a programmable timings among which:
• Programmable wait states (up to 15)
• Programmable bus turnaround cycles (up to 15)
• Programmable output enable and write enable delays (up to 15)
• Independent read and write timings and protocol to support the widest variety of 
memories and timings
• Programmable continuous clock (FMC_CLK) output.
The FMC Clock (FMC_CLK) is a submultiple of the HCLK clock. It can be delivered to the 
selected external device either during synchronous accesses only or during asynchronous 
and synchronous accesses depending on the CCKEN bit configuration in the FMC_BCR1 
register:
• If the CCLKEN bit is reset, the FMC generates the clock (CLK) only during 
synchronous accesses (Read/write transactions). 
• If the CCLKEN bit is set, the FMC generates a continuous clock during asynchronous 
and synchronous accesses. To generate the FMC_CLK continuous clock, Bank 1 must 
be configured in Synchronous mode (see Section 19.6.6: NOR/PSRAM controller 
registers). Since the same clock is used for all synchronous memories, when a 
continuous output clock is generated and synchronous accesses are performed, the 
AHB data size has to be the same as the memory data width (MWID) otherwise the 
FMC_CLK frequency is changed depending on AHB data transaction (refer to 
Section 19.6.5: Synchronous transactions for FMC_CLK divider ratio formula). 
The size of each bank is fixed and equal to 64 Mbytes. Each bank is configured through 
dedicated registers (see Section 19.6.6: NOR/PSRAM controller registers).
The programmable memory parameters include access times (see Table 123) and support 
for wait management (for PSRAM and NOR Flash accessed in Burst mode).