Контроллер флэш-памяти - Википедия - Flash memory controller

USB-накопитель Lexar 8 ГБ - Silicon Motion SM3253L - одноканальный флэш-контроллер USB 2.0.

А контроллер флэш-памяти (или же флэш-контроллер) управляет данными, хранящимися на флэш-память и общается с компьютер или же гаджет. Контроллеры флэш-памяти могут быть рассчитаны на работу с низким рабочий цикл среды, такие как SD-карты, CompactFlash карты или другие подобные средства массовой информации для использования в цифровые фотоаппараты, КПК, мобильные телефоны, так далее. USB-накопители использовать контроллеры флэш-памяти, предназначенные для связи с персональные компьютеры сквозь USB-порт при низком рабочем цикле. Контроллеры Flash также могут быть разработаны для сред с более высоким рабочим циклом, таких как твердотельные накопители (SSD) используется в качестве хранилища данных для ноутбук компьютерные системы очищают до критически важный предприятие массивы хранения.[1]

Начальная настройка

После того, как устройство флэш-памяти изначально изготовлено, сначала используется контроллер флэш-памяти для форматирования флэш-памяти. Это обеспечивает правильную работу устройства, выявляет неисправные ячейки флеш-памяти и выделяет запасные ячейки для замены вышедших из строя ячеек в будущем. Некоторая часть запасных ячеек также используется для удержания прошивка который управляет контроллером и другими специальными функциями для конкретного запоминающего устройства. Создается структура каталогов, позволяющая контроллеру преобразовывать запросы логических секторов в физические местоположения на фактических микросхемах флэш-памяти.[1]

Чтение, письмо и стирание

Когда системе или устройству необходимо прочитать данные или записать данные во флэш-память, они будут взаимодействовать с контроллером флэш-памяти. В более простых устройствах, таких как SD-карты и USB-накопители, обычно одновременно подключено небольшое количество кристаллов флэш-памяти. Операции ограничены скоростью отдельного кристалла флэш-памяти. Напротив, высокопроизводительный твердотельный накопитель будет иметь до 100 или более кристаллов, организованных в матрицу с параллельными путями связи, чтобы обеспечить скорость, во много раз превышающую скорость одиночного кристалла флэш-памяти.[нужна цитата ]

Выравнивание износа и подбор блоков

Флэш-память может выдерживать ограниченное количество циклов стирания программ. Если конкретный блок флэш-памяти был запрограммирован и многократно стирался без записи в какие-либо другие блоки, один блок изнашивался раньше всех других блоков, тем самым преждевременно заканчивая срок службы запоминающего устройства. По этой причине в контроллерах флэш-памяти используется метод, называемый выравнивание износа для максимально равномерного распределения записей по всем блокам флэш-памяти в SSD. В идеальном сценарии это позволило бы каждому блоку быть записанным на максимальный срок, чтобы все они выходили из строя одновременно.[2]

Слой трансляции Flash (FTL) и отображение

Обычно контроллеры флэш-памяти также включают в себя «уровень трансляции флэш-памяти» (FTL), уровень ниже файловой системы, который сопоставляет адреса логических блоков (LBA) со стороны хоста или файловой системы с физическим адресом флэш-памяти (логически-физическим отображение). LBA относятся к номерам секторов и к единице отображения размером 512 байт. Все LBA, представляющие логический размер, видимый файловой системой и управляемый ею, сопоставляются с физическим расположением (ID блока, ID страницы и ID сектора) Flash. В рамках выравнивание износа и другие алгоритмы управления флэш-памятью (управление плохими блоками, управление нарушениями чтения, безопасная обработка флэш-памяти и т. д.), физическое расположение LBA может часто динамически меняться. Единицы отображения FTL могут отличаться, поэтому LBA отображаются на основе блоков, страниц или даже подстраниц. В зависимости от модели использования более тонкая детализация отображения может значительно снизить износ флэш-памяти и максимально увеличить срок службы носителей на основе флэш-памяти.[3][4][5]

Поскольку метаданные FTL занимают собственное флеш-пространство, они также нуждаются в защите в случае потери питания. Кроме того, таблица сопоставления может изнашиваться раньше других частей флэш-памяти, преждевременно прекращая срок службы устройства хранения. На корпоративных устройствах этого обычно избегают, выделяя слишком большое пространство для запчастей, хотя более надежные формы хранения, такие как MRAM был предложен и для FTL.

Вывоз мусора

После того, как каждый блок твердотельного запоминающего устройства был записан один раз, флэш-контроллеру необходимо будет вернуться к некоторым из начальных блоков, которые больше не имеют текущих данных (также называемых устаревшими блоками). Данные в этих блоках были заменены вновь записанными блоками, и теперь они ожидают стирания, чтобы в них можно было записать новые данные. Этот процесс называется вывоз мусора (GC). Все твердотельные накопители, CF-карты и другие устройства флэш-памяти будут включать определенный уровень сборки мусора. Скорость, с которой это будет делать контроллер вспышки, может варьироваться.[6]

Рекомендации

  1. ^ а б «Руководство по флэш-памяти» (PDF). kingston.com. Получено 7 марта 2013.
  2. ^ Чанг, Ли-Пин (2007-03-11). «Об эффективном выравнивании износа для крупномасштабных систем хранения с флэш-памятью». Национальный университет Чиаотунг, Синьчжу, Тайвань. CiteSeerX  10.1.1.103.4903. Цитировать журнал требует | журнал = (помощь)
  3. ^ Гудсон, Гарт; Айер, Рахул. «Компромисс дизайна на уровне Flash-перевода» (PDF). Архивировано из оригинал (PDF) 23 июня 2015 г.
  4. ^ «Понимание Flash: уровень перевода Flash». 17 сентября 2014 г.
  5. ^ Гейдрих, Сьюзен (февраль 2015 г.). «Новая архитектура управления флэш-памятью позволяет использовать MLC для промышленных хранилищ» (PDF).
  6. ^ «SSD - усиление записи, TRIM и GC» (PDF). OCZ Technology. Архивировано из оригинал (PDF) на 2012-05-26. Получено 2010-05-31.