IPC분류정보
국가/구분 |
United States(US) Patent
등록
|
국제특허분류(IPC7판) |
|
출원번호 |
US-0493750
(2012-06-11)
|
등록번호 |
US-8683182
(2014-03-25)
|
발명자
/ 주소 |
- Hansen, Craig
- Moussouris, John
- Massalin, Alexia
|
출원인 / 주소 |
- Microunity Systems Engineering, Inc.
|
대리인 / 주소 |
McDermott Will & Emery LLP
|
인용정보 |
피인용 횟수 :
25 인용 특허 :
113 |
초록
▼
Systems and apparatuses are presented relating a programmable processor comprising an execution unit that is operable to decode and execute instructions received from an instruction path and partition data stored in registers in the register file into multiple data elements, the execution unit capab
Systems and apparatuses are presented relating a programmable processor comprising an execution unit that is operable to decode and execute instructions received from an instruction path and partition data stored in registers in the register file into multiple data elements, the execution unit capable of executing group data handling operations that re-arrange data elements in different ways in response to data handling instructions, the execution unit further capable of executing a plurality of different group floating-point and group integer arithmetic operations that each arithmetically operates on the multiple data elements stored in registers in the register file to produce a catenated result that is returned to a register in the register file, wherein the catenated result comprises a plurality of individual results.
대표청구항
▼
1. In a programmable processor having an instruction path, a data path, a register file having at least a source register and a result register coupled to the data path, and having an execution unit coupled to the instruction path and the data path operable to decode and execute group instructions r
1. In a programmable processor having an instruction path, a data path, a register file having at least a source register and a result register coupled to the data path, and having an execution unit coupled to the instruction path and the data path operable to decode and execute group instructions received from the instruction path, a method comprising: decoding a single group floating-point instruction indicating (i) the source register, (ii) the result register, and (iii) a source precision and a result precision, the result precision being a factor of two different than the source precision;on an instruction-by-instruction basis, dynamically partitioning data from the source register into multiple source floating-point data elements each having the source precision;converting each of the multiple source floating-point data elements to the result precision, thereby forming multiple result floating-point data elements; andcatenating the multiple result floating-point data elements in the result register. 2. In a programmable processor having an instruction path, a data path, a register file having at least a source register and a result register coupled to the data path, and having an execution unit coupled to the instruction path and the data path operable to decode and execute group instructions received from the instruction path, a method comprising: decoding a single group floating-point instruction indicating (i) the source register, (ii) the result register, and (iii) a source precision and a result precision, the result precision being twice greater than the source precision;on an instruction-by-instruction basis, dynamically partitioning data from the source register into multiple source floating-point data elements each having the source precision;converting each of the multiple source floating-point data elements to the result precision to thereby form multiple result floating-point data elements; andcatenating the multiple result floating-point data elements in the result register. 3. The method of claim 2, wherein the source floating-point data elements and the result floating-point data elements have separate fields for a sign value, an exponent and a significant. 4. The method of claim 2, wherein the result precision is 32-bit precision. 5. The method of claim 2, wherein result precision is 64-bit precision. 6. In a programmable processor having an instruction path, a data path, a register file having at least a source register and a result register coupled to the data path, and having an execution unit coupled to the instruction path and the data path operable to decode and execute group instructions received from the instruction path, a method comprising: decoding a single group floating-point instruction indicating (i) the source register, (ii) the result register, and (iii) a source precision and a result precision, the result precision being one-half the source precision;on an instruction-by-instruction basis, dynamically partitioning data from the source register into multiple source floating-point data elements;converting each of the multiple source floating-point data elements to the result precision to thereby form the multiple result floating-point data elements; andcatenating the multiple result floating-point data elements in the result register. 7. The method of claim 6, wherein the source floating-point data elements and the result floating-point data elements have separate fields for a sign value, an exponent and a significant. 8. The method of claim 6, wherein the result precision is 16-bit precision. 9. The method of claim 6, wherein the result precision is 32-bit precision. 10. The method of claim 6, wherein the step of converting further comprises rounding each result floating-point data element using one of a plurality of rounding options. 11. The method of claim 10, wherein the single group floating-point instruction further specifies the rounding option. 12. An article of manufacture for use with a programmable processor having an instruction path, a data path, a register file having at least a source register and a result register coupled to the data path, and having an execution unit coupled to the instruction path and the data path operable to decode and execute group instructions received from the instruction path, a non-transitory computer readable medium having computer readable code therein for causing the processor to perform steps comprising: decode a single group floating-point instruction indicating (i) the source register, (ii) the result register, and (iii) a source precision and a result precision, the result precision being a factor of two different than the source precision;on an instruction-by-instruction basis dynamically partition data from the source register into multiple source floating-point data elements each having the source precision;convert each of the multiple source floating-point data elements to the result precision, thereby forming multiple result floating-point data elements; andcatenate the multiple result floating-point data elements in the result register. 13. An article of manufacture for use with a programmable processor having an instruction path, a data path, a register file having at least a source register and a result register coupled to the data path, and having an execution unit coupled to the instruction path and the data path operable to decode and execute group instructions received from the instruction path, a non-transitory computer readable medium having computer readable code therein for causing the processor to perform steps comprising: decode a single group floating-point instruction indicating (i) the source register, (ii) the result register, and (iii) a source precision and a result precision, the result precision being twice the source precision:on an instruction-by-instruction basis dynamically partition data from the source register into multiple source floating-point data elements each having the source precision;convert each of the multiple source floating-point data elements to the result precision to thereby form multiple result floating-point data elements; andcatenate the multiple result floating-point data elements in the result register. 14. The article of manufacture of claim 13, wherein the source floating-point data elements and the result floating-point data elements have separate fields for a sign value, an exponent and a significant. 15. The article of manufacture of claim 13, wherein the result precision is 32-bit precision. 16. The article of manufacture of claim 13, wherein the result precision is 64-bit precision. 17. An article of manufacture for use with a programmable processor having an instruction path, a data path, a register file having at least a source register and a result register coupled to the data path, and having an execution unit coupled to the instruction path and the data path operable to decode and execute group instructions received from the instruction path, a non-transitory computer readable medium having computer readable code therein for causing the processor to perform steps comprising: decode a single group floating-point instruction specifying (i) the source register, (ii) the result register, and (iii) a source precision and a result precision, the result precision being one-half the source precision;on an instruction-by-instruction basis, dynamically partition data from the source register into multiple source floating-point data elements;convert each of the multiple source floating-point data elements to the result precision to thereby form the multiple result floating-point data elements; andcatenate the multiple result floating-point data elements in the result register. 18. The article of manufacture of claim 17, wherein the source floating-point data elements and the result floating-point data elements have separate fields for a sign value, an exponent and a significant. 19. The article of manufacture of claim 17, wherein the result precision is 16-bit precision. 20. The article of manufacture of claim 17, wherein the result precision is 32-bit precision. 21. The article of manufacture of claim 17, wherein the step of converting further comprises rounding each result floating-point data element using one of a plurality of rounding options. 22. The article of manufacture of claim 17, wherein the single group floating-point instruction further specifies the rounding option.
※ AI-Helper는 부적절한 답변을 할 수 있습니다.