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.
Patent No.:
Date of Patent:
Feb. 22, 2005
Filed:
Oct. 19, 1998
Dean Batten, Allentown, PA (US);
Paul Gerard D'arcy, Harleysville, PA (US);
C. John Glossner, Allentown, PA (US);
Sanjay Jinturkar, Bethlehem, PA (US);
Jesse Thilo, Bethlehem, PA (US);
Kent E. Wires, Phillipsburg, NJ (US);
Dean Batten, Allentown, PA (US);
Paul Gerard D'Arcy, Harleysville, PA (US);
C. John Glossner, Allentown, PA (US);
Sanjay Jinturkar, Bethlehem, PA (US);
Jesse Thilo, Bethlehem, PA (US);
Kent E. Wires, Phillipsburg, NJ (US);
Agere Systems Inc., Allentown, PA (US);
Abstract
The invention provides techniques for reducing the power consumption of pipelined processors. In an illustrative embodiment, the invention evaluates the predicates of predicated instructions in a decode stage of a pipelined processor, and annuls instructions with false predicates before those instructions can be processed by subsequent stages, e.g, by execute and writeback stages. The predicate dependencies can be handled using, e.g., a virtual single-cycle execution technique which locks a predicate register while the register is in use by a given instruction, and then stalls subsequent instructions that depend on a value stored in the register until the register is unlocked. As another example, the predicate dependencies can be handled using a compiler-controlled dynamic dispatch (CCDD) technique, which identifies dependencies associated with a set of instructions during compilation of the instructions in a compiler. One or more instructions are then grouped in a code block which includes a field indicating the dependencies associated with those instructions, and the instructions are then, e.g., either stalled or decoded serially, based on the dependencies present in the code block. By eliminating unnecessary processing for false-predicate instructions, the invention significantly reduces the power consumption of the processor.