Таблица размещения файлов

Семейство файловых систем, изначально разработанных корпорацией Microsoft.

ТОЛСТЫЙ
Разработчик(и)Microsoft , NCR , SCP , IBM , Compaq , Цифровые исследования , Novell , Caldera
Полное имяТаблица размещения файлов
Варианты8-битный FAT, FAT12, FAT16, FAT16B, FAT32, ExFAT , FATX, FAT+
Введено1977 с автономным диском BASIC-80 ( 1977 )
Идентификаторы разделовМБР / ЭБР :
  • FAT12:  ea (расширенный атрибут)0x01
  • FAT16:  еа0x040x060x0E
  • FAT32:  еа0x0B0x0C
  • БДП :EBD0A0A2-B9E5-4433-87C0-68B6B72699C7
Структуры
Содержимое каталогаСтол
Распределение файловСвязанный список
Плохие блокиКластерная маркировка
Пределы
Максимальный размер тома
  • FAT12: 32  МБ (256 МБ для кластеров по 64 КБ)
  • FAT16: 2 ГБ (4 ГБ для кластеров по 64 КБ)
  • FAT32: 2  ТБ (16 ТБ для секторов по 4 КБ )
Максимальный размер файла4 294 967 295 байт (4  ГБ − 1) с FAT16B и FAT32 [1]
Макс . кол- во файлов
  • FAT12: 4068 для  кластеров по 8 КБ
  • FAT16: 65 460 для кластеров по 32 КБ
  • FAT32: 268 173 300 для кластеров по 32 КБ
Максимальная длина имени файла8.3 имя файла или 255 символов UCS-2 при использовании LFN [nb 1]
Функции
Даты записаны
  • Дата/время изменения, дата/время создания (только DOS 7.0 и выше),
  • дата доступа (доступно только при включенном ACCDATE ), [2]
  • дата/время удаления (только с DELWATCH 2)
Диапазон дат1980-01-01 по 2099-12-31 ( 2107-12-31 )
Разрешение даты
  • 2 секунды для времени последнего изменения,
  • 10 мс на время создания,
  • 1 день для даты доступа,
  • 2 секунды на время удаления
ВилкиНе изначально
АтрибутыТолько для чтения, скрытый, системный, том, каталог, архив

Разрешения файловой системы
Прозрачное
сжатие
Прозрачное
шифрование
  • FAT12/FAT16: только для тома с DR-DOS
  • FAT32: Нет

Таблица размещения файлов ( FAT ) — файловая система , разработанная для персональных компьютеров и являвшаяся файловой системой по умолчанию для операционных систем MS-DOS и Windows 9x . [ требуется ссылка ] Первоначально разработанная в 1977 году для использования на дискетах , она была адаптирована для использования на жестких дисках и других устройствах. Увеличение емкости дисковых накопителей потребовало четырех основных вариантов: FAT12, FAT16, FAT32 и ExFAT . FAT была заменена на NTFS в качестве файловой системы по умолчанию в операционных системах Microsoft, начиная с Windows XP . [3] Тем не менее, FAT продолжает использоваться на флэш-памяти и других твердотельных картах и ​​модулях памяти (включая USB-флеш-накопители ), многих портативных и встраиваемых устройствах из-за ее совместимости и простоты внедрения. [4]

Использует

Исторический

FAT также использовалась на жестких дисках в эпоху DOS и Windows 9x . Microsoft представила NTFS с платформой Windows NT в 1993 году, но FAT оставалась стандартом для домашних пользователей до появления Windows XP в 2001 году. Windows Me была последней версией Windows , которая использовала FAT в качестве файловой системы по умолчанию.

Для дискет FAT была стандартизирована как ECMA -107 [5] и ISO / IEC  9293:1994 [6] (заменяющий ISO 9293:1987 [7] ). Эти стандарты охватывают FAT12 и FAT16 только с поддержкой коротких имен файлов 8.3 ; длинные имена файлов с VFAT были частично запатентованы. [8] В то время как FAT12 используется на дискетах, FAT16 и FAT32 обычно встречаются на более крупных носителях.

Современный

FAT используется внутри для системного раздела EFI на этапе загрузки компьютеров, совместимых с EFI . [9] Скрытые файловые системы FAT также используются в загрузочном разделе UEFI на современных ПК.

FAT по-прежнему используется в дисках, которые, как ожидается, будут использоваться несколькими операционными системами, например, в общих средах Windows, Linux и DOS. Microsoft Windows дополнительно поставляется с предустановленным инструментом для преобразования файловой системы FAT в NTFS напрямую без необходимости переписывать все файлы, хотя это не может быть легко отменено. [10] Файловая система FAT используется в съемных носителях, таких как дискеты , супердискеты , карты памяти и флэш-памяти или USB-флеш-накопители . FAT поддерживается портативными устройствами, такими как КПК , цифровые камеры , видеокамеры , медиаплееры и мобильные телефоны. [ требуется цитата ]

Файловая система DCF , принятая почти всеми цифровыми камерами с 1998 года, определяет логическую файловую систему с именами файлов 8.3 и делает использование FAT12, FAT16, FAT32 или exFAT обязательным для ее физического уровня для совместимости. [11]

Технические подробности

Файловая система использует индексную таблицу, хранящуюся на устройстве, для идентификации цепочек областей хранения данных, связанных с файлом, таблицу размещения файлов ( FAT ). FAT статически выделяется во время форматирования. Таблица представляет собой связанный список записей для каждого кластера , непрерывной области дискового хранилища. Каждая запись содержит либо номер следующего кластера в файле, либо маркер, указывающий конец файла, неиспользуемое дисковое пространство или специальные зарезервированные области диска. Корневой каталог диска содержит номер первого кластера каждого файла в этом каталоге. Затем операционная система может проходить по FAT, просматривая номер кластера каждой последующей части файла на диске как цепочку кластеров , пока не будет достигнут конец файла. Подкаталоги реализованы как специальные файлы, содержащие записи каталогов соответствующих им файлов.

Каждая запись в связанном списке FAT представляет собой фиксированное число бит: 12, 16 или 32. Максимальный размер файла или диска, к которому можно получить доступ, является произведением наибольшего числа, которое может быть сохранено в записях (за вычетом нескольких значений, зарезервированных для указания нераспределенного пространства или конца списка), и размера кластера диска. Даже если для расширения файла требуется всего один байт памяти, ему должен быть выделен целый кластер. В результате большое количество небольших файлов может привести к выделению кластеров, которые могут содержать в основном «пустые» данные для соответствия минимальному размеру кластера.

Первоначально разработанная как 8-битная файловая система, максимальное количество кластеров должно увеличиваться по мере увеличения емкости диска, поэтому количество бит, используемых для идентификации каждого кластера, возросло. Последовательные основные варианты формата FAT названы по количеству битов элемента таблицы: 12 (FAT12), 16 (FAT16) и 32 (FAT32).

Варианты

Существует несколько вариантов файловой системы FAT (например, FAT12, FAT16 и FAT32). FAT16 относится как к исходной группе файловых систем FAT с 16-битными записями кластера, так и к более поздним вариантам. «VFAT» — это необязательное расширение для длинных имен файлов, которое может работать поверх любой файловой системы FAT. Тома, использующие длинные имена файлов VFAT, могут читаться также операционными системами, не поддерживающими расширение VFAT.

Оригинальный 8-битный FAT

8-битный FAT-файл
Разработчик(и)Microsoft , NCR , SCP
Полное имя8-битная таблица размещения файлов
Введено
Пределы
Максимальный размер файла8 МБ
Детализация размера файлагранулярность записи (128 байт) [12] [13]
Максимальная длина имени файла6.3 имя файла (двоичные файлы), 9 символов (файлы ASCII) [12] [13]
Максимальная глубина каталогаНет подкаталогов
Допустимые
символы в имени файла
ASCII ( 0x00и 0xFFне допускается в качестве первого символа) [12] [13]
Функции
Даты записаныНет
АтрибутыЗащита от записи, преобразование EBCDIC , чтение после записи, двоичный (случайный, а не последовательный файл) [12] [13]

Первоначальная файловая система FAT (или структура FAT , как она изначально называлась) была разработана и реализована Марком Макдональдом [14] на основе серии дискуссий между Макдональдом и Биллом Гейтсом . [14] Он был представлен с 8-битными элементами таблицы [12] [13] [14] (и допустимыми номерами кластеров данных до 0xBF[12] [13] ) в предшественнике Microsoft Standalone Disk BASIC-80 для преемника на базе 8080 [nb 2] терминала ввода данных NCR 7200 model VI , оснащенного 8-дюймовыми (200 мм) дискетами, в 1977 [15] или 1978 году. [nb 2] В 1978 году Standalone Disk BASIC-80 был портирован на 8086 с помощью эмулятора на DEC PDP-10 [16] , поскольку в то время не было настоящих систем 8086. Файловая система FAT также использовалась в MDOS/MIDAS от Microsoft , [14] операционной системе для платформ 8080/Z80, написанной Макдональдом с 1979 года. Версия Standalone Disk BASIC поддерживала три FAT, [12] [13] [17] тогда как для MIDAS это был параметр. Как сообщается, MIDAS также был готов поддерживать 10-, 12- и 16-битные варианты FAT. В то время как размер записей каталога составлял 16 байт в Standalone Disk BASIC , [12] [13] MIDAS вместо этого занимал 32 байта на запись.

