FTL Organization: A Bad Approach

Let's look at the direct mapped approach for FTL and its drawbacks.

We'll cover the following

Direct mapped

The simplest organization of an FTL would be something we call direct mapped. In this approach, a read to the logical page NN is mapped directly to a read of a physical page NN. A write to the logical page NN is more complicated; the FTL first has to read in the entire block that page NN is contained within; it then has to erase the block; finally, the FTL programs the old pages as well as the new one.

Problems

As you can probably guess, the direct-mapped FTL has many problems, both in terms of performance as well as reliability.

Performance

The performance problems come on each write: the device has to read in the entire block (costly), erase it (quite costly), and then program it (costly). The end result is severe write amplification (proportional to the number of pages in a block) and as a result, terrible write performance, even slower than typical hard drives with their mechanical seeks and rotational delays.

Reliability

Even worse is the reliability of this approach. If file system metadata or user file data is repeatedly overwritten, the same block is erased and programmed, over and over, rapidly wearing it out and potentially losing data. The direct mapped approach simply gives too much control over wear out to the client workload; if the workload does not spread write load evenly across its logical blocks, the underlying physical blocks containing popular data will quickly wear out.

For both reliability and performance reasons, a direct-mapped FTL is a bad idea.

Get hands-on with 1300+ tech skills courses.