TWI738681B - 處理器、用於檢測消抵效應之方法及消抵效應檢測單元 - Google Patents
處理器、用於檢測消抵效應之方法及消抵效應檢測單元 Download PDFInfo
- Publication number
- TWI738681B TWI738681B TW105137261A TW105137261A TWI738681B TW I738681 B TWI738681 B TW I738681B TW 105137261 A TW105137261 A TW 105137261A TW 105137261 A TW105137261 A TW 105137261A TW I738681 B TWI738681 B TW I738681B
- Authority
- TW
- Taiwan
- Prior art keywords
- processor
- instruction
- cancellation
- floating
- unit
- Prior art date
Links
- 230000000694 effects Effects 0.000 title claims abstract description 125
- 238000001514 detection method Methods 0.000 title claims description 63
- 238000000034 method Methods 0.000 title claims description 47
- 238000007667 floating Methods 0.000 claims abstract description 77
- 238000012545 processing Methods 0.000 claims description 85
- 230000009471 action Effects 0.000 claims description 5
- 230000004044 response Effects 0.000 claims description 4
- 230000015654 memory Effects 0.000 description 194
- 238000003860 storage Methods 0.000 description 38
- 238000010586 diagram Methods 0.000 description 36
- 230000007246 mechanism Effects 0.000 description 24
- 238000004891 communication Methods 0.000 description 22
- 238000005516 engineering process Methods 0.000 description 21
- 230000006870 function Effects 0.000 description 18
- 239000000872 buffer Substances 0.000 description 17
- 230000008030 elimination Effects 0.000 description 17
- 238000003379 elimination reaction Methods 0.000 description 17
- 239000003795 chemical substances by application Substances 0.000 description 14
- 238000013461 design Methods 0.000 description 13
- 238000004519 manufacturing process Methods 0.000 description 13
- 238000004364 calculation method Methods 0.000 description 11
- 230000002093 peripheral effect Effects 0.000 description 10
- 230000009977 dual effect Effects 0.000 description 8
- 230000003287 optical effect Effects 0.000 description 8
- 230000001419 dependent effect Effects 0.000 description 7
- 230000003068 static effect Effects 0.000 description 7
- 238000013500 data storage Methods 0.000 description 6
- 238000000605 extraction Methods 0.000 description 6
- 238000004088 simulation Methods 0.000 description 6
- 238000013519 translation Methods 0.000 description 6
- 230000008901 benefit Effects 0.000 description 5
- 238000009826 distribution Methods 0.000 description 5
- 230000008569 process Effects 0.000 description 5
- 239000000700 radioactive tracer Substances 0.000 description 5
- 238000004422 calculation algorithm Methods 0.000 description 4
- 230000006835 compression Effects 0.000 description 4
- 238000007906 compression Methods 0.000 description 4
- 230000008878 coupling Effects 0.000 description 4
- 238000010168 coupling process Methods 0.000 description 4
- 238000005859 coupling reaction Methods 0.000 description 4
- 239000004973 liquid crystal related substance Substances 0.000 description 4
- 230000033001 locomotion Effects 0.000 description 4
- 230000005291 magnetic effect Effects 0.000 description 4
- 238000007726 management method Methods 0.000 description 4
- 230000001360 synchronised effect Effects 0.000 description 4
- 238000011161 development Methods 0.000 description 3
- 230000003993 interaction Effects 0.000 description 3
- 239000004065 semiconductor Substances 0.000 description 3
- 101100285899 Saccharomyces cerevisiae (strain ATCC 204508 / S288c) SSE2 gene Proteins 0.000 description 2
- 230000001133 acceleration Effects 0.000 description 2
- 230000001413 cellular effect Effects 0.000 description 2
- 230000000052 comparative effect Effects 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000006837 decompression Effects 0.000 description 2
- 229910052754 neon Inorganic materials 0.000 description 2
- GKAOGPIIYCISHV-UHFFFAOYSA-N neon atom Chemical compound [Ne] GKAOGPIIYCISHV-UHFFFAOYSA-N 0.000 description 2
- 238000010606 normalization Methods 0.000 description 2
- 239000000758 substrate Substances 0.000 description 2
- 102100026693 FAS-associated death domain protein Human genes 0.000 description 1
- 101000911074 Homo sapiens FAS-associated death domain protein Proteins 0.000 description 1
- 101000912503 Homo sapiens Tyrosine-protein kinase Fgr Proteins 0.000 description 1
- 102000001332 SRC Human genes 0.000 description 1
- 108060006706 SRC Proteins 0.000 description 1
- 102100026150 Tyrosine-protein kinase Fgr Human genes 0.000 description 1
- 238000004458 analytical method Methods 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000015572 biosynthetic process Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 230000001427 coherent effect Effects 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 238000012938 design process Methods 0.000 description 1
- 235000019800 disodium phosphate Nutrition 0.000 description 1
- 238000005538 encapsulation Methods 0.000 description 1
- 239000012634 fragment Substances 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000010354 integration Effects 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 238000005259 measurement Methods 0.000 description 1
- 230000003278 mimic effect Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000004806 packaging method and process Methods 0.000 description 1
- 238000013439 planning Methods 0.000 description 1
- 230000011664 signaling Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000000638 solvent extraction Methods 0.000 description 1
- 238000003786 synthesis reaction Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
- 238000012384 transportation and delivery Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/30029—Logical and Boolean instructions, e.g. XOR, NOT
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/3001—Arithmetic instructions
- G06F9/30014—Arithmetic instructions with variable precision
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/38—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
- G06F7/48—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
- G06F7/483—Computations with numbers represented by a non-linear combination of denominational numbers, e.g. rational numbers, logarithmic number system or floating-point numbers
- G06F7/485—Adding; Subtracting
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/38—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
- G06F7/48—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
- G06F7/499—Denomination or exception handling, e.g. rounding or overflow
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/38—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation
- G06F7/48—Methods or arrangements for performing computations using exclusively denominational number representation, e.g. using binary, ternary, decimal representation using non-contact-making devices, e.g. tube, solid state device; using unspecified devices
- G06F7/499—Denomination or exception handling, e.g. rounding or overflow
- G06F7/49905—Exception handling
- G06F7/4991—Overflow or underflow
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
- G06F9/30021—Compare instructions, e.g. Greater-Than, Equal-To, MINMAX
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30145—Instruction analysis, e.g. decoding, instruction word fields
- G06F9/3016—Decoding the operand specifier, e.g. specifier format
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3861—Recovery, e.g. branch miss-prediction, exception handling
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Computational Mathematics (AREA)
- Mathematical Analysis (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- Computing Systems (AREA)
- Nonlinear Science (AREA)
- Quality & Reliability (AREA)
- Executing Machine-Instructions (AREA)
- Advance Control (AREA)
Abstract
一種處理器包括:用以解碼一指令之一前端;以及用以將該指令指派至一執行單元以執行該指令以計算經受一消抵效應之一浮點結果之一分配器。該執行單元包括:用以控制該消抵效應之通知的一臨限值;用以自一源值計算最大指數的一邏輯;用以計算浮點指數的一邏輯;用以計算經檢測消抵值的一邏輯;以及用以比較該經檢測消抵值與該臨限值的一邏輯。
Description
本發明係關於處理邏輯、微處理器及關聯指令集架構之領域,關聯指令集架構在由處理器或其他處理邏輯執行時執行邏輯、數學或其他功能操作。
多處理器系統正變得愈來愈常見。多處理器系統之應用包括浮點數。多處理器系統之應用包括自始至終進行動態域分割直至桌上型計算。為了利用多處理器系統,可將待執行之程式碼分成多個執行緒以供各種處理實體執行。每一執行緒可彼此並行地執行。指令在其接收於一處理器上時可解碼成原生或更加原生之項或指令字,以供在該處理器上執行。處理器可實施於系統單晶片中。浮點數可相加或相減。浮點數之相加或相減可用於數學模擬中。
依據本發明之一實施例,係特地提出一種處理器,其包含:一前端,其用以解碼一指令,該指令用以
計算經受一消抵效應之一浮點結果;一執行單元;一分配器,用以將該指令指派至該執行單元以執行該指令;其中該執行單元包括:一臨限值,其用以控制該消抵效應之通知;一第一邏輯,其用以自兩個源值計算一最大指數;一第二邏輯,其用以判定該浮點結果之一浮點指數;一第三邏輯,其用以透過自該最大指數減去該浮點指數而計算一經檢測消抵值;以及一第四邏輯,其用以比較該經檢測消抵值與該臨限值。
100:電腦系統
102、200、500、610、615、1000、1215、1710、1802:處理器
104:層級1(L1)內部快取記憶體
106、145、164、208、210:暫存器檔案
108、142、162、462、1822:執行單元
109、143:封裝指令集
110:處理器匯流排
112:圖形控制器/圖形卡
114:加速圖形埠(AGP)互連件
116:記憶體控制器集線器(MCH)
118:記憶體介面
119、1830:指令
120、640、732、734、1140:記憶體
121:資料
122:專屬集線器介面匯流排
123:舊版I/O控制器
124:資料儲存體
125:使用者輸入介面
126:無線收發器
127:串列擴展埠
128:韌體集線器(快閃BIOS)
129:音訊控制器
130:I/O控制器集線器(ICH)
134:網路控制器
140:資料處理系統/電腦系統
141:匯流排
144、165:解碼器
146:同步動態隨機存取記憶體(SDRAM)控制
147:靜態隨機存取記憶體(SRAM)控制
148:叢發快閃記憶體介面
149:個人電腦記憶體卡國際協會(PCMCIA)/緊密快閃(CF)卡控制
150:液晶顯示器(LCD)控制
151:直接記憶體存取(DMA)控制器
152:替代性匯流排主控器介面
153:I/O匯流排
154:I/O橋接器
155:通用非同步接收器/傳輸器(UART)
156:通用串列匯流排(USB)
157:藍芽無線UART
158:I/O擴展介面
159、170:處理核心
160:資料處理系統
161:SIMD共處理器
163:指令集
166:主處理器
167、506、572、574、1525、1532:快取記憶體
168:輸入/輸出系統
169:無線介面
171:共處理器匯流排
201:有序前端
202:快速排程器/uop排程器
203:無序執行引擎
204:慢速/一般浮點排程器/uop排程器
205:整數/浮點uop佇列
206:簡單浮點排程器/uop排程器
207、234:uop佇列
209:記憶體排程器
211:執行區塊
212、214:位址產生單元(AGU)/執行單元
215:分配器/暫存器重新命名器
216、218:快速ALU/執行單元
220:慢速ALU/執行單元
222:浮點ALU/執行單元
224:浮點移動單元/執行單元
226:指令預提取器
228:指令解碼器
230:追蹤快取記憶體
232:微碼ROM
310:封裝位元組
320:封裝字
330:封裝雙字(dword)
341:封裝半
342:封裝單
343:封裝雙
344:無正負號封裝位元組表示
345:有正負號封裝位元組表示
346:無正負號封裝字表示
347:有正負號封裝字表示
348:無正負號封裝雙字表示
349:有正負號封裝雙字表示
360:格式
361、362、383、384、387、388、371、372:欄位
363、373:MOD欄位
364、365、374、375、385、390:源運算元識別符
366、376、386:目的地運算元識別符
370、380:操作編碼(作業碼)格式
378:首碼位元組
381:條件欄位
382、389:CDP作業碼欄位
400:處理器管線
402:提取級
404:長度解碼級
406:解碼級
408:分配級
410:重新命名級
412:排程級
414:暫存器讀取/記憶體讀取級
416:執行級
418:寫回/記憶體寫入級
422:例外狀況處置級
424:認可級
430:前端單元
432、1535:分支預測單元
434:指令快取記憶體單元
436:指令轉譯後援緩衝器(TLB)
438:指令提取單元
440:解碼單元
450:執行引擎單元
452:重新命名/分配器單元
454:淘汰單元
456:排程器單元
458:實體暫存器檔案單元
460:執行叢集
464:記憶體存取單元
470:記憶體單元
472:資料TLB單元
474:資料快取記憶體單元
476:層級2(L2)快取記憶體單元
490、502、502A、502N、1406、1407:核心
503:快取記憶體階層
508:基於環之互連單元
510:系統代理
512:顯示引擎
514:快速圖形PCI(PEG)
516:直接媒體介面(DMI)
518:PCIe橋接器
520:記憶體控制器
522:同調邏輯
552:記憶體控制單元
560:圖形模組
565:媒體引擎
570、1806:前端
580:無序引擎
582:分配模組
584:資源排程器
586:資源
588:重新排序緩衝器
590:模組
595:最後層級快取記憶體(LLC)
599:隨機存取記憶體(RAM)
600、1800:系統
620:圖形記憶體控制器集線器(GMCH)
645、1724:顯示器
650:輸入/輸出(I/O)控制器集線器(ICH)
660:外部圖形裝置
670:另一周邊裝置
695:前側匯流排(FSB)
700:多處理器系統
714、814:I/O裝置
716:第一匯流排
718:匯流排橋接器
720:第二匯流排
722:鍵盤及/或滑鼠
724:音訊I/O
727:通訊裝置
728:儲存單元
730:指令/程式碼及資料
738:高效能圖形電路
739:高效能圖形介面
750:點對點互連件
752、754:P-P介面
770:第一處理器
772、782:記憶體控制器單元(IMC)
776、778、786、788:點對點(P-P)介面/點對點介面電路
780:第二處理器
790:晶片組
794、798:點對點介面電路
796:介面
800:第三系統
815:舊版I/O裝置
872、882:整合式記憶體及I/O控制邏輯(「CL」)
900:SoC裝置
902:互連單元
908:整合式圖形邏輯
910:應用程式處理器
914:整合式記憶體控制器單元
916:匯流排控制器單元
920:媒體處理器
924、1015:影像處理器
926:音訊處理器
928、1020:視訊處理器
930:靜態隨機存取記憶體(SRAM)單元
932:直接記憶體存取(DMA)單元
940:顯示單元
1005:中央處理單元(CPU)
1010、1415:圖形處理單元(GPU)
1025:USB控制器
1030:UART控制器
1035:SPI/SDIO控制器
1040:顯示裝置
1045:記憶體介面控制器
1050:MIPI控制器
1055:快閃記憶體控制器
1060:雙資料速率(DDR)控制器
1065:安全引擎
1070:I2S/I2C控制器
1100:儲存體
1110:硬體或軟體模型
1120:模擬軟體
1150:有線連接
1160:無線連接
1165:製造設施
1205:程式
1210:模仿邏輯
1302:高階語言
1304:x86編譯器
1306:x86二進位碼
1308:替代性指令集編譯器
1310:替代性指令集二進位碼
1312:指令轉換器
1314:不具有x86指令集核心之處理器
1316:具有至少一個x86指令集核心之處理器
1400:指令集架構
1408:L2快取記憶體控制
1409、1520:匯流排介面單元
1410:互連件
1411:層級2(L2)快取記憶體
1420:視訊程式碼
1425:液晶顯示器(LCD)視訊介面
1430:用戶介面模組(SIM)介面
1435:開機ROM介面
1440:同步動態隨機存取記憶體(SDRAM)控制器
1445:快閃控制器
1450:串列周邊介面(SPI)主控器單元
1460:SDRAM晶片或模組
1465:快閃記憶體
1470:藍芽模組
1475:高速3G數據機
1480:全球定位系統模組
1485:無線模組
1490:行動產業處理器介面(MIPI)
1495:高清晰度多媒體介面(HDMI)
1500:指令架構
1510:單元
1511:中斷控制及散佈單元
1512:窺探控制單元
1514:窺探篩選器
1515:計時器
1516:AC埠
1530:預提取級
1531:選項
1536:全域歷史
1537:目標位址
1538:傳回堆疊
1540:記憶體系統
1543:預提取器
1544:記憶體管理單元(MMU)
1545:轉譯後援緩衝器(TLB)
1546:載入儲存單元
1550:雙指令解碼級
1555:暫存器重新命名級
1556:暫存器集區
1557:分支
1560:發行級
1561:指令佇列
1565:執行實體
1566:ALU/乘法單元(MUL)
1567:ALU
1568:浮點單元(FPU)
1569:給定位址
1570:寫回級
1575:追蹤單元
1580:經執行指令指標
1582:淘汰指標
1600:執行管線
1700:電子裝置
1715:低電力雙資料速率(LPDDR)記憶體單元
1720:磁碟機
1722:BIOS/韌體/快閃記憶體
1725:觸控螢幕
1730:觸控板
1735:快速晶片組(EC)
1736:鍵盤
1737:風扇
1738:受信任平台模組(TPM)
1739、1746:熱感測器
1740:感測器集線器
1741:加速度計
1742:環境光感測器(ALS)
1743:羅盤
1744:迴轉儀
1745:近場通訊(NFC)單元
1750:無線區域網路(WLAN)單元
1752:藍芽單元
1754:攝影機
1756:無線廣域網路(WWAN)單元
1757:SIM卡
1760:數位信號處理器
1762:音訊單元
1763:揚聲器
1764:頭戴式耳機
1765:麥克風
1804、1804A、1804B:指令串流
1814:主核心
1816:有序或無序執行管線
1818:分配單元
1820:排程器
1824:淘汰單元/重新排序緩衝器
1826:消抵效應檢測單元
1828:智慧財產權(IP)核心
1902、1904、1906:有效位數
1910、1912、1914:基數
1930:經正規化結果
1932、1934、1936:位置
1938、1940、1942:前置位元
1946:區段
2000:方法
在隨附圖式之各圖中作為實例而非限制來說明實施例:圖1A為根據本發明之實施例的例示性電腦系統之方塊圖,該電腦系統被形成有可包括用以執行指令之執行單元的處理器;圖1B說明根據本發明之實施例的資料處理系統;圖1C說明用於執行文字字串比較操作之資料處理系統之其他實施例;圖2為根據本發明之實施例的用於處理器之微架構之方塊圖,該處理器可包括用以執行指令之邏輯電路;圖3A說明根據本發明之實施例的多媒體暫存器中之各種封裝資料類型表示;圖3B說明根據本發明之實施例的可能暫存器內資料儲存格式;圖3C說明根據本發明之實施例的多媒體暫存器中之
各種有正負號及無正負號封裝資料類型表示;圖3D說明操作編碼格式之實施例;圖3E說明根據本發明之實施例的具有四十或更多位元之另一可能操作編碼格式;圖3F說明根據本發明之實施例的又一可能操作編碼格式;圖4A為根據本發明之實施例的說明有序管線及暫存器重新命名級、無序發行/執行管線之方塊圖;圖4B為根據本發明之實施例的說明待包括於處理器中之有序架構核心及暫存器重新命名邏輯、無序發行/執行邏輯之方塊圖;圖5A為根據本發明之實施例的處理器之方塊圖;圖5B為根據本發明之實施例的核心之實例實施方案之方塊圖;圖6為根據本發明之實施例的系統之方塊圖;圖7為根據本發明之實施例的第二系統之方塊圖;圖8為根據本發明之實施例的第三系統之方塊圖;圖9為根據本發明之實施例的系統單晶片之方塊圖;圖10說明根據本發明之實施例的可執行至少一個指令之含有中央處理單元及圖形處理單元之處理器;圖11為說明根據本發明之實施例的IP核心之開發之方塊圖;圖12說明根據本發明之實施例的第一類型之指令可如何由不同類型之處理器模仿;
圖13說明根據本發明之實施例的對比軟體指令轉換器之使用之方塊圖,該軟體指令轉換器用以將源指令集中之二進位指令轉換至目標指令集中之二進位指令;圖14為根據本發明之實施例的處理器之指令集架構之方塊圖;圖15為根據本發明之實施例的處理器之指令集架構之更詳細方塊圖;圖16為根據本發明之實施例的用於處理器之指令集架構之執行管線之方塊圖;圖17為根據本發明之實施例的用於利用處理器之電子裝置之方塊圖;圖18為根據本發明之實施例的用於檢測浮點消抵效應之系統之方塊圖;圖19為根據本發明之實施例的用於檢測浮點消抵效應之系統之元件的更詳細方塊圖;以及圖20為根據本發明之實施例的用於檢測浮點消抵效應之方法之操作的圖解。
以下實施方式描述用於檢測浮點消抵效應之指令及處理邏輯。該指令及處理邏輯可實施於無序處理器上。在以下實施方式中,闡述諸如處理邏輯、處理器類型、微架構條件、事件、啟用機制及類似者之眾多特定細節,以便提供對本發明之實施例之更透徹的理解。然而,熟習此項技
術者應瞭解,可在無此等特定細節的情況下實踐實施例。另外,尚未詳細地展示一些熟知結構、電路及類似者以避免不必要地混淆本發明之實施例。
儘管以下實施例係參考處理器予以描述,但其他實施例適用於其他類型之積體電路及邏輯裝置。本發明之實施例之相似技術及教示可應用於可受益於較高管線輸送量及經改良效能的其他類型之電路或半導體裝置。本發明之實施例之教示適用於執行資料操縱之任一處理器或機器。然而,該等實施例並不限於執行512位元、256位元、128位元、64位元、32位元或16位元資料操作之處理器或機器,且可應用於可執行資料之操縱或管理之任一處理器及機器。此外,以下實施方式提供實例,且隨附圖式出於說明之目的而展示各種實例。然而,不應在限制性意義上解釋此等實例,此係因為該等實例僅僅意欲提供本發明之實施例之實例,而非提供本發明之實施例的所有可能實施方案之詳盡清單。
儘管以下實例在執行單元及邏輯電路之上下文中描述指令處置及散佈,但本發明之其他實施例可藉由儲存於機器可讀有形媒體上之資料或指令而實現,該資料或該等指令在由機器執行時致使機器執行與本發明之至少一個實施例一致的功能。在一個實施例中,與本發明之實施例相關聯的功能係以機器可執行指令予以體現。該等指令可用以致使可運用該等指令而規劃之一般用途或特殊用途處理器執行本發明之步驟。本發明之實施例可被提供
為電腦程式產品或軟體,其可包括機器或電腦可讀媒體,該媒體具有儲存於其上之指令,該等指令可用以規劃電腦(或其他電子裝置)以執行根據本發明之實施例的一或多個操作。此外,本發明之實施例的步驟可由含有用於執行該等步驟之固定功能邏輯的特定硬體組件執行,或由經規劃電腦組件與固定功能硬體組件之任何組合執行。
用以規劃邏輯以執行本發明之實施例的指令可儲存於系統中之記憶體內,諸如DRAM、快取記憶體、快閃記憶體或其他儲存體。此外,該等指令可經由網路或藉由其他電腦可讀媒體而散佈。因此,機器可讀媒體可包括用於以可由機器(例如,電腦)讀取之形式儲存或傳輸資訊的任何機構,但不限於軟碟、光碟、緊密光碟唯讀記憶體(CD-ROM)及磁光碟、唯讀記憶體(ROM)、隨機存取記憶體(RAM)、可抹除可規劃唯讀記憶體(EPROM)、電可抹除可規劃唯讀記憶體(EEPROM)、磁卡或光卡、快閃記憶體,或用於在網際網路上經由電、光學、聲學或其他形式之傳播信號(例如,載波、紅外線信號、數位信號等等)來傳輸資訊的有形機器可讀儲存體。因此,電腦可讀媒體可包括適合於以可由機器(例如,電腦)讀取之形式儲存或傳輸電子指令或資訊的任何類型之有形機器可讀媒體。
一設計可經歷各種階段:自建立至模擬至製造。表示設計之資料可以數種方式表示設計。首先,可使用硬體描述語言或另一功能描述語言來表示硬體,此在模擬中可為有用的。另外,可在設計程序之一些階段產生具
有邏輯及/或電晶體閘極之電路層級模型。此外,在某一階段,設計可達到表示各種裝置在硬體模型中之實體置放的資料層級。在使用一些半導體製造技術之狀況下,表示硬體模型之資料可為指定各種特徵在用於用以生產積體電路之遮罩之不同遮罩層上之存在或不存在的資料。在設計之任何表示中,可以機器可讀媒體之任一形式儲存資料。記憶體或磁性或光學儲存體(諸如光碟)可為用以儲存資訊之機器可讀媒體,該資訊係經由經調變或以其他方式產生以傳輸此資訊之光波或電波而傳輸。當傳輸指示或攜載程式碼或設計之電載波時,在執行電信號之複製、緩衝或重新傳輸的程度上,可產生新複本。因此,通訊提供者或網路提供者可至少臨時地在有形機器可讀媒體上儲存體現本發明之實施例之技術的物品,諸如被編碼成載波之資訊。
在現代處理器中,數個不同執行單元可用以處理及執行多種程式碼及指令。一些指令之完成可較快,而其他指令之完成可花費數個時脈循環。指令之輸送量愈快,則處理器之總體效能愈好。因此,將有利的是使一樣多的指令儘可能快地執行。然而,可存在具有較大複雜性且在執行時間及處理器資源方面需要更多之某些指令,諸如浮點指令、載入/儲存操作、資料移動等等。
隨著較多電腦系統用於網際網路、文字及多媒體應用程式中,已隨著時間推移而引入額外處理器支援。在一個實施例中,一指令集可與一或多個電腦架構相關聯,該一或多個電腦架構包括資料類型、指令、暫存器
架構、定址模式、記憶體架構、中斷及例外狀況處置,以及外部輸入及輸出(I/O)。
在一個實施例中,指令集架構(ISA)可由可包括用以實施一或多個指令集之處理器邏輯及電路的一或多個微架構實施。因此,具有不同微架構之處理器可共用共同指令集之至少一部分。舉例而言,Intel® Pentium 4處理器、Intel® CoreTM處理器及來自Sunnyvale CA之Advanced Micro Devices公司之處理器實施x86指令集之幾乎相同的版本(其中已運用較新版本而添加一些延伸),但具有不同的內部設計。相似地,由其他處理器開發公司(諸如ARM Holdings有限公司、MIPS,或其使用人或採用者)設計之處理器可共用共同指令集之至少一部分,但可包括不同的處理器設計。舉例而言,可在使用新技術或熟知技術之不同微架構中以不同方式實施ISA之相同暫存器架構,包括專用實體暫存器、使用暫存器重新命名機制(例如,使用暫存器別名表格(RAT)之一或多個動態分配實體暫存器、重新排序緩衝器(ROB)及淘汰暫存器檔案。在一個實施例中,暫存器可包括一或多個暫存器、暫存器架構、暫存器檔案,或可為或可不為軟體規劃師可定址之其他暫存器集。
一指令可包括一或多個指令格式。在一個實施例中,指令格式可指示用以尤其指定待執行之運算及彼運算將被執行之運算元的各種欄位(位元之數目、位元之位置等等)。在一另外實施例中,一些指令格式可進一步由指
令範本(或子格式)界定。舉例而言,給定指令格式之指令範本可被界定為具有指令格式之欄位的不同子集,及/或被界定為具有經不同解譯之給定欄位。在一個實施例中,指令可使用指令格式(且在被界定的情況下,以彼指令格式之指令範本中之給定者)予以表達,且指定或指示運算及運算元,該運算將對該等運算元進行運算。
科學、金融、自動向量化一般用途、RMS(辨識、採擷及合成)以及視覺及多媒體應用程式(例如,2D/3D圖形、影像處理、視訊壓縮/解壓縮、語音辨識演算法及音訊操縱)可需要對大量資料項目執行相同操作。在一個實施例中,單指令多資料(SIMD)指代致使處理器對多個資料元素執行操作的一類型之指令。SIMD技術可用於可邏輯上將暫存器中之位元劃分成數個固定大小或可變大小之資料元素的處理器中,該等資料元素中之每一者表示一單獨值。舉例而言,在一個實施例中,64位元暫存器中之位元可被組織為含有四個單獨16位元資料元素之源運算元,該等資料元素中之每一者表示一單獨16位元值。此類型之資料可被稱作「封裝」資料類型或「向量」資料類型,且此資料類型之運算元可被稱作封裝資料運算元或向量運算元。在一個實施例中,封裝資料項目或向量可為儲存於單一暫存器內之一連串封裝資料元素,且封裝資料運算元或向量運算元可為SIMD指令(或「封裝資料指令」或「向量指令」)之源或目的地運算元。在一個實施例中,SIMD指令指定待對兩個源向量運算元執行以產生具有相同或不同
大小、具有相同或不同數目個資料元素且呈相同或不同資料元素次序之目的地向量運算元(亦被稱作結果向量運算元)的單一向量運算。
諸如由以下處理器使用之技術的SIMD技術已實現應用效能之顯著改良:Intel® CoreTM處理器,其具有包括x86、MMXTM、串流SIMD延伸(SSE)、SSE2、SSE3、SSE4.1及SSE4.2指令之指令集;ARM處理器,諸如ARM Cortex®處理器家族,其具有包括向量浮點(VFP)及/或NEON指令之指令集;及MIPS處理器,諸如由中國科學院計算技術研究所開發之Loongson處理器家族(CoreTM及MMXTM為Santa Clara,Calif.之Intel Corporation的註冊商標或商標)。
在一個實施例中,目的地及源暫存器/資料可為表示對應資料或操作之源及目的地之一般術語。在一些實施例中,其可由暫存器、記憶體或具有與所描繪之名稱或功能不同之名稱或功能的其他儲存區域實施。舉例而言,在一個實施例中,「DEST1」可為臨時儲存暫存器或其他儲存區域,而「SRC1」及「SRC2」可為第一及第二源儲存暫存器或其他儲存區域等等。在其他實施例中,SRC及DEST儲存區域中之兩者或多於兩者可對應於同一儲存區域(例如,SIMD暫存器)內之不同資料儲存元件。在一個實施例中,源暫存器中之一者亦可藉由(例如)將對第一及第二源資料執行之運算之結果寫回至充當目的地暫存器之兩個源暫存器中之一者來充當目的地暫存器。
圖1A為根據本發明之實施例的例示性電腦系統之方塊圖,該電腦系統被形成有可包括用以執行指令之執行單元的處理器。根據本發明,諸如在本文中所描述之實施例中,系統100可包括諸如用以使用執行單元之處理器102的組件,該等執行單元包括用以執行用於程序資料之演算法的邏輯。系統100可表示基於可購自Santa Clara,California之Intel Corporation的PENTIUM® III、PENTIUM® 4、XeonTM、Itanium®、XScaleTM及/或StrongARMTM微處理器之處理系統,但亦可使用其他系統(包括具有其他微處理器、工程設計工作站、機上盒及類似者之PC)。在一個實施例中,樣本系統100可執行可購自Redmond,Washington之Microsoft Corporation的WINDOWSTM作業系統之版本,但亦可使用其他作業系統(例如,UNIX及Linux)、嵌入式軟體及/或圖形使用者介面。因此,本發明之實施例並不限於硬體電路系統與軟體之任何特定組合。
實施例並不限於電腦系統。本發明之實施例可用於諸如手持型裝置及嵌入式應用之其他裝置中。手持型裝置之一些實例包括蜂巢式電話、網際網路協定裝置、數位攝影機、個人數位助理(PDA)及手持型PC。嵌入式應用可包括微控制器、數位信號處理器(DSP)、系統單晶片、網路電腦(NetPC)、機上盒、網路集線器、廣域網路(WAN)交換器,或可執行根據至少一個實施例之一或多個指令之任何其他系統。
電腦系統100可包括處理器102,處理器102可包括一或多個執行單元108以執行演算法以執行根據本發明之一個實施例的至少一個指令。可在單一處理器桌上型電腦或伺服器系統之上下文中描述一個實施例,但其他實施例可包括於多處理器系統中。系統100可為「集線器」系統架構之實例。系統100可包括用於處理資料信號之處理器102。處理器102可包括複雜指令集電腦(CISC)微處理器、精簡指令集計算(RISC)微處理器、超長指令字(VLIW)微處理器、實施指令集之組合的處理器,或任何其他處理器裝置,諸如數位信號處理器。在一個實施例中,處理器102可耦接至可在處理器102與系統100中之其他組件之間傳輸資料信號的處理器匯流排110。系統100之元件可執行熟習此項技術者所熟知之習知功能。
在一個實施例中,處理器102可包括層級1(L1)內部快取記憶體104。取決於架構,處理器102可具有單一內部快取記憶體或多個層級之內部快取記憶體。在另一實施例中,快取記憶體可駐留於處理器102外部。取決於特定實施方案及需要,其他實施例亦可包括內部快取記憶體與外部快取記憶體之組合。暫存器檔案106可將不同類型之資料儲存於包括整數暫存器、浮點暫存器、狀態暫存器及指令指標暫存器之各種暫存器中。
執行單元108(包括用以執行整數及浮點運算的邏輯)亦駐留於處理器102中。處理器102亦可包括儲存用於某些巨集指令之微碼的微碼(ucode)ROM。在一個
實施例中,執行單元108可包括用以處置封裝指令集109的邏輯。藉由在一般用途處理器102之指令集中包括封裝指令集109,連同用以執行指令之關聯電路系統,可使用一般用途處理器102中之封裝資料來執行由許多多媒體應用程式使用之操作。因此,可藉由使用處理器之資料匯流排的全寬以用於對封裝資料執行操作來更高效地加速及執行許多多媒體應用程式。此可消除對橫越處理器之資料匯流排傳送較小資料單元以每次對一個資料元素執行一或多個操作的需要。
亦可在微控制器、嵌入式處理器、圖形裝置、DSP及其他類型之邏輯電路中使用執行單元108之實施例。系統100可包括記憶體120。記憶體120可被實施為動態隨機存取記憶體(DRAM)裝置、靜態隨機存取記憶體(SRAM)裝置、快閃記憶體裝置或其他記憶體裝置。記憶體120可儲存由可由處理器102執行之資料信號表示的指令及/或資料。
系統邏輯晶片116可耦接至處理器匯流排110及記憶體120。系統邏輯晶片116可包括記憶體控制器集線器(MCH)。處理器102可經由處理器匯流排110而與MCH 116通訊。MCH 116可提供至記憶體120之高頻寬記憶體路徑118以用於指令及資料儲存及用於圖形命令、資料及紋理之儲存。MCH 116可在處理器102、記憶體120與系統100中之其他組件之間引導資料信號,且在處理器匯流排110、記憶體120與系統I/O 122之間橋接資料信
號。在一些實施例中,系統邏輯晶片116可提供用於耦接至圖形控制器112之圖形埠。MCH 116可透過記憶體介面118而耦接至記憶體120。圖形卡112可透過加速圖形埠(AGP)互連件114而耦接至MCH 116。
系統100可使用專屬集線器介面匯流排122以將MCH 116耦接至I/O控制器集線器(ICH)130。在一個實施例中,ICH 130可經由本機I/O總線而提供至一些I/O裝置之直接連接。本機I/O匯流排可包括用於將周邊設備連接至記憶體120、晶片組及處理器102之高速I/O匯流排。實例可包括音訊控制器、韌體集線器(快閃BIOS)128、無線收發器126、資料儲存體124、含有使用者輸入及鍵盤介面之舊版I/O控制器、諸如通用串列匯流排(USB)之串列擴展埠,及網路控制器134。資料儲存裝置124可包含硬碟機、軟碟機、CD-ROM裝置、快閃記憶體裝置,或其他大容量儲存裝置。
對於系統之另一實施例,根據一個實施例之指令可與系統單晶片一起使用。系統單晶片之一個實施例包含處理器及記憶體。用於一個此類系統之記憶體可包括快閃記憶體。快閃記憶體可與處理器及其他系統組件位於同一晶粒上。另外,諸如記憶體控制器或圖形控制器之其他邏輯區塊亦可位於系統單晶片上。
圖1B說明實施本發明之實施例之原理的資料處理系統140。熟習此項技術者應容易瞭解,在不脫離本發明之實施例之範疇的情況下,本文中所描述之實施例
可與替代性處理系統一起操作。
電腦系統140包含用於執行根據一個實施例之至少一個指令之處理核心159。在一個實施例中,處理核心159表示任一類型之架構的處理單元,該架構包括但不限於CISC、RISC或VLIW類型架構。處理核心159亦可適合於以一或多種程序技術之製造,且藉由足夠詳細地在機器可讀媒體上予以表示而可適合於促進該製造。
處理核心159包含執行單元142、一組暫存器檔案145,及解碼器144。處理核心159亦包括對於理解本發明之實施例可為不必要的額外電路系統(未圖示)。執行單元142可執行由處理核心159接收之指令。除了執行典型處理器指令以外,執行單元142亦可執行封裝指令集143中之指令以用於對封裝資料格式執行操作。封裝指令集143可包括用於執行本發明之實施例之指令以及其他封裝指令。執行單元142可由內部匯流排耦接至暫存器檔案145。暫存器檔案145可表示處理核心159上的用於儲存資訊(包括資料)之儲存區域。如先前所提到,應理解,儲存區域可儲存可能並非關鍵之封裝資料。執行單元142可耦接至解碼器144。解碼器144可將由處理核心159接收之指令解碼成控制信號及/或微碼入口點。回應於此等控制信號及/或微碼入口點,執行單元142執行適當操作。在一個實施例中,解碼器可解譯指令之作業碼,其將指示應對指令內所指示之對應資料執行何操作。
處理核心159可與匯流排141耦接以用於與
各種其他系統裝置通訊,該等其他系統裝置可包括但不限於(例如)同步動態隨機存取記憶體(SDRAM)控制146、靜態隨機存取記憶體(SRAM)控制147、叢發快閃記憶體介面148、個人電腦記憶體卡國際協會(PCMCIA)/緊密快閃(CF)卡控制149、液晶顯示器(LCD)控制150、直接記憶體存取(DMA)控制器151,及替代性匯流排主控器介面152。在一個實施例中,資料處理系統140亦可包含I/O橋接器154以用於經由I/O匯流排153而與各種I/O裝置通訊。此等I/O裝置可包括但不限於(例如)通用非同步接收器/傳輸器(UART)155、通用串列匯流排(USB)156、藍芽無線UART 157,及I/O擴展介面158。
資料處理系統140之一個實施例提供行動、網路及/或無線通訊,及可執行包括文字字串比較操作之SIMD操作之處理核心159。處理核心159可運用以下各者予以規劃:各種音訊、視訊、成像及通訊演算法,包括離散變換,諸如沃爾什-哈達瑪(Walsh-Hadamard)變換、快速傅立葉變換(FFT)、離散餘弦變換(DCT)及其各別反變換;壓縮/解壓縮技術,諸如色彩空間變換、視訊編碼運動估計或視訊解碼運動補償;及調變/解調變(數據機)功能,諸如脈碼調變(PCM)。
圖1C說明執行SIMD文字字串比較操作之資料處理系統之其他實施例。在一個實施例中,資料處理系統160可包括主處理器166、SIMD共處理器161、快取記憶體167,及輸入/輸出系統168。輸入/輸出系統168可視
情況耦接至無線介面169。SIMD共處理器161可執行包括根據一個實施例之指令之操作。在一個實施例中,處理核心170可適合於以一或多種程序技術之製造,且藉由足夠詳細地在機器可讀媒體上予以表示而可適合於促進包括處理核心170之資料處理系統160之全部或部分的製造。
在一個實施例中,SIMD共處理器161包含執行單元162,及一組暫存器檔案164。主處理器165之一個實施例包含解碼器165以辨識包括用於由執行單元162執行之根據一個實施例之指令的指令集163之指令。在其他實施例中,SIMD共處理器161亦包含解碼器165之至少部分以解碼指令集163之指令。處理核心170亦可包括對於理解本發明之實施例可為不必要的額外電路系統(未圖示)。
在操作中,主處理器166執行控制一般類型之資料處理操作(包括與快取記憶體167及輸入/輸出系統168之互動)的資料處理指令串流。嵌入於資料處理指令串流內的可為SIMD共處理器指令。主處理器166之解碼器165將此等SIMD共處理器指令辨識為屬於應由附接式SIMD共處理器161執行之類型。因此,主處理器166在共處理器匯流排166上發行此等SIMD共處理器指令(或表示SIMD共處理器指令之控制信號)。自共處理器匯流排166,此等指令可由任何附接式SIMD共處理器接收。在此狀況下,SIMD共處理器161可接受及執行意欲用於SIMD共處理器161的任何經接收SIMD共處理器指令。
可經由無線介面169接收資料以供SIMD共
處理器指令處理。對於一個實例,可以數位信號之形式接收語音通訊,該數位信號可由SIMD共處理器指令處理以再生表示語音通訊之數位音訊樣本。對於另一實例,可以數位位元串流之形式接收經壓縮音訊及/或視訊,該數位位元串流可由SIMD共處理器指令處理以再生數位音訊樣本及/或運動視訊圖框。在處理核心170之一個實施例中,主處理器166及SIMD共處理器161可整合至單一處理核心170中,單一處理核心170包含執行單元162、一組暫存器檔案164,及用以辨識包括根據一個實施例之指令的指令集163之指令的解碼器165。
圖2為根據本發明之實施例的用於處理器200之微架構之方塊圖,處理器200可包括用以執行指令之邏輯電路。在一些實施例中,可實施根據一個實施例之指令以對具有位元組、字、雙字、四倍字等等之大小以及諸如單精確度及雙精確度整數及浮點資料類型之資料類型的資料元素進行操作。在一個實施例中,有序前端201可實施處理器200之部分,其可提取待執行之指令且準備使該等指令稍後在處理器管線中使用。前端201可包括若干單元。在一個實施例中,指令預提取器226自記憶體提取指令且將該等指令饋送至又解碼或解譯該等指令之指令解碼器228。舉例而言,在一個實施例中,解碼器將經接收指令解碼成機器可執行之一或多個操作,其被稱為「微指令」或「微操作(micro-operation)」(亦被稱為微op或uop)。在其他實施例中,解碼器將指令剖析成可由微架構使用以
執行根據一個實施例之操作的作業碼以及對應資料及控制欄位。在一個實施例中,追蹤快取記憶體230可將經解碼uop組譯成uop佇列234中之程式有序序列或追蹤以供執行。當追蹤快取記憶體230遇到複雜指令時,微碼ROM 232提供完成操作所需要之uop。
一些指令可被轉換成單一微op,而其他指令需要若干微op來完成全部操作。在一個實施例中,若完成一指令需要多於四個微op,則解碼器228可存取微碼ROM 232以執行該指令。在一個實施例中,可將指令解碼成少量微op以供在指令解碼器228處處理。在另一實施例中,若需要數個微op來實現操作,則指令可儲存於微碼ROM 232內。追蹤快取記憶體230指代入口點可規劃邏輯陣列(PLA)以判定用於自微碼ROM 232讀取微碼序列以完成根據一個實施例之一或多個指令的正確微指令指標。在微碼ROM 232完成針對一指令之定序微op之後,機器之前端201可繼續自追蹤快取記憶體230提取微op。
無序執行引擎203可準備指令以供執行。無序執行邏輯具有數個緩衝器以隨著指令通過管線且經排程以供執行而使指令之流動平穩且將指令之流動重新排序以使效能最佳化。分配器邏輯分配每一uop所需要以便執行之機器緩衝器及資源。暫存器重新命名邏輯將邏輯暫存器重新命名至暫存器檔案中之輸入項目上。分配器亦在指令排程器之前方分配用於兩個uop佇列中之一者中的每一uop之入口,一個用於記憶體操作且一個用於非記憶體操
作:記憶體排程器、快速排程器202、慢速/一般浮點排程器204,及簡單浮點排程器206。uop排程器202、204、206基於其相依輸入暫存器運算元源之就緒及uop完成其操作所需要之執行資源之可用性來判定uop何時就緒以執行。一個實施例之快速排程器202可按每半個主時脈循環而排程,而其他排程器可在每主處理器時脈循環僅排程一次。該等排程器對分派埠仲裁以排程uop以供執行。
暫存器檔案208、210可配置於排程器202、204、206與執行區塊211中之執行單元212、214、216、218、220、222、224之間。暫存器檔案208、210中之每一者分別執行整數及浮點運算。每一暫存器檔案208、210可包括旁路網路,其可繞過尚未寫入至暫存器檔案中的剛剛完成之結果或將該等結果轉遞至新相依uop。整數暫存器檔案208及浮點暫存器檔案210可與其他者傳達資料。在一個實施例中,可將整數暫存器檔案208分裂成兩個單獨暫存器檔案,一個暫存器檔案用於資料之低階三十二位元且第二暫存器檔案用於資料之高階三十二位元。浮點暫存器檔案210可包括128位元寬之輸入項目,此係因為浮點指令通常具有寬度為64位元至128位元之運算元。
執行區塊211可含有執行單元212、214、216、218、220、222、224。執行單元212、214、216、218、220、222、224可執行指令。執行區塊211可包括儲存微指令需要執行之整數及浮點資料運算元值的暫存器檔案208、210。在一個實施例中,處理器200可包含數個執
行單元:位址產生單元(AGU)212、AGU 214、快速ALU 216、快速ALU 218、慢速ALU 220、浮點ALU 222、浮點移動單元224。在另一實施例中,浮點執行區塊222、224可執行浮點、MMX、SIMD及SSE或其他操作。在又一實施例中,浮點ALU 222可包括64位元乘64位元之浮點除法器以執行除法、平方根及餘數微op。在各種實施例中,可運用浮點硬體來處置涉及浮點值之指令。在一個實施例中,可將ALU運算傳遞至高速ALU執行單元216、218。高速ALU 216、218可運用一半之時脈循環之有效潛時來執行快速運算。在一個實施例中,最複雜的整數運算轉至慢速ALU 220,此係因為慢速ALU 220可包括用於長潛時類型之運算的整數執行硬體,諸如乘法器、移位、旗標邏輯及分支處理。記憶體載入/儲存操作可由AGU 212、214執行。在一個實施例中,整數ALU 216、218、220可對64位元資料運算元執行整數運算。在其他實施例中,可實施ALU 216、218、220以支援多種資料位元大小,包括十六、三十二、128、256等等。相似地,可實施浮點單元222、224以支援具有各種寬度之位元的一系列運算元。在一個實施例中,浮點單元222、224可結合SIMD及多媒體指令而對128位元寬之封裝資料運算元進行運算。
在一個實施例中,uop排程器202、204、206在親代載入已完成執行之前分派相依操作。因為可在處理器200中推測性地排程及執行uop時,所以處理器200亦可包括用以處置記憶體遺漏的邏輯。若資料載入在資料快取
記憶體中遺漏,則管線中可存在使排程器具有臨時不正確資料的運作中之相依操作。重新執行機構追蹤及再執行使用不正確資料之指令。可僅需要重新執行相依操作且可允許獨立操作完成。處理器之一個實施例的排程器及重新執行機構亦可經設計以捕捉指令序列以用於文字字串比較操作。
術語「暫存器」可指代可用作用以識別運算元之指令之部分的機載處理器儲存位置。換言之,暫存器可為可自處理器外部(根據規劃師之觀點)使用的暫存器。然而,在一些實施例中,暫存器可不限於特定類型之電路。實情為,暫存器可儲存資料,提供資料,且執行本文中所描述之功能。本文中所描述之暫存器可由使用任何數目個不同技術之處理器內之電路系統(諸如專用實體暫存器、使用暫存器重新命名之動態分配實體暫存器、專用與動態分配實體暫存器之組合等等)實施。在一個實施例中,整數暫存器儲存32位元整數資料。一個實施例之暫存器檔案亦含有用於封裝資料之八個多媒體SIMD暫存器。對於以下論述,可將暫存器理解為經設計以保持封裝資料之資料暫存器,諸如運用來自Santa Clara,California之Intel Corporation之MMX技術而啟用的微處理器中之64位元寬MMXTM暫存器(在一些情況下亦被稱作「mm」暫存器)。以整數及浮點形式兩者可用之此等MMX暫存器可運用伴隨SIMD及SSE指令之封裝資料元素而操作。相似地,與SSE2、SSE3、SSE4或更高(一般被稱作「SSEx」)
技術相關之128位元寬XMM暫存器可保持此等封裝資料運算元。在一個實施例中,在儲存封裝資料及整數資料時,暫存器並不需要區分兩個資料類型。在一個實施例中,整數及浮點可含於同一暫存器檔案或不同暫存器檔案中。此外,在一個實施例中,浮點及整數資料可儲存於不同暫存器或相同暫存器中。
在以下諸圖之實例中,描述數個資料運算元。圖3A說明根據本發明之實施例的多媒體暫存器中之各種封裝資料類型表示。圖3A說明用於128位元寬運算元之封裝位元組310、封裝字320及封裝雙字(dword)330之資料類型。此實例之封裝位元組格式310可為128個位元長且含有十六個封裝位元組資料元素。舉例而言,可將位元組界定為八個資料位元。用於每一位元組資料元素之資訊可儲存於用於位元組0之位元7至位元0、用於位元組1之位元15至位元8、用於位元組2之位元23至位元16及最後用於位元組15之位元120至位元127中。因此,所有可用位元可用於暫存器中。此儲存配置增加處理器之儲存效率。同樣,在存取十六個資料元素的情況下,現在可並行地對十六個資料元素執行一個操作。
通常,資料元素可包括與具有相同長度之其他資料元素一起儲存於單一暫存器或記憶體位置中的個別資料片段。在與SSEx技術相關之封裝資料序列中,儲存於XMM暫存器中之資料元素的數目可為128個位元除以個別資料元素之位元長度。相似地,在與MMX及SSE技術相
關之封裝資料序列中,儲存於MMX暫存器中之資料元素的數目可為64位元除以個別資料元素之位元長度。儘管圖3A所說明之資料類型可為128個位元長,但本發明之實施例亦可運用64位元寬或其他大小之運算元而操作。此實例之封裝字格式320可為128個位元長且含有八個封裝字資料元素。每一封裝字含有十六個資訊位元。圖3A之封裝雙字格式330可為128位元個長且含有四個封裝雙字資料元素。每一封裝雙字資料元素含有三十二個資訊位元。封裝四倍字可為128個位元長且含有兩個封裝四倍字資料元素。
圖3B說明根據本發明之實施例的可能暫存器內資料儲存格式。每一封裝資料可包括多於一個獨立資料元素。說明三個封裝資料格式:封裝半341、封裝單342及封裝雙343。封裝半341、封裝單342及封裝雙343之一個實施例含有定點資料元素。對於另一實施例,封裝半341、封裝單342及封裝雙343中之一或多者可含有浮點資料元素。封裝半341之一個實施例可為128個位元長,含有八個16位元資料元素。封裝單342之一個實施例可為128個位元長且含有四個32位元資料元素。封裝雙343之一個實施例可為128個位元長且含有兩個64位元資料元素。應瞭解,此等封裝資料格式可進一步延伸至其他暫存器長度,例如,延伸至96位元、160位元、192位元、224位元、256位元、512位元或更多。
圖3C說明根據本發明之實施例的多媒體暫
存器中之各種有正負號及無正負號封裝資料類型表示。無正負號封裝位元組表示344說明無正負號封裝位元組在SIMD暫存器中之儲存。用於每一位元組資料元素之資訊可儲存於用於位元組0之位元7至位元0、用於位元組1之位元15至位元8、用於位元組2之位元23至位元16及最後用於位元組15之位元120至位元127中。因此,所有可用位元可用於暫存器中。此儲存配置可增加處理器之儲存效率。同樣,在存取十六個資料元素的情況下,現在可以並行方式對十六個資料元素執行一個操作。有正負號封裝位元組表示345說明有正負號封裝位元組之儲存。應注意,每一位元組資料元素之第八個位元可為正負號指示符。無正負號封裝字表示346說明字七至字零可如何儲存於SIMD暫存器中。有正負號封裝字表示347可相似於無正負號封裝字暫存器內表示346。應注意,每一字資料元素之第十六個位元可為正負號指示符。無正負號封裝雙字表示348展示如何儲存雙字資料元素。有正負號封裝雙字表示349可相似於無正負號封裝雙字暫存器內表示348。應注意,必要的正負號位元可為每一雙字資料元素之第三十二位元。
圖3D說明操作編碼(作業碼)之實施例。此外,格式360可包括暫存器/記憶體運算元定址模式,其與「IA-32 Intel Architecture Software Developer's Manual Volume 2:Instruction Set Reference」中所描述的一類型之作業碼格式對應,其可在全球資訊網(www)上在intel.com/design/litcentr自Intel Corporation(Santa
Clara,CA)獲得。在一個實施例中,且指令可由欄位361及362中之一或多者編碼。可每指令識別高達兩個運算元位置,包括高達兩個源運算元識別符364及365。在一個實施例中,目的地運算元識別符366可與源運算元識別符364相同,而在其他實施例中,其可不同。在另一實施例中,目的地運算元識別符366可與源運算元識別符365相同,而在其他實施例中,其可不同。在一個實施例中,由源運算元識別符364及365識別的源運算元中之一者可被文字字串比較操作之結果覆寫,而在其他實施例中,識別符364對應於源暫存器元素且識別符365對應於目的地暫存器元素。在一個實施例中,運算元識別符364及365可識別32位元或64位元之源運算元及目的地運算元。
圖3E說明根據本發明之實施例的具有四十或更多位元之另一可能操作編碼(作業碼)格式370。作業碼格式370與作業碼格式360對應且包含可選首碼位元組378。根據一個實施例之指令可由欄位378、371及372中之一或多者編碼。每指令高達兩個運算元位置可由源運算元識別符374及375且由首碼位元組378識別。在一個實施例中,首碼位元組378可用以識別32位元或64位元源運算元及目的地運算元。在一個實施例中,目的地運算元識別符376可與源運算元識別符374相同,而在其他實施例中,其可不同。對於另一實施例,目的地運算元識別符376可與源運算元識別符375相同,而在其他實施例中,其可不同。在一個實施例中,指令對由運算元識別符374及375
識別之運算元中之一或多者操作,且由運算元識別符374及375識別之一或多個運算元可被指令結果覆寫,而在其他實施例中,由識別符374及375識別之運算元可被寫入至另一暫存器中之另一資料元素。作業碼格式360及370允許由MOD欄位363及373及由可選比例-索引-基址及位移位元組部分地指定之暫存器至暫存器定址、記憶體至暫存器定址、按記憶體之暫存器定址、逐暫存器定址、即刻暫存器定址、暫存器至記憶體定址。
圖3F說明根據本發明之實施例的又一可能操作編碼(作業碼)格式。64位元單指令多資料(SIMD)算術運算可透過共處理器資料處理(CDP)指令而執行。操作編碼(作業碼)格式380描繪具有CDP作業碼欄位382及389之一個此類CDP指令。對於另一實施例,CDP指令之類型,操作可由欄位383、384、387及388中之一或多者編碼。可每指令識別高達三個運算元位置,包括高達兩個源運算元識別符385及390以及一個目的地運算元識別符386。共處理器之一個實施例可對八、十六、三十二及64位元值操作。在一個實施例中,可對整數資料元素執行指令。在一些實施例中,可使用條件欄位381有條件地執行指令。對於一些實施例,源資料大小可由欄位383編碼。在一些實施例中,可對SIMD欄位進行零(Z)、負數(N)、進位(C)及溢位(V)檢測。對於一些指令,飽和之類型可由欄位384編碼。
圖4A為根據本發明之實施例的說明有序管
線及暫存器重新命名級、無序發行/執行管線之方塊圖。圖4B為根據本發明之實施例的說明待包括於處理器中之有序架構核心及暫存器重新命名邏輯、無序發行/執行邏輯之方塊圖。圖4A中之實線方框說明有序管線,而虛線方框說明暫存器重新命名、無序發行/執行管線。相似地,圖4B中之實線方框說明有序架構邏輯,而虛線方框說明暫存器重新命名邏輯及無序發行/執行邏輯。
在圖4A中,處理器管線400可包括提取級402、長度解碼級404、解碼級406、分配級408、重新命名級410、排程(亦被稱為分派或發行)級412、暫存器讀取/記憶體讀取級414、執行級416、寫回/記憶體寫入級418、例外狀況處置級422,及認可級424。
在圖4B中,箭頭表示兩個或更多單元之間的耦接,且箭頭之方向指示彼等單元之間的資料流動方向。圖4B展示處理器核心490,其包括耦接至執行引擎單元450之前端單元430,且該兩者可耦接至記憶體單元470。
核心490可為精簡指令集計算(RISC)核心、複雜指令集計算(CISC)核心、超長指令字(VLIW)核心,或混合式或替代性核心類型。在一個實施例中,核心490可為特殊用途核心,諸如網路或通訊核心、壓縮引擎、圖形核心或類似者。
前端單元430可包括耦接至指令快取記憶體單元434之分支預測單元432。指令快取記憶體單元434可耦接至指令轉譯後援緩衝器(TLB)436。TLB 436可耦接
至指令提取單元438,指令提取單元438耦接至解碼單元440。解碼單元440可解碼指令,且產生作為輸出的一或多個微操作、微碼入口點、微指令、其他指令或其他控制信號,前述各者可自原始指令解碼,或以其他方式反映原始指令,或可自原始指令導出。可使用各種不同機制來實施解碼器。合適機制之實例包括但不限於查找表、硬體實施方案、可規劃邏輯陣列(PLA)、微碼唯讀記憶體(ROM)等等。在一個實施例中,指令快取記憶體單元434可進一步耦接至記憶體單元470中之層級2(L2)快取記憶體單元476。解碼單元440可耦接至執行引擎單元450中之重新命名/分配器單元452。
執行引擎單元450可包括耦接至淘汰單元454及一組一或多個排程器單元456之重新命名/分配器單元452。排程器單元456表示任何數目個不同排程器,包括保留站、中央指令窗等等。排程器單元456可耦接至實體暫存器檔案單元458。實體暫存器檔案單元458中之每一者表示一或多個實體暫存器檔案,其中之不同者儲存一或多個不同資料類型,諸如純量整數、純量浮點、封裝整數、封裝浮點、向量整數、向量浮點等等、狀態(例如,為待執行之下一指令之位址之指令指標)等等。實體暫存器檔案單元458可由淘汰單元154重疊以說明可實施暫存器重新命名及無序執行之各種方式(例如,使用一或多個重新排序緩衝器及一或多個淘汰暫存器檔案;使用一或多個未來檔案、一或多個歷史緩衝器及一或多個淘汰暫存器檔案;使
用暫存器映像及暫存器集區;等等)。通常,架構暫存器可自處理器外部或根據規劃師之觀點可見。暫存器可不限於任何已知特定類型之電路。各種不同類型之暫存器可為合適的,只要該等暫存器如本文中所描述而儲存及提供資料即可。合適暫存器之實例包括但可不限於專用實體暫存器、使用暫存器重新命名之動態分配實體暫存器、專用與動態分配實體暫存器之組合等等。淘汰單元454及實體暫存器檔案單元458可耦接至執行叢集460。執行叢集460可包括一組一或多個執行單元162及一組一或多個記憶體存取單元464。執行單元462可執行各種運算(例如,移位、加法、減法、乘法)且對各種類型之資料(例如,純量浮點、封裝整數、封裝浮點、向量整數、向量浮點)執行各種運算。雖然一些實施例可包括專用於特定功能或功能集合之數個執行單元,但其他實施例可包括僅一個執行單元或皆執行所有功能之多個執行單元。排程器單元456、實體暫存器檔案單元458及執行叢集460被展示為可能多個,此係因為某些實施例建立用於某些類型之資料/操作之單獨管線(例如,各自具有其自身排程器單元、實體暫存器檔案單元及/或執行叢集的純量整數管線、純量浮點/封裝整數/封裝浮點/向量整數/向量浮點管線及/或記憶體存取管線-且在單獨記憶體存取管線之狀況下,可實施僅此管線之執行叢集具有記憶體存取單元464之某些實施例)。亦應理解,在使用單獨管線的情況下,此等管線中之一或多者可為無序發行/執行且其餘部分為有序的。
該組記憶體存取單元464可耦接至記憶體單元470,記憶體單元470可包括耦接至資料快取記憶體單元474之資料TLB單元472,資料快取記憶體單元474耦接至層級2(L2)快取記憶體單元476。在一個例示性實施例中,記憶體存取單元464可包括載入單元、儲存位址單元及儲存資料單元,其中之每一者可耦接至記憶體單元470中之資料TLB單元472。L2快取記憶體單元476可耦接至快取記憶體之一或多個其他層級且最終耦接至主記憶體。
作為實例,例示性暫存器重新命名、無序發行/執行核心架構可如下實施管線400:1)指令提取438可執行提取級402及長度解碼級404;2)解碼單元440可執行解碼級406;3)重新命名/分配器單元452可執行分配級408及重新命名級410;4)排程器單元456可執行排程級412;5)實體暫存器檔案單元458及記憶體單元470可執行暫存器讀取/記憶體讀取級414;執行叢集460可執行執行級416;6)記憶體單元470及實體暫存器檔案單元458可執行寫回/記憶體寫入級418;7)各種單元可參與執行例外狀況處置級422;以及8)淘汰單元454及實體暫存器檔案單元458可執行認可級424。
核心490可支援一或多個指令集(例如,x86指令集(其中已運用較新版本而添加一些延伸);MIPS Technologies(Sunnyvale,CA)之MIPS指令集;ARM Holdings(Sunnyvale,CA)之ARM指令集(具有可選額外延伸,諸如NEON))。
應理解,核心可以多種方式支援多執行緒處理(執行操作或執行緒之兩個或更多平行集合)。多執行緒處理支援可藉由(例如)包括時間分片多執行緒處理、同時多執行緒處理(其中單一實體核心為實體核心同時進行多執行緒處理的執行緒中之每一者提供邏輯核心)或其組合而執行。此組合可包括(例如)時間分片提取及解碼,及此後的同時多執行緒處理,諸如在Intel®超執行緒處理技術中。
雖然可在無序執行之上下文中描述暫存器重新命名,但應理解,暫存器重新命名可用於有序架構中。雖然處理器之所說明實施例亦可包括單獨指令快取記憶體單元434及資料快取記憶體單元474以及共用L2快取記憶體單元476,但其他實施例可具有用於指令及資料兩者之單一內部快取記憶體,諸如層級1(L1)內部快取記憶體或多個層級之內部快取記憶體。在一些實施例中,系統可包括內部快取記憶體與可在核心及/或處理器外部的外部快取記憶體之組合。在其他實施例中,所有快取記憶體可在核心及/或處理器外部。
圖5A為根據本發明之實施例的處理器500之方塊圖。在一個實施例中,處理器500可包括多核心處理器。處理器500可包括以通訊方式耦接至一或多個核心502之系統代理510。此外,核心502及系統代理510可以通訊方式耦接至一或多個快取記憶體506。核心502、系統代理510及快取記憶體506可經由一或多個記憶體控制單
元552而以通訊方式耦接。此外,核心502、系統代理510及快取記憶體506可經由記憶體控制單元552而以通訊方式耦接至圖形模組560。
處理器500可包括用於互連核心502、系統代理510及快取記憶體506與圖形模組560之任何合適機構。在一個實施例中,處理器500可包括基於環之互連單元508,以將核心502、系統代理510及快取記憶體506與圖形模組560互連。在其他實施例中,處理器500可包括用於互連此等單元之任何數目個熟知技術。基於環之互連單元508可利用記憶體控制單元552來促進互連。
處理器500可包括一記憶體階層,其包含核心內之一或多個快取記憶體層級、一或多個共用快取記憶體單元(諸如快取記憶體506),或耦接至該組整合式記憶體控制器單元552之外部記憶體(未圖示)。快取記憶體506可包括任何合適快取記憶體。在一個實施例中,快取記憶體506可包括一或多個中間層級快取記憶體,諸如層級2(L2)、層級3(L3)、層級4(L4)或其他層級之快取記憶體、最後層級快取記憶體(LLC),及/或其組合。
在各種實施例中,核心502中之一或多者可執行多執行緒處理。系統代理510可包括用於協調及操作核心502之組件。系統代理單元510可包括(例如)電力控制單元(PCU)。PCU可為或可包括調節核心502之電力狀態所需要的邏輯及組件。系統代理510可包括用於驅動一或多個外部連接顯示器或圖形模組560之顯示引擎512。系統
代理510可包括介面以用於針對圖形之通訊匯流排。在一個實施例中,介面可由快速PCI(PCIe)實施。在一另外實施例中,介面可由快速圖形PCI(PEG)514實施。系統代理510可包括直接媒體介面(DMI)516。DMI 516可提供電腦系統之主機板或其他部分上之不同橋接器之間的連結。系統代理510可包括用於提供至計算系統之其他元件之PCIe連結之PCIe橋接器518。PCIe橋接器518可使用記憶體控制器520及同調邏輯522予以實施。
核心502可以任何合適方式予以實施。在架構及/或指令集方面,核心502可為均質的或異質的。在一個實施例中,核心502中之一些可為有序的,而其他可為無序的。在另一實施例中,核心502中之兩個或更多核心可執行同一指令集,而其他核心可僅執行彼指令集中之子集或不同指令集。
處理器500可包括一般用途處理器,諸如可購自Santa Clara,Calif.之Intel Corporation的CoreTM i3、i5、i7、2 Duo及Quad、XeonTM、ItaniumTM、XScaleTM或StrongARMTM處理器。處理器500可提供自另一公司,諸如ARM Holdings有限公司、MIPS等等。處理器500可為特殊用途處理器,諸如網路或通訊處理器、壓縮引擎、圖形處理器、共處理器、嵌入式處理器或類似者。處理器500可實施於一或多個晶片上。處理器500可為一或多個基板之部分及/或可使用數種程序技術中之任一者(諸如BiCMOS、CMOS或NMOS)而實施於該一或多個基板上。
在一個實施例中,快取記憶體506中之給定者可由核心502中之多個核心共用。在另一實施例中,快取記憶體506中之給定者可專用於核心502中之一者。快取記憶體506至核心502之指派可由快取記憶體控制器或其他合適機構處置。藉由實施給定快取記憶體506之時間配量,快取記憶體506中之給定者可由兩個或更多核心502共用。
圖形模組560可實施整合式圖形處理子系統。在一個實施例中,圖形模組560可包括圖形處理器。此外,圖形模組560可包括媒體引擎565。媒體引擎565可提供媒體編碼及視訊解碼。
圖5B為根據本發明之實施例的核心502之實例實施方案之方塊圖。核心502可包括以通訊方式耦接至無序引擎580之前端570。核心502可透過快取記憶體階層503而以通訊方式耦接至處理器500之其他部分。
前端570可以任何合適方式予以實施,諸如完全地或部分地由如上文所描述之前端201實施。在一個實施例中,前端570可透過快取記憶體階層503而與處理器500之其他部分通訊。在一另外實施例中,前端570可自處理器500之部分提取指令且準備使該等指令稍後隨著該等指令被傳遞至無序執行引擎580而在處理器管線中使用。
無序執行引擎580可以任何合適方式予以實施,諸如完全地或部分地由如上文所描述之無序執行引擎203實施。無序執行引擎580可準備自前端570接收之指令
以供執行。無序執行引擎580可包括分配模組1282。在一個實施例中,分配模組1282可分配處理器500之資源或其他資源(諸如暫存器或緩衝器)以執行給定指令。分配模組1282可在排程器(諸如記憶體排程器、快速排程器或浮點排程器)中進行分配。此等排程器在圖5B中可由資源排程器584表示。分配模組1282可由結合圖2所描述之分配邏輯完全地或部分地實施。資源排程器584可基於給定資源之源之就緒及執行指令所需要之執行資源之可用性來判定指令何時就緒以執行。資源排程器584可由(例如)如上文所論述之排程器202、204、206實施。資源排程器584可在一或多個資源上排程指令之執行。在一個實施例中,此等資源可在核心502內部,且可被說明為(例如)資源586。在另一實施例中,此等資源可在核心502外部且可為可由(例如)快取記憶體階層503存取。舉例而言,資源可包括記憶體、快取記憶體、暫存器檔案或暫存器。在核心502內部之資源可由圖5B中之資源586表示。必要時,可透過(例如)快取記憶體階層503來協調寫入至資源586或自其讀取之值與處理器500之其他部分。當指令被指派資源時,該等指令可置放於重新排序緩衝器588中。重新排序緩衝器588可在指令被執行時追蹤該等指令,且基於處理器500之任何合適準則來選擇性地重新排序其執行。在一個實施例中,重新排序緩衝器588可識別可獨立地執行的指令或一系列指令。此等指令或一系列指令可與其他此等指令並行地執行。核心502中之並行執行可由任何合適數目個單獨
執行區塊或虛擬處理器執行。在一個實施例中,共用資源(諸如記憶體、暫存器及快取記憶體)可為給定核心502內之多個虛擬處理器存取。在其他實施例中,共用資源可為處理器500內之多個處理實體存取。
快取記憶體階層503可以任何合適方式予以實施。舉例而言,快取記憶體階層503可包括一或多個較低或中間層級快取記憶體,諸如快取記憶體572、574。在一個實施例中,快取記憶體階層503可包括以通訊方式耦接至快取記憶體572、574之LLC 595。在另一實施例中,LLC 595可實施於可為處理器500之所有處理實體存取之模組590中。在一另外實施例中,模組590可實施於來自Intel,Inc.之處理器之非核心模組中。模組590可包括核心502之執行所必要的處理器500之部分或子系統,但可不實施於核心502內。除了LLC 595以外,模組590亦可包括(例如)硬體介面、記憶體同調性協調器、處理器間互連件、指令管線,或記憶體控制器。對可用於處理器500之RAM 599之存取可透過模組590(且更具體言之,LLC 595)而進行。此外,核心502之其他執行個體可相似地存取模組590。核心502之執行個體之協調可部分地透過模組590而促進。
圖6至圖8可說明適合於包括處理器500之例示性系統,而圖9可說明可包括核心502中之一或多者的例示性系統單晶片(SoC)。此項技術中所知的用於以下各者之其他系統設計及實施方案亦可為合適的:膝上型電腦、
桌上型電腦、手持型PC、個人數位助理、工程設計工作站、伺服器、網路裝置、網路集線器、交換器、嵌入式處理器、數位信號處理器(DSP)、圖形裝置、視訊遊戲裝置、機上盒、微控制器、蜂巢式電話、攜帶型媒體播放器、手持型裝置,及各種其他電子裝置。一般而言,併有如本文中所揭示之處理器及/或其他執行邏輯之很多種系統或電子裝置可為大體上合適的。
圖6說明根據本發明之實施例的系統600之方塊圖。系統600可包括可耦接至圖形記憶體控制器集線器(GMCH)620之一或多個處理器610、615。在圖6中運用虛線來表示額外處理器615之可選本質。
每一處理器610、615可為處理器500之某一版本。然而,應注意,整合式圖形邏輯及整合式記憶體控制單元可不存在於處理器610、615中。圖6說明GMCH 620可耦接至可為(例如)動態隨機存取記憶體(DRAM)之記憶體640。對於至少一個實施例,DRAM可與非依電性快取記憶體相關聯。
GMCH 620可為晶片組或晶片組之部分。GMCH 620可與處理器610、615通訊且控制處理器610、615與記憶體640之間的互動。GMCH 620亦可充當處理器610、615與系統600之其他元件之間的加速匯流排介面。在一個實施例中,GMCH 620經由多點匯流排(諸如前側匯流排(FSB)695)而與處理器610、615通訊。
此外,GMCH 620可耦接至顯示器645(諸
如平板顯示器)。在一個實施例中,GMCH 620可包括整合式圖形加速器。GMCH 620可進一步耦接至可用以將各種周邊裝置耦接至系統600之輸入/輸出(I/O)控制器集線器(ICH)650。外部圖形裝置660可包括為連同另一周邊裝置670耦接至ICH 650之離散圖形裝置。
在其他實施例中,額外或不同處理器亦可存在於系統600中。舉例而言,額外處理器610、615可包括可與處理器610相同之額外處理器、可與處理器610異質或不對稱之額外處理器、加速器(諸如圖形加速器或數位信號處理(DSP)單元)、場可規劃閘陣列,或任何其他處理器。在包括架構、微架構、熱、功率消耗特性及類似者之一系列優點度量方面,實體資源610、615之間可存在多種差異。此等差異可有效地將其自身顯現為處理器610、615之間的不對稱性及異質性。對於至少一個實施例,各種處理器610、615可駐留於同一晶粒封裝體中。
圖7說明根據本發明之實施例的第二系統700之方塊圖。如圖7所展示,多處理器系統700可包括點對點互連系統,且可包括經由點對點互連件750而耦接之第一處理器770及第二處理器780。處理器770及780中之每一者可為處理器500之某一版本,如處理器610、615中之一或多者。
雖然圖7可說明兩個處理器770、780,但應理解,本發明之範疇並不受到如此限制。在其他實施例中,一或多個額外處理器可存在於給定處理器中。
處理器770及780被展示為分別包括整合式記憶體控制器單元772及782。處理器770亦可包括作為其匯流排控制器單元之部分的點對點(P-P)介面776及778;相似地,第二處理器780可包括P-P介面786及788。處理器770、780可使用P-P介面電路778、788經由點對點(P-P)介面750而交換資訊。如圖7所展示,IMC 772及782可將該等處理器耦接至各別記憶體(即,記憶體732及記憶體734),該等記憶體在一個實施例中可為在本機附接至各別處理器的主記憶體之部分。
處理器770、780可各自使用點對點介面電路776、794、786、798經由個別P-P介面752、754而與晶片組790交換資訊。在一個實施例中,晶片組790亦可經由高效能圖形介面739而與高效能圖形電路738交換資訊。
共用快取記憶體(未圖示)可包括於兩個處理器中之任一處理器中或在兩個處理器外部,但經由P-P互連件而與該等處理器連接,使得可將任一處理器或兩個處理器之本機快取記憶體資訊儲存於共用快取記憶體中(若處理器被置於低電力模式)。
晶片組790可經由介面796而耦接至第一匯流排716。在一個實施例中,第一匯流排716可為周邊組件互連(PCI)匯流排,或諸如PCI高速匯流排或另一第三代I/O互連件匯流排之匯流排,但本發明之範疇並不受到如此限制。
如圖7所展示,各種I/O裝置714可連同匯流
排橋接器718耦接至第一匯流排716,匯流排橋接器718將第一匯流排716耦接至第二匯流排720。在一個實施例中,第二匯流排720可為低接腳計數(LPC)匯流排。在一個實施例中,各種裝置可耦接至第二匯流排720,包括(例如)鍵盤及/或滑鼠722、通訊裝置727及儲存單元728(諸如可包括指令/程式碼及資料730之磁碟機或其他大容量儲存裝置)。另外,音訊I/O 724可耦接至第二匯流排720。應注意,其他架構可為可能的。舉例而言,代替圖7之點對點架構,系統可實施多點匯流排或其他此類架構。
圖8說明根據本發明之實施例的第三系統800之方塊圖。圖7及圖8中之類似元件具有類似參考數字,且已自圖8省略圖7之某些態樣,以便避免混淆圖8之其他態樣。
圖8說明處理器870、880可分別包括整合式記憶體及I/O控制邏輯(「CL」)872及882。對於至少一個實施例,CL 872、882可包括整合式記憶體控制器單元,諸如上文關於圖5及圖7所描述之整合式記憶體控制器單元。此外,CL 872、882亦可包括I/O控制邏輯。圖8說明不僅記憶體832、834可耦接至CL 872、882,而且I/O裝置814亦可耦接至控制邏輯872、882。舊版I/O裝置815可耦接至晶片組890。
圖9說明根據本發明之實施例的SoC 900之方塊圖。圖5中之相似元件具有類似參考數字。又,虛線方框可表示較進階的SoC上之可選特徵。互連單元902可
耦接至:應用程式處理器910,其可包括一組一或多個核心902A至902N及共用快取記憶體單元906;系統代理單元910;匯流排控制器單元916;整合式記憶體控制器單元914;一組或一或多個媒體處理器920,其可包括整合式圖形邏輯908、用於提供靜態及/或視訊攝影機功能性之影像處理器924、用於提供硬體音訊加速之音訊處理器926,及用於提供視訊編碼/解碼加速之視訊處理器928;靜態隨機存取記憶體(SRAM)單元930;直接記憶體存取(DMA)單元932;及用於耦接至一或多個外部顯示器之顯示單元940。
圖10說明根據本發明之實施例的含有中央處理單元(CPU)及圖形處理單元(GPU)之處理器,其可執行至少一個指令。在一個實施例中,用以執行根據至少一個實施例之操作的指令可由CPU執行。在另一實施例中,該指令可由GPU執行。在又一實施例中,該指令可透過由GPU及CPU執行之操作的組合而執行。舉例而言,在一個實施例中,可接收及解碼根據一個實施例之指令以供在GPU上執行。經解碼指令內之一或多個操作可由CPU執行且結果被傳回至GPU以用於該指令之最終淘汰。相反地,在一些實施例中,CPU可充當主要處理器且GPU可充當共處理器。
在一些實施例中,受益於高度並行輸送量處理器之指令可由GPU執行,而受益於處理器之效能(受益於深度管線化架構)之指令可由CPU執行。舉例而言,圖
形、科學應用程式、金融應用程式及其他平行工作負載可受益於GPU之效能且被相應地執行,而較多依序應用程式(諸如作業系統核心程式或應用程式碼)可較好地適合於CPU。
在圖10中,處理器1000包括CPU 1005、GPU 1010、影像處理器1015、視訊處理器1020、USB控制器1025、UART控制器1030、SPI/SDIO控制器1035、顯示裝置1040、記憶體介面控制器1045、MIPI控制器1050、快閃記憶體控制器1055、雙資料速率(DDR)控制器1060、安全引擎1065,及I2S/I2C控制器1070。圖10之處理器中可包括其他邏輯及電路,包括較多CPU或GPU以及其他周邊介面控制器。
至少一個實施例之一或多個態樣可由儲存於機器可讀媒體上之代表性資料實施,該資料表示處理器內之各種邏輯,其在由機器讀取時致使機器製造用以執行本文中所描述之技術的邏輯。被稱為「IP核心」之此等表示可儲存於有形機器可讀媒體(「磁帶」)上,且供應至各種消費者或製造設施以載入至實際上製造該邏輯或處理器之製造機器中。舉例而言,IP核心(諸如由ARM Holdings有限公司開發之CortexTM處理器家族及由中國科學院計算技術研究所(ICT)開發之Loongson IP核心)可有使用權或出售給各種消費者或使用人(諸如Texas Instruments、Qualcomm、Apple或Samsung)且實施於由此等消費者或使用人生產之處理器中。
圖11為說明根據本發明之實施例的IP核心之開發之方塊圖。儲存體1130可包括模擬軟體1120及/或硬體或軟體模型1110。在一個實施例中,可經由記憶體1140(例如,硬碟)、有線連接(例如,網際網路)1150或無線連接1160將表示IP核心設計之資料提供至儲存體1130。可接著將由模擬工具及模型產生之IP核心資訊傳輸至製造設施,其中可由第3方製造IP核心資訊以執行根據至少一個實施例之至少一個指令。
在一些實施例中,一或多個指令可對應於第一類型或架構(例如,x86)且在不同類型或架構(例如,ARM)之處理器上予以轉譯或模仿。根據一個實施例之指令因此可在包括ARM、x86、MIPS、GPU或其他處理器類型或架構之任一處理器或處理器類型上執行。
圖12說明根據本發明之實施例的第一類型之指令可如何由不同類型之處理器模仿。在圖12中,程式1205含有可執行與根據一個實施例之指令相同或實質上相同之功能的一些指令。然而,程式1205之指令可屬於與處理器1215不同或不相容之類型及/或格式,此意謂程式1205中之類型的指令可不能夠由處理器1215原生地執行。然而,藉助於模仿邏輯1210,程式1205之指令可轉譯成原生地可由處理器1215執行之指令。在一個實施例中,可以硬體體現模仿邏輯。在另一實施例中,可以有形機器可讀媒體體現模仿邏輯,有形機器可讀媒體含有用以將程式1205中之類型之指令轉譯成原生地可由處理器1215執
行之類型的軟體。在其他實施例中,模仿邏輯可為固定功能或可規劃硬體與儲存於有形機器可讀媒體上之程式的組合。在一個實施例中,處理器含有模仿邏輯,而在其他實施例中,模仿邏輯存在於處理器外部且可由第三方提供。在一個實施例中,處理器可藉由執行含於處理器中或與處理器相關聯之微碼或韌體來載入體現於含有軟體之有形機器可讀媒體中的模仿邏輯。
圖13說明根據本發明之實施例的對比軟體指令轉換器之使用之方塊圖,該軟體指令轉換器用以將源指令集中之二進位指令轉換至目標指令集中之二進位指令。在所說明實施例中,指令轉換器可為軟體指令轉換器,但指令轉換器可以軟體、韌體、硬體或其各種組合予以實施。圖13展示可使用x86編譯器1304來編譯呈高階語言1302之程式以產生x86二進位碼1306,x86二進位碼1306可原生地由具有至少一個x86指令集核心之處理器1316執行。具有至少一個x86指令集核心之處理器1316表示可藉由相容地執行或以其他方式處理以下各者以便達成與具有至少一個x86指令集核心之Intel處理器實質上相同的結果而執行與具有至少一個x86指令集核心之Intel處理器實質上相同的功能的任一處理器:(1)Intel x86指令集核心之指令集的實質部分,或(2)目標為在具有至少一個x86指令集核心之Intel處理器上執行的應用程式或其他軟體之物件碼版本。x86編譯器1304表示可操作以產生x86二進位碼1306(例如,物件碼)之編譯器,x86二進位碼1306可在
具有或不具有額外連結處理的情況下在具有至少一個x86指令集核心之處理器1316上執行。相似地,圖13展示可使用替代性指令集編譯器1308來編譯呈高階語言1302之程式以產生替代性指令集二進位碼1310,替代性指令集二進位碼1310可原生地由不具有至少一個x86指令集核心之處理器1314(例如,具有執行MIPS Technologies(Sunnyvale,CA)之MIPS指令集及/或執行ARM Holdings(Sunnyvale,CA)之ARM指令集的核心之處理器)執行。指令轉換器1312可用以將x86二進位碼1306轉換成可原生地由不具有x86指令集核心之處理器1314執行的程式碼。此經轉換程式碼可不與替代性指令集二進位碼1310相同;然而,該經轉換程式碼將實現一般操作且由來自替代性指令集之指令構成。因此,指令轉換器1312表示透過模仿、模擬或任何其他程序而允許不具有x86指令集處理器或核心之處理器或其他電子裝置執行x86二進位碼1306的軟體、韌體、硬體或其組合。
圖14為根據本發明之實施例的處理器之指令集架構1400之方塊圖。指令集架構1400可包括任何合適數目或種類之組件。
舉例而言,指令集架構1400可包括處理實體,諸如一或多個核心1406、1407及圖形處理單元1415。核心1406、1407可透過任何合適機構(諸如透過匯流排或快取記憶體)而以通訊方式耦接至指令集架構1400之其餘部分。在一個實施例中,核心1406、1407可透過L2快取
記憶體控制1408(其可包括匯流排介面單元1409及L2快取記憶體1410)而以通訊方式耦接。核心1406、1407及圖形處理單元1415可透過互連件1410而以通訊方式耦接至彼此及至指令集架構1400之剩餘部分。在一個實施例中,圖形處理單元1415可使用界定將編碼及解碼特定視訊信號以供輸出之方式的視訊程式碼1420。
指令集架構1400亦可包括用於與電子裝置或系統之其他部分介接或通訊的任何數目或種類之介面、控制器或其他機構。此等機構可促進與(例如)周邊設備、通訊裝置、其他處理器或記憶體之互動。在圖14之實例中,指令集架構1400可包括液晶顯示器(LCD)視訊介面1425、用戶介面模組(SIM)介面1430、開機ROM介面1435、同步動態隨機存取記憶體(SDRAM)控制器1440、快閃控制器1445,及串列周邊介面(SPI)主控器單元1450。LCD視訊介面1425可將視訊信號之輸出自(例如)GPU 1415且透過(例如)行動產業處理器介面(MIPI)1490或高清晰度多媒體介面(HDMI)1495而提供至顯示器。舉例而言,此顯示器可包括LCD。SIM介面1430可提供至或自SIM卡或裝置之存取。SDRAM控制器1440可提供至或自記憶體(諸如SDRAM晶片或模組)之存取。快閃控制器1445可提供至或自記憶體(諸如快閃記憶體或RAM之其他執行個體)之存取。SPI主控器單元1450可提供至或自通訊模組(諸如實施諸如802.11之通訊標準的藍芽模組1470、高速3G數據機1475、全球定位系統模組1480或無線模組
1485)之存取。
圖15為根據本發明之實施例的處理器之指令集架構1500之更詳細方塊圖。指令架構1500可實施指令集架構1400之一或多個態樣。此外,指令集架構1500可說明用於在處理器內執行指令之模組及機構。
指令架構1500可包括以通訊方式耦接至一或多個執行實體1565之記憶體系統1540。此外,指令架構1500可包括以通訊方式耦接至執行實體1565及記憶體系統1540之快取及匯流排介面單元,諸如單元1510。在一個實施例中,指令至執行實體1564中之載入可由一或多個執行級執行。舉例而言,此等級可包括指令預提取級1530、雙指令解碼級1550、暫存器重新命名級155、發行級1560,及寫回級1570。
在一個實施例中,記憶體系統1540可包括經執行指令指標1580。經執行指令指標1580可儲存識別一批指令內最舊的未分派指令之值。最舊指令可對應於最低程式次序(PO)值。PO可包括指令之唯一編號。此指令可為由多個股線表示之執行緒內的單一指令。PO可用於排序指令中以確保程式碼之正確的執行語義。可藉由諸如評估至在指令中編碼之PO之增量而非絕對值的機制來重新建構PO。此經重新建構PO可被稱為「RPO」。雖然本文中可參考PO,但可將此PO與RPO互換地使用。股線可包括彼此資料相依之一連串指令。股線可由二進位轉譯器在編譯時間配置。執行股線之硬體可按根據各種指令之PO的次序
執行給定股線之指令。執行緒可包括多個股線,使得不同股線之指令可彼此相依。給定股線之PO可為股線中尚未自發行級分派至執行的最舊指令之PO。因此,在給出多個股線之執行緒的情況下,每一股線包括按PO排序之指令,經執行指令指標1580可將最舊(由最低編號所說明)PO儲存於執行緒中。
在另一實施例中,記憶體系統1540可包括淘汰指標1582。淘汰指標1582可儲存識別最後經淘汰指令之PO的值。淘汰指標1582可由(例如)淘汰單元454設定。若尚未淘汰指令,則淘汰指標1582可包括空值。
執行實體1565可包括可供處理器執行指令的任何合適數目及種類之機制。在圖15之實例中,執行實體1565可包括ALU/乘法單元(MUL)1566、ALU 1567,及浮點單元(FPU)1568。在一個實施例中,此等實體可使用含於給定位址1569內之資訊。執行實體1565與級1530、1550、1555、1560、1570之組合可共同地形成執行單元。
單元1510可以任何合適方式予以實施。在一個實施例中,單元1510可執行快取記憶體控制。在此實施例中,單元1510可因此包括快取記憶體1525。在一另外實施例中,快取記憶體1525可被實施為具有任何合適大小之L2統一快取記憶體,諸如零、128k、256k、512k、1M或2M位元組之記憶體。在另一另外實施例中,快取記憶體1525可實施於錯誤校正碼記憶體中。在另一實施例中,單
元1510可執行至處理器或電子裝置之其他部分的匯流排介接。在此實施例中,單元1510可因此包括用於在互連件、處理器內匯流排、處理器間匯流排或其他通訊匯流排、埠或線路上通訊之匯流排介面單元1520。匯流排介面單元1520可提供介接以便執行(例如)記憶體及輸入/輸出位址之產生以用於在執行實體1565與系統的在指令架構1500外部之部分之間傳送資料。
為了進一步促進匯流排介面單元1520之功能,匯流排介面單元1520可包括用於產生中斷及至處理器或電子裝置之其他部分之其他通訊的中斷控制及散佈單元1511。在一個實施例中,匯流排介面單元1520可包括處置快取記憶體存取及多個處理核心之同調性的窺探控制單元1512。在一另外實施例中,為了提供此功能性,窺探控制單元1512可包括處置不同快取記憶體之間的資訊交換之快取記憶體至快取記憶體傳送單元。在另一另外實施例中,窺探控制單元1512可包括一或多個窺探篩選器1514,窺探篩選器1514監測其他快取記憶體(未圖示)之同調性,使得快取記憶體控制器(諸如單元1510)不必直接執行此監測。單元1510可包括用於使指令架構1500之動作同步的任何合適數目個計時器1515。單元1510亦可包括AC埠1516。
記憶體系統1540可包括用於儲存用於指令架構1500之處理需要之資訊的任何合適數目及種類之機構。在一個實施例中,記憶體系統1504可包括用於儲存資
訊之載入儲存單元1530,諸如寫入至記憶體或暫存器或自記憶體或暫存器讀取之緩衝器。在另一實施例中,記憶體系統1504可包括轉譯後援緩衝器(TLB)1545,其提供位址值在實體位址與虛擬位址之間的查找。在又一實施例中,匯流排介面單元1520可包括用於促進對虛擬記憶體之存取的記憶體管理單元(MMU)1544。在再一實施例中,記憶體系統1504可包括預提取器1543以用於在指令實際上需要執行之前向記憶體請求此等指令,以便縮減潛時。
用以執行指令之指令架構1500之操作可透過不同級而執行。舉例而言,在使用單元1510的情況下,指令預提取級1530可透過預提取器1543來存取指令。可將所擷取之指令儲存於指令快取記憶體1532中。預提取級1530可啟用用於快速迴路模式之選項1531,其中執行形成足夠小以擬合於給定快取記憶體內之迴路之一系列指令。在一個實施例中,可執行此執行而無需自(例如)指令快取記憶體1532存取額外指令。對預提取何指令之判定可由(例如)分支預測單元1535進行,分支預測單元1535可存取全域歷史1536中之執行之指示、目標位址1537之指示,或傳回堆疊1538之內容,以判定接下來將執行程式碼之分支1557中的哪一者。結果,可能可預提取此等分支。分支1557可透過如下文所描述之其他操作級而產生。指令預提取級1530可將指令以及關於未來指令之任何預測提供至雙指令解碼級。
雙指令解碼級1550可將經接收指令轉譯成
可執行的基於微碼之指令。雙指令解碼級1550可在每時脈循環同時解碼兩個指令。此外,雙指令解碼級1550可將其結果傳遞至暫存器重新命名級1555。此外,雙指令解碼級1550可自其解碼及微碼之最後執行來判定任何所得分支。此等結果可輸入至分支1557中。
暫存器重新命名級1555可將對虛擬暫存器或其他資源之參考轉譯成對實體暫存器或資源之參考。暫存器重新命名級1555可包括暫存器集區1556中的此映像之指示。暫存器重新命名級1555可在接收到指令時更改該等指令且將結果發送至發行級1560。
發行級1560可將命令發行或分派至執行實體1565。此發行可以無序方式執行。在一個實施例中,可在執行多個指令之前將該等指令保持於發行級1560。發行級1560可包括用於保持此等多個命令之指令佇列1561。基於任何可接受準則(諸如用於給定指令之執行的資源之可用性或適用性),指令可由發行級1560發行至特定處理實體1565。在一個實施例中,發行級1560可對指令佇列1561內之資料重新排序,使得所接收之第一指令可不為被執行之第一指令。基於指令佇列1561之排序,可將額外分支資訊提供至分支1557。發行級1560可將指令傳遞至執行實體1565以供執行。
在執行後,寫回級1570就可將資料寫入至暫存器、佇列或指令集架構1500之其他結構中,以傳達給定命令之完成。取決於配置於發行級1560中之指令之次序,
寫回級1570之操作可使額外指令能夠被執行。指令集架構1500之執行可由追蹤單元1575監測或除錯。
圖16為根據本發明之實施例的用於處理器之指令集架構之執行管線1600之方塊圖。執行管線1600可說明(例如)圖15之指令架構1500之操作。
執行管線1600可包括步驟或操作之任何合適組合。在1605中,可進行接下來將執行之分支之預測。在一個實施例中,此等預測可基於指令之先前執行及其結果。在1610中,可將對應於經預測執行分支之指令載入至指令快取記憶體中。在1615中,可提取指令快取記憶體中之一或多個此等指令以供執行。在1620中,可將已提取之指令解碼成微碼或更特定的機器語言。在一個實施例中,可同時解碼多個指令。在1625中,可重新指派經解碼指令內對暫存器或其他資源之參考。舉例而言,可運用對對應實體暫存器之參考來替換對虛擬暫存器之參考。在1630中,可將指令分派至佇列以供執行。在1640中,可執行指令。可以任何合適方式執行此執行。在1650中,可將指令發行至合適執行實體。執行指令之方式可取決於執行指令之特定實體。舉例而言,在1655處,ALU可執行算術功能。ALU可將單一時脈循環用於其操作,以及利用兩個移位器。在一個實施例中,可使用兩個ALU,且因此,在1655處可執行兩個指令。在1660處,可進行所得分支之判定。程式計數器可用以指定分支將到達之目的地。1660可在單一時脈循環內執行。在1665處,可由一或多個FPU執行浮
點算術。浮點運算可需要執行多個時脈循環,諸如兩個至十個循環。在1670處,可執行乘法及除法運算。此等運算可在四個時脈循環中執行。在1675處,可執行至管線1600之暫存器或其他部分之載入及儲存操作。該等操作可包括載入及儲存位址。此等操作可在四個時脈循環中執行。在1680處,可如由1655至1675之所得操作所需要而執行寫回操作。
圖17為根據本發明之實施例的用於利用處理器1710之電子裝置1700之方塊圖。舉例而言,電子裝置1700可包括筆記型電腦、超級本、電腦、塔式伺服器、架式伺服器、刀鋒伺服器、膝上型電腦、桌上型電腦、平板電腦、行動裝置、電話、嵌入式電腦,或任何其他合適電子裝置。
電子裝置1700可包括以通訊方式耦接至任何合適數目或種類之組件、周邊設備、模組或裝置的處理器1710。此耦接可由諸如以下各者的任何合適種類之匯流排或介面實現:I2C匯流排、系統管理匯流排(SMBus)、低接腳計數(LPC)匯流排、SPI、高清晰度音訊(HDA)匯流排、串列進階附接技術(SATA)匯流排、USB匯流排(版本1、2、3),或通用非同步接收器/傳輸器(UART)匯流排。
舉例而言,此等組件可包括顯示器1724、觸控螢幕1725、觸控板1730、近場通訊(NFC)單元1745、感測器集線器1740、熱感測器1746、快速晶片組(EC)1735、受信任平台模組(TPM)1738、BIOS/韌體/快閃記憶體
1722、數位信號處理器1760、磁碟機1720(諸如固態磁碟(SSD)或硬碟機(HDD))、無線區域網路(WLAN)單元1750、藍芽單元1752、無線廣域網路(WWAN)單元1756、全球定位系統(GPS)、攝影機1754(諸如USB 3.0攝影機),或以(例如)LPDDR3標準而實施之低電力雙資料速率(LPDDR)記憶體單元1715。此等組件可各自以任何合適方式予以實施。
此外,在各種實施例中,其他組件可透過上文所論述之組件而以通訊方式耦接至處理器1710。舉例而言,加速度計1741、環境光感測器(ALS)1742、羅盤1743及迴轉儀1744可以通訊方式耦接至感測器集線器1740。熱感測器1739、風扇1737、鍵盤1746及觸控板1730可以通訊方式耦接至EC 1735。揚聲器1763、頭戴式耳機1764及麥克風1765可以通訊方式耦接至音訊單元1764,該音訊單元又可以通訊方式耦接至DSP 1760。音訊單元1764可包括(例如)音訊編解碼器及D類放大器。SIM卡1757可以通訊方式耦接至WWAN單元1756。諸如WLAN單元1750及藍芽單元1752之組件以及WWAN單元1756可以下一代外觀尺寸(next generation form factor;NGFF)予以實施。
本發明之實施例涉及用於檢測浮點消抵效應之指令及處理邏輯。圖18為用於檢測浮點消抵效應之指令及邏輯的系統1800之實例實施例之說明。系統1800可包括處理器、SoC、積體電路或其他機構。舉例而言,系統1800可包括處理器1802。儘管在圖18中將處理器1802展
示及描述為實例,但可使用任何合適機構。處理器1802可包括用於檢測浮點消抵效應之任何合適機構。在一個實施例中,此等機構可以硬體予以實施。處理器1802可由圖1至圖17所描述之元件完全地或部分地實施。
在一個實施例中,系統1800可包括用於浮點算術之消抵效應檢測單元1826。系統1800可在系統1800之任何合適部分中包括消抵效應檢測單元1826。舉例而言,消抵效應檢測單元1826可被實施為有序或無序執行管線1816內之執行單元1822。在另一實例中,消抵效應檢測單元1826可實施於與處理器1802之主核心1814分離的智慧財產權(IP)核心1828內。消抵效應檢測單元1826可由處理器之電路系統或硬體計算邏輯之任何合適組合實施。
浮點單元可用於高效能計算(HPC)及其他應用(包括行動及桌上型計算)中以用科學記法來表示數。此表示包括有限準確度,此引起捨位誤差。彼此接近之值的相加或相減可引起在運算之前累積的捨位誤差之非預期擴大。因此,一連串浮點計算可造成消抵效應或災難性消抵。在各種實施例中,消抵效應檢測單元1826可分析浮點運算以檢測是否已發生消抵效應。
在處理浮點值時檢測及傳信消抵效應之存在可在計算上付出大的代價。基於軟體之解決方案(其中用於檢測及傳信消抵效應之程式碼在解碼於處理器1802上時在典型執行單元上簡單地執行)常常為慢速或高功率消耗的。消抵效應檢測單元1826可實施用以高效地檢測消抵
效應之區塊。處理器1802可辨識(隱含地或透過特定指令之解碼及執行)需要對浮點計算檢查消抵效應之存在。在此等狀況下,消抵效應檢測單元1826可分擔消抵效應檢測之計算。在一個實施例中,消抵效應檢測單元1826可為指令串流1804中待執行之特定指令的目標。此等特定指令可由(例如)編譯器產生,或可由產生指令串流1804之程式碼之描圖器指定。該指令可包括於經界定以用於由處理器1802或消抵效應檢測單元1826執行之程式庫中。在另一實施例中,消抵效應檢測單元1826可為處理器1802之部分的目標,其中處理器1802辨識指令串流1804中用以執行具有用於檢測消抵效應之所要臨限值之浮點指令的嘗試。
指令1830可對應於消抵效應檢測單元1826之使用。可使用單獨指令或藉由在計算浮點結果之每一指令中包括額外運算元來設定臨限值控制設定THLD。在一個實施例中,具有THLD控制參數之SETCONTROLFPQQ指令可設定控制暫存器中之適當欄位。在另一實施例中,具有浮點結果之每一指令可包括THLD控制設定。舉例而言,除了可包括兩個源浮點暫存器及一目的地浮點暫存器之典型運算元以外,諸如FADD、FADDP、FIADD、FSUB、FSUBP、FISUB之基本浮點指令亦可包括THLD參數。相似地,ADD及SUB指令或此等指令之向量形式VADD及VSUB可包括THLD參數。可包括此參數而不管運算之資料類型,包括純量單精確度(SS)、純量雙精確度(SD)、封裝單精確度(PS)及封裝雙精確度(PD)。同樣地,
諸如ADDSUBPD及ADDSUBPS之複雜算術指令可包括THLD參數。最後,諸如VFMADD、VFNMADD、VFMSUB、VFNMSUB、VFMADDSUB及VFMSUBADD之FMA指令可包括THLD參數以指定用於消抵效應檢測之臨限值。FMA指令包括任何合適資料類型,包括上文針對向量指令所列出之資料類型,以及用來處理源運算元之任何合適次序。此參數THLD連同界定浮點結果之指令之任何其他參數可呈任何合適形式,包括用於排列指令之參數旗標、顯式參數、所需參數、具有假定預設值之可選參數,或儲存於不要求資訊作為參數顯式地傳遞之暫存器或其他已知位置中之固有參數。
可自指令串流1804接收指令,指令串流1804可駐留於系統1800之記憶體子系統內。指令串流1804可包括於系統1800之處理器1802之任何合適部分中。在一個實施例中,指令串流1804A可包括於SoC、系統或其他機構中。在另一實施例中,指令串流1804B可包括於處理器、積體電路或其他機構中。處理器1802可包括前端1806,前端1806可自指令串流1804接收指令且使用解碼管線級來解碼該等指令。經解碼指令可由執行管線1816之分配單元1818及排程器1820分派、分配及排程以供執行且分配至特定執行單元1822。在執行之後,指令可由淘汰單元1824中之寫回級或淘汰級淘汰。若處理器1802無序地執行指令,則分配單元1818可重新命名指令且該等指令可被輸入至結合淘汰單元之重新排序緩衝器1824中。可淘汰指令,
就如同其係按次序執行。此執行管線化之各種部分可由一或多個核心1814執行。
消抵效應檢測單元1826可以任何合適方式實施。在一個實施例中,消抵效應檢測單元1826可由浮點單元中之電路系統實施。在另一實施例中,消抵效應檢測單元1826可包括或可以通訊方式耦接至記憶體元件以儲存對於檢測消抵效應所必要之資訊。在一另外實施例中,消抵效應檢測單元1826可為能夠存取浮點指令運算元之單獨執行單元。
在一個實施例中,消抵效應檢測單元1826可包括用以判定是否在檢測到消抵效應之狀況下傳信例外狀況的電路系統。在另一實施例中,消抵效應檢測單元1826可在狀態暫存器欄位中設定與消抵效應相關聯之旗標。
假定值A及B彼此接近,則相對誤差可與t之指數及位置成比例。因此,經正規化結果可具有誤差2t(ε-δ),其中初始相關誤差係藉由將誤差乘以2t之正規化而擴大。
雖然在本發明中將各種操作描述為由處理器1802之特定組件執行,但功能性可由處理器1802之任何
合適部分執行。
圖19說明根據本發明之實施例的系統1800之實例操作及各種部分之實施方案。
在一個實施例中,消抵效應之檢測可由單獨指令控制。該指令可指示必須被超過以便傳信消抵效應之所要臨限值。在另一實施例中,消抵效應之檢測可由用於關聯浮點、SIMD或混合乘加(FMA)指令之可選旗標控制。舉例而言,FMA指令可將乘法及加法組合至單一指令中或將乘法及減法組合至單一指令中。FMA指令可對純量浮點或SIMD資料進行運算。FMA指令之目的地暫存器可儲存將兩個值相乘且將第三值加至彼乘積或自彼乘積減去第三值(在此期間可發生消抵效應)之結果。
在一個實施例中,可在將兩個浮點數相減時發生消抵效應。兩個指向點數可在浮點、SIMD或FMA指令內相減。具有有效位數1902之第一浮點運算元可乘以(1918)基數1912。具有有效位數1904之第二浮點運算元可乘以(1920)另一基數1910。可在1926中自第一運算元減去第二運算元。變數t可為兩個運算元之尾數中的第一位置,在該位置中值不同。位置1932及1934可對應於t處之第一尾數及第二尾數之值。尾數之前置位元可相同,包括前置位元1938及1940以及由a1至at-1表示之前t-1個位元。尾數之後置位元在兩個運算元之間可為唯一的,如由xt+1至x52及yt+1至y52表示。
減法(1926)之結果可為具有有效位數1906
之輸出乘以(1922)基數1914。該輸出可含有具有零值之前置位元1942,此係因為兩個源運算元之值可相似。相似地,有效位數1906中在位置1936中之t之前的所有位置可為零。為了將前置位元位置更新為非零值,可在1928中將輸出左移t個位元。此移位操作可針對區段1946中之t數目個後置位元插入零。若源運算元含有可在先前計算或量測期間累積之誤差,則正規化程序可將該誤差之相對有效值擴大2t。歸因於在浮點加法或減法運算期間之前置有效位元消抵的相對誤差之擴大可被稱為災難性消抵。程式碼之描圖器可需要進一步分析災難性消抵以重新描圖程式碼。
在另一實施例中,經正規化結果1930可為浮點加法運算之輸出。在一另外實施例中,經正規化結果1930可為SIMD加法或減法運算之輸出,在該運算中可輸出一組結果。在又一實施例中,經正規化結果1930可為加法、減法之FMA運算或對SIMD值之FMA運算的輸出。
在一個實施例中,消抵效應檢測單元1826可分析兩個源運算元以判定經正規化結果1930是否含有災難性消抵。該單元可使用第一運算元之基數1912內的指數及第二運算元之基數1910內的指數。消抵效應檢測單元1826亦可計算對應於兩個輸入之兩個指數的最大值。兩個輸入可具有浮點表示或呈另一格式。消抵效應檢測單元1826可藉由評估最大指數與浮點結果之浮點指數之間的差而判定是否發生災難性消抵。在一個實施例中,若經評估差大於零,則可傳信消抵效應。在另一實施例中,臨限
值判定是否可傳信消抵效應。在一個實施例中,該臨限值可由軟體程式碼之編譯器設定。在另一實施例中,該臨限值可由程式碼之描圖器設定。
圖20為根據本發明之實施例的用於檢測浮點消抵效應之實例方法2000之方塊圖。方法2000可由圖1至圖19所展示之元件中之任一者實施。方法2000可由任何合適準則起始且可在任何合適點起始操作。在一個實施例中,方法2000可在2005處起始操作。方法2000可包括比所說明之彼等步驟更多或更少的步驟。此外,方法2000可以與下文所說明之次序不同的次序執行其步驟。方法2000可在任何合適步驟處終止。此外,方法2000可在任何合適步驟處重複操作。方法2000可與方法2000之其他步驟或其他方法中之其他步驟並行地執行其步驟中之任一者。
在2005處,在一個實施例中,可接收計算以浮點表示之結果的一或多個指令。可接收、解碼、分配及執行該等指令。該等指令可指定消抵效應檢測單元1826判定在指令之執行期間是否發生消抵效應。在另一實施例中,可接收一指令以實現對浮點消抵效應之檢測。可接收、解碼、分配及執行該指令。該指令可特定地指定由消抵效應檢測單元1826進行之處置,或其可判定該指令可由消抵效應檢測單元處置。與檢測消抵效應相關之輸入可被交遞至消抵效應檢測單元以供處理。2005可由(例如)前端、核心、執行單元或其他合適元件執行。
在2010處,在一個實施例中,可分析一或多
個指令以設定用於消抵通知之臨限值。經檢測之經計算消抵可需要超過臨限值以便使方法2000傳信已發生災難性消抵,或使方法2000設定指示已發生災難性消抵之旗標。在一個實施例中,臨限值可儲存於一般用途暫存器中。在另一實施例中,臨限值可被儲存為浮點控制暫存器中之欄位。在一另外實施例中,臨限值可被指定為與一或多個指令相關聯之即刻值。
在2015處,在一個實施例中,可運用具有浮點表示之結果來判定兩個源運算元之間的最大指數。在另一實施例中,可自源運算元計算最大指數。源運算元可呈浮點表示或另一格式。在2020處,在一個實施例中,可判定浮點結果之浮點指數。浮點結果之浮點指數可由浮點邏輯單元計算。因此,結果之浮點指數可為包括源值之加法及減法之相關計算的函數,其中結果使用浮點表示。
在2025處,在一個實施例中,可透過自最大指數減去結果之浮點指數而計算經檢測消抵。
在2030處,在一個實施例中,可對照臨限值來評估經檢測消抵值。臨限值可預設為零或某一其他固定值。臨限值亦可由程式碼之編譯器或程式碼之描圖器設定。若經檢測值大於臨限值,則可傳信消抵效應。
在2035處,在一個實施例中,可設定對應於經檢測消抵之旗標。具有值零之旗標可對應於消抵效應之缺乏,且值一可對應於消抵效應之存在。可使用消抵效應檢測單元1826針對每一浮點結果來更新該旗標,或可針對
所有指令將該旗標初始化為零。該旗標可駐留於對應於指令之執行的狀態暫存器欄位內。規劃師可需要檢查狀態暫存器欄位中之旗標的狀態以判定消抵效應之存在。
在2040處,在一個實施例中,可判定是否設定遮罩位元以控制是否傳信消抵例外狀況。遮罩位元可由程式碼之編譯器或程式碼之描圖器設定。遮罩位元可駐留於對應於指令之執行的控制欄位中,諸如MXCSR控制欄位中。
在2045處,在一個實施例中,可藉由基於未設定遮罩位元之判定而報告例外狀況來傳信消抵效應。若設定遮罩位元,則可不報告消抵效應例外狀況。在一個實施例中,遮罩位元可控制在2035中的旗標之設定及在2045中的例外狀況之傳信兩者。
在2050處,可由(例如)淘汰單元淘汰一或多個指令。方法2000可視情況而重複或終止。
本文中所揭示之機制之實施例可以硬體、軟體、韌體或此等實施方法之組合予以實施。本發明之實施例可被實施為執行於可規劃系統上之電腦程式或程式碼,該可規劃系統包含至少一個處理器、一儲存系統(包括依電性及非依電性記憶體及/或儲存元件)、至少一個輸入裝置,及至少一個輸出裝置。
可將程式碼應用於輸入指令以執行本文中所描述之功能且產生輸出資訊。可以已知方式將輸出資訊應用於一或多個輸出裝置。出於此應用之目的,處理系統
可包括具有諸如數位信號處理器(DSP)、微控制器、特殊應用積體電路(ASIC)或微處理器之處理器的任何系統。
可以高階程序性或物件導向式規劃語言實施程式碼以與處理系統通訊。視需要,亦可以組譯語言或機器語言實施程式碼。事實上,本文中所描述之機制之範疇並不限於任一特定規劃語言。在任何狀況下,該語言可為編譯或解譯語言。
可由儲存於機器可讀媒體上的表示處理器內之各種邏輯的代表性指令實施至少一實施例之一或多個態樣,該等代表性指令在由機器讀取時致使該機器製造用以執行本文中所描述之技術的邏輯。被稱為「IP核心」之此等表示可儲存於有形機器可讀媒體上,且供應至各種消費者或製造設施以載入至實際上製造該邏輯或處理器之製造機器中。
此等機器可讀儲存媒體可包括但不限於由機器或裝置製造或形成之物品的非暫時性有形配置,包括儲存媒體,諸如硬碟、包括軟碟的任何其他類型之光碟、光學光碟、緊密光碟唯讀記憶體(CD-ROM)、可重寫緊密光碟(CD-RW)及磁光碟、諸如唯讀記憶體(ROM)之半導體裝置、諸如動態隨機存取記憶體(DRAM)、靜態隨機存取記憶體(SRAM)之隨機存取記憶體(RAM)、可抹除可規劃唯讀記憶體(EPROM)、快閃記憶體、電可抹除可規劃唯讀記憶體(EEPROM)、磁卡或光卡,或適合於儲存電子指令的任何其他類型之媒體。
因此,本發明之實施例亦可包括含有指令或含有界定本文中所描述之結構、電路、設備、處理器及/或系統特徵之設計資料(諸如硬體描述語言(HDL))的非暫時性有形機器可讀媒體。此等實施例亦可被稱作程式產品。
在一些狀況下,指令轉換器可用以將指令自源指令集轉換至目標指令集。舉例而言,指令轉換器可將指令轉譯(例如,使用靜態二進位轉譯、包括動態編譯之動態二進位轉譯)、轉化、模仿或以其他方式轉換至待由核心處理之一或多個其他指令。指令轉換器可以軟體、硬體、韌體或其組合予以實施。指令轉換器可在處理器上、在處理器外,或部分地在處理器上且部分地在處理器外。
因此,揭示用於執行根據至少一個實施例之一或多個指令之技術。雖然已描述且在隨附圖式中展示某些例示性實施例,但應理解,此等實施例僅僅說明而不限定其他實施例,且此等實施例並不限於所展示及描述之特定構造及配置,此係因為一般熟習此項技術者在研究本發明後就可想到各種其他修改。在諸如此技術之技術領域(其中增長快速且另外進步不易於預見)中,在不脫離本發明之原理或隨附申請專利範圍之範疇的情況下,可如藉由實現技術進步所促進而易於對所揭示實施例之配置及細節進行修改。
在本發明之一些實施例中,一種處理器可包括:用以解碼一指令之一前端;一執行單元;以及用以將該指令指派至該執行單元以執行該指令之一分配器或其他
機構。該指令可用以計算經受一消抵效應之一浮點結果。結合以上實施例中之任一者,在一實施例中,該執行單元可包括一臨限值。該臨限值可用於控制該消抵效應之通知。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於自兩個源值計算一最大指數的一第一邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於判定該浮點結果之一浮點指數的一第二邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於透過自該最大指數減去該浮點指數而計算一經檢測消抵值的一第三邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於比較該經檢測消抵值與該臨限值的一第四邏輯。
結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標的一第五邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括一第五邏輯及第六邏輯。該第五邏輯可用於判定是否設定一遮罩位元以防止傳信該消抵效應。該第六邏輯可用於基於未設定該遮罩位元之該判定且基於該經檢測消抵值與該臨限值之該比較而傳信一例外狀況。結合以上實施例中之任一者,在一實施例中,該比較可判定該經檢測消抵值是否大於該臨限值。結合以上實施例中之任一者,在一實施例中,該指令可為一浮點加法指令。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於將該兩個
源值相加的一第五邏輯。結合以上實施例中之任一者,在一實施例中,該指令可為一混合乘加指令。結合以上實施例中之任一者,在一實施例中,至該混合乘加指令之兩個輸入之乘積對應於該兩個源值中之另一者。結合以上實施例中之任一者,在一實施例中,至該混合乘加指令之一個輸入對應於該兩個源值中之一者。結合以上實施例中之任一者,在一實施例中,該臨限值可使用一浮點控制暫存器予以設定。結合以上實施例中之任一者,在一實施例中,該臨限值可由一先前指令設定。
在本實施例中之一些中,一種方法可包括設定一臨限值以控制與計算一浮點結果相關聯之一消抵效應之通知。結合以上實施例中之任一者,在一實施例中,該方法可包括自兩個源值計算一最大指數。結合以上實施例中之任一者,在一實施例中,該方法可包括判定該浮點結果之一浮點指數。結合以上實施例中之任一者,在一實施例中,該方法可包括透過自該最大指數減去該浮點指數而計算一經檢測消抵值。結合以上實施例中之任一者,在一實施例中,該方法可包括比較該經檢測消抵值與該臨限值。
結合以上實施例中之任一者,在一實施例中,該方法可包括基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標。結合以上實施例中之任一者,在一實施例中,該方法可包括判定是否設定一遮罩位元以防止傳信該消抵效應。結合以上實施例中之任一者,在一實施例中,該方法可包括基於未設定該遮罩位元之該判定且基
於該經檢測消抵值與該臨限值之該比較而傳信一例外狀況。結合以上實施例中之任一者,在一實施例中,該比較可判定該經檢測消抵值是否大於該臨限值。結合以上實施例中之任一者,在一實施例中,該方法可包括處理一浮點加法運算。結合以上實施例中之任一者,在一實施例中,該方法可包括藉由計算至一混合乘加運算之兩個輸入之一乘積且使用該乘積作為該兩個源值中之一者來處理該混合乘加運算。結合以上實施例中之任一者,在一實施例中,該方法可包括使用一浮點控制暫存器來設定該臨限值。
在本發明之一些實施例中,一種系統可包括:用以解碼一指令之一前端;一執行單元;以及用以將該指令指派至該執行單元以執行該指令之一分配器或其他機構。該指令可用以計算經受一消抵效應之一浮點結果。結合以上實施例中之任一者,在一實施例中,該執行單元可包括一臨限值。該臨限值可用於控制該消抵效應之通知。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於自兩個源值計算一最大指數的一第一邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於判定該浮點結果之一浮點指數的一第二邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於透過自該最大指數減去該浮點指數而計算一經檢測消抵值的一第三邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於比較該經檢測消抵值與該臨限值的一第四邏輯。
結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標的一第五邏輯。結合以上實施例中之任一者,在一實施例中,該執行單元可包括一第五邏輯及第六邏輯。該第五邏輯可用於判定是否設定一遮罩位元以防止傳信該消抵效應。該第六邏輯可用於基於未設定該遮罩位元之該判定且基於該經檢測消抵值與該臨限值之該比較而傳信一例外狀況。結合以上實施例中之任一者,在一實施例中,該比較可判定該經檢測消抵值是否大於該臨限值。結合以上實施例中之任一者,在一實施例中,該指令可為一浮點加法指令。結合以上實施例中之任一者,在一實施例中,該執行單元可包括可用於將該兩個源值相加的一第五邏輯。結合以上實施例中之任一者,在一實施例中,該指令可為一混合乘加指令。結合以上實施例中之任一者,在一實施例中,至該混合乘加指令之兩個輸入之乘積對應於該兩個源值中之另一者。結合以上實施例中之任一者,在一實施例中,至該混合乘加指令之一個輸入對應於該兩個源值中之一者。結合以上實施例中之任一者,在一實施例中,該臨限值可使用一浮點控制暫存器予以設定。結合以上實施例中之任一者,在一實施例中,該臨限值可由一先前指令設定。
在本發明之一些實施例中,一種消抵效應檢測單元可包括一臨限值。該臨限值可控制與計算一浮點結果相關聯之一消抵效應之通知。結合以上實施例中之任一
者,在一實施例中,該消抵檢測單元可包括可用於自兩個源值計算一最大指數的一第一邏輯。結合以上實施例中之任一者,在一實施例中,該消抵檢測單元可包括可用於判定該浮點結果之一浮點指數的一第二邏輯。結合以上實施例中之任一者,在一實施例中,該消抵檢測單元可包括可用於透過自該最大指數減去該浮點指數而計算一經檢測消抵值的一第三邏輯。結合以上實施例中之任一者,在一實施例中,該消抵檢測單元可包括可用於比較該經檢測消抵值與該臨限值的一第四邏輯。
結合以上實施例中之任一者,在一實施例中,該消抵效應檢測單元可包括可用於基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標的一第五邏輯。結合以上實施例中之任一者,在一實施例中,該消抵效應檢測單元可包括一第五邏輯及一第六邏輯。該第五邏輯可用於判定是否設定一遮罩位元以防止傳信該消抵效應。該第六邏輯可用於基於未設定該遮罩位元之一判定及該經檢測消抵值與該臨限值之該比較而傳信一例外狀況。結合以上實施例中之任一者,在一實施例中,該比較可判定該經檢測消抵值是否大於該臨限值。結合以上實施例中之任一者,在一實施例中,該消抵效應檢測單元可包括至一浮點邏輯單元之一介面。該介面或浮點邏輯單元可包括可用於處理一浮點加法運算的一第五邏輯。結合以上實施例中之任一者,在一實施例中,該消抵效應檢測單元可包括至一混合乘加指令邏輯單元之一介面。該介面或邏輯單元可包
括可用於處理一混合乘加運算的一第五邏輯。結合以上實施例中之任一者,在一實施例中,至該混合乘加運算之一個輸入可對應於該兩個源值中之一者,且至該混合乘加運算之兩個其他輸入之乘積可對應於該兩個源值中之另一者。結合以上實施例中之任一者,在一實施例中,該臨限值可使用一浮點控制暫存器予以設定。結合以上實施例中之任一者,在一實施例中,該臨限值可由一先前指令設定。
在本發明之一些實施例中,一種設備可包括一用於檢測一消抵效應的構件。結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括一臨限值構件。該臨限值構件可控制與計算一浮點結果相關聯之一消抵效應之通知。結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括一用於自兩個源值計算一最大指數的構件。結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括一用於判定該浮點結果之一浮點指數的構件。結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括一用於透過自該最大指數減去該浮點指數而計算一經檢測消抵值的構件。結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括一用於比較該經檢測消抵值與該臨限值的構件。
結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括一用於基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標的構
件。結合以上實施例中之任一者,在一實施例中,用於判定是否設定一遮罩位元以防止傳信該消抵效應的構件以及一用於基於未設定該遮罩位元之該判定及該比較構件而傳信一例外狀況的構件。該比較構件可判定該經檢測消抵值是否大於該臨限值。結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括至一浮點邏輯單元之一介面構件。該介面構件可包括一用於處理一浮點加法運算的構件。結合以上實施例中之任一者,在一實施例中,該用於檢測一消抵效應的構件可包括至一混合乘加指令邏輯構件之一介面構件。該介面構件或該邏輯單元可包括一用於處理一混合乘加運算的構件。至該混合乘加運算之一個輸入可對應於該兩個源值中之一者,且至該混合乘加運算之兩個其他輸入之乘積可對應於該兩個源值中之另一者。結合以上實施例中之任一者,在一實施例中,該臨限值構件可使用一浮點控制暫存器予以設定。結合以上實施例中之任一者,在一實施例中,該臨限值構件可由一先前指令設定。
200:處理器
201:有序前端
202:快速排程器/uop排程器
203:無序執行引擎
204:慢速/一般浮點排程器/uop排程器
205:整數/浮點uop佇列
206:簡單浮點排程器/uop排程器
207、234:uop佇列
208、210:暫存器檔案
209:記憶體排程器
211:執行區塊
212、214:位址產生單元(AGU)/執行單元
215:分配器/暫存器重新命名器
216、218:快速ALU/執行單元
220:慢速ALU/執行單元
222:浮點ALU/執行單元
224:浮點移動單元/執行單元
226:指令預提取器
228:指令解碼器
230:追蹤快取記憶體
232:微碼ROM
Claims (18)
- 一種處理器,其包含:一前端,其用以解碼一指令,該指令用以計算經受一消抵效應之一浮點結果,其中該指令包含運算元欄位及一臨限值欄位,該等運算元欄位包含兩個源值且該臨限值欄位包含一臨限值控制設定參數;一消抵效應檢測單元,其在該處理器之一浮點單元中實施;一分配器,其用以回應於解碼該臨限值控制設定參數來將該指令指派至該消抵效應檢測單元以執行該指令;其中該消抵效應檢測單元包含特定的硬體電路系統以進行下列動作:識別該臨限值控制設定參數,其中該臨限值控制設定參數識別用於該消抵效應之一臨限值;自該兩個源值計算一最大指數;判定該浮點結果之一浮點指數;透過自該最大指數減去該浮點指數而計算一經檢測消抵值;以及比較該經檢測消抵值與由該臨限值控制設定參數所識別之該臨限值以判定是否提供該消抵效應之通知。
- 如請求項1之處理器,其中該消抵效應檢測單元之該硬體電路系統係進一步用以基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標。
- 如請求項1之處理器,其中該消抵效應檢測單元之該硬體電路系統係進一步用以進行下列動作:判定一遮罩位元是否被設定以防止傳信該消抵效應;以及基於該遮罩位元未被設定之該判定且基於該經檢測消抵值與該臨限值之該比較而傳信一例外狀況,其中該比較判定該經檢測消抵值是否大於該臨限值。
- 如請求項1之處理器,其中該指令為一浮點加法指令,且該消抵效應檢測單元進一步包含用以進行該兩個源值之相加的電路系統。
- 如請求項1之處理器,其中該指令為一混合乘加指令,其中用於該混合乘加指令之一個輸入對應於該兩個源值中之一者,且用於該混合乘加指令之兩個其他輸入的乘積對應於該兩個源值中之另一者。
- 如請求項1之處理器,其中該臨限值控制設定參數係用以基於該指令而在一浮點控制暫存器中被設定。
- 一種用於檢測一消抵效應之方法,其包含:設定一臨限值以控制與計算一浮點結果相關聯之該消抵效應的通知;提供該臨限值作為一指令中之一運算元以執行一浮點算術,其中該指令包含運算元欄位及一臨限值欄位,該等運算元欄位包含兩個源值且該臨限值欄位包含該臨限值;回應於解碼在該指令中之該臨限值來將該指令提供至 一處理器之一浮點單元電路系統之一消抵效應檢測單元;以及藉由該消抵效應檢測單元之特定的硬體電路系統來自該兩個源值計算一最大指數;藉由該消抵效應檢測單元之該特定的硬體電路系統來判定該浮點結果之一浮點指數;藉由該消抵效應檢測單元之該特定的硬體電路系統來透過自該最大指數減去該浮點指數而計算一經檢測消抵值;以及藉由該消抵效應檢測單元之該特定的硬體電路系統來比較該經檢測消抵值與該臨限值以判定是否提供該消抵效應之通知。
- 如請求項7之方法,其進一步包含基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標。
- 如請求項7之方法,其進一步包含:判定一遮罩位元是否被設定以防止傳信該消抵效應;以及基於該遮罩位元未被設定之該判定且基於該經檢測消抵值與該臨限值之該比較而傳信一例外狀況,其中該比較判定該經檢測消抵值是否大於該臨限值。
- 如請求項7之方法,其進一步包含處理一浮點加法運算。
- 如請求項7之方法,其進一步包含藉由計算用於一混合乘加運算之兩個輸入的乘積且使用該乘積作 為該兩個源值中之一者來處理該混合乘加運算。
- 如請求項7之方法,其進一步包含使用一浮點控制暫存器來設定該臨限值。
- 一種處理器之消抵效應檢測單元,其包含特定的硬體電路系統以進行下列動作:回應於用以進行浮點算術之一指令來控制與計算一浮點結果相關聯之一消抵效應的通知,該指令包含運算元欄位及一臨限值欄位,該等運算元欄位包含兩個源值且該臨限值欄位包含一臨限值;自該兩個源值計算一最大指數;判定該浮點結果之一浮點指數;透過自該最大指數減去該浮點指數而計算一經檢測消抵值;以及比較該經檢測消抵值與該臨限值以判定是否提供該消抵效應之通知。
- 如請求項13之消抵效應檢測單元,其中該硬體電路系統係進一步用以基於該經檢測消抵值與該臨限值之間的該比較而設定一旗標。
- 如請求項13之消抵效應檢測單元,其中該硬體電路系統係進一步用以進行下列動作:判定一遮罩位元是否被設定以防止傳信該消抵效應;以及基於該遮罩位元未被設定之該判定及該經檢測消抵值與該臨限值之該比較而傳信一例外狀況,其中該比較判定 該經檢測消抵值是否大於該臨限值。
- 如請求項13之消抵效應檢測單元,其進一步包含用於一浮點邏輯單元之一介面,該介面包含用以進行一浮點加法運算的電路系統。
- 如請求項13之消抵效應檢測單元,其進一步包含至一混合乘加指令邏輯單元之一介面,該介面包含用於處理一混合乘加運算的電路系統,其中用於該混合乘加運算之一個輸入對應於該兩個源值中之一者,且用於該混合乘加運算之兩個其他輸入的乘積對應於該兩個源值中之另一者。
- 如請求項13之消抵效應檢測單元,其中該臨限值被設定在一浮點控制暫存器中。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/975,811 | 2015-12-20 | ||
US14/975,811 US10114642B2 (en) | 2015-12-20 | 2015-12-20 | Instruction and logic for detecting the floating point cancellation effect |
Publications (2)
Publication Number | Publication Date |
---|---|
TW201729079A TW201729079A (zh) | 2017-08-16 |
TWI738681B true TWI738681B (zh) | 2021-09-11 |
Family
ID=59064336
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW105137261A TWI738681B (zh) | 2015-12-20 | 2016-11-15 | 處理器、用於檢測消抵效應之方法及消抵效應檢測單元 |
Country Status (5)
Country | Link |
---|---|
US (1) | US10114642B2 (zh) |
EP (1) | EP3391198B1 (zh) |
CN (1) | CN108351778A (zh) |
TW (1) | TWI738681B (zh) |
WO (1) | WO2017112191A1 (zh) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10114642B2 (en) | 2015-12-20 | 2018-10-30 | Intel Corporation | Instruction and logic for detecting the floating point cancellation effect |
US20170177336A1 (en) * | 2015-12-22 | 2017-06-22 | Intel Corporation | Hardware cancellation monitor for floating point operations |
CN111915003B (zh) * | 2019-05-09 | 2024-03-22 | 深圳大普微电子科技有限公司 | 一种神经网络硬件加速器 |
EP3987388A1 (en) * | 2019-08-23 | 2022-04-27 | Google LLC | Signed multiword multiplier |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6571265B1 (en) * | 1999-10-29 | 2003-05-27 | Intel Corporation | Mechanism to detect IEEE underflow exceptions on speculative floating-point operations |
US20090228690A1 (en) * | 2008-03-10 | 2009-09-10 | Adam James Muff | Early Exit Processing of Iterative Refinement Algorithm Using Register Dependency Disable |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5583805A (en) * | 1994-12-09 | 1996-12-10 | International Business Machines Corporation | Floating-point processor having post-writeback spill stage |
JP3544846B2 (ja) * | 1997-02-13 | 2004-07-21 | 株式会社東芝 | 論理回路及び浮動小数点演算装置 |
US6631392B1 (en) | 1999-07-30 | 2003-10-07 | Mips Technologies, Inc. | Method and apparatus for predicting floating-point exceptions |
US8239441B2 (en) * | 2008-05-15 | 2012-08-07 | Oracle America, Inc. | Leading zero estimation modification for unfused rounding catastrophic cancellation |
US8219605B2 (en) | 2010-05-28 | 2012-07-10 | International Business Machines Corporation | Decimal floating-pointing quantum exception detection |
US8965945B2 (en) * | 2011-02-17 | 2015-02-24 | Arm Limited | Apparatus and method for performing floating point addition |
US8775494B2 (en) | 2011-03-01 | 2014-07-08 | Nvidia Corporation | System and method for testing whether a result is correctly rounded |
US9213523B2 (en) * | 2012-06-29 | 2015-12-15 | Intel Corporation | Double rounded combined floating-point multiply and add |
US9317478B2 (en) * | 2012-09-10 | 2016-04-19 | Crossfield Technology LLC | Dual-path fused floating-point add-subtract |
US9104515B2 (en) | 2012-12-14 | 2015-08-11 | Fujitsu Limited | Floating-point error detection and correction |
US9483266B2 (en) * | 2013-03-15 | 2016-11-01 | Intel Corporation | Fusible instructions and logic to provide OR-test and AND-test functionality using multiple test sources |
US10114642B2 (en) | 2015-12-20 | 2018-10-30 | Intel Corporation | Instruction and logic for detecting the floating point cancellation effect |
-
2015
- 2015-12-20 US US14/975,811 patent/US10114642B2/en not_active Expired - Fee Related
-
2016
- 2016-11-15 TW TW105137261A patent/TWI738681B/zh active
- 2016-11-18 EP EP16879681.1A patent/EP3391198B1/en active Active
- 2016-11-18 CN CN201680067629.5A patent/CN108351778A/zh active Pending
- 2016-11-18 WO PCT/US2016/062921 patent/WO2017112191A1/en unknown
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6571265B1 (en) * | 1999-10-29 | 2003-05-27 | Intel Corporation | Mechanism to detect IEEE underflow exceptions on speculative floating-point operations |
US20090228690A1 (en) * | 2008-03-10 | 2009-09-10 | Adam James Muff | Early Exit Processing of Iterative Refinement Algorithm Using Register Dependency Disable |
Non-Patent Citations (1)
Title |
---|
Michael O.Lam et al. "Dynamic Floating Point Cancellation Detection",Dept. of Computer Science, University of Maryland, A.V. Williams Building, College Park, MD 20742, United States,Available online 28 September 2012. * |
Also Published As
Publication number | Publication date |
---|---|
EP3391198A4 (en) | 2019-07-31 |
TW201729079A (zh) | 2017-08-16 |
EP3391198A1 (en) | 2018-10-24 |
US10114642B2 (en) | 2018-10-30 |
CN108351778A (zh) | 2018-07-31 |
US20170177347A1 (en) | 2017-06-22 |
WO2017112191A1 (en) | 2017-06-29 |
EP3391198B1 (en) | 2023-09-13 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI739772B (zh) | 處理器、用於安全指令執行管線之方法、及運算系統 | |
TWI731892B (zh) | 用於以通道為基礎的跨步儲存操作之指令及邏輯 | |
CN109791513B (zh) | 用于检测数值累加误差的指令和逻辑 | |
TWI733710B (zh) | 用於重複發生相鄰聚集的處理器、方法和單元 | |
TWI738674B (zh) | 與快取控制操作有關的處理器、系統及非暫時性機器可讀媒體 | |
TWI743064B (zh) | 用於取得多重向量元素操作之指令及邏輯 | |
EP3384378B1 (en) | Instruction and logic for in-order handling in an out-of-order processor | |
US10157059B2 (en) | Instruction and logic for early underflow detection and rounder bypass | |
TWI720056B (zh) | 用於設置多重向量元素操作之指令及邏輯 | |
TW202042056A (zh) | 用於使用monitor及mwait架構之使用者層級執行緒同步的方法及裝置 | |
US20180004526A1 (en) | System and Method for Tracing Data Addresses | |
TWI723075B (zh) | 用於向量置換的方法和處理器以及向量置換單元 | |
US20170168819A1 (en) | Instruction and logic for partial reduction operations | |
TWI738681B (zh) | 處理器、用於檢測消抵效應之方法及消抵效應檢測單元 | |
TWI729029B (zh) | 用於向量位元欄壓縮及擴展的指令及邏輯 | |
US20160314000A1 (en) | Instruction and logic for identifying instructions for retirement in a multi-strand out-of-order processor | |
US10884735B2 (en) | Instruction and logic for predication and implicit destination | |
US20170123799A1 (en) | Performing folding of immediate data in a processor | |
US20160179534A1 (en) | Instruction length decoding | |
TWI773654B (zh) | 處理器、運算系統及用於執行以向量為基礎的位元操控之方法 | |
CN107408035B (zh) | 用于缕程间通信的装置和方法 |