Unified Address Translation for Memory-Mapped SSDs with FlashMap

  • Jian Huang ,
  • Anirudh Badam ,
  • Moinuddin K. Qureshi ,
  • Karsten Schwann

International Symposium on Computer Architecture (ISCA'15) |

Published by IEEE - Institute of Electrical and Electronics Engineers

IEEE Micro TopPicks'16 Honorable Mention

Applications can map data on SSDs into virtual memory to transparently scale beyond DRAM capacity, permitting them to leverage high SSD capacities with few code changes. Obtaining good performance for memory-mapped SSD content, however, is hard because the virtual memory layer, the file system and the flash translation layer (FTL) perform address translations, sanity and permission checks independently from each other. We introduce FlashMap, an SSD interface that is
optimized for memory-mapped SSD-files. FlashMap combines all the address translations into page tables that are used to index files and also to store the FTL-level mappings without altering the guarantees of the file system or the FTL. It uses the state in the OS memory manager and the page tables to perform sanity and permission checks respectively. By combining these layers, FlashMap reduces critical-path latency and improves DRAM caching efficiency. We find that this in-
creases performance for applications by up to 3.32x compared to state-of-the-art SSD file-mapping mechanisms. Additionally, latency of SSD accesses reduces by up to 53.2%.