КР580ВМ80А - недокументированные инструкции
Moderator: Shaos
-
- Junior
- Posts: 1
- Joined: 23 Mar 2006 13:00
КР580ВМ80А - недокументированные инструкции
Драсте, господа, есть такой вопрос:
Слухи ходят, что ВМ80 имел две (вроде) недокументированные инструкции которых небыло в оригинальном, забугорном i8080.
Собственно, интересно, что эт были за инструкции?
Может ктонибудь из обитателей форума знает о них.
Слухи ходят, что ВМ80 имел две (вроде) недокументированные инструкции которых небыло в оригинальном, забугорном i8080.
Собственно, интересно, что эт были за инструкции?
Может ктонибудь из обитателей форума знает о них.
-
- Maniac
- Posts: 252
- Joined: 21 Jan 2003 04:08
-
- Banned
- Posts: 2139
- Joined: 20 Mar 2005 13:41
- Location: От туда
-
- Retired
- Posts: 1474
- Joined: 03 Aug 2003 22:37
- Location: Moscow
Re: КР580ВМ80А - недокументированные инструкции
Что-то мне подсказывает, что речь идёт не о ВМ80, а о ВМ1, у которого в самом деле были такие команды. Позволю себе вольность привести цитату из FAQ по "Вектору-06Ц":
Code: Select all
Q1: "Что это за процессор - КР580ВМ1?"
A1: "КР580ВМ1 - еще один пpоцессоp без аналогов. Питание - 5 вольт, система команд чуть шиpе, чем у КР580ВМ80А, pегистpов на 2 больше, паспоpтная частота до 5 МГц, паспоpтная адpесация - 128 Кб. Его в свое вpемя выпускал киевский завод "Квазаp", но с pазвалом Союза они захиpели и сдохли. Знаю только, что в связи с отсутствием спpоса на новый пpоцессоp на Укpаине, последнюю паpтию готовых чипов они пpосто пустили под пpесс. Еще были слухи о выпуске ВМ1 в Омске. В "Вектоp" ВМ1 вставляется элементаpно, pаботает очень надежно, совместимость с ВМ80 после этого- абсолютная. Из адаптиpованного ПО есть веpсия ДОС Т-34 для этого пpоцессоpа. Ускоpение основных функций заметно даже на глаз." /Сергей Терентьев/
Extreme Entertainment
-
- Retired
- Posts: 490
- Joined: 16 Mar 2002 17:00
-
- Retired
- Posts: 490
- Joined: 16 Mar 2002 17:00
-
- Admin
- Posts: 23989
- Joined: 08 Jan 2003 23:22
- Location: Silicon Valley
Надо проверить 8085 на это дело - а так прикольный путь создания программ, неработающих на всемогущем Z80Shiru Otaku wrote:Сам и нашёл ответ (в исходниках MAME):
* - Undocumented i8080 opcodes added:
* 08h, 10h, 18h, 20h, 28h, 30h, 38h - NOP
* 0CBh - JMP
* 0D9h - RET
* 0DDh, 0EDh, 0FDh - CALL
* Thanks for the info go to Anton V. Ignatichev.

