UltraSPARC T1

維基百科,自由的百科全書
UltraSPARC T1
產品化2005
設計團隊Sun Microsystems
生產商
指令集架構SPARC V9
核心數量4, 6, 8
CPU主頻範圍1.0 GHz 至 1.4 GHz
核心代號
  • S1
繼任產品UltraSPARC T2

UltraSPARC T1太陽電腦所研發的微處理器,而處理器還在開發階段時的研發代號稱為「Niagara,尼亞加拉瀑布」,之後在2005年11月14日正式研發完成並發表。UltraSPARC T1是一顆多核心(執行核)、多線程(多執行緒)的CPU,且針對伺服器運算的運用需求而強化省電設計,在1.2GHz運作時脈下的典型用電為72W(Watt,瓦、瓦特)。

UltraSPARC T1衍生自UltraSPARC系列微處理器,它是太陽電腦公司的第一顆多核多緒處理器,這顆處理器內可以有4個、6個、8個CPU核心,且每個核心最多可同時執掌、處理4個執行緒,如此UltraSPARC T1處理器在最理想狀態下可同時執行32個執行緒。

UltraSPARC T1的運作與太陽電腦的高階對稱處理(SMP)系統很近似,它具有系統分割能力,可以將一個或數個核心切割成一個分區(Partition),然後在分區內執行一個或數個程序(Process)及執行緒(Thread),此外待執行的程序、執行緒也可以儘速派送或轉移給其他較閒餘的執行核心,進而增加整體執行效率。

核心

管線(Pipeline)UltraSPARC T1

UltraSPARC T1是針對多緒執行而設計的特殊處理器,它運用新的架構來獲取高執行效率,而不是為單一個執行核心加入更多智慧化、最優化的心力設計,昇陽的目標是在同一時間內盡可能執行、處理多個執行緒,使每個執行核心的執行管線能達到最大的使用率。

此種作法目前來看似乎成效不錯,現有的基準標竿測試證實UltraSPARC T1內的每個執行核心確實更有效率,這是與約2001年的UltraSPARC III相比,UltraSPARC III是一顆單核、單緒,且能完整執行SPARC v9指令集的處理器。

UltraSPARC T1內雖有8個執行核心,但每個執行核心的結構複雜度並不如現有的高階處理器,而且每個執行核心也不具備超序執行(out-of-order execution,簡稱:OOO,也稱亂序執行)的能力,也沒有配屬大容量的快取記憶體。單緒型的處理器極倚賴大容量的快取記憶體來提升執行效能,原因是:一旦在快取記憶體中抓取不到所需的資料(稱為:漏失,miss)時,就必須從主記憶體中去提取(fetch)資料,而增加快取記憶體的容量可減少漏失的概率,不過即便如此,漏失對效能依然是很大的衝擊影響。

相對的,UltraSPARC T1的核心是運用多執行緒的處理特性來避開快取漏失所造成的效能衝擊,當快取漏失發生時,核心會轉去處理另一個執行緒(在此假設還有其他可放置的待處理位置,每個核最多可執掌4個執行緒),在處理的同時,原先漏失的的需求資料,也會在這時候以背景作業的方式自外部主記憶體提取到處理器內。如此雖然每個執行緒的處理速度會較慢,但每個核心的整體處理進出量及運算利用率反而是大幅提高。而這也意味着快取漏失的衝擊影響被大幅降低,這樣UltraSPARC T1就能以較少的內建快取記憶體而仍可維持大量的進出處理執行效率,快取記憶體的容量不再需要大到得容納執行核心所需的所有資料或絕大多數的資料,只要能容納每個執行緒最近所漏失而必須提取至處理器內的資料。

目標市場

UltraSPARC T1有其獨到的功效能力使其能專注、適合在特有的市場,而不是用在高階財務數字運算及超高效能的應用,它是鎖定在網絡方面的高需求伺服運算上,如高流量的網站伺服器,這類的伺服運算會用到大量的執行緒,且各執行緒間沒有相依性,或者是沒有太高的相依性,各緒相當的個別獨立。