Тим Патерсон из Seattle Computer Products (SCP) впервые познакомился со структурой FAT от Microsoft, когда он помогал Бобу О'Риру адаптировать порт эмулятора Standalone Disk BASIC-86 на прототип платы процессора SCP S-100 bus 8086 во время гостевой недели в Microsoft в мае 1979 года. [16] Окончательный продукт был показан на стенде Lifeboat Associates на Национальной компьютерной конференции в Нью-Йорке [16] 4–7 июня 1979 года, где Патерсон узнал о более сложной реализации FAT в MDOS/MIDAS [14] , а Макдональд поговорил с ним о конструкции файловой системы. [15]

FAT12

FAT12
Разработчик(и)SCP , Microsoft , IBM , Цифровые исследования , Novell
Полное имя12-битная таблица размещения файлов
Введено
  • 1980-07 ( QDOS 0.10 , 16-байтовые записи каталога)
  • 1981-02-25 ( 86-DOS 0.42 , 32-байтовые записи каталога , несколько зарезервированных секторов)
  • ок. 1981–08/10 ( PC DOS 1.0 , 32-байтовые записи каталога, 1 зарезервированный сектор)
  • 1982-03-03 ( MS-DOS 1.25 , 32-байтовые записи каталога, 1 зарезервированный сектор)
Идентификаторы разделовМБР / ЭБР :
  • FAT12: еа0x01
  • БДП :EBD0A0A2-B9E5-4433-87C0-68B6B72699C7
Пределы
Максимальный размер тома
  • 16 МБ (с кластерами по 4 КБ)
  • 32 МБ (с кластерами по 8 КБ)
Максимальный размер файлаОграничено размером тома
Детализация размера файла1 байт
Макс . кол- во файлов4068 для кластеров по 8 КБ
Максимальная длина имени файлаИмя файла 8.3 с символами OEM ,
255 символов UCS-2 [примечание 1] при использовании LFN
Максимальная глубина каталога32 уровня или 66 символов (с CDS ),
60 уровней или более (без CDS)
Функции
Даты записаны
  • Измененная дата (не для 86-DOS до версии 0.42),
  • время изменения (не для PC DOS 1.0 и 86-DOS), дата/время создания (только для DOS 7.0 и выше),
  • дата доступа (доступно только при включенном ACCDATE ), [2]
  • дата/время удаления (только с DELWATCH 2)
Диапазон дат1980-01-01 по 2099-12-31 ( 2107-12-31 )
Разрешение даты
  • 2 секунды для времени последнего изменения,
  • 10 мс на время создания,
  • 1 день для даты доступа,
  • 2 секунды на время удаления
АтрибутыТолько для чтения (с DOS 2.0), скрытый , системный , томMS-DOS 1.28 и PC DOS 2.0 ), каталогMS-DOS 1.40 и PC DOS 2.0), архив (с DOS 2.0)

Разрешения файловой системы
Прозрачное
сжатие
На том, SuperStor , Stacker , DoubleSpace , DriveSpace
Прозрачное
шифрование
Только для тома с DR-DOS

В период с апреля по август 1980 года, заимствуя концепцию FAT для собственной операционной системы SCP 8086 QDOS 0.10 , [16] Тим Патерсон расширил элементы таблицы до 12 бит , [18] сократил количество FAT до двух, переопределил семантику некоторых зарезервированных значений кластера и изменил структуру диска, так что корневой каталог теперь располагался между FAT и областью данных для его реализации FAT12 . Патерсон также увеличил ограничение длины имени файла в девять символов (6.3) [12] [13] до одиннадцати символов для поддержки имен файлов 8.3 в стиле CP/M и блоков управления файлами . Формат, используемый в 8-битной файловой системе-предшественнике Microsoft Standalone Disk BASIC, не поддерживался QDOS. К августу 1980 года QDOS была переименована в 86-DOS . [19] Начиная с 86-DOS 0.42 , размер и расположение записей каталога были изменены с 16 байт до 32 байт [20] для того, чтобы добавить отметку даты файла [20] и увеличить теоретический предел размера файла сверх предыдущего предела в 16 МБ. [20] 86-DOS 1.00 стал доступен в начале 1981 года. Позже в 1981 году 86-DOS превратился в MS-DOS от Microsoft и IBM PC DOS . [14] [18] [21] Возможность чтения ранее отформатированных томов с 16-байтовыми записями каталога [20] была исключена в MS-DOS 1.20 .

FAT12 использовала 12-битные записи для адресов кластеров; некоторые значения были зарезервированы для обозначения конца цепочки кластеров, для обозначения неиспользуемых областей диска или для других целей, поэтому максимальное количество кластеров было ограничено 4078. [22] [23] Для экономии дискового пространства две 12-битные записи FAT использовали три последовательных 8-битных байта на диске, требуя манипуляций для распаковки 12-битных значений. Этого было достаточно для оригинальных дисководов и небольших жестких дисков объемом до 32 мегабайт. Версия FAT16B, доступная с DOS 3.31, поддерживала 32-битные номера секторов, и, таким образом, увеличивала предельный размер тома.

Все управляющие структуры помещались внутри первой дорожки, чтобы избежать перемещения головки во время операций чтения и записи. Любой плохой сектор в области управляющих структур делал диск непригодным для использования. Инструмент форматирования DOS полностью отклонял такие диски. Плохие сектора допускались только в области данных файла. Кластеры, содержащие плохие сектора, помечались как непригодные для использования с зарезервированным значением 0xFF7в FAT.

В то время как 86-DOS поддерживала три формата дисков (250,25 КБ, 616 КБ и 1232 КБ, с идентификаторами FAT 0xFF и 0xFE) на 8-дюймовых (200 мм) дисководах, IBM PC DOS 1.0 , выпущенная с оригинальным персональным компьютером IBM в 1981 году, поддерживала только формат дискеты на 8 секторов с отформатированной емкостью 160 КБ (FAT ID 0xFE) для односторонних 5,25-дюймовых дисководов, а PC DOS 1.1 добавила поддержку двустороннего формата с 320 КБ (FAT ID 0xFF). PC DOS 2.0 ввела поддержку форматов дискеты на 9 секторов с 180 КБ (FAT ID 0xFC) и 360 КБ (FAT ID 0xFD).

Записи каталогов 86-DOS 1.00 и PC DOS 1.0 включали только одну дату — дату последнего изменения. PC DOS 1.1 добавлял время последнего изменения. Атрибуты файлов PC DOS 1.x включали скрытый бит и системный бит, а остальные шесть битов были неопределенными. В то время DOS не поддерживал подкаталоги, но обычно на дискете было всего несколько десятков файлов .

PC XT был первым ПК с жестким диском, поставляемым IBM, и PC DOS 2.0 поддерживал этот жесткий диск с FAT12 ( FAT ID 0xF8 ). Фиксированное предположение о 8 секторах на кластер на жестких дисках фактически ограничивало максимальный размер раздела 16 МБ для секторов по 512 байт и кластеров по 4 КБ.

Блок параметров BIOS ( BPB ) также был представлен в PC DOS 2.0, и эта версия также добавила биты атрибутов «только для чтения», «архив» , «метка тома» и «каталог» для иерархических подкаталогов. [24]

В MS-DOS 3.0 появилась поддержка 5,25-дюймовых дискет высокой плотности (дескриптор носителя 0xF9) объемом 1,2 МБ, которые, в частности, имели 15 секторов на дорожку, а значит, больше места для FAT.

FAT12 по-прежнему используется на всех распространенных дискетах , включая диски емкостью 1,44 МБ и более поздние — 2,88 МБ (байт дескриптора носителя 0xF0).

Начальная FAT16

FAT16
Разработчик(и)Microsoft , IBM , Цифровые исследования , Novell
Полное имя16-битная таблица размещения файлов
(с 16-битными записями секторов)
Введено14 августа 1984 г. (ПК DOS 3.0)
1984 г. 08 г. (MS-DOS 3.0)
Идентификаторы разделовМБР / ЭБР :
  • FAT16:  еа0x04
  • БДП :EBD0A0A2-B9E5-4433-87C0-68B6B72699C7
Пределы
Максимальный размер файла4,294,967,295 байт (4 ГБ − 1)
Детализация размера файла1 байт
Макс . кол- во файлов65 536 для кластеров по 32 КБ
Максимальная длина имени файлаИмя файла 8.3 с символами OEM , 255  символов UCS-2 [примечание 1] при использовании LFN
Максимальная глубина каталога32 уровня или 66 символов (с CDS ),
60 уровней или более (без CDS)
Функции
Даты записаны
  • Дата/время изменения, дата/время создания (только DOS 7.0 и выше),
  • дата доступа (доступно только при включенном ACCDATE ), [2]
  • дата/время удаления (только с DELWATCH 2)
Диапазон дат1980-01-01 по 2099-12-31 ( 2107-12-31 )
Разрешение даты
  • 2 секунды для времени последнего изменения,
  • 10 мс на время создания,
  • 1 день для даты доступа,
  • 2 секунды на время удаления
АтрибутыТолько для чтения , скрытый , система , том , каталог , архив

