Přerušit příznak - Interrupt flag

The Přerušit příznak (LI) je systémový příznak bit v architektura x86 je VLAJKY registr, která určuje, zda centrální procesorová jednotka (CPU) bude reagovat na maskovatelný hardware přerušení.[1]

Bit, který je bitem 9 FLAGS registru, může být nastaven nebo vymazán programy s dostatečnými oprávněními, jak je obvykle určeno operační systém. Pokud je příznak nastaven na 1, budou zpracována maskovatelná hardwarová přerušení. Pokud je zrušeno (nastaveno na 0), tato přerušení budou ignorována. IF nemá vliv na zacházení s nemaskovatelná přerušení (NMI) nebo softwarová přerušení generovaná INT návod.

Nastavení a vymazání

Příznak lze nastavit nebo vymazat pomocí CLI (Clucho nterrupts), STI (SEt nterrupts) a POPF (Pop Fzpoždění) instrukce.

CLI vymaže IF (nastaví na 0), zatímco STI nastaví IF na 1. POPF vyskočí 16 bitů ze zásobníku do VLAJKY registr, což znamená, že IF bude nastaven nebo vymazán na základě devátého bitu v horní části zásobníku.[1]

Úroveň oprávnění

Ve všech třech případech pouze privilegované aplikace (obvykle OS jádro ) může upravit IF. Toto platí pouze pro chráněný režim kód. (Skutečný režim kód může vždy upravit IF.)

CLI a STI jsou privilegované pokyny, které spustí chybu obecné ochrany, pokud se ji neprivilegovaná aplikace pokusí spustit, zatímco POPF jednoduše neupraví příznak IF, pokud je aplikace neprivilegovaná.

The úroveň oprávnění požadované k provedení instrukce CLI nebo STI, nebo nastavení IF pomocí POPF, určuje IOPL (Úroveň oprávnění I / O) v EFLAGS. Pokud je například IOPL nastaven na 2, může libovolný program spuštěný pouze v kruhu 0 spustit CLI. Většina moderních operačních systémů nastavuje IOPL na 0, takže CLI / STI může spouštět pouze jádro. Důvodem je to, že protože vymazání IF donutí procesor ignorovat všechna přerušení, jádro nemusí nikdy získat kontrolu zpět, pokud není znovu nastaveno na 1.

Staré programy pro DOS

Některé staré DOS programy, které používají chráněný režim DOS extender a instalují své vlastní obslužné rutiny přerušení (obvykle hry), používají instrukce CLI v obslužné rutině k deaktivaci přerušení a buď POPF (po odpovídajícím PUSHF) nebo IRET (který obnovuje příznaky ze zásobníku jako součást jeho účinky) jej obnovit. To funguje, pokud byl program spuštěn v reálném režimu, ale způsobí problémy při spuštění těchto programů v a DPMI - kontejner založený na moderních operačních systémech (např NTVDM pod Windows NT nebo novějším). Protože CLI je privilegovaná instrukce, spouští a chyba když se program pokusí jej použít, do operačního systému. Operační systém pak obvykle přestane doručovat přerušení programu, dokud program neprovede STI (což by způsobilo další poruchu). Instrukce POPF však není privilegovaná a jednoduše selže tiše při obnovení IF. Výsledkem je, že operační systém přestane poskytovat přerušení programu, který pak přestane reagovat. Programy DOS, které nepoužívají rozšiřovač chráněného režimu, tento problém netrpí, protože se spouštějí v režimu V86, kde POPF způsobí chybu.

Existuje několik uspokojivých řešení tohoto problému. Obvykle není možné program upravit, protože zdrojový kód obvykle není k dispozici a v proudu instrukcí není místo pro zavedení STI bez rozsáhlých úprav na úrovni sestavy. Odebrání CLI z programu nebo způsobení, že hostitel V86 úplně ignoruje CLI, může způsobit další chyby, pokud obslužné rutiny přerušení hosta nejsou znovu bezpečné (i když jsou prováděny na moderním procesoru, obvykle se provádějí dostatečně rychle, aby se zabránilo překrývání přerušení).

CLI

CLI se běžně používá jako synchronizace mechanismus v jednoprocesorových systémech. Například CLI se používá v operační systémy deaktivovat přerušení tak jádro kód (obvykle a Řidič ) se lze vyhnout podmínky závodu s obsluha přerušení. Upozorňujeme, že rozhraní CLI ovlivňuje pouze příznak přerušení pro procesor, na kterém je spuštěn; v víceprocesorový systémy, provedení instrukce CLI nezakáže přerušení na jiných procesorech. Stále tedy může nastat podmínka závodu ovladače / přerušení obslužného programu, protože jiné procesory mohou obsluhovat přerušení a spustit obsluhu přerušení, která porušuje pravidla. U těchto systémů mohou být použity další synchronizační mechanismy, jako např zámky musí být použito navíc k CLI / STI, aby se zabránilo všem podmínkám závodu.

Protože HLT instrukce se zastaví, dokud nedojde k přerušení, obvykle se úmyslně používá kombinace CLI následovaná HLT pověsit počítač.

STI

Instrukce STI umožňuje přerušení nastavením IF.

Jedním zajímavým podivem ohledně instrukce STI je, že na rozdíl od CLI, které má okamžitý účinek, přerušení jsou ve skutečnosti povolena až po instrukci bezprostředně následující po STI. Jedním z vedlejších účinků by to mohlo být IF = 0, pak provedení instrukce CLI bezprostředně po instrukci STI znamená, že přerušení nejsou nikdy rozpoznána. Instrukce STI nastaví příznak IF, ale přerušení se kontrolují až po další instrukci, což by v tomto případě bylo CLI, které se projeví okamžitě. Toto chování existuje, takže procesor, který neustále přijímá přerušení, může stále dopředu postupovat. Vidět IA-32 manuály pro podrobnosti.

Viz také

Reference

  1. ^ A b „Intel Architecture Software Developer's Manual, Volume 2: Instruction Set Reference Manual“ (PDF). Citováno 2007-07-13.

externí odkazy