The patent badge is an abbreviated version of the USPTO patent document. The patent badge does contain a link to the full patent document.

The patent badge is an abbreviated version of the USPTO patent document. The patent badge covers the following: Patent number, Date patent was issued, Date patent was filed, Title of the patent, Applicant, Inventor, Assignee, Attorney firm, Primary examiner, Assistant examiner, CPCs, and Abstract. The patent badge does contain a link to the full patent document (in Adobe Acrobat format, aka pdf). To download or print any patent click here.

Date of Patent:
Apr. 21, 2015

Filed:

Feb. 28, 2013
Applicant:

Cray Inc., Seattle, WA (US);

Inventors:

Terry D. Greyzck, Eagan, MN (US);

William R. Fulton, Eden Prairie, MN (US);

David W. Oehmke, Northfield, MN (US);

Gary W. Elsesser, Eagan, MN (US);

Assignee:

Cray Inc., Seattle, WA (US);

Attorney:
Primary Examiner:
Assistant Examiner:
Int. Cl.
CPC ...
G06F 9/44 (2006.01); G06F 9/45 (2006.01); G06F 15/76 (2006.01);
U.S. Cl.
CPC ...
G06F 15/76 (2013.01); G06F 8/20 (2013.01); G06F 8/36 (2013.01); G06F 8/41 (2013.01); G06F 8/30 (2013.01);
Abstract

A system implementing a method for generating code for execution based on a SIMT model with parallel units of threads is provided. The system identifies a loop within a program that includes vector processing. The system generates instructions for a thread that include an instruction to set a predicate based on whether the thread of a parallel unit corresponds to a vector element. The system also generates instructions to perform the vector processing via scalar operations predicated on the predicate. As a result, the system generates instructions to perform the vector processing but to avoid branch divergence within the parallel unit of threads that would be needed to check whether a thread corresponds to a vector element.


Find Patent Forward Citations

Loading…