Я тут за главного - если что шлите мыло на me собака shaos точка net
-
- Retired
- Posts: 490
- Joined: 16 Mar 2002 17:00
Про 8085 там особо отмечено, у него другие команды с этими кодами. Комментарии разбросаны по коду, но вроде так:
#08 DSUB
#10 ASRH
#18 RLDE
#20 RIM
#28 LDEH nn
#2f CMA (устанавливает флаги, в отличии от 8080)
#30 SIM
#38 LDES nn
#CB RST 8 либо RST V (в зависимости от флага)
#D9 SHLX
#DD JNX nnnn
#ED LHLX
#FD JX nnnn
Что именно делают эти команды - можно посмотреть в коде эмулятора, но я вроде встречал в интернете инфу о недокументированных командах 8085.
А ещё в исходниках отмечено:
#08 DSUB
#10 ASRH
#18 RLDE
#20 RIM
#28 LDEH nn
#2f CMA (устанавливает флаги, в отличии от 8080)
#30 SIM
#38 LDES nn
#CB RST 8 либо RST V (в зависимости от флага)
#D9 SHLX
#DD JNX nnnn
#ED LHLX
#FD JX nnnn
Что именно делают эти команды - можно посмотреть в коде эмулятора, но я вроде встречал в интернете инфу о недокументированных командах 8085.
А ещё в исходниках отмечено:
* changes in V1.3
* - Added undocumented opcodes for the 8085A, based on a german
* book about microcomputers: "Mikrocomputertechnik mit dem
* Prozessor 8085A".
* - This book also suggest that INX/DCX should modify the X flag bit
* for a LSB to MSB carry and
* - that jumps take 10 T-states only when they're executed, 7 when
* they're skipped.
-
- Admin
- Posts: 23989
- Joined: 08 Jan 2003 23:22
- Location: Silicon Valley
RIM и SIM - документированные дополнительные команды, а вот все остальные по видимому являются недокументированными и мне неизвестны - надо чтоли покопать в инетеShiru Otaku wrote:Про 8085 там особо отмечено, у него другие команды с этими кодами. Комментарии разбросаны по коду, но вроде так:
#08 DSUB
#10 ASRH
#18 RLDE
#20 RIM
#28 LDEH nn
#2f CMA (устанавливает флаги, в отличии от 8080)
#30 SIM
#38 LDES nn
#CB RST 8 либо RST V (в зависимости от флага)
#D9 SHLX
#DD JNX nnnn
#ED LHLX
#FD JX nnnn
Что именно делают эти команды - можно посмотреть в коде эмулятора, но я вроде встречал в интернете инфу о недокументированных командах 8085.
Я тут за главного - если что шлите мыло на me собака shaos точка net
-
- Maniac
- Posts: 252
- Joined: 21 Jan 2003 04:08
-
- Retired
- Posts: 490
- Joined: 16 Mar 2002 17:00
Вот чего я ещё нашёл по 8085:
А что за история с недокументированными флагами сабжа? Т.е. биты 1, 3, 5. Бит 1 - флаг N на Z80; в коде эмуляции 8080/8085 в MAME этот флаг есть, и юзается в обоих режимах. Но нигде в документации на 8080 (которой, надо заметить, в интернете маловато) про флаг N ничего не сказано; а в архивах различных ньюсгрупп в обсуждениях разницы между Z80/8080 указывается, что этого флага 8080 не имеет, и, соответственно, он не используется в команде DAA (DAA работает корректно только после операций сложения).Hex 8085 Meaning
---------------------
08 SUB HL-BC
10 Shift right HL
18 Rotate right DE
20 RIM Read Interrupt Mask [legal 8085, but new from 8080]
28 Add HL and Immidiate nnnn into DE
30 SIM Set Interrupt Mask [legal 8085, but new from 8080]
38 Add SP and Immidiate nnnn into DE
CB ReSTart on Overflow to 0040h
D9 Load [DE] from HL
DD Jump on 'Not X5'
ED Load Hl from [DE]
FD Jump on 'X5'
-
- Supreme God
- Posts: 16676
- Joined: 21 Oct 2009 08:08
- Location: Россия
Бззз... сказала пилорама...
Это анекдот такой вспомнился...
- Вжик - сказала импортная пилорама и распилила бревно..
- Ого! - сказали русские рабочие и засунули в пилораму лом.
- Бзззз... - сказала пилорама.
- То-та!!! - сказали русские рабочие.
Я когда разбирался с К580, то подсовывал ему недокументрованные
команды как раз вот вместо лома по адресу 0000H и делал RST0.
Поскольку во всякой книге вумной написано - что процесор должен
считать КОП (код операции) - мне было интересно, а что будет, если
не КОП ? А на это годились недокументированные команды.
Но процессор не зависал и исполнял их, некоторые я даже определил
тогда - что это примерно за команды.
В итоге мысль ко мне пришла следующая - похоже что внутри у проца
недоопределённый дешифратор кода команд и по недокументированным
командам он выполняет не чюдо - а документированные, которые так
дешифруются.
Конечно, трудно сказать, что внутри у i8080, но похоже на то, как на
дешифратор семисегментного индикатора подать код, который он индицировать
не должен.
Такое у меня было мнение.
- Вжик - сказала импортная пилорама и распилила бревно..
- Ого! - сказали русские рабочие и засунули в пилораму лом.
- Бзззз... - сказала пилорама.
- То-та!!! - сказали русские рабочие.
Я когда разбирался с К580, то подсовывал ему недокументрованные
команды как раз вот вместо лома по адресу 0000H и делал RST0.
Поскольку во всякой книге вумной написано - что процесор должен
считать КОП (код операции) - мне было интересно, а что будет, если
не КОП ? А на это годились недокументированные команды.
Но процессор не зависал и исполнял их, некоторые я даже определил
тогда - что это примерно за команды.
В итоге мысль ко мне пришла следующая - похоже что внутри у проца
недоопределённый дешифратор кода команд и по недокументированным
командам он выполняет не чюдо - а документированные, которые так
дешифруются.
Конечно, трудно сказать, что внутри у i8080, но похоже на то, как на
дешифратор семисегментного индикатора подать код, который он индицировать
не должен.
Такое у меня было мнение.

