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:
Feb. 19, 2019

Filed:

Jun. 02, 2015
Applicant:

Advanced Micro Devices, Inc., Sunnyvale, CA (US);

Inventors:

David A. Wood, Madison, WI (US);

Steven K. Reinhardt, Vancouver, WA (US);

Bradford M. Beckmann, Redmond, WA (US);

Marc S. Orr, Newcastle, WA (US);

Assignee:

Advanced Micro Devices, Inc., Santa Clara, CA (US);

Attorney:
Primary Examiner:
Int. Cl.
CPC ...
G06F 9/52 (2006.01); G06F 9/30 (2018.01); G06F 9/345 (2018.01); G06F 9/38 (2018.01);
U.S. Cl.
CPC ...
G06F 9/3004 (2013.01); G06F 9/30072 (2013.01); G06F 9/30087 (2013.01); G06F 9/345 (2013.01); G06F 9/3851 (2013.01); G06F 9/52 (2013.01); G06F 9/526 (2013.01);
Abstract

A conditional fetch-and-phi operation tests a memory location to determine if the memory locations stores a specified value and, if so, modifies the value at the memory location. The conditional fetch-and-phi operation can be implemented so that it can be concurrently executed by a plurality of concurrently executing threads, such as the threads of wavefront at a GPU. To execute the conditional fetch-and-phi operation, one of the concurrently executing threads is selected to execute a compare-and-swap (CAS) operation at the memory location, while the other threads await the results. The CAS operation tests the value at the memory location and, if the CAS operation is successful, the value is passed to each of the concurrently executing threads.


Find Patent Forward Citations

Loading…