MMIX - MMIX

MMIX
TasarımcıDonald Knuth
Bit sayısı64 bit
TasarımRISC
KodlamaSabit
DallanmaDurum Kodu
AşkBüyük
AçıkEvet ve telifsiz
Kayıtlar
32 özel amaçlı kayıt
Genel amaç256

MMIX (telaffuz edildi em karışımı) bir 64 bit azaltılmış komut seti hesaplama (RISC) mimari tarafından tasarlandı Donald Knuth tarafından önemli katkılarla John L. Hennessy (tasarımına kim katkıda bulundu? MIPS mimarisi ) ve Richard L. Sites ( Alfa mimari). Knuth, "MMIX, programlamanın makine düzeyindeki yönlerini göstermeyi amaçlayan bir bilgisayardır. Kitaplarımda Bilgisayar Programlama Sanatı, yerini alır MIX, eskiden böyle bir rol oynayan 1960'ların tarzı makine… MMIX'i makine dili basit, zarif ve öğrenmesi kolay olacak şekilde tasarlamaya çalıştım. Aynı zamanda, uygulamada yüksek performans elde etmek için gereken tüm karmaşıklıkları dahil etmeye özen gösterdim, böylece MMIX prensipte inşa edilebilir ve hatta piyasadaki en hızlı genel amaçlı bilgisayarlardan bazılarıyla rekabet edebilir. "[1]

İşlemci "2009" olarak numaralandırılmıştır ve Knuth bunun aritmetik ortalama diğer bilgisayar mimarilerinin sayılarından; yanı sıra "MMIX" Roma rakamları.[2]

Mimari

MMIX bir büyük adam 64 bit indirgenmiş komut seti bilgisayarı (RISC), 256 64 bit genel amaçlı kayıt, 32 64 bit özel amaçlı kayıt, sabit uzunlukta 32 bit Talimatlar ve 64 bit sanal adres alanı. MMIX komut seti, biri gelecekteki genişletme için ayrılmış olan 256 işlem kodundan oluşur[kaynak belirtilmeli ]. MMIX kullanır IEEE 754 Kayan nokta sayıları.

Talimatlar

Tüm talimatların ilişkili bir anımsatıcısı vardır. Örneğin, talimat # 20 (32 ondalık) ADD ile ilişkilidir. Çoğu komutun sembolik biçimi "OP X, Y, Z" dir, burada OP komut türünü belirtir, X komutun sonucunu saklamak için kullanılan kaydı belirtir ve geri kalanı komutun işlenenlerini belirtir. Bu alanların her biri sekiz bit genişliğindedir. Örneğin, 0 $ EKLE, 1,3 $ "0 $ 'ı 1 ve 3 $ toplamına ayarla" anlamına gelir.

Çoğu talimat ya anlık değerleri alabilir ya da içeriği kaydedebilir; bu nedenle tek bir talimat anımsatıcısı, iki işlem kodundan birine karşılık gelebilir.

MMIX programları tipik olarak MMIXAL birleştirme dili kullanılarak oluşturulur. Aşağıdaki, "dizgesini yazdıran basit bir MMIXAL programıdır"Selam Dünya! ":

        LOC # 100% Programın adresini% başlangıçta 0x100 olarak ayarlayın. Ana GETA $ 255, string%% dizesinin adresini 255 registerına koyun. TRAP 0, Fputs, StdOut%% register 255 ile gösterilen dizeyi standart% çıktı dosyası. TRAP 0, Halt, 0% End process.string BYTE "Merhaba dünya!", # A, 0% Yazdırılacak dizge. #a% yeni satırdır, 0% dizesini sonlandırır.

Kayıtlar

