ATE511674T1 - Verfahren und system zur auflösung gleichzeitig vorgegebener verzweigungsinstruktionen - Google Patents

Verfahren und system zur auflösung gleichzeitig vorgegebener verzweigungsinstruktionen

Info

Publication number
ATE511674T1
ATE511674T1 AT07843403T AT07843403T ATE511674T1 AT E511674 T1 ATE511674 T1 AT E511674T1 AT 07843403 T AT07843403 T AT 07843403T AT 07843403 T AT07843403 T AT 07843403T AT E511674 T1 ATE511674 T1 AT E511674T1
Authority
AT
Austria
Prior art keywords
branch instructions
predicted
given branch
simultaneously given
predicted branch
Prior art date
Application number
AT07843403T
Other languages
English (en)
Inventor
Rodney Wayne Smith
Brian Micheal Stempel
James Norris Dieffenderfer
Thomas Andrew Sartorius
Original Assignee
Qualcomm Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Qualcomm Inc filed Critical Qualcomm Inc
Application granted granted Critical
Publication of ATE511674T1 publication Critical patent/ATE511674T1/de

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3836Instruction issuing, e.g. dynamic instruction scheduling or out of order instruction execution
    • G06F9/3842Speculative instruction execution
    • G06F9/3844Speculative instruction execution using dynamic branch prediction, e.g. using branch history tables
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/3005Arrangements for executing specific machine instructions to perform operations for flow control
    • G06F9/30058Conditional branch instructions
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3861Recovery, e.g. branch miss-prediction, exception handling
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3885Concurrent instruction execution, e.g. pipeline or look ahead using a plurality of independent parallel functional units

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)
AT07843403T 2006-09-27 2007-09-27 Verfahren und system zur auflösung gleichzeitig vorgegebener verzweigungsinstruktionen ATE511674T1 (de)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/535,536 US7617387B2 (en) 2006-09-27 2006-09-27 Methods and system for resolving simultaneous predicted branch instructions
PCT/US2007/079781 WO2008039947A1 (en) 2006-09-27 2007-09-27 Methods and system for resolving simultaneous predicted branch instructions

Publications (1)

Publication Number Publication Date
ATE511674T1 true ATE511674T1 (de) 2011-06-15

Family

ID=38924371

Family Applications (1)

Application Number Title Priority Date Filing Date
AT07843403T ATE511674T1 (de) 2006-09-27 2007-09-27 Verfahren und system zur auflösung gleichzeitig vorgegebener verzweigungsinstruktionen

Country Status (7)

Country Link
US (2) US7617387B2 (de)
EP (1) EP2069915B1 (de)
JP (2) JP5221546B2 (de)
KR (1) KR101073732B1 (de)
CN (1) CN101523344B (de)
AT (1) ATE511674T1 (de)
WO (1) WO2008039947A1 (de)

