# EXHIBIT D ### (12) United States Patent ### Lindholm et al. (10) Patent No.: US 8,174,531 B1 (45) **Date of Patent:** May 8, 2012 ### (54) PROGRAMMABLE GRAPHICS PROCESSOR FOR MULTITHREADED EXECUTION OF PROGRAMS (75) Inventors: John Erik Lindholm, Saratoga, CA (US); **Brett W. Coon**, San Jose, CA (US); **Stuart F. Oberman**, Sunnyvale, CA (US); **Ming Y. Siu**, Santa Clara, CA (US); **Matthew P. Gerlach**, Commerce Township, MI (US) (73) Assignee: **NVIDIA Corporation**, Santa Clara, CA (US) (\*) Notice: Subject to any disclaimer, the term of this patent is extended or adjusted under 35 U.S.C. 154(b) by 0 days. 0.5.e. 13 1(b) by 0 da. (22) Filed: Dec. 29, 2009 (21) Appl. No.: 12/649,201 ### Related U.S. Application Data (60) Division of application No. 11/458,633, filed on Jul. 19, 2006, which is a continuation-in-part of application No. 10/696,714, filed on Oct. 29, 2003, now Pat. No. 7,103,720, and a continuation-in-part of application No. 10/736,437, filed on Dec. 15, 2003, now Pat. No. 7,139,003, and a continuation-in-part of application No. 11/292,614, filed on Dec. 2, 2005, now Pat. No. 7,836,276. (51) **Int. Cl.** G06F 15/16 (2006.01) G06F 15/80 (2006.01) G06F 13/14 (2006.01) G06T 1/20 (2006.01) (52) **U.S. Cl.** ........ **345/505**; 345/502; 345/506; 345/520 (58) Field of Classification Search ....... 345/502, 345/505, 520, 506, 522 See application file for complete search history. ### (56) References Cited ### U.S. PATENT DOCUMENTS | 5 424 020 4 | 5/1005 | C | |-------------|---------|---------------------| | 5,421,028 A | 5/1995 | Swanson | | 5,579,473 A | 11/1996 | Schlapp et al. | | 5,815,166 A | 9/1998 | Baldwin | | 5,838,988 A | 11/1998 | Panwar et al. | | 5,860,018 A | 1/1999 | Panwar et al. | | 5,890,008 A | 3/1999 | Panwar et al. | | 5,948,106 A | 9/1999 | Hetherington et al. | | 5,958,047 A | 9/1999 | Panwar et al. | | 5,978,864 A | 11/1999 | Hetherington et al. | | 5,996,060 A | 11/1999 | Medelson et al. | | 5,999,727 A | 12/1999 | Panwar et al. | | | | | #### (Continued) ### FOREIGN PATENT DOCUMENTS JP 2003-35589 5/2003 ### OTHER PUBLICATIONS Intel, IA-32 Intel Architecture Software Developer's Manual, vol. 1, pp. 11-23 through 11-25. 2004. (Continued) Primary Examiner — Hau Nguyen (74) Attorney, Agent, or Firm — Patterson & Sheridan, LLP. ### (57) ABSTRACT A processing unit includes multiple execution pipelines, each of which is coupled to a first input section for receiving input data for pixel processing and a second input section for receiving input data for vertex processing and to a first output section for storing processed pixel data and a second output section for storing processed vertex data. The processed vertex data is rasterized and scan converted into pixel data that is used as the input data for pixel processing. The processed pixel data is output to a raster analyzer. ### 10 Claims, 14 Drawing Sheets ### US 8,174,531 B1 Page 2 | | U.S. | PATENT | DOCUMENTS | 2004/0024993 | | | Parthasarathy | | | | |------------------------|------|---------|---------------------------------|-----------------------------------------------------------------------|--------|-------------|-----------------------------------|--|--|--| | 6,178,481 | R1 | 1/2001 | Krueger et al. | 2004/0194096 | | | Armstrong et al. | | | | | 6,204,856 | | | Wood et al. | 2004/0207623 | | | Isard et al. | | | | | 6,222,550 | | | Roseman et al. | 2004/0208066 | | 10/2004 | | | | | | 6,266,733 | | | Knittel et al. | 2005/0108720 | A1 | 5/2005 | Cervini | | | | | 6,279,086 | | | Arimilli et al. | 2005/0122330 | | | Boyd et al. | | | | | 6,279,080 | | | Tremblay et al. | 2006/0020772 | | | Hussain | | | | | 6,288,730 | | | Duluk, Jr. et al. | 2006/0155966 | A1 | 7/2006 | Burky et al. | | | | | 6,397,300 | | | Arimilli et al. | | О.Т. | | or real micros | | | | | , , | | | Arimilli et al. | OTHER PUBLICATIONS | | | | | | | | 6,405,285<br>6,418,513 | | | Arimilii et al. Arimilli et al. | | | | | | | | | | | | | Intel, IA-32 Intel Architecture Software Developer's Manual, vol. | | | | | | | | 6,434,667 | | | Arimilli et al. | 2B, p. 4-72. 2004. | | | | | | | | 6,446,166 | | | Arimilli et al. | Lo, et al. "Converting Thread-Level Parallelism to Instruction-Level | | | | | | | | 6,463,507 | | | Arimilli et al. | Parallelism via Simultaneous Multithreading," ACM Transactions on | | | | | | | | 6,559,852 | | | Ashburn et al. | Computer Systems, vol. 15, No. 3, Aug. 1997, pp. 322-354. | | | | | | | | 6,658,447 | | | Cota-Robles | Tullsen, et al. "Exploiting Choice: Instruction Fetch and Issue on an | | | | | | | | 6,704,925 | | | Bugnion | | | | | | | | | 6,750,869 | | | Dawson | Implementable Simultaneous Multithreading Processor," Proceed- | | | | | | | | 6,771,264 | | | Duluk et al. | ings of the 23rd Annual International Symposium on Computer | | | | | | | | 6,816,161 | | | Lavelle et al. | Architecture, May 1996, pp. 1-12. | | | | | | | | 6,819,325 | | | Boyd et al. | Eggers, et al. "Simultaneous Multithreading: A Platform for Next- | | | | | | | | 6,919,896 | | | Sasaki et al 345/505 | Generation Processors," IEEE Micro, vol. 17, No. 5, pp. 12-19, | | | | | | | | 6,947,047 | | | Moy et al. | Sep./Oct. 1997. | | | | | | | | 7,015,718 | | | Burky et al. | English abstract of JP 2003-35589 with additional translated infor- | | | | | | | | 7,103,720 | | | Moy et al. | mation. | | | | | | | | 7,139,003 | | | Kirk et al. | | of Ist | nanese Offi | ce Action dated Jun 9, 2008 (pro- | | | | | 7,237,094 | | | Curran et al. | Translated copy of Japanese Office Action dated Jun. 9, 2008 (pro- | | | | | | | | 7,254,697 | | | Bishop et al. | vided as an explanation of relevance of Citation No. B1). | | | | | | | | 7,278,011 | | 10/2007 | | Hinton, et al. "The Microarchitecture of the Pentium 4 Processor," | | | | | | | | 7,328,438 | | 2/2008 | Armstrong et al. | Intel Technology Journal Q1, 2001, pp. 1-12. | | | | | | | | 7,447,873 | | | Nordquist | Sen et al., "Shadow Silhouette Maps" Jul. 2003, ACM transactions on | | | | | | | | 7,577,869 | | | Mantor et al 714/11 | Graphics 22, 3, p | p. 52 | 1-526. | | | | | | 001/0056456 | | | Cota-Robeles | | | | | | | | | 003/0097395 | A1 | 5/2003 | Peterson | * cited by examiner | | | | | | | U.S. Patent May 8, 2012 Sheet 1 of 14 US 8,174,531 B1 U.S. Patent May 8, 2012 Sheet 2 of 14 US 8,174,531 B1 # DOCKET ## Explore Litigation Insights Docket Alarm provides insights to develop a more informed litigation strategy and the peace of mind of knowing you're on top of things. ### **Real-Time Litigation Alerts** Keep your litigation team up-to-date with **real-time** alerts and advanced team management tools built for the enterprise, all while greatly reducing PACER spend. Our comprehensive service means we can handle Federal, State, and Administrative courts across the country. ### **Advanced Docket Research** With over 230 million records, Docket Alarm's cloud-native docket research platform finds what other services can't. Coverage includes Federal, State, plus PTAB, TTAB, ITC and NLRB decisions, all in one place. Identify arguments that have been successful in the past with full text, pinpoint searching. Link to case law cited within any court document via Fastcase. ### **Analytics At Your Fingertips** Learn what happened the last time a particular judge, opposing counsel or company faced cases similar to yours. Advanced out-of-the-box PTAB and TTAB analytics are always at your fingertips. ### API Docket Alarm offers a powerful API (application programming interface) to developers that want to integrate case filings into their apps. ### **LAW FIRMS** Build custom dashboards for your attorneys and clients with live data direct from the court. Automate many repetitive legal tasks like conflict checks, document management, and marketing. ### **FINANCIAL INSTITUTIONS** Litigation and bankruptcy checks for companies and debtors. ### **E-DISCOVERY AND LEGAL VENDORS** Sync your system to PACER to automate legal marketing.