Разрешения файловой системы
Прозрачное
сжатие
На том, SuperStor , Stacker , DoubleSpace , DriveSpace
Прозрачное
шифрование
Только для тома с DR-DOS

В 1984 году IBM выпустила PC AT , которому для доступа к жесткому диску объемом 20 МБ требовался PC DOS 3.0. [25] [26] Параллельно Microsoft представила MS-DOS 3.0. Адреса кластеров были увеличены до 16 бит, что позволило использовать до 65 526 кластеров на том. Однако максимально возможное количество секторов и максимальный размер раздела в 32 МБ не изменились. Хотя адреса кластеров были 16 бит, этот формат не был тем, что сегодня обычно понимается как FAT16 . Тип раздела 0x04 указывает на эту форму FAT16 с менее чем 65 536 секторами (менее 32 МБ для размера сектора 512). Преимуществом FAT16 было использование меньших кластеров, что делало использование диска более эффективным, особенно для большого количества файлов размером всего в несколько сотен байт.

Поскольку MS-DOS 3.0 форматировала все разделы размером 16–32 МБ в формате FAT16, жесткий диск размером 20 МБ, отформатированный в MS-DOS 3.0, был недоступен для MS-DOS 2.0. [27] MS-DOS 3.0 — MS-DOS 3.30 все еще могли получать доступ к разделам FAT12 размером менее 15 МБ, но требовали, чтобы все разделы размером 16–32 МБ были FAT16, и поэтому не могли получить доступ к разделам MS-DOS 2.0 в этом диапазоне размеров. MS-DOS 3.31 и выше снова могли получать доступ к разделам FAT12 размером 16–32 МБ.

Логическая секторная FAT

Реализации FAT12 и FAT16 для MS-DOS и PC DOS не могли получить доступ к разделам диска размером более 32 мегабайт. Несколько производителей разработали собственные варианты FAT в своих OEM-версиях MS-DOS. [28]

Некоторые поставщики ( AST и NEC [28] ) поддерживали восемь , вместо стандартных четырёх , записей первичных разделов в своей пользовательской расширенной главной загрузочной записи ( MBR ), и они адаптировали MS-DOS для использования более одного первичного раздела.

Другие производители обходили ограничения размера тома, налагаемые 16-битными записями секторов, увеличивая видимый размер секторов, с которыми работала файловая система. Эти логические секторы были больше (до 8192 байт), чем размер физического сектора (все еще 512 байт) на диске. Затем DOS-BIOS или системный BIOS объединяли несколько физических секторов в логические секторы для работы файловой системы.

Эти изменения были прозрачны для реализации файловой системы в ядре DOS. Базовый DOS-BIOS переводил эти логические сектора в физические сектора в соответствии с информацией о разделах и физической геометрией диска.

Недостатком этого подхода было увеличение памяти, используемой для буферизации секторов и деблокирования. Поскольку старые версии DOS не могли использовать большие логические сектора, OEM-производители ввели новые идентификаторы разделов для своих вариантов FAT, чтобы скрыть их от готовых проблем MS-DOS и PC DOS. Известные идентификаторы разделов для логических секторных FAT включают: 0x08( Commodore MS-DOS 3.x), 0x11( Leading Edge MS-DOS 3.x), 0x14(AST MS-DOS 3.x), 0x24(NEC MS-DOS 3.30 [28] ), 0x56( AT&T MS-DOS 3.x), 0xE5( Tandy MS-DOS), 0xF2( Sperry IT MS-DOS 3.x, Unisys MS-DOS 3.3 – также используется Digital Research DOS Plus 2.1). [29] Известно , что OEM-версии, такие как Toshiba MS-DOS, Wyse MS-DOS 3.2 и 3.3, [30] а также Zenith MS-DOS также использовали логическую секторизацию. [31]

Хотя эти варианты FAT нестандартны и неоптимальны, они вполне допустимы в соответствии со спецификациями самой файловой системы. [ требуется ссылка ] Поэтому, даже если проблемы по умолчанию в MS-DOS и PC DOS не смогли с ними справиться, большинство из этих специфичных для поставщика вариантов FAT12 и FAT16 можно смонтировать с помощью более гибких реализаций файловых систем в операционных системах, таких как DR-DOS, просто изменив идентификатор раздела на один из распознаваемых типов. [nb 3] Кроме того, если они больше не должны распознаваться исходными операционными системами, существующие разделы можно «преобразовать» в тома FAT12 и FAT16, более совместимые с версиями MS-DOS/PC DOS 4.0–6.3, которые не поддерживают размеры секторов, отличные от 512 байт, [32] переключившись на BPB с 32-битной записью для количества секторов, как это было введено с DOS 3.31 (см. FAT16B ниже), сохранив размер кластера и уменьшив размер логического сектора в BPB до 512 байт, в то же время увеличив количество логических секторов на кластер, зарезервированных логических секторов, общего количества логических секторов и логических секторов на FAT во столько же раз.

Параллельным развитием в MS-DOS / PC DOS, которое позволило увеличить максимально возможный размер FAT, стало введение нескольких разделов FAT на жестком диске. Чтобы разрешить использование большего количества разделов FAT совместимым образом, в PC DOS 3.2 (1986) был введен новый тип раздела, расширенный раздел (EBR), [14] который является контейнером для дополнительного раздела, называемого логическим диском . Начиная с PC DOS 3.3 (апрель 1987), есть еще один, необязательный расширенный раздел, содержащий следующий логический диск , и так далее. MBR жесткого диска может либо определять до четырех основных разделов, либо расширенный раздел в дополнение к трем основным разделам.

Окончательный FAT16

FAT16B
Разработчик(и)Compaq , Цифровые исследования , IBM , Microsoft , Novell
Полное имя16-битная таблица размещения файлов
(с 32-битными записями секторов)
Введено
Идентификаторы разделовМБР / ЭБР :
  • FAT16B:  ( LBA ), шт.0x060x0E
  • БДП :EBD0A0A2-B9E5-4433-87C0-68B6B72699C7
Пределы
Минимальный размер тома
Максимальный размер тома
  • ГБ (с кластерами по 32  КБ )
  • 4 ГБ (с кластерами по 64 КБ) (NT 4, PTS-DOS, EDR-DOS)
  • 8 ГБ (с кластерами по 128 КБ и секторами по 1 или 2 КБ) (только NT 4 и EDR-DOS)
  • 8 ГБ (с кластерами по 128 КБ и секторами по 512 байт) (только EDR-DOS)
  • 16 ГБ (с кластерами по 256 КБ и секторами по 2 или 4 КБ) (только NT 4)
Максимальный размер файла
  • 2,147,483,647 байт (2 ГБ − 1) (без LFS )
  • 4,294,967,295 байт (4 ГБ − 1) (с LFS )
  • ограничено только размером тома (с FAT16+ [33] )
Детализация размера файла1 байт
Макс . кол- во файлов65 460 для кластеров по 32 КБ
Максимальная длина имени файлаИмя файла 8.3 с символами OEM ,
255 символов UCS-2 [примечание 1] при использовании LFN
Максимальная глубина каталога32 уровня или 66 символов (с CDS ),
60 уровней или более (без CDS)
Функции
Даты записаны
  • Дата/время изменения, дата/время создания (только DOS 7.0 и выше),
  • дата доступа (доступно только при включенном ACCDATE ), [2]
  • дата/время удаления (только с DELWATCH 2)
Диапазон дат1980-01-01 по 2099-12-31 ( 2107-12-31 )
Разрешение даты
  • 2 секунды для времени последнего изменения,
  • 10 мс на время создания,
  • 1 день для даты доступа,
  • 2 секунды на время удаления
АтрибутыТолько для чтения , скрытый , система , том , каталог , архив

Разрешения файловой системы
Прозрачное
сжатие
На том, SuperStor , Stacker , DoubleSpace , DriveSpace
Прозрачное
шифрование
Только для тома с DR-DOS

В ноябре 1987 года Compaq Personal Computer DOS 3.31 (модифицированная OEM-версия MS-DOS 3.3, выпущенная Compaq вместе со своими машинами) представила то, что сегодня просто известно как формат FAT16 , с расширением 16-битного количества секторов диска до 32 бит в BPB. Хотя изменения на диске были незначительными, весь драйвер диска DOS пришлось преобразовать для использования 32-битных номеров секторов, задача усложнялась тем фактом, что он был написан на 16-битном языке ассемблера . Результат изначально назывался DOS 3.31 Large File System . Инструмент MicrosoftDSKPROBE называет тип 0x06BigFAT , [ 34] тогда как некоторые старые версии FDISKописывали его как BIGDOS . Технически он известен как FAT16B .

Так как старые версии DOS не были рассчитаны на обработку более 65 535 секторов, необходимо было ввести новый тип раздела для этого формата, чтобы скрыть его от проблем DOS до версии 3.31. Первоначальная форма FAT16 (с менее чем 65 536 секторами) имела тип раздела 0x04 . Для работы с дисками большего размера 0x06был введен тип для указания 65 536 или более секторов. В дополнение к этому драйвер диска был расширен для обработки более 65 535 секторов. Единственное другое различие между оригинальным FAT16 и более новым форматом FAT16B заключается в использовании более нового формата BPB с 32-битной записью сектора. Поэтому более новые операционные системы, поддерживающие формат FAT16B, могут работать и с оригинальным форматом FAT16 без каких-либо необходимых изменений.

