Июль 2019
ПнВтСрЧтПтСбВс
1234567
891011121314
15161718192021
22232425262728
293031    

Календарь Календарь

Последние темы
» ПЭВМ "ПК8002 Эльф"
автор alemorf Сегодня в 00:59

» SINOVATE (SIN). Криптовалюта Синовэйт.
автор Viktor2312 Вчера в 23:57

» РК86: подключение винчестера IDE (или CF-карты)
автор barsik Вчера в 22:28

» РК86 в роли терминала
автор freddy Вчера в 20:07

» Упрощаем схему Микро-80 и исправляем косяки. И собираем по технологиям 80-х годов.
автор alemorf Вчера в 10:02

» Радио-86РК: внешние видео-адаптеры
автор freddy Вчера в 01:00

» Анти Радио-86РК
автор freddy Вчера в 00:43

» Новинки. Книги. Часть 3.
автор Viktor2312 Вс Июл 21 2019, 18:45

» Использование ЯВУ для разработки программ для РК86
автор freddy Вс Июл 21 2019, 17:50

» Журнал: Электричество.
автор Viktor2312 Вс Июл 21 2019, 16:14

» Личная тех. тема.
автор Viktor2312 Пн Июл 15 2019, 17:07

» Расширение ОЗУ
автор barsik Пн Июл 15 2019, 09:06

» ZX-Spectrum. Статьи, заметки, очерки, разное...
автор Viktor2312 Пт Июл 05 2019, 21:32

» Микросхемы ПЛИС CPLD CoolRunner-II.
автор Viktor2312 Чт Июл 04 2019, 21:22

» Программирование для ИРИШИ
автор barsik Ср Июл 03 2019, 20:04

» Куплю телеграфный аппарат РТА-80.
автор Savoj Вт Июл 02 2019, 09:54

» Новости. Xilinx.
автор Viktor2312 Вт Июл 02 2019, 09:40

» ПЭВМ "Электроника МК-85"
автор alemorf Пт Июн 28 2019, 22:45

» Арго ПК ФВ 6511. Информация, докуметы, фото.
автор alemorf Ср Июн 26 2019, 00:15

» К1810ГФ84
автор Viktor2312 Пт Июн 21 2019, 22:39

» Для начинающих.
автор barsik Пт Июн 21 2019, 21:41

» ПЭВМ "Поиск". Статьи, заметки, очерки, разное...
автор alemorf Ср Июн 19 2019, 22:21

» Современный Hard and Soft. Статьи, заметки, очерки, разное...
автор Viktor2312 Ср Июн 19 2019, 14:41

» Другой микропроцессор в ИРИШЕ
автор barsik Ср Июн 19 2019, 13:50

» Ферритовые антенны.
автор Viktor2312 Вт Июн 18 2019, 16:27

Самые активные пользователи за месяц
Viktor2312
"Радио-86РК". Статьи, заметки, очерки, разное... Vote_lcap"Радио-86РК". Статьи, заметки, очерки, разное... Voting_bar"Радио-86РК". Статьи, заметки, очерки, разное... Vote_rcap 
barsik
"Радио-86РК". Статьи, заметки, очерки, разное... Vote_lcap"Радио-86РК". Статьи, заметки, очерки, разное... Voting_bar"Радио-86РК". Статьи, заметки, очерки, разное... Vote_rcap 
freddy
"Радио-86РК". Статьи, заметки, очерки, разное... Vote_lcap"Радио-86РК". Статьи, заметки, очерки, разное... Voting_bar"Радио-86РК". Статьи, заметки, очерки, разное... Vote_rcap 
alemorf
"Радио-86РК". Статьи, заметки, очерки, разное... Vote_lcap"Радио-86РК". Статьи, заметки, очерки, разное... Voting_bar"Радио-86РК". Статьи, заметки, очерки, разное... Vote_rcap 
Savoj
"Радио-86РК". Статьи, заметки, очерки, разное... Vote_lcap"Радио-86РК". Статьи, заметки, очерки, разное... Voting_bar"Радио-86РК". Статьи, заметки, очерки, разное... Vote_rcap 

Поиск
 
 

Результаты :
 


Rechercher Расширенный поиск


"Радио-86РК". Статьи, заметки, очерки, разное...

Перейти вниз

"Радио-86РК". Статьи, заметки, очерки, разное... Empty "Радио-86РК". Статьи, заметки, очерки, разное...

Сообщение  Viktor2312 в Пт Сен 23 2016, 13:27

1
*


Последний раз редактировалось: Viktor2312 (Вт Фев 19 2019, 18:44), всего редактировалось 1 раз(а)
Viktor2312
Viktor2312
Гуру+

Сообщения : 11627
Дата регистрации : 2012-08-10
Возраст : 40
Откуда : Пятигорск

Посмотреть профиль

Вернуться к началу Перейти вниз

"Радио-86РК". Статьи, заметки, очерки, разное... Empty Re: "Радио-86РК". Статьи, заметки, очерки, разное...

Сообщение  Viktor2312 в Сб Янв 21 2017, 15:44

