JP2013546099A - ユーザモードからのグラフィックス処理ディスパッチ - Google Patents
ユーザモードからのグラフィックス処理ディスパッチ Download PDFInfo
- Publication number
- JP2013546099A JP2013546099A JP2013544544A JP2013544544A JP2013546099A JP 2013546099 A JP2013546099 A JP 2013546099A JP 2013544544 A JP2013544544 A JP 2013544544A JP 2013544544 A JP2013544544 A JP 2013544544A JP 2013546099 A JP2013546099 A JP 2013546099A
- Authority
- JP
- Japan
- Prior art keywords
- command
- application
- work queue
- apd
- processing device
- Prior art date
- Legal status (The legal status 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 status listed.)
- Granted
Links
- 238000012545 processing Methods 0.000 title claims abstract description 77
- 239000000872 buffer Substances 0.000 claims abstract description 104
- 238000000034 method Methods 0.000 claims abstract description 71
- 230000008569 process Effects 0.000 claims abstract description 39
- 238000004886 process control Methods 0.000 claims description 38
- 238000004364 calculation method Methods 0.000 claims description 26
- 238000012546 transfer Methods 0.000 claims description 3
- 230000007704 transition Effects 0.000 abstract description 10
- 238000004590 computer program Methods 0.000 abstract description 5
- 230000006870 function Effects 0.000 description 23
- 239000013256 coordination polymer Substances 0.000 description 18
- 238000010586 diagram Methods 0.000 description 17
- 238000004891 communication Methods 0.000 description 12
- 238000007726 management method Methods 0.000 description 10
- 238000013459 approach Methods 0.000 description 9
- 230000007246 mechanism Effects 0.000 description 6
- 230000008901 benefit Effects 0.000 description 4
- 238000004519 manufacturing process Methods 0.000 description 4
- 230000006399 behavior Effects 0.000 description 3
- 238000004422 calculation algorithm Methods 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 241001522296 Erithacus rubecula Species 0.000 description 2
- XUIMIQQOPSSXEZ-UHFFFAOYSA-N Silicon Chemical compound [Si] XUIMIQQOPSSXEZ-UHFFFAOYSA-N 0.000 description 2
- 230000015572 biosynthetic process Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 230000009467 reduction Effects 0.000 description 2
- 238000013468 resource allocation Methods 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 230000011664 signaling Effects 0.000 description 2
- 229910052710 silicon Inorganic materials 0.000 description 2
- 239000010703 silicon Substances 0.000 description 2
- 238000004088 simulation Methods 0.000 description 2
- 239000000758 substrate Substances 0.000 description 2
- 238000003786 synthesis reaction Methods 0.000 description 2
- 238000013519 translation Methods 0.000 description 2
- 230000001133 acceleration Effects 0.000 description 1
- 230000003213 activating effect Effects 0.000 description 1
- 230000002411 adverse Effects 0.000 description 1
- 238000013473 artificial intelligence Methods 0.000 description 1
- 238000000098 azimuthal photoelectron diffraction Methods 0.000 description 1
- 230000004888 barrier function Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000000903 blocking effect Effects 0.000 description 1
- 230000003139 buffering effect Effects 0.000 description 1
- 230000005465 channeling Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 230000003111 delayed effect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 239000002360 explosive Substances 0.000 description 1
- 238000007667 floating Methods 0.000 description 1
- 239000012530 fluid Substances 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 230000009249 intrinsic sympathomimetic activity Effects 0.000 description 1
- 230000001404 mediated effect Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 238000012913 prioritisation Methods 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 230000036962 time dependent Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/545—Interprogram communication where tasks reside in different layers, e.g. user- and kernel-space
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/544—Buffers; Shared memory; Pipes
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Image Processing (AREA)
- Advance Control (AREA)
- Image Generation (AREA)
Abstract
【選択図】図7
Description
本発明の様々な実施形態が上述されているが、それらは例としてのみ提示されており、制限ではないことが理解されるべきである。当業者には、形式および詳細における様々な変更が、添付の特許請求項で定義されている本発明の精神および範囲から逸脱することなく、行われ得ることが理解されるであろう。本発明がこれらの例に制限されないことが理解されるべきである。本発明は、本明細書に記載するとおりに動作する任意の要素に対して適用可能である。さらに、本発明の範囲は、上述の代表的な実施形態のいずれよっても制限されるものではなく、以下の特許請求項およびそれらの均等物にしたがって定められるべきである。
Claims (21)
- アクセラレーテッド処理デバイスの作業待ち行列を、カーネルモードドライバを介してアプリケーションに割り当てるステップと、
コマンドを、前記アプリケーションから前記作業待ち行列に転送するステップと、
前記コマンドを、前記作業待ち行列から前記アクセラレーテッド処理デバイスにディスパッチするステップと、
を含む方法。 - 前記コマンドを、コマンドバッファに格納するステップをさらに含み、
前記コマンドを前記アプリケーションから前記作業待ち行列に転送するステップは、前記コマンドを、前記コマンドバッファから前記作業待ち行列に転送するステップを含む、
請求項1に記載の方法。 - アクセラレーテッド処理デバイスにアクセス可能なメモリリソースを、前記アプリケーションに割り当てるステップをさらに含む、
請求項1に記載の方法。 - 前記アクセラレーテッド処理デバイスの作業待ち行列を、前記アプリケーションに割り当てるステップは、計算コマンドリングバッファを、前記アプリケーションに割り当てるステップを含む、
請求項1に記載の方法。 - 前記アプリケーションに対応する計算プロセス制御ブロックを割り当てるステップであって、前記計算プロセス制御ブロックは、前記アプリケーションの前記アクセラレーテッド処理デバイスの作業待ち行列の位置を識別する情報を格納するステップをさらに含む、
請求項1に記載の方法。 - 前記コマンドを、前記作業待ち行列から前記アクセラレーテッド処理デバイスにディスパッチするステップは、前記アクセラレーテッド処理デバイスが、前記計算プロセス制御ブロックからの前記位置情報に基づいて前記作業待ち行列にアクセスし、コマンドを読み出すステップを含む、
請求項5に記載の方法。 - 前記計算プロセス制御ブロックおよび1つ以上の追加的な計算プロセス制御ブロックへの参照を含む計算プロセスリストを割り当てるステップをさらに含む、
請求項5に記載の方法。 - 命令が記録されているコンピュータ使用可能媒体であって、
前記命令は、コンピューティング装置によって実行される場合に、前記コンピューティング装置に、
アクセラレーテッド処理デバイスの作業待ち行列を、カーネルモードドライバを介してカーネルモードドライバを介してアプリケーションに割り当てることと、
コマンドを、前記アプリケーションから前記作業待ち行列に転送することと、
前記コマンドを、前記作業待ち行列から前記アクセラレーテッド処理デバイスにディスパッチすることと、
を含む方法を実行させる、
コンピュータ使用可能媒体。 - 前記コマンドを、コマンドバッファに格納することをさらに含み、
前記コマンドを、前記アプリケーションから前記作業待ち行列に転送することは、前記コマンドを、前記コマンドバッファから前記作業待ち行列に転送することを含む、
請求項8に記載のコンピュータ使用可能媒体。 - アクセラレーテッド処理デバイスにアクセス可能なメモリリソースを、前記アプリケーションに割り当てることをさらに含む、
請求項8に記載のコンピュータ使用可能媒体。 - 前記アクセラレーテッド処理デバイスの作業待ち行列を、前記アプリケーションに割り当てることは、計算コマンドリングバッファを、前記アプリケーションに割り当てることを含む、
請求項8に記載のコンピュータ使用可能媒体。 - 前記アプリケーションに対応する計算プロセス制御ブロックを割り当てることであって、前記計算プロセス制御ブロックは、前記アプリケーションの前記アクセラレーテッド処理デバイスの作業待ち行列の位置を識別する情報を格納することを含む、
請求項8に記載のコンピュータ使用可能媒体。 - 前記コマンドを、前記作業待ち行列から前記アクセラレーテッド処理デバイスにディスパッチすることは、前記アクセラレーテッド処理デバイスが、前記計算プロセス制御ブロックからの前記位置情報に基づいて前記作業待ち行列にアクセスし、コマンドを読み出すことを含む、
請求項12に記載のコンピュータ使用可能媒体。 - 前記計算プロセス制御ブロックおよび1つ以上の追加的な計算プロセス制御ブロックへの参照を含む計算プロセスリストを割り当てることをさらに含む、
請求項12に記載のコンピュータ使用可能媒体。 - メモリと、
アクセラレーテッド処理デバイスの作業待ち行列を、カーネルモードドライバを介してアプリケーションに割り当て、コマンドを、前記アプリケーションから前記作業待ち行列に転送し、および、前記コマンドを、前記作業待ち行列から前記アクセラレーテッド処理デバイスにディスパッチするように構成されたプロセッサと、を備える、
システム。 - 前記プロセッサは、前記コマンドを、コマンドバッファに格納するように構成されており、
前記コマンドを、前記アプリケーションから前記作業待ち行列に転送することは、前記コマンドを、前記コマンドバッファから前記作業待ち行列に転送することを含む、
請求項15に記載のシステム。 - 前記プロセッサは、アクセラレーテッド処理デバイスにアクセス可能なメモリリソースを、前記アプリケーションに割り当てるように構成されている、
請求項15に記載のシステム。 - 前記アクセラレーテッド処理デバイスの作業待ち行列を、前記アプリケーションに割り当てることは、計算コマンドリングバッファを、前記アプリケーションに割り当てることを含む、
請求項15に記載のシステム。 - 前記プロセッサは、前記アプリケーションに対応する計算プロセス制御ブロックを割り当てるように構成されており、前記計算プロセス制御ブロックは、前記アプリケーションの前記アクセラレーテッド処理デバイスの作業待ち行列の位置を識別する情報を格納する、
請求項15に記載のシステム。 - 前記コマンドを、記作業待ち行列から前記アクセラレーテッド処理デバイスにディスパッチすることは、前記アクセラレーテッド処理デバイスが、前記計算プロセス制御ブロックからの前記位置情報に基づいて前記作業待ち行列にアクセスし、コマンドを読み出すことを含む、
請求項19に記載のシステム。 - 前記プロセッサは、前記計算プロセス制御ブロックおよび1つ以上の追加的な計算プロセス制御ブロックへの参照を含む計算プロセスリストを割り当てるように構成されている、
請求項19に記載のシステム。
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US42246510P | 2010-12-13 | 2010-12-13 | |
US61/422,465 | 2010-12-13 | ||
US13/289,304 | 2011-11-04 | ||
US13/289,304 US9176795B2 (en) | 2010-12-13 | 2011-11-04 | Graphics processing dispatch from user mode |
PCT/US2011/063240 WO2012082424A1 (en) | 2010-12-13 | 2011-12-05 | Graphics processing dispatch from user mode |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2013546099A true JP2013546099A (ja) | 2013-12-26 |
JP6086868B2 JP6086868B2 (ja) | 2017-03-01 |
Family
ID=45418793
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2013544544A Active JP6086868B2 (ja) | 2010-12-13 | 2011-12-05 | ユーザモードからのグラフィックス処理ディスパッチ |
Country Status (6)
Country | Link |
---|---|
US (1) | US9176795B2 (ja) |
EP (1) | EP2652614B1 (ja) |
JP (1) | JP6086868B2 (ja) |
KR (1) | KR101786767B1 (ja) |
CN (1) | CN103392171B (ja) |
WO (1) | WO2012082424A1 (ja) |
Families Citing this family (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8578129B2 (en) * | 2011-12-14 | 2013-11-05 | Advanced Micro Devices, Inc. | Infrastructure support for accelerated processing device memory paging without operating system integration |
US9778859B2 (en) | 2013-09-18 | 2017-10-03 | Western Digital Technologies, Inc. | Doorless protocol having multiple queue read requests in flight |
US9547472B2 (en) * | 2013-09-18 | 2017-01-17 | HGST Netherlands B.V. | ACK-less protocol for noticing completion of read requests |
GB2524063B (en) | 2014-03-13 | 2020-07-01 | Advanced Risc Mach Ltd | Data processing apparatus for executing an access instruction for N threads |
US10346941B2 (en) * | 2014-05-30 | 2019-07-09 | Apple Inc. | System and method for unified application programming interface and model |
US9740464B2 (en) | 2014-05-30 | 2017-08-22 | Apple Inc. | Unified intermediate representation |
US10430169B2 (en) | 2014-05-30 | 2019-10-01 | Apple Inc. | Language, function library, and compiler for graphical and non-graphical computation on a graphical processor unit |
EP3866007A1 (en) * | 2014-06-26 | 2021-08-18 | INTEL Corporation | Intelligent gpu scheduling in a virtualization environment |
US9773292B2 (en) * | 2014-06-26 | 2017-09-26 | Intel Corporation | Graphics workload submissions by unprivileged applications |
US20170069054A1 (en) * | 2015-09-04 | 2017-03-09 | Intel Corporation | Facilitating efficient scheduling of graphics workloads at computing devices |
GB2546343A (en) * | 2016-01-15 | 2017-07-19 | Stmicroelectronics (Grenoble2) Sas | Apparatus and methods implementing dispatch mechanisms for offloading executable functions |
US9792051B2 (en) * | 2016-02-24 | 2017-10-17 | Samsung Electronics Co., Ltd. | System and method of application aware efficient IO scheduler |
US10664942B2 (en) | 2016-10-21 | 2020-05-26 | Advanced Micro Devices, Inc. | Reconfigurable virtual graphics and compute processor pipeline |
CN109388592B (zh) * | 2017-08-02 | 2022-03-29 | 伊姆西Ip控股有限责任公司 | 采用用户空间存储驱动器内的多个排队结构来提高速度 |
US11977933B2 (en) * | 2019-12-19 | 2024-05-07 | Advanced Micro Devices, Inc. | Gang scheduling with an onboard graphics processing unit and user-based queues |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2003233508A (ja) * | 2002-01-04 | 2003-08-22 | Microsoft Corp | コンピューティングシステム中のコプロセッサの計算リソースを制御するための方法およびコンピューティング装置 |
JP2010020803A (ja) * | 2003-02-18 | 2010-01-28 | Microsoft Corp | コプロセッサの性能を強化するシステムおよび方法 |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7024672B2 (en) * | 2002-06-26 | 2006-04-04 | Microsoft Corporation | Process-mode independent driver model |
US7444637B2 (en) * | 2003-02-18 | 2008-10-28 | Microsoft Corporation | Systems and methods for scheduling coprocessor resources in a computing system |
US7673304B2 (en) * | 2003-02-18 | 2010-03-02 | Microsoft Corporation | Multithreaded kernel for graphics processing unit |
US7765558B2 (en) * | 2004-07-06 | 2010-07-27 | Authentium, Inc. | System and method for handling an event in a computer system |
US7459822B1 (en) | 2005-05-13 | 2008-12-02 | Johnson Weston C | Rotating electric machine having switched or variable reluctance with flux transverse to the axis of rotation |
US7650603B2 (en) * | 2005-07-08 | 2010-01-19 | Microsoft Corporation | Resource management for virtualization of graphics adapters |
US8817029B2 (en) * | 2005-10-26 | 2014-08-26 | Via Technologies, Inc. | GPU pipeline synchronization and control system and method |
US8345053B2 (en) * | 2006-09-21 | 2013-01-01 | Qualcomm Incorporated | Graphics processors with parallel scheduling and execution of threads |
US7830387B2 (en) * | 2006-11-07 | 2010-11-09 | Microsoft Corporation | Parallel engine support in display driver model |
US8522242B2 (en) * | 2007-12-31 | 2013-08-27 | Intel Corporation | Conditional batch buffer execution |
US8310492B2 (en) * | 2009-09-03 | 2012-11-13 | Ati Technologies Ulc | Hardware-based scheduling of GPU work |
US20110063306A1 (en) | 2009-09-16 | 2011-03-17 | Nvidia Corporation | CO-PROCESSING TECHNIQUES ON HETEROGENEOUS GPUs INCLUDING IDENTIFYING ONE GPU AS A NON-GRAPHICS DEVICE |
-
2011
- 2011-11-04 US US13/289,304 patent/US9176795B2/en active Active
- 2011-12-05 KR KR1020137017094A patent/KR101786767B1/ko active IP Right Grant
- 2011-12-05 WO PCT/US2011/063240 patent/WO2012082424A1/en active Application Filing
- 2011-12-05 EP EP11802224.3A patent/EP2652614B1/en active Active
- 2011-12-05 JP JP2013544544A patent/JP6086868B2/ja active Active
- 2011-12-05 CN CN201180059919.2A patent/CN103392171B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2003233508A (ja) * | 2002-01-04 | 2003-08-22 | Microsoft Corp | コンピューティングシステム中のコプロセッサの計算リソースを制御するための方法およびコンピューティング装置 |
JP2010020803A (ja) * | 2003-02-18 | 2010-01-28 | Microsoft Corp | コプロセッサの性能を強化するシステムおよび方法 |
Also Published As
Publication number | Publication date |
---|---|
WO2012082424A1 (en) | 2012-06-21 |
CN103392171A (zh) | 2013-11-13 |
US20120188258A1 (en) | 2012-07-26 |
US9176795B2 (en) | 2015-11-03 |
CN103392171B (zh) | 2017-06-23 |
EP2652614A1 (en) | 2013-10-23 |
EP2652614B1 (en) | 2019-05-01 |
JP6086868B2 (ja) | 2017-03-01 |
KR20140004669A (ko) | 2014-01-13 |
KR101786767B1 (ko) | 2017-10-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6381734B2 (ja) | グラフィックス計算プロセススケジューリング | |
JP6086868B2 (ja) | ユーザモードからのグラフィックス処理ディスパッチ | |
JP6228459B2 (ja) | システムコール要求の通信の最適化 | |
JP2013546097A (ja) | グラフィックス処理計算リソースのアクセシビリティ | |
JP6373586B2 (ja) | 異種処理デバイスの動的ワークパーティション | |
EP2791795B1 (en) | Policies for shader resource allocation in a shader core | |
US9507632B2 (en) | Preemptive context switching of processes on ac accelerated processing device (APD) based on time quanta | |
US20120180056A1 (en) | Heterogeneous Enqueuinig and Dequeuing Mechanism for Task Scheduling | |
JP5805783B2 (ja) | コンピュータシステムインタラプト処理 | |
JP2014503898A (ja) | 処理装置の同期動作のための方法およびシステム | |
US20120194526A1 (en) | Task Scheduling | |
WO2012082777A1 (en) | Managed task scheduling on an accelerated processing device (apd) | |
WO2013081975A1 (en) | Saving and restoring shader and non-shader state using a command processor | |
US20130155079A1 (en) | Saving and Restoring Shader Context State | |
WO2013090605A2 (en) | Saving and restoring shader context state and resuming a faulted apd wavefront |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20141203 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20151130 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20151215 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20160315 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20160830 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20161128 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20170104 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20170131 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 6086868 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |