The present application is being filed concurrently with the following related U.S. patent application, which is assigned to NVIDIA Corporation, the assignee of the present invention, and the disclosure of which is hereby incorporated by reference for all purposes:
U.S. patent application Ser. No. 11/015,600, entitled “COHERENCE OF DISPLAYED IMAGES FOR SPLIT FRAME RENDERING IN A MULTI-PROCESSOR GRAPHICS SYSTEM”.
The present application is related to the following U.S. patent applications, which are assigned to NVIDIA Corporation, the assignee of the present invention, and the disclosures of which are hereby incorporated by reference for all purposes:
U.S. application Ser. No. 10/990,712, filed Nov. 17, 2004, entitled “CONNECTING GRAPHICS ADAPTERS FOR SCALABLE PERFORMANCE”.
U.S. patent application Ser. No. 11/012,394, filed Dec. 15, 2004, entitled “BROADCAST APERTURE REMAPPING FOR MULTIPLE GRAPHICS ADAPTERS”.
U.S. patent application Ser. No. 10/642,905, filed Aug. 18, 2003, entitled “ADAPTIVE LOAD BALANCING IN A MULTI-PROCESSOR GRAPHICS PROCESSING SYSTEM”.
The demand for ever higher performance in computer graphics has lead to the continued development of more and more powerful graphics processing subsystems and graphics processing units (GPUs). However, it may be desirable to achieve performance increases by modifying and/or otherwise utilizing existing graphics subsystems and GPUs. For example, it may be more cost effective to obtain performance increases by utilizing existing equipment, instead of developing new equipment. As another example, development time associated with obtaining performance increases by utilizing existing equipment may be significantly less, as compared to designing and building new equipment. Moreover, techniques for increasing performance utilizing existing equipment may be applied to newer, more powerful graphics equipment when it become available, to achieve further increases in performance.
On approach for obtaining performance gains by modifying or otherwise utilizing existing graphics equipment relates to the use of multiple GPUs to distribute the processing of images that would otherwise be processed using a single GPU. While the use of multiple GPUs to distribute processing load and thereby increase overall performance is a theoretically appealing approach, a wide variety of challenges must be overcome in order to effectively implement such a system. To better illustrate the context of the present invention, description of a typical computer system employing a graphics processing subsystem and a GPU is provided below.
Graphics processing subsystem 112 includes a graphics processing unit (GPU) 114 and a graphics memory 116, which may be implemented, e.g., using one or more integrated circuit devices such as programmable processors, application specific integrated circuits (ASICs), and memory devices. GPU 114 includes a rendering module 120, a memory interface module 122, and a scanout module 124. Rendering module 120 may be configured to perform various tasks related to generating pixel data from graphics data supplied via system bus 106 (e.g., implementing various 2-D and or 3-D rendering algorithms), interacting with graphics memory 116 to store and update pixel data, and the like. Rendering module 120 is advantageously configured to generate pixel data from 2-D or 3-D scene data provided by various programs executing on CPU 102. Operation of rendering module 120 is described further below.
Memory interface module 122, which communicates with rendering module 120 and scanout control logic 124, manages interactions with graphics memory 116. Memory interface module 122 may also include pathways for writing pixel data received from system bus 106 to graphics memory 116 without processing by rendering module 120. The particular configuration of memory interface module 122 may be varied as desired, and a detailed description is omitted as not being critical to understanding the present invention.
Graphics memory 116, which may be implemented using one or more integrated circuit memory devices of generally conventional design, may contain various physical or logical subdivisions, such as a pixel buffer 126 and a command buffer 128. Pixel buffer 126 stores pixel data for an image (or for a part of an image) that is read and processed by scanout module 124 and transmitted to display device 110 for display. This pixel data may be generated, e.g., from 2-D or 3-D scene data provided to rendering module 120 of GPU 114 via system bus 106 or generated by various processes executing on CPU 102 and provided to pixel buffer 126 via system bus 106. In some implementations, pixel buffer 126 can be double buffered so that while data for a first image is being read for display from a “front” buffer, data for a second image can be written to a “back” buffer without affecting the currently displayed image. Command buffer 128 is used to queue commands received via system bus 106 for execution by rendering module 120 and/or scanout module 124, as described below. Other portions of graphics memory 116 may be used to store data required by GPU 114 (such as texture data, color lookup tables, etc.), executable program code for GPU 114 and so on.
Scanout module 124, which may be integrated in a single chip with GPU 114 or implemented in a separate chip, reads pixel color data from pixel buffer 118 and transfers the data to display device 110 to be displayed. In one implementation, scanout module 124 operates isochronously, scanning out frames of pixel data at a prescribed refresh rate (e.g., 80 Hz) regardless of any other activity that may be occurring in GPU 114 or elsewhere in system 100. Thus, the same pixel data corresponding to a particular image may be repeatedly scanned out at the prescribed refresh rate. The refresh rate can be a user selectable parameter, and the scanout order may be varied as appropriate to the display format (e.g., interlaced or progressive scan). Scanout module 124 may also perform other operations, such as adjusting color values for particular display hardware and/or generating composite screen images by combining the pixel data from pixel buffer 126 with data for a video or cursor overlay image or the like, which may be obtained, e.g., from graphics memory 116, system memory 104, or another data source (not shown). Operation of scanout module 124 is described further below.
During operation of system 100, CPU 102 executes various programs that are (temporarily) resident in system memory 104. These programs may include one or more operating system (OS) programs 132, one or more application programs 134, and one or more driver programs 136 for graphics processing subsystem 112. It is to be understood that, although these programs are shown as residing in system memory 104, the invention is not limited to any particular mechanism for supplying program instructions for execution by CPU 102. For instance, at any given time some or all of the program instructions for any of these programs may be present within CPU 102 (e.g., in an on-chip instruction cache and/or various buffers and registers), in a page file or memory mapped file on system disk 128, and/or in other storage space.
Operating system programs 132 and/or application programs 134 may be of conventional design. An application program 134 may be, for instance, a video game program that generates graphics data and invokes appropriate rendering functions of GPU 114 (e.g., rendering module 120) to transform the graphics data to pixel data. Another application program 134 may generate pixel data and provide the pixel data to graphics processing subsystem 112 for display. It is to be understood that any number of application programs that generate pixel and/or graphics data may be executing concurrently on CPU 102. Operating system programs 132 (e.g., the Graphical Device Interface (GDI) component of the Microsoft Windows operating system) may also generate pixel and/or graphics data to be processed by graphics card 112.
Driver program 136 enables communication with graphics processing subsystem 112, including both rendering module 120 and scanout module 124. Driver program 136 advantageously implements one or more standard application program interfaces (APIs), such as Open GL, Microsoft DirectX, or D3D for communication with graphics processing subsystem 112; any number or combination of APIs may be supported, and in some implementations, separate driver programs 136 are provided to implement different APIs. By invoking appropriate API function calls, operating system programs 132 and/or application programs 134 are able to instruct driver program 136 to transfer geometry data or pixel data to graphics card 112 via system bus 106, to control operations of rendering module 120, to modify state parameters for scanout module 124 and so on. The specific commands and/or data transmitted to graphics card 112 by driver program 136 in response to an API function call may vary depending on the implementation of GPU 114, and driver program 136 may also transmit commands and/or data implementing additional functionality (e.g., special visual effects) not controlled by operating system programs 132 or application programs 134.
In some implementations, command buffer 128 queues the commands received via system bus 106 for execution by GPU 114. More specifically, driver program 136 may write one or more command streams to command buffer 128. A command stream may include rendering commands, data, and/or state commands, directed to rendering module 120 and/or scanout module 124. In some implementations, command buffer 128 may include logically or physically separate sections for commands directed to rendering module 120 and commands directed to display pipeline 124; in other implementations, the commands may be intermixed in command buffer 128 and directed to the appropriate pipeline by suitable control circuitry within GPU 114.
Command buffer 128 (or each section thereof) is advantageously implemented as a first in, first out buffer (FIFO) that is written by CPU 102 and read by GPU 114. Reading and writing can occur asynchronously. In one implementation, CPU 102 periodically writes new commands and data to command buffer 128 at a location determined by a “put” pointer, which CPU 102 increments after each write. Asynchronously, GPU 114 may continuously read and process commands and data sets previously stored in command buffer 128. GPU 114 maintains a “get” pointer to identify the read location in command buffer 128, and the get pointer is incremented after each read. Provided that CPU 102 stays sufficiently far ahead of GPU 114, GPU 114 is able to render images without incurring idle time waiting for CPU 102. In some implementations, depending on the size of the command buffer and the complexity of a scene, CPU 102 may write commands and data sets for frames several frames ahead of a frame being rendered by GPU 114. Command buffer 128 may be of fixed size (e.g., 5 megabytes) and may be written and read in a wraparound fashion (e.g., after writing to the last location, CPU 102 may reset the “put” pointer to the first location).
In some implementations, execution of rendering commands by rendering module 120 and operation of scanout module 124 need not occur sequentially. For example, where pixel buffer 126 is double buffered as mentioned previously, rendering module 120 can freely overwrite the back buffer while scanout module 124 reads from the front buffer. Thus, rendering module 120 may read and process commands as they are received. Flipping of the back and front buffers can be synchronized with the end of a scanout frame as is known in the art. For example, when rendering module 120 has completed a new image in the back buffer, operation of rendering module 120 may be paused until the end of scanout for the current frame, at which point the buffers may be flipped. Various techniques for implementing such synchronization features are known in the art, and a detailed description is omitted as not being critical to understanding the present invention.
The system described above is illustrative, and variations and modifications are possible. A GPU may be implemented using any suitable technologies, e.g., as one or more integrated circuit devices. The GPU may be mounted on an expansion card, mounted directly on a system motherboard, or integrated into a system chipset component (e.g., into the north bridge chip of one commonly used PC system architecture). The graphics processing subsystem may include any amount of dedicated graphics memory (some implementations may have no dedicated graphics memory) and may use system memory and dedicated graphics memory in any combination. In particular, the pixel buffer may be implemented in dedicated graphics memory or system memory as desired. The scanout circuitry may be integrated with a GPU or provided on a separate chip and may be implemented, e.g., using one or more ASICs, programmable processor elements, other integrated circuit technologies, or any combination thereof. In addition, GPUs embodying the present invention may be incorporated into a variety of devices, including general purpose computer systems, video game consoles and other special purpose computer systems, DVD players, handheld devices such as mobile phones or personal digital assistants, and so on.
While a modern GPU such as the one described above may efficiently process images with remarkable speed, there continues to be a demand for ever higher graphics performance. By using multiple GPUs to distribute processing load, overall performance may be significantly improved. However, implementation of a system employing multiple GPUs relates to significant challenges. Of particular concern is the coordination of the operations performed by various GPUs. The present invention provides innovative techniques related to the timing of GPU operations relevant in a multiple GPU system.
The present invention relates to method, apparatuses, and systems for processing an ordered sequence of images for display using a display device involving operating a plurality of graphics devices each capable of processing images by performing rendering operations to generate pixel data, including at least one first graphics device and at least one second graphics device, using the plurality of graphics devices to process the ordered sequence of images, wherein the at least one first graphics device processes certain ones of the ordered sequence of images, including a first image, and the at least one second graphics device processes certain other ones of the ordered sequence of images, including a second image, wherein the first image precedes the second image in the ordered sequence of images, delaying at least one operation of the at least one second graphics device to allow processing of the first image by the at least one first graphics device to advance relative to processing of the second image by the at least one second graphics device, in order to maintain sequentially correct output of the ordered sequence of images, and selectively providing output from the plurality of graphics devices to the display device, to display pixel data for the ordered sequence of images.
In one embodiment of the invention, the at least one operation is delayed while the at least one second graphics device awaits to receive a token from the at least one first graphics device. Specifically, the at least one second graphics device may be precluded from starting to output pixel data corresponding to the second image, until the at least one second graphics device receives the token from the at least one first graphics device. Each of the graphics devices may be a graphics processing unit (GPU). Further, the at least one first graphics device may be part of a first graphics device group comprising one or more graphics devices responsible for processing the first image, and the at least one second graphics device may be a part of a second graphics device group comprising one or more graphics devices responsible for processing the second image. Each of the first and second graphics device groups may be a GPU group
In another embodiment of the invention, the at least one first graphics device receives a first sequence of commands for processing images, the at least one second graphics device receives a second sequence of commands for processing images, and the at least one second graphics device synchronizes its execution of the second sequence of commands with the at least one first graphics device's execution of the first sequence of commands. The at least one second graphics device, upon receiving a command in the second sequence of commands, may delay execution of the second sequence of commands until an indication is provided that the at least one first graphics device has received a corresponding command in the first sequence of commands. The command in the second sequence of commands and the corresponding command in the first sequence of commands may each relate to a flip operation to alternate buffers for writing pixel data and reading pixel data. Further, the first and second sequences of commands may correspond to commands for outputting pixel data.
In yet another embodiment of the invention, the at least one first graphics device receives a first sequence of commands for processing images, the at least one second graphics device receives a second sequence of commands for processing images, and a software routine synchronizes the at least one second graphics device's execution of the second sequence of commands with the at least one first graphics device's execution of the first sequence of commands. The software routine, in response to the at least one second graphics device receiving a command in the second sequence of commands, may cause the at least one second graphics device to delay execution of the second sequence of commands until an indication is provided that the at least one first graphics device has received a corresponding command in the first sequence of commands. The software routine may employ at least one semaphore to implement synchronization, wherein the semaphore is released upon the at least one first graphics device's execution of the corresponding command in the first sequence of commands, and the semaphore must be acquired to allow the at least one second graphics device to continue executing the second sequence of commands. The command in the second sequence of commands and the corresponding command in the first sequence of commands may each relates to a flip operation to alternate buffers for writing pixel data and reading pixel data. Further, the first and second sequences of commands may correspond to commands for performing rendering operations to generate pixel data.
Appropriate circuitry may be implemented for selectively connecting the outputs of GPUs 220, 222, and 224 to display device 210, to facilitate the display of images 0 through 5. For example, an N-to-1 switch (not shown), e.g., N=3, may be built on graphics subsystem 202 to connect the outputs of GPU 220, 222, and 224 to display device 210. Alternatively, the GPUs may be arranged in a daisy-chain fashion (such as the configuration illustrated in
As shown in
In
In
According to the present embodiment of the invention, possession of the token represents the opportunity for a GPU to begin outputting a new image. By passing the token back and forth, GPU 0 and GPU 1 take alternate turns at advancing through their respective sequence of images, in lock step. Referring back to
Thus, each time a GPU is ready to output pixel data for a new image, the GPU determines whether it is in possession of the token. If it is in possession of the token, the GPU begins outputting pixel data for the new image and passes the token to the next GPU. Otherwise, the GPU waits until it receives the token, then begins outputting pixel data for the new image and passes the token to the next GPU. In a GPU that implements double buffering, this may effectively delay a “flip” of the front and back buffers. In some implementations, for example, when the rendering module has completed a new image in the back buffer, operation of rendering module may be paused until the end of scanout of a frame of the current image, at which point the buffers may be flipped. By delaying scanout of the current image, the rendering module can thus be paused, effectively delaying the “flip” that is about to occur in the GPU.
According to one embodiment of the invention, a GPU preferably stops outputting pixel data for its current image whenever it receives a token. Thus, with each passing of the token, not only does the GPU that passes the token begin outputting pixel data for a new image, the GPU that receives the token stops outputting pixel data for its current image. This technique can be utilized to ensure that only one GPU is outputting pixel data at any particular point in time, which may a desirable feature depending on the specific details of the implementation.
In one implementation, status of the token may also be utilized in selectively connecting each GPU to the display device. For example, the GPUs may be arranged in a daisy-chain configuration, such as the configuration illustrated in
According to the present embodiment of the invention, the token is implemented in hardware, by including a counter in each GPU. The counters in the GPUs uniformly maintain a count that is incremented through values that are assigned to the GPUs. For example, if there are three GPUs, the count may increment as 0, 1, 2, 0, 1, 2, . . . . Each GPU is assigned to one of the three values “0”, “1”, and “2.” Thus, a count of “0” by the counters indicates that GPU 0 has the token. A count of “1” by the counters indicates that GPU 1 has the token. A count of “2” by the counters indicates that GPU 2 has the token. Each GPU can thus determine the location of the token by referring to its own counter. This embodiment presents one particular manner of implementing a token. There may be different ways to implement the token, as is known in the art.
Thus, by preventing the present GPU from starting to output pixel data for a current image until it receives a token from another GPU, the other GPU's processing of images is allowed to advance relative to the present GPU's processing of images. This permits the relative timing of multiple GPUs to be controlled such that sequentially correct output of the ordered sequence of images can be maintained.
According to one embodiment of the invention, a GPU preferably stops outputting pixel data for its current image whenever it receives a token. Thus, with each passing of the token, not only does the GPU that passes the token begin outputting pixel data for a new image, the GPU that receives the token stops outputting pixel data for its current image. This technique can be utilized to ensure that only one GPU is outputting pixel data at any particular point in time, which may a desirable feature depending on the specific details of the implementation.
According to yet another embodiment of the invention, a token may be passed from one GPU group to another GPU group to control timing of graphics processing for an ordered sequence of images. Here, each GPU group refers to a collection of one or more GPUs. GPUs from a GPU group may jointly process a single image. For example, in a mode that may be referred to as “split frame rendering,” two or more GPUs may jointly process a single image by dividing the image into multiple portions. A first GPU may be responsible for processing one portion of the image (e.g., performing rendering operations and scanning out pixel data for that portion of the image), a second GPU may be responsible for processing another portion of the image, and so on. Details of techniques related to “split frame rendering” are discussed in related U.S. patent application Ser. No. 11/015,600, entitled “COHERENCE OF DISPLAYED IMAGES FOR SPLIT FRAME RENDERING IN A MULTI-PROCESSOR GRAPHICS SYSTEM,”, as well as related U.S. patent application Ser. No. 10/642,905, entitled “ADAPTIVE LOAD BALANCING IN A MULTI-PROCESSOR GRAPHICS PROCESSING SYSTEM,” both mentioned previously.
Thus, from an ordered sequence of images 0, 1, 2, 3, . . . , a first GPU group may jointly process image 0, then jointly process image 2, and so on, while a second GPU group may jointly process image 1, then jointly process image 3, and so on. A token may be used in a similar manner as discussed previously. However, instead of being passed from one GPU to another, the token is passed from one GPU group to another GPU group. For example, each time GPUs from a GPU group are ready to output pixel data for a new image, it is determined whether the GPU group is in possession of the token. If it is in possession of the token, the GPU group begins outputting pixel data for the new image and passes the token to the next GPU group. Otherwise, the GPU group waits until it receives the token, then begins outputting pixel data for the new image and passes the token to the next GPU group.
Referring to
Similarly, display command stream 604 for GPU 1 includes not only flip commands for images that GPU 1 is to process, but also dummy flip commands relating to images to be processed by GPU 0. For example, display command stream 604 includes the “F1” flip command 620. In addition, it also includes dummy flip 620, which corresponds to the “F0” flip command 610 in display command stream 602 for GPU 0. Thus, display command stream 604 may contain a dummy flip command for image 0, followed by a flip command for image 1, followed by a dummy flip command for image 2, followed by a flip command for image 3, and so on. Again, by including dummy flips such as 620, display command stream 604 provides the scanout module of GPU 1 with information regarding the order of other images relative to images 1, 3, . . . , which GPU 1 is to process.
Upon receiving a flip command in the display command stream, a GPU's rendering module may begin display operations related to a “flip,” such as reading pixel data for a new image from the front buffer. By contrast, upon receiving a dummy flip command, the rendering module may not perform normal display operations related to a “flip.” Instead, the rendering module receiving the dummy flip may enter a stall mode to wait for some indication that a corresponding real flip command has been executed by a rendering module in another GPU, in order to control timing of the GPU relative to that of the other GPU. For example, the scanout module for GPU 0, upon receiving the “F0” flip command 610 for image 0, may begin reading pixel data for image 0 from the front buffer. However, upon receiving dummy flip command 612 for image 1, the scanout module may stop executing further commands from display command stream 602, until an indication is provided that the corresponding “F1” real flip command for image 1 has been executed in GPU 1.
According to the present embodiment of the invention, this indication is provided by a special hardware signal that indicates whether all of the relevant GPUs have reached execution of their respective flip command, or dummy flip command, for a particular image. Effectively, this special hardware signal represents the output of an AND function, with each input controlled by one of the GPUs based on whether the GPU has reached the real flip command or dummy flip command for an image. For example, referring to
Accordingly, each GPU may then utilize its display command stream, which includes real flip commands and dummy flip commands, to identify the proper sequence of images to be displayed and control the timing of its scanout module with respect to the timing of other GPU(s). In other embodiments, commands used for providing image sequence information, such as dummy flip commands, may be provided in rendering command streams received and executed by each GPU. While
Referring to
Render command stream 704 for GPU 1 includes additional commands 740, followed by a flip command 742, followed by rendering commands 744 for image 1, followed by a flip command 746, followed by additional commands 748, followed by a flip command 750, followed by rendering commands 752 for image 3, followed by a flip command 754, and so on. The additional commands 740 and 748, labeled as “-----” in render command stream 704, may comprise rendering commands for images 0, 2, . . . , and so on. In one embodiment of the invention, these additional commands are ignored by the rendering module of GPU 1.
According to the present embodiment of the invention, software such as driver software executed on a CPU controls the timing of the operations of GPU 0 and GPU 1, such that GPU 0's processing of images 0, 2, . . . is kept in lock step with GPU 1's processing of images 1, 3, . . . , and vice versa. Specifically, each time a rendering module of a GPU encounters a flip command, such as those shown in
As shown in
For example, referring back to
Meanwhile, when GPU 0 encounters flip command 722, an interrupt is generated by GPU 0, and flip( ) is called to service the interrupt. Here, GPU 0's current image is also image 1, as indicated by FrameNumber[0]=1. GPU 0 is in the inactive state, as indicated by GPUState[0]=INACTIVE. This means GPU 0 is not responsible for processing the current image, image 1. Thus, flip( ) does not call any functions for GPU 0 to process image 1. Flip( ) simply releases the semaphore for image 1, making it free to acquired. When this occurs, the call to Semaphore.Acquire( ) mentioned above with respect to GPU 1 may acquire the semaphore for image 1 and allow GPU 1 to proceed with the processing of image 1. Thereafter, the state of GPU 0 is toggled to the active state in preparation for the next image. Finally, GPU 0's current image is incremented in preparation for the next image.
In this manner, flip command 742 may delay GPU 1's processing of image 1, until corresponding flip command 722 is encountered by GPU 0. Similarly, flip command 726 may delay GPU 0's processing of image 2, until corresponding flip command 746 is encountered by GPU 1. Also, flip command 750 may delay GPU 1's processing of image 3, until corresponding flip command 730 is encountered by GPU 0. This process thus keeps the operation of GPU 0 in lock step with the operation of GPU 1, and vice versa, by selectively delaying each GPU when necessary. Here, interrupt service routine “flip( )” may be halted while delaying the processing of a GPU. In such a case, the interrupt service routine may be allocated to a thread of a multi-threaded process executed in the CPU, so that the halting of the interrupt service routine does not create a blocking call that suspends other operations of the CPU. In certain implementations, however, allocating the interrupt service routine to another thread for this purpose may not be practicable. An alternative implementation is described below that does not require the use of such a separate thread of execution.
When a flip encountered by a GPU is in the “active” state, flip( ) determines whether the semaphore for the current image has been acquired. If so, GPU is taken out of stall mode, SemaphoreAcquiring[i] is set to FALSE in preparation for the next image, and GPU(i).Display(NewBuffer) is called to instruct the GPU to proceed with the processing of the current image. If not, SemaphoreAcquiring[i] is set to TRUE, and SemaphoreAquiringValue[i] is set to the current image, to indicate that the GPU is now attempting to acquire the semaphore for the current image.
When a flip encountered by a GPU is in the “inactive” state, flip( ) releases the semaphore for the current image by updating the variable “Semaphore” to the current image number, as represented by FrameNumber[i]. Then flip( ) determines whether the other GPU is attempting to acquire a semaphore and whether the other GPU is attempting to acquire a semaphore for the current image. If both conditions are true, this indicates that the other GPU is still attempting to acquire the semaphore that the present GPU is releasing. Thus, if both conditions are true, flip( ) performs operations that it was not able to perform previously for the other GPU when it was unable to acquire the semaphore for the current image. Namely, the other GPU is taken out of stall mode, SemaphoreAcquiring[i] is set to FALSE for the other GPU in preparation for the next image, and GPU(i).Display(NewBuffer) is called to instruct the other GPU to proceed with the processing of the current image.
Note that the “other” GPU is represented by the index “(1−i).” This is applicable to the two GPU case, such that if the current GPU is represented by GPU (i=0), the other GPU is represented by GPU(1−i), or GPU (1). Conversely, if the current GPU is represented by GUP (i=1), the other GPU is represented by GPU (1−i), or GPU (0). The code in
The flip( ) routine shown in
In a step 1006, a determination is made as to whether the GPU should continue to perform rendering and/or scanout operations, by taking into account input relating to the progress of other GPU(s). In one embodiment, this input takes the form of a token that is passed to the present GPU from another GPU, indicating that the present GPU may begin scanout operations for a new image. In another embodiment, this input takes the form of a hardware signal corresponding to a “dummy flip” received in the command stream(s) of the present GPU, indicating that other GPU(s) have reached a certain point in their processing of images. In yet another embodiment, the input takes the form of an acquired semaphore implemented in software that indicates other GPU(s) have reached a certain point in the processing of images, such that the current GPU may proceed with its operations.
If the determination in step 1006 produces a negative result, the process advances to step 1008, in which at least one operation of the GPU is delayed. For example, the operation that is delayed may include reading of a rendering command, execution of a rendering operation, reading of a scanout command, execution of a scanout operation, and/or other tasks performed by the GPU. By delaying an operation of the GPU, the overall timing of the GPU in its processing of success images may be shifted, so that other GPU(s) processing other images from the ordered sequence of images may be allowed to catch up with the timing of the present GPU. If the determination step 1006 produces a positive result, the process advances to step 1010, in which operations of the GPU such as rendering and/or scanout operations are continued. Thereafter, the process proceeds back to step 1004.
The representative steps in
While the present invention has been described in terms of specific embodiments, it should be apparent to those skilled in the art that the scope of the present invention is not limited to the described specific embodiments. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that additions, subtractions, substitutions, and other modifications may be made without departing from the broader spirit and scope of the invention as set forth in the claims.
Number | Name | Date | Kind |
---|---|---|---|
5742812 | Baylor et al. | Apr 1998 | A |
5790130 | Gannett | Aug 1998 | A |
5799204 | Pesto, Jr. | Aug 1998 | A |
5841444 | Mun et al. | Nov 1998 | A |
5889531 | Koike et al. | Mar 1999 | A |
6023281 | Grigor et al. | Feb 2000 | A |
6078339 | Meinerth et al. | Jun 2000 | A |
6157395 | Alcorn | Dec 2000 | A |
6191800 | Arenburg et al. | Feb 2001 | B1 |
6226717 | Reuter et al. | May 2001 | B1 |
6259461 | Brown | Jul 2001 | B1 |
6266072 | Koga et al. | Jul 2001 | B1 |
6317133 | Root et al. | Nov 2001 | B1 |
6362818 | Gardiner et al. | Mar 2002 | B1 |
6445391 | Sowizral et al. | Sep 2002 | B1 |
6469745 | Maida | Oct 2002 | B1 |
6473086 | Morein et al. | Oct 2002 | B1 |
6570571 | Morozumi | May 2003 | B1 |
6724390 | Dragony et al. | Apr 2004 | B1 |
6747654 | Laksono et al. | Jun 2004 | B1 |
6781590 | Katsura et al. | Aug 2004 | B2 |
6900813 | Stefanidis | May 2005 | B1 |
6965933 | Haartsen | Nov 2005 | B2 |
20020130870 | Ebihara | Sep 2002 | A1 |
20030128216 | Walls et al. | Jul 2003 | A1 |
20040075623 | Hartman | Apr 2004 | A1 |
20050012749 | Gonzalez | Jan 2005 | A1 |
20050088445 | Gonzalez | Apr 2005 | A1 |
Number | Date | Country |
---|---|---|
0571969 | May 2003 | EP |