Если разделы, которые будут использоваться в версиях DOS до DOS 3.31, необходимо создавать современными инструментами, единственными критериями, которые теоретически необходимо соблюдать, являются количество секторов менее 65536 и использование старого идентификатора раздела ( 0x04). Однако на практике тип 0x01и 0x04основные разделы не должны физически располагаться за пределами первых 32 МБ диска из-за других ограничений в MS-DOS 2.x, которая не могла бы справиться с ними в противном случае.

В 1988 году усовершенствование FAT16B стало более общедоступным через DR DOS  3.31, PC DOS 4.0, OS/2  1.1 и MS-DOS 4.0. Ограничение на размер раздела было продиктовано 8-битным числом секторов со знаком на кластер, которое изначально имело максимальное значение степени двойки 64. При стандартном размере сектора жесткого диска 512 байт это дает максимальный размер кластера 32 КБ, тем самым фиксируя «окончательный» предел для размера раздела FAT16 в 2 ГБ для размера сектора 512. На магнитооптических носителях, которые могут иметь сектора 1 или 2 КБ вместо 0,5 КБ, этот предельный размер пропорционально больше.

Гораздо позже Windows NT увеличила максимальный размер кластера до 64 КБ, считая количество секторов на кластер беззнаковым. Однако полученный формат не был совместим ни с одной другой реализацией FAT того времени и создавал большую внутреннюю фрагментацию . Windows 98 , SE и ME также поддерживали чтение и запись этого варианта, но его дисковые утилиты с ним не работали, а некоторые службы FCB недоступны для таких томов. Это приводит к запутанной ситуации совместимости.

До 1995 года версии DOS обращались к диску только через адресацию CHS . Когда Windows 95 (MS-DOS 7.0) представила доступ к диску LBA , разделы могли начать физически располагаться за пределами первых 8 ГБ этого диска и, таким образом, быть вне досягаемости традиционной схемы адресации CHS. Разделы, частично или полностью расположенные за барьером CHS, поэтому приходилось скрывать от операционных систем, не поддерживающих LBA, используя 0x0Eвместо этого новый тип раздела в таблице разделов. Разделы FAT16, использующие этот тип раздела, также называются FAT16X . [35] Единственное отличие по сравнению с предыдущими разделами FAT16 заключается в том, что некоторые записи геометрии, связанные с CHS, в записи BPB, а именно количество секторов на дорожку и количество головок, могут не содержать или содержать вводящие в заблуждение значения и не должны использоваться.

Количество записей корневого каталога, доступных для FAT12 и FAT16, определяется при форматировании тома и хранится в 16-битном поле. Для заданного числа RDEи размера сектора SSколичество RDSсекторов корневого каталога равно RDS = ceil((RDE × 32) / SS), и RDEобычно выбирается для заполнения этих секторов, т. е. RDE × 32 = RDS × SS. Носители FAT12 и FAT16 обычно используют 512 записей корневого каталога на недискетных носителях. Некоторые сторонние инструменты, такие как mkdosfs, позволяют пользователю устанавливать этот параметр. [36]

FAT32

FAT32
Разработчик(и)Майкрософт , Кальдера
ВведеноАвгуст 1996 г. ( Windows 95 OSR2 )
Идентификаторы разделовМБР / ЭБР :
Пределы
Минимальный размер тома
  • 32  МБ – 4,5  КБ (с 65525 кластерами и секторами по 512 байт)
  • 256 МБ – 36 КБ (с 65525 кластерами и  секторами по 4 КБ )
Максимальный размер тома
  • ТБ (с секторами по 512 байт)
  • 8 ТБ (с секторами по 2 КБ и кластерами по 32 КБ)
  • 16 ТБ (с секторами 4 КБ и кластерами 64 КБ)
Максимальный размер файла
  • 2 147 483 647 байт (2 ГиБ − 1 байт) (без LFS )
  • 4,294,967,295 байт (4 ГиБ − 1 байт) [1]LFS )
  • 274,877,906,943 байт (256 ГиБ − 1 байт) (только с FAT32+ [33] )
Детализация размера файла1 байт
Макс . кол- во файлов268,173,300 для кластеров по 32 КБ
Максимальная длина имени файлаИмя файла 8.3 с символами OEM ,
255 символов UCS-2 [примечание 1] при использовании LFN
Максимальная глубина каталога32 уровня или 66 символов (с CDS ),
60 уровней или более (без CDS)
Функции
Даты записаны
  • Дата/время изменения, дата/время создания (только DOS 7.0 и выше),
  • дата доступа (доступно только при включенном ACCDATE ), [2]
  • дата/время удаления (только с DELWATCH 2)
Диапазон дат1980-01-01 по 2099-12-31 ( 2107-12-31 )
Разрешение даты
  • 2 секунды для времени последнего изменения,
  • 10 мс на время создания,
  • 1 день для даты доступа,
  • 2 секунды на время удаления
АтрибутыТолько для чтения , скрытый , система , том , каталог , архив

Разрешения файловой системы
Частично, только с ОС DR-DOS , REAL/32 и 4690
Прозрачное
сжатие
Да

Чтобы преодолеть ограничение на размер тома FAT16, в то же время позволяя коду реального режима DOS обрабатывать этот формат, Microsoft разработала новую версию файловой системы FAT32 , которая поддерживала увеличенное количество возможных кластеров, но могла повторно использовать большую часть существующего кода, так что обычный объем памяти был увеличен менее чем на 5 КБ под DOS. [37] Значения кластера представлены 32-битными числами, из которых 28 бит используются для хранения номера кластера.

Максимальные размеры

Загрузочный сектор FAT32 использует 32-битное поле для количества секторов, ограничивая максимальный размер тома FAT32 до 2  терабайт с размером сектора 512  байт . Максимальный размер тома FAT32 составляет 16 ТБ с размером сектора 4096 байт. [38] [39] Встроенный инструмент форматирования диска оболочки Windows в Windows NT произвольно поддерживает только размеры томов до 32 ГБ, [nb 4] но Windows поддерживает чтение и запись на уже существующие большие тома FAT32, и их можно создать с помощью командной строки , PowerShell или сторонних инструментов, [41] или путем форматирования тома в системе, отличной от Windows, или в системе Windows 9x с поддержкой FAT32, а затем перенести его в систему Windows NT. Спустя 30 лет Microsoft увеличила FAT32 с 32 ГБ до 2 ТБ. [42]

Максимально возможный размер файла на томе FAT32 составляет 4  ГБ минус 1 байт, или 4 294 967 295 (2 32  − 1) байт. Это ограничение является следствием записи о 4-байтовой длине файла в таблице каталогов и также повлияет на относительно большие разделы FAT16, поддерживаемые достаточным размером сектора.

Как и FAT12 и FAT16, FAT32 не включает в себя прямую встроенную поддержку длинных имен файлов, но тома FAT32 могут опционально содержать длинные имена файлов VFAT в дополнение к коротким именам файлов точно так же, как длинные имена файлов VFAT опционально реализованы для томов FAT12 и FAT16.

Разработка

FAT32 был представлен в Windows 95 OSR2 (MS-DOS 7.1) в 1996 году, хотя для его использования требовалось переформатирование, а DriveSpace 3 (версия, поставлявшаяся с Windows 95 OSR2 и Windows 98) никогда его не поддерживала. В Windows 98 появилась утилита для преобразования существующих жестких дисков из FAT16 в FAT32 без потери данных.

В линейке Windows NT встроенная поддержка FAT32 появилась в Windows 2000. Бесплатный драйвер FAT32 для Windows NT 4.0 был доступен от Winternals , компании, позже приобретенной Microsoft. Получение драйвера из официальных источников больше невозможно. С 1998 года динамически загружаемый драйвер DRFAT32 компании Caldera мог использоваться для включения поддержки FAT32 в DR-DOS. [43] [44] Первой версией DR-DOS с собственной поддержкой доступа FAT32 и LBA стала OEM DR-DOS 7.04 в 1999 году. В том же году IMS представила собственную поддержку FAT32 с REAL/32 7.90, а IBM 4690 OS добавила поддержку FAT32 с версией 2. [45] Ahead Software предоставила еще один динамически загружаемый драйвер FAT32.EXE для DR-DOS 7.03 с Nero Burning ROM в 2004 году. IBM представила собственную поддержку FAT32 с OEM PC DOS 7.1 в 1999 году.

Для разделов FAT32 зарезервированы два типа разделов, 0x0Bи 0x0C. Последний тип также называется FAT32X , чтобы указать на использование доступа к диску LBA вместо CHS. [43] [46] [47] [48] [49] На таких разделах записи геометрии, связанные с CHS, а именно адреса секторов CHS в MBR, а также количество секторов на дорожку и количество головок в записи EBPB, могут не содержать или содержать вводящие в заблуждение значения и не должны использоваться. [50] [48] [49]

Расширения

Расширенные атрибуты

OS/2 в значительной степени зависит от расширенных атрибутов (EAs) и хранит их в скрытом файле с именем " EA␠DATA.␠SF" в корневом каталоге тома FAT12 или FAT16. Этот файл индексируется двумя ранее зарезервированными байтами в записи каталога файла (или каталога) по смещению 0x14. [51] В формате FAT32 эти байты содержат верхние 16 бит начального номера кластера файла или каталога, что делает невозможным хранение OS/2 EAs в FAT32 с использованием этого метода.

