Sıra | DOSYA ADI | Format | Bağlantı |
---|---|---|---|
01. | Ölçeklenebilir Mimariler | ppt | Sunumu İndir |
Transkript
ZEYNEP YURDAKUL704061015Ölçeklenebilir MimarilerScalable Architectures
İçerikGirişÖlçeklenebilirlikSPARC : Scalable Processor ARChitectureUltraSPARC T1Sonuç
ÖlçeklenebilirlikYatay Ölçeklenebilirlik Birbirine paralel donanımların sayısının artırılması... Dikey Ölçeklenebilirlik Tek bir birimin (işlemcinin) hızının vb. artırılması...
Ölçeklenebilir Mimariler Ölçeklenebilir çok işlemcili mimarilerTek bir kırmık üzerinde çokluişlem tabanlı ölçeklenebilir mimarilerÖlçeklenebilir İşlemci Mimarisi: SPARC
SPARC : Ölçeklenebilir İşlemci MimarisiSPARC, açık kaynaklı ölçeklenebilir işlemci mimarisiSPARC bir tanımlamadır; bir işlemci değildir. SPARC mimarisiyle gerçeklenmiş çeşitli ölçeklenebilir işlemciler bulunmaktadır. 1985 yılında Sun Microsystems tarafından RISC mimarisiyle dizayn edilmiştirSPARC International, Inc., bir organizasyon olarak 1989 yılında SPARC’ ı duyurmak ve uyum testlerini yürütmek amacıyla kuruldu.
SPARCSPARC Versiyon 8 (V8), standart 32-bit SPARC mimari tanımı, SPARC International tarafından 1990 yılında piyasaya çıkarılmıştır. (big endian)SPARC Versiyon 9 (V9), standart 64-bit SPARC mimari tanımı, SPARC International tarafından 1994 yılında piyasaya çıkarılmıştır.
SPARC Mimarisiyle Gerçeklenmiş İşlemciler Sparc – 1984İlk Sparc İşlemci– 1986SuperSparc – 1992 UltraSparc I – 1995 UltraSparc II – 1997 UltraSparc III – 2001 UltraSparc IV – 2004UltraSparc IV+ – 2005 UltraSparc T1 – 2005
SPARC : Donanımsal Çok İşçiklilikTeorik olarak bir işçik bellek erişimi için durakladığında, dört kadar farklı işçik arasında geçiş yapabilen bir çok işçikli işlemci çekirdeğinin çalışması
SPARC : Kırmık çok işçikliliği (CMT)Çoklu çekirdek (çoklu işlem) teknolojisi donanımsal çok işçikliğinin faydalarını artırmak ve ölçeklenebilirlik için kullanılabilir. Bu uygulamaya Sun firması, kırmık çok işçikliliği (chip multithreading – CMT) adını vermiştir. CMT işlemcileri kullanılabilir transistör miktarından yararlanarak birden fazla çok işçikli işlemci çekirdeğini tek bir kırmık üzerinde oluştururlar. Bu ayrık işlemci çekirdekleri çok daha basit iş hatları (ağırlıklı olarak TLP üzerine ILP) oluşturduklarından dolayı daha az enerji ile çalışırlar ve daha az ısı üretirler.
SPARC : SaklayıcılarGenel Pencereli Tanım%r0 - %r7 %g0 - %g7Global Saklayıcılar (tüm pencelerelerden erişilebilir)%r8 - %r15 %o0 - %o7 Pencere çıktı saklayıcıları%r16 - %r23 %l0 - % l7 Pencere yerel saklayıcıları%r24 - %r31 %i0 - %i7 Pencere girdi saklayıcılarıSPARC, genel saklayıcı yükle-sakla mimarisindedir. Sadece iki adresleme modu vardır : saklayıcı + saklayıcı saklayıcı + 13 bit işaretli değerTüm komutlar V8’de 32 bit uzunluğundadır.
Saklayıcı PencereleriSaklayıcı penceresinin döngüsü save ve restore komutlarıyla programcının kontrolündedir. Sadece prosedür giriş ve çıkışlarında saklayıcı penceresinin taşınmasına izin veren Berkeley RISC mimarisine ters bir uygulamadır.
Saklayıcı Pencereleri v8 SPARC v8, işlemci durum saklayıcısında en fazla 5 bitlik bir alanı o anki pencereyi (anlık pencere işaretçisi - CWP) saklamak için kullanır. Bu nedenle en çok kullanılacabilecek saklayıcı penceresi genelde daha az olabilse de sayısı 32’dir. Bunlarla ilgili bulunan bir eşleştirme tablsounda geçersiz saklayıcı pencerelerinin (Window Invalid Mask - WIM) bir kaydı tutulur. İşlemciler üzerinde bulunan ve durumu daha karmaşık hale getiren bir başka etken de işlemcinin çökmesi (traplemesi) durumunda, saklayıcı penceresi koşulsuz olarak yer değiştirir, ayrıca iç içe çökmeler desteklenmez (bir çökmenin sonunda başka bir çökme olamaz). Bağlam (context) değişiminde, diğer işlerin saklayıcı pencereleri, geçersiz olarak işaretlenir. CWP her save işlemiyle birlikte bir azaltılır. Yeni pencerenin geçerliliği WIM’e karşı kontrol edilir ve eğer geçersiz bir pencereyse bir trap oluşturulur.
Saklayıcı Pencereleri v9 CANSAVE: bir overflow trapi oluşana kadar gerçekleştirilen toplam save komutlarının sayısı CANRESTORE: bir underflow trapi oluşana kadar gerçekleştirilen toplam restore komutlarının sayısı OTHERWIN: alternatif spill (dağıtma) /fill (birleştirme) aykırı durumu oluşturacak pencerelerin sayısıV9’da, trap yakalayıcılara ayrılmış fazladan global saklayıcılar eklenerek 5 seviye içiçe trap oluşması desteklenecek şekilde mimaride değişiklik yapılmıştır.
Saklayıcı Pencereleri v9Eğer kullanıcı OTHERWIN pencerelerine save veya restore yapmaya çalışırsa, alternatif hata yakalayıcıları çağırılabilir.Bu şekilde daha hızlı trap ayıklayıcılar ve daha iyi işlemler arası güvenli geçiş sağlanabilir. Bu mekanizma daha hızlı sistem çağrıları gerçekleşmesine de olanak sağlar. Örneğin; CANRESTORE değerini sıfıra ayarlayarak, sistem çağrılarından dönüşleri daha hızlı tespit edebilir ve daha hızlı trap ayıklayıcılar kullanılabilir.
Altprogram Saklayıcı TahsisiSPARC işlemcileri genelde 128 genel amaçlı saklayıcı bulundururlar.Global olmayan 24 saklayıcı, saklayıcı penceresi olarak adlandırılan yapıyı oluştururlar. Bir altprogram çağrısı yapıldığında çıkış (%o0 - %o7) saklayıcıları tekrardan isimlendirilerek çağrılan altprogram için giriş (%i0 - %i7) saklayıcıları olarak tanımlanır. Ayrıca altprogram için yeni yerel (%l0 - %l7) ve çıkış (%o0 - %o7) saklayıcıları oluşturulur. Bu çıkış saklayıcıları daha sonra bu altprogram içerisinden çağrılacak başka bir altprogram için giriş saklayıcıları olacaklardır.
Altprogram Saklayıcı TahsisiAltprogram1 Altprogram2'i Çağırırken Yığının Gösterimi
UltraSparc T1UltraSPARC T1 işlemcisinin çoklu işçikli kavramsal diyagramı. Onaltı aktif çalışma işçiğini destekleyen dört donanımsal çok işçikli çekirdeğin bir CMT işlemcinde birleştirilmiş halidir.
UltraSparc T1UltraSparc T1 mimarisi, 8 çekirdek destekleyen bir yapıda oluşturulmuştur. Her bir çekirdek 16KiB 4-yollu kümeli çağrışımsal cebe, 32 byte büyüklüğünde L1I’ya ve 8KiB 4-yollu kümeli çağrışımsal cebe, 16KiB büyüklüğünde L1D’e sahiptir. Sekiz çekirdeğin her biri 4 işçiği (işçik grubu) destekler. Gruptaki her bir işçik, ayrık bir saklayıcı kümesine, komut tamponuna sahiptir. Fakat işçik grubu L1 cebini, komut ve veri TLB değerlerini, yürütme birimlerini ve diğer işhattı kaynaklarını paylaşır.
UltraSPARC T1’in iş hattı yapısı Komut Al İplik Seçimi Çöz Yürüt Bellek Geri Yazım
Temel İşçik Değişimi Kuralları Cep Iskaları : Cep ıskaları uzun gecikmelidir ve işçik değişimine neden olurlar. Sıralayıcı, load komutlarını cep vurusu olarak kabul eder, ve bu yüzden daha detaylı bağlı komutları riskli gibi işler. Buna rağmen, bir riskli işçik birlikte çalıştığı başka birinden daha düşük önceliğe sahiptir. Traps : Trapler, işhattının sadece ilerleyen katlarında oluşabilir. Trapler, daha yeni komutların tampondan temizlenmesini gerektirirler. Kaynak Çakışması : Kaynak çakışması bir işçiği durdurabilir. Her bir işçik, sınırlı sayıdaki komutu tutabilen ayrık bir komut tamponuna sahiptir.
SonuçSPARC mimarisiyle gerçeklenmiş, gömülü sistemlerde ve sunucu makinelerde kullanılan işlemciler bulunmaktadır. SPARC mimarisinin, ölçeklenebilirliğinin temel kaynakları; çok çekirdekli olması ve her bir çekirdek için donanımsal çok işçikli yapının kullanılmasıdır. Saklayıcı pencereleri yapısının kullanılmasıdır.
Kaynaklar Weaver, David L., and Germond, Tom: The SPARC Architecure Manual, Version 9, Prentice Hall, 2000 “The scalable processor architecture (SPARC)”, Garner, R.B.; Agrawal, A.; Briggs, F.; Brown, E.W.; Hough, D.; Joy, B.; Kleiman, S.; Muchnick, S.; Namjoo, M.; Patterson, D.; Pendleton, J.; Tuck, R.; Compcon Spring '88. Thirty-Third IEEE Computer Society International Conference, Digest of Papers, Pages: 278 – 283 The SPARC Architecture Manual Version 8, Sun Microsystems Ana Sonia Leon, Jinuk Luke Shin, Kenway W. Tam, William Bryg, Francis Schumacher, Poonacha Kongetira, David Weisner, and Allan Strong. A power–efficient high–throughput 32–thread SPARC processor. In IEEE International Solid State Circuit Conference, 2006. http://www.sparc.org/history.html Dean M. Tullsen, Susan J. Eggers, and Henry M. Levy. Simultaneous multithreading: Maximizing on-chip parallelism. In ISCA, pages 392–403, 1995.
Teşekkürler Sorularınız ?