Bir MMIX yongasında 0 ile 255 ABD Doları arasında gösterilen 256 doğrudan adreslenebilir genel amaçlı mimari kayıt ve 32 özel amaçlı mimari kayıt vardır. Özel amaçlı kayıtlara GET ve PUT komutları ile erişilebilir. Özel kayıtlardan ikisi, rL ve rG, genel kayıtlardan hangilerinin yerel ve hangilerinin global olduğunu belirler. 0 $ 'dan tüm kayıtlar ... ([rL] - 1) yerel sicillerdir ve bir pencere dahili bir kayıt yığınına.[3] [RL] 'den kayıtlar ... ([rG] - 1) "marjinal kayıtlardır", bir işlemde kaynak olarak kullanılırlarsa her zaman 0 döndürürler. Bir işlemin hedefi olarak bir marjinal kayıt kullanmak, makinenin bu kaydı dahil etmek için otomatik olarak rL'yi artırmasına neden olacaktır. Tüm kayıtlar [rG] ... 255 $ global kayıtlar olarak adlandırılır ve kayıt yığınının bir parçası değildir.

Yerel kayıt yığını

Yerel yazmaç yığını, her alt yordama, 0 ile $ 0 ile belirlenen kendi rL yerel yazmaçlarını sağlar. $ (rL - 1). Bir alt rutin çağrıldığında, bir dizi yerel kayıt yığının aşağısına itilir (pencerenin başlangıcını kaydırarak). Çağrılan alt yordamın argümanları, kalan yerel kayıtlarda bırakılır. Bir alt rutin bittiğinde, önceden itilen kayıtları açar. Dahili yığın yalnızca sınırlı sayıda yazmaç içerebildiğinden, yığının bir bölümünü bellekte saklamak gerekebilir.[3] Bu, yerel yazmaç yığınının hangi bölümünün bellekte olduğunu ve hangi bölümün hala yerel fiziksel kayıtlarda olduğunu kaydeden özel yazmaçlar rO ve rS ile gerçekleştirilir. Kayıt yığını, hızlı alt program bağlantısı sağlar.

Özel kayıtlar

