Kesinti tanımlayıcı tablosu - Interrupt descriptor table - Wikipedia

Kesinti Tanımlayıcı Tablosu (IDT) tarafından kullanılan bir veri yapısıdır x86 mimarisi uygulamak için kesme vektörü tablo. IDT, işlemci tarafından aşağıdakilere doğru yanıtı belirlemek için kullanılır. keser ve istisnalar.

Aşağıdaki açıklamadaki ayrıntılar özellikle x86 mimarisi ve AMD64 mimari. Diğer mimariler benzer veri yapılarına sahiptir, ancak farklı davranabilir.

IDT'nin kullanımı üç tür olay tarafından tetiklenir: donanım kesintileri, yazılım kesintileri ve işlemci istisnaları, bunlara birlikte keser. IDT, 256 kesinti vektörleri –İlk 32'si (0-31 veya 0x00–0x1F) işlemci istisnaları için ayrılmıştır.

Gerçek mod

İçinde 8086 işlemci, kesme tablosu IVT (kesme vektör tablosu) olarak adlandırılır. IVT her zaman hafızada aynı yerde bulunur. 0x0000 -e 0x03ffve 256 dört bayttan oluşur gerçek mod uzak işaretçiler (256 × 4 = 1024 bayt bellek).

Bir gerçek mod işaretçisi, 16 bitlik bir segment ve bu segmente 16 bit ofset olarak tanımlanır. Segment, işlemci tarafından 4 bit sola kaydırılarak dahili olarak 20 bite genişletilir, böylece gerçek mod kesme işleyicileri ilk 1 megabayt bellek ile sınırlandırılır. İlk 32 vektör, işlemcinin dahili istisnaları için ayrılmıştır ve donanım kesintileri, programlanabilir bir kesinti kontrolörü aracılığıyla vektörlerden herhangi birine eşlenebilir.

Üzerinde 80286 ve daha sonra, IVT'nin boyutu ve yerleri, IDT'de olduğu gibi değiştirilebilir. korumalı mod (yani, LIDT talimatı aracılığıyla) formatını değiştirmese de. 80286 ayrıca yüksek hafıza alanı gerçek modda adres sınırını 65.520 bayt yükseltir.

Yaygın olarak kullanılan bir x86 gerçek mod kesintisi INT 10H, Video BIOS piksel çizimi ve ekran çözünürlüğünü değiştirme gibi ilkel ekran çizim işlevlerini işlemek için kod.

Korumalı mod

İçinde korumalı mod IDT, bellekte art arda saklanan ve bir kesme vektörü tarafından indekslenen bir tanımlayıcılar dizisidir. Tam nüfuslu bir IDT 2'dir 32 bit korumalı modda KB (her biri 8 baytlık 256 giriş) uzunluğunda ve 4 64 bit korumalı modda KB (her biri 16 baytlık 256 giriş). Tüm olası girişleri kullanmak gerekli değildir: IDT'yi kullanılan en yüksek kesme vektörüne kadar doldurmak ve IDT uzunluk kısmını ayarlamak yeterlidir. IDTR buna göre.

Korumalı mod IDT, fiziksel belleğin herhangi bir yerinde bulunabilir. İşlemcinin özel bir kaydı vardır (IDTR) IDT'nin hem fiziksel temel adresini hem de uzunluğunu bayt olarak depolamak için. Bir kesme meydana geldiğinde, işlemci kesme vektörünü tanımlayıcı boyutuyla çarpar ve sonucu IDT temel adresine ekler. IDT uzunluğunun yardımıyla, elde edilen bellek adresinin tablo içinde olduğu doğrulanır; çok büyükse, bir istisna oluşturulur. Her şey yolundaysa, hesaplanan bellek konumunda depolanan tanımlayıcı yüklenir ve tanımlayıcının türüne ve içeriğine göre işlem yapılır.

Tanımlayıcılar, kesme kapıları, tuzak kapıları veya yalnızca 32 bit korumalı mod için görev kapıları olabilir. Kesme ve tuzak geçitleri, her iki segmenti de belirterek yürütülecek kodu içeren bir bellek konumuna işaret eder (her iki GDT veya LDT ) ve bu segment içinde bir ofset. Bu ikisi arasındaki tek fark, bir kesinti geçidinin, donanım kesintilerinin daha fazla işlemciye işlenmesini devre dışı bırakması ve bu da onu özellikle donanım kesintilerine hizmet vermeye uygun hale getirmesidir; tuzak geçidi, donanım kesintilerini etkin bırakacak ve bu nedenle esas olarak yazılım kesintilerini ve istisnaları ele almak için kullanılır. Son olarak, bir görev geçidi, işlemcinin kullanımını etkili bir şekilde başka bir programa, iş parçacığına veya işleme devretmek için donanım görev anahtarı mekanizmasını kullanarak o anda aktif olan görev durumu segmentinin değiştirilmesine neden olacaktır.

0-31 arasındaki vektörler, işlemci tarafından oluşturulan istisnalar için Intel tarafından ayrılmıştır (Genel koruma Hatası, sayfa hatası, vb.). Şu anda Intel işlemciler tarafından sadece 0–20 vektörleri kullanılırken, AMD işlemciler 0–19 ve 29–30 vektörlerini kullanır. Ancak gelecekteki işlemciler, bu vektörleri başka amaçlar için kullanan bozuk yazılımlar için uyumsuzluklar yaratabilir.

Donanım tarafından oluşturulan istisnalar

0x0 ile 0x1F arasındaki tüm INT_NUM, istisnalar için ayrılmıştır; 0x1F'den büyük INT_NUM, kesme rutinleri için kullanılır. (Unutmayın ki IBM PC bu kurala her zaman uymadı, örneğin interrupt 5'i kullanarak Ekran görüntüsü tuşuna basıldı.)

INT_NUMKısa Açıklama ÖS[açıklama gerekli ]
0x00Sıfıra bölüm
0x01Tek adımlı kesinti (bkz. tuzak bayrağı )
0x02NMI
0x03Kesme noktası (hata ayıklayıcılar tarafından kullanılan özel 1 baytlık talimat 0xCC tarafından çağrılabilir)
0x04Taşma
0x05Sınırlar
0x06Geçersiz İşlem Kodu
0x07Yardımcı işlemci mevcut değil
0x08Çift hata
0x09Yardımcı İşlemci Segment Aşımı (Yalnızca 386 veya öncesi)
0x0AGeçersiz Görev Durumu Segmenti
0x0BSegment mevcut değil
0x0CYığın Hatası
0x0DGenel koruma Hatası
0x0ESayfa hatası
0x0Fayrılmış
0x10Matematik Hatası
0x11Hizalama Kontrolü
0x12Makine Kontrolü
0x13SIMD Kayan Nokta İstisnası
0x14Sanallaştırma İstisnası
0x15Kontrol Koruması İstisnası

Çengel

Biraz pencereler programları kanca IDT'ye aramalar. Bu, bir çekirdek modu yazmayı içerir sürücü IDT'ye yapılan çağrıları kesen ve kendi işlemesine ekler. Bu hiçbir zaman resmi olarak desteklenmedi Microsoft, ancak işletim sistemlerinde programatik olarak engellenmedi. 64 bit Windows sürümleri, burada bir sürücü kullanmaya çalışan bir çekirdek modu kanca, makinenin hata kontrolü.[1]

Referanslar

  1. ^ "X64 Tabanlı Sistemler için Yama Politikası". İşletim sistemi bu değişikliklerden birini veya başka herhangi bir yetkisiz yama tespit ederse, bir hata kontrolü oluşturacak ve sistemi kapatacaktır.
Genel

Dış bağlantılar