[an error occurred while processing this directive] [an error occurred while processing this directive]
Вообщем делается это так...
(«Телесистемы»: Конференция «Программируемые логические схемы и их применение»)
[an error occurred while processing this directive] [an error occurred while processing this directive]

Отправлено Maksim 12 июня 2002 г. 13:39
В ответ на: Может кто подскажет по PCI... отправлено Maksim Z. 12 июня 2002 г. 11:01

1.Считывание данных, а именно MEMORY READ идет всегда 4-мя байтами.
2.Формат заголовка расширения BIOS отличается от ISA (см. описание
стандарта по PCI).
3.Быстродействие памяти не имеет значения,т.е система выставляет
адреса с шагом в 4 байта, а ваше устройство готовит эти 4 байта с
тем темпом который ней доступен (100 нс, 1000 нс,... 100 лет).Но тут
возникает вопрос - а как системе сказать: "подожди". Сделать это
можно двумя способами:
а)Retry
б)удерживать Devsel в нуле до тех пор пока не будут готовы 4 байта
для считывания, как всё готово выставлять TRDY на один период и
вместе с Devsel завершать обмен.
Вторым способом пользуются очень многие (легко убедиться посмотрев
различные PCI карточки, там даже нет сигнала STOP на краевом
разъёме)
Не которые могут сказать, что будет конфликт с MASTER платами, но
расширение BIOS загружается до старта ОС (соответственно и нет
никаких драйверов на тот момент которые могли бы активизировать
MASTER)

P.S. Если после загрузки расширения BIOS требуется обращаться к этой
ПЗУ в процессе работы, то надо использовать, только RETRY.


Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание  |||  Без кадра

E-mail: info@telesys.ru