<?xml version="1.0" encoding="windows-1251"?>
<rss version="2.0" xmlns="http://backend.userland.com/rss2" xmlns:yandex="http://news.yandex.ru">
<channel>
<title>Интерфейсы устройств хранения - Аппаратные интерфейсы ПК</title>
<link>http://intpc.ru/</link>
<language>ru</language>
<description>Интерфейсы устройств хранения - Аппаратные интерфейсы ПК</description>
<image>
<url>http://intpc.ru/yandexlogo.gif</url>
<title>Интерфейсы устройств хранения - Аппаратные интерфейсы ПК</title>
<link>http://intpc.ru/</link>
</image>
<generator>DataLife Engine</generator><item>
<title>Устройства хранения данных</title>
<link>http://intpc.ru/134-ustrojjstva-khranenija-dannykh.html</link>
<description>Устройства хранения данных - накопители на магнитных дисках (гибких и жестких, фиксированных и сменяемых), оптические диски CD и DVD, ленточные и твердотельные - подключаются к компьютеру самыми разнообразными способами. Первые устройства хранения в ПК - накопители на гибких магнитных дисках (НГМД) - подключались интерфейсным кабелем-шлейфом к контроллеру, отделенному от самих устройств.</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 17:32:16 +0300</pubDate>
<yandex:full-text>Устройства хранения данных - накопители на магнитных дисках (гибких и жестких, фиксированных и сменяемых), оптические диски CD и DVD, ленточные и твердотельные - подключаются к компьютеру самыми разнообразными способами. Первые устройства хранения в ПК - накопители на гибких магнитных дисках (НГМД) - подключались интерфейсным кабелем-шлейфом к контроллеру, отделенному от самих устройств. Этот специализированный интерфейс сохранился до сих пор, им подключают дисководы, требующие скорости передачи всего 500 Кбит/с (около 60 Кбайт/с). Скорость 1000 Кбит/с, требуемая для так и не распространившихся дисководов на 2,88 Мбайт, осталась невостребованной. К интерфейсу дисководов подключали и старые стриммеры (очень тихоходные). Аналогичный интерфейс поначалу использовался и для подключения винчестеров (так называемых MFM и RLL), по нему передавались «сырые» данные записи чтения с головок диска, правда, усиленные. Позже накопители слегка «интеллектуализировали», и появился (ненадолго) интерфейс дисков ESDI, обеспечивающий скорость передачи данных аж 1 Мбайт/с. Однако вскоре контроллер полностью переселился на само устройство, да еще и с собственной буферной памятью (сначала на один сектор, а потом объем стал стремительно расти), и из внешнего интерфейса устройства хранения ушла вся специфика, связанная с магнитной записью и воспроизведением данных. Так появились устройства с интерфейсом AT А, начавшим свою историю в 1988 г. и ставшим в наши дни самым распространенным. Для устройств, логически отличающихся от жестких дисков - оптических, магнитооптических, ленточных и любых других, - в 1996 г. была принята спецификация AT API. Это пакетное расширение интерфейса, которое позволяет передавать по шине АТА устройству блоки командной информации, структура которых была позаимствована из SCSI. Потолок скорости АТА - 100 Мбайт/с (Ultra DMA Mode 5). Интерфейс АТА имеет уже вполне видимую границу по адресации около 137 Гбайт, в AT API используется принятая в SCSI 32-битная адресация, позволяющая адресовать до 2 Тбайт (при 512-байт-ном блоке). Дальнейшее развитие интерфейса - Serial ATA; здесь повышается скорость обмена с устройством, решается проблема одновременной работы с несколькими устройствами, значительно расширяются возможности адресации.&lt;br /&gt;Для устройств хранения используют и универсальные интерфейсы, первым конкурентом АТА является шина SCSI, как в парарельном варианте так и в последовательном (FCAL). Примерно при тех же скоростях обмена SCSI позволяет эффективно работать с несколькими устройствами на одной шине, которая во время выполнения команды с длительной фазой ожидания данных свободна для обмена с другими устройствами. В отличие от сугубо внутренней шины AT A, SCSI позволяет подключать и внешние устройства. Для внешних устройств хранения с успехом применяются и шины USB, реже Fire Wire, а также подключение к LPT-порту.&lt;br /&gt;</yandex:full-text>
</item><item>
<title>Интерфейс НГМД</title>
<link>http://intpc.ru/135-interfejjs-ngmd.html</link>
<description>Накопители на гибких магнитных дисках (НГМД) подключаются к контроллеру через специальный стандартный интерфейс. Основные функции по управлению НГМД, а также кодирование-декодирование данных выполняет контроллер, расположенный на большинстве современных системных плат. Раньше контроллер часто выносили на специальную карту расширения («в компании» с интерфейсом НЖМД). На плате электроники, установленной на корпусе НГМД, расположены только схемы приводов двигателей, усилители-формирователи сигналов записи и считывания и формирователи сигналов от датчиков.</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 17:32:56 +0300</pubDate>
<yandex:full-text>Накопители на гибких магнитных дисках (НГМД) подключаются к контроллеру через специальный стандартный интерфейс. Основные функции по управлению НГМД, а также кодирование-декодирование данных выполняет контроллер, расположенный на большинстве современных системных плат. Раньше контроллер часто выносили на специальную карту расширения («в компании» с интерфейсом НЖМД). На плате электроники, установленной на корпусе НГМД, расположены только схемы приводов двигателей, усилители-формирователи сигналов записи и считывания и формирователи сигналов от датчиков.</yandex:full-text>
</item><item>
<title>Аппаратный интерфейс</title>
<link>http://intpc.ru/136-apparatnyjj-interfejjs.html</link>
<description>Все сигналы интерфейса НГМД являются логическими с уровнями ТТЛ, активный уровень - низкий. Формирователи выходных сигналов накопителя имеют выход типа «открытый коллектор».</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 17:34:10 +0300</pubDate>
<yandex:full-text>Все сигналы интерфейса НГМД являются логическими с уровнями ТТЛ, активный уровень - низкий. Формирователи выходных сигналов накопителя имеют выход типа «открытый коллектор». Интерфейс подразумевает наличие терминаторов - нагрузочных резисторов - для каждой сигнальной линии устройства. Теоретически их предполагалось включать только на последнем дисководе в шлейфе, практически же их никогда и не отключают. Современные трехдюймовые накопители используют «распределенный терминатор» - резисторы с относительно высоким сопротивлением (1-1,5 кОм), постоянно соединяющие входные линии интерфейса с шиной +5 В. Низкие частоты интерфейсных сигналов позволяют не задумываться о точности согласования импеданса шлейфа и сопротивления терминатора. Однако если на шлейфе стоят только старые 5&quot;-накопители со снятыми терминаторами, они могут отказаться надежно работать (выходные линии с открытым коллектором останутся без нагрузки).&lt;br /&gt;Логически интерфейс довольно прост. Для того чтобы заставить накопитель работать, его нужно выбрать сигналом Drive Sel и запустить мотор шпинделя сигналом Motor On. Для выборки накопитель имеет четыре сигнала DSO...DS3, но отзывается только на один из них, определенный установкой джамперов. Выбранный накопитель воспринимает управляющие сигналы от контроллера и передает кон-троллеру свои выходные сигналы. О том, что накопитель выбран, свидетельствует светодиодный индикатор на его лицевой панели.&lt;br /&gt;Для перемещения головок на один шаг контроллер должен подать импульс Step; направление перемещения определяется уровнем сигнала Direction: при низком уровне (сигнал активен) перемещение происходит в сторону центра диска (номер трека увеличивается). Нулевой трек контроллер находит, перемещая головки от центра до появления сигнала Track 00. Выбор номера головки производится сигналом Side 1. Начало трека накопитель отмечает импульсом Index, который вырабатывается при прохождении индексного отверстия вращающейся дискеты мимо&lt;br /&gt;датчика. Считываемые данные в закодированном (MFM) виде (но усиленные и сформированные в ТТЛ-сигнал) поступают от накопителя по линии Read Data. Для включения режима записи служит сигнал Write Gate, закодированные данные в цифровом виде поступают от контроллера по линии Write Data. Если установлена дискета, защищенная от записи, накопитель сообщит об этом сигналом Write Protect. Для снижения тока записи, которое требуется при работе накопителей HD с дискетами DD и QD, предназначен сигнал Reduce Write, его иное название - Low Current или FDHDIN. Для переключения головок на «вертикальную запись» (для дискет 2,88 Мбайт) служит сигнал FDEDIN. Оба эти сигнала вырабатываются контроллером, но для самого дисковода они дублируются сигналами от датчиков типа дискеты (сигнал FDEDIN необязателен, дисковод сам переключится по сигналу отдатчика). Некоторые модели дисководов позволяют изменить описанный способ работы датчиков типа дискеты, принятый для PC-совместимых ПК, - они могут быть отключены или выполнять информирование контроллера. Однако практически все кбн-троллеры сами управляют линиями интерфейса, соответствующими сигналам от этих датчиков. В этом управлении учитывается тип дисковода, описанный в CMOS Setup, и заказанный формат дискеты. Сигнал Reduce Write (низкий уровень) формируется контроллером при любом обращении к дисководу, описанному в CMOS как HD (High Density - высокая плотность, емкость 1,2 или 1,44 Мбайт), для работы с дискетами DD или QD (360 или 720 Кбайт). В некоторых контроллерах этот сигнал формировался, только когда контроллер настроен на скорость 300 Кбит/с (дискета 360/720 Кбайт в дисководе на 1,2 Мбайт). Такой контроллер может надежно форматировать и записывать дискеты 720 Кбайт в приводе на 1,44 Мбайт только при наличии правильно сконфигурированного датчика HD, иначе он все 3,5&quot; дискеты будет записывать с высоким током записи, недопустимым для дискет QD.&lt;br /&gt;Накопители HD при смене дискеты устанавливают сигнал Disk Changed, который сбрасывается после обращения к этому накопителю. Этот сигнал заслуживает особого внимания. Он имеется только у дисководов HD и ED (Extra High Density, малораспространенные дисководы на 2,88 Мбайт), причем способ использования этого контакта может определяться джамперами дисковода. В PC соответствующий джампер устанавливается в положение DC (Disk Change). Альтернативное использование этой линии - сигнализация готовности устройства, что может обозначаться как RY, RDY или SR, - для PC непригодно.&lt;br /&gt;Заметим, что в интерфейсе нет никаких сигналов, прямо информирующих контрол-лер о готовности - наличии установленной дискеты. Контроллер может определить готовность, лишь выбрав накопитель и запустив мотор. Тогда отсутствие импульсов Index будет означать неготовность - нет дискеты или она не зафиксирована на шпинделе, или же не подключен дисковод (интерфейс или питание). Наличие дисковода контроллер может определить с помощью команды рекалибровки (см. ниже) - при ее выполнении дисковод должен подать сигнал TrackOO. Все НГМД, применяемые в PC, независимо от типа и размера имеют одинаковый интерфейс и унифицированные 34-контактные разъемы двух типов: с печатными двусторонними ламелями у устройств 5&quot; и двухрядными штырьковыми контактами у устройств 3,5&quot;. Используемый в PC кабель-шлейф имеет перевернутый фрагмент из 7 проводов с номерами 10-16 (рис. 9.1). Этот поворот позволяет подключать к контроллеру одним шлейфом до двух НГМД, причем адрес накопителя.&lt;br /&gt;&lt;br /&gt;определяется его положением на шлейфе: для привода А: фрагмент перевернут, для В: - нет. Универсальный шлейф с пятью разъемами, изображенный на рисунке, позволяет подключать пару любых дисководов, которые должны располагаться в разных зонах шлейфа. Некоторые разъемы могут и отсутствовать, что сковывает свободу конфигурирования дисководов. В табл. 9.1 описан интерфейсный кабель с сигналами, приходящими на разные накопители. Направление сигналов (I/O - ввод-вывод) указано относительно контроллера.&lt;br /&gt; &lt;br /&gt;Таблица 9.1. Кабель интерфейса НГМД&lt;br /&gt;&lt;br /&gt;Контроллер		ДисководВ:	ДИСКОВОДА:&lt;br /&gt;Контакт1	Сигнал	I/O	Контакт1 Сигнал	Контакт1	Сигнал&lt;br /&gt;2	FDHDIN (Reduce Write)	О	2	Low Current	2	Low Current&lt;br /&gt;4	Резерв	-	4	Резерв	4	Резерв&lt;br /&gt;6	FDEDEIN	-	6	FDEDIN (DS3)	6	FDEDIN (DS3)&lt;br /&gt;8	Index	I	8	Index	8	Index&lt;br /&gt;10	Motor On A	о	10	DSO	16	Motor2&lt;br /&gt;12	Drive Sel 1	о	12	DS11	14	DS2&lt;br /&gt;14	Drive Sel 0	о	14	DS2	12	DS11&lt;br /&gt;16	Motor On В	о	16	Motor2	10	DSO&lt;br /&gt;18	Direction	о	18	Direction	18	Direction&lt;br /&gt;20	Step	о	20	Step	20	Step&lt;br /&gt;22	Write Data	о	22	WData	22	Wdata&lt;br /&gt;24	Write Gate	о	24	WGate	24	Wgate&lt;br /&gt;26	Track 00	I	26	ТВ 00	26	TROO&lt;br /&gt;28	Write Protect	1	28	WProt	28	WProt&lt;br /&gt;30	Read Data	1	30	RData	30	Rdata&lt;br /&gt;32	Side l	о	32	Sidel	32	Side l&lt;br /&gt;343	Disk Changed	1	343	DC	34Э	DC&lt;br /&gt;1	Нечетные контакты 1 -33 - земля. Для дисководов 5&quot; ключ между контактами 4-5 и 6-7.&lt;br /&gt;2	Пара сигналов, обеспечивающая выборку FDD (Motor On А и Drive Sel 0 для дисковода А: и Motor On&lt;br /&gt;В и Drive Sel 1 для дисковода В:). 3 Контакт 34 в XT не используется.&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;Контроллер НГМД и интерфейсный кабель, принятый в PC, позволяют адресоваться к одному из двух накопителей и включать мотор сигналами Drive Sel 0 и Motor On А для накопителя А: и Drive Sel 1 и Motor On В для накопителя В:. При этом на обоих накопителях джамперы устанавливаются так, что они отзываются на сигнал DS 1 (контакт 12 разъема). Обычно джамперы на дисководе обозначаются DSO / DS1 / DS2 / DS3, и следует установить джампер DS1. Если джамперы обозначаются как DS1 / DS2 / DS3 / DS4, что встречается нечасто, то следует устано-вить DS2. Принятая система выборки позволяет все дисководы конфигурировать однотипно, а адрес задавать положением на шлейфе. В некоторых специфических клонах PC применяют иную систему выборки накопителей и «прямой» кабель-шлейф. При этом используется выборка устройства сигналом DS0, ко переключение выборки на эту линию некоторыми накопителями не поддерживается, в результате замена накопителей в этих «фирменных» машинах может стать хлопотным де-лом, особенно при отсутствии технической документации.&lt;br /&gt;</yandex:full-text>
</item><item>
<title>Контроллер НГМД</title>
<link>http://intpc.ru/137-kontroller-ngmd.html</link>
<description>Программное взаимодействие с НГМД производится через контроллер накопителей на гибких дисках FDC (Floppy Drive Controller), как правило, при участии контроллера DMA и прерываний.</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 17:35:29 +0300</pubDate>
<yandex:full-text>Программное взаимодействие с НГМД производится через контроллер накопителей на гибких дисках FDC (Floppy Drive Controller), как правило, при участии контроллера DMA и прерываний. Программирование контроллера НГМД для выполнения операций с дискетами - довольно хлопотное занятие (см. [4,8,9]). Все функции, необходимые для использования НГМД в качестве устройств хранения данных, реализованы сервисами BIOS Int 13h (см. 12.8.1) и ОС. Игнорирование сервисов BIOS и даже ОС оправданно в основном лишь для нетривиальных задач типа работы с ключевыми дискетами и т. п.&lt;br /&gt;Все контроллеры, применяемые в IBM PC, обеспечивают совместимость с «исторической» микросхемой контроллера NEC PD765, которая является аналогом i8272. Контроллер FDC А Т поддерживает два накопителя; он позволяет работать со скоростями передачи данных 250 Кбит/с (для работы с дискетами SD, DD и QD в старых дисководах 5&quot;), 500 Кбит/с для плотности HD (1,2 и 1,44 Мбайт), а также 300 Кбит/с для работы с дискетами SD, DD и QD в приводах HD 5&quot;. Современные контроллеры, поддерживающие накопители ED (2,88 Мбайт), должны обеспечивать и скорость 1000 Кбит/с. Режимы контроллеров, соответствующие скоростям 250/300,500 и 1000 Кбит/с, обозначаются соответственно 1М, 2М и 4М. В режиме 1М на одном треке умещается 9 секторов (по 512 байт); для этого при частоте вращения 300 об/мин требуется скорость 250 Кбит/с, а при 360 об/мин -300 Кбит/с. В режиме 2М при частоте вращения 300 об/мин (у дисководов HD 3,5&quot;) на одном треке умещается 18 секторов, а при частоте вращения 360 об/мин (у дис-ководов HD 5&quot;) - 15 секторов. Режим 4М, похоже, так и останется невостребованным. Выбор скорости задает частоту синхронизации при записи и форматировании, а также настраивает цепи Ф АПЧ сепаратора данных контроллера. Сепаратор данных способен устойчиво выделять данные и синхросигнал из сигнала, принятого с головки, лишь при небольших (порядка ±10 %) отклонениях скорости от номинала, поэтому скорость должна быть правильно выбрана для всех операций обмена данными с диском.&lt;br /&gt; &lt;br /&gt;В карте ресурсов AT имеется место под два контроллера НГМД:&lt;br /&gt;-	FDC АТ#1 (стандартный или основной) занимает порты с адресами 3FOh-&lt;br /&gt;3F7h (как и FDC XT);&lt;br /&gt;-	FDC AT#2 (дополнительный) занимает порты с адресами 370h-377h.&lt;br /&gt;Контроллеры вырабатывают запрос аппаратного прерывания IRQ6 (BIOS I n t 0E h) по окончании выполнения внутренних операций. Для обмена данными может использоваться канал DMA2. Назначение регистров контроллера приведено в табл. 9.2.&lt;br /&gt;Адрес регистра состояния FDC 3F7 (377) совпадает с адресом регистра HDC (давно неиспользуемого), в связи с чем раздельная работа FDC и HDC, расположенных на разных платах, проблематична. В нормальном (не диагностическом) режиме из этого регистра интерес представляет только бит 7 - признак смены носителя.&lt;br /&gt;Таблица 9.2. Регистры контроллера НГМД Адрес     Назначение (R - чтение, W - запись)&lt;br /&gt;3F2 (372) RW: DOR (Digital Output Register) - регистр управления: биты [4:7] - включение моторов А, В, С, D: 1 - включен; бит 3:1- разрешение использования DMA2 и IRQ6; бит 2:0 - сброс, 1 - разрешение контроллера; биты [1:0] - номер выбранного привода 0-3. В AT биты 6,7 и 1 не используются&lt;br /&gt;3F3 (373) RW: TDR (Tape Drive Register) - регистр стриммера: биты [1:0]- номер устройства, которому соответствует стриммер. По сбросу устанавливается 00, но это означает отсутствие стриммера (вместо дисковода А: стиммер не поставить)&lt;br /&gt;3F4 (374) R: MSR (Main State Register) - главный регистр состояния: бит 7 (DQM) - запрос: 1 - готов к приему/передаче байта; бит 6 (DIO) - направление данных: 1 - FDC -&gt; CPU; бит 5 (NON DMA) - использование DMA: 1 - DMA не используется; БИТ4(CMDBSY): 1 - контроллер занят выполнением команды; биты [0:3] - привод А:, В:, С:, D: занят (в AT используются только биты 0,1)&lt;br /&gt;3F4 (374)1 W: DSR (Datarate Select Register) - регистр выбора скорости: бит 7:1 - сброс&lt;br /&gt;контроллера (обнуляется автоматически); бит 6:1 - отключение питания контроллера; бит 5:1 - разрешение внешней ФАПЧ (должен быть 0); биты [4:2] - выбор времени предкомпенсации записи (000 - предкомпенсация по умолчанию); биты [1:0] - скорость обмена (00 - 500Кбит/с,01 - 300 Кбит/с, 10 -250 Кбит/с, 11 -1 Мбит/с)&lt;br /&gt;3F5 (375) RW: DR (Data Register) - регистр команд/данных&lt;br /&gt;3F7 (377) W: CCR (Configuration Control Register) - регистр параметров контроллера (AT): биты [7:2] - не используются; биты [1:0]- скорость обмена (00 - 500 Кбит/с, 01-300 Кбит/с, 10 - 250 Кбит/с, 11-1 Мбит/с)&lt;br /&gt;3F7 (377) R: DIR (Digital Input Register) - регистр состояния (только в AT): бит 7:1 =смена носителя (чтение инвертированной линии DC); биты [6:0] - не используются, при чтении не выводятся на шину данных&lt;br /&gt;1 Регистр DSR обеспечивает совместимость с контроллером 18272; в современных контроллерах НГМД на АТ-совместимых компьютерах вместо него используют CCR, поскольку требуется только задание скорости.&lt;br /&gt;Контроллер НГМД может быть использован и для работы со стриммерами; специально для этого в контроллере имеется регистр TDR (Tape Drive Register), пара младших битов которого задает номер устройства, которому соответствует стриммер (для него иначе настраиваются цепи ФАПЧ сепаратора данных).&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;Все операции с дискетами выполняются по командам, посылаемым хостом в регистр DR (3F5) согласно состоянию битов регистра MSR (3F4). Запись байта команды или данных в регистр DR разрешается лишь при текущем значении MSR=10xxxxxxb, чтение - при MSR=llxxxxxxb. Для записи/чтения этого регистра приходится использовать отдельные подпрограммы, не только дожидающиеся разрешающих значений MSR, но и имеющие аварийный выход по тайм-ауту. Хост также выполняет запись в регистр DOR (3F2) для запуска/останова дисковода, а также в CCR (3F7) или DSR (3F4) для выбора скорости передачи данных. В операциях обмена данными с дискетами обычно участвует контроллер DMA, и он должен быть своевременно проинициализирован. Сигнал ТС (завершение цикла DMA) используется как признак завершения фазы данных. В общем виде процедура обмена данными состоит из следующих шагов.&lt;br /&gt;1.	Запуск мотора и выбор дисковода (записью в регистр DOR).&lt;br /&gt;2.	Установка скорости (записью в регистр CCR).&lt;br /&gt;3.	Выполнение команды рекалибровки.&lt;br /&gt;4.	Ожидание раскрутки двигателя (если мотор работает еще менее 0,5 с).&lt;br /&gt;5.	Позиционирование головки на требуемый цилиндр.&lt;br /&gt;6.	Инициализация контроллера DMA.&lt;br /&gt;7.	Посылка команды чтения/записи.&lt;br /&gt;8.	Ожидание прерывания от контроллера. Прерывание произойдет, когда завер&lt;br /&gt;шится фаза исполнения, во время которой контроллер обычно обменивается&lt;br /&gt;данными с хостом. Если за определенное время прерывание не получено, фик&lt;br /&gt;сируется неудачная попытка обращения с ошибкой тайм-аута.&lt;br /&gt;9.	По прерыванию от контроллера считываются байты результата, и если ошибок&lt;br /&gt;нет, на этом обмен успешно завершается. Если есть ошибки, то снова переходят&lt;br /&gt;на шаг инициализации DMA и далее повторяют команду чтения/записи. Если за несколько (3) раз успех не достигается, то выполняется рекалибровка, затем инициализация DMA и повторные попытки чтения/записи. Если успех не достигается и после нескольких рекалибровок, обмен прекращается аварийно.&lt;br /&gt;Помимо описанного механизма имеется механизм автоматического выключения&lt;br /&gt;мотора НГМД, если к нему долго нет обращения. Для этого в фиксированном&lt;br /&gt;месте ОЗУ (BIOS Data Area, ячейка 0:0440) имеется счетчик времени работы мотора НГМД и адрес дисковода (в позиционном коде), мотор которого включен (0:043F). При каждом обращении к дискете (когда в регистре DOR устанавливается бит включения мотора) в счетчик времени заносится константа, соответствующая выдержке на отключение (по умолчанию - 2 с). Обработчик аппаратного прерывания от таймера IRQ0 (BIOS Int 08h)c интервалом около 55 мс декрементирует счетчик времени и По его обнулению отключает мотор (записью в регистр DOR). Таким образом, если в течение заданного интервала нет обращений, мотор автоматически выключается. Конечно, это работает, лишь когда BIOS отрабатывает аппаратные прерывания от таймера, так что не отключающийся мотор дисковода может быть косвенным признаком «зависания» компьютера.&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;Исполнение каждой команды имеет три фазы.&lt;br /&gt;1.	Фаза команды. Контроллер устанавливает биты DQM=1 и DIO-0, что является приглашением к вводу команды. В регистр DR посылается байт команды, после которого посылаются байты параметров в строго предписанном порядке. На прием каждого байта контроллер отзывается обнулением DQM на время обработки. После получения последнего требуемого байта DQM остается обнуленным и контроллер переходит в фазу исполнения. В качестве параметров фигурируют номер цилиндра С, номер головки Н, номер сектора R, код размера N или длина поля данных сектора DTL, номер последнего сектора на треке EOT, число секторов SC, длительность зазоров GPL и некоторые другие данные.&lt;br /&gt;2.	Фаза исполнения требует передачи данных от хоста к контроллеру или обратно,&lt;br /&gt;передача может происходить как в режиме DMA, так и чисто программно (РЮ). В режиме DMA обмен выполняется по сигналам DRQ и DACK# используемого канала. Если DMA не используется, то запросом на передачу является бит DQM и сигнал прерывания. По окончании фазы вырабатывается сигнал прерывания (и его признак в регистре ST0), и контроллер переходит в фазу результата.&lt;br /&gt;3.	В фазе результата DQM=1 и 010=1, хост должен считать байты результата из DR, после чего биты установятся в значение DQM=1 и 010=0, что соответствует переходу в фазу приема команды.&lt;br /&gt;С момента получения команды и до окончания фазы результата в регистре MSR бит СМО BSY=1. Контроллер всегда можно принудительно сбросить (перевести в начало фазы команды) записью в регистр DOR или DSR. Если контроллер получит неподдерживаемую команду, он сразу выставит DQM=1 и 010=1, что является указанием на необходимость чтения DR. Хост должен прочитать из DR код состояния, в котором будет значение 80h (недопустимая команда).&lt;br /&gt;В современных контроллерах НГМД имеется буфер FIFO глубиной 16 байт, работающий при передаче данных (но не команд и параметров) через регистр DR; в «историческом» контроллере 18272 буфера FIFO не было. Логика общения с регистром DR остается той же. Буфер должен быть своевременно обслужен, чтобы не происходило его переполнения или опустошения. Логика буфера устанавливает запрос данных так, чтобы не отвлекать хост «по пустякам». При чтении из DR запрос устанавливается, когда в буфере имеется (16-яорог) байтов или же считан последний байт сектора. При записи в OR запрос первоначально устанавливается и удерживается до заполнения буфера, впоследствии он устанавливается снова, когда в буфере остается порог байтов. Переход в фазу результата происходит, когда завершается обмен хоста с DR и буфер опустошается. Общение с регистром DR при записи команд и параметров должно выполняться согласно значениям старших битов регистра MSR (буфер FIFO при этом не используется).&lt;br /&gt;</yandex:full-text>
</item><item>
<title>Интерфейс АТА/ATAPI (IDE)</title>
<link>http://intpc.ru/138-interfejjs-ataatapi-ide.html</link>
<description>Интерфейс ATA (AT Attachment for Disk Drives) разрабатывался в 1986-1990 гг. для подключения накопителей на жестких магнитных дисках к компьютерам IBM PC AT с шиной ISA.</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 17:46:07 +0300</pubDate>
<yandex:full-text>Интерфейс ATA (AT Attachment for Disk Drives) разрабатывался в 1986-1990 гг. для подключения накопителей на жестких магнитных дисках к компьютерам IBM PC AT с шиной ISA. Стандарт, выработанный комитетом ХЗТ10, определяет набор регистров устройств и назначение сигналов 40-контактного интерфейсного разъема. Интерфейс появился в результате переноса стандартного (для PC/AT) контроллера жесткого диска ближе к накопителю, то есть создания устройств со встроенным контроллером - IDE (Integrated Drive Electronics). Стандартный контроллер AT позволял подключать до двух накопителей, что в интерфейсе АТА означает параллельное подключение контроллеров двух устройств. В специфика-ции АТА фигурируют следующие компоненты.&lt;br /&gt;-	Хост-адаптер - средства сопряжения интерфейса АТА с шиной компьютера.&lt;br /&gt;Хостом мы будем называть компьютер с хост-адаптером интерфейса АТА.&lt;br /&gt;Хост-контроллер - более развитый вариант хост-адаптера.&lt;br /&gt;-	Ведущее устройство (Master) - ПУ, в спецификации АТА официально называемое Device-О (устройство 0).&lt;br /&gt;-	Ведомое устройство (Slave) - ПУ, в спецификации официально называемое Device-1 (устройство 1).&lt;br /&gt;Хост-адаптер и устройства объединяются кабелем-шлейфом, соединяющим параллельно одноименные контакты интерфейсных разъемов. Регистры обоих контроллеров оказываются расположенными в одних и тех же областях пространства ввода-вывода. Для выбора устройства, исполняющего текущую команду, используется бит выбора накопителя (DEV) в регистре номера устройства и головки (drive/head register). Если бит DEV4), выбрано ведущее устройство, если DEV=1 - ведомое. Запись в этот регистр воспринимается сразу обоими устройствами, на обращения к остальным регистрам реагирует только выбранное. Достаточно универсальный набор сигналов позволяет подключать любое устройство со встроенным контроллером, которому в пространстве портов ввода-вывода достаточно того же набора регистров, способное поддержать режим выбора устройства через вышеупомянутый бит. Принятая система команд и регистров, являющаяся частью спецификации АТА, ориентирована на блочный обмен данными с устрой-ствами прямого доступа. Для иных устройств существует спецификация AT API, основанная на тех же аппаратных средствах, но позволяющая обмениваться пакетами управляющей информации (Package Interface, PI). Структура и наполнение пакетов позаимствованы из универсального интерфейса SCSI. Пакетный интерфейс позволяет расширить границы применения шины АТА.&lt;br /&gt;Адресация в АТА имеет «дисковые корни»: для накопителей изначально указывали адрес цилиндра (cylinder), головки (head) и сектора (sector) - так называемая трехмерная адресация CHS. Сначала эта адресация точно соответствовала реальной геометрии - физически сектор действительно находился по указанному адресу. Позже по ряду причин диски АТА стали описывать внешней геометрией, отличающейся от реальной внутренней (например, разные зоны треков имеют разное число секторов, причем часть секторов может резервироваться на случай замены дефектных). При этом одно и то же устройство может иметь различную внешнюю геометрию. Преобразование адресов в реальные выполняется встроенным контроллером устройства. В системе CHS устройство АТА позволяет адресовать до 267 386 880 (65 536x16x255) секторов (блоков), что при размере сектора в 512 байт дает 136 902 082 560 байт (около 137 Гбайт). Позже пришли к линейной&lt;br /&gt;адресации логических блоков LBA (Logical Block Addressing), где адрес блока (сектора) определяется 28-битным числом, что позволяет адресовать до 268 435 455 (228) блоков (немного больше, чем в CHS). Для устройств AT А, поддерживающих и CHS, и LBA, режим адресации определяется для каждой команды битом L (бит 6) регистра D/H; режимы могут чередоваться произвольным образом. Устройства ATAPI используют принятую в SCSI 32-битную логическую адресацию, позволя-ющую адресовать до 2 Тбайт (при 512-байтном блоке).&lt;br /&gt;Если к шине АТА подключено одно устройство, оно должно быть ведущим. Если подключены два устройства, одно должно быть ведущим, другое - ведомым. О своей роли (ведущее или ведомое) устройства «узнают» с помощью предварительно установленных конфигурационных джамперов. Если применяется «кабельная выборка» (см. ниже), роль устройства определяется его положением на специальном ленточном кабеле. Оба устройства воспринимают команды от хост-адаптера одновременно. Однако исполнять команду будет лишь выбранное устройство. Выводить выходные сигналы на шину АТА имеет право только выбранное устройство. Такая система подразумевает, что, начав операцию обмена с одним из устройств, хост-адаптер не может переключиться на обслуживание другого до завершения начатой операции. Параллельно могут работать только устройства IDE, подключаемые к разным шинам (каналам) АТА. Спецификация АТА-4 определяет способ обхода этого ограничения, но эту возможность используют редко.&lt;br /&gt;Для устройств IDE существует несколько разновидностей интерфейса.&lt;br /&gt;-	АТА, он же AT-BUS, - 16-битный интерфейс подключения к шине компьютера AT. Наиболее распространенный 40-проводный сигнальный и 4-проводный питающий интерфейс для подключения дисковых накопителей к компьютерам AT. Для миниатюрных (2,5&quot; и менее) накопителей используют 44-проводный кабель, по которому передается и питание.&lt;br /&gt;-	PC Card ATA - 16-битный интерфейс с 68-контактным разъемом PC Card&lt;br /&gt;(PCMCIA) для подключения к блокнотным PC. XT IDE (8 бит), он же XT-BUS, - 40-проводный интерфейс, похожий на АТА, но несовместимый с ним.&lt;br /&gt;-	MCA IDE (16 бит) - 72-проводный интерфейс, предназначенный специально для шины и накопителей PS/2.&lt;br /&gt;-	АТА-2 - расширенная спецификация АТА. Включает 2 канала, 4 устройства, PIO Mode 3, Multiword DMA Mode 1, Block mode, объем диска до 8 Гбайт, поддержка LBA и CHS.&lt;br /&gt;-	Fast АТА-2 разрешает использовать Multiword DMA Mode 2 (13,3 Мбайт/с), PIO Mode 4.&lt;br /&gt;-	АТА-3 - расширение АТА-2. Включает средства парольной защиты, улучшенного управления питанием, самотестирования с предупреждением приближения отказа - SMART (Self Monitoring Analysis and Report Technology).&lt;br /&gt;-	ATA/ATAPI-4 - расширение АТА-3, включающее режим Ultra DMA со скоростью обмена до 33 Мбайт/с и пакетный интерфейс ATAPI. Появляется поддержка очередей и возможность перекрытия команд.&lt;br /&gt; &lt;br /&gt;-	ATA/ATAPI-5 - ревизия ATA/ATAPI-4: удаляются устаревшие команды&lt;br /&gt;и биты, добавляются новые возможности защиты и управления энергопотреб&lt;br /&gt;лением. Включает режим Ultra DMA со скоростью обмена до 66 Мбайт/с.&lt;br /&gt;-	ATA/ATAPI-6 - дополнения к ATA/ATAPI-5: потоковое расширение для чтения/записи аудио- и видеоданных, управление акустическим шумом, режим Ultra DMA со скоростью обмена до 100 Мбайт/с.&lt;br /&gt;-	Serial ATA - последовательный интерфейс.&lt;br /&gt;-	E-IDE (Enhanced IDE) - расширенный интерфейс, введенный фирмой Western Digital. Реализуется в адаптерах для шин PCI и VLB. Позволяет подключать до 4 устройств (к двум каналам), включая CD-ROM и стриммеры (ATAPI). Поддерживает РЮ Mode 3, Multiword DMA Mode 1, объем диска до 8 Гбайт, LBA и CHS. С аппаратной точки зрения практически полностью соответствует спецификации АТА-2.&lt;br /&gt;Устройства ATA IDE, E-IDE, АТА-2, Fast АТА-2, АТА-3^ ATA/ATAPI-4, ATA/ ATAPI-5 и ATA/ATAPI-6 электрически совместимы. Степень логической совместимости достаточно высока (все базовые возможности АТА доступны). Однако для полного использования всех расширений необходимо соответствие спецификаций устройств, хост-адаптера и его ПО.&lt;br /&gt;Разработкой спецификаций ATA/ATAPI занимается технический комитет Т13 американского Национального Комитета но стандартизации в области информационных технологий (NCITS). Разработанные им спецификации оформляются в виде стандартов ANSI. Спецификация ATA/ATAPI-6 объявлена последней версией параллельного интерфейса АТА, за которой следует последовательный интерфейс Serial ATA.&lt;br /&gt;</yandex:full-text>
</item><item>
<title>Параллельный интерфейс АТА</title>
<link>http://intpc.ru/139-parallelnyjj-interfejjs-ata.html</link>
<description>Параллельный интерфейс АТА представляет собой шину, в которой все сигналы соответствуют стандартной логике ТТЛ</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 19:34:26 +0300</pubDate>
<yandex:full-text>Параллельный интерфейс АТА представляет собой шину, в которой все сигналы соответствуют стандартной логике ТТЛ:&lt;br /&gt;-	высокий уровень выходного сигнала не ниже 2,4 В (при токе до 400 мкА, сигнал DMARQ - до 500 мкА), низкий уровень не выше 0,5 В (при токе 4 мА, для линии DASP ради совместимости со старыми устройствами - 12 мА);&lt;br /&gt;-	высокий уровень входного сигнала не ниже 2,0 В, низкий уровень не выше 0,8 В.&lt;br /&gt;Все информационные сигналы интерфейса передаются через 40-контактный разъем, у которого ключом является отсутствующий на вилке и закрытый на розетке контакт 20. Использование в качестве ключа выступа на корпусе розетки и прорези в бандаже вилки стандартом не приветствуется. Для соединения устройств применяется плоский многожильный кабель-шлейф, длина кабеля не должна превышать 0,46 м(18&quot;), допустимая емкость проводников - неболее 35 пФ. Терминаторы стандартом не предусматриваются (они имеются в каждом устройстве и хост-адаптере), но если кабель с тремя разъемами (розетками) используют для подключения одного устройства, то устройство и хост-адаптер рекомендуется подключать к противоположным концам кабеля. Состав информационных сигналов интерфейса АТА приведен в табл. 9.3, вид кабеля - на рис. 9.2. В большинстве кабелей одноименные контакты всех разъемов соединяются своими проводами и все коннекторы равноправны. Встречаются (редко) ленточные кабели с кабельной выборкой, изображенные на рис. 9.3. В них провод 28 перерезан, так что контакт 28 (CSEL) для ведущего устройства заземлен через хост-адаптер, а для ведомого - не подключен. Кабель должен соответствовать системе адресации, выбранной для обоих устройств.&lt;br /&gt;Таблица 9.3. Интерфейс ATA (IDE)&lt;br /&gt;&lt;br /&gt;Сигнал	Тип1	Контакт	Контакт	Тип1	Сигнал&lt;br /&gt;RESET#	1	1	2	-	GND&lt;br /&gt;DD7	I/OTS	3	4	I/OTS	DD8&lt;br /&gt;DD6	I/OTS	5	6	I/OTS	DD9&lt;br /&gt;DD5	I/OTS	7	8	I/O TS	DD10&lt;br /&gt;DD4	I/OTS	9	10	I/OTS	DD11&lt;br /&gt;DD3	I/OTS	11	12	I/O TS	DD12&lt;br /&gt;DD2	I/OTS	13	14	I/OTS	DD13&lt;br /&gt;DD1	I/OTS	15	16	I/OTS	DD14&lt;br /&gt;DDO	I/OTS	17	18	I/OTS	DD15&lt;br /&gt;GND	-	19	20	-	Ключ (нет штырька)&lt;br /&gt;DMARQ	OTS2	21	22	-	GND&lt;br /&gt;DlOWtf/STOP3	1	23	24	-	GND&lt;br /&gt;DIOR#/HDMARDY#/HSTROBE3	1	25	26	-	GND&lt;br /&gt;IORDY/DDMARDY#/DSTROBE3	OTS2	27	28	I/O	SPSYNC/CSEL7&lt;br /&gt;DMACK#	1	29	30	-	GND&lt;br /&gt;INTRQ	OTS2	31	32	ОOK	IOCS16#8&lt;br /&gt;DA1	1	33	34	I,O&gt;	PDIAG#/CBLID3&lt;br /&gt;DAO	1	35	36	1	DA2&lt;br /&gt;CSO#	1	37	38	1	CS1#&lt;br /&gt;DASP#	I/O OK5	39	40	-	GND&lt;br /&gt;+5 В (Logic)	-	41е	426	-	+5 В (Motor)&lt;br /&gt;GND	-	436	446	-	Зарезервирован&lt;br /&gt;1	Тип сигнала для устройства: I - вход, О- выход, I/O - двунаправленный, TS - тристабильный, ОК -&lt;br /&gt;открытый коллектор. Для хост-адаптера значения I и О имеют противоположный смысл.&lt;br /&gt;2	У старых устройств сигнал может иметь тип ОК (при разнотипных сигналах на одной шине возможен&lt;br /&gt;конфликт).&lt;br /&gt;3	Сигналы, приведенные после символа /,используются только в режиме Ultra DMA (AT A-4).&lt;br /&gt;4	У ведущего устройства -&#039; вход, у ведомого - выход.&lt;br /&gt;5	У ведомого устройства - только выход.&lt;br /&gt;6	Контакты 41-44 используются только для миниатюрных дисков.&lt;br /&gt;7	Начиная с АТА-3 - только CSEL.&lt;br /&gt;8	Начиная с АТ А-3 зарезервирован.&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;Начиная с ATA/ATAPI-4 в шлейфах узаконили кабельную выборку и для подключения устройства 1 определили средний коннектор. В нем контакт 28 либо не соединен с проводом, либо просто отсутствует. Вполне понятно, что при использовании кабельной выборки хост-контроллер подключать к среднему коннектору нельзя (как и к правому на рис. 9.3). Если номер устройства назначается джампером, то для 40-проводного кабеля можно подключать устройства и хост-контроллер к любым коннекторам произвольно (но желательно избегать «висячих» концов).&lt;br /&gt;&lt;br /&gt;Для устойчивой работы в режиме Ultra DMA рекомендуется применение 80-про-водных кабелей, обеспечивающих чередование сигнальных цепей и проводов схемной земли (GND). Такие кабели требуются для режимов UltraDMA выше 2 (скорость выше 33 Мбайт/с). Эти кабели разделываются на специальные разъемы, имеющие 40-контактные гнезда с обычным назначением контактов, но ножевые контакты для врезки 80 проводов. В шлейфе для схемной земли используются либо все четные, либо все нечетные провода - это зависит от применяемых разъемов (на них должна быть маркировка EVN GND или ODD GND соответственно). Установка&lt;br /&gt;на одном шлейфе разнотипных разъемов недопустима (тогда все 80 проводов окажутся соединенными вместе). На 80-проводном кабеле в разъеме для подключения контроллера контакт 34 соединен с шиной GND и не соединен с проводом шлейфа; этим обеспечивается идентификация типа кабеля (CBLID). Провод шлейфа соединяет контакты 34 разъемов устройств, что обеспечивает прохождение сигнала PDIAG* от ведомого устройства к ведущему. С учетом возможности кабельной выборки на 80-проводном шлейфе положение коннекторов уже однозначно.&lt;br /&gt;-	Коннектор хост-контроллера расположен на конце шлейфа, у него контакт 34 заземлен и не соединен со шлейфом. Корпус коннектора должен быть синего цвета .&lt;br /&gt;-	Коннектор устройства 0 расположен на противоположном конце шлейфа, у&lt;br /&gt;него все контакты соединены со шлейфом. Корпус коннектора должен быть&lt;br /&gt;черного цвета.&lt;br /&gt;-	Коннектор устройства 1 (необязательный) расположен в середине шлейфа, у него контакт 28 не соединен со шлейфом. Корпус коннектора должен быть серого цвета.&lt;br /&gt;Если кабельная выборка не используется, то устройства 0 и 1 можно менять местами.&lt;br /&gt;Спецификация АТА «узаконивает» как 40-контактный интерфейсный разъем, так и 4-контактный разъем питания (рис. 9.4), но для малогабаритных устройств питание может подаваться по 44-проводному интерфейсному кабелю.&lt;br /&gt; &lt;br /&gt;				А			         б&lt;br /&gt; 9.4. Разъемы интерфейса АТА (вилки на устройствах): а - интерфейсный, б - питания&lt;br /&gt;Для большинства устройств применяется 40-контактный разъем с шагом контактов 2,54 мм. Рядом с ним могут располагаться дополнительные контакты, служащие для конфигурирования устройства и технологических целей (диагностики и других операций по служебному последовательному интерфейсу). Спецификация AT A/ AT API предусматривает два варианта, приведенные на рис. 9.5, а и б. Здесь пустым квадратиком обозначены позиции ключевых (пропущенных) выводов, контакты 1-40 используются для интерфейса (см. табл. 9.3), а контакты А-Н - для установки джамперов (табл. 9.4) и технологических целей. Для миниатюрных устройств предназначен 50-контактный разъем с шагом выводов 2 мм (рис. 9.5, в), у которого контакты 1-44 соответствуют табл. 9.3, контакты A-D - табл. 9.4 (используются для конфигурирования, а пара пропущенных контактов является до-полнительным ключом). Для 50-контактного кабеля принято назначение выводов накопителей IBM Thinkpad/Travelstar:&lt;br /&gt;-	контакт А через резистор 10 кОм соединяется с шиной +5 В;&lt;br /&gt;-	контакт В для устройства задает его роль: низкий уровень - устройство 0, высокий - устройство 1;&lt;br /&gt;-	контакт С определяет режим устройства по включении питания: низкий уро&lt;br /&gt;вень - Standby, высокий - Idle;&lt;br /&gt;-	контакт D соединяется с контактом 28 (CSEL) и через резистор 10 кОм - с шиной +5 В.&lt;br /&gt;Это назначение, позволяющее конфигурировать и адресацию, и режим потребления, применяется не на всех устройствах. На винчестерах фирмы Toshiba контакты А и В могут использоваться как выход и вход последовательного интерфейса (В подтянут к шине +5 В через резистор 47 кОм), С - GND, D - роль устройства (низкий уровень для устройства 1).&lt;br /&gt; &lt;br /&gt; 9.5. Дополнительные контакты на разъемах интерфейса АТА: а - SFF8057, б - SFF8058, в - SFF8212 (50-контактный разъем)&lt;br /&gt;Таблица 9.4. Использование дополнительных контактов&lt;br /&gt;&lt;br /&gt;Выборка	SFF8057	SFF8058	SFF8212	Toshiba (1996)&lt;br /&gt;Используемые контакты	Е-Н	A-F	A-D	A-D&lt;br /&gt;Кабельная выборка	E-F	A-B	B-D	B-D&lt;br /&gt;Master	G-H	E-F	-	-&lt;br /&gt;Master при наличии Slave	G-H,E-F	E-F	-	-&lt;br /&gt;Slave	-	C-D	A-B	C-D&lt;br /&gt;Для малогабаритных внешних устройств-существует довольно распространенный разъем HP 36, но в спецификацию ATA/ATAPI он не входит. Для устройств хранения на флэш-памяти используется коннектор, соответствующий спецификации CompactFlash Association.&lt;br /&gt;В документации на устройства могут быть указаны несколько отличающиеся обозначения сигналов. Здесь приведены обозначения из стандарта ATA/ATAPI-4.&lt;br /&gt;- RESET* (Device Reset) - сброс устройства (инвертированный сигнал сброса системной шины). Сигнал длительностью не менее 25 мкс вырабатывается после установления питающих напряжений. Сигнал вызывает сброс интерфейса в исходное состояние и устанавливает параметры по умолчанию.&lt;br /&gt; &lt;br /&gt;Э.2. Интерфейс АТА/ATAPI (IDE)        	367&lt;br /&gt;-	DA[2:0] (Device Address) - три младших бита системной шины адреса, используемые для выбора регистров устройств.&lt;br /&gt;-	DD[15:0] (Device Data) - двунаправленная 16-битная шина данных между адаптером и устройствами. При 8-битных обменах используются младшие биты D[7:0]. У устройства не должно быть «подтягивающего» резистора на линии DD7 - на хост-контроллере эта линия через резистор 10 кОм соединена с шиной GND. Это позволяет хосту определить факт отсутствия устройства на шине сразу после аппаратного сброса: при чтении регистра состояния отсутству-ющего устройства бит BSY окажется сброшенным.&lt;br /&gt;-	DIOR* (Device I/O Read) - строб чтения портов ввода-вывода. Данные фиксируются по положительному перепаду сигнала.&lt;br /&gt;-	DIOW# (Device I/O Write) - строб записи портов ввода-вывода. Данные фиксируются по положительному перепаду сигнала.&lt;br /&gt;-	IORDY (I/O channel Ready) - готовность устройства завершить цикл обмена. Низким уровнем сигнала во время цикла обмена устройство может ввести такты ожидания шины. Сигнал требуется при обмене в РЮ Mode 3 и выше. На хост-контроллере эта линия через резистор 1 кОм должна подтягиваться к шине питания.&lt;br /&gt;-	IOCS16* - разрешение 16-битных операций. Обращение ко всем регистрам, кроме регистра данных, всегда 8-битное. Для РЮ Mode 0,1,2 при активном сигнале обращения 16-битные, при неактивном - 8-битные. Для РЮ Mode 3,4 и DMA все обмены 16-битные, кроме дополнительных байтов (выходящих за границу 512-байтного сектора) «длинного» считывания и записи. Начиная с ATA/ATAPI-3 не используется.&lt;br /&gt;-	DMARQ (DMA Request) - запрос обмена по каналу DMA (необязательный). При разрешении обмена сигнал (высокий уровень) вводится устройством по готовности к обмену. Введя сигнал DMARQ, устройство должно дождаться подтверждения от хост-адаптера сигналом DMACK*, после чего может снять запрос DMARQ. Для очередной передачи запрос должен быть введен снова. В режиме Multiword DMA запрос может удерживаться на время передачи всех данных. Выход должен быть тристабильным, во время работы с DMA он может быть в активном состоянии (0 или 1) только у выбранного устройства. В АТА-1 для&lt;br /&gt;этого сигнала мог использоваться как тристабильный, так и стандартный ТТЛ-&lt;br /&gt;выход. Работа на одной шине устройств с разнотипными выходами DMARQ может привести к конфликтам. На хост-контроллере линия должна соединяться с шиной GND через резистор 5,6 кОм.&lt;br /&gt;-	DMACK# (DMA Acknowledge) - подтверждение DMA. Сигнал вырабатывается хост-адаптером как подтверждение цикла передачи. Передача слова данных управляется сигналами DIOR* или DIOW*. Во время обмена по каналу DMA сигналы IOCS16#, CSO# и CS1# не используются, обмен всегда производится 16-битными словами.&lt;br /&gt;-	INTRQ (Interrupt Request) - запрос прерывания. Выход должен быть тристабильным, активный сигнал (логическую единицу) вырабатывает только вы-&lt;br /&gt; &lt;br /&gt;368	Глава 9. Интерфейсы устройств хранения&lt;br /&gt;бранное устройство, когда у него имеется необслуженный запрос прерывания и его вырабатывание не запрещено битом n IE N в регистре Device Control.Запрос сбрасывается по сигналу RESET*, установке бита SRST в регистре Devi се Control, записи в регистр команд или чтении регистра состояния. При обменах PIO запрос устанавливается в начале передачи каждого блока (сектора или группы секторов при многосекторных операциях). Исключения: по командам Format Track, Write Sector(S),Write Buffer и Write Long в начале пере-дачи первого блока данных запрос прерывания не вырабатывается. При обменах DMA запрос прерывания вырабатывается только по завершении операции. На хост-контроллере эта линия через резистор 10 кОм должна подтягиваться к шине GND.&lt;br /&gt;-	CSO# (Chip Select 0) - сигнал выбора блока командных регистров (Command Block Registers). Для первого канала он вырабатывается при наличии на системной шине адреса порта ввода-вывода в диапазоне !FOh-lF7h (сигнал так же называют CS1FX*).&lt;br /&gt;-	CS1# (Chip Select 1) - выбор блока управляющих регистров (Control Block&lt;br /&gt;Registers). Для первого канала он вырабатывается при наличии на системной шине адреса порта ввода-вывода в диапазоне 3F6h-3F7h (часто этот сигнал называется CS3FX*).&lt;br /&gt;-	PDIAG* (Passed Diagnostics) - сигнал о прохождении диагностики. Ведущее устройство наблюдает за этим сигналом, который ведомое устройство должно выработать в ответ на сброс или команду диагностики. Если ведомое устройство обнаружено (по сигналу DASP#), ведущее устройство ожидает сигнал в течение 31с после сброса и 6 с после команды диагностики. Если за это время сигнал не появился, ведущее устройство отмечает этот факт установкой бита 7 регистра ошибок. Если ведомое устройство не обнаружено, ведущее обнуляет регистр состояния ведомого устройства и сообщает свое состояние сразу после завершения собственной самодиагностики. Сигнал служит только для связи двух устройств и хост-адаптером не используется (в АТА-4 контакт задействован для сигнала CBLID*).&lt;br /&gt;-	CBLID* (Cable assembly type identifier) - идентификация типа кабеля. В 80-проводной сборке контакт 34 на разъеме хост-адаптера соединяется с шиной GND, а контакты 34 разъемов устройств соединяются между собой, но связи с разъемом хост-адаптера не имеют. На устройстве эта линия через резистор 10 кОм должна подтягиваться к шине питания. После прохождения сброса (когда сиг-нал PDIAG* снимается) хост может определить наличие 80-проводного кабеля по низкому уровню сигнала.&lt;br /&gt;-	DASP# (Device Active, Slave Present) - сигнал двойного назначения: индикатор активности устройства и присутствия ведомого устройства. Устройства имеют выход типа «открытый коллектор» с нагрузочным резистором 10 кОм к шине +5 В. После сброса по сигналу RESET* или при инициализации по включении питания оба устройства в течение 1 мс должны деактивировать этот сигнал, после чего не позже чем через 400 мс его вводит ведомое устройство для сообщения о своем присутствии. Ведущее устройство не активирует этот сиг-&lt;br /&gt; &lt;br /&gt;9.2. Интерфейс АТА/ATAPI (IDE)		369&lt;br /&gt;нал в течение 450 мс. Сигнал деактивируется ведомым устройством после получения им команды или через 31 с автоматически (смотря что произойдет раньше). После этого сигнал может быть введен любым устройством как индикатор активности. Адаптер использует этот сигнал для включения светодиодного индикатора доступа к диску.&lt;br /&gt;-	SPSYNC/CSEL (Spindle Synchronization/Cable Select) - синхронизация шпинделя или выборка кабелем. Сигнал двойного назначения, которое должно быть единым для обоих устройств. Сигнал SPSYNC позволяет синхронизировать шпиндели устройств (актуально для RAID-массивов); используется по усмотрению производителя накопителя, начиная с ATA/ATAPI-3 этот сигнал из спецификации изъят. Сигнал CSEL позволяет устройствам определять свой адрес по положению на специальном кабеле с разрывом провода 28 между разъемами двух устройств (малораспространенная «кабельная выборка»). Эта линия на хост-адаптере заземлена, и ведущее устройство получает заземленную линию, а ведомое - неподключенную. На устройстве линия подтягивается к высокому уровню резистором 10 кОм. Состояние сигнала (если он управляется хост-адаптером) должно удерживаться по крайней мере 31с после сигнала RESET*.&lt;br /&gt;При использовании режима Ultra DMA четыре линии получают новое назначение сигналов.&lt;br /&gt;-	STOP (Stop Ultra DMA burst) - останов передачи пакета Ultra DMA.&lt;br /&gt;-	DDMARDY* (Device Ultra DMA ready) - готовность устройства при приеме пакета Ultra DMA (управление потоком).&lt;br /&gt;-	DSTROBE (Host Ultra DMA data strobe) - строб данных устройства при передаче пакета хосту. Данные передаются по обоим перепадам DSTROBE.&lt;br /&gt;-	HDMARDY* (Host Ultra DMA ready) - готовность хоста при приеме им пакета Ultra DMA (управление потоком).&lt;br /&gt;-	HSTROBE (Host Ultra DMA data strobe) - строб данных хоста при передаче пакета устройству. Данные передаются по обоим перепадам HSTROBE.&lt;br /&gt;Для блокнотных ПК в стандарте имеется вариант интерфейса IDE на 68-контактном разъеме PCMCIA (PC Card), приведенный в табл. 9.5. Здесь имеется ряд специфичных сигналов.&lt;br /&gt;-	SELATA* (Select 68-pin ATA) - сигнал, которым хост идентифицирует режим использования разъема, PC Card (сигнал снят) или АТА (сигнал установлен, то есть низкий уровень). Этот сигнал хост должен установить до подачи питания на коннектор. В течение 19 мс после подачи питания устройство игнорирует все интерфейсные сигналы, кроме этого. Если этот сигнал активен, то устройство должно сконфигурироваться на режим АТА. Если сигнал неактивен, оно должно сконфигурироваться на режим PC Card или не отвечать на другие сигналы хоста.&lt;br /&gt;-	CD1 # и CD2# (Card Detect) заземляются в устройстве - по этим сигналам хост определяет присутствие устройства.&lt;br /&gt;-	CS1# (Device chip select 1) - выбор устройства, подается хостом на оба контакта (Ни 42), но устройство воспринимает только один из них. &lt;br /&gt;-	DMARQ, DMACK* и IORDY - не обязательны для использования.&lt;br /&gt;-	M/S# (Master/Slave) - инверсия сигнала CSEL. Хост выдает сигналы M/S# и CSEL до подачи питания, устройство воспринимает лишь один из них.&lt;br /&gt;Для обеспечения «горячего» подключения разъем для цепи GND обеспечивает более раннее соединение при подключении и более позднее при отключении. В устройстве сигналы CSO#, CS1#, RESET* и SELATA* подтягиваются к пассивному состоянию.&lt;br /&gt;Таблица 9.5.68-контактный интерфейс АТА для PC Card (PCMCIA) Контакт   Сигнал    Контакт   Сигнал&lt;br /&gt;&lt;br /&gt;1	GND	35	GND&lt;br /&gt;2	DD3	36	CD1#&lt;br /&gt;3	DD4	37	DD11&lt;br /&gt;4	DD5	38	DD12&lt;br /&gt;5	DD6	39	DD13&lt;br /&gt;6	DD7	40	DD14&lt;br /&gt;7	CSO#	41	DD15&lt;br /&gt;8		42	CS1#&lt;br /&gt;9	SELATA*	43	&lt;br /&gt;10		44	DIOR#&lt;br /&gt;11	CS1#	45	DIOW#&lt;br /&gt;12		46	&lt;br /&gt;13		47	&lt;br /&gt;14		48	&lt;br /&gt;15		49	&lt;br /&gt;16	INTRQ	50	&lt;br /&gt;17	+5 В	51	+5 В&lt;br /&gt;18		52	&lt;br /&gt;19		53	&lt;br /&gt;20		54	&lt;br /&gt;21		55	M/S#&lt;br /&gt;22		56	CSEL&lt;br /&gt;23		57	&lt;br /&gt;24		58	RESET#&lt;br /&gt;25		59	IORDY*&lt;br /&gt;26		60	DMARQ&lt;br /&gt;27	DA2	61	DMACK#&lt;br /&gt;28	DA1	62	DASP#&lt;br /&gt;29	DAO	63	PDIAG*&lt;br /&gt;30	DDO	64	DD8&lt;br /&gt;31	DD1	65	DD9&lt;br /&gt;32	DD2	66	DD10&lt;br /&gt;33		67	CD2#&lt;br /&gt;34	GND	68	GND&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;Для компьютеров класса ЛТ существует 8-битная версия интерфейса, называемая XT-IDE, реже - XT-Bus. Этот интерфейс [2,5], как и AT А, реализован на 40-провод-ном кабеле, и многие его сигналы совпадают с 16-битной шиной AT А. Интерфейс XT-IDE можно рассматривать как подмножество AT А, хотя прямой совместимости нет. Ряд устройств АТА имеют джампер выбора режима XT/AT (в накопителях Seagate на это указывает окончание «АХ» в обозначении модели).&lt;br /&gt;Регистры устройств&lt;br /&gt;Каждое устройство АТА имеет стандартный набор регистров, адресуемых сигналами от хост-адаптера (CSO#, CS1#, DA2, DA1, ОАО, DIOR* и DIOW#). Набор регистров (табл. 9.6) состоит из двух блоков, выбираемых сигналами CSO# и CS1#, из которых активным (низкий уровень, «О») может быть только один. В таблице приведены адреса регистров в пространстве ввода-вывода IBM PC-совместимого ПК для первого и второго каналов АТА. При обращении к регистрам сигнал DMACK* должен быть неактивным. Блок командных регистров служит для посылки команд устройству и чтения информации о его состоянии. Блок управляющих регистров используется для управления устройством и получения более подробной информации о его состоянии. На действительность содержимого регистров командного блока и альтернативного регистра состояния указывает нулевое значение бита BSY регистра состояния. Запись в регистры должна производиться лишь при BSY=0 и DRQ=0, кроме особо оговоренных случаев. Если устройство поддерживает управление энергопотреблением, в «спящем» режиме содержимое этих регистров недействительно и запись игнорируется, кроме особо оговоренных случаев.&lt;br /&gt;Таблица 9.6. Регистры контроллеров устройств АТА&lt;br /&gt;&lt;br /&gt;Адрес	Сигналы адресации канала №	Назначение (R - чтение, W - запись)&lt;br /&gt;		(0 - низкий уровень, 1 - высокий)&lt;br /&gt;1	2	CSO#	CS1#	DA2	DA2   DA1О	&lt;br /&gt;		1	1	X	X          X	Нет обращения (шина данных в третьем&lt;br /&gt;						состоянии)&lt;br /&gt;		0	0	X	x      X	Недопустимый адрес (шина данных в третьем&lt;br /&gt;						состоянии)&lt;br /&gt;3FX	37Х	Control Block Registers - блок управляющих регистров&lt;br /&gt;		1	0	0	X         X	Не используется (шина данных в третьем&lt;br /&gt;						состоянии)&lt;br /&gt;		1	0	1	0      X	Не используется (шина данных в третьем&lt;br /&gt;						состоянии)&lt;br /&gt;3F6	376	1	0	1	1       0	R: Alternate Status (AS) - альтернативный&lt;br /&gt;						регистр состояния&lt;br /&gt;3F6	376	1	0	1	1       0	W: Device Control (DC) - регистр управления&lt;br /&gt;						устройством&lt;br /&gt;3F7	377	1	0	1	1       1	R: Drive Address (DA) - регистр адреса&lt;br /&gt;						(не используется)1&lt;br /&gt;продолжение^&lt;br /&gt; &lt;br /&gt;372	Глава 9. Интерфейсы устройств хранения&lt;br /&gt;Таблица 9.6. (продолжение)&lt;br /&gt;Адрес      Сигналы адресации канала №      Назначение (R - чтение, W - запись) (0 - низкий уровень, 1 - высокий)&lt;br /&gt;1      2      CSO# CS1#   DA2   DA1   ОАО	&lt;br /&gt;1FX  17Х   Command Block Registers - блок командных регистров&lt;br /&gt;1F0	170	0	1	0	0	0&lt;br /&gt;1F1	171	0	1	0	0	1&lt;br /&gt;1F1	171	0	1	0	0	1&lt;br /&gt;1F2	172	0	1	0	1	0&lt;br /&gt;1F3	173	0	1	0	1	1&lt;br /&gt;1F4	174	0	1	1	0	0&lt;br /&gt;1F5	175	0	1	1	0	1&lt;br /&gt;1F6	176	0	1	1	1	0&lt;br /&gt;1F7	177	0	1	1	1	1&lt;br /&gt;1F7	177	0	1	1	1	1&lt;br /&gt;R/W: Data (DR) - регистр данных&lt;br /&gt;R: Error (ER) - регистр ошибок &lt;br /&gt;W: Features (FR) - регистр свойств&lt;br /&gt;R/W: Sector Count (SC) - регистр счетчика секторов&lt;br /&gt;&lt;br /&gt;R/W: Sector Number (SN) - регистр номера&lt;br /&gt;сектора/LBA[7:0]2&lt;br /&gt;R/W: Cylinder Low (CL) - регистр младшего&lt;br /&gt;байта номера цилиндраДВА[15:8]2&lt;br /&gt;R/W: Cylinder High (CH) - регистр старшего байта номера цилиндра/1-ВА[23:1 б]2&lt;br /&gt;R/W: Device/Head (D/H) - регистр номера устройства и головки/1_ВА[27:24]2&lt;br /&gt;R: Status (SR) - регистр состояния &lt;br /&gt;W: Command (CR) - регистр команд&lt;br /&gt;1	Рекомендуется, чтобы на сигнал чтения по этому адресу устройство не отвечало.&lt;br /&gt;2	Регистры сектора, цилиндра и головки в режиме LBA содержат указанные биты логического адреса.&lt;br /&gt;Альтернативный регистр состояния AS (для первого канала адрес 3F6h, для второго - 376h) имеет те же биты, что и основной (см. ниже), но его чтение не приводит ни к каким изменениям состояния устройства.&lt;br /&gt;Регистр управления устройством DC (3F6h, 376h) служит для программного сброса обоих устройств одновременно и управления разрешением прерывания выбранного устройства. Запись в этот регистр возможна в любой момент. Программный сброс через регистр DC должен отрабатываться ив состоянии Sleep. Назначение битов регистра DC:&lt;br /&gt;-	биты [7:3] зарезервированы;&lt;br /&gt;-	бит 2 - SRST (Software Reset) - программный сброс, действует все время, пока бит не будет снят (оба устройства на шине воспринимают программный сброс одновременно);&lt;br /&gt;-	бит 1 - n IE N (Interrupt Enable) - инверсный бит разрешения прерывания (при нулевом значении бита выбранное устройство может вырабатывать сигнал INTRQ через тристабильный выход);&lt;br /&gt;-	бит 0 - 0.&lt;br /&gt;Регистр адреса устройства DA (3F7h, 377h) использовался только в первой версии АТА для совместимости со старыми контроллерами, чтением этого регистра можно было определить адресованный привод и головку. Регистр выпадает из блока (он совпадает с диагностическим регистром состояния онтроллера НГМД)&lt;br /&gt; &lt;br /&gt;9.2. Интерфейс АТА/ATAPI (IDE)	373&lt;br /&gt;и рекомендуется, чтобы устройство АТА не отвечало на чтение этого регистра. Если устройство отвечает на чтение, то оно не должно управлять битом DD7 во избежание конфликта с контроллером НГМД, у которого по этой линии передается бит смены носителя. Из-за несоблюдения этого требования могут возникать проблемы, когда контроллер (адаптер) АТА и контроллер НГМД находятся на разных платах. Назначение битов регистра DA:&lt;br /&gt;-	бит 7 - (HiZ) - высокоимпедансный, при считывании не выдается на шину;&lt;br /&gt;-	бит 6 - nWTG - инверсный признак записи (во время физического выполнения записи на носитель бит нулевой);&lt;br /&gt;-	биты [5:2] - nHS [3 :0] - номер головки (инверсные биты);&lt;br /&gt;-	биты [1:0] - nDS [1:0] - выбор устройства (инверсные биты): 10 - выбрано устройство 0, 01 - выбрано устройство 1.&lt;br /&gt;Регистр данных DR (IFOh, 170h) может использоваться как 8-битный или 16-битный в зависимости от типа данных, передаваемых в текущей команде. Обращение к этому регистру происходит в режиме обмена РЮ (когда сигнал DMACK* неактивен), при выполнении передач протокола РО (РЮ Out) хост производит запись в этот регистр, при PI (РЮ In) - чтение. В режиме DMA обмен данными происходит через порт данных, при этом активны сигналы DMARQ и DMACK*, а сигналы CSO# и CS1# неактивны.&lt;br /&gt;Регистр ошибок ER (IFlh, 171h) хранит состояние выполнения последней операции или диагностический код. После завершения операции на наличие ошибки указывает бит ERR регистра состояния.&lt;br /&gt;Назначение битов регистра ER:&lt;br /&gt;-	бит 7 - зарезервирован;&lt;br /&gt;-	бит 6 - UNC (Uncorrectable Data Error) - неисправимая ошибка данных;&lt;br /&gt;-	бит 5 - МС (Media Changed) - смена носителя (после смены носителя первая команда обращения отвергается и устанавливается данный бит, после сброса бита следующие команды будут выполняться нормальным образом);&lt;br /&gt;-	бит 4 - IDN F (ID Not Found) - указывает на ненайденный идентификатор сектора;&lt;br /&gt;-	бит 3 - MCR (Media Change Requested) - индикатор запроса смены носителя (после обнаружения запроса смены носителя команды Door Lock будут возвращать бит ошибки ERR и бит MCR, бит MCR сбрасывается командами Door Unlock, Medi a Ej ect или сигналом аппаратного сброса);&lt;br /&gt;-	бит 2 - ABRT (Aborted Command) - устанавливается, если команда отвергнута как недействительная или в случае возникновения иной ошибки;&lt;br /&gt;-	бит 1 -TK0NF (Track ONot Found) -указываетна то, что по команде Recalibrate не удалось найти нулевой трек;&lt;br /&gt;-	бит 0 - AMNF (Address Mark Not Found) - не найден адресный маркер данных в заголовке сектора.&lt;br /&gt; &lt;br /&gt;После выполнения любого сброса или команды Execute Device Diagnostic регистр ошибок содержит диагностический код. Трактовка битов, за исключением бита 2 (ABRT), может меняться в зависимости от исполненной команды.&lt;br /&gt;Регистр свойств FR (IFlh, 171h) используется в зависимости от команды. В команде Set Features через него задается код подкоманды. Некоторые старые устройства могут игнорировать запись в этот регистр. До принятия спецификации АТА-2 в этот регистр помещали значение рекомендуемого номера цилиндра для предкомпен-сации записи.&lt;br /&gt;Регистр счетчика секторов SC (lF2h, 172h) содержит число секторов, участвующих в обмене. Хост инициализирует этот регистр до подачи команды (нулевое значение соответствует 256 секторам). По успешному завершению операции доступа к данным регистр должен обнулиться. Если команда завершилась с ошибкой, в регистре будет число секторов, которые должны быть переданы для успешного завершения предыдущего запроса. Команды Initialize Device Parameters или Write Same могут переопределить значение этого регистра. В некоторых командах регистр используется для передачи иных параметров.&lt;br /&gt;Регистры номера сектора S N (1 F3h, 173h) и номера цилиндра - младшего С L (1 F4h, 174h) и старшего байта СН (lF5h, 175h) - имеют двоякое назначение в зависимости от выбранной системы адресации (CHS или LEA). Они инициализируются хост-адаптером, а в случае возникновения ошибки при выполнении операции устройство поместит в них адрес, по которому встретилась ошибка.&lt;br /&gt;Регистр номера устройства и головки D/H (IFGh, 176h) кроме хранения части адресной информации служит для выбора ведущего или ведомого устройства и метода адресации.&lt;br /&gt;Назначение битов регистра D/H:&lt;br /&gt;-	биты 7 и 5 вплоть до АТА-3 должны были быть единичными, в AT A/ AT API -4 их объявили устаревшими;&lt;br /&gt;-	бит 6 - L - единичным значением указывает на применение режима адресации LBA, при нулевом значении бита используется режим CHS;&lt;br /&gt;-	бит 4 - DEV (Device) - выбор устройства, при DEV=0 выбрано ведущее, при DEV=1 - ведомое;&lt;br /&gt;-	биты [3:0] имеют двоякое назначение в зависимости от выбранной системы&lt;br /&gt;адресации, в режиме CHS они содержат номер головки, в режиме LBA - старшие биты логического адреса.&lt;br /&gt;Как и предыдущие (5М,СНИС1_), адресный регистр D/H инициализируется хост-адаптером, а в случае возникновения ошибки при операции устройство поместит в них адрес, по которому встретилась ошибка. До принятия спецификации АТА-2 считалось, что адресные регистры должны модифицироваться и после успешного выполнения операции, отражая текущее значение адреса в носителе. Регистр состояния S R (l F7h, 177h) отражает текущее состояние устройства в процессе выполнения команд: занятость, готовность, наличие ошибок и др. Чтение регистра состояния разрешает дальнейшее изменение его битов и сбрасывает запрос аппаратного прерывания.&lt;br /&gt; &lt;br /&gt;9.2. Интерфейс АТА/ATAPI (IDE)    	375&lt;br /&gt;Назначение битов регистра SR описано ниже.&lt;br /&gt;-	Бит 7 - BSY (Busy) указывает на занятость устройства, значение этого бита действительно всегда. При BSY=1 устройство игнорирует попытки записи в командный блок регистров, а чтение этих регистров дает неопределенный результат. При BSY=0 регистры командного блока доступны, в это время устройство не может устанавливать бит DRQ, изменять значение битов Е RR и содержимое остальных командных регистров (могут меняться только значения битов IDX, DRDY, DF,&lt;br /&gt;DSC и CORR). Бит может устанавливаться на кратковременный интервал, так что хост может этого не заметить. Бит устанавливается:&lt;br /&gt;•	при сбросе устройства;&lt;br /&gt;•	по получении команды, если не устанавливается DRQ;&lt;br /&gt;•	между передачами блоков данных в режиме РЮ и после них, пока не обнулился DRQ;&lt;br /&gt;•	во время передач данных в режиме DMA.&lt;br /&gt;&lt;br /&gt;-	Бит 6 - DRDY (Device Ready) указывает на готовность устройства к восприятию любых кодов команд. Если состояние бита изменилось, оно не может вернуться обратно до чтения регистра состояния. При DRDY=0 устройство воспринимает только команды Execute Device Diagnostic и Initialize Device Parameters, прекращая выполнение текущей команды и сообщая об этом флагом ABRT в регистре ошибок и флагом ERR в регистре состояния. Другие команды приводят к непредсказуемым результатам. Устройства AT API сбрасывают бит по любому сбросу и команде Execute Device Diagnostic. Бит устанавливается устройством AT A, когда оно готово к выполнению всех команд. Устройство AT API устанавливает бит до завершения выполнения команд, за исключением команд Device Reset и Execute Device Diagnostic.&lt;br /&gt;-	Бит 5 - DF (Device Fault) - индикатор отказа устройства.&lt;br /&gt;-	Бит 4 - DSC (Device Seek Complete) - индикатор завершения поиска трека. В командах, допускающих перекрытие, бит называется SERV (Service Required) - устройство требует обслуживания.&lt;br /&gt;-	Бит 3 - DRQ (Data Request) - индикатор готовности к обмену словом или байтом данных.&lt;br /&gt;-	Бит 2 - CORR (Corrected Data) - индикатор исправленной ошибки данных.&lt;br /&gt;-	Бит 1 - I DX (Index) - индекс, трактуется особо каждым производителем.&lt;br /&gt;-	Бит 0 - ERR (Error) - индикатор ошибки выполнения предыдущей операции.&lt;br /&gt;Дополнительная информация содержится в регистре ошибок. Если установ&lt;br /&gt;лен бит ERR, до приема следующей команды, программного или аппаратного сброса устройство не изменит состояние этого бита, а также регистра ошибок, регистра количества секторов и регистров цилиндра, головки и номера сектора. Для команд PacketnService бит называется СНК и служит признаком исключительной ситуации.&lt;br /&gt;В стандарте ATA/ATAPI-4 для некоторых команд биты 4 и 5 могут иметь иное назначение, а биты 1 и 2 объявлены устаревшими.&lt;br /&gt; &lt;br /&gt; &lt;br /&gt;Назначение регистра команд CR (lF7h, 177h) очевидно из названия. Устройство начинает исполнять команду сразу, как только ее код записан в данный регистр. Команда Devi ce Reset выполняется устройством AT API независимо от состояния битов BSY и DRQ, и даже в состоянии Sleep.&lt;br /&gt;Полный список команд АТА приведен в литературе [4,5,9].&lt;br /&gt;Протоколы и режимы передачи данных&lt;br /&gt;Программа общается с устройствами АТА через регистры, используя инструкции ввода-вывода IN и OUT. Для передачи данных с максимальной скоростью применяют программный доступ РЮ к регистру данных инструкциями INSW/OUTSW или по каналу DMA. Тип обмена (РЮ или DMA) определяется командой обращения. Программный доступ РЮ обязателен для всех устройств, команды режима DMA устройствами могут не поддерживаться. Параметры различных режимов обмена приведены в табл. 9.7.&lt;br /&gt;Таблица 9.7. Параметры режимов передачи&lt;br /&gt;&lt;br /&gt;Режим передачи	Минимальное	Скорость	Интерфейс&lt;br /&gt;	время цикла, не	передачи, Мбайт/с	&lt;br /&gt;РЮ mode 0	600	3,3	АТА&lt;br /&gt;РЮ mode 1	383	5,2	АТА&lt;br /&gt;РЮ mode 2	240	8,3	АТА&lt;br /&gt;РЮ mode 3	180	11,1	E-IDE, АТА-2&lt;br /&gt;			(используется IORDY)&lt;br /&gt;РЮ mode 4	120	16,6	E-IDE, Fast АТА-2&lt;br /&gt;			(используется IORDY)&lt;br /&gt;Singleword DMA Mode 0	960	2,08	АТА&lt;br /&gt;Singleword DMA Mode 1	480	4,16	АТА&lt;br /&gt;Singleword DMA Mode 2	240	8,33	АТА&lt;br /&gt;Multiword DMA Mode 0	480	4,12	АТА&lt;br /&gt;Multiword DMA Mode 1	150	13,3	АТА-2&lt;br /&gt;Multiword DMA Mode 2	120	16,6	FastАТА-2&lt;br /&gt;Ultra DMA Mode 0	120&#039;	16,6	ATA/ATAPI-4&lt;br /&gt;Ultra DMA Mode 1	80&#039;	25	ATA/ATAPI-4&lt;br /&gt;Ultra DMA Mode 2	601	33	ATA/ATAPI-4&lt;br /&gt;Ultra DMA Mode 3	451	44,4	ATA/ATAPI-5&lt;br /&gt;Ultra DMA Mode 4	ЗО1	66,6	ATA/ATAPI-5&lt;br /&gt;Ultra DMA Mode 5	201	100	ATA/ATAPI-6&lt;br /&gt;1 В пакете данных режима Ultra DMA за каждый такт передаются два слова данных, один по фронту синхронизирующего сигнала, другой по спаду. Период следования синхросигналов равен удвоенному времени цикла.&lt;br /&gt;Программный доступ РЮ (Programmed Input/Output) выполняется в виде следующих друг за другом операций чтения или записи в пространстве ввода-вывода по адресу регистра данных. Готовность устройства проверяется перед началом&lt;br /&gt;передачи блока, после чего хост производит серию операций в определенном темпе, который определяется выбранным режимом РЮ Mode 0-4. Для каждого режима определены допустимые параметры временной диаграммы цикла обмена. Обмен РЮ программно реализуется с помощью процессорных инструкций ввода-вывода строк REP INS или REP OUTS с занесенным в регистр СХ количеством слов (или байтов) в передаваемом блоке. Эти инструкции обеспечивают максимально возможную скорость обмена для данного процессора и системной шины. «Обуздать» процессор в соответствии с выбранным режимом входит в задачу адаптера AT А, который использует для удлинения цикла сигнал готовности шины (для ISA - IOCHRDY). Традиционные режимы 0,1 и 2 имеют временные параметры, фиксируемые только хост-адаптером. Для прогрессивных режимов АТА-2 (РЮ Mode 3 и выше) устройство может затормозить обмен, используя сигнал готовности IORDY. Программный обмен на все время передачи блока занимает и процессор, и системную шину.&lt;br /&gt;Обмен по каналу DMA занимает исключительно шины ввода-вывода и памяти. Процессору требуется выполнить только процедуру инициализации канала, после чего он свободен до прерывания от устройства в конце передачи блока (этим могут воспользоваться многозадачные системы). Стандартные каналы DMA шины ISA для интерфейса АТА не используются из-за низкой пропускной способности. Высокопроизводительные адаптеры АТА имеют собственные более эффективные контроллеры. Режимы обмена по каналу DMA бывают одиночными и множественными. При одиночном режиме - Singleword DMA - устройство для передачи каждого слова вырабатывает сигнал запроса DMARQ и сбрасывает его по сигналу DMACK#, подтверждающему цикл обмена. При множественном режиме - Multiword DMA - на сигнал DMARQ хост отвечает потоком циклов, сопровождаемых сигналами DMACK*. Если устройство не справляется с потоком, оно может приостановить его снятием сигнала DMARQ, а по готовности установить его снова. Множественный режим позволяет развить более высокую скорость передачи.&lt;br /&gt;В спецификации ATA/ATAPI-4 появился новый режим - Ultra DMA, позволяющий перешагнуть барьер в 16,6 Мбайт/с, свойственный традиционным режимам и используемому кабелю. При этом обеспечивается и контроль достоверности передачи данных по шине, чего не делалось ни в РЮ, ни в стандартных режимах DMA (а зря!). Стандартом АТА-4 было определено 3 режима Ultra DMA (0,1 и 2), впоследствии ввели новые; выбор режима осуществляется командой Set Features. В режимах Ultra DMA сигналы DMARQ и DMACK* сохраняют свое назначение, а вот смысл сигналов DIOR#, DIQW# и IORDY на время передачи пакета (Ultra DMA Burst) существенно меняется. В пакете данные на шине сопровождаются стробом, генерируемым источником данных, причем для синхронизации используются оба перепада сигналов. Это позволяет повысить пропускную способность шины до 33 Мбайт/с, не увеличивая частоту переключения сигналов сверх 8,33 с&quot;1 (этот предел для обычного кабеля достигается в режиме РЮ Mode 4 и Multiword DMA Mode 2). Каждое переданное слово участвует в подсчете CRC-кода, который передается хост-контроллером в конце пакета. Подсчет ведется и источником данных, и приемником.&lt;br /&gt; &lt;br /&gt;При несовпадении принятого устройством кода с ожидаемым кодом фиксируется ошибка передачи, о которой устройство сообщает в конце исполнения команды. Передача в пакете может приостановиться, если приемник снимет сигнал готовности (DDMARDY* или HDMARDY*). Передача пакета может прекращаться по инициативе устройства (снятием сигнала) или хоста (сигналом STOP). Противоположная сторона должна подтвердить окончание цикла сигналом STOP или DMARQ соответственно.&lt;br /&gt;Способ сообщения об ошибке передачи зависит от типа выполнявшейся команды. Для команд READ DMA,WRITE DMA, READ DMA QUEUED или WRITE DMA QUEUED в регистре ошибок ER устанавливается бит 7 (ICRC) и бит 2 (ABRT). Для пакетной команды REQUEST SENSE (уточнить состояние) в случае ошибки в регистре состояния SR устанавливается бит О (СНК) и сообщается ключ состояния (Sense key) OBh (команда отвергнута). Для всех других пакетных команд в случае ошибки устанавливается бит СНК и сообщается состояние 04h (аппаратная ошибка), а в последующих командах REQUEST SENSE сообщается значениеЛ5С/А5СО 08h/03h (ошибка CRC при связи с логическим устройством). Получив сообщение об ошибке, хост должен повторить команду. Если ошибки появляются постоянно, хост должен понизить скорость обмена (вплоть до выхода из режима Ultra DMA).&lt;br /&gt;Тип режима обмена определяется возможностями хост-адаптера (и его драйвера), устройств и кабеля, и для каждого устройства он будет ограничен минимумом из максимальных возможностей всех этих компонентов. Как правило, режимы устанавливаются системой автоматически, но пользователю дается возможность при необходимости «подрезать крылья» контроллеру настройками BIOS Setup. Для работы в режимах Ultra DMA Mode 3 и выше требуется 80-проводный кабель, присутствие которого должно быть программно определено до включения этого режима обмена. Правда, в спецификации есть оговорка, что при двухточечном соединении (контроллер-устройство) для режимов 3 и 4 можно использовать 40-проводный кабель (без среднего разъема). Система не должна позволить пользователю применить высокоскоростные режимы на обычном кабеле, при этом желательно, чтобы она сообщала об обнаруженном несоответствии. Для определения типа кабеля есть несколько возможностей [4].&lt;br /&gt;- Определение типа кабеля через хост-контроллер, для чего хост-контроллер должен иметь приемник сигнала CBLID*. После включения питания или аппаратного сброса хост ожидает завершения протокола сброса и затем подает команду идентификации Identyf у (Packet) Devi се устройству 1. Устройство 1 стандарта АТА-3 и выше обязано после сброса снять сигнал PDIAG#/CBLID# не позднее, чем по приходу первой команды. Если обнаружено старое устройство, то протокол идентификации кабеля хостом работать не будет (но со старым устройством на шлейфе включать высокоскоростной режим и не стоит). Современное устройство снимет сигнал, и хост-адаптер сможет определить наличие 80-проводного кабеля по низкому уровню CBLID*. Некорректно работающее устройство может удержать низкий уровень сигнала, и в этом случае 40-проводный кабель будет ошибочно трактоваться как 80-проводный.&lt;br /&gt; &lt;br /&gt;-	Определение типа кабеля через устройство не требует дополнительного при&lt;br /&gt;емника в контроллере - линия PDIAG#/CBLID# в хост-контроллере заземляется через конденсатор емкостью 0,047 мкФ±20 %. Приемник сигнала идентификации кабеля располагается в устройстве. Для определения типа кабеля хост посылает команду Identyf у (Packet) Device устройству 1, чтобы оно освободило линию (сняло сигнал PDIAG*). Затем команда идентификации посылается устройству 0. Примерно через 30 мкс после получения команды устройство кратковременно обнуляет эту линию, затем отпускает и только через 20-30 мкс после этого считывает ее состояние и сообщает его в бите 13 слова 93. Линия подтягивается к +5 В резисторами 10 кОм, установленными в устройствах. Если используется 40-проводный кабель, то конденсатор в хост-адаптере не успеет перезарядиться и устройство сообщит нулевое значение бита. Если кабель 80-проводный, то конденсатор оказывается изолированным от линии PDIAG*/CBLID* в устройстве, и оно сообщит единичное значение бита. Если на хост-контроллере нет конденсатора, то даже 40-проводный кабель будет идентифи&lt;br /&gt;цироваться как 80-проводный, что опасно при передаче данных. Если некор&lt;br /&gt;ректно работающее ведомое устройство своевременно не отпустит линию, то&lt;br /&gt;даже 80-проводный кабель будет казаться 40-проводным.&lt;br /&gt;-	Комбинированный метод определения типа кабеля предполагает наличие на&lt;br /&gt;хост-контроллере и приемника сигнала CBLID#, и конденсатора (они друг другу не мешают). Решение о наличии 80-проводного кабеля принимается, только если это подтвердят оба метода. Возможная ошибка идентификации будет безопасной - при некорректном устройстве 1 на 80-проводном кабеле не будет включен высокоскоростной режим (наверное, это и к лучшему).&lt;br /&gt;Правильный выбор режима обмена обеспечивает надежность и производительность. Все устройства поддерживают режим РЮ Mode 0, в котором считывается блок параметров идентификации. В блоке имеются поля, описывающие режим обмена по умолчанию и более эффективные режимы обмена, поддерживаемые устройством. Командой Set Features можно изменить параметры режима. Иногда накопитель не обеспечивает надежной передачи данных в заявленном высокоскоростном режиме. Если данные начинают пропадать, первым делом следует понизить режим обмена.&lt;br /&gt;BIOS определяет режим обмена с каждым устройством с учетом ограничений, заданных в Setup. Старые диски, не сообщающие своих параметров, могут не работать с новыми режимами PIO. На одном ленточном кабеле (канале ATА) могут присутствовать устройства с разным режимом обмена - спецификация это допускает. Однако реально могут возникать аппаратные или программные ограничения. Некоторые чипсеты не позволяют независимо программировать режим обмена для устройств канала. В таком случае при подключении двух разных устройств (например, PIO Mode 1 и 3) обмен с обоими устройствами будет происходить со скоростью меньшего (PIO Mode 1). Поэтому не рекомендуется к одному каналу АТА (порту IDE) подключать быстрый винчестер и медленный CD-ROM. Иногда завязка режимов обмена двух устройств обусловлена ограниченным набором параметров конфигурации в BIOS. Быстрые режимы множественного обмена по&lt;br /&gt;DMA реализуются только драйверами ОС. «Глупый» драйвер может попытаться навязать медленный режим обоим устройствам канала, так что смешивать разные устройства не стоит и по этой причине.&lt;br /&gt;Протокол обмена PIO хорош только для однозадачных ОС. Для многозадачных ОС больший интерес представляет обмен по протоколу DMA, если, конечно, поддерживаемый режим обеспечивает приемлемую скорость обмена. С точки зрения драйвера есть различия лишь между типами режимов (РЮ, DMA и UltraDMA); аппаратные нюансы режимов внутри типа влияют только на скорость передачи. Режим UltraDMA значительно отличается от обычного DMA необходимостью обработки возможных ошибок передачи по шине; в случае постоянных ошибок драйвер должен понизить режим UltraDMA (вплоть до перехода на традиционные режимы).&lt;br /&gt;Протокол взаимодействия хоста с устройством выглядит следующим образом.&lt;br /&gt;1.	Хост читает регистр состояния устройства, дожидаясь нулевого значения бита В S Y.Если присутствуют два устройства, хост обращается к ним «наугад» - состояние будет сообщаться последним выбранным устройством.&lt;br /&gt;2.	Дождавшись освобождения устройства, хост записывает в регистр D/H байт,у которого бит DEV указывает на адресуемое устройство. Здесь кроется причина невозможности параллельной работы двух устройств на одной шине AT А:обратиться к устройству можно только после освобождения обоих устройств.&lt;br /&gt;3.	Хост читает основной или альтернативный регистр состояния адресованного&lt;br /&gt;устройства, дожидаясь признака готовности (DRDY=1).&lt;br /&gt;4.	Хост заносит требуемые параметры в блок командных регистров.&lt;br /&gt;5.	Хост записывает код команды в регистр команд.&lt;br /&gt;6.	Устройство устанавливает бит BSY и переходит к исполнению команды.&lt;br /&gt;Дальнейшие действия зависят от протокола передачи данных, заданного командой.&lt;br /&gt;Для команд, не требующих передачи данных, следующий шаг (шаг 7) - последний. Завершив исполнение команды, устройство сбрасывает бит BSY и устанавливает запрос прерывания (если он не запрещен). К этому моменту в регистрах состояния и ошибок уже имеется информация о результате исполнения. Единичное значение бита BSY может «промелькнуть» между шагами 6 и 7 так быстро, что хост его не зафиксирует, но для фиксации факта выполнения команды или ее части предназначен запрос прерывания.&lt;br /&gt;Для команд, требующих чтения данных в режиме РЮ, процедура продолжается следующим образом.&lt;br /&gt;7.	Подготовившись к передаче первого блока данных по шине АТА, устройство&lt;br /&gt;устанавливает бит DRQ. Если была ошибка, она фиксируется в регистрах состояния и ошибок. Далее устройство сбрасывает бит BSY и устанавливает запрос прерывания (если он не запрещен).&lt;br /&gt;8.	Зафиксировав обнуление бита BSY (или по прерыванию), хост считывает регистр состояния, что приводит к сбросу прерывания от устройства.&lt;br /&gt; &lt;br /&gt;9. Если хост обнаружил единичное значение бита DRQ, он производит чтение первого блока данных в режиме PIO (адресуясь к регистру данных). Если обнаружена ошибка, считанные данные могут быть недостоверными. После передачи блока данных возможно одно из следующих действий:&lt;br /&gt;•	если на шаге 8 ошибка не обнаружена и требуется передача следующего&lt;br /&gt;блока, устройство устанавливает бит BSY и данная последовательность повторяется с шага 7;&lt;br /&gt;•	если есть ошибка или передан последний блок данных, устройство сбрасы&lt;br /&gt;вает бит DRQ и выполнение команды завершается.&lt;br /&gt;Для операций записи данных после шага б для устройства начинается активная фаза записи на носитель, что отмечается установкой бита BSY.&lt;br /&gt;Для команд, требующих записи данных в режиме PIO, процедура после шага 6 продолжается следующим образом.&lt;br /&gt;7.	Подготовившись к приему первого блока данных по шине ATА, устройство устанавливает бит DRQ (если нет ошибок) и сбрасывает бит B5Y. Если была ошибка, она фиксируется.&lt;br /&gt;8.	Зафиксировав обнуление бита BSY, хост считывает регистр состояния.&lt;br /&gt;9.	Если хост обнаружил единичное значение бита DRQ, он производит запись первого блока данных в режиме PIO по адресу в регистре данных.&lt;br /&gt;10.	После передачи блока данных возможно одно из следующих действий:&lt;br /&gt;•	если обнаружена ошибка, устройство сбрасывает бит DRQ, устанавливает запрос прерывания и выполнение команды завершается, а переданные по шине данные остаются устройством необработанными (не записываются на носитель);&lt;br /&gt;•	если ошибка не обнаружена, устройство устанавливает бит BSY и переходит к следующему шагу.&lt;br /&gt;11.	Устройство обрабатывает принятый блок данных, затем:&lt;br /&gt;•	если нет ошибок и обработанный блок - последний, устройство сбрасывает бит B5Y и устанавливает запрос прерывания, на чем выполнение команды успешно завершается;&lt;br /&gt;•	если обнаружена ошибка, выполнение команды завершается таким же об&lt;br /&gt;разом, но с установкой битов ошибок;&lt;br /&gt;•	если нет ошибок и требуется передача следующего блока, процедура про&lt;br /&gt;должается.&lt;br /&gt;&lt;br /&gt;12.	По готовности приема следующего блока устройство устанавливает бит DRQ, сбрасывает бит BSY и устанавливает запрос прерывания.&lt;br /&gt;13.	По обнулении бита BSY (или по прерыванию) хост считывает регистр состояния.&lt;br /&gt;14.	Обнаружив бит DRQ, хост выполняет запись очередного блока в регистр данных, и последовательность повторяется с шага 11.&lt;br /&gt; &lt;br /&gt;Команды с передачей данных в режиме DMA выполняются похожим образом, но с некоторыми исключениями.&lt;br /&gt;-	Вместо PIO используется прямой доступ к памяти. Хост должен инициализи&lt;br /&gt;ровать канал DMA до записи кода в регистр команд, чтобы при появлении сигнала DMARQ начался обмен.&lt;br /&gt;-	Запрос прерывания даже в многосекторных передачах производится один&lt;br /&gt;раз - по выполнении команды.&lt;br /&gt;Адаптеры и контроллеры шины АТА&lt;br /&gt;Простейший адаптер АТА содержит только буферы сигналов шины и дешифратор зоны адресов. Все регистры контроллера и схемы кодирования размещены в самом устройстве IDE. Шина АТА требует выделения системных ресурсов - двух областей портов ввода-вывода и линии прерывания; дополнительно может потребоваться канал DMA. Интерфейсу АТА первого канала выделили ресурсы, ранее использовавшиеся контроллером жестких дисков. Второму каналу назна-чили ресурсы альтернативного контроллера жестких дисков. Позже определили ресурсы еще для двух каналов (табл. 9.8). Традиционному контроллеру жестких дисков выделялся канал DMA3, но он является 8-битным, в то время как шина АТА требует 16-битного канала DMA. Производительности стандартных каналов DMA для шины АТА явно недостаточно.&lt;br /&gt;Таблица 9.8. Системные ресурсы каналов АТА&lt;br /&gt;Канал   CSO	CS1	IRQ&lt;br /&gt;&lt;br /&gt;1	1FOh-1F7h	3F6h-3F7h	14&lt;br /&gt;2	170h-177h	376h-377h	15или 10&lt;br /&gt;3	1E8h-1Efh	3Eeh-3Efh	12 или 11&lt;br /&gt;4	168h-16Fh	36Eh-36Fh	10 или 9&lt;br /&gt;На системных платах с шиной PCI стандартом является установка двухканального адаптера, занимающего ресурсы каналов 1 и 2. В идеальном варианте двухканаль-ные контроллеры имеют шины, полностью изолированные друг от друга буферными и логическими схемами. В самом дешевом варианте они используют общие буферы для линий данных и управляющих сигналов и отдельные только для некоторых сугубо индивидуальных сигналов. С точки зрения логики здесь все в порядке, но следует учитывать нагрузочную способность (влияние паразитных параметров): суммарная длина обоих ленточных кабелей не должна превышать 46 см, а суммарная емкость каждой линии со всеми устройствами не должна превышать 35 пФ. Иначе на высокоскоростных режимах обмена возможны неконтролируемые искажения передаваемых данных. Стандарт ATA/ATAPI-6 предписывает следующее.&lt;br /&gt;- В каждом канале должны быть собственные формирователи управляющих сигналов DIOR#, DIOW# и приемник IORDY (рекомендуемый вариант); либо должны быть раздельные формирователи CSO# и CS1# (второй вариант логичнее, но хуже в плане помех). Такая конфигурация позволяет использовать все режимы обмена, кроме Ultra DMA.&lt;br /&gt; &lt;br /&gt;-	Для поддержки Ultra DMA 0,1 и 2 (до 33 Мбайт/с) к этим требованиям добав&lt;br /&gt;ляется наличие раздельных формирователей сигнала DMACK#.&lt;br /&gt;-	Для поддержки Ultra DMA 3 и выше (44-100 Мбайт/с) все линии должны&lt;br /&gt;иметь раздельные приемопередатчики. Общими могут быть только сигналы&lt;br /&gt;RESET*, INTRQ, DA(2:0), CSO#, CS1# и DASP#, но стандарт этого не рекомендует.&lt;br /&gt;Поскольку скорость программного обмена задается хост-адаптером, интересно индивидуальное программирование режимов РЮ Mode для каждого канала/устройства. Ряд чипсетов этого не допускает и при инициализации назначает общий минимальный режим. В результате подключение «тихоходного» устройства замедляет обмен быстрого соседнего устройства.&lt;br /&gt;Современные системные платы оснащаются высокопроизводительными контроллерами шины AT А, обеспечивающими прямое управление шиной PCI (bus mastering) при обмене с устройствами в режимах DMA и Ultra DMA. Прямое управление шиной повышает суммарную производительность компьютера в многозадачных и многопоточных операционных системах. Сами по себе режимы DMA не дают выигрыша в скорости обмена по шине АТА - только режимы UltraDM A Mode 1 и выше превосходят по скорости режим РЮ Mode 4 (см. табл. 9.7). Однако обмен в режиме DMA значительно меньше загружает центральный процессор компьютера, и параллельно с дисковым обменом процессор может заниматься обработкой других потоков (задач). В однозадачных (и однопоточных) системах во время дискового обмена процессор все равно ничем другим не занимается, поэтому для них хорош и режим РЮ Mode. Для реального использования режима прямого управления в операционной системе должен быть установлен специальный драйвер Bus-Master, соответствующий используемому контроллеру АТА (как правило, чипсету системной платы). Стандартный контроллер PCI IDE описан ниже. Операционная система MS-DOS режимы DMA (и прямое управление) не использует. Для многозадачных ОС (Windows 9x/NT/2000, OS/2, Unix, Linux, NetWare...) драйверы могут входить в комплект поставки ОС или поставляться производителями системных плат (контроллеров АТА). И наконец, режим DMA должны поддерживать подключаемые устройства. Практически все современные устройства поддерживают Ultra DMA (или Multiword DMA), но если в паре с таким устройством к одному контроллеру подключено старое устройство, не поддерживающее этот режим, то прогрессивные режимы могут оказаться недоступными (по вине чипсета или драйвера) и для нового устройства.&lt;br /&gt;ВНИМАНИЕ	&lt;br /&gt;Режим UltraDMA привлекателен не только скоростью и разгрузкой процессора, но и контро-лем достоверности передач по шине АТА (правда, этот контроль корректно работает не со всеми драйверами).&lt;br /&gt;Поскольку контроллеры АТА подключаются к 32-разрядной шине PCI, в них ввели возможность обращения к регистру данных АТА двойными словами. При этом за одну 32-битную операцию процессора и шины PCI по шине АТА последовательно передаются два 16-битных слова. Возможностью 32-разрядного доступа к регистру данных можно управлять через параметр IDE 32-bit Transfer (Enable/Disable) BIOS Setup.&lt;br /&gt; &lt;br /&gt;Более сложные контроллеры (отдельные карты расширения) могут иметь собственную кэш-память и управляющий процессор. Они могут аппаратно поддерживать «зеркальные» диски и организовывать RAID-массивы АТА-дисков. Некоторые адаптеры позволяют соединять несколько физических дисков в один логический на уровне вызовов BIOS.&lt;br /&gt;Адаптеры АТА одно время часто размещали на звуковых картах (для подключения CD-ROM). По умолчанию им назначают ресурсы канала 3 или 4. К этим каналам можно подключать винчестеры, но будет ли их там искать BIOS во время теста POST - вопрос. Современные версии BIOS позволяют хранить конфигурационные параметры четырех жестких дисков, более старые версии - двух. Четыре канала АТА физически позволяют подключить до восьми накопителей, но работа с ними лимитирована программными ограничениями.&lt;br /&gt;Существуют гибридные адаптеры для подключения АТА HDD к шинам XT и МСА или, например, к LPT-порту. В последнее время получили распространение переходные адаптеры, позволяющие подключать устройства AT A/ AT API к шине USB. При использовании USB 2.0 простота подключения внешнего устройства будет сочетаться и с высокой скоростью передачи данных.&lt;br /&gt;Контроллер PCI IDE&lt;br /&gt;Для шины PCI существует стандартный вариант интерфейса контроллера IDE (название «АТА» здесь не очень уместно, поскольку оно ориентировано на ISA-подобную шину). Спецификация «PCI IDE Controller Specification» появилась еще в 1994 году, она описывала реализацию контроллера, совместимого с интерфейсом АТА. По сравнению с обычным контроллером, у данного контроллера в блоке управляющих регистров имеется лишь один адрес (устаревший регистр адреса недоступен). Чуть позже была опубликована спецификация «Programming Interface for Bus Master IDE Controller», описывающая работу с устройствами в режиме DMA с прямым управлением шиной. Двухканальный контроллер является одной функцией PCI; четырехканальный контроллер будет уже многофункциональным устройством PCI. Для контроллера определены два режима распределения ресурсов:&lt;br /&gt;-	режим совместимости (compatibility), в котором каналам выделяются тради&lt;br /&gt;ционные области адресов ввода-вывода и линии прерываний;&lt;br /&gt;-	естественный режим PCI (native-PCI), в котором базовые адреса блоков регистров и линии прерывания задаются в регистрах конфигурационного пространства и могут быть произвольно перемещаемы в любую область.&lt;br /&gt;Распределение ресурсов для контроллера приведено в табл. 9.9. В режиме совместимости контроллер может работать только на первичной шине PCI, поскольку мост PCI-PCI не будет транслировать обращения по стандартным адресам на другую шину. В режиме PCI с перемещаемыми ресурсами контроллер может находиться на любой шине. Конкретный контроллер может поддерживать изменение режима или один из режимов. Если контроллер по умолчанию (или всегда) работает в режиме совместимости, то для ПО он «прозрачен» - работа с ним не отличается от традиционного контроллера АТА. Текущий режим и возможность&lt;br /&gt;его смены отражается в байте программного интерфейса, являющегося последним элементом идентификатора класса устройства. Байт интерфейса имеет следующее назначение битов:&lt;br /&gt;-	бит 7 (bus mastering) - возможность работы в режиме прямого управления;&lt;br /&gt;-	биты 6:4 - 000 (признак стандартного интерфейса, соответствующего PCI IDE Controller Specification);&lt;br /&gt;-	бит 3 - индикатор программируемое™ режима для второго канала (возможности изменения бита 2);&lt;br /&gt;-	бит 2 - режим второго канала: 0 - совместим со стандартным контроллером ATA IDE, 1 - PCI IDE;&lt;br /&gt;-	бит 1 - индикатор программируемости режима для первого канала (возможности изменения бита 0);&lt;br /&gt;-	бит 0 - режим первого канала: 0 - совместим с ATA IDE, I - PCI IDE.&lt;br /&gt;Таблица 9.9. Ресурсы контроллера PCI IDE&lt;br /&gt;Ресурс	Режим совместимости:   Естественный режим PCI:&lt;br /&gt;ресурсы для каналов      базовый адрес (смещение&lt;br /&gt;в конфигурационном пространстве) для канала&lt;br /&gt;12	12&lt;br /&gt;&lt;br /&gt;Блок командных регистров	1FOh-1F7h	170h-177h	10h	14h&lt;br /&gt;Блок управляющих регистров	3F6h	376h	18h	1Ch&lt;br /&gt;Прерывание	14	15		&lt;br /&gt;Типовой контроллер имеет класс 01:01:80h и реализован в чипсетах большинства современных системных плат. Контроллер выглядит как расширение стандартного АТА-контроллера, обеспечивающего доступ к регистрам устройств AT A/ AT API по известным адресам. Расширение касается прямого управления шиной PCI (bus mastering), благодаря которому можно реализовать обмен данными с устройствами в режимах DMA. Контроллер позволяет использовать все доступные ему режимы обмена РЮ (3,3-16,6 Мбайт/с), режимы DMA в стиле контроллера 8237 А (2-16,6 Мбайт/с) и режимы UltraDMA (16,6-100 Мбайт/с). Все настройки временных параметров выполняются через конфигурационные регистры PCI, их состав может быть специфичным. Однако с этими регистрами должна иметь дело только процедура POST, устанавливая для каждого обнаруженного устройства AT A/ AT API оптимальные режимы РЮ и DMA/UltraDMA. В эти настройки может вмешаться пользователь, установив какие-либо ограничивающие параметры в BIOS Setup. В итоге после конфигурирования во время POST при обращении программ к устройствам остается выбор лишь между РЮ и DMA (если устройство поддерживает DMA). Для обмена в режиме РЮ никаких специальных дей-ствий не требуется, программа просто выполняет чтение или запись в регистр данных командами REP IN5/OUTS. Для обмена в режиме DMA требуется «зарядить» и запустить контроллер прямого управления, о чем и пойдет речь ниже.&lt;br /&gt; &lt;br /&gt;Двухканальный контроллер имеет 16-байтный блок регистров, расположенный в пространстве портов ввода-вывода. Базовый адрес блока хранится в конфигурационном пространстве устройства по смещению 20h (берутся младшие 16 бит двойного слова). Расположение регистров в блоке показано в табл. 9.10, имена регистров имеют префикс BMI (Bus Master IDE) и окончание Р (Primary) для первого канала, S (Secondary) - для второго; в описании будем использовать окончание х (любой канал).&lt;br /&gt;Таблица 9.10. Блок регистров контроллера PCI IDE&lt;br /&gt;Смещение для канала   Длина, байт   Регистр для первого/второго каналов&lt;br /&gt;J	2	&lt;br /&gt;0	8	1	BMICP/BMICS (RW) - регистр команд: бит 0:&lt;br /&gt;1 - запуск, 0 - останов; бит 3 - направление: 0 - чтение памяти, 1 - запись в память; биты 1 -2, 3-7 - резерв (0)&lt;br /&gt;1	9	1	Резерв (0)&lt;br /&gt;2	OAh	1	BMISP/BMISS- регистр состояния: бит 0 (R/O) -&lt;br /&gt;активность канала; бит 1 (RWC) - ошибка обмена по PCI; бит 2 (RWC) - запрос прерывания от устройства; биты 3-4 - резерв (0); бит 5 (RW) - устройство 0 поддерживает DMA; бит 6 (RW) - устройство 1 поддерживает DMA; бит 7 - признак симплексного режима (1, если каналы не могут работать одновременно)&lt;br /&gt;3	OBh	1	Резерв (0)&lt;br /&gt;4	ОСИ	4	BMIDPTP/BMIDPTS(RW)- адрес таблицы&lt;br /&gt;дескрипторов&lt;br /&gt;Регистр команд BMICx, доступный по чтению и записи, используется для запуска контроллера и задания направления передачи. Запуск осуществляется при переходе бита 0 из нуля в единицу, останов для текущего сеанса необратим. Останов контроллера (сброс бита) обычно выполняют по окончании выполнения команды ATA/ATAPI (по прерыванию). Преждевременный останов приведет к ошибке выполнения команды с соответствующим сообщением. Направление должно быть задано до запуска контроллера, изменять его «на ходу» нельзя.&lt;br /&gt;В регистре состояния BMISx биты 1 и 2 устанавливаются аппаратно, а сбрасываются при записи байта с единичным значением в соответствующем бите. После сброса бита запроса прерывания он снова установится только по следующему фронту сигнала прерывания от устройства. Биты 5 и 6 устанавливаются программно, обычно когда POST определяет возможности подключенных устройств и программирует режимы контроллера. Регистр состояния должен быть прочитан после завершения выполнения команды для определения успешности операций на шине PCI. В регистр ВМI DPTx заносят адрес таблицы дескрипторов областей памяти, с которыми производится обмен данными. Контроллер способен при чтении памяти собрать поток данных из произвольного числа областей (gathered read), а при записи «разбросать» поток по этим областям (scatter write). Такая возможность ветречалась еще в EISA-системах, она позволяет преодолевать барьеры на границах страниц, свойственные стандартным контроллерам DMA и страничной переадресации процессоров х86. Каждый дескриптор занимает 8 байтов:&lt;br /&gt;-	байты 0-3 (двойное слово) - физический адрес начала области (четный);&lt;br /&gt;-	байты 4-5 (слово) - счетчик байтов (четный, 0000 соответствует 65 536);&lt;br /&gt;-	байты 6-7 (слово) - признак конца таблицы (бит 15), биты 0-14 не используются (0).&lt;br /&gt;Каждая область может быть расположена в произвольном месте памяти (кроме отображаемой на шину ISA) и иметь произвольный размер, но не должна пересекать границы страниц размером 64 Кбайт. Таблица дескрипторов должна быть выровнена по границе двойного слова и не должна пересекать границы страниц, имеющих размер 64 Кбайт. Число дескрипторов в таблице произвольно, последний должен содержать признак конца таблицы. Обмен начинается с области, описанной первым дескриптором; за ней идет область следующего дескриптора и так далее до последнего. Контроллер остановится по исчерпании счетчика в по-следнем дескрипторе или по инициативе устройства, если в обмене должно участво-вать меньшее число данных. Если устройству данных не хватит, оно укажет на ошибку при завершении команды.&lt;br /&gt;После запуска контроллера второй и нулевой биты регистра состояния отражают следующие ситуации:&lt;br /&gt;-	0,1 - происходит обмен с памятью, прерывания по концу операции еще нет;&lt;br /&gt;-	1,0 - обмен завершен, переданный объем соответствует объему описанных буферов (нормальное завершение);&lt;br /&gt;-	1,1 - устройство завершило обмен, но по команде АТА передано меньше данных, чем описано в таблицах (допустимое завершение);&lt;br /&gt;-	0,0 - ошибка на шине (бит 1), или в таблицах описано меньше данных, чем в команде АТА.&lt;br /&gt;Конфигурирование устройств&lt;br /&gt;Устройства АТА перед подключением к шине должны быть корректно сконфигурированы. Конфигурирование подразумевает выбор типа интерфейса и определение адреса устройства. Тип интерфейса - XT или AT - определяется моделью накопителя. В изделиях фирмы Seagate, например, тип обозначается последней буквой в шифре модели: А - АТА (16 бит,) X - для XT (8 бит), а сочетание АХ означает возможность выбора AT/XT с помощью джампера.&lt;br /&gt;Существует два способа задания адреса устройства - кабельной выборкой или явным заданием адреса на каждом из устройств. Режим кабельной выборки включается перемычкой CS (Cable Select - кабельная выборка). В этом случае о</yandex:full-text>
</item><item>
<title>Последовательный интерфейс Serial АТА</title>
<link>http://intpc.ru/140-posledovatelnyjj-interfejjs-serial-ata.html</link>
<description>Параллельный интерфейс АТА исчерпал свои ресурсы пропускной способности, достигшей 100 Мбайт/с в режиме UltraDM A Mode 5.</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 19:36:03 +0300</pubDate>
<yandex:full-text>Параллельный интерфейс АТА исчерпал свои ресурсы пропускной способности, достигшей 100 Мбайт/с в режиме UltraDM A Mode 5. Для дальнейшего повышения пропускной способности интерфейса (но, конечно же, не самих устройств хранения, которые имеют гораздо меньшие внутренние скорости обмена с носителем) было принято решение о переходе на последовательный интерфейс. Цель перехода - улучшение и удешевление кабелей и коннекторов, улучшение условий охлаждения устройств внутри системного блока (избавление от широкого шлейфа), обеспечение возможности разработки компактных устройств, облегчение конфигурирования устройств пользователем. Попутно расширяется адресация блоков (достижение предельной емкости адресации АТА в 137 Гбайт не за горами). Спецификация Serial ATA версии 1.0 опубликована в 2001 г. и доступна в Сети по адресу www.serialata.org. Сейчас уже ведутся работы над новой спецификацией Serial ATA II с большей пропускной способностью и специальными средствами для поддержки сетевых устройств хранения. Приведенная ниже информация относится к версии 1.0.&lt;br /&gt;Интерфейс Serial ATA является хост-центрическим, в нем определяется только взаимодействие хоста с каждым из подключенных устройств, а взаимодействие между ведущим и ведомым устройствами, свойственное традиционному интерфейсу АТА, исключается. Программно хост видит множество устройств, подключенных к контроллеру, как набор каналов АТА, у каждого из которых имеется единственное ведущее устройство. Имеется возможность эмуляции пар устройств (ведущее - ведомое) на одном канале, если такая необходимость возникнет. Программное взаимодействие с устройствами Serial ATA практически совпадает с прежним, набор команд соответствует ATA/ATAPI-5. В то же время аппаратная реализация хост-адаптера Serial ATA сильно отличается от примитивного (в исходном варианте) интерфейса АТА. В параллельном интерфейсе АТА хост-адаптер был простым средством, обеспечивающим программное обращение к регистрам, расположенным в самих подключенных устройствах. В Serial ATA ситуация иная: хост-адаптер имеет блоки так называемых «теневых» регистров (Shadow Registers), совпадающих по назначению с обычными регистрами устройств АТА. Каждому подключенному устройству соответствует свой набор регистров. Обраще-ния к этим теневым регистрам вызывают процессы взаимодействия хост-адаптера с подключенными устройствами и исполнение команд.&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;В стандарте рассматривается многоуровневая модель взаимодействия хоста и устройства, где прикладным уровнем является обмен командами, информацией о состоянии и хранимыми данными. На физическом уровне для передачи информации между контроллером и устройством используются две пары проводов. Данные передаются кадрами, транспортный уровень формирует и проверяет корректность информационных структур кадров (Frame Information Structure, FIS). Для облегчения высокоскоростной передачи на канальном уровне данные кодируются по схеме 8В/10В (8 бит данных кодируются 10-битным символом) и скремблиру-ются, после чего по физической линии передаются по простейшему методу NRZ (уровень сигнала соответствует передаваемому биту). Между канальным и прикладным уровнем имеется транспортный уровень, отвечающий за доставку кадров. На каждом уровне имеются свои средства контроля достоверности и целостности.&lt;br /&gt;В первом поколении Serial ATA данные по кабелю передаются со скоростью 1500 Мбит/с, что с учетом кодирования 8В/10В обеспечивает скорость 150 Мбайт/с (без учета накладных расходов протоколов верхних уровней). В дальнейшем планируется повышать скорость передачи, и в интерфейсе заложена возможность согласования скоростей обмена по каждому интерфейсу в соответствии с возможностями хоста и устройства, а также качеством связи. Хост-адаптер имеет средства управления соединениями, программно эти средства доступны через специальные регистры Serial ATA.&lt;br /&gt;В стандарте предусматривается управление энергорежимом интерфейсов. Каждый интерфейс кроме активного состояния может находиться в состояниях PARTIAL и SLUMBER с пониженным энергопотреблением, для выхода из которых требуется заметное время (10 мс).&lt;br /&gt;Команды, требующие передачи данных, могут исполняться в различных режимах обмена. Обращение в режиме PIO и традиционный способ обмена по DMA (legacy DMA) выполняется аналогично привычному интерфейсу АТ А. Однако внутренний протокол обмена между хост-адаптером и устройствами позволяет передавать между ними разноплановую информацию (структуры FIS определены не только для команд, состояния и собственно хранимых данных). В приложении D к спецификации описывается весьма своеобразный способ обмена по DMA, который предполагается основным (First-party DMA) для устройств Serial ATA. В традиционном контроллере DMA адаптера АТ А для каждого канала имеется буфер, в который перед выполнением операции обмена загружают дескрипторы блоков памяти, участвующей в обмене (см. п. 9.2.1). Теперь же предполагается, что адресная информация, относящаяся к оперативной памяти хост компьютера, будет доводиться до устройства хранения, подключенного к адаптеру Serial ATA. Эта ин-формация из устройства хранения при исполнении команд обмена выгружается в контроллер DMA хост-адаптера и используется им для формирования адреса текущей передачи. Мотивы и полезность этого нововведения не совсем понятны; расплатой за некоторое упрощение хост-адаптера (особенно многоканального) является усложнение протокола и расширение функций, выполняемых устройством хранения. Все-таки более привычно традиционное разделение функций, при котором задача устройств внешней памяти - хранить данные, «не интересуясь» тем, в каком месте оперативной памяти компьютера они должны находиться при операциях обмена.&lt;br /&gt; &lt;br /&gt;Физический интерфейс Serial ATA&lt;br /&gt;Последовательный интерфейс АТА, как и его параллельный предшественник, предназначен для подключений устройств внутри компьютера. Длина кабелей не превышает 1 м, при этом все соединения радиальные, каждое устройство подключается к хост-адаптеру своим кабелем. В стандарте предусматривается и непосредственное подключение устройств к разъемам кросс-платы с возможностью «горячей» замены. Стандарт определяет новый однорядный двухсегментный разъем с механическими&#039; ключами, препятствующими ошибочному подключению. Сигнальный сегмент имеет 7 контактов (S1-S7), питающий - 15 (Р1-Р15); все контакты расположены в один ряд с шагом 1,27 мм. Назначение контактов приведено в табл. 9.11. Малые размеры разъема (полная длина - около 36 мм) и малое количество цепей облегчают компоновку системных плат и карт расширения. Питающий сегмент может отсутствовать (устройство может получать питание и от обычного 4-контактного разъема АТА). Вид разъемов приведен на рис. 9.6. Для обеспечения «горячего» подключения контакты разъемов имеют разную длину, в первую очередь соединяются контакты «земли» Р4 и Р12, затем остальные «земли» и контакты предзаряда конденсаторов в цепях питания РЗ, Р7 и Р13 (для уменьшения броска потребляемого тока), после чего соединяются основные питающие контакты и сигнальные цепи.&lt;br /&gt;Таблица 9.11. Разъем Serial ATA Контакт    Цепь     Назначение&lt;br /&gt;&lt;br /&gt;51	GND	Экран&lt;br /&gt;52	А+	Дифференциальная пара сигналов А&lt;br /&gt;53	А-	Дифференциальная пара сигналов А&lt;br /&gt;54	GND	Экран&lt;br /&gt;55	В-	Дифференциальная пара сигналов В&lt;br /&gt;56	В+	Дифференциальная пара сигналов В&lt;br /&gt;57	GND	Экран&lt;br /&gt;Ключи и свободное пространство&lt;br /&gt;Р1	V33	Питание 3,3 В&lt;br /&gt;Р2	V33	Питание 3,3 В&lt;br /&gt;РЗ	V33	Питание 3,3 В, предзаряд&lt;br /&gt;Р4	GND	Общий&lt;br /&gt;Р5	GND	Общий&lt;br /&gt;Р6	GND	Общий&lt;br /&gt;Р7	V5	Питание 5 В, предзаряд&lt;br /&gt;Р8	V5	Питание 5 В&lt;br /&gt;Р9	V5	Питание 5 В&lt;br /&gt;Р10	GND	Общий&lt;br /&gt;Р11	Резерв	&lt;br /&gt;Р12	GND	Общий&lt;br /&gt;Р13	V12	Питание 12В, предзаряд&lt;br /&gt;Р14	V12	Питание 12 В&lt;br /&gt;Р15	V12	Питание 12 В&lt;br /&gt; &lt;br /&gt; &lt;br /&gt; 9.6. Разъемы Serial ATA: a - полный разъем на устройстве, б - сигнальный сегмент кабельного разъема, в - питающий сегмент кабельного разъема, г - сигнальный сегмент разъема хост-адаптера, д - разъем хоста для непосредственного подключения устройства&lt;br /&gt;Регистры Serial ATA&lt;br /&gt;Каждое устройство, подключенное к адаптеру Serial ATA, представляется тремя блоками регистров, два из которых соответствуют традиционным регистрам АТА (см. п. 9.2.1) и называются «теневыми», третий блок - новый. Привязка адресов блоков к адресному пространству хоста стандартом не регламентируется; для PCI-контроллера блоки задаются регистрами конфигурационного пространства и «теневые» регистры могут располагаться по стандартным адресам АТА.&lt;br /&gt;В блоке управляющих регистров, как и в АТА, используется лишь один (AS для чтения, DC для записи). В блоке командных регистров разрядность регистров SC, SN, CL и СН расширена до 16 бит, назначение младших байтов сохранилось. В режиме LBA старшие байты регистров SN, С L и СН несут биты логического адреса [24:31], [32:39] и [40:47] соответственно. В регистре D/H бит DEV игнорируется (при эмуляции пар устройств на одном канале бит DEV используется для выбора устройства). Из спецификации не совсем ясно, используются ли младшие биты D/H для задания бит LBA[27:24], поскольку эти же биты фигурируют в старшем байте SN.&lt;br /&gt;Новый блок регистров SCR (Serial ATA Status and Control registers) состоит из 16 смежных 32-разрядных регистров SCR0-SCR15, из которых пока определены лишь 3 (остальные зарезервированы).&lt;br /&gt;Регистр SStatus (SCR0) - регистр текущего состояния интерфейса хост адаптера (только чтение).&lt;br /&gt;- Биты [3:0] - поле DET, подключение устройств:&lt;br /&gt;•	0000 - устройство не обнаружено, физической связи нет;&lt;br /&gt;•	0001 - устройство обнаружено, но физическая связь не установлена;&lt;br /&gt;•	ООП - устройство обнаружено, физическая связь установлена;&lt;br /&gt;•	0100 - устройство отключено (запретом интерфейса или запуском внутреннего теста).&lt;br /&gt; &lt;br /&gt;9.2. Интерфейс АТА/ATAPI (IDE)	393&lt;br /&gt;-	Биты [7:4] - SPD, скорость:&lt;br /&gt;•	0000 - нет согласованной скорости (устройство не подключено или связь не установлена);&lt;br /&gt;•	0001 - согласована скорость 1-го поколения.&lt;br /&gt;-	Биты [11:8] - поле IPM, состояние энергопотребления интерфейса:&lt;br /&gt;•	0000 - устройство не обнаружено, физической связи нет;&lt;br /&gt;•	0001 - интерфейс в активном состоянии;&lt;br /&gt;•	0010 - интерфейс в состоянии PARTIAL;&lt;br /&gt;•	0110 - интерфейс в состоянии SLUMBER.&lt;br /&gt;Остальные биты и значения полей зарезервированы.&lt;br /&gt;Регистр SError (SCR1) - регистр диагностической информации, относящейся к интерфейсу. В регистре представлены ошибки, накапливающиеся с момента последней очистки регистра. Регистр очищается операцией сброса, отдельные биты можно сбрасывать операцией записи в регистр (единицы в позициях сбрасываемых бит).&lt;br /&gt;-	Биты [15:0] - поле ERR, ошибки, обрабатываемые обычным программным&lt;br /&gt;обеспечением:&lt;br /&gt;•	бит 9 - С - устойчивая неисправимая ошибка связи или нарушение целостности данных (может возникать при неправильном подключении, отказе или отключении устройства);&lt;br /&gt;•	бит 11 - Е - внутренняя ошибка, обнаруженная хост-адаптером (если&lt;br /&gt;ошибка повторяется после сброса, она может быть признаком несовмести&lt;br /&gt;мости адаптера и устройства);&lt;br /&gt;•	бит 0 - I - исправленное нарушение целостности данных (не требует действий со стороны ПО, но может учитываться, например, для принятия решения о снижении скорости);&lt;br /&gt;•	бит 1 - М - исправленная ошибка связи (может возникать при временном отключении устройства, потере синхронизации, не требует действий со стороны ПО);&lt;br /&gt;•	бит 10 - Р - протокольная ошибка, требует сброса интерфейса и повтора операции (в случае устойчивости может быть признаком несовместимости устройства и адаптера);&lt;br /&gt;•	бит 8 - Т - не исправленное нарушение целостности данных, требует повтора операции.&lt;br /&gt;-	Биты [31:16] - поле DIAG, используемое диагностическим ПО:&lt;br /&gt;•	бит 19 - В - ошибка декодирования 10В/8В;&lt;br /&gt;•	бит 21 - С - ошибка CRC на канальном уровне;&lt;br /&gt;•	бит 20 - D - ошибка паритета блоков данных (Disparity);&lt;br /&gt;•	бит 26 - F - неопознанный тип FIS (ошибка, обнаруженная на транспортном уровне при корректном CRC-коде);&lt;br /&gt;•	бит 17 - I - внутренняя ошибка физического уровня интерфейса;&lt;br /&gt; &lt;br /&gt;394	Глава 9. Интерфейсы устройств хранения&lt;br /&gt;•	бит 16 - N - сигнал готовности физического уровня менял состояние;&lt;br /&gt;•	бит 22 - Н - ошибка подтверждения кадров (может возникать как следствие ошибок В, С, D);&lt;br /&gt;•	бит 23 - S - ошибка последовательности состояний канального уровня;&lt;br /&gt;•	бит 24 - Т - ошибка на транспортном уровне;&lt;br /&gt;•	бит 18 - W - обнаружен пробуждающий сигнал Сотт Wake.&lt;br /&gt;Остальные биты зарезервированы.&lt;br /&gt;Регистр SControl (SCR2) - регистр управления интерфейсом (запись и чтение).&lt;br /&gt;-	Биты [3:0] - поле DET, управление обнаружением и инициализацией устройств:&lt;br /&gt;•	0000 - нет действий;&lt;br /&gt;•	0001 - инициализация и установление соединения (эквивалентно аппаратному сбросу);&lt;br /&gt;•	0100 - запрет интерфейса и перевод физического уровня в режим Offline.&lt;br /&gt;-	Биты [7:4] - поле SPD, задает ограничение на скорость при согласовании соединений:&lt;br /&gt;•	0000 - нет ограничений;&lt;br /&gt;•	0001 - скорость не выше 1-го поколения.&lt;br /&gt;-	Биты [11:8] - поле IPM, управление энергорежимом интерфейса:&lt;br /&gt;•	0000 - нет ограничений;&lt;br /&gt;•	0001 - запрет перехода в состояние PARTIAL;&lt;br /&gt;•	0010 - запрет перехода в состояние SLUMBER;&lt;br /&gt;•	0011 - запрет перехода в состояние PARTIAL и SLUMBER.&lt;br /&gt;Остальные биты и значения полей зарезервированы.</yandex:full-text>
</item><item>
<title>Интерфейсы и конструктивы твердотельных носителей информации</title>
<link>http://intpc.ru/141-interfejjsy-i-konstruktivy-tverdotelnykh.html</link>
<description>Твердотельные устройства хранения используются в миниатюрных компьютерах, а также компьютеризированных цифровых устройствах бытовой электроники - фотокамерах, плейерах, приемниках глобальной системы позиционирования (GPS), музыкальных инструментах и прочих.</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 19:37:15 +0300</pubDate>
<yandex:full-text>Твердотельные устройства хранения используются в миниатюрных компьютерах, а также компьютеризированных цифровых устройствах бытовой электроники - фотокамерах, плейерах, приемниках глобальной системы позиционирования (GPS), музыкальных инструментах и прочих. В большинстве своем эти устройства основаны на микросхемах флэш-памяти, в наиболее современных используется память со структурой NAND (см. п. 7.3.2). Этому типу флэш-памяти присуще быстрое чтение, запись и стирание небольших блоков (256 или 512 байт), что удобно для записи файлов. Правда, для этой памяти характерны довольно медленное чтение произвольного байта и отсутствие возможности побайтной записи, но приложениям этих карт такая возможность и не требуется, поскольку они ориентированы на блочный обмен. Устройства на флэш-памяти являются энергонезависимыми (в режиме хранения не требуют питания), экономичными в плане потребления, особенно при чтении, достаточно производительными, но, увы, недешевыми. Запись на эти носители специфична: быстрее всего она выполняется в чистый (стертый) блок (сектор диска), а перезапись требует относительно длительного стирания. Кроме того, флэш-память имеет хоть и большое (порядка 105), но ограниченное число циклов стирания-записи - как ни странно, у носителей с подвижным носителем с этим ограничением не сталкиваются. Устройства хранения обычно представляют комбинацию собственно микросхем памяти и микроконтроллера, обеспечивающего внешние интерфейсные функции. Этим они отличаются от карт памяти с линейным доступом, например Miniature Card, на которых располагаются только микросхемы памяти (встроенный контроллер не требуется).&lt;br /&gt;Есть и другие твердотельные хранители - например, ферроэлектрическая память (FRAM), но пока что массового применения они не имеют. Менее чем за десятилетие устройства хранения на флэш-памяти прошли большой путь от электронных «дисков» («винчестеров») размером в 3&quot; до современных, размером с почтовую марку. Интерфейсы твердотельных устройств хранения - карт внешней памяти - тесно связаны с их конструктивами; основные характеристики наиболее распро-страненных карт приведены в табл. 9.12.&lt;br /&gt;Таблица 9.12. Основные характеристики карт внешней памяти&lt;br /&gt;&lt;br /&gt;	CompactFlash	SmartMedia	MultiMedia	Sequre	Miniature&lt;br /&gt;		Card	Card	Digital	Card&lt;br /&gt;Длина	36,0	45,0	32,0	32,0	33,0&lt;br /&gt;Ширина	43,0	37,0	24,0	24,0	38,0&lt;br /&gt;Высота	3,3/5,0	0,76	1,4	2,1	3,5&lt;br /&gt;Коннектор	Штырьковый	Печатный	Печатный	Печатный	Эластомер&lt;br /&gt;Число контактов	50	22	7	9	60&lt;br /&gt;Вышеперечисленные карты можно подключать и к обычным компьютерам. Для этого существуют различные адаптеры: для слотов PC Card (к блокнотным ПК), для шины USB (для самых разных ПК) и для других внешних интерфейсов. С помощью этих адаптеров компьютер «видит» подключенную карту как обычный сменный носитель информации (диск). Конечно, компьютеры общего назначения в такой внешней памяти не нуждаются - своя и больше, и дешевле. Главная цель подключения карты к ПК - быстрая передача прикладных данных бытового устройства (фотографий, музыки и т. п.) или перенос (хранения) информации (вместо дискет).&lt;br /&gt;В качестве интерфейса твердотельных устройств хранения может использоваться и самый обычный вариант AT А. Существуют устройства DOM (Disk On Module) - небольшие модули, которые вставляются в обычный 40-контактный разъем АТА, имеющийся на любой современной системной плате. Правда, этот «винчестер» не блещет выдающимися параметрами: объем - 4-256 Мбайт, средняя скорость передачи данных - 1,6 Мбайт/с, удельная стоимость хранения - около $1,5 за мегабайт. Внутри модуля находится флэш-память структуры NAND с контроллером, эмулирующим систему команд АТА. Основное применение этих модулей - хранение ПО встраиваемых компьютеров, но можно ими пользоваться и как сменными устройствами хранения.&lt;br /&gt;</yandex:full-text>
</item><item>
<title>CompactFlash</title>
<link>http://intpc.ru/142-compactflash.html</link>
<description>Карты CompactFlash, поддерживаемые ассоциацией CFA (Compact Flash association), широко используются в различных электронных приборах</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 19:39:04 +0300</pubDate>
<yandex:full-text>Карты CompactFlash, поддерживаемые ассоциацией CFA (Compact Flash association), широко используются в различных электронных приборах: цифровых фотокамерах, фотопринтерах, МРЗ-плейерах, цифровых диктофонах, персональных коммуникаторах и, конечно же, компьютерах - настольных, карманных, автомобильных. Карты имеют размер 42,8 х 36,4 х 3,3 мм (4 мм с учетом выступа) и 50-контактный разъем (розетка на карте, двухрядный штырьковый разъем с шагом 1,27 мм на слоте). Назначение контактов приведено в табл. 9.13. Через переходник с 50 на 68-контактный разъем карты могут устанавливаться в слот PC Card Type II или III, имеющийся практически во всех блокнотных ПК. Объем памяти выпускаемых в настоящее время карт - от 4 Мбайт до 1 Гбайт, напряжение питания - 5 или 3,3 В. Карты могут работать в одном из трех режимов: карт памяти (Mem), карт ввода-вывода PC Card (I/O), «чистого» режима IDE (ATA). В первых двух режимах карты работают с теми же интерфейсными сигналами, что и PC Card. В режиме IDE электрический интерфейс и система команд полностью совместимы со спецификацией АТА (см. п. 9.2.1), правда, обмен данными возможен только в режиме РЮ. Режим IDE выбирается заземлением на стороне хоста сигнала ATA_SEL#. При этом из шины адреса используются только А[2:0] (остальные заземлены хостом); шина данных при обращениях к регистрам АТА имеет разрядность 8 бит, а при передаче данных - 16. Сигналы CSO# и CS1# используются для выбора блока командных и управляющих регистров соответственно. Сигналы PDIAG#, DASP#, CSEL#, RESET* и IORDY соответствуют спецификации АТА. Сигналом CSEL# выбирается роль карты: при заземленном контакте - устройство 0 (master), при разомкнутом - устройство 1 (slave); можно воспользоваться и «кабельной выборкой». Сигналы REG# и WE# должны подключаться к шине питания (Vcc). Сигналы CD1# и CD2# являются индикаторами установки карты (их контакты замыкаются последними, на карте они заземлены). В табл. 9.14 описан чисто пассивный переходник, позволяющий подключить карту Compact Flash к обычному порту АТА (IDE), имеющемуся на любой современной системной плате.&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;&lt;br /&gt; &lt;br /&gt;Таблица 9.13. Назначение контактов карт CompactFlash&lt;br /&gt; &lt;br /&gt;№    Mem&lt;br /&gt; &lt;br /&gt;I/O&lt;br /&gt; &lt;br /&gt;IDE&lt;br /&gt; &lt;br /&gt;№     Mem&lt;br /&gt; &lt;br /&gt;I/O&lt;br /&gt; &lt;br /&gt;IDE&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;1	GND	GND	GND	26	CD1#	CD1#	CD1#&lt;br /&gt;2	DOS	DOS	DOS	27	D11	D11	D11&lt;br /&gt;3	D04	D04	D04	28	D12	D12	D12&lt;br /&gt;4	DOS	DOS	DOS	29	D13	D13	D13&lt;br /&gt;5	D06	D06	D06	30	D14	D14	D14&lt;br /&gt;6	D07	D07	D07	31	D15	D15	D15&lt;br /&gt;7	CE1#	CE1#	CSO#	32	CE2#	CE2#	CS1#&lt;br /&gt;8	A10	A10	A10	33	VS1#	VS1#	VS1#&lt;br /&gt;9	OE#	OE#	ATA_SEL#	34	IORD#	IORD#	IORD#&lt;br /&gt;10	A09	A09	A09	35	IOWR#	IOWR#	IOWR#&lt;br /&gt;11	A08	A08	A08	36	WE#	WE#	WE#&lt;br /&gt;12	A07	A07	A07	37	RDY/BSY	IREQ	INTRQ&lt;br /&gt;13.	VCC	VCC	VCC	38	VCC	VCC	VCC&lt;br /&gt;14	A06	A06	A06	39	CSEL#	CSEL#	CSEL#&lt;br /&gt;15	A05	A05	A05	40	VS2#	VS2#	VS2#&lt;br /&gt;16	A04	A04	A04	41	RESET	RESET	RESET#&lt;br /&gt;17	A03	A03	A03	42	WAIT*	WAIT#	IORDY&lt;br /&gt;18	A02	A02	A02	43	INPACK*	INPACK*	INPACK#&lt;br /&gt;19	A01	A01	A01	44	REG#	REG#	REG#&lt;br /&gt;20	AGO	AOO	AOO	45	BVD2	SPKR#	DASP#&lt;br /&gt;21	DOO	DOO    .	DOO	46	BVD1	STSCHG#	PDIAGtf&lt;br /&gt;22	D01	D01	D01	47	D08	DOS	DOS&lt;br /&gt;23	D02	D02	D02	48	D09	D09	D09&lt;br /&gt;24	WP	IOIS16*	IOCS16*	49	D10	D10	D10&lt;br /&gt;25	CD2#	CD2#	CD2#	50	GND	GND	GND&lt;br /&gt;Таблица 9.14. Переходник CompactFlash Card - ATA&lt;br /&gt; &lt;br /&gt;ATA, конт. №    Цепь&lt;br /&gt; &lt;br /&gt;CFC, конт. №   CFC, конт. №   Цепь&lt;br /&gt; &lt;br /&gt;ATA, конт. №&lt;br /&gt; &lt;br /&gt;&lt;br /&gt; &lt;br /&gt;2&lt;br /&gt;11&lt;br /&gt;9&lt;br /&gt;7&lt;br /&gt;5&lt;br /&gt;3&lt;br /&gt;37&lt;br /&gt;GND1&lt;br /&gt;GND&#039;&lt;br /&gt;GND1&lt;br /&gt;GND1&lt;br /&gt;GND1&lt;br /&gt;+5V2&lt;br /&gt;GND1&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;GND	1&lt;br /&gt;DOS	2&lt;br /&gt;D04	3&lt;br /&gt;DOS	4&lt;br /&gt;D06	5&lt;br /&gt;D07	6&lt;br /&gt;CSO#	7&lt;br /&gt;A10	8&lt;br /&gt;ATA_SEL#	9&lt;br /&gt;A09	10&lt;br /&gt;A08	11&lt;br /&gt;A07	12&lt;br /&gt;VCC	13&lt;br /&gt;A06	14&lt;br /&gt; &lt;br /&gt;26 27 28 29 30 31 32 33 34 35 36 37 38 39&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;CD1#	-&lt;br /&gt;D11	10&lt;br /&gt;D12	12&lt;br /&gt;D13	14&lt;br /&gt;D14	16&lt;br /&gt;D15	18&lt;br /&gt;CS1#	38&lt;br /&gt;VS1#	-&lt;br /&gt;IORD#	25&lt;br /&gt;IOWR#	23&lt;br /&gt;WE#	+5V2&lt;br /&gt;INTRQ	31&lt;br /&gt;VCC	+5V2&lt;br /&gt;CSEL#	283&lt;br /&gt;	продолжение &amp;&lt;br /&gt;&lt;br /&gt;Таблица 9.14 (продолжение)&lt;br /&gt; &lt;br /&gt;АТА, конт. №    Цепь         CFC, конт. №    CFC, конт. №   Цепь&lt;br /&gt; &lt;br /&gt;ATA, конт. №&lt;br /&gt; &lt;br /&gt;&lt;br /&gt;GND1	А05	15	40	VS2#	-&lt;br /&gt;GND1	А04	16	41	RESET*	1&lt;br /&gt;GND1	АОЗ	17	42	IORDY	27&lt;br /&gt;36	А02	18	43	INPACK#	-&lt;br /&gt;33	А01	19	44	REG#	+5V2&lt;br /&gt;35	АОО	20	45	DASP#	39&lt;br /&gt;17	DOO	21	46	PDIAG#	34&lt;br /&gt;15	D01	22	47	D08	4&lt;br /&gt;13	D02	23	48	D09	6&lt;br /&gt;32	IOCS16#	24	49	D10	8&lt;br /&gt;-	CD2#	25	50	GND	GND&#039;&lt;br /&gt;1	С шиной GND должны быть соединены контакты 2,19,22,24,26,30 и 40 разъема АТА, а также контакт разъема питания.&lt;br /&gt;2	Питание +5V на переходник подается от дополнительного разъема.&lt;br /&gt;3	Возможно подключение не к разъему АТА, а к шине GND через джампер: замкнут - ведущее устройство, разомкнут - ведомое.</yandex:full-text>
</item><item>
<title>SmartMedia Card</title>
<link>http://intpc.ru/143-smartmedia-card.html</link>
<description>Карты SmartMedia Card, поддерживаемые ассоциацией PCMCIA, предназначены примерно для того же круга приложений, что и CompactFlash.</description>
<category>Интерфейсы устройств хранения</category>
<author>jcrush</author>
<pubDate>Mon, 29 Dec 2008 19:40:00 +0300</pubDate>
<yandex:full-text>Карты SmartMedia Card, поддерживаемые ассоциацией PCMCIA, предназначены примерно для того же круга приложений, что и CompactFlash. Они совсем тонкие, имеют менее «нежный» печатный разъем с малым числом контактов (всего 22) и не боятся не только повышенной влажности, но и воды. Карты основаны на микросхемах флэш-памяти с организацией запоминающих ячеек NAND. Средняя скорость передачи данных - 2 Мбайт/с, пиковая - до 10. Вид карт приведен на рис. 9.8, назначение контактов -в табл. 9.15. Карты на 5 В выпускаются объемом 16и32 Мбит (2 и 4 Мбайт). Карты на 3,3 В выпускаются объемом 16, 32 или 64 Мбит (2, 4, 8 Мбайт); у них контакт 17 соединен с Vcc. Для карт SmartMedia выпускают простые переходные адаптеры на слот PC Card Type II. Появились даже устройства FlashPath™ для считывания этих карт в обычном дисководе(!) 1,44 Мбайт.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;Таблица 9.15. Назначение контактов SmartMedia Card&lt;br /&gt;№     Цепь	№      Цепь&lt;br /&gt;&lt;br /&gt;22	VCC(5 B)	1	Vss&lt;br /&gt;21	СЕ#	2	CLE&lt;br /&gt;20	RE#	3	ALE&lt;br /&gt;19	R/B	4	WE#&lt;br /&gt;18	GND	5	WP#&lt;br /&gt;17	Power Detect	6	1/01&lt;br /&gt;16	I/08	7	I/02&lt;br /&gt;15	I/O?	8	I/O3&lt;br /&gt;14	I/06	9	I/O4&lt;br /&gt;13	I/O5	10	Vss&lt;br /&gt;12	Vcc	11	vss&lt;br /&gt;</yandex:full-text>
</item></channel></rss>