32 özel fiziksel mimari kayıt aşağıdaki gibidir:

  1. rB, önyükleme kaydı (gezi)
  2. Açma sırasında, rB ← $ 255 ve $ 255 ← rJ. Böylece rJ'yi genel bir sicilde kaydeder.
  3. rD, temettü kaydı
    İşaretsiz tamsayı bölme, bunu diğer işlenen tarafından bölünecek olan 128 bitlik girişin sol yarısı olarak kullanır.
  4. rE, epsilon kaydı
    Epsilon'a göre değişken karşılaştırmalar için kullanılır.
  5. rH, himult kaydı
    İşaretsiz tamsayı çarpımının 128 bitlik sonucunun sol yarısını depolamak için kullanılır.
  6. rJ, dönüş atlama yazmacı
    Bir PUSH'den dönmek için bir sonraki komutun adresini PUSHes ve POP ile kaydetmek için kullanılır.
  7. rM, multipleks maske kaydı
    Multipleks talimatı tarafından kullanılır.
  8. rR, kalan kayıt
    Tamsayı bölmesinin kalanına ayarlanır.
  9. rBB, önyükleme kaydı (tuzak)
    Yakalama sırasında, rBB ← 255 $ ve 255 $ ← rJ. Böylece rJ'yi genel bir sicilde kaydet
  10. rC, döngü sayacı
    Her döngüde artırıldı.
  11. rN, seri numarası
    Bu özel MMIX işlemcisini tanımlayan bir sabit.
  12. rO, kayıt yığını ofseti
    Kayıt yığınını uygulamak için kullanılır.
  13. rS, kayıt yığını işaretçisi
    Kayıt yığınını uygulamak için kullanılır.
  14. rI, aralık sayacı
    Her döngüde azaldı. Sıfır olduğunda kesintiye neden olur.
  15. rT, tuzak adres kaydı
    Yolculuk vektörünün adresini saklamak için kullanılır.
  16. rTT, dinamik tuzak adres kaydı
    Tuzak vektörünün adresini saklamak için kullanılır.
  17. rK, kesinti maskesi kaydı
    Belirli kesintileri etkinleştirmek ve devre dışı bırakmak için kullanılır.
  18. rQ, kesme isteği yazmacı
    Kesintileri meydana geldikçe kaydetmek için kullanılır.
  19. rU, kullanım sayacı
    Yürütülen talimatların sayısını tutmak için kullanılır.
  20. rV, sanal çeviri kaydı
    Sanal adresleri fiziksel adreslere çevirmek için kullanılır. Segmentlerin boyutunu ve sayısını, sayfa tablosunun kök konumunu ve adres alanı numarasını içerir.
  21. rG, küresel eşik kaydı
    RG'ye eşit veya daha büyük bir sayıya sahip tüm genel kayıt referansları, genel kayıtları ifade eder.
  22. rL, yerel eşik kaydı
    RL'den daha küçük numaralı tüm genel kayıt referansları yerel kayıtlara atıfta bulunur.
  23. rA, aritmetik durum kaydı
    Taşma ve sıfıra bölme gibi aritmetik istisnaları kaydetmek, etkinleştirmek ve devre dışı bırakmak için kullanılır.
  24. rF, arıza yeri kaydı
    Hataya neden olan talimatın adresini saklamak için kullanılır.
  25. rP, tahmin kaydı
    Koşullu takas (CSWAP) tarafından kullanılır.
  26. rW, nerede kesintiye uğrayan kayıt (açma)
    Açma sırasında, kesilen talimatın adresini saklamak için kullanılır.
  27. rX, yürütme kaydı (açma)
    Açma sırasında kesilen talimatı saklamak için kullanılır.
  28. rY, Y işleneni (gezi)
    Açma sırasında, kesilen komutun Y işlenenini saklamak için kullanılır.
  29. rZ, Z işleneni (gezi)
    Açma sırasında, kesilen komutun Z işlenenini saklamak için kullanılır.
  30. rWW, nerede kesintiye uğrayan kayıt (tuzak)
    Yakalama sırasında, kesilen talimatın adresini saklamak için kullanılır.
  31. rXX, yürütme kaydı (tuzak)
    Yakalama sırasında kesilen talimatı saklamak için kullanılır.
  32. rYY, Y işleneni (tuzak)
    Yakalama sırasında, kesilen komutun Y işlenenini saklamak için kullanılır.
  33. rZZ, Z işleneni (tuzak)
    Yakalama sırasında kesilen komutun Z işlenenini saklamak için kullanılır.

Hemen hemen tüm diğer CPU'larda çalışan programlar gibi, MMIX programları da kesildi Zamanlayıcılar gibi harici donanımlar ortak bir kaynaktır. preemption (hesaplama) Bazı istisnai durumlarda birçok talimat kesintiye neden olur; gibi hafıza koruması sayfa hatası sanal bellek ve kayan nokta uygulamak için kullanılan istisnalar istisna işleme.MMIX'in 2 tür kesinti vardır: "açmalar" ve "tuzaklar". "Açmalar" ile "tuzaklar" arasındaki temel fark, tuzakların işletim sistemindeki bir "tuzak işleyici" programına kontrol göndermesi (yakalama), buttriplerin kontrol göndermesidir. Kullanıcı uygulamasında bir "yolculuk işleyici" programı (açma). Kullanıcılar ayrıca herhangi bir kesme işleyicisini açıkça yazılım kesintisi TRIP ve TRAP talimatları, bazı türlere benzer tuzak diğer bilgisayar sistemlerinde. özellikle bir sistem çağrısı bir kullanıcı programından işletim sistemine bir TRAP talimatı kullanır.[1]:38

Donanım uygulamaları

Ekim 2015 itibariyleMMIX komut seti mimarisinin bilinen donanım uygulamaları mevcut değildir. Ancak, fpgammix[4] proje MMIX'i uygular Verilog, bir kullanarak uygulamayı mümkün kılar alanda programlanabilir kapı dizisi.

Yazılım araçları

MMIX komut seti mimarisi, bilgisayar mimarisi araştırması ve yazılım geliştirme için bir dizi yazılım aracı tarafından desteklenmektedir.