Однако сторонний драйвер устанавливаемой файловой системы FAT32 (IFS) FAT32.IFS версии 0.70 и выше от Henk Kelder & Netlabs для OS/2, eComStation и ArcaOS хранит расширенные атрибуты в дополнительных файлах с именами файлов, имеющими строку " ␠EA.␠SF", добавленную к обычному имени файла, к которому они принадлежат. Драйвер также использует байт по смещению 0x0Cв записях каталога для хранения специального байта метки, указывающего на наличие расширенных атрибутов, что помогает ускорить работу. [52] [53] (Это расширение критически несовместимо с методом FAT32+ для хранения файлов размером более 4 ГБ минус 1 на томах FAT32.) [33]

Расширенные атрибуты доступны через рабочий стол Workplace Shell , через скрипты REXX и многие системные графические интерфейсы и утилиты командной строки (например, 4OS2 ). [54]

Для размещения своей подсистемы OS/2 , Windows NT поддерживает обработку расширенных атрибутов в HPFS , NTFS , FAT12 и FAT16. Он хранит EA в FAT12, FAT16 и HPFS, используя точно такую ​​же схему, как OS/2, но не поддерживает никаких других видов ADS , которые хранятся на томах NTFS. Попытка скопировать файл с любым ADS, отличным от EA, с тома NTFS на том FAT или HPFS приводит к появлению предупреждающего сообщения с именами ADS, которые будут потеряны. Он не поддерживает метод FAT32.IFS для хранения EA на томах FAT32.

Windows 2000 и более поздние версии работают точно так же, как Windows NT, за исключением того, что игнорируют EA при копировании в FAT32 без предупреждения (но показывают предупреждение для других ADS, таких как «Macintosh Finder Info» и «Macintosh Resource Fork»).

CygwinEA␠DATA.␠SF также использует файлы " ".

Длинные имена файлов

Одной из целей пользовательского опыта для разработчиков Windows 95 была возможность использовать длинные имена файлов (LFN — до 255 кодовых единиц UTF-16 ), [nb 1] в дополнение к классическим именам файлов 8.3 (SFN). Для обратной и прямой совместимости LFN были реализованы как необязательное расширение поверх существующих структур файловой системы FAT с использованием обходного пути в способе расположения записей каталога.

Этот прозрачный метод хранения длинных имен файлов в существующих файловых системах FAT без изменения их структур данных обычно известен как VFAT (от «Virtual FAT») по названию драйвера виртуального устройства Windows 95. [ примечание 5]

Операционные системы, не поддерживающие VFAT, по-прежнему могут получать доступ к файлам под их короткими псевдонимами без ограничений; однако связанные с ними длинные имена файлов могут быть утеряны при копировании файлов с длинными именами в операционных системах, не поддерживающих VFAT.

В Windows NT поддержка длинных имен файлов VFAT началась с версии 3.5 .

Linux предоставляет драйвер файловой системы VFAT для работы с томами FAT с длинными именами файлов VFAT. Некоторое время был доступен драйвер UVFAT для обеспечения комбинированной поддержки разрешений в стиле UMSDOS с длинными именами файлов VFAT.

OS/2 добавила поддержку длинных имен файлов в FAT с помощью расширенных атрибутов (EA) до введения VFAT. Таким образом, длинные имена файлов VFAT невидимы для OS/2, а длинные имена файлов EA невидимы для Windows; поэтому опытным пользователям обеих операционных систем пришлось бы вручную переименовывать файлы.

Human68K поддерживал до 18,3 имен файлов и символов кандзи ( Shift JIS ) в фирменном варианте файловой системы FAT.

Для поддержки приложений Java , в IBM 4690 OS версии 2 на базе FlexOS была введена собственная архитектура виртуальной файловой системы (VFS) для хранения длинных имен файлов в файловой системе FAT в обратно совместимом режиме. Если эта опция включена, виртуальные имена файлов (VFN) доступны под отдельными буквами логических дисков, тогда как реальные имена файлов (RFN) остаются доступными под исходными буквами дисков. [55]

Форки и альтернативные потоки данных

Сама файловая система FAT не предназначена для поддержки альтернативных потоков данных (ADS), но некоторые операционные системы, которые сильно зависят от них, разработали различные методы для их обработки на томах FAT. Такие методы либо сохраняют дополнительную информацию в дополнительных файлах и каталогах ( классические Mac OS и macOS ), либо придают новую семантику ранее неиспользуемым полям структур данных FAT на диске ( OS/2 и Windows NT ).

Mac OS с помощью PC Exchange хранит свои различные даты, атрибуты файлов и длинные имена файлов в скрытом файле с именем " FINDER.DAT", а вилки ресурсов (обычный ADS Mac OS) в подкаталоге с именем " RESOURCE.FRK" в каждом каталоге, где они используются. Начиная с PC Exchange 2.1, они хранят длинные имена файлов Mac OS как стандартные длинные имена файлов FAT и преобразуют имена файлов FAT длиннее 31 символа в уникальные имена файлов из 31 символа, которые затем можно сделать видимыми для приложений Macintosh.

macOS хранит ветки ресурсов и метаданные (атрибуты файлов, другие ADS) с использованием формата AppleDouble в скрытом файле с именем, составленным из имени файла владельца с префиксом « ._», а Finder хранит некоторые метаданные папок и файлов в скрытом файле с именем « .DS_Store» (но обратите внимание, что Finder использует .DS_Storeдаже собственную файловую систему macOS, HFS+ ).

Разрешения и имена файлов UMSDOS

Ранние дистрибутивы Linux также поддерживали формат, известный как UMSDOS , вариант FAT с атрибутами файлов Unix (такими как длинное имя файла и права доступа), хранящимися в отдельном файле с именем " --linux-.---". UMSDOS вышел из употребления после выпуска VFAT и не включен по умолчанию в Linux, начиная с версии 2.5.7. [56] В течение некоторого времени Linux также предоставлял комбинированную поддержку разрешений в стиле UMSDOS и длинных имен файлов VFAT через UVFAT .

ЖИР+

В 2007 году открытый проект FAT+ предложил способ хранения больших файлов до 256 ГБ минус 1 байт, или 274 877 906 943 (2 38  − 1) байт, на слегка измененных и в остальном обратно совместимых томах FAT32, [33] но налагает риск того, что дисковые инструменты или реализации FAT32, не знающие об этом расширении, могут обрезать или удалить файлы, превышающие обычный предел размера файла FAT32. Поддержка FAT32+ и FAT16+ ограничена некоторыми версиями DR-DOS и недоступна в основных операционных системах. [57] (Это расширение критически несовместимо с /EASопцией метода FAT32.IFS для хранения расширенных атрибутов OS/2 на томах FAT32.)

Производные

Турбо ЖИР

В своей файловой системе NetWare File System ( NWFS ) Novell реализовала сильно модифицированный вариант файловой системы FAT для операционной системы NetWare . Для больших файлов она использовала функцию повышения производительности Turbo FAT .

ФАТХ

FATX — это семейство файловых систем, разработанное для жестких дисков и карт памяти игровой консоли Xbox компании Microsoft , [58] [59] представленное в 2001 году.

Несмотря на то, что базовые идеи конструкции FATX16 и FATX32 напоминают FAT16 и FAT32, дисковые структуры FATX16 и FATX32 упрощены, но принципиально несовместимы с обычными файловыми системами FAT16 и FAT32, что делает невозможным монтирование таких томов обычными драйверами файловой системы FAT.

Незагрузочный сектор суперблока имеет размер 4 КБ и содержит 18-байтовую структуру, похожую на BPB, полностью отличную от обычных BPB . Кластеры обычно имеют размер 16 КБ, и на Xbox есть только одна копия FAT. Записи каталога имеют размер 64 байта вместо обычных 32 байт . Файлы могут иметь имена длиной до 42 символов с использованием набора символов OEM и иметь размер до 4 ГБ минус 1 байт. Временные метки на диске содержат даты и время создания, изменения и доступа, но отличаются от FAT: в FAT эпоха1980 ; в FATX эпоха — 2000. На Xbox 360 эпоха — 1980. [60]

эксFAT

exFAT — файловая система, представленная в Windows Embedded CE 6.0 в ноябре 2006 года и перенесенная в семейство Windows NT с Vista Service Pack 1 и Windows XP Service Pack 3 (или отдельной установкой Windows XP Update KB955704). Она основана на архитектуре File Allocation Table, но несовместима, является частной собственностью и защищена патентами. [61]

exFAT предназначен для использования на флэш-накопителях и картах памяти , таких как SDXC и Memory Stick XC , где в противном случае используется FAT32. Поставщики обычно предварительно форматируют карты SDXC с его помощью. Его главным преимуществом является превышение ограничения на размер файла в 4 ГБ, поскольку ссылки на размер файла хранятся восемью, а не четырьмя байтами, что увеличивает ограничение до 2 64  − 1 байта.

Графический интерфейс и утилиты форматирования командной строки Microsoft предлагают его в качестве альтернативы NTFS (и, для меньших разделов, FAT16B и FAT32). Тип раздела MBR (тот же, что используется для IFS , HPFS и NTFS). Логическая геометрическая информация, расположенная в VBR, хранится в формате, не напоминающем ни один из видов BPB.0x07

