GB2524619B - Method and apparatus for implementing a dynamic out-of-order processor pipeline - Google Patents
Method and apparatus for implementing a dynamic out-of-order processor pipelineInfo
- Publication number
- GB2524619B GB2524619B GB1500942.6A GB201500942A GB2524619B GB 2524619 B GB2524619 B GB 2524619B GB 201500942 A GB201500942 A GB 201500942A GB 2524619 B GB2524619 B GB 2524619B
- Authority
- GB
- United Kingdom
- Prior art keywords
- implementing
- processor pipeline
- order processor
- dynamic out
- dynamic
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
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/38—Concurrent instruction execution, e.g. pipeline or look ahead
- G06F9/3836—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
- G06F9/3853—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution of compound instructions
-
- 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/3867—Concurrent instruction execution, e.g. pipeline or look ahead using instruction pipelines
-
- 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/30149—Instruction analysis, e.g. decoding, instruction word fields of variable length instructions
-
- 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/3802—Instruction prefetching
-
- 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/3004—Arrangements for executing specific machine instructions to perform operations on memory
-
- 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
-
- 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/30149—Instruction analysis, e.g. decoding, instruction word fields of variable length instructions
- G06F9/30152—Determining start or end of instruction; determining instruction length
-
- 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/30181—Instruction operation extension or modification
- G06F9/30196—Instruction operation extension or modification using decoder, e.g. decoder per instruction set, adaptable or programmable decoders
-
- 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/3836—Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
-
- 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/3854—Instruction completion, e.g. retiring, committing or graduating
- G06F9/3856—Reordering of instructions, e.g. using queues or age tags
-
- 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/3885—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
-
- 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/3885—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units
- G06F9/3889—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units controlled by multiple instructions, e.g. MIMD, decoupled access or execute
- G06F9/3891—Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units controlled by multiple instructions, e.g. MIMD, decoupled access or execute organised in groups of units sharing resources, e.g. clusters
-
- 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/46—Multiprogramming arrangements
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Advance Control (AREA)
- Executing Machine-Instructions (AREA)
- Devices For Executing Special Programs (AREA)
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/228,690 US9612840B2 (en) | 2014-03-28 | 2014-03-28 | Method and apparatus for implementing a dynamic out-of-order processor pipeline |
Publications (3)
Publication Number | Publication Date |
---|---|
GB201500942D0 GB201500942D0 (en) | 2015-03-04 |
GB2524619A GB2524619A (en) | 2015-09-30 |
GB2524619B true GB2524619B (en) | 2017-04-19 |
Family
ID=52630858
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
GB1500942.6A Active GB2524619B (en) | 2014-03-28 | 2015-01-20 | Method and apparatus for implementing a dynamic out-of-order processor pipeline |
Country Status (7)
Country | Link |
---|---|
US (2) | US9612840B2 (de) |
JP (2) | JP6043374B2 (de) |
KR (1) | KR101754462B1 (de) |
CN (1) | CN104951281B (de) |
DE (1) | DE102015002383A1 (de) |
GB (1) | GB2524619B (de) |
TW (1) | TWI599949B (de) |
Families Citing this family (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9436476B2 (en) * | 2013-03-15 | 2016-09-06 | Soft Machines Inc. | Method and apparatus for sorting elements in hardware structures |
US9612840B2 (en) * | 2014-03-28 | 2017-04-04 | Intel Corporation | Method and apparatus for implementing a dynamic out-of-order processor pipeline |
US11561792B2 (en) * | 2015-06-08 | 2023-01-24 | Qualcomm Incorporated | System, apparatus, and method for a transient load instruction within a VLIW operation |
KR102276718B1 (ko) * | 2015-11-25 | 2021-07-13 | 삼성전자주식회사 | Vliw 인터페이스 장치 및 제어 방법 |
US20170177542A1 (en) * | 2015-12-16 | 2017-06-22 | Cognitive Systems Corp. | Operating a VLIW Processor in a Wireless Sensor Device |
US11106467B2 (en) * | 2016-04-28 | 2021-08-31 | Microsoft Technology Licensing, Llc | Incremental scheduler for out-of-order block ISA processors |
US10552152B2 (en) * | 2016-05-27 | 2020-02-04 | Arm Limited | Method and apparatus for scheduling in a non-uniform compute device |
CN106066434B (zh) * | 2016-05-31 | 2018-10-19 | 国网河北省电力公司电力科学研究院 | 一种电能表自动化检定流水线健康程度评价方法 |
US10445100B2 (en) | 2016-06-09 | 2019-10-15 | International Business Machines Corporation | Broadcasting messages between execution slices for issued instructions indicating when execution results are ready |
US10331454B2 (en) * | 2016-09-29 | 2019-06-25 | Intel Corporation | System and method for load balancing in out-of-order clustered decoding |
CN107977305B (zh) * | 2016-10-24 | 2019-05-03 | 百度在线网络技术(北京)有限公司 | 用于检测应用的方法和装置 |
CN106681812B (zh) * | 2016-12-14 | 2020-09-29 | 西北工业大学 | 一种分区调度方法 |
US10318433B2 (en) * | 2016-12-20 | 2019-06-11 | Texas Instruments Incorporated | Streaming engine with multi dimensional circular addressing selectable at each dimension |
US10489204B2 (en) | 2017-01-31 | 2019-11-26 | Samsung Electronics Co., Ltd. | Flexible in-order and out-of-order resource allocation |
US10672175B2 (en) * | 2017-04-17 | 2020-06-02 | Intel Corporation | Order independent asynchronous compute and streaming for graphics |
US10186011B2 (en) * | 2017-04-28 | 2019-01-22 | Intel Corporation | Programmable coarse grained and sparse matrix compute hardware with advanced scheduling |
US10719325B2 (en) * | 2017-11-07 | 2020-07-21 | Qualcomm Incorporated | System and method of VLIW instruction processing using reduced-width VLIW processor |
JP7102840B2 (ja) * | 2018-03-26 | 2022-07-20 | 日本電気株式会社 | プロセッサコア、命令制御方法、プログラム |
US11188337B2 (en) * | 2018-09-28 | 2021-11-30 | The Florida State University Research Foundation, Inc. | Micro-architecture designs and methods for eager execution and fetching of instructions |
KR101996842B1 (ko) * | 2018-12-26 | 2019-07-08 | (주)자람테크놀로지 | 사용자 정의 명령어 셋을 지원하는 하드웨어 고속 연산 결합형 risc-v 기반 연산 장치 및 그 방법 |
CN109918134B (zh) * | 2019-03-06 | 2023-05-30 | 湖南科技大学 | 用于vliw基本块调度的组合启发式指令选择优化方法 |
US10956168B2 (en) * | 2019-03-08 | 2021-03-23 | International Business Machines Corporation | Post completion execution in an out-of-order processor design |
US10733016B1 (en) * | 2019-04-26 | 2020-08-04 | Google Llc | Optimizing hardware FIFO instructions |
US11392378B2 (en) * | 2019-07-25 | 2022-07-19 | Arm Limited | Executing a set of load operations for a gather-load instruction and controlling handling of another instruction that depends on completion of the gather-load instruction |
US11848980B2 (en) * | 2020-07-09 | 2023-12-19 | Boray Data Technology Co. Ltd. | Distributed pipeline configuration in a distributed computing system |
CN111857832B (zh) * | 2020-07-15 | 2023-10-20 | 国家电网有限公司能源互联网技术研究院 | 一种超长指令插入判断方法及系统 |
CN111857823A (zh) * | 2020-07-15 | 2020-10-30 | 北京百度网讯科技有限公司 | 用于写回指令执行结果的装置和方法、处理装置 |
CN112286456B (zh) * | 2020-10-27 | 2022-03-08 | 清华大学 | 存储方法及装置 |
WO2022094964A1 (zh) * | 2020-11-06 | 2022-05-12 | 华为技术有限公司 | 处理指令的方法以及图计算装置 |
CN112463723A (zh) * | 2020-12-17 | 2021-03-09 | 王志平 | 一种微内核阵列的实现方法 |
US20220206793A1 (en) * | 2020-12-24 | 2022-06-30 | Intel Corporation | Methods, systems, and apparatuses for a scalable reservation station implementing a single unified speculation state propagation and execution wakeup matrix circuit in a processor |
US11593110B2 (en) | 2021-01-07 | 2023-02-28 | Texas Instruments Incorporated | Instruction packing scheme for VLIW CPU architecture |
US11775307B2 (en) * | 2021-09-24 | 2023-10-03 | Apple Inc. | Systems and methods for synchronizing data processing in a cellular modem |
CN114925018B (zh) * | 2022-07-22 | 2022-10-21 | 中科声龙科技发展(北京)有限公司 | 片上交叉开关系统及芯片 |
CN118550587A (zh) * | 2024-07-29 | 2024-08-27 | 上海芯联芯智能科技有限公司 | 一种指令编译方法及一种指令处理方法 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6081884A (en) * | 1998-01-05 | 2000-06-27 | Advanced Micro Devices, Inc. | Embedding two different instruction sets within a single long instruction word using predecode bits |
EP1152329A1 (de) * | 2000-03-30 | 2001-11-07 | Agere Systems Guardian Corporation | Verfahren und Vorrichtung zum Identifizieren von teilbaren Paketen in einem Multi-threaded VLIW Prozessor |
US20020035677A1 (en) * | 1998-12-23 | 2002-03-21 | Gad S. Sheaffer | Method and apparatus for pre-processing instructions for a processor |
US20040268098A1 (en) * | 2003-06-30 | 2004-12-30 | Yoav Almog | Exploiting parallelism across VLIW traces |
US20060288195A1 (en) * | 2005-06-18 | 2006-12-21 | Yung-Cheng Ma | Apparatus and method for switchable conditional execution in a VLIW processor |
US20070083736A1 (en) * | 2005-10-06 | 2007-04-12 | Aravindh Baktha | Instruction packer for digital signal processor |
Family Cites Families (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5630157A (en) * | 1991-06-13 | 1997-05-13 | International Business Machines Corporation | Computer organization for multiple and out-of-order execution of condition code testing and setting instructions |
DE69311330T2 (de) * | 1992-03-31 | 1997-09-25 | Seiko Epson Corp., Tokio/Tokyo | Befehlsablauffolgeplanung von einem risc-superskalarprozessor |
WO1998006042A1 (en) * | 1996-08-07 | 1998-02-12 | Sun Microsystems, Inc. | Wide instruction unpack method and apparatus |
US6253309B1 (en) * | 1998-09-21 | 2001-06-26 | Advanced Micro Devices, Inc. | Forcing regularity into a CISC instruction set by padding instructions |
US6484255B1 (en) * | 1999-09-20 | 2002-11-19 | Intel Corporation | Selective writing of data elements from packed data based upon a mask using predication |
US6738893B1 (en) | 2000-04-25 | 2004-05-18 | Transmeta Corporation | Method and apparatus for scheduling to reduce space and increase speed of microprocessor operations |
US6895494B1 (en) | 2000-06-26 | 2005-05-17 | Texas Instruments Incorporated | Sub-pipelined and pipelined execution in a VLIW |
US20020178360A1 (en) * | 2001-02-25 | 2002-11-28 | Storymail, Inc. | System and method for communicating a secure unidirectional response message |
AU2002243655A1 (en) | 2001-01-25 | 2002-08-06 | Improv Systems, Inc. | Compiler for multiple processor and distributed memory architectures |
US6950926B1 (en) | 2001-03-02 | 2005-09-27 | Advanced Micro Devices, Inc. | Use of a neutral instruction as a dependency indicator for a set of instructions |
US7617496B2 (en) * | 2004-04-23 | 2009-11-10 | Apple Inc. | Macroscalar processor architecture |
US7752426B2 (en) * | 2004-08-30 | 2010-07-06 | Texas Instruments Incorporated | Processes, circuits, devices, and systems for branch prediction and other processor improvements |
US8181003B2 (en) * | 2008-05-29 | 2012-05-15 | Axis Semiconductor, Inc. | Instruction set design, control and communication in programmable microprocessor cores and the like |
US20110307688A1 (en) * | 2010-06-10 | 2011-12-15 | Carnegie Mellon University | Synthesis system for pipelined digital circuits |
US9612840B2 (en) * | 2014-03-28 | 2017-04-04 | Intel Corporation | Method and apparatus for implementing a dynamic out-of-order processor pipeline |
-
2014
- 2014-03-28 US US14/228,690 patent/US9612840B2/en not_active Expired - Fee Related
-
2015
- 2015-01-20 GB GB1500942.6A patent/GB2524619B/en active Active
- 2015-01-22 JP JP2015010321A patent/JP6043374B2/ja not_active Expired - Fee Related
- 2015-02-16 TW TW104105377A patent/TWI599949B/zh not_active IP Right Cessation
- 2015-02-25 KR KR1020150026821A patent/KR101754462B1/ko active IP Right Grant
- 2015-02-25 DE DE102015002383.7A patent/DE102015002383A1/de active Pending
- 2015-02-28 CN CN201510091809.4A patent/CN104951281B/zh active Active
-
2016
- 2016-11-11 JP JP2016221057A patent/JP2017027636A/ja not_active Ceased
-
2017
- 2017-04-03 US US15/477,374 patent/US10338927B2/en active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6081884A (en) * | 1998-01-05 | 2000-06-27 | Advanced Micro Devices, Inc. | Embedding two different instruction sets within a single long instruction word using predecode bits |
US20020035677A1 (en) * | 1998-12-23 | 2002-03-21 | Gad S. Sheaffer | Method and apparatus for pre-processing instructions for a processor |
EP1152329A1 (de) * | 2000-03-30 | 2001-11-07 | Agere Systems Guardian Corporation | Verfahren und Vorrichtung zum Identifizieren von teilbaren Paketen in einem Multi-threaded VLIW Prozessor |
US20040268098A1 (en) * | 2003-06-30 | 2004-12-30 | Yoav Almog | Exploiting parallelism across VLIW traces |
US20060288195A1 (en) * | 2005-06-18 | 2006-12-21 | Yung-Cheng Ma | Apparatus and method for switchable conditional execution in a VLIW processor |
US20070083736A1 (en) * | 2005-10-06 | 2007-04-12 | Aravindh Baktha | Instruction packer for digital signal processor |
Also Published As
Publication number | Publication date |
---|---|
CN104951281B (zh) | 2018-08-24 |
DE102015002383A1 (de) | 2015-10-01 |
JP2017027636A (ja) | 2017-02-02 |
GB201500942D0 (en) | 2015-03-04 |
US9612840B2 (en) | 2017-04-04 |
US20150277916A1 (en) | 2015-10-01 |
GB2524619A (en) | 2015-09-30 |
TW201602906A (zh) | 2016-01-16 |
JP6043374B2 (ja) | 2016-12-14 |
US10338927B2 (en) | 2019-07-02 |
US20170300334A1 (en) | 2017-10-19 |
KR101754462B1 (ko) | 2017-07-05 |
KR20150112774A (ko) | 2015-10-07 |
JP2015191660A (ja) | 2015-11-02 |
CN104951281A (zh) | 2015-09-30 |
TWI599949B (zh) | 2017-09-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
GB2524619B (en) | Method and apparatus for implementing a dynamic out-of-order processor pipeline | |
HK1209522A1 (en) | Device and method for detection | |
EP3557406C0 (de) | Vorrichtung und verfahren zur ausführung von funktionen | |
EP3190401A4 (de) | Inspektionsvorrichtung und inspektionsverfahren | |
EP3203217A4 (de) | Inspektionsvorrichtung und inspektionsverfahren | |
EP3215865A4 (de) | Vorrichtung und verfahren zur detektion von objekten | |
HK1219315A1 (zh) | 種應用的處理方法及裝置 | |
EP3129872A4 (de) | Anwendungsausführungsverfahren und -vorrichtung | |
GB201406615D0 (en) | An apparatus and method for sensing | |
GB201510267D0 (en) | Method and apparatus for monitoring pipeline | |
SG11201607901YA (en) | Detection apparatus and detection method | |
HK1213042A1 (zh) | 種基於步態的定位方法和裝置 | |
PL3280815T3 (pl) | Sposób i urządzenie do detekcji enterobakterii wytwarzających karbapenemazy | |
GB201409795D0 (en) | A Method and apparatus | |
HK1247665A1 (zh) | 用於檢查管道的裝置和方法 | |
GB2532923B (en) | Methods and apparatus for securing a line | |
GB201409036D0 (en) | Detection apparatus and method | |
EP3092434A4 (de) | Verfahren und vorrichtung zum auskleiden einer rohrleitung | |
PL3018451T3 (pl) | Urządzenie i sposób wykrywania | |
ZA201608151B (en) | System and method for inspecting a body | |
HK1221310A1 (zh) | 種 應用處理方法及裝置 | |
HK1214336A1 (zh) | 檢查裝置和檢查方法 | |
GB201513866D0 (en) | Method and apparatus for electrocagulation | |
EP3237083C0 (de) | Verfahren und vorrichtung zur erkennung von physischer leistung | |
AU2016224098B2 (en) | Pipeline method and apparatus |