不過,UltraSPARC T1的設計上也有個局限,那就是整個處理器內僅有1個浮點運算單元,且使用上由8個核心所共享,因此UltraSPARC T1不適合用來執行具有大量浮點運算的應用程式。然而,這顆處理器所想定的互聯網伺服器應用市場本就不常用到大量的浮點運算[1],太陽電腦方面不認為在這個市場上這將成為一個問題。

  1. ^ - 附註:文章雖如此翻譯,但我持有另一個看法,即是太陽電腦為了及早推出UltraSPARC T1處理器,因此將重要性較次的設計項目加以精省,而浮點運算、加密運算皆在此列,所以UltraSPARC T1僅有8個整數運算核心,但卻沒有8個浮點數運算核心及8個加密運算核心,反而是只有1個浮點數運算核心與1個加密運算核心,而這些已在後續的新款處理器中得到補足強化。

已經證實這些問題已經在昇陽的下一代晶片UltraSPARC T2中得到解決。這款晶片將具有8個核,每個核具有8個硬件線程支持能力(這比UltraSPARC-T1多一倍)。同時,每個核心都具有獨立的浮點運算單元。因此,這款晶片的浮點運算能力甚至可用於高性能計算領域(需要大量浮點運算支持)。

同為多核心處理器,Sun的Niagara系列晶片(UltraSPARC T1, T2)與IBM的多核心晶片Cell顯著不同。首先,前者是對等結構,各核之間地位對等、沒有差異;而後者是主從結構。其次,前者的每個核心均具有完整的SPARC V9指令集支持能力,均可獨立執行任何指令,理論上二進制代碼可以直接運行;後者只有一個Power核心作為主控,其餘核心實質上都是向量處理單元(VPE),只負責執行SIMD指令,如果要充分發揮其處理能力,應用程式必須以SIMD指令重寫。以上不同造成了兩款晶片面向不同應用的事實,即前者適合於處理無規則數據流,如網絡伺服器;後者適合大批量規則運算,如做為遊戲機處理晶片。

研發代號:「Rock」

UltraSPARC T1是針對單顆CPU的系統所設計,所以它不具備對稱處理(SMP)能力,即由UltraSPARC T1組成的系統,最多只能有一顆多核心晶片。而未來昇陽的CMT UltraSPARC處理器,如Rock(研發代號)將會是多顆處理晶片的伺服器架構,多顆多核心Rock晶片將能組成對稱多處理機(SMP)系統,進一步擴展運算能力。Rock處理器將鎖定在傳統資料運算工作,如資料庫執行。因此,Rock看來將成為太陽電腦在SMP架構處理器上的新接替,預計會取代現有的UltraSPARC III、UltraSPARC IV。

與UltraSPARC T1不同的,Rock重視且強化浮點運算的能力。另外根據太陽電腦的透露,Rock上將具有一種Hardware Scout(硬件偵測,硬件偵察)功能,是以多執行緒式的硬件線路設計讓Rock具有數據預取(prefetching)的能力。

此外,Rock不是用來接替UltraSPARC T1,太陽電腦已公開其UltraSPARC T2(Niagara 2)處理器的計劃,Niagara 2將與UltraSPARC T1相同,皆訴求在網絡型運算。

UltraSPARC T2

UltraSPARC T2是太陽電腦所研發的 8 核心處理器,每個核心最高可執掌8個執行緒,即可同時執行64個執行緒;且每個核心皆會配屬到1個浮點運算單元,即是一顆T2處理器內會有8個浮點運算單元。

開放原碼

2006年3月21日,太陽電腦將UltraSPARC T1的相關原始程式碼,以GPL(GNU General Public License)授權的方式加以公開公佈,而公開的項目包括:

  • UltraSPARC T1在邏輯電路設計上的原始程式碼(使用Verilog語言)
  • 驗證套件與電路功效的模擬推演模型
  • 指令集的規格(2005年的UltraSPARC架構版本)
  • Solaris 10作業系統在推演模擬之用時的系統映象檔(Image)

作業系統支持

外部連結