Last edited by Lavr on 01 Dec 2012 12:30, edited 2 times in total.
-
- Admin
- Posts: 23989
- Joined: 08 Jan 2003 23:22
- Location: Silicon Valley
-
- God
- Posts: 1343
- Joined: 13 Nov 2010 04:06
А какие операции соответствуют другим "свободным" кодам, не известно? Ещё остаются C0, C7, C8, CF, D0, D7, DF, E0, E7, E8, EF, F0, F7, F8, FF. Особенно мне интересен код FF, проверил на своём НедоПЦ, после его считывания:
/MR 0800 FF
происходит запись в ОЗУ:
/MW CD53 08
/MW CD52 00
после чего чтение:
/MR 0038 xx.
/MR 0800 FF
происходит запись в ОЗУ:
/MW CD53 08
/MW CD52 00
после чего чтение:
/MR 0038 xx.
-
- Supreme God
- Posts: 16676
- Joined: 21 Oct 2009 08:08
- Location: Россия
Если ты - про 6502, то в Инете есть статья (находится по 6502) гдеVituZz wrote:А какие операции соответствуют другим "свободным" кодам, не известно? Ещё остаются C0, C7, C8, CF, D0, D7, DF, E0, E7, E8, EF, F0, F7, F8, FF. Особенно мне интересен код FF, проверил на своём НедоПЦ, после его считывания:
/MR 0800 FF
происходит запись в ОЗУ:
/MW CD53 08
/MW CD52 00
после чего чтение:
/MR 0038 xx.
довольно подробно разбирается, что происходит в недокументированных
командах... Там правда всё весьма задумчиво, и не все коды могут
соответствовать конкретной команде.
Я эту статью вот тут чутка цытировал, правда по иному поводу:
viewtopic.php?t=9386&postdays=0&postorder=asc&start=15
http://www.emuverse.ru/wiki/MOS_Technology_6502Lavr wrote:Кстати говоря, внутренняя шина 6502 выполнена на открытых коллекторах:Недокументированные команды
Многие недокументированные команды реально не выполняют операцию AND между регистрами. Это происходит автоматически, когда два значения помещаются одновременно на внутреннюю шину с открытыми коллекторами.
PS. Там надо выбрать ссылку - "Система команд".