<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>https://emuverse.ru/w/index.php?action=history&amp;feed=atom&amp;title=%D0%A3%D0%9A%D0%9D%D0%A6_%D0%B6%D1%83%D1%80%D0%BD%D0%B0%D0%BB_1994-01_%D0%BF%D1%80%D0%B5%D1%80%D1%8B%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F</id>
	<title>УКНЦ журнал 1994-01 прерывания - История изменений</title>
	<link rel="self" type="application/atom+xml" href="https://emuverse.ru/w/index.php?action=history&amp;feed=atom&amp;title=%D0%A3%D0%9A%D0%9D%D0%A6_%D0%B6%D1%83%D1%80%D0%BD%D0%B0%D0%BB_1994-01_%D0%BF%D1%80%D0%B5%D1%80%D1%8B%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F"/>
	<link rel="alternate" type="text/html" href="https://emuverse.ru/w/index.php?title=%D0%A3%D0%9A%D0%9D%D0%A6_%D0%B6%D1%83%D1%80%D0%BD%D0%B0%D0%BB_1994-01_%D0%BF%D1%80%D0%B5%D1%80%D1%8B%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F&amp;action=history"/>
	<updated>2026-05-04T00:06:55Z</updated>
	<subtitle>История изменений этой страницы в вики</subtitle>
	<generator>MediaWiki 1.40.0</generator>
	<entry>
		<id>https://emuverse.ru/w/index.php?title=%D0%A3%D0%9A%D0%9D%D0%A6_%D0%B6%D1%83%D1%80%D0%BD%D0%B0%D0%BB_1994-01_%D0%BF%D1%80%D0%B5%D1%80%D1%8B%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F&amp;diff=1969&amp;oldid=prev</id>
		<title>Nzeemin: Новая страница: «__NOTOC__ {{ДИ}}  = СИСТЕМА ПРЕРЫВАНИЙ ПРОЦЕССОРА К1801ВМ2 = :&#039;&#039;Статья из журнала «Персональный ком…»</title>
		<link rel="alternate" type="text/html" href="https://emuverse.ru/w/index.php?title=%D0%A3%D0%9A%D0%9D%D0%A6_%D0%B6%D1%83%D1%80%D0%BD%D0%B0%D0%BB_1994-01_%D0%BF%D1%80%D0%B5%D1%80%D1%8B%D0%B2%D0%B0%D0%BD%D0%B8%D1%8F&amp;diff=1969&amp;oldid=prev"/>
		<updated>2015-10-07T06:19:58Z</updated>

		<summary type="html">&lt;p&gt;Новая страница: «__NOTOC__ {{ДИ}}  = СИСТЕМА ПРЕРЫВАНИЙ ПРОЦЕССОРА К1801ВМ2 = :&amp;#039;&amp;#039;Статья из журнала «Персональный ком…»&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;__NOTOC__&lt;br /&gt;
{{ДИ}}&lt;br /&gt;
&lt;br /&gt;
= СИСТЕМА ПРЕРЫВАНИЙ ПРОЦЕССОРА К1801ВМ2 =&lt;br /&gt;
:&amp;#039;&amp;#039;Статья из журнала «Персональный компьютер УКНЦ» №1 1994 год&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
== Терминология ==&lt;br /&gt;
&lt;br /&gt;
* ВЕКТОР СОСТОЯНИЯ ПРОЦЕССА   — значения счетчика команд и слова состояния&lt;br /&gt;
* ВЕКТОР ПРЕРЫВАНИЯ                       — вектор состояния прерывающего процесса.&lt;br /&gt;
* АДРЕС ВЕКТОРА ПРЕРЫВАНИЯ      — адрес ячейки памяти, содержащей значение СК прерывающего процесса. В следующей ячейке хранится значение ССП прерывающего процесса.&lt;br /&gt;
* ПРОСЛЕЖИВАЕМАЯ КОМАНДА      — команда, выполняемая при установленном Т-разряде в ССП.&lt;br /&gt;
&lt;br /&gt;
== Источники прерываний и их АВП ==&lt;br /&gt;
&lt;br /&gt;
Прерывания, обусловленные применением процессора К1801ВМ2 и регистрируемые на магистралях ЦП и ПП, приведены в табл. 1.&lt;br /&gt;
&lt;br /&gt;
;Таблица 1&lt;br /&gt;
{| cellpadding=&amp;quot;2&amp;quot; cellspasing=&amp;quot;2&amp;quot; border=&amp;quot;1&amp;quot; style=&amp;quot;border-collapse:collapse&amp;quot;&lt;br /&gt;
!АВП	!!Очередность	!!Описание&lt;br /&gt;
|-&lt;br /&gt;
|4	||2	||Прерывание по запрещенной команде возникает при попытке выполнить команду с неправильно заданным методом адресации. К таким командам относятся команды JMP и JSR с регистровыми методами адресации&lt;br /&gt;
|-&lt;br /&gt;
|4	||1	||Прерывание по зависанию в канале возникает при попытке обращения по адресу несуществующей ячейки памяти или регистра ВУ&lt;br /&gt;
|-&lt;br /&gt;
|10	||2	||Прерывание по резервной команде возникает при попытке выполнить команду, код которой в данном процессоре не используется&lt;br /&gt;
|-&lt;br /&gt;
|14	||4	||Прерывание по Т-разряду вызывается после выполнения команды при установленном 4-м разряде ССП. Установка и очистка 4-го разряда возможна только при выполнении команд RTT, RTI, ШАГ, ПУСК и при загрузке вектора прерывания&lt;br /&gt;
|-&lt;br /&gt;
|24	||5	||Прерывание по сбою питания происходит при снижении сетевого питания за пределы допустимого уровня. По завершении выполнения текущей команды процессор переходит на выполнение программы обработки прерывания...&lt;br /&gt;
|-&lt;br /&gt;
|100	||7	||Прерывания от «сетевого таймера» возникают в момент достижения лучом кинескопа монитора конца кадра кадровый синхросигнал монитора.)&lt;br /&gt;
|-&lt;br /&gt;
|250	||3	||Прерывание по сигналу WIR. В ЦП УКНЦ используется только для работы внешних расширений магистрали ЦП (например, обработка ошибок обмена с дополнительными магистралями)&lt;br /&gt;
|-&lt;br /&gt;
|******	||8	||Сигнал VIRQ (от устройств ЭВМ, см. след. главу)&lt;br /&gt;
|-&lt;br /&gt;
|160000	||	||Прерывание по включении питания&lt;br /&gt;
|-&lt;br /&gt;
|160004	||4	||Зависание в режиме HALT&lt;br /&gt;
|-&lt;br /&gt;
|160170	||6	||Сигнал (команда) HALT&lt;br /&gt;
|-&lt;br /&gt;
|160174	||6	||Двойное зависание возникает в случае зависания в канале во время выполнения микропрограммной процедуры прерывания, вызванной зависанием при передаче данных по каналу (т.е. если при загрузке ВП процесса обработки прерывания по зависанию в СК попадает адрес несуществующей ячейки)&lt;br /&gt;
|-&lt;br /&gt;
|160274	||6	||Зависание при приеме адреса вектора прерывания фиксируется в случае, если внешнее устройство выставило запрос на прерывание и не формирует АВП. Это, в частности, происходит при возникновении требования прерывания внешним устройством во время выполнения команды маскирования прерывания в регистре состояния этого же устройства. Отсюда рекомендация запрещать прерывания конкретных устройств только при высоком приоритете процессора (ССП(7)-1)&lt;br /&gt;
|-&lt;br /&gt;
|160010	||	||По этому вектору возникает прерывание в случае попытки выполнить команду арифметики с плавающей запятой *&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Особые случаи прерывания по Т-разряду ==&lt;br /&gt;
&lt;br /&gt;
#	Если прослеживаемая команда RTI или RTT очищает Т-разяд, то после ее выполнения все же происходит прерывание по Т-разряду. Однако в стеке сохранится ССП с очищенным Т-разрядом.&lt;br /&gt;
#	Если прослеживаемая команда ШАГ, ПУСК, HALT или команда прерывания очищает Т-разряд, то после ее выполнения прерывания по Т-разряду не происходит.&lt;br /&gt;
#	Если прослеживаемая команда ШАГ или RTT устанавливает Т-разряд, то прерывание по Т-разряду произойдет после выполнения следующей за ШАГ или RTT командой.&lt;br /&gt;
#	После выполнения остальных команд, устанавливающих Т-разряд, прерывание происходит сразу за ними.&lt;br /&gt;
#	Если во время выполнения прослеживаемой команды произошло зависание и при загрузке ВП Т-разряд очищается, то прерывание по Т-разряду не происходит.&lt;br /&gt;
#	Во время выполнения прослеживаемой команды WAIT Т-разряд игнорируется. При возврате из прерывания условия возникновения прерывания стандартны (см. пункты 4.1 и 4.3).&lt;br /&gt;
&lt;br /&gt;
== Алгоритм обработки прерываний ==&lt;br /&gt;
&lt;br /&gt;
Прерывание текущего процесса обычно допускается лишь в конце выполнения команды. Только зависание в канале может прервать выполнение команды на любой фазе ее выполнения.&lt;br /&gt;
&lt;br /&gt;
При возникновении условий прерывания процессор последовательно выполняет следующие действия:&lt;br /&gt;
&lt;br /&gt;
#	Микропрограммное сохранение вектора состояния прерываемого процесса либо в стеке, либо в КРСК и КРСП.&lt;br /&gt;
#	Формирование значения АВП. Микропрограммная загрузка вектора прерывания из пары ячеек ОЗУ или ПЗУ.&lt;br /&gt;
#	Анализируется состояние запросов на прерывание. Если незамаскированных запросов нет, то производится чтение первой команды нового процесса и ее выполнение. Иначе снова происходит процедура прерывания.&lt;br /&gt;
&lt;br /&gt;
В ситуации включения питания, фатальных состояний или выполнения команды HALT (обработки сигнала HALT) процедура прерывания отличается от обычной:&lt;br /&gt;
#	по процедуре безадресного чтения читается внешний регистр (SEL);&lt;br /&gt;
#	формируется значение адреса вектора прерывания;&lt;br /&gt;
#	разряды 15-8 берутся из соответствующих разрядов внешнего регистра, разряды 7-0 устанавливаются в зависимости от причины прерывания**;&lt;br /&gt;
#	происходит принудительная установка режима «HALT», для загрузки ВП из адресного пространства этого режима;&lt;br /&gt;
#	загружаются СК и ССП процесса обработки прерывания;&lt;br /&gt;
#	если разряд 8 загруженного ССП очищен, то происходит возврат в режим «USER».&lt;br /&gt;
&lt;br /&gt;
;Примечания.&lt;br /&gt;
&lt;br /&gt;
(*) Вообще говоря, процессор К1801ВМ2 фиксирует данное прерывание только в том случае, если 7 бит внешнего регистра (флаг наличия программной эмуляции команд арифметики с плавающей запятой) установлен. Но в УКНЦ возможность изменения этого регистра отсутствует, и по этому прерывание возникает всегда при прочтении вышеобозначенных команд.&lt;br /&gt;
&lt;br /&gt;
(**) Биты 15-8 внешнего регистра служат для указания старших адресов рассматриваемых векторов прерываний, поэтому данные векторы могут размещаться в любом 256-байтном сегменте памяти. Это актуально для машин с отсутствующим или проецирующимся по другим адресам системном (SEL) ОЗУ. Как уже отмечено, в УКНЦ, изменить эти биты нельзя.&lt;br /&gt;
&lt;br /&gt;
[[Категория:УКНЦ]]&lt;/div&gt;</summary>
		<author><name>Nzeemin</name></author>
	</entry>
</feed>