The present invention relates to graphics processing, and more particularly to processing graphics attributes utilizing a pixel shader.
Typical graphics processors are equipped various “shaders” for determining surface properties of different graphics data. For example, vertex shaders are typically provided for determining the surface properties of a vertex. Still yet, pixel shaders are traditionally included downstream with respect to the vertex shaders as well as others) for determining the surface properties of a pixel or portion thereof (e.g. fragment, etc.).
Traditionally, the shaders upstream from the pixel shader are capable of outputting more graphics attributes than the pixel shader is capable of using. To this end, the amount of graphics attributes that are typically sent to pixel shaders, from upstream shaders, is often excessive and results in the transmission, storage, etc. of unused graphics data. Unfortunately, this, in turn, results in less than optimal storage use, an increase in unnecessary computation, overly complex hardware logic at the pixel shader, etc.
There is thus a need for overcoming these and/or other problems associated with the prior art.
A system, method, and computer program product are provided for packing graphics attributes. In use, a plurality of graphics attributes is identified. Such graphics attributes are packed, such that the packed graphics attributes are capable of being processed utilizing a pixel shader.
Yet another system, method, and computer program product are provided for providing a reorder table. Included is a data structure embodied on a computer readable medium. Such data structure includes a reorder table in communication with a first shader and a second shader. In use, the reorder table is adapted for being used to map an output of the first shader to an input of the second shader.
Still yet another system, method, and computer program product are provided for packing graphics attributes. A subset of a plurality of graphics attributes is first identified. Thus, the subset of graphics attributes may be processed utilizing a pixel shader.
Still yet, the graphics attributes may be identified in any desired manner, using any desired logic, method, etc. Just by way of example, in various embodiments, the graphics attributes that are stored in a buffer and used as input or output from a shader may be identified by examining the input or output from another shader. Such other shader may include a vertex shader, a geometry shader, a tessellation shader, and/or any other component of a graphics pipeline, for that matter.
in operation 104, the graphics attributes are packed. In one embodiment, this can optionally be done as the attributes are stored into a temporary buffer, for example. As will soon become apparent during reference to subsequent figures, additional processing may optionally be carried out on the graphics attributes, prior to the packing of operation 104. To this end, the packed graphics attributes may be processed utilizing the pixel shader. See operation 106. Such pixel shader processing may refer to any determination of surface properties of a pixel or portion thereof (e.g. fragment, etc), and/or any other processing capable of being performed by the pixel shader.
More illustrative information will now be set forth regarding various optional architectures and features with which the foregoing framework may or may not be implemented, per the desires of the user. It should be strongly noted that the following information is set forth for illustrative purposes and should not be construed as limiting in any manner. Any of the following features may be optionally incorporated with or without the exclusion of other features described.
As shown in
Next, in operation 154, the subset of graphics attributes are rearranged in various ways to optimize receipt and/or processing by a subsequent pixel shader. It should be noted that the aforementioned rearrangement may involve any techniques that result in the graphics attributes being arranged differently than that in which they were received. To this end, the following examples of rearrangement are set forth for illustrative purposes only.
Just by way of example, as indicated in operation 154A, the graphics attributes may be separated into a plurality of groups. Specifically, in one embodiment, the groups may include a first group including interpolated attributes, and a second group including non-interpolated (e.g. constant, etc.) attributes. By separating the graphics attributes in such manner, interpolated attributes and non-interpolated attributes may be arranged to provide economies in the hardware. For example, since plane equations are needed for interpolating the non-constant attributes, and not needed for constant attributes, separating the attributes into constant and non-constant sets makes the storage and address computation of the attributes easier to do in hardware and/or with pixel shader instructions. By separating the graphics attributes in the foregoing manner, an identification of non-constant attributes is inherently simplified, since the shader program would simply need to select, graphics attributes from the first group of interpolated attributes. This may, in some embodiments, optionally optimize storage, reduce unnecessary computation, accommodate or possibly allow a reduction of hardware logic, etc.
Still yet, the rearrangement of the graphics attributes of operation 154 may further involve the identification of a plurality of the graphics attributes having overwrite capabilities. Such overwrite capabilities may involve any ability to overwrite other graphics attributes. To this end, such graphics attributes having overwrite capabilities may be moved before other graphics attributes. See operation 154B. By forcing such overwriting graphics attributes before others in an attribute stream, the hardware design is simplified, because the overwriting attributes can be saved in a temporary buffer until the overwritten attributes arrive, and then the overwriting attributes can take the place of the overwritten attributes, if the overwritten attributes were to come prior to the overwriting attributes, in some embodiments, the overwriting could not necessarily take place easily, since the overwritten attributes have already been passed along in the graphics pipeline.
Even still, in operation 154C, coordinates (e.g. x, y, z, w, s, t, etc.) may be moved ahead of other graphics attributes. In some embodiments, pixel shader processing may almost always require use of such coordinates. Thus, by moving them ahead in the graphics attributes stream, they may be addressed ahead of others, in order to simplify various types of processing, such as clipping, which involved the interpolation of attributes. Specifically, if vertex coordinates are received before attributes, clipping parameters can be computed before the attributes are processed, which means the clipping attributes are available when the attributes arrive.
Next, in operation 156, the graphics attributes may then be packed. Such packing may be similar to that set forth in operation 106 of
As shown, the system 200 includes a plurality of shaders including a first shader 202, a second shader 209, a pixel shader 213, as well as a stream output 219 for feeding vertex data to a frame buffer (not shown). It should be noted that the first and second shaders 202, 209 may include a vertex shader, a geometry shader, a tessellation shader, and/or any other shader, for that matter. Further, while not shown, various other components may also feed or be fed by the pixel shader 213.
Further included is a plurality of reorder tables 206, 212, and 217 which provide an interface between their respective shaders, components, etc. In use, the reorder tables 206, 212, and/or 217 may be adapted for being used to map an output of a first shader to an input of a second shader. For example, in some embodiments, such mapping may be used to allow an input of one shader (in a first sequential position amongst a plurality of graphics attributes) to be mapped (e.g. translated, correlated, etc.) to an output of another shader (in a second, different sequential position amongst a plurality of graphics attributes).
Table 1 illustrates one generic exemplary mapping.
In the context of the shaders shown in
As a further option, any of the reorder tables 206, 212, and/or 217 may include at least one default value (e.g. “0,” “1,” etc.) capable of being received by the input of one of the shaders in communication therewith. To this end, such default value may be read, as desired. In the context of graphics processing, it may sometimes be beneficial for obtaining such values, particularly to accommodate some graphics application program interfaces (APIs). For example, such default values may be used, in some embodiments, to accommodate calculations involving “w” coordinate values. Thus, by equipping the reorder tables 206, 212, and/or 217 with such value(s), they may be made more accessible to the associated shader.
Still yet, as shown, the number of inputs/outputs of each shader may vary, per the desires of the user. See, for example, the second shader 209 having an input 208 including a fraction of the number of outputs 210 thereof. Of course, any number of inputs/outputs may be employed. To accommodate such possible input/output disparity among shaders, the size of the reorder tables 206, 212, and/or 217 may also be tailored to accommodate an associated input/output with the most attributes, and also, the number of reorder table entries being used at a given time may also be a variable value loaded at the same time the reorder table is loaded. See, for example, reorder table 212 which accommodates the larger output 210 of the second shader 209. In one exemplary embodiment, one or more of the reorder tables (e.g. reorder table 212) may include a large number (e.g. 128, 129, or more) graphics attributes. An exemplary extended set of graphics attributes will be set forth during reference to
During use, in addition to the aforementioned mapping, the reorder tables 206, 212, and/or 217 may also allow desired graphics attributes to be rearranged and/or packed in accordance with the methods 100 and 150 of
In a single-instruction multiple-data (SIMID) embodiment, multiple parallel processing threads may be operating on multiple pieces of data. When operating on multiple pieces of data corresponding to pixels, the parallel nature of such processing is complementary to such data, since pixels are positioned in a parallel manner on screen. However, when operating on multiple pieces of data corresponding to a vertex, such data is typically input in a sequential manner, which is not complimentary like pixel data. Thus, as an option, multiple pieces of data may be grouped and processed in “lock step,” for allowing “corner turning” which allows writing of rows and reading of columns when such data is read for processing purposes.
As shown, a geometry shader output 302 (e.g. see, for example, the output 210 of
Situated between the geometry shader output 302 and the pixel shader input 306 is a reorder table 309 (e.g. see, for example, reorder table 212 of
Further included in association with the reorder table 309 is a plurality of flags 313 associated with each of the coordinates x, y, z, and w. Such flags 313 may be used to indicate which, if any, of the coordinates are to be fed to the pixel shader input 306. For example, associated logic 317 may feed the associated coordinate if the flag, is “TRUE” and not feed the associated coordinate if the flag is “FALSE.” Of course, while not shown, additional flags with similar functionality may be provided in association with texture coordinates (or any other graphics attributes, for that matter) for selectively inputting the same to the pixel shader. By this technique, only a minimal number of graphics attributes (which are required) are received by the associated pixel shader.
As shown, in addition to the graphics attributes mentioned hereinabove, the graphics attributes may further include front color attributes 315 and back color attributes 316, as well as the others shown in
Further, with continuing reference to
It should be again noted that the above rearrangement, packing, etc. is set forth for illustrative purposes only. Any rearrangement, packing, etc is contemplated to fall within the scope of the present technology. For instance, Table 2 illustrates an exemplary order of graphics attributes that may be used to rearrange, pack, etc. the graphics attributes in preparation for pixel shader processing.
While not shown, similar techniques may be employed to feed other components of a graphics pipeline. Just by way of example, the foregoing functionality may be employed to feed a data stream which, in turn, may feed a frame buffer, etc. Of course, graphics attributes in a reorder table may be used by more than one graphics pipeline component (e.g. a pixel shader and a data stream, etc.), such that some of the graphics attributes are used by one component or the other, or both.
As shown, a plurality of programs is provided including, but not necessarily limited to a vertex program 402, a geometry program 406, and a pixel program 412. Each of such programs is associated with a corresponding shader which is capable of executing the same.
To facilitate such execution, each of the programs is compiled via operations 404, 408, and 414, respectively, carried out by a compiler. Resulting from such compilation is object code including, but not limited to vertex object code 407, geometry object code 410, and pixel object code 416. Still yet, each set of object code includes a data structure 417 associated with the object code compiled from the shader programs. For reasons that will soon become apparent, such data structure 4117 may be monitored by a driver 418, and includes a state of the object code.
Specifically, each of such sets of object code selects their own input. Sometimes, however, a set of object code may select an input at location A, which correlates with the output of another set of object code at location B. Further, in use, each set of object code has its own “domain” with corresponding input and output locations, which change temporally. To accommodate this, each set of object code may be “bound,” where such binding is reflected in the data structure 417, to ensure that the appropriate data may be received from the desired shader(s).
Thus, the driver 418 may use the data structure 417 associated with each of the sets of object code for generating and updating one or more reorder tables 420 to reflect the aforementioned temporal changes during operation. Further, as an option, the driver 418 may generate such reorder table 420 during runtime.
As shown, a computer system 500 is provided including at least one central processor 501 which is connected to a communication bus 501. The computer system 500 also includes a main memory 504. Control logic (software) and data are stored in the main memory 504 which may take the form of random access memory (RAM).
The computer system 500 also includes a graphics processor 506 and a display 508, i.e. a computer monitor. In one embodiment, the graphics processor 506 may include shader modules, a rasterization module, etc. Each of the foregoing modules may even be situated on a single semiconductor platform to form a graphics processing unit (GPU).
In the present description, a single semiconductor platform may refer to a sole unitary semiconductor-based integrated circuit or chip. It should be noted that the term single semiconductor platform may also refer to multi-chip modules with increased connectivity which simulate on-chip operation, and make substantial improvements over utilizing a conventional central processing unit (CPU) and bus implementation. Of course, the various modules may also be situated separately or in various combinations of semiconductor platforms per the desires of the user.
The computer system 500 may also include a secondary storage 510. The secondary storage 510 includes, for example, a hard disk drive and/or a removable storage drive, representing a floppy disk drive, a magnetic tape drive, a compact disk drive, etc. The removable storage drive reads from and/or writes to a removable storage unit in a well known manner.
Computer programs, or computer control logic algorithms, may be stored in the main memory 504 and/or the secondary storage 510. Such computer programs, when executed, enable the computer system 500 to perform various functions. Memory 504, storage 510 and/or any other storage are possible examples of computer-readable media.
In one embodiment, the architecture and/or functionality set forth during the description of the foregoing figures may be implemented in the context of the central processor 501, graphics processor 506, a chipset (i.e. a group of integrated circuits designed to work and sold as a unit for performing related functions, etc.), and/or any other integrated circuit(s) for that matter.
Still yet, the architecture and/or functionality of the foregoing figures may be implemented in the context of a general computer system, a circuit board system, a game console system dedicated for entertainment purposes, an application-specific system, and/or any other desired system.
While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. For example, any of the network elements may employ any of the desired functionality set forth hereinabove. Thus, the breadth and scope of a preferred embodiment should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
Number | Name | Date | Kind |
---|---|---|---|
5949428 | Toelle et al. | Sep 1999 | A |
6342888 | Lindholm et al. | Jan 2002 | B1 |
6532009 | Fox et al. | Mar 2003 | B1 |
6629188 | Minkin et al. | Sep 2003 | B1 |
6636223 | Morein | Oct 2003 | B1 |
6661421 | Schlapp | Dec 2003 | B1 |
6664963 | Zatz | Dec 2003 | B1 |
6760019 | Graham | Jul 2004 | B1 |
6947047 | Moy et al. | Sep 2005 | B1 |
7202872 | Paltashev et al. | Apr 2007 | B2 |
7450132 | Park et al. | Nov 2008 | B2 |
7809250 | Seo et al. | Oct 2010 | B2 |
20020024522 | Schimpf et al. | Feb 2002 | A1 |
20020033817 | Boyd et al. | Mar 2002 | A1 |
20030142105 | Lavelle et al. | Jul 2003 | A1 |
20030169255 | Lavelle et al. | Sep 2003 | A1 |
20040012598 | Zatz | Jan 2004 | A1 |
20040012602 | Mech | Jan 2004 | A1 |
20040221071 | Baker et al. | Nov 2004 | A1 |
20040240755 | Wong et al. | Dec 2004 | A1 |
20050027564 | Yantis | Feb 2005 | A1 |
20050093873 | Paltashev et al. | May 2005 | A1 |
20050122334 | Boyd et al. | Jun 2005 | A1 |
20050190183 | Barone et al. | Sep 2005 | A1 |
20050243094 | Patel et al. | Nov 2005 | A1 |
20060098018 | Tarditi et al. | May 2006 | A1 |
20060098019 | Tarditi, et al. | May 2006 | A1 |
20070002070 | Hoppe et al. | Jan 2007 | A1 |
20070030278 | Prokopenko et al. | Feb 2007 | A1 |
20070146197 | Wimmer | Jun 2007 | A1 |
20080049031 | Liao et al. | Feb 2008 | A1 |