В начале 2010 года файловая система была подвергнута обратному проектированию Институтом SANS . [62] 28 августа 2019 года Microsoft опубликовала техническую спецификацию exFAT, чтобы ее можно было использовать в ядре Linux и других операционных системах. [63]

Патенты

Microsoft подала заявку и получила ряд патентов на ключевые части файловой системы FAT в середине 1990-х годов. Все четыре относятся к длинным расширениям имен файлов FAT, впервые появившимся в Windows 95 : патент США 5,579,517, [64] патент США 5,745,902, [65] патент США 5,758,352, [66] патент США 6,286,013 (все истекли в 2013 году). [67]

3 декабря 2003 года Microsoft объявила [68] , что будет предлагать лицензии на использование своей спецификации FAT и «связанной с ней интеллектуальной собственности» по цене роялти в размере 0,25 долл. США за проданную единицу, с максимальным роялти в размере 250 000 долл. США за лицензионное соглашение. [69] С этой целью Microsoft сослалась на четыре патента на файловую систему FAT в качестве основания своих претензий на интеллектуальную собственность.

В спецификации EFI FAT32 [9] Microsoft специально предоставляет ряд прав, которые многие читатели интерпретировали как разрешение поставщикам операционных систем внедрять FAT. [70] Патенты, не принадлежащие Microsoft, влияющие на FAT, включают: патент США 5,367,671, относящийся к расширенным атрибутам объектов OS/2 (истек в 2011 году). [71]

Проблемы и судебные иски

В 2004 году Патентный фонд США (PUBPAT) представил в Патентное и товарное ведомство США (USPTO) доказательства, оспаривающие действительность патента США 5 579 517, [64] включая ссылки на предшествующий уровень техники от Xerox и IBM. [72] Патентное ведомство США начало расследование и в итоге отклонило все требования патента. [73] В следующем году Патентное ведомство США также объявило, что после процесса повторной экспертизы оно подтвердило отклонение патента 517 и дополнительно признало патент США 5 758 352 [66] недействительным на том основании, что патент имел неправильных правообладателей.

Однако в 2006 году USPTO постановило, что особенности реализации системы FAT компанией Microsoft являются «новыми и неочевидными», отменив оба предыдущих решения и оставив патенты в силе. [74]

В феврале 2009 года Microsoft подала иск о нарушении патентных прав против TomTom , утверждая, что продукция производителя устройств нарушает патенты, связанные с длинными именами файлов VFAT. Поскольку некоторые продукты TomTom основаны на Linux , это был первый случай, когда Microsoft попыталась применить свои патенты против платформы Linux. [75] Иск был урегулирован во внесудебном порядке в следующем месяце соглашением о том, что Microsoft получит доступ к четырем патентам TomTom, что TomTom прекратит поддержку длинных имен файлов VFAT в своих продуктах, и что взамен Microsoft не будет подавать иски против TomTom в течение пятилетнего срока действия соглашения об урегулировании. [76]

В октябре 2010 года Microsoft подала иск о нарушении патентных прав против Motorola, утверждая, что несколько патентов (включая два патента VFAT) не были лицензированы для использования в операционной системе Android . [77] Они также подали жалобу в ITC . [78] Разработчики программного обеспечения с открытым исходным кодом разработали методы, призванные обойти патенты Microsoft. [79] [80]

В 2013 году патент EP0618540 «Общее пространство имен для длинных и коротких имен файлов» (истек с 2014 года [81] ) был признан недействительным в Германии. [82] После того, как апелляция была отозвана, это решение вступило в силу 28 октября 2015 года. [83]

Смотрите также

Примечания

  1. ^ abcdef Начиная с Windows 2000 , Microsoft Windows использует UTF-16 вместо UCS-2 для внутреннего "Unicode" . В UTF-16 "символ" (кодовая точка) может занимать две кодовые единицы.
  2. ^ ab Источники расходятся в отношении первого терминала ввода данных NCR, интегрирующего поддержку файловой системы FAT. По словам Стивена Мэйнса и Пола Эндрюса, «Гейтса», разработка велась для NCR 8200 в конце 1977 года, ошибочно классифицированного как основанное на дискете обновление NCR 7200 , которое было выпущено в 1975-11 годах ( модели I и IV ) и было построено на базе 8-битного процессора Intel 8080 , но было основано только на кассетах. Однако NCR Century 8200 был 16-битным мини-компьютером, к которому можно было подключить несколько терминалов ввода данных. Марк Макдональд даже вспомнил NCR 8500 , мэйнфрейм серии Criterion, который также можно исключить. Анонсированная в 1977-10 для поставки в 1978-02, NCR также представила серию NCR I-8100 , включая модели NCR I-8130 и NCR I-8150 на базе 8080 для систем малого бизнеса с двумя дискетами. Другие источники указывают, что либо сама серия NCR 7200, либо последовавшая за ней серия были фактической целевой платформой. NCR Basic Plus 6 (основанная на Microsoft Extended BASIC-80 ) стала доступна для кассетной модели NCR 7200 VI в Q1/1977. Серия NCR 7500 была выпущена в 1978 году на основе аналогичного оборудования 8080, но теперь включающая модели NCR 7520 и 7530 с 8-дюймовыми дискетами. NCR Basic +6 , предшественник или адаптация Standalone Disk BASIC-80, был доступен для них по крайней мере с 1979 года. Один источник утверждает, что существовал специальный вариант модели NCR 7200 с двумя 8-дюймовыми дискетами и Microsoft BASIC, который был импортирован NCR Sydney в Австралию по крайней мере.
  3. ^ DR-DOS может загружаться с носителей с логическими секторами FAT12/FAT16 с размером логического сектора до 1024 байт.
  4. ^ Это решение было принято застройщиком, который предполагал, что его решение будет пересмотрено позже, чего так и не произошло. [40]
  5. ^ Драйвер под названием VFAT появился еще до Windows 95 , в Windows for Workgroups 3.11, но эта старая версия использовалась только для реализации 32-разрядного доступа к файлам и не поддерживала длинные имена файлов .

