The present disclosure is related to co-pending U.S. patent application Ser. No. 10/388,112, filed Mar. 12, 2003, and titled “Double-Buffering of Pixel Data using Copy-on-Write Semantics,” which is incorporated by reference in its entirety for all purposes.
This invention relates generally to generating graphical images, and more particularly, this invention relates to managing memory to use graphical images as input for effectuating graphics processing. As an example, a memory includes a render target and a copy of that render target for use as texture, whereby the copy is formed and updated in an efficient manner.
To hasten the generation and display of increasingly complex computer-generated imagery, conventional graphics processing techniques include recursively rendering and combining previously generated images, whereby a single, highly detailed graphic image is formed. An algorithm implementing such a technique is referred to as a multiple pass (“multipass”) algorithm. To illustrate, consider a graphical processor unit (“GPU”) executing instructions of a video game application, those instructions including a multipass algorithm. In this example, the multipass algorithm renders and then stores an image of a computer-generated scene. Next, the multipass algorithm uses the stored scene as an input to render the scene in combination with another graphical image, such as with one or more characters. Thereafter, the image of the scene with the characters is available as an input for further rendering, where each additional pass adds other like graphical images, such as weaponry, special effects (e.g., muzzle flashes), etc., to the scene.
Each of pixel pipelines 108 continues from shader 104 and extends to a render target 122 residing in graphics memory 120, which can be implemented as a frame buffer. Conventionally, render target 122 is an intermediary storage that is accessible as both as a target and a source of image data. That is, it is a target to which image data is written so computer-images can be displayed, and it is a source for providing a texture as input back into shader 104. By recursively writing to render target 122 and reading a texture from that render target, multiple passes can integrate complex visual effects into images of previous rendering passes.
But there are several drawbacks to the approach of using render target 122 as texture as input to further render graphical images. For example, synchronicity of multiple writes 130 to and reads 132 from render target 122 is computationally expensive, among other things, when managing those writes 130 and reads 132 in parallel, or during any overlapping interval of time. Since render target 122 is a shared resource (i.e., memory), writes 130 and reads 132 with respect to each pixel stored in render target 122 must be managed at a fine-grained level. That is, every memory location storing pixel data from each pipeline 108 is managed to prevent overlapping write and read operations from interfering with each other and corrupting the pixel data. Without properly ordering these operations, conflicting write and read operations would result in incorrect pixel data. And if GPU 102 implements multiple threads or an increased number of shaders 104, the amount of computations and/or hardware to synchronize the increased numbers of writes 130 and reads 132 becomes expensive. Further to this approach, latency is introduced into the multipass rendering of graphical images, especially when system 100 performs synchronization at fine-grained levels, such as when memory locations are “locked-out” (i.e., blocked against programming or otherwise altering). While any access to or from the render target is prohibited or locked-out, one or more pixel pipelines stall until such access is granted. This delays graphical image generation and thus hinders performance. These delays are relatively long because pixel pipelines 108 between render target 122 and 108 include numerous intermediary graphics subprocesses, such as depth testing, compositing, blending, etc.
In view of the foregoing, it would be desirable to provide an apparatus and a method for efficiently employing a render target as a texture. Ideally, an exemplary method would minimize or eliminate at least the above-described drawbacks.
An apparatus, system, method, and computer readable medium is disclosed for generating graphical images. In one embodiment, an exemplary method comprises detecting an update to data representing a portion of a render target, and forming a copy of the portion configured to be overwritten with data for a subsequent update to the portion of the render target, where data representing the portion is designated as texture. According to an alternative embodiment, this method further comprises designating the copy as texture rather than the portion.
In another embodiment of the present invention, an exemplary method for managing image data constituting a computer-generated image is provided. This method comprises establishing a first and a second tile association for each of a plurality of tiles, each of said first tile associations indicating which of two memory banks stores image data representing a portion of a render target, each of said second tile associations indicating which of said two memory banks stores image data representing a portion of texture, selecting one of the plurality of tiles for storing data representing a portion of an updated render target; and modifying a first tile association of said one of said plurality of tiles from one to another of the two memory banks.
The invention is more fully appreciated in connection with the following detailed description taken in conjunction with the accompanying drawings, in which:
Like reference numerals refer to corresponding parts throughout the several views of the drawings.
System 200 generally also can ameliorate latency inherent in schemes that share memory to implement a render target as texture. With render target 222 being a write-only memory, GPU 202 can render image data to render target 222 without invoking a “lock-out” for any write access when a read access of texture 224 is pending, unlike some structures using shared memory as both render target and texture. For these reasons, and those that follow, a graphical image generation process in accordance with the present invention enhances GPU performance by, for example, freeing up graphics processing that otherwise is dedicated to managing memory when a shared memory is used as both render target and texture. Although this discussion describes a system that operates in conjunction with GPU 202, one ordinarily skilled in the art should appreciate that any central processor unit (“CPU”)-based graphics generation device (single or multiple CPUs), as well as any other kinds of graphics generation devices, is within the scope and the spirit of the present invention.
Each of render target 222 and texture 224 can be implemented as a two-dimensional array of tiles, with each array having a number of “N” tiles. A tile represents a grouping of one or more units of image data, such as one or more pixels, texels (i.e., texture elements), or any other kind of data for generating graphical imagery. With other such tiles, the tiles either constitute a displayable computer-generated scene (e.g., on display monitor, such as a liquid crystal display) if in render target 222, or constitute a texture for further graphics processing if in texture 224. In operation, render target 222 is available for receiving image data from a source, such as GPU 202, when that data is rendered to graphics memory 220. So, render target 222 generally contains data representing graphical images as that data is generated. By contrast, once the image data from render target 222 is copied into texture 224, then that image data can be available as texture during discrete intervals of time.
As an example, consider that texture 224 is a copy of render target 222 formed, at least in part, when an application (not shown), such as a software program that generates graphical images, instructs the GPU 202, such as by way of a “snapshot” command, to use render target 222 as texture during a pass of a multipass algorithm. A snapshot command causes image data in render target 222 to copy 234 over into texture 224 to form a “snapshot” of the render target so that it can be used as texture. According to one embodiment, a “snapshot” operation designates image data of a render target (or a portion thereof) as image data that also can represent a texture (or a portion thereof). As a result, a unit of render target image can occupy the same memory location containing a unit of texture image data. Typically after a snapshot is performed, the texture remains as a previously rendered graphical image (until the next snapshot) while the render target is available for receiving image data that can be written (i.e., updated) in real or near real time.
Further, consider that a previous pass of a multipass algorithm renders a graphical image of a character (as in a video game) onto a graphical image of a scene, such as a wall, and stores the combined graphical image into render target 222. To render a special effect (e.g., lens flare, distortion, etc.) into that combined graphical image, GPU 202 performs a snapshot of render target 222 so that image data can be used as a texture. Specifically, GPU 202 copies 234 the contents of render target 222 into texture 224 in response to the snapshot command. Texture 224 provides an input as texture in discrete states until the next snapshot command again updates the image data of texture 224. Although a snapshot command can be implemented in a variety of ways and circumstances, a snapshot command can be coded into an application so that it is positioned for execution between one or more passes of a multipass algorithm. As a result, the render target is available as an updated texture for each pass of the algorithm.
According to the present invention, GPU 202 can perform snapshots on a coarse-grained level rather than at a fine-grained level, thus freeing up processing resources that otherwise would be devoted to managing the physical copying of a render target to texture on a pixel-by-pixel basis. According to an embodiment of the present invention, render target 222 is copied into texture 224 on a tile-by-tile basis (or a quad-by-quad basis), where a tile can include any number of pixels. As such, GPU 202 need only manage the copying of pixels as a collection rather than treating them as individuals. The computational overhead of copying of the tiles from render target 222 into texture 224 is further decreased by managing the copying of tiles by modifying pointers indicating whether a tile belongs to either render target 222 or texture 224, according to another embodiment of the present invention. Modifying pointers enable both the reading of texture from and the writing of image data to a tile by just changing the memory to which the pointers indicate. By editing bit vectors containing those pointers, there is less processing overhead necessary for copying select tiles of render target into texture in comparison with, for example, the “naïve,” or “blind,” copying of the entire render target into texture. Some exemplary embodiments employing pointer-based copying are described below.
According to a specific embodiment of the present invention, a snapshot of render target 222, as texture, includes image data that has been selected to be written into render target 222 before the assertion of the snapshot command. In particular, a pending write 230 that is in pipelines 208 when a specific snapshot has been asserted can be included in the snapshot. So, during such a snapshot, image data in pipelines 208 can be copied 234 at the same time as the image data residing in render target, or can be copied 234 either at any time thereafter. Consequently, if a surface (of a computer-generated 3-D object) is selected as both render target and texture, then writes 230 bound for render target 222 can also be copied 234 over into texture 224 as part of the snapshot.
First, the texture is incrementally formed when GPU 202 writes to one or more tiles of a render target. If these tiles have yet to been written to since first being rendered, then a copy of what is selected to be written into these tiles are instead written into another bank (rather than the bank presently containing the render target). Typically, these tiles would not be available immediately available as texture, but would be available after a snapshot. During such a snapshot, the tiles that were not written in the render target would not need to be copied as part of the texture, thus preserving computational resources. Second, a snapshot command designates tiles that were already incrementally copied (during subsequent writes to the render target) as texture after the snapshot is performed. Accordingly, texture relating to other tiles that were not part of the first phase will not need to be copied, again preserving computational resources.
At 404, a determination is made as to whether a rendering pass is pending during which at least one tile is selected to be written. If a rendering pass is not pending, flow 400 continues to 410. But when a rendering pass is pending, flow 400 continues to block 406. At 406, each tile that is selected to be written with data representing the render target is identified. Once identified, the image data that was to be written into each tile of the first bank is instead written (i.e., preliminarily copied) into a tile in a second bank at 408, so long as each of these tiles has yet to be written before a snapshot is performed at 410. By writing the render target of each tile to the second bank, the tile containing image data representing the original render target remains to be used as texture, if desired. An example of image data written into the second bank as a render target is image data 324b of
At 410, a determination is made as to whether a snapshot is pending. If not, then flow 400 continues back to 404. But if a snapshot is pending, then flow 400 continues to block 412. At 412, the tiles constituting the render target are then designated as texture, too. In some cases, this can be implemented by indicating to a GPU that tiles written to the second bank as image data for the render target are, after the snapshot, to be considered both texture and render target. An example of image data written into the second bank as both texture and render target is image data 324c of
System 500 also includes tile manager 504 coupled to GPU 502 and to graphics memory 520, which includes at least two banks (“Bank[0]”) 524 and (“Bank[1]”) 522. In operation, tile manager 504 governs which tiles of banks 524 and 522 will be rendered (i.e., written) as render target, and which tiles of banks 524 and 522 will be read as texture. Tile manager 504 contains logic and/or memory indicating, for each tile, where to locate both a memory location containing a render target, and another memory location containing a texture, if in a different location than the render target. In managing tile-by-tile writing and reading, tile manager includes memory, such as bit vectors, for bookkeeping purposes. Tile manager 504 uses these bit vectors to determine for each tile in which bank a render target and a texture resides. Tile manager 504 can also contain logic (as software, hardware, or a combination thereof) to initialize the bit vectors for implementing an incremental render target copy, as well as logic for performing a snapshot operation. The communication among GPU 502, tile manager 504 and graphics memory 520 (as well as other elements of
Each of render target 222 and texture 224 of
Graphics memory 520 need not be limited to two banks, but rather can include any number of banks for implementing a render target as a texture, according to the present invention. In some embodiments, graphics memory 520 can be a frame buffer. In some instances, bank 522 is configured as a front buffer, and bank 524 is configured as a back buffer, both of which constitute a double-buffer implementation of memory. In some embodiments, application 508 can be composed of instructions in OpenGL®, where an exemplary command for implementing a snapshot is “glCopyPixels,” according to a specific embodiment.
According to at least one embodiment, tile manager 504 implements an addressing scheme for managing memory storing image data as render target or texture. In an exemplary addressing scheme, any tile, “t,” can be identified by:
t=Tile([b],[i]), Equation 1
where “b” represents the bank in which the tile resides, and “i” is the specific position. For example, a tile identified as Tile ([1],[456]) indicates that the 456th tile in bank (“Bank[1]”) 522 will either be written as a render target or read as a texture. The bank to which “b” points depends on whether a texture read of a render target write is pending in relation to that tile i. An exemplary method for determining which bank is accessed is discussed next.
Tile manager 504 of
T[i]=(P[i],[i]), Equation 2
where “T” is the texture for tile “i.” The bank in which the tile resides is determined from the polarity bit, P[i], of bit vector 602. For example, consider that a GPU requests the texture for the 3rd tile, where bit 3 of P 602 is “1.” The expression P[i],[i], yields T[i]=(1,3) and thus, the tile manager will access bank one, tile 3 to obtain the requested texture. Optionally, tile manager 600 can predetermined and store these values in a texture bit vector (“T”) 616, where each bit represents the results obtained by Equation 2.
Once a GPU instructs tile manager 504 to use a render target as texture, tile manager 504 initializes its bookkeeping bit vectors. As shown in
When rendering to a render target, the bank to which the GPU writes depends, at least in part, on whether the one or more target memory locations have or have not been written since the last snapshot. First, consider that the target has yet to be written. When the GPU instructs tile manager 504 to write a render target into a particular tile i, logic 605 of tile manager 504 does so by writing (i.e., copying) image data from the present render target (i.e., the present bank) into the render target in the bank defined by the expression “˜P[i]^D[i],” so long as the dirty bit for this tile has a value of zero. Because the dirty bit indicates whether a specific tile has been previously written, a value of zero specifies that the tile has not been written with updated image data as a render target, whereas a value of one means that the tile has already been subject to a render target write during an interval when no snapshot has occurred.
Second, consider when a render target write operation is pending after a previous write to the subject tile before performance of a snapshot operation. In this case, GPU 502 instructs tile manager 504 to select the bank to which image data will be written as a render target for a specific tile i. In response, tile manager 504 applies the following expression 614 to determine where to write the render target:
R[i]=(P[i]^D[i],[i]), Equation 3
Where “R” is the render target for tile “i.” The bank in which the tile resides is determined from the polarity bit, P[i], of bit vector 602 XOR'ed with the corresponding dirty bit, D[i], of bit vector 604, where the symbol “^” indicates an exclusive-OR logical operation. For example, consider that a GPU requests to write image data into render target at the 19th tile, where bit 19 of P 602 is “1” and bit 19 of D 604 is “1.” The expression P[i]^D[i], [i] yields R[i]=(0,19), and hence, the tile manager will write the render target access to tile 19 of bank zero. Optionally, tile manager 600 can predetermine and store these values in a render target bit vector (“R”) 620, where each bit represents the results obtained by Equation 3. Lastly, the significance of the functionalities performed by tile manager 600, such as performed by logic 618, is discussed further in connection with
At 702 of
At 704, tile manager 504 of
Further to the example,
Next, flow 700 continues to 716. If tile manager 504 determines that the render target is no longer needed as texture (e.g., a multipass algorithm has terminated), then flow 700 ends at 718. But if the render target still is used as texture, then flow 700 returns to 704. Further to the example of the two banks of four tiles, consider that a rendering pass is identified as pending (or has been requested) at 704. This means that at least one tile of the render target is selected to be written, and as such, flow 700 moves to 706. At 706, tile manager 504 identifies each tile i to be written.
But note that after the dirty bit associated with a tile has been set to 1 (because that tile has been written with data representing an updated render target), then the next time that same tile is subsequently identified as a tile to again be written (without any intervening snapshot operation), the tile will not be again copied. Rather, at 708, the tile receiving the copy of the original tile will be the subsequent target for writing image data. For example, consider that
At 710, consider that GPU 502 requests another snapshot. Again, tile manager 504 can modify the one or more bits (e.g., operating as pointers) of the polarity and dirty bit vectors as determined by logic 603 and 608 of
Next, at 704, consider that GPU 502 selects tiles [1] and [2] of bank 1 to write as render target image data. Tile manger 504 identifies those tiles at 704 and copies them from Bank 1 to Bank 0 at 708, as determined by logic 618 of
The various methods of using a render target for use as texture, as described above, can be governed by software processes, and thereby can be implemented as part of an algorithm (e.g., a multipass algorithm) governing the access of tiles (e.g., by managing access to memory locations) containing data representing either texture or a render target, or both.
An embodiment of the present invention relates to a computer storage product with a computer-readable medium having computer code thereon for performing various computer-implemented operations. The media and computer code may be those specially designed and constructed for the purposes of the present invention, or they may be of the kind well known and available to those having skill in the computer software arts. Examples of computer-readable media include, but are not limited to: magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROMs and holographic devices; magneto-optical media such as floptical disks; and hardware devices that are specially configured to store and execute program code, such as application-specific integrated circuits (“ASICs”), programmable logic devices (“PLDs”) and ROM and RAM devices. Examples of computer code include machine code, such as produced by a compiler, and files containing higher-level code that are executed by a computer using an interpreter. For example, an embodiment of the invention may be implemented using Java, C++, or other object-oriented programming language and development tools. Another embodiment of the invention may be implemented in hardwired circuitry in place of, or in combination with, machine-executable software instructions.
The foregoing description, for purposes of explanation, used specific nomenclature to provide a thorough understanding of the invention. However, it will be apparent to one skilled in the art that specific details are not required in order to practice the invention. Thus, the foregoing descriptions of specific embodiments of the invention are presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed; obviously, many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, they thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is intended that the following claims and their equivalents define the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
6201547 | Rogers et al. | Mar 2001 | B1 |
6883074 | Lee et al. | Apr 2005 | B2 |
6911983 | Sabella et al. | Jun 2005 | B2 |
7034841 | Weiblen et al. | Apr 2006 | B1 |
7091979 | Donovan | Aug 2006 | B1 |
7328316 | Moir et al. | Feb 2008 | B2 |
20040179019 | Sabella et al. | Sep 2004 | A1 |