Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Скачиваний:
18
Добавлен:
16.04.2013
Размер:
399.87 Кб
Скачать

6.4.2. Организация и управление пдп на at-подобных пэвм.

IBM PC AT и AT-подобные ПЭВМ имеют два контроллера ПДП 8237А, работающиe в каскадном режиме.

Назначение каналов следующие:

0 - свободен;

1 - адаптер SDLC;

2 - контроллер накопителей на гибких дисках;

3 - контроллер накопителей на жестких дисках;

4 - каскад с первым контроллером ПДП;

5, 6, 7 - свободны.

Управление каналами 0 - 3 осуществляется аналогично PC/ХТ. Каналы 4 - 7 предназначены для обмена 16-разрядными словами. В связи с этим возникает ряд отличий в работе с этими каналами:

- бит 0 в данных, заносимых в регистры начального и текущего адреса, всегда подразумевается равным 0, поэтому через эти регистры передаются биты 1 - 16 полного 23-разрядного адреса (а не биты 0 - 15 полного 20-разрядного адреса, как это реализовано на ХТ-подобных ПЭВМ), по этой же причине в

страничные регистры каналов 4 - 7 заносятся биты 17 - 23 полного адреса, а не биты 16 - 23, как это надо сделать при работе с каналами 0 - 3;

- поскольку передача осуществляется 16-разрядными словами, в регистры текущего и начального счетчика циклов заносится не число байт, а число слов, уменьшенное на единицу;

- размеры страниц памяти, в пределах которых возможен обмен в течение одной передачи составляют 2000h байтов.

В таблице приведено описание портов ввода-вывода, предназначенных для управления вторым контроллером ПДП.

-------T--------T---------------------------------------------¬

¦ Порт ¦ Режим ¦ Назначение ¦

+------+--------+---------------------------------------------+

¦ 0C0h ¦ запись ¦ Запись начального адреса в регистр начально-¦

¦ ¦ ¦ го адреса и регистр текущего адреса канала 4¦

¦ ¦ ¦ ¦

¦ 0C4h ¦ запись ¦ то же для канала 5 ¦

¦ ¦ ¦ ¦

¦ 0C8h ¦ запись ¦ то же для канала 6 ¦

¦ ¦ ¦ ¦

¦ 0CCh ¦ запись ¦ то же для канала 7 ¦

¦ ¦ ¦ ¦

¦ 0C0h ¦ чтение ¦ Чтение начального адреса из регистра началь-¦

¦ ¦ ¦ ного адреса канала 4 ¦

¦ ¦ ¦ ¦

¦ 0C4h ¦ чтение ¦ то же для канала 5 ¦

¦ ¦ ¦ ¦

¦ 0C8h ¦ чтение ¦ то же для канала 6 ¦

¦ ¦ ¦ ¦

¦ 0CCh ¦ чтение ¦ то же для канала 7 ¦

¦ ¦ ¦ ¦

¦ 0C2h ¦ запись ¦ Запись в регистр начального счетчика циклов ¦

¦ ¦ ¦и в регистр текущего счетчика циклов канала 4¦

¦ ¦ ¦ ¦

¦ 0C6h ¦ запись ¦ то же для канала 5 ¦

¦ ¦ ¦ ¦

¦ 0CAh ¦ запись ¦ то же для канала 6 ¦

¦ ¦ ¦ ¦

¦ 0CEh ¦ запись ¦ то же для канала 7 ¦

¦ ¦ ¦ ¦

¦ 0C2h ¦ чтение ¦ Чтение текущего значения из регистра теку- ¦

¦ ¦ ¦ щего счетчика циклов канала 4 ¦

¦ ¦ ¦ ¦

¦ 0C6h ¦ чтение ¦ то же для канала 5 ¦

¦ ¦ ¦ ¦

¦ 0Cah ¦ чтение ¦ то же для канала 6 ¦

¦ ¦ ¦ ¦

¦ 0CCh ¦ чтение ¦ то же для канала 7 ¦

¦ ¦ ¦ ¦

¦ 89h ¦ запись ¦ Задание номера страницы для канала 6 ¦

¦ ¦ ¦ ¦

¦ 8Bh ¦ запись ¦ то же для канала 5 ¦

¦ ¦ ¦ ¦

¦ 8Ah ¦ запись ¦ то же для канала 7 ¦

¦ ¦ ¦ ¦

¦ 8Fh ¦ запись ¦ то же для канала 4 ¦

L------+--------+----------------------------------------------

В следующей таблице приведено описание назначения портов второго контроллера ПДП с указанием аналогичных портов первого контроллера. Форматы данных, вводимых/выводимых через эти порты совпадают с форматами данных аналогичных портов первого контроллера. При работе с этими портами следует только учитывать, что нумерация каналов начинается не с 0, как у первого контроллера, а с 4 (канал 4 - это канал 0 второго контроллера, канал 5 - это его канал 1 и т. д.).

-------T--------T-----------------------------------T---------¬

¦ Порт ¦ ¦ ¦ Аналог. ¦

¦ ¦ Режим ¦ Назначение ¦ порт ¦

¦ ПДП-2¦ ¦ ¦ ПДП-1 ¦

+------+--------+-----------------------------------+---------+

¦ 0D0h ¦ запись ¦ Запись регистра команд ПДП ¦ 8h ¦

¦ ¦ ¦ ¦ ¦

¦ 0D0h ¦ чтение ¦ Чтение регистра состояния ПДП ¦ 8h ¦

¦ ¦ ¦ ¦ ¦

¦ 0D2h ¦ запись ¦ Запись в регистр запросов ПДП ¦ 9h ¦

¦ ¦ ¦ ¦ ¦

¦ 0D4h ¦ запись ¦ Запись бита маски для одного из ка¦ 0Ah ¦

¦ ¦ ¦ каналов ПДП ¦ ¦

¦ ¦ ¦ ¦ ¦

¦ 0D6h ¦ запись ¦ Запись регистра режимов для одного¦ 0Bh ¦

¦ ¦ ¦ из каналов ПДП ¦ ¦

¦ ¦ ¦ ¦ ¦

¦ 0D8h ¦ запись ¦ Очистка (сброс) триггера-защелки ¦ 0Ch ¦

¦ ¦ ¦ (триггера первого/последнего) ¦ ¦

¦ ¦ ¦ ¦ ¦

¦ 0DAh ¦ запись ¦ Программный сброс контроллера ¦ 0Dh ¦

¦ ¦ ¦ ¦ ¦

¦ 0DCh ¦ запись ¦ Очистка битов масок всех каналов ¦ 0Eh ¦

¦ ¦ ¦ ¦ ¦

¦ 0DEh ¦ запись ¦ Запись регистра масок для всех 4-х¦ 0Fh ¦

¦ ¦ ¦ каналов ¦ ¦

¦ ¦ ¦ ¦ ¦

¦ 0DAh ¦ чтение ¦ Чтение рабочего регистра ПДП ¦ 0Dh ¦

¦ ¦ ¦ ¦ ¦

L------+--------+-----------------------------------+----------

Тут вы можете оставить комментарий к выбранному абзацу или сообщить об ошибке.

Мы не исправляем ошибки в тексте (почему?), но будем благодарны, если вы все же напишите об ошибках.