Families Citing this family (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7617387B2 (en) * 2006-09-27 2009-11-10 Qualcomm Incorporated Methods and system for resolving simultaneous predicted branch instructions
CN102184091A (zh) * 2011-04-18 2011-09-14 孙瑞琛 一种分支预测方法及装置
WO2013100998A1 (en) * 2011-12-28 2013-07-04 Intel Corporation Processor with second jump execution unit for branch misprediction
US20140156977A1 (en) * 2011-12-28 2014-06-05 Mark J. Dechene Enabling and disabling a second jump execution unit for branch misprediction
US9268569B2 (en) * 2012-02-24 2016-02-23 Apple Inc. Branch misprediction behavior suppression on zero predicate branch mispredict
US9411590B2 (en) 2013-03-15 2016-08-09 Qualcomm Incorporated Method to improve speed of executing return branch instructions in a processor
US10108419B2 (en) * 2014-09-26 2018-10-23 Qualcomm Incorporated Dependency-prediction of instructions
US10853076B2 (en) * 2018-02-21 2020-12-01 Arm Limited Performing at least two branch predictions for non-contiguous instruction blocks at the same time using a prediction mapping
US10782976B2 (en) * 2018-05-07 2020-09-22 Dejan Spasov Issuing and flushing instructions from reservation stations using wrap bits and indexes
US12204908B2 (en) * 2018-06-04 2025-01-21 Advanced Micro Devices, Inc. Storing incidental branch predictions to reduce latency of misprediction recovery
US11086629B2 (en) * 2018-11-09 2021-08-10 Arm Limited Misprediction of predicted taken branches in a data processing apparatus
US10846097B2 (en) * 2018-12-20 2020-11-24 Samsung Electronics Co., Ltd. Mispredict recovery apparatus and method for branch and fetch pipelines
US20210149676A1 (en) * 2019-11-14 2021-05-20 Higon Austin R&D Center Corporation Branch Prediction Method, Branch Prediction Unit and Processor Core
CN111459549B (zh) 2020-04-07 2022-11-01 上海兆芯集成电路有限公司 具有高度领先分支预测器的微处理器
CN112256331B (zh) * 2020-12-22 2021-04-27 鹏城实验室 虚拟机指令解析加速方法、装置和计算机存储介质
US11663013B2 (en) 2021-08-24 2023-05-30 International Business Machines Corporation Dependency skipping execution
US11809874B2 (en) * 2022-02-01 2023-11-07 Apple Inc. Conditional instructions distribution and execution on pipelines having different latencies for mispredictions
US12067399B2 (en) 2022-02-01 2024-08-20 Apple Inc. Conditional instructions prediction
KR20240102798A (ko) 2022-12-26 2024-07-03 리벨리온 주식회사 뉴럴 프로세서 및 이의 명령어 페치 방법
US12450068B2 (en) 2023-07-25 2025-10-21 Apple Inc. Biased conditional instruction prediction
US12578965B2 (en) 2023-07-25 2026-03-17 Apple Inc. Biased indirect control transfer prediction

Family Cites Families (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5287467A (en) * 1991-04-18 1994-02-15 International Business Machines Corporation Pipeline for removing and concurrently executing two or more branch instructions in synchronization with other instructions executing in the execution unit
US5434985A (en) * 1992-08-11 1995-07-18 International Business Machines Corporation Simultaneous prediction of multiple branches for superscalar processing
JPH0756735A (ja) * 1993-08-16 1995-03-03 Nkk Corp 並列演算処理装置
ES2138051T3 (es) * 1994-01-03 2000-01-01 Intel Corp Metodo y aparato para la realizacion de un sistema de resolucion de bifurcaciones en cuatro etapas en un procesador informatico.
US5586278A (en) * 1994-03-01 1996-12-17 Intel Corporation Method and apparatus for state recovery following branch misprediction in an out-of-order microprocessor
JP3670290B2 (ja) * 1995-02-14 2005-07-13 富士通株式会社 特殊機能を提供する高性能投機的実行プロセッサの構造及び方法
US5943494A (en) * 1995-06-07 1999-08-24 International Business Machines Corporation Method and system for processing multiple branch instructions that write to count and link registers
US5740417A (en) * 1995-12-05 1998-04-14 Motorola, Inc. Pipelined processor operating in different power mode based on branch prediction state of branch history bit encoded as taken weakly not taken and strongly not taken states
US5752014A (en) * 1996-04-29 1998-05-12 International Business Machines Corporation Automatic selection of branch prediction methodology for subsequent branch instruction based on outcome of previous branch prediction
DE69611388T2 (de) * 1996-07-16 2001-08-09 Advanced Micro Devices Inc., Austin Lade/speichereinheit mit mehrfachen zeigern zum ergänzen von speicherung und fehlgriffladebefehlen
US5758143A (en) * 1996-10-07 1998-05-26 International Business Machines Corporation Method for updating a branch history table in a processor which resolves multiple branches in a single cycle
JPH10133874A (ja) * 1996-11-01 1998-05-22 Mitsubishi Electric Corp スーパスカラプロセッサ用分岐予測機構
JPH10333908A (ja) * 1997-05-30 1998-12-18 Mitsubishi Electric Corp 分岐予測方法
US6119075A (en) * 1997-11-26 2000-09-12 Digital Equipment Corporation Method for estimating statistics of properties of interactions processed by a processor pipeline
US6157998A (en) * 1998-04-03 2000-12-05 Motorola Inc. Method for performing branch prediction and resolution of two or more branch instructions within two or more branch prediction buffers
US6260138B1 (en) * 1998-07-17 2001-07-10 Sun Microsystems, Inc. Method and apparatus for branch instruction processing in a processor
JP2000132391A (ja) * 1998-10-23 2000-05-12 Nec Corp 分岐予測機構
US6460132B1 (en) * 1999-08-31 2002-10-01 Advanced Micro Devices, Inc. Massively parallel instruction predecoding
US6578134B1 (en) * 1999-11-29 2003-06-10 Ati International Srl Multi-branch resolution
US6757816B1 (en) * 1999-12-30 2004-06-29 Intel Corporation Fast branch misprediction recovery method and system
SE0003446L (sv) * 2000-09-27 2002-03-28 Ericsson Telefon Ab L M En pipelinemikroprocessor och ett förfarnade relaterande därtill
WO2002082717A1 (en) * 2001-04-05 2002-10-17 Kent Ridge Digital Labs Method and apparatus for constructing efficient elliptic curve cryptosystems
US7107438B2 (en) 2003-02-04 2006-09-12 Via Technologies, Inc. Pipelined microprocessor, apparatus, and method for performing early correction of conditional branch instruction mispredictions
US7000233B2 (en) * 2003-04-21 2006-02-14 International Business Machines Corporation Simultaneous multithread processor with result data delay path to adjust pipeline length for input to respective thread
JP4009248B2 (ja) * 2003-12-05 2007-11-14 富士通株式会社 分岐予測装置および分岐予測方法
US7949861B2 (en) * 2005-06-10 2011-05-24 Qualcomm Incorporated Method and apparatus for managing instruction flushing in a microprocessor's instruction pipeline
US7617387B2 (en) * 2006-09-27 2009-11-10 Qualcomm Incorporated Methods and system for resolving simultaneous predicted branch instructions

Also Published As

Publication number Publication date
US7617387B2 (en) 2009-11-10
JP2013122774A (ja) 2013-06-20
KR101073732B1 (ko) 2011-10-13
KR20090061667A (ko) 2009-06-16
EP2069915A1 (de) 2009-06-17
US8082428B2 (en) 2011-12-20
CN101523344B (zh) 2013-01-23
WO2008039947A1 (en) 2008-04-03
US20080077781A1 (en) 2008-03-27
EP2069915B1 (de) 2011-06-01
CN101523344A (zh) 2009-09-02
JP2010505210A (ja) 2010-02-18
US20100023696A1 (en) 2010-01-28
JP5221546B2 (ja) 2013-06-26

Similar Documents

Publication Publication Date Title
ATE511674T1 (de) Verfahren und system zur auflösung gleichzeitig vorgegebener verzweigungsinstruktionen
PL2999314T3 (pl) Układ sterujący lampą i sposób wysterowania lampy
DE602007008174D1 (de) Verfahren und System zur Erkennung von Phishing
BRPI0716647A2 (pt) processos de tratamento de mieloma múltiplo utilizando terapias de combinação baseadas em anticorpos anti-cs1
EP2137609A4 (de) Vertrauenswürdiges komponentenaktualisierungssystem und verfahren
FI20085920A7 (fi) Menetelmä ja järjestelmä harjoitteleun ohjaamiseksi
DK3626157T3 (da) Fremgangsmåde og system til brilleordination
DK2030476T3 (da) Fremgangsmåde og system til forbedring af forståeligheden af lyde
DK2031957T3 (da) Drivhus samt system og fremgangsmåde til tvangsstyring af drivhusklima
DK1969099T3 (da) Fremgangsmåde og indretning til behandling af biomasse
DE112006003916A5 (de) Zwischenschaltkreis, Brennstoffzellensystem mit Zwischenschaltkreis sowie Verfahren zur Ansteuerung des Zwischenschaltkreises
DE602007013671D1 (de) System zur Verringerung von Kraftwerksemissionen
DK2676967T3 (da) Fremgangsmåder til behandling af inflammatoriske og autoimmune sygdomme med natalizumab
DE602007013980D1 (de) Vorrichtung und Verfahren zur Betriebssystemsteuerung sowie Betriebssystem
DK1845126T3 (da) Dobbelt-hærdende resinkompositsystem og fremgangsmåde til at fremstille dette
DE112008001796A5 (de) Wechselrichtersystem und Steuerverfahren
JP2010287131A5 (ja) 学習制御システム及び学習制御方法
DE602007002333D1 (de) CAM-System und Verfahren dazu
BRPI0819660A2 (pt) Método e sistema educacional que inclui pelo menos uma interface de usuário
EP2013554A4 (de) Kühlsystemsteuerung und verfahren
IL190287A (en) Method of and system for controlling a kiln
DE602004011889D1 (de) Anordnung und Verfahren zur Durchführung einer frühen Korrektur von falschen Vorhersagen beim bedingten Verzweigungsbefehl
BRPI0720076A2 (pt) Sistema e método de entrada interativa
DK2228629T3 (da) System og fremgangsmåde til bestemmelse af positionen af en motordel
NL1036277A1 (nl) Lithographic apparatus, stage system and stage control method.

Legal Events

Date Code Title Description
RER Ceased as to paragraph 5 lit. 3 law introducing patent treaties