2
резерв.
Viktor2312
Viktor2312
Гуру+

Сообщения : 11627
Дата регистрации : 2012-08-10
Возраст : 40
Откуда : Пятигорск

Посмотреть профиль

Вернуться к началу Перейти вниз

"Радио-86РК". Статьи, заметки, очерки, разное... Empty IN/OUT в системах на 8080 без системного контроллера

Сообщение  barsik в Сб Май 04 2019, 20:20

3
Почитывая на досуге вражеские книги и журналы на тему антикварных микропроцессоров (благо проблем с знанием вражеских языков нет), узнал недавно, как следовало с пользой использовать наличие в КР580 команд IN/OUT. Оказывается, чтобы использовать команды IN/OUT совершенно необязательно ставить системный контроллер СК ВК28 (или делать его аналог вокруг 589ИР12 на мелкой логике).

IN/OUT выгодны тем, что они 2-х байтовые, тогда как команды работы с ОЗУ (если не считать косвенную адресацию) - трёх-байтовые. Когда идёт битва за каждый байт, что типично для кода прошиваемого в ПЗУ, то возможность применить IN/OUT становится ценной. Например, лишь из-за нелегального использования команд IN/OUT в РК-ДОС её автор Е.Седов выиграл в объёме кода ~полсотни байт (что вызвало впоследствии много горя при процессоре Z80).

Т.к I/O-портов всего 256, то в РК86 достаточно выделить в области памяти одну страницу в 256 байт. В РК найти свободные сплошные 256 адресов не проблема. Чтобы поиметь 256 портов в памяти, но с которыми можно работать командами IN/OUT, хитрые враги обычно делают так.

Они при работе команд IN/OUT хитро выдают на старшую половину шины адреса (msb) старший адрес страницы выделенной для портов. Например, если мы решили отдать портам участок A000...A0FF, то надо выдавать при OUT на адреса A15...A8 число $A0.

Процессоры 8085 и Z80 сразу дают /IORD и /IOWR, которые можно объединить на двух диодах и резисторе, получив сигнал /IO о том, что идёт команда IN/OUT. А вот при КР580 требуется получать его из "слова состояния", для чего надо по фронту SYNC защёлкивать в 155 ТМ2 биты D4 и D6, а инверсные выходы этих триггеров также объединить двумя диодами. Полученный с помощью 2-х диодов сигнал /IO, когда он равен 0, свидетельствует, что идёт работа с портами.

Если по этому сигналу /IO выдавать на шину данных адрес страницы портов в памяти (в данном примере это $A0), то с портами отображёнными в память можно работать командами IN/OUT, как при наличии системного контроллера. Выгоднее всего старший (msb) байт адреса страницы портов выдавать с помощью двух 555 КП11, т.к при этом одновременно адреса A15...A8 процессора буферизуются. Но можно использовать отключаемый 8-ми разрядный буфер АП6 и резисторы привязки (что даёт страницу портов FF00).

Эти КП11-тые при не OUT-командах пропускают через себя адреса A15...A8 от процессора, а при OUT командах выдают в линии A15...A8 msb-байт адреса страницы портов. Если изменять число набранное на входе КП11, то страницу портов можно "гонять" по всему адресному пространству, что, кстати, и делается в «Корвете» (позволяя создать конфигурацию наиболее удобную для конкретной задачи, например, там одна конфигурация портов для МГ-бейсика и совсем другая для CP/M).

Причём, интересно, что мы получаем порты, которые читаются и по обращению в память и по IN/OUT, что даёт нам ещё больше выигрыша. Во-первых, скорость. LD A,(HL) вдвое быстрее, чем IN A,(port). Во-вторых, мы можем проверять один флаг по биту D7 всего одной командой. Например, INC (HL) при HL указывающем в порт выдаст во флаге Signum значение бита D7 порта, что экономит нам команду OR A. При этом возможность работать с портами двухбайтовыми IN/OUT, и экономить тем самым объём кода в некритичных к скорости местам, сохраняется.

Не знаю дошла ли эта идея до узколобых, что читают этот форум (малоизвестный среди энтузиастов антикварных компьютеров), потому подскажу лишь, что если бы разработчики «РК86» читали в своё время вражеские книги, то они могли бы израсходовать на порты не 32 тысячи адресов, а всего 256, получив при этом выигрыш в объёме кода за счёт двухбайтовости команд IN/OUT, причём не увеличивая число корпусов (даже уменьшив его на один корпус).

PS. Подсказка для технически малограмотных. msb на вражьем языке означает "most significant byte of word or address".

_________________
***
barsik
barsik
Мастер++

Сообщения : 506
Дата регистрации : 2016-11-10
Откуда : С-Петербург

Посмотреть профиль

Вернуться к началу Перейти вниз

"Радио-86РК". Статьи, заметки, очерки, разное... Empty Re: "Радио-86РК". Статьи, заметки, очерки, разное...

Сообщение  Спонсируемый контент

4

Спонсируемый контент


Вернуться к началу Перейти вниз

Вернуться к началу


 
Права доступа к этому форуму:
Вы не можете отвечать на сообщения