RUЭВМ
Вы хотите отреагировать на этот пост ? Создайте аккаунт всего в несколько кликов или войдите на форум.
Июль 2020
ПнВтСрЧтПтСбВс
  12345
6789101112
13141516171819
20212223242526
2728293031  

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

Последние темы
» Радио-86РК: внешние видео-адаптеры
автор Microsha Сегодня в 14:06

» Новости криптовалют: статьи, заметки, разное...
автор Viktor2312 Пн Июл 06 2020, 10:51

» Новинки. Книги. Часть 1.
автор Viktor2312 Сб Июл 04 2020, 11:56

» Арго ПК ФВ 6511. Информация, документы, фото.
автор Viktor2312 Ср Июл 01 2020, 21:23

» Обзор крипто проектов.
автор Viktor2312 Вс Июн 28 2020, 00:03

» МИКРО - 80. Статьи, заметки, очерки, разное...
автор barsik Сб Июн 27 2020, 22:56

» Серия видео про Биткоин.
автор Viktor2312 Сб Июн 27 2020, 16:09

» Электроника КР-04. Информация, документы, фото.
автор barsik Пт Июн 26 2020, 13:25

» Флейм только по теме "Радио-86РК".
автор barsik Чт Июн 25 2020, 20:06

» Netbox.Global (NBX) - браузер с инновационной технологией.
автор Viktor2312 Вт Июн 23 2020, 14:45

» Электроника КР-03: Обсуждение
автор barsik Чт Июн 18 2020, 21:24

» Радио-86РК: Разное
автор barsik Чт Июн 18 2020, 02:06

» Биткоин, с технической точки зрения. Разное...
автор Viktor2312 Вт Июн 16 2020, 22:47

» Радио-86РК: Расширение ОЗУ
автор barsik Чт Июн 11 2020, 10:21

» Разное
автор Viktor2312 Вт Июн 09 2020, 01:40

» Улучшение видео возможностей РК86
автор barsik Вс Май 31 2020, 12:39

» Турбирование Специалиста
автор barsik Пт Май 22 2020, 13:33

» Программы от РК86 на Специалисте
автор barsik Ср Май 20 2020, 21:08

» Варианты улучшения платы ЭКСПРЕСС минимальной ценой
автор barsik Ср Май 20 2020, 21:02

» Z80 в Специалисте
автор barsik Ср Май 20 2020, 21:00

» Семейство PIC32MZ EF 32-разрядных МК (252 МГц).
автор Viktor2312 Вт Апр 28 2020, 15:53

» Микросхема ЦАП AK4499, ЦАПы на её основе. Общая тема.
автор Viktor2312 Вс Апр 12 2020, 14:27

» Можно ли улучшить цвет Специалиста ?
автор barsik Чт Апр 09 2020, 19:03

» USB --> I2S
автор Viktor2312 Пн Апр 06 2020, 00:25

» Часики на лампах
автор freddy Вс Мар 15 2020, 14:27

Самые активные пользователи за месяц
Viktor2312
"Радио-86РК". Статьи, заметки, очерки, разное... Vote_lcap"Радио-86РК". Статьи, заметки, очерки, разное... Voting_bar"Радио-86РК". Статьи, заметки, очерки, разное... Vote_rcap 
barsik
"Радио-86РК". Статьи, заметки, очерки, разное... Vote_lcap"Радио-86РК". Статьи, заметки, очерки, разное... Voting_bar"Радио-86РК". Статьи, заметки, очерки, разное... Vote_rcap 
Microsha
"Радио-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
Гуру+

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

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

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

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

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

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

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

"Радио-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
Мастер++

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

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

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

Сообщение  barsik в Сб Авг 03 2019, 07:26

4
Ставить микросхемы памяти вторым этажом догадались не только авторы РК86. Чуть раньше до этого додумались японцы из фирмы Hitachi, когда в начале 80-тых разрабатывали свои клоны моторолловских микроконтроллеров 6801 и 6805. Наряду с микроконтроллерами в которых программа хранится в ПЗУ с УФ-очисткой и масочных (программируемых при изготовлении на заводе) они изобрели двухэтажные микроконтроллеры совместимые с теми по цоколёвке.

Вторым этажом ставится обычное УФ-ПЗУ типа 2764...27256. И если в традиционных микроконтроллерах за 35 лет встроенное в кристалл УФ-ПЗУ сдохло, то двухэтажные микроконтроллеры пригодны для использования и 35 лет спустя. В них можно любое число раз изменять прошивку (а если используемое перепрограммируемое УФ-ПЗУ сдохнет, не проблема заменить его на новое).

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

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

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

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

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

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

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

5

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


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

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


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