Simülatörler ve montajcı

  • MMIXware[5] - Donald Knuth'un MMIX-SIM basit (davranışsal) simülatörü, MMIXAL assembler, test paketi, örnek programlar, tam dokümantasyon ve MMIX mimari (boru hattı) simülatörü (gzip ile sıkıştırılmış katran dosya).
  • MMIXX[6] - Bir X11 Andrew Pochinsky'nin katkıda bulunduğu tabanlı grafik paketi MIT Yukarıdaki MMIXware kaynakları ile birleştirildiğinde, MMIX sanal makineyi bir ile zenginleştiren Teorik Fizik Merkezi'nin 640 × 480 piksel, doğru renk "Sanal ekran" (UNIX / Linux için).

Derleyici

GNU Derleyici Koleksiyonu bir MMIX içerir arka uç onun için C /C ++ derleyiciler, katkılarıyla Hans-Peter Nilsson ve 2001'in sonlarından bu yana ana KİK dağıtımının bir parçası. Kasım 2017 itibarıylaGCC'nin MMIX arka ucu, gönüllüler tarafından aktif olarak geliştirilmeye ve sürdürülmeye devam ediyor.

  • Hans-Peter Nilsson tarafından GCC + MMIX araçları için kurulum talimatları.[7]
  • §3.17.26. MMIX Seçenekleri GNU GCC sürüm 7.2.0[8] (GNU GCC Web sitesi).
  • §9.28.  MMIX'e Bağlı Özellikler[9] için GNU gibi itibaren GNU Binutils sürüm 2.29, GNU GCC için derleyici arka uç (GNU Binutils Web sitesi).

Yukarıdaki araçlar teorik olarak bir bütünün derlenmesi, oluşturulması ve önyüklenmesi için kullanılabilir. FreeBSD, Linux veya MMIX donanımına benzer diğer işletim sistemi çekirdeği, böyle bir donanımın varolmasıydı.

Ayrıca bakınız

Referanslar

  1. ^ a b Knuth, Donald E. (Ekim 1999), MMIXware: Üçüncü Binyıl İçin Bir RISC Bilgisayarı, Bilgisayar Bilimi Eğitiminde Ders Notları, 1750, Heidelberg: Springer-Verlag, ISBN  3-540-66938-8 (Hatalar)
  2. ^ Knuth Donald (1999-02-09). MMIX: Yeni Milenyum İçin Bir RISC Bilgisayarı (uzaklık 7:36). Stanford Dersi. (Cray-1 + IBM 801 + RISC II + Clipper C300 + AMD 29k + Motorola 88k + IBM 601 + Intel i960 + Alfa 21164 + GÜÇ2 + MIPS R4000 + Hitachi Süper H4 + Güçlü kol 110 + SPARC 64) / 14 = 28126 / 14 = 2009
  3. ^ a b Knuth, Donald (2005). "Bölüm 1.4.2'". MMIX — Yeni Milenyum İçin Bir RISC Bilgisayarı. Bilgisayar Programlama Sanatı. Cilt 1, Fasc. 1. Addison Wesley. s. 58.
  4. ^ usta (2008-08-24). "fpgammix". Repo.or.cz. Alındı 2014-05-25.
  5. ^ "MMIXware". Cs-faculty.stanford.edu. Alındı 2014-05-25.
  6. ^ "MMIXX". Malgil.com. 2002-03-06. Alındı 2014-05-25.
  7. ^ GCC + MMIX araçları için kurulum talimatları
  8. ^ https://gcc.gnu.org/onlinedocs/gcc-7.2.0/gcc/MMIX-Options.html §3.17.26. MMIX
  9. ^ "§9.28 MMIX Bağımlı Özellikler". Sourceware.org. Alındı 2017-11-20.
  • Donald E. Knuth (2005). Bilgisayar Programlama Sanatı Cilt 1 Fascicle 1: MMIX Yeni Milenyum İçin Bir RISC Bilgisayarı. Addison-Wesley. ISBN  0-201-85392-2 (hata verileri)

Dış bağlantılar