aboutsummaryrefslogtreecommitdiffstats
path: root/docs/source/fsmc.rst
blob: c8f0125f07499399ff55e08b43e3e483a8565099 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
.. _fsmc:

FSMC
====

The Flexible Static Memory Controller (FSMC) is a peripheral which an
be configured to control a variety of external memory chips.

Normally, any variables in your program will be allocated space in RAM
(notable exceptions are variables marked with ``const`` or
:ref:`__FLASH__ <arm-gcc-attribute-flash>`).  Without the FSMC, this
space is limited to the amount that comes built-in to the chip's
*internal* SRAM.

The addition of the FSMC peripheral allows addtional memory to be
used.  For example, it is used on the Maple Native to interface with
the board's built-in external SRAM chip.  However, this extra memory
comes at a cost: the FSMC uses a fairly large number of GPIOs.

The FSMC peripheral is currently only available on the Maple Native.
On that board, we have broken out a wide variety of the FSMC lines, so
that experienced users can add additional external memory chips to
suit their own applications' purposes.

.. TODO Find some tutorials on SRAM or write one on FSMC, specifically
.. ones that cover: address, data, chip-select etc. pins, memory bank
.. organization

Recommended Reading
-------------------

- Wikipedia article on `SRAM <http://en.wikipedia.org/wiki/Static_random-access_memory>`_
- :ref:`ST RM0008 <maple-native-b-stdocs>` chapter on FSMC.