Ссылки

  1. ^ ab "File Systems". Microsoft TechNet . 2001. Архивировано из оригинала 2011-08-12 . Получено 2011-07-31 .
  2. ^ abcde Microsoft (2006-11-15). Файл Windows 95 CD-ROM CONFIG.TXT Архивировано 31 июля 2020 г. в статье Wayback Machine 135481, редакция: 1.1, получено 22 декабря 2011 г.: "Для каждого жесткого диска указывает, следует ли записывать дату последнего доступа к файлам. Даты последнего доступа отключаются для всех дисков при запуске компьютера в безопасном режиме и по умолчанию не сохраняются для дискет. Синтаксис: ACCDATE=drive1+|- [drive2+|-]..."
  3. ^ "Сравнение файловых систем NTFS и FAT". Microsoft. Архивировано из оригинала 2016-06-20 . Получено 2014-01-27 .
  4. ^ "Краткое введение в форматы FAT (File Allocation Table)". www.wizcode.com . Архивировано из оригинала 25 сентября 2015 г. . Получено 24 сентября 2015 г. .
  5. ^ "Объем и структура файлов дисковых картриджей для обмена информацией". Стандарт ECMA-107 (2-е изд., июнь 1995 г.) . ECMA . 1995. Архивировано из оригинала 2018-10-07 . Получено 2011-07-30 .
  6. ^ "Информационные технологии – Объем и структура файлов дисковых картриджей для обмена информацией". ISO/IEC 9293:1994 . Каталог ISO . 1994. Архивировано из оригинала 2012-01-17 . Получено 2012-01-06 .
  7. ^ "Обработка информации – Объем и структура файлов картриджей гибких дисков для обмена информацией". ISO 9293:1987 . Каталог ISO . 1987. Архивировано из оригинала 2012-01-17 . Получено 2012-01-06 .
  8. ^ Рейнольдс, Аарон Р .; Адлер, Деннис Р.; Липе, Ральф А.; Педрицетти, Рэй Д.; Парсонс, Джеффри Т.; Арун, Расипурам В. (1998-05-26). "Общее пространство имен для длинных и коротких имен файлов". Патент США 5758352. Получено 19 января 2012 г.[ мертвая ссылка ]
  9. ^ ab "Спецификация файловой системы FAT32 от Microsoft Extensible Firmware Initiative, FAT: общий обзор формата на диске". Microsoft . 2011-03-30. Архивировано из оригинала 2021-07-23 . Получено 2018-12-21 .
  10. ^ "Как преобразовать диск из FAT32 в NTFS без потери данных". WindowsLoop . 2021-07-11. Архивировано из оригинала 2021-08-08 . Получено 2021-08-08 .
  11. ^ JEIDA/JEITA/CIPA (2010). "Стандарт Ассоциации камер и устройств обработки изображений, CIPA DC-009-Translation-2010, Правила проектирования файловой системы камер: DCF версии 2.0 (издание 2010 г.)" (PDF) . Архивировано из оригинала (PDF) 30 сентября 2013 г. . Получено 2011-04-13 .
  12. ^ abcdefghij Xerox BASIC-80 – basic-80 справочное руководство (PDF) . 5.0. Microsoft , Xerox . 1979. 610P70641. Архивировано (PDF) из оригинала 2016-03-04 . Получено 2014-06-02 .(Примечание. Для Microsoft (автономный диск / диск / расширенный / 8K) BASIC-80, (автономный диск / расширенный) BASIC-86, компилятор BASIC, версия 5.0)
  13. ^ abcdefghij Справочное руководство MICROSOFT BASIC-80 версии 5.0 / Дополнение к интерпретатору и компилятору BASIC-80, выпуск 5.1 (PDF) . 5.1. Microsoft . 1979. Архивировано (PDF) из оригинала 04.03.2016 . Получено 02.06.2014 .(Примечание. Для Microsoft (автономный диск / диск / расширенный / 8K) BASIC-80, (автономный диск / расширенный) BASIC-86, компилятор BASIC, выпуск 5.1)
  14. ^ abcdefg Дункан, Рэй; Боствик, Стив; Бергойн, Кейт (1988). Энциклопедия MS-DOS: версии с 1.0 по 3.2 (полностью переработанное издание). Редмонд, Вашингтон, США: Microsoft Press . ISBN 1-55615-049-0. LCCN  87-21452. OCLC  16581341.(xix+1570 страниц; 26 см) (Примечание. Это издание было опубликовано в 1988 году после обширной переработки отозванного первого издания 1986 года другой группой авторов. [1] Архивировано 14 октября 2018 года на Wayback Machine )
  15. ^ ab Manes, Stephen; Andrews, Paul (1993). Gates: How Microsoft's Mogul Reinvent an Industry—and Make Himself the Bogthousand Man in America . Doubleday. ISBN 0-385-42075-7.
  16. ^ abcd Хантер, Дэвид (1983). «Тим Патерсон – Корни DOS». Softalk для IBM Personal Computer (март 1983). Архивировано из оригинала 2019-09-06 . Получено 2014-06-02 .
  17. ^ Шульман, Эндрю; Браун, Ральф Д .; Макси, Дэвид; Михельс, Рэймонд Дж.; Кайл, Джим (1994) [ноябрь 1993]. Недокументированная DOS: руководство программиста по зарезервированным функциям и структурам данных MS-DOS — расширено для включения MS-DOS 6, Novell DOS и Windows 3.1 (2-е изд.). Reading, Массачусетс: Addison Wesley . стр. 11. ISBN 0-201-63287-X.(xviii+856+vi страниц, 3,5-дюймовая дискета) Опечатки: [2][3]
  18. ^ ab Paterson, Tim (2007-09-30). "Design of DOS". DosMan Drivel . Архивировано из оригинала 2013-01-20 . Получено 04.07.2011 .
  19. ^ Seattle Computer Products (август 1980 г.). "86-DOS - 8086 OPERATING SYSTEM - $95". Byte (Реклама). Том 5, № 8. BYTE Publications Inc. стр. 173. ISSN  0360-5280. КОДЕН  BYTEDJ . Получено 18.08.2013 .[4] Архивировано 01.02.2020 на Wayback Machine (Примечание. В рекламе SCP продукт уже называется 86-DOS , но не указан конкретный номер версии. Известно, что версия 0.3 уже называется 86-DOS, поэтому изменение названия должно было произойти либо для версии 0.2, либо сразу после нее в августе 1980 года.)
  20. ^ abcd Seattle Computer Products (1981). "SCP 86-DOS 1.0 Addendum" (PDF) . Архивировано (PDF) из оригинала 2012-10-03 . Получено 2013-03-10 .
  21. ^ Уоллес, Джеймс; Эриксон, Джим; (1992); Жесткий диск: Билл Гейтс и создание империи Microsoft , John Wiley & Sons, ISBN 0-471-56886-4 
  22. ^ Нортон, Питер ; (1986); Внутри IBM PC, пересмотренное и расширенное издание , Брэди, ISBN 0-89303-583-1 , стр. 157 
  23. ^ Дженкинсон, Брайан; Сэммс, Эй Джей (2000). Криминалистические вычисления: Руководство для практикующего специалиста (серия для практикующего специалиста) . Берлин: Шпрингер. п. 157. ИСБН 1-85233-299-9. ... можно адресовать только 2^12 (то есть 4096) единиц распределения или кластеров. Фактически, это число меньше, поскольку 000h и 001h не используются, а FF0h до FFFh зарезервированы или используются для других целей, оставляя 002h до FEFh (от 2 до 4079) в качестве диапазона возможных кластеров.
  24. ^ Патерсон, Тим (1983). «Взгляд изнутри на MS-DOS». Byte . Архивировано из оригинала 20 июля 2011 г. Получено 18 июля 2011 г. Нумерация начинается с 2; первые две цифры, 0 и 1, зарезервированы.
  25. ^ IBM (1984). Анонсное письмо IBM PC DOS 3.0 .
  26. ^ IBM (1985). Технический справочник IBM PC DOS . Первое издание, P/N 6024181, датировано февралем 1985 г.
  27. ^ "Статья базы знаний Microsoft: "MS-DOS Partitioning Summary"". Архивировано из оригинала 2018-06-12 . Получено 2018-06-02 .
  28. ^ abc FYI – Установка DR DOS на разделы NEC DOS 3.3, Novell, 1993-01-05, FYI.M.1101, заархивировано из оригинала 2016-03-04 , извлечено 2014-08-12
  29. ^ Брауэр, Андрис. "Список идентификаторов разделов для ПК". Архивировано из оригинала 2019-04-23 . Получено 2012-01-11 .
  30. ^ "Q78407: Разделы Wyse DOS 3.3 несовместимы с MS-DOS 5.x и 6.x". Microsoft. 2000-12-17.[ мертвая ссылка ] Альтернативный URL
  31. ^ "Q68176: Обновление систем до версии 4.0 с логическими дисками > 32 МБ". Microsoft. 2000-12-17.[ мертвая ссылка ] Альтернативный URL
  32. ^ Брауэр, Андрис. "Свойства таблиц разделов". Архивировано из оригинала 2019-04-23 . Получено 2012-01-11 .
  33. ^ abcd Kuhnt, Udo; Georgiev, Luchezar I.; Davis, Jeremy (2007). "FAT+ draft revision 2" (2-е изд.). Архивировано из оригинала (FATPLUS.TXT) 2015-02-19 . Получено 2015-08-05 .
  34. ^ "Обзор Dskprobe: Восстановление данных". Microsoft TechNet . 2003-03-28. Архивировано из оригинала 2011-07-03 . Получено 2011-08-03 .
  35. ^ «Ошибки создания файлов или папок в корневом каталоге». Справка и поддержка Microsoft. 2004-12-16. Архивировано из оригинала 2020-07-31 . Получено 2006-10-14 .
  36. ^ "mkdosfs man page". Архивировано из оригинала 2006-10-07 . Получено 2006-11-21 .
  37. ^ "Windows 98 Resource Kit – Глава 10 – Диски и файловые системы". Microsoft TechNet . 1998. Архивировано из оригинала 2012-05-01 . Получено 2012-07-16 .
  38. ^ "Ограничения файловой системы FAT32". База знаний Microsoft . 2007-03-26. Архивировано из оригинала 2020-07-31 . Получено 2011-08-21 . Кластеры не могут быть 64 килобайта ( КБ ) или больше
  39. ^ «Ограничения файловой системы FAT32 в Windows XP». База знаний Microsoft . 2007-12-01. Архивировано из оригинала 2020-07-31 . Получено 2011-08-21 .
  40. ^ «Объяснение: Идея, лежащая в основе ограничения формата Windows в 32 ГБ для FAT32».
  41. ^ Гленн, Уолтер (2017-07-20). «Как отформатировать USB-накопители объемом более 32 ГБ с помощью FAT32 в Windows». How-To Geek . Архивировано из оригинала 2021-01-26 . Получено 2021-01-26 .
  42. ^ Рошан Ашраф Шейх (16.08.2024). «В предварительной версии Windows 11 размер раздела FAT32 увеличен до 2 ТБ после 30 лет». Tom's Hardware . Получено 23.08.2024 .
  43. ^ ab README.TXT – Загрузочный диск Caldera DR-DOS FAT32 (DRFAT32) . Caldera, Inc. 1998-07-24.
  44. ^ DRFAT32.SYS R1.00 INT 13h Интерфейс для перенаправления FAT32 , Caldera, Inc., 1998-09-11
  45. ^ IBM; Руководство пользователя ОС 4690, версия 5.2 , документ IBM SC30-4134-01, 10.01.2008 ([5])
  46. ^ Карповиц, Кристина (1998-09-23). ​​"PowerQuest PartitionMagic 4.0 теперь доступен". PowerQuest . Архивировано из оригинала 1999-02-08 . Получено 2015-04-17 .
  47. ^ Ливингстон, Брайан (1998-10-28). "FAT-32X может работать иначе, чем FAT-32 на больших жестких дисках". InfoWorld . Том 20, № 43. Архивировано из оригинала 2015-11-12 . Получено 2015-04-17 .
  48. ^ ab Duitz, Neal (2001-07-17). "Может ли кто-нибудь объяснить FAT32X?". Win98 Private FAQ, Программа Windows 98 Consumer Preview. Архивировано из оригинала 2004-06-13 . Получено 2015-04-17 .
  49. ^ ab Costanzo, Lance (1998-05-14). "FAT32X". Архивировано из оригинала 1998-05-21 . Получено 2015-04-17 .
  50. ^ Steinberg, David (1998-05-01). "Что такое раздел FAT32X?". Технический совет / FAQ . Техническая поддержка PowerQuest . Архивировано из оригинала 2015-09-21 . Получено 2015-04-17 .
  51. Eager, Bob; Tavi Systems (28 октября 2000 г.); Реализация расширенных атрибутов в файловой системе FAT ([6] Архивировано 13 июня 2006 г. на Wayback Machine )
  52. ^ Kelder, Henk; (2003); FAT32.TXT для FAT32.IFS версии 0.9.13 . ([7] Архивировано 11.05.2013 на Wayback Machine ): "Этот байт [...] не изменяется при работе Windows 95 и выше [sic] с помощью SCANDISK или DEFRAG. [...] Если другая программа устанавливает значение для 0x00файла, который имеет EA , эти EA больше не будут найдены с помощью вызовов DosFindFirst/Next. Другие вызовы OS/2 для извлечения EA (DosQueryPathInfo, DosQueryFileInfo и DosEnumAttribute) не полагаются на этот байт. Также может произойти обратное [...]. [...] В этой ситуации снизится только производительность сканирования каталогов. Обе ситуации [...] исправляются с помощью CHKDSK ".
  53. Kelder, Henk; FAT32.TXT для FAT32.IFS версии 0.74 ( «@Macarlo, Inc». Архивировано из оригинала 30 марта 2012 г. Получено 14 января 2012 г.). Комментарий: В этой старой версии файла README по-прежнему обсуждаются старые 0xEAи 0xECмагические значения.
  54. ^ Eager, Bob (2000-10-28). "Реализация расширенных атрибутов в файловой системе FAT". Страницы Tavi OS/2 . Архивировано из оригинала 2006-06-13 . Получено 2006-10-14 .
  55. ^ IBM; Руководство по программированию ОС 4690, версия 5.2 , документ IBM SC30-4137-01, 2007-12-06 ([8])
  56. ^ "Release notes for v2.5.7". Архив ядра Linux. 2002-03-12. Архивировано из оригинала 2006-04-15 . Получено 2006-10-14 .
  57. ^ Kuhnt, Udo (2011-07-21). "DR-DOS/OpenDOS Enhancement Project". Архивировано из оригинала 2016-07-06 . Получено 2015-04-20 .
  58. ^ "FATX Specification". free60 wiki. Архивировано из оригинала 2018-07-26 . Получено 2011-08-16 .
  59. ^ de Quincey, Andrew; Murray-Pitts, Lucien (2008-08-29). "Разбиение на разделы и сведения о файловой системе Xbox". 0.13. Проект Xbox-Linux. Архивировано из оригинала 2010-06-17 . Получено 2014-05-25 .
  60. ^ Steil, Michael (2008-02-26) [2003]. "Различия между Xbox FATX и MS-DOS FAT". Проект Xbox-Linux. Архивировано из оригинала 2010-06-17 . Получено 2014-05-25 .
  61. ^ Microsoft. "Программа лицензирования интеллектуальной собственности файловой системы exFAT". Microsoft . Архивировано из оригинала 7 мая 2013 г. Получено 23 апреля 2013 г.
  62. ^ "Обратная разработка файловой системы Microsoft exFAT | Институт SANS". Архивировано из оригинала 21.04.2021 . Получено 20.03.2021 .
  63. ^ "exFAT в ядре Linux? Да!". Блог Microsoft Open Source . 2019-08-28. Архивировано из оригинала 2019-09-01 . Получено 2019-10-06 .
  64. ^ ab US 5579517, Рейнольдс, Аарон Р.; Адлер, Деннис Р. и Липе, Ральф А. и др., «Общее пространство имен для длинных и коротких имен файлов», выпущено в 1996 г. 
  65. ^ US 5745902, Miller, Thomas J. & Kimura, Gary D., «Метод и система доступа к файлу с использованием имен файлов, имеющих различные форматы имен файлов», выпущенный в 1998 г. 
  66. ^ ab US 5758352, Рейнольдс, Аарон Р.; Адлер, Деннис Р. и Липе, Ральф А. и др., «Общее пространство имен для длинных и коротких имен файлов», выпущено в 1998 г. 
  67. ^ US 6286013, Рейнольдс, Аарон Р.; Адлер, Деннис Р. и Липе, Ральф А. и др., «Метод и система предоставления общего пространства имен для длинных и коротких имен файлов в операционной системе», выпущенный в 1996 г. 
  68. Microsoft.com Архивировано 22 августа 2009 г. на Wayback Machine
  69. ^ "FAT File System". Лицензирование интеллектуальной собственности . Microsoft. Архивировано из оригинала 2016-09-21.
  70. ^ Гарретт, Мэтью (19.01.2012). «EFI и Linux: будущее уже здесь, и оно ужасно». linux.conf.au . YouTube. Архивировано из оригинала 02.11.2021 . Получено 12.01.2014 .
  71. ^ US 5367671, Фейгенбаум, Барри А. и Миро, Феликс, «Система доступа к данным расширенных атрибутов объектов (EA) через связи имен файлов или дескрипторов EA в таблицах путей», выпущенный в 1994 г. 
  72. ^ Ravicher, Daniel B. (2004-04-15). "Запрос PUBPAT на повторную экспертизу патента FAT компании Microsoft" (PDF) . Public Patent Foundation. Архивировано (PDF) из оригинала 2013-06-07 . Получено 2014-01-12 .
  73. ^ USPTO (2004-09-30). "Действие патентного ведомства, отклоняющее патент Microsoft FAT" (PDF) . Public Patent Foundation. Архивировано (PDF) из оригинала 2013-05-26 . Получено 2014-01-12 .
  74. ^ Броач, Энн (10.01.2006). «Патент на файловую систему Microsoft поддержан». Новости CNET. Архивировано из оригинала 03.05.2016 . Получено 07.04.2016 .
  75. ^ Пол, Райан (25.02.2009). «Иск Microsoft по патентам FAT может открыть ящик Пандоры OSS». arstechnica.com. Архивировано из оригинала 27.02.2009 . Получено 28.02.2009 .
  76. ^ Фрид, Ина (2009-03-30). "Microsoft, TomTom урегулировали патентный спор". cnet.com. Архивировано из оригинала 2009-08-05 . Получено 2009-08-22 .
  77. ^ "Microsoft Motorola Patent Suit". 2010-10-01. Архивировано из оригинала 2010-10-06 . Получено 2010-10-02 .
  78. ^ Проталински, Эмиль (2010-10-01). «Microsoft подает в суд на Motorola, ссылаясь на нарушение патента Android». arstechnica.com. Архивировано из оригинала 2010-10-02 . Получено 2010-10-02 .
  79. ^ Пол, Райан (2009-07-02). "Новый патч Linux может обойти патенты FAT от Microsoft". ArsTechnica.com. Архивировано из оригинала 2013-11-01 . Получено 2013-10-30 .
  80. ^ Браун, Эрик (2009-07-02). "Может ли исправление FAT избежать судебных исков Microsoft?". DesktopLinux.Com. Архивировано из оригинала 2013-01-31 . Получено 2009-08-23 .
  81. ^ [9], "Общее пространство имен для длинных и коротких имен файлов", выпущено 1994-03-31 "EP0618540B1 - Общее пространство имен для длинных и коротких имен файлов - Google Patents". Архивировано из оригинала 2020-03-28 . Получено 2021-05-07 .  {{cite web}}: CS1 maint: бот: исходный статус URL неизвестен ( ссылка )
  82. ^ Мюллер, Флориан (2013-12-05). «Федеральный патентный суд Германии признает патент Microsoft FAT недействительным, апелляционный суд может не согласиться». FOSS Patents. Архивировано из оригинала 2014-01-04 . Получено 2014-01-12 .
  83. ^ Лабезиус, Стефан (28 мая 2017 г.). «Bundespatentgericht erklärt VFAT-Patent erneut für nichtig». ифрОСС. Архивировано из оригинала 2 августа 2019 г. Проверено 2 августа 2019 г.
  • Описание файловой системы FAT32: статья базы знаний Microsoft 154997
  • MS-DOS: Ограничения каталогов и подкаталогов: статья базы знаний Microsoft 39927
  • Обзор файловых систем FAT, HPFS и NTFS: статья базы знаний Microsoft 100108
  • Microsoft Technet; Ограничения по объему и размеру файлов в файловых системах FAT, копия статьи с обзором ограничений в FAT32, сделанная Internet Archive Wayback Machine, которая больше не доступна на веб-сайте Microsoft.
  • Чен, Рэймонд ; Microsoft TechNet: Краткая и неполная история FAT32
  • Fdisk не распознает полный размер жестких дисков объемом более 64 ГБ: статья базы знаний Microsoft 263044, копия сделана Internet Archive Wayback Machine. Объясняет невозможность работы с очень большими томами в Windows 95/98.
  • Microsoft Windows XP: Файловая система FAT32, копия статьи с обзором ограничений в FAT32, созданная Wayback Machine из Internet Archive , которая больше не доступна на веб-сайте Microsoft.
Получено с "https://en.wikipedia.org/w/index.php?title=Таблица_распределения_файлов&oldid=1252011115#FAT12"