TWI298454B - Method for accelerating the data processing of a special purpose processor, associated system, and machine-readable medium recording related instructions - Google Patents

Method for accelerating the data processing of a special purpose processor, associated system, and machine-readable medium recording related instructions Download PDF

Info

Publication number
TWI298454B
TWI298454B TW093135869A TW93135869A TWI298454B TW I298454 B TWI298454 B TW I298454B TW 093135869 A TW093135869 A TW 093135869A TW 93135869 A TW93135869 A TW 93135869A TW I298454 B TWI298454 B TW I298454B
Authority
TW
Taiwan
Prior art keywords
data
processor
special purpose
purpose processor
driver
Prior art date
Application number
TW093135869A
Other languages
English (en)
Other versions
TW200529041A (en
Inventor
Jen-Hsun Huang
Michael Brian Cox
Ziyad S Hakura
John S Montrym
Brad W Simeral
Brian Keith Langendorf
Blanton Scott Kephart
Frank R Diard
Original Assignee
Nvidia Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nvidia Corp filed Critical Nvidia Corp
Publication of TW200529041A publication Critical patent/TW200529041A/zh
Application granted granted Critical
Publication of TWI298454B publication Critical patent/TWI298454B/zh

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T1/00General purpose image data processing
    • G06T1/20Processor architectures; Processor configuration, e.g. pipelining
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T15/003D [Three Dimensional] image rendering
    • G06T15/005General purpose rendering architectures

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Graphics (AREA)
  • Image Generation (AREA)
  • Image Processing (AREA)
  • Hardware Redundancy (AREA)
  • Control Of Stepping Motors (AREA)
  • Advance Control (AREA)

Description

1298454 (1) 九、發明說明 【發明所屬之技術領域】 本發明大體上關於資料處理領域。詳言之,本發明關 於使用特殊用途處理器來處理的系統和方法。 【先前技術】 桌上型電腦和其他資料處理系統通常包含中央處理單 元(c P U )以進行算術計算、邏輯運算、控制功能和/或 其他處理。許多應用爲處理器密集。例如,將三維(3 D )場景繪圖中,每一影像物體通常使用稱爲圖元(通常是 三角形或其他多邊形)的數百或數千或甚至數萬的幾何物 體來描繪。場景可由數百或數千個圖元的組合來代表。每 一物體的表面可貼圖和著色以造成看起來真實的3 D影像 。在指定時間限制內將圖元定義、定位、貼圖、著色、繪 圖所需的計算會超乎CPU的處理能力(或頻寬)。 開發許多措施從CPU減少負載處理。一措施是在多 處理組態新增額外的一般用途CPU。此措施的缺點是一般 用途C P U可能不適於一些應用的計算需求。此外,多處 理需要某些同步和管理負擔,會在主CPU產生無效率。 不用新增CPU,特殊用途處理器可從CPU減少特定 任務。例如,圖形應用中,稱爲圖形處理單元(GPU )的 特殊用途處理器有時用以從CPU減少配合3D圖形之產生 和/或繪圖的計算。特殊用途處理器也可用來控制資料儲 存碟、網路通訊、或其他功能。在應用程式或作業系統( -5- (2) 1298454 〇 S )的控制下,驅動程式軟體用來管理特殊用途處理器 的介面。 但從CPU減少計算至特殊用途處理器的已知系統和 方法也有各種缺點。例如,在圖形處理的情形,GPU甚至 會負擔過多。此外,已知應用中,當特殊用途處理器故障 時’特殊用途處理器所進行的整體功能失去。 因此,需要能加速諸如GPU之特殊用途處理器的系 統和方法。 【發明內容】 本發明的實施例使用至少一輔助處理器來加速諸如 GPU的至少一特殊用途處理器,或管理特殊用途處理器的 驅動程式。本發明中,其他實施例可選擇性實施。任何揭 露的實施例可新增一個以上的特殊用途處理器和/或輔助 處理器。本發明的實施例容忍故障,若輔助處理器不能運 作’則GPU或其他特殊用途處理器可執行所有計算,雖 然也許性能較差。根據性能考量,輔助處理器也可選擇性 使用。 從下文和詳細說明會凸顯本發明的特性和優點。 【實施方式】 本發明實施例利用輔助處理器加速特殊用途處理器的 處理,而圖形處理單元(GPU )是此特殊用途處理器的實 例。說明本發明實施例中,參考圖1 —4呈現四功能架構。 -6- 1298454 ‘ " (3) 參考圖5 A說明故障容忍運作的方法,例如當輔 不運作時。參考圖5 B說明輔助處理器選擇性使 。然後,參考圖6和7提供輔助處理器二例證。 提供關於圖形處理領域之本發明實施例的二應用 頂點著色加速和二次Z-cull。 以下次標題只爲了組織方便;任何特定特性 以上來說明。 架構 圖1-4顯示系統的另一功能架構,具有應用 動程式元件、特殊用途處理器、加速特殊用途處 助處理器。這些顯示的實施例中,驅動程式是圖 式110,特殊用途處理器是GPU(分別是120、 、4 1 〇 ),輔助處理器(分別是1 1 5、2 0 5、3 0 5、 來加速 GPU(分別是 120、210、310、410)。 施例中,應用軟體1 05和圖形驅動程式1 1 0可常 (未顯示)或由其執行。圖形驅動程式1 1 0管理 器和/或GPU上進行的處理任務。 圖1是本發明實施例之功能系統架構的方塊 示’圖形驅動程式1 1 0提供資料A ( 1 2 5 )給輔 和GPU 120。輔助處理器115輸出A ( 125 A’(130)給 GPU 120。然後 GPU 120 使用 A(l: (130)做爲輸入以產生輸出B(135)。八’( GPU 120比只有A ( 125 )輸入GPU 120較快產 助處理器 用的方法 圖8和9 :分別是 會以一段
軟體、驅 理器的輔 形驅動程 210、 310 4 05 )用 顯示的實 駐於CPU 輔助處理 圖。如所 助處理器 )的轉換 2 5 )和 A, 1 3 0 )使 生輸出B (4) 1298454 (135 )。 圖2是本發明實施例之功能系統架構 示,圖形驅動程式1 1 0提供資料A ( 2 1 5 205。輔助處理器205輸出A ( 21 5 )的轉 GPU 210。然後 GPU 210 使用 A’(220) | )° 圖3是本發明實施例之功能系統架構 示,圖形驅動程式1 1 0提供資料A ( 3 1 5 : GPU 3 1 0將資料A ( 3 1 5 )送到輔助處理器 器3 0 5輸出A ( 3 1 5 )的轉換A ’( 3 2 0 )給 GPU 3 10 使用 A ( 315)和 A’( 3 20 )做爲 B ( 3 2 5 ) 。A’(320)使 GPU 310 比只有 GPU 3 10較快產生輸出B ( 3 25 )。 圖4是本發明實施例之功能系統架構 示,圖形驅動程式1 1 0提供資料A ( 4 1 5 4 0 5。然後輔助處理器4 0 5輸出A ( 4 1 5 ) )給圖形驅動程式1 1 0。然後GP U 4 1 0使 A’( 4 20 )做爲輸入以產生輸出B ( 425 ) GPU 410 比只有 A(415)輸入 GPU 410 (425 ) 〇 因此,參考圖4,輔助處理器40 5可〕 但當輔助處理器4 0 5進行通常配合圖形驅 定處理任務時,輔助處理器4 0 5加速管理 形驅動程式1 1 〇的處理。參考圖1 -3所述 的方塊圖。如所 )給輔助處理器 換 A ’( 2 2 0 )給 I生輸出B ( 225 的方塊圖。如所 )給 GPU 3 10。 3〇5。輔助處理 GPU 310 。然後 輸入以產生輸出 A ( 3 1 5 )輸入 的方塊圖。如所 )給輔助處理器 的轉換A ’( 4 2 0 [用 A ( 4 1 5 )和 。A ’( 4 2 0 )使 較快產生輸出B b 口速 GPU 4 10。 動程式1 1 0的特 GPU 410之圖 的架構同樣可加 -8- 1298454 (5) 速圖形驅動程式11 〇。 本發明一實施例中,圖形驅動程式1 1 0依據應用特定 性能需求或資源可用性而選擇性實施二個以上的功能架構 。例如,對一處理任務,圖形驅動程式1 1 0實施圖1的功 能架構,而對不同處理任務,圖形驅動程式1 0 0實施圖4 的功能架構。因此,本發明的實施例可交替或組合使用以 提供彈性處理解決。 上述架構可修改而不偏離發明的範禱和精神。例如, 圖1 -4的每一實施例雖參考涉及圖形處理的應用,但本發 明可用於其他驅動程式或介面取代圖形驅動程式1 1 〇,另 一種特殊用途處理器可用來取代GPU ( 135、210、310、 4 10)。 此外,圖1 _4的任何功能架構可修改使得多個輔助處 理器提供轉換給GPU (135、210、310或410)或其他特 殊用途處理器以加速處理。此外,其他實施例中,單一輔 助處理器可用來加速多個GPU (135、210、310或410) 或其他特殊用途處理器的運作。於是,依據應用需求’本 發明實施例可縮放。 根據應用,輔助處理器(1 15、2 0 5、3 0 5、4 05、625 、7 3 0 )可具有進行相當簡單任務的能力。例如,圖形處 理環境中,輔助處理器可進行第一次z-cull處理(下述) 。其他實施例中,輔助處理器(1 15、205 ' 3 05、405、 625、7 30)可具有 GPU(120、210、310、410、635、735 )或由輔助處理器所加速之其他特殊用途處理器的所有功 -9- (6) 1298454 肯b 。 故障容忍 圖5 A是本發明實施例之故障容忍方法的流程圖。圖 5 A顯示對輔助處理器1 1 5、3 0 5或4 0 5之故障之反應的方 法。如所示,流程在步驟5 0 5開始,然後前進到條件步驟 5 1 0判定輔助處理器是否運作。當條件步驟5 1 0的結果肯 定(是)時’流程前進到步驟5 1 5,GPU或其他特殊用途 處理器運算輸入A和A’,或只根據A,( A ’是輔助處理器 的輸出,如圖1 -4 )。當條件步驟5 1 0的結果否定(否) 時,流程前進到步驟520,GPU或其他特殊用途處理器只 運算輸入A (例如,沒有來自輔助處理器的結果)。 依據設計選擇,可對圖1、3、4的任何架構實施圖 5 A的故障容忍處理。 若輔助處理器故障,GPU或其他特殊用途處理器只根 據A來運算(例如,步驟5 20 ),則性能會退化。例如, 依據設計選擇,當一個以上的輔助處理器故障時,可預先 判定一個以上的像素解析度 '色彩解析度、或框速會減小 輔助處理器的選擇性使用 即使一個以上的輔助處理器運作,相較於只用特殊用 途處理器,使用一個以上的輔助處理器不一定增進性能。 於是,輔助處理器的選擇性使用會有利。 -10- 1298454 ·, (7) 圖5 B是本發明實施例之輔助處理器選擇性使用方法 的流程圖。如所示,流程在步驟5 2 5開始,然後前進到條 件步驟5 3 0判定輔助處理器使用是否增進性能。性能可關 於處理速度、精確度、或其他準則。當條件步驟5 3 0的結 果肯定(是)時,流程前進到步驟5 3 5,GPU或其他特殊 用途處理器運算輸入A和A’,或只根據A’( A’是輔助處 理器的輸出,如圖1-4)。當條件步驟5 3 0的結果否定( 否)時,流程前進到步驟5 3 5,GPU或其他特殊用途處理 器只運算輸入A (例如,沒有來自輔助處理器的結果)。 至少有條件步驟5 3 0的三實施例可交替或組合使用。 條件步驟5 3 0的第一實施例中,預先判定哪個應用或任務 經由輔助處理器的使用達成增進性能。此例中,條件步驟 5 3 0的運算根據預定設定。預定設定可包含在查表。 條件步驟5 3 0的第二實施例中,歷史資料(例如,用 和不用輔助處理器之實際處理時間的日誌)用來判定輔助 處理器應用是否增進性能。例如,條件步驟5 3 0的運算可 包含用和不用輔助處理器之平均處理時間的比較。 條件步驟5 3 0的第三實施例中’輔助處理器是否增進 性能的判定是根據瞬間或近瞬間知識。例如,參考圖1, 若GPU 120未及時接收A ’來開始處理框N + 1,則可在條 件步驟5 3 0判定輔助處理器1 1 5不增進性能。另一方面, 若GPU 120及時接收A’而開始處理框N + 2,則可在條件 步驟5 3 0判定輔助處理器增進性能。參考圖2,輔助處理 器2 0 5可輪詢GPU 210的狀態暫存器以判定GPU 2] 0何 -11 - 1298454 (8) 1 . 時可開始處理資料的最早點。當GPU 2 1 0可開始處理’ 且輔助處理器2 0 5未完成Α1的計算時,輔助處理器可將Α 送到GPU 210而非Α,。參考圖3,當GPU 310開始處理 A時,GPU 3 10的正常運作模式可從輔助處理器3 0 5取還 A’。當輔助處理器3 0 5從GPU 3 1 0接收取還命令時,若輔 助處理器3 05未完成計算A,,則輔助處理器3 05將零送 到GPU 3 10以回應取還命令。當GPU 310接收零時,條 件步驟5 3 0的結果否定(否),GPU 310只根據A處理( 步驟5 4 0 )。 如上述,依據設計需求,條件步驟5 3 0的運算可在圖 形驅動程式、輔助處理器、和/或GPU中進行。 輔助處理器例證 圖6和7提供上述功能架構更詳細的圖。前段的任何 功能架構可依據參考圖6或7的說明來實施。其他實施也 可能。 圖6是本發明一實施例之顯示輔助處理器例證之功能 系統架構的方塊圖。如所示,CPU 60 5包含應用軟體610 和圖形驅動程式6 1 5。核心邏輯620包含積體輔助處理器 62 5。核心邏輯620可爲或包含晶片組,諸如北橋和/或 南橋。北橋晶片組通常將CPU接到PCI匯流排和/或系 統記憶體;南橋晶片組通常控制通用串列匯流排(USB ) 和/或積體開發環境(IDE )匯流排,和/或進行電力管 理、鍵盤/滑鼠控制、或其他功能。核心邏輯6 2 0耦合到 -12 - 1298454 ⑼ • « 記憶體6 3 0和GPU 63 5。記憶體63 0可爲系統記憶體或區 域記憶體。積體輔助處理器62 5加速GPU 63 5或其他特 殊用途處理器。 圖7是本發明另一實施例之顯示輔助處理器例證之功 能系統架構的方塊圖。如所示,CPU 70 5包含應用軟體 7 10和圖形驅動程式715。CPU 705耦合到核心邏輯720 。核心邏輯7 2 0可爲或包含晶片組,諸如北橋和/或南橋 。核心邏輯720耦合到記憶體72 5、輔助處理器7 3 0、 GPU 73 5。核心邏輯720和輔助處理器73 0之間的耦合可 符合PCI或其他通訊協定。記憶體725可爲系統記憶體或 區域記憶體。積體輔助處理器73 0加速GPU 73 5或其他 特殊用途處理器。 圖1 - 7中’依據設計選擇,CPU ( 605、705)可爲或 包含 Intel Pentium III Xeo η、Intel Pentium 4、Intel Pentium M、AMD Athlon、或其他 CPU。GPU (135、225 、310、410、6 3 5、7 3 5 )可爲或包含 NVIDIA GeForce 2 5 6 GPU、NVIDIA Quadro FX 5 0 0、NVIDIA GeForce FX G〇5 2 00、NVIDIA G e F o r c e F X G o 5 6 0 0、或其他 G P U。無 關圖形處理的應用中,可使用非GP U的特殊用途處理器 例示應用 圖7和8提供圖形處理領域之本發明的例示應用。無 關圖形處理的其他應用也可受惠於加速特殊用途處理器的 -13- 1298454 (10) • i 輔助處理器。 圖8是本發明實施例之進行頂點著色之方法的流程圖 。顯示的方法預處理頂點緩衝,因而可較快繪圖。如所示 ,頂點緩衝A在步驟8 0 5產生,頂點在步驟8 1 0過濾或 著色,頂點緩衝A在步驟8 1 5繪圖。於是,頂點緩衝a 在步驟8 1 0預處理,因而可較快繪圖。步驟8丨〇和8 i 5選 擇性利用著色程式(未顯示)來執行各處理。步驟8 〇 5可 由圖形驅動程式1 1 〇執行,步驟8 1 0可由輔助處理器( 115、 205、 305' 405、 625、 730)進行,步驟 815 可由 GPU ( 120、210、310、410、635、73 5 )執行。 圖9是本發明實施例之進行二次Z-cull之方法的流程 圖。3 D成像中,z軸是離開銀幕往觀者眼睛的軸。z軸過 濾(Z-cull,a/k/a閉塞過濾)通常是丟棄第一組圖元的處 理’另一圖元要在第一組圖元和觀者眼睛之間的位置繪圖 於z軸上。換言之,z-cuU是丟棄阻隔顯示影像之圖元的 處理。運作中,通常對在相同框中分享相同X和y空間的 物體做Z値比較,以判定哪個可看見,哪個要過濾。 二次Z-cull中,在二步驟進行過濾。於是,如圖9, 在步驟905接收圖元,然後在第一次Z-CU11步驟910繪圖 以產生z-cull資訊。然後,在第二次z-cull步驟915,第 一次z-cull資訊可用來過濾比單次z-cull措施多的圖元。 步驟9 0 5可由圖形驅動程式1 1 〇執行,步驟9 1 0可由輔助 處理器(115、205、305、405、625、730)進行,步驟 915 可由 GPU (120、210、310、4 ]0、635、735)執行。 - 14 - (11) 1298454 其他應用中,輔助處理器(115、205、305、405、 62 5、7 3 0 )進行其他功能。例如,圖形應用中,輔助處理 器(115、205、305、405、625、73 0 )可進行 GPU 加速 之第一次的二次模板陰影量演算法、代表驅動程式之記憶 體拷貝的實施(使得拷貝不涉及CPU )、網路控制器所完 成之網路封包處理的進一步加速、產生較小輸入 A’以節 省頻寬之輸入A的壓縮、和/或特殊用途處理器之較快 存取的資料位置管理。 參考美國專利案 09/5 8 5,8 1 0 ( 5/3 1 /00申請)、 09/8 8 5,66 5 ( 6/ 1 9/0 1 申請)、1〇/2 3 051 24 ( 8/27/02 申請 )可更完整瞭解上述實施例,倂入做爲參考。 結論 因此上述本發明實施例以一個以上的其他特殊用途處 理器加速特殊用途處理器或管理特殊用途處理器的驅動程 式來克服已知系統方法的缺點。此外,揭露的措施有彈性 '可縮放,能以故障容忍和/或選擇性的方式實施。 本發明得由熟悉技藝之人任施匠思而爲諸般修飾,然 皆不脫如申請專利範圍所欲保護者。例如,描述單一輔助 處理器之使用的實施例可修改以使用多個輔助處理器。此 外’描述GPU之使用的實施例可修改以使用不同類的特 殊用途處理器’例如非關圖形處理的應用。 【圖式簡單說明】 -15- (12) 1298454 圖1是本發明實施例之功能系統架構的方塊圖; 圖2是本發明實施例之功能系統架構的方塊圖; 圖3是本發明實施例之功能系統架構的方塊圖; 圖4是本發明實施例之功能系統架構的方塊圖; 圖5 A是本發明實施例之故障容忍方法的流程圖; 圖5 B是本發明實施例之輔助處理器選擇性使用方法 的流程圖; 圖6是本發明一實施例之顯示輔助處理器例證之功能 系統架構的方塊圖; 圖7是本發明另一實施例之顯示輔助處理器例證之功 能系統架構的方塊圖; 圖8是本發明實施例之進行頂點著色之方法的流程圖 , 圖9是本發明實施例之進行二次Z-cxill之方法的流程 圖。 要元件符號說 明 105 應 用 程 式 110 圖 形 驅 動 程 式 115 輔 助 處 理 器 120 圖 形 處 理 單 元 205 輔 助 處 理 器 210 圖 形 處 理 單 元 3 05 輔 助 處 理 器 -16- 1298454 (13) 3 10 圖 405 輔 4 10 圖 605 中 6 10 應 625 圖 620 核 625 積 630 記 635 圖 705 中 7 10 應 7 25 圖 720 核 730 積 7 25 記 735 圖 形處理單元 助處理器 形處理單元 央處理單元 用程式 形驅動程式 心邏輯 體輔助處理器 憶體 形處理單元 央處理單元 用程式 形驅動程式 心邏輯 助處理器 憶體 形處理單元
-17 -

Claims (1)

  1. 1298454 (1) 十、申請專利範圍 附件4A : 第93 1 3 5 869號專利申請案 中文申請專利範圍替換本 民國96年7月9日修正 1 · 一種用於加速特殊用途處理器之資料處理的方法, 包括: 從驅動程式輸出資料至輔助處理器和特殊用途處理器
    9 轉換該輔助處理器的資料; 從該輔助處理器輸出該轉換資料至該特殊用途處理器 ;以及 根據該資料和該轉換資料來計算該特殊用途處理器的 結果’該計算比該特殊用途處理器只接收該資料做爲輸入 更快達成結果。
    2 ·如申請專利範圍第1項的方法,其中該驅動程式是 圖形驅動程式’該特殊用途處理器是圖形處理單元。 3 ·如申請專利範圍第2項的方法,其中轉換該資料包 含進行第一次z-cull,計算結果包含進行第二次z-cull。 4 · 一種根據來自驅動程式元件的資料來判定是否加速 特殊用途處理器之資料處理的方法,包括: 在特殊用途處理器接收資料; 判定輔助處理器是否運作; 若該輔助處理器運作, 則從該特殊用途處理器的輔助處理器接收轉換資料; (2) 1298454 以及 丰艮Μ該資料和該轉換資料來計算該特殊用途處理器的 結果’該計算比特殊用途處理器只接收該資料做爲輸入更 快達成結果;以及 若該輔助處理器不運作,則只根據接收自該驅動程式 元件的資料來計算該特殊用途處理器的結果。
    5 ·如申請專利範圍第4項的方法,其中該驅動程式是 圖形驅動程式,且該特殊用途處理器是圖形處理單元。 6 ·如申請專利範圍第4項的方法,進一步包括若該輔 助處理器運作,則從該驅動程式元件接收該輔助處理器的 資料。 7 ·如申請專利範圍第4項的方法,進一步包括若該輔 助處理器運作,則從該特殊用途處理器接收該輔助處理器 的資料。
    8 · —種用於加速特殊用途處理器之資料處理的系統, 包括= 輸出資料的驅動程式; 耦合到驅動程式並轉換資料的輔助處理器; 耦合到驅動程式和輔助處理器的特殊用途處理器,該 特殊用途處理器接收來自從驅動程式的資料和來自輔助處 理器的轉換資料,該特殊用途處理器進一步根據該資料和 該轉換資料比該特殊用途處理器只接收該資料做爲輸入更 快計算結果。 9·如申請專利範圍第8項的系統,其中該特殊用途處 -2- (3) 1298454 理器進一步判定該輔助處理器是否運作,若該輔助處理器 不運作,則只根據該資料來計算結果。 I 〇 ·如申請專利範圍第8項的系統,其中該驅動程式 是圖形驅動程式,且該特殊用途處理器是圖形處理單元。 II ·如申請專利範圍第1 0項的系統,其中該轉換資料 包含第一次z-cull資訊’結果包含第二次z_cull資訊。
    1 2 · —種記錄可以執行加速特殊用途處理器之資料處 理的指令的機器可讀取媒體,以進行方法,該方法包括·· 從驅動程式輸出資料至輔助處理器和特殊用途處理器 轉換輔助處理器的資料; 從該輔助處理器輸出該轉換資料至該特殊用途處理器 :以及
    根據資料和轉換資料來計算該特殊用途處理器的結果 ’該計算比該特殊用途處理器只接收該資料做爲輸入更快 達成結果。 1 3 · —種記錄可以執行加速特殊用途處理器之資料處 理的f日令的機窃可5買取媒體’進行根據來自驅動程式元件 的資料從特殊用途處理器提供輸出的方法,該方法包括: 在該特殊用途處理器接收資料; 判定該輔助處理器是否運作; 若該輔助處理器運作, 則從該特殊用途處理器的輔助處理器接收轉換資料; 根據該資料和該轉換資料來計算該特殊用途處理器的 -3 -
    1298454 .................^ .,,., …· 結果’該計算比該特殊用途處理器只接收該資料做爲輸入 更快達成結果;以及 若該輔助處理器不運作,則只根據接收自該驅動程式 元件的資料來計算該特殊用途處理器的結果。 14·一種用於加速特殊用途處理器之資料處理的方法 ,包括: 從驅動程式輸出資料至特殊用途處理器;
    從特殊用途處理器輸出該資料至輔助處理器; 轉換輔助處理器的資料; 從該輔助處理器輸出轉換資料至該特殊用途處理器; 以及 根據資料和轉換資料來計算特殊用途處理器的結果, 該計算比特殊用途處理器只接收資料做爲輸入更快達成結 果。
    1 5 ·如申請專利範圍第1 4項的方法,其中該驅動程式 是圖形驅動程式,特殊用途處理器是圖形處理單元。 1 6 · —種用於加速特殊用途處理器之資料處理的方法 ,包括: 從驅動程式輸出資料至特殊用途處理器和輔助處理器 轉換該輔助處理器的資料; 從該輔助處理器輸出轉換資料至該驅動程式; 從該驅動程式輸出轉換資料至該特殊用途處理器;以 -4-
    1298454 (5) 根據該資料和轉換資料來計算特殊用途處理器的結果 ,該計算比該特殊用途處理器只接收該資料做爲輸入更快 達成結果。 1 7 ·如申請專利範圍第1 6項的方法,其中該驅動程式 是圖形驅動程式,且特殊用途處理器是圖形處理單元。 1 8 · —種根據來自驅動程式元件的資料來判定是否加 速特殊用途處理器之資料處理的方法,包括:
    在該特殊用途處理器接收該資料; 判定輔助處理器是否運作; 若該輔助處理器運作, 則從該驅動程式元件的輔助處理器接收轉換資料; 從該驅動程式將轉換資料傳到特殊用途處理器; 根據該資料和轉換資料來計算特殊用途處理器的結果 ,該計算比特殊用途處理器只接收資料做爲輸入更快達成 結果,以及
    若該輔助處理器不運作,則只根據接收自該驅動程式 元件的資料來計算特殊用途處理器的結果。 1 9 · 一種用於加速特殊用途處理器之資料處理的方法 ,包括: 從驅動程式輸出資料至特殊用途處理器; 選擇性從該驅動程式和特殊用途處理器之一輸出資料 至輔助處理器; 轉換該輔助處理器的資料; 若資料從該驅動程式輸出至該輔助處理器, -5- _一 丨•丨IV,丨丨…^^-——-------- 1298454 !卓匕务i修(|f)t替换頁 (6) ~———— * 則從該輔助處理器選擇性輸出該轉換資料至該驅動程 式和該特殊用途處理器之一; 若該轉換資料輸出至該驅動程式,則從該驅動程式輸 出轉換資料至特殊用途處理器; 若資料從該特殊用途處理器輸出至該輔助處理器,則 從該輔助處理器輸出轉換資料至該特殊用途處理器;以及 根據該資料和該轉換資料來計算該特殊用途處理器的 結果’該i十算比該特殊用途處理器只接收該資料做爲輸入 更快達成結果。 20·—種用於加速處理圖形資料的方法,包括: 在驅動程式產生頂點緩衝; 轉換該頂點緩衝,該轉換包含使用該輔助處理器將該 頂點緩衝的複數個頂點過濾和著色的至少其中之一;以及 根據該特殊用途處理器的轉換頂點緩衝將該頂點緩衝 繪圖,該繪圖比該特殊用途處理器接收該頂點緩衝而不接 收該轉換頂點緩衝進行更快。 2 1 · —種選擇性使用輔助處理器以增進資料處理性能 的方法,包括: 判定輔助處理器的使用是否增進性能; 若判定該輔助處理器的使用未增進性能,則處理特殊 用途處理器的輸入;以及 若判定該輔助處理器的使用增進性能,則處理該特殊 用途處理器的轉換輸入,該轉換輸入是輔助處理器的輸入 處理結果。 -6 -
    1298454 (7) 22.如申請專利範圍第21項的方法,若判定該輔助處 理器的使用增進性能,則進一步包括處理該特殊處理器的 輸入。 23 .如申請專利範圍第2 1項的方法,其中判定是根據 經由該輔助處理器使用增進性能之應用的預定清單。 24.如申請專利範圍第2 1項的方法,其中判定是根據 任務的歷史性能資料。 2 5.如申請專利範圍第21項的方法,其中判定是根據 近瞬間知識。
TW093135869A 2003-12-11 2004-11-22 Method for accelerating the data processing of a special purpose processor, associated system, and machine-readable medium recording related instructions TWI298454B (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US10/732,445 US7053901B2 (en) 2003-12-11 2003-12-11 System and method for accelerating a special purpose processor

Publications (2)

Publication Number Publication Date
TW200529041A TW200529041A (en) 2005-09-01
TWI298454B true TWI298454B (en) 2008-07-01

Family

ID=34523048

Family Applications (1)

Application Number Title Priority Date Filing Date
TW093135869A TWI298454B (en) 2003-12-11 2004-11-22 Method for accelerating the data processing of a special purpose processor, associated system, and machine-readable medium recording related instructions

Country Status (5)

Country Link
US (1) US7053901B2 (zh)
EP (1) EP1542160B1 (zh)
AT (1) ATE434807T1 (zh)
DE (1) DE602004021667D1 (zh)
TW (1) TWI298454B (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TWI510056B (zh) * 2011-12-27 2015-11-21 Hon Hai Prec Ind Co Ltd 3d成像模組及3d成像方法
KR20170001721U (ko) 2015-11-09 2017-05-17 종산 잉리앙 헬스 테크놀로지 컴퍼니 리미티드 인버전 시트

Families Citing this family (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080094403A1 (en) * 2003-11-19 2008-04-24 Reuven Bakalash Computing system capable of parallelizing the operation graphics processing units (GPUs) supported on a CPU/GPU fusion-architecture chip and one or more external graphics cards, employing a software-implemented multi-mode parallel graphics rendering subsystem
US8085273B2 (en) 2003-11-19 2011-12-27 Lucid Information Technology, Ltd Multi-mode parallel graphics rendering system employing real-time automatic scene profiling and mode control
US20080074431A1 (en) * 2003-11-19 2008-03-27 Reuven Bakalash Computing system capable of parallelizing the operation of multiple graphics processing units (GPUS) supported on external graphics cards
US7961194B2 (en) 2003-11-19 2011-06-14 Lucid Information Technology, Ltd. Method of controlling in real time the switching of modes of parallel operation of a multi-mode parallel graphics processing subsystem embodied within a host computing system
US20090027383A1 (en) * 2003-11-19 2009-01-29 Lucid Information Technology, Ltd. Computing system parallelizing the operation of multiple graphics processing pipelines (GPPLs) and supporting depth-less based image recomposition
US8497865B2 (en) 2006-12-31 2013-07-30 Lucid Information Technology, Ltd. Parallel graphics system employing multiple graphics processing pipelines with multiple graphics processing units (GPUS) and supporting an object division mode of parallel graphics processing using programmable pixel or vertex processing resources provided with the GPUS
US20070291040A1 (en) * 2005-01-25 2007-12-20 Reuven Bakalash Multi-mode parallel graphics rendering system supporting dynamic profiling of graphics-based applications and automatic control of parallel modes of operation
CA2546427A1 (en) * 2003-11-19 2005-06-02 Reuven Bakalash Method and system for multiple 3-d graphic pipeline over a pc bus
US7450120B1 (en) * 2003-12-19 2008-11-11 Nvidia Corporation Apparatus, system, and method for Z-culling
US8490101B1 (en) * 2004-11-29 2013-07-16 Oracle America, Inc. Thread scheduling in chip multithreading processors
US20090096798A1 (en) * 2005-01-25 2009-04-16 Reuven Bakalash Graphics Processing and Display System Employing Multiple Graphics Cores on a Silicon Chip of Monolithic Construction
JP2008538620A (ja) * 2005-01-25 2008-10-30 ルーシッド インフォメイション テクノロジー リミテッド モノリシック構成のシリコン・チップ上に多数のグラフィックス・コアを用いるグラフィック処理及び表示システム
US7839854B2 (en) * 2005-03-08 2010-11-23 Thomas Alexander System and method for a fast, programmable packet processing system
US20070005852A1 (en) * 2005-06-30 2007-01-04 International Business Machines Corporation Graphical verification tool for packet-based interconnect bus
JP4327175B2 (ja) * 2005-07-12 2009-09-09 株式会社ソニー・コンピュータエンタテインメント マルチグラフィックプロセッサシステム、グラフィックプロセッサおよび描画処理方法
US8570331B1 (en) 2006-08-24 2013-10-29 Nvidia Corporation System, method, and computer program product for policy-based routing of objects in a multi-graphics processor environment
US8207972B2 (en) * 2006-12-22 2012-06-26 Qualcomm Incorporated Quick pixel rendering processing
US8179394B1 (en) * 2007-12-13 2012-05-15 Nvidia Corporation Cull streams for fine-grained rendering predication
US9489767B1 (en) 2007-12-13 2016-11-08 Nvidia Corporation Cull streams for fine-grained rendering predication
US8102393B1 (en) * 2007-12-13 2012-01-24 Nvidia Corporation Cull streams for fine-grained rendering predication
US8330762B2 (en) 2007-12-19 2012-12-11 Advanced Micro Devices, Inc. Efficient video decoding migration for multiple graphics processor systems
US10157492B1 (en) 2008-10-02 2018-12-18 Nvidia Corporation System and method for transferring pre-computed Z-values between GPUS
US8395619B1 (en) * 2008-10-02 2013-03-12 Nvidia Corporation System and method for transferring pre-computed Z-values between GPUs
US8427474B1 (en) * 2008-10-03 2013-04-23 Nvidia Corporation System and method for temporal load balancing across GPUs
US8228337B1 (en) 2008-10-03 2012-07-24 Nvidia Corporation System and method for temporal load balancing across GPUs
TWI497396B (zh) * 2009-10-13 2015-08-21 Via Tech Inc 三維物件旋轉方法,與其對應的電腦系統和記錄媒體
US8941655B2 (en) 2011-09-07 2015-01-27 Qualcomm Incorporated Memory copy engine for graphics processing
US9159156B2 (en) * 2012-05-14 2015-10-13 Nvidia Corporation Cull streams for fine-grained rendering predication
US10101982B2 (en) * 2013-01-31 2018-10-16 Htc Corporation Methods for application management in an electronic device supporting hardware acceleration
US11295506B2 (en) * 2015-09-16 2022-04-05 Tmrw Foundation Ip S. À R.L. Chip with game engine and ray trace engine
US11301951B2 (en) 2018-03-15 2022-04-12 The Calany Holding S. À R.L. Game engine and artificial intelligence engine on a chip
US11625884B2 (en) 2019-06-18 2023-04-11 The Calany Holding S. À R.L. Systems, methods and apparatus for implementing tracked data communications on a chip

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5579455A (en) * 1993-07-30 1996-11-26 Apple Computer, Inc. Rendering of 3D scenes on a display using hierarchical z-buffer visibility
US5706478A (en) 1994-05-23 1998-01-06 Cirrus Logic, Inc. Display list processor for operating in processor and coprocessor modes
EP0740272A2 (en) * 1995-04-28 1996-10-30 Sun Microsystems, Inc. Method and apparatus for fast rendering of three-dimensional objects
US5936641A (en) 1997-06-27 1999-08-10 Object Technology Licensing Corp Graphics hardware acceleration method, computer program, and system
US6184908B1 (en) * 1998-04-27 2001-02-06 Ati Technologies, Inc. Method and apparatus for co-processing video graphics data
US6247113B1 (en) 1998-05-27 2001-06-12 Arm Limited Coprocessor opcode division by data type
US6097400A (en) * 1998-06-01 2000-08-01 Ati Technologies, Inc. Method and apparatus for anti-aliasing post rendering of an image
US6646639B1 (en) * 1998-07-22 2003-11-11 Nvidia Corporation Modified method and apparatus for improved occlusion culling in graphics systems
US6323860B1 (en) * 1999-03-17 2001-11-27 Nvidia Corporation Circuit and method for deferring the binding of render states to primitives in a graphics system
US6624816B1 (en) 1999-09-10 2003-09-23 Intel Corporation Method and apparatus for scalable image processing
US6476808B1 (en) * 1999-10-14 2002-11-05 S3 Graphics Co., Ltd. Token-based buffer system and method for a geometry pipeline in three-dimensional graphics
US6452595B1 (en) 1999-12-06 2002-09-17 Nvidia Corporation Integrated graphics processing unit with antialiasing
US20030122820A1 (en) * 2001-12-31 2003-07-03 Doyle Peter L. Object culling in zone rendering

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TWI510056B (zh) * 2011-12-27 2015-11-21 Hon Hai Prec Ind Co Ltd 3d成像模組及3d成像方法
KR20170001721U (ko) 2015-11-09 2017-05-17 종산 잉리앙 헬스 테크놀로지 컴퍼니 리미티드 인버전 시트

Also Published As

Publication number Publication date
TW200529041A (en) 2005-09-01
EP1542160B1 (en) 2009-06-24
ATE434807T1 (de) 2009-07-15
EP1542160A1 (en) 2005-06-15
US7053901B2 (en) 2006-05-30
US20050128203A1 (en) 2005-06-16
DE602004021667D1 (de) 2009-08-06

Similar Documents

Publication Publication Date Title
TWI298454B (en) Method for accelerating the data processing of a special purpose processor, associated system, and machine-readable medium recording related instructions
US10311541B2 (en) Multi-user multi-GPU render server apparatus and methods
EP2068279B1 (en) System and method for using a secondary processor in a graphics system
TWI417806B (zh) 單一通過鑲嵌
EP2080170B1 (en) Combined intensity projection
US20060010454A1 (en) Architecture for rendering graphics on output devices
JP5616333B2 (ja) ジオメトリシェーダを用いる平面充填エンジンのためのシステム、方法及びコンピュータプログラム
HUE031474T2 (en) Graphic processing unit instruction with execution unit
JP2008536213A (ja) モデルの簡略化した表示を決定するためのシステム及び方法
JP2001243481A (ja) 画像生成装置
US20220346888A1 (en) Device and system for multidimensional data visualization and interaction in an augmented reality virtual reality or mixed reality environment
CN114968559B (zh) 基于lsf的多主机多gpu分布式布置深度学习模型的方法
JP4342193B2 (ja) 三次元cadシステム、部分再投影方法、及びコンピュータプログラム
WO2007052394A1 (ja) 描画処理装置、並列処理装置および排他制御方法
WO2018140238A1 (en) Out of order pixel shader exports
JP5798357B2 (ja) 画像処理装置、画像処理方法
US20230054394A1 (en) Device and system for multidimensional data visualization and interaction in an augmented reality virtual reality or mixed reality image guided surgery
JP2004072553A (ja) 映像歪み補正方法及び同方法用プログラム
US11417058B2 (en) Anti-aliasing two-dimensional vector graphics using a multi-vertex buffer
EP4035001A1 (en) Flexible multi-user graphics architecture
WO2024082695A1 (zh) 一种渲染指令的合批方法及装置
CN112351213B (zh) 用于有效信号处理的芯片资源上的系统动态分配
JP3422278B2 (ja) グラフィックアクセラレータ
US9953396B1 (en) Ray casting visualization multi-user interaction processing method based on hadoop and CUDA
CN117671106A (zh) 遮挡查询方法、装置、电子设备及存储介质