This application claims the benefit of China Patent Application No. 201510521991.2, filed on Aug. 24, 2015, the entirety of which is incorporated by reference herein.
Technical Field
The present invention relates to graphics processing, and in particular, it relates to methods for combining instructions and apparatuses having multiple data pipes.
Description of the Related Art
The GPU (Graphics Processing Unit) architecture typically has hundreds of basic shader processing units, referred to as SPs (Stream Processors). Each SP may deal with one SIMD (Single Instruction Multiple Data) thread of one instruction per cycle, and then switch into another SIMD thread at the next cycle. The performance of GPU is affected by two important factors: the total amount of SPs and the capacities of one SP. Thus, methods for combining instructions and apparatuses having multiple data pipes are introduced to improve the capacities of one SP.
An embodiment of a method for combining instructions, performed by a compiler, contains at least the following steps. First instructions are obtained, where each performs one of a calculation operation, a comparison operation, a logic operation, a selection operation, a branching operation, a LD/ST (Load/Store) operation, a SMP (sampling) operation and a complicated mathematics operation. The first instructions are combined as one combined instruction according to data dependencies between the first instructions. The combined instruction is sent to a SP (Stream Processor).
An embodiment of an apparatus having multiple data pipes is introduced, contains at least a DF (Data Fetch) unit, a bypass-pipe and a main-pipe. The bypass-pipe is coupled to a CR (Common Register), a CB (Constant Buffer) and the DF unit. The main-pipe, coupled to the DF unit and the bypass-pipe, comprises an ALG (Algorithm) unit, a comparison/logic unit and a post-PROC (Process) unit. The ALG, comparison/logic and post-PROC units are coupled in series and each of the ALG, comparison/logic and post-PROC units is coupled to the bypass-pipe.
A detailed description is given in the following embodiments with reference to the accompanying drawings.
The present invention can be fully understood by reading the subsequent detailed description and examples with references made to the accompanying drawings, wherein:
The following description is of the best-contemplated mode of carrying out the invention. This description is made for the purpose of illustrating the general principles of the invention and should not be taken in a limiting sense. The scope of the invention is best determined by reference to the appended claims.
The present invention will be described with respect to particular embodiments and with reference to certain drawings, but the invention is not limited thereto and is only limited by the claims. It will be further understood that the terms “comprises,” “comprising,” “includes” and/or “including,” when used herein, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
Use of ordinal terms such as “first”, “second”, “third”, etc., in the claims to modify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed, but are used merely as labels to distinguish one claim element having a certain name from another element having the same name (but for use of the ordinal term) to distinguish the claim elements.
The conventional SP (Stream Processor) executes simple operations, such as Algorithm, Compare, Logic, Selection, Branch etc. But a lot of data dependencies exist among adjacent instructions in one shader, so the SP has to read or write CR (common registers) frequently. The data dependencies may consume the CR bandwidth greatly and produce bottlenecks. In addition, the CR RAW (Read after write) issue may arise, decreasing the performance of the instruction execution. Shaders often use move instructions to initialize CRs, which requires the SP to pass data or constants from one CR or CB (Constant Buffer) to another. For a post-processing operation, such as an LD/ST (load/store) unit for data access, an SMP (sampling) unit for texture sampling, an SFU (Special Function unit), etc., the SP is responsible for reading one or more source values from CRs or CBs, and then passing them on to corresponding post-processing units. In such cases, it is not necessary to walk data or constants through algorithm execution, leading to wasting a certain level of SP capacity. A novel architecture with two data paths in one SP is introduced to improve SP performance. The first path may be referred to as a main-pipe with Algorithm, Compare, Logic, Selection and Branch operations, while the second path may be referred to as a bypass-pipe for a data- or constant-reading from one CR or CB and a passing to another CR or one post-processing unit.
Instructions used in the compiler may be classified into three kinds: main-pipe; bypass-pipe; and post-process-unit. The main-pipe instructions are used in the ALG, Post-LGC and Post-PROC stages. The ALG stage may use the following ALG instructions: FMAD, FADD, FMUL, IMUL24, IMUL16, IADD, SHL, SHR, FRC, FMOV, IMUL32I, IMUL24I, IADDI, IMAXI, IMINI, SHLI, SHRI, etc. The Post-LGC stage may use CMP/LGC (Comparison/Logic) instructions, such as IMAX, IMIN, FCMP, ICMP, IMAXI, IMINI, NOR, AND, OR, XOR, ICMPI, NORI, ANDI, ORI, XORI, etc. The Post-PROC stage may use SEL/Branch instruction, such as SEL, B, BL, IFANY, IFALL, etc. The post-processing-unit instructions are used in the LD/ST unit 171, the SMP unit 173 and SFU 175. The LD/ST unit 171 may perform the loading and storing instructions, such as LDU, STU, REDU, LDT, STT, REDUT, GLD, GST, GREDU, etc. The SMP unit 173 may perform the texture sampling instructions, such as SAMPLE, SAMPLE_B, SAMPLE_L, SAMPLE_C, SAMPLE_D, SAMPLE_GTH, SAMPLE_FTH, etc. The SFU 175 may perform the mathematics computation instructions, such as RCP, RSQ, LOG, EXP, SIN, COS, SQRT, etc. The bypass-pipe instructions may contain moving instructions, such as MOV, MOVIMM, etc.
With the above architecture, the compiler may combine several main-pipe instructions and the post-processing-unit instructions as one according to the data dependencies between the instructions, referred to as the static combination.
ALG+CMP+SEL;
ALG+CMP+SEL+SFU/LS/SMP;
ALG+CMP+Branch;
ALG+LGC+SEL;
ALG+LGC+SEL+SFU/LS/SMP; or
ALG+LGC+Branch.
ALG indicates calculation instructions, CMP indicates comparison instructions, LGC indicates logic instructions, SEL indicates selection instructions, Branch indicates branching instructions, SFU indicates mathematics computation instructions, LS indicates Load/Store instructions and SMP indicates sampling instructions. An example is introduced to explain the static combination, where exemplary pseudo code is as follows:
The compiler performs the static combination to the pseudo code and translates it into the following machine code:
First machine code instructs to add the value of CR R8 to the value of CR R4 (that is, the values of variables b and a), and send the result to the next stage, in which “SFWD” indicates a passing of the result (that is, the value of variable x) to the next stage. Second machine code instructs to compare the value of CR R5 (that is, the value of variable c) with the value received from the prior stage (that is, the value of variable x), in which “+” indicates that this instruction is combined with the previous one and “SFWD” indicates a reception of the result from the prior stage. Third machine code instructs to write the value received from the prior stage (that is, the value of variable x) or the value of CR R5 (that is, the value of variable c) into the CR R according to the flag P1, in which “+” indicates that this instruction is combined with the previous one. If the flag P1 is “1”, the value of CR R5 (that is, the value of variable c) is written into the CR R0. Otherwise, the value received from the prior stage (that is, the value of variable x) is written into the CR R0.
The computation units of the architecture may be modified to enable the GPU to execute the combined instructions.
With the above architecture, the compiler may combine the bypass-pipe instruction and the main-pipe instructions and/or the post-processing-unit instructions as one, referred to as the bypassed combination.
First machine code instructs to store the value of CR R4 in the CR R0. Second machine code instructs to add the value of CR R4 to the value of CR R8, and send the result to the next stage, in which “+” indicates that this instruction is combined with the previous one and “SFWD” indicates a passing of the result to the next stage. Third machine code instructs to obtain a reciprocal of the value received from the prior stage and stores the reciprocal in the CR R7, in which “SFWD” indicates a reception of the result from the prior stage.
Refer to
Although the embodiments have been described in
While the invention has been described by way of example and in terms of the preferred embodiments, it is to be understood that the invention is not limited to the disclosed embodiments. On the contrary, it is intended to cover various modifications and similar arrangements (as would be apparent to those skilled in the art). Therefore, the scope of the appended claims should be accorded the broadest interpretation so as to encompass all such modifications and similar arrangements.
Number | Date | Country | Kind |
---|---|---|---|
2015 1 0521991 | Aug 2015 | CN | national |
Number | Name | Date | Kind |
---|---|---|---|
6237086 | Koppala et al. | May 2001 | B1 |
7937561 | Col et al. | May 2011 | B2 |
8055883 | Lutz | Nov 2011 | B2 |
9053292 | Abdallah | Jun 2015 | B2 |
9639336 | Grover | May 2017 | B2 |
20040193821 | Ruhovets et al. | Sep 2004 | A1 |
20060271738 | Tran et al. | Nov 2006 | A1 |
20070198815 | Liu et al. | Aug 2007 | A1 |
20090013108 | Rajamani | Jan 2009 | A1 |
20110004743 | Lutz | Jan 2011 | A1 |
20130117548 | Grover | May 2013 | A1 |
20140237458 | Elias | Aug 2014 | A1 |
20140281397 | Loktyukhin et al. | Sep 2014 | A1 |
20140372733 | Diewald | Dec 2014 | A1 |
20150186168 | Jennings | Jul 2015 | A1 |
20150186169 | Jennings | Jul 2015 | A1 |
20150186170 | Jennings | Jul 2015 | A1 |
20150205757 | Dally | Jul 2015 | A1 |
20150347105 | Avkarogullari | Dec 2015 | A1 |
20160092181 | Rodgers | Mar 2016 | A1 |
20160139900 | Pudiyapura | May 2016 | A1 |
20160139934 | Sarangi | May 2016 | A1 |
20160179524 | Gschwind | Jun 2016 | A1 |
20160328236 | Kamatsuka | Nov 2016 | A1 |
20160357586 | Rose | Dec 2016 | A1 |
20170039043 | Haupt | Feb 2017 | A1 |
20170269929 | Hegarty | Sep 2017 | A1 |
Number | Date | Country |
---|---|---|
101180611 | May 2008 | CN |
101238454 | Aug 2008 | CN |
101377736 | Mar 2009 | CN |
103646009 | Mar 2014 | CN |
I275994 | Mar 2007 | TW |
I383318 | Jan 2013 | TW |
WO 2006127857 | Nov 2006 | WO |
WO 2007018467 | Feb 2007 | WO |
Entry |
---|
Kawahito et al., “Instruction Combining for Coalescing Memory Accesses Using Global Code Motion”, ACM, MSP 2004, Jun. 2004, pp. 1-11; <https://dl.acm.org/citation.cfm?id=1065897&CFID=1010142667&CFTOKEN=63671704>. |
D. S. Ivanov, “Register allocation with instruction scheduling for VLIW-architectures”, Programming and Computer Software, vol. 36, No. 6, 2010, Pleiades Publishing, Ltd, Mar. 2010, pp. 363-367; <https://link.springer.com/content/pdf/10.1134%2FS0361768810060058.pdf>. |
Koo et al., “Revealing Critical Loads and Hidden Data Locality in GPGPU Applications”, Nov. 2015, IEEE, pp. 120-129; <http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=7314158>. |
Chinese language Notice of Allowance dated Jul. 22, 2016, issued in application No. TW 104132348. |
European Search Report dated Jan. 5, 2017, issued in application No. 15189469.8-1957. |
Chinese language office action dated May 10, 2017, issued in application No. CN 201510521991.2. |
Number | Date | Country | |
---|---|---|---|
20170060594 A1 | Mar 2017 | US |