Mechanism for software register renaming and load speculation in an optimizer

One technique commonly used in program optimization is register renaming, which reduces false dependencies among the instructions, and gives an optimizer greater freedom to reorder instructions. This technique is especially useful in binary translators, emulators, and just-in-time compilers, which p...

Ausführliche Beschreibung

Gespeichert in:
Bibliographische Detailangaben
Hauptverfasser: Brauch, Rupert, Dunn, David A
Format: Patent
Sprache:eng
Online-Zugang:Volltext bestellen
Tags: Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
container_end_page
container_issue
container_start_page
container_title
container_volume
creator Brauch, Rupert
Dunn, David A
description One technique commonly used in program optimization is register renaming, which reduces false dependencies among the instructions, and gives an optimizer greater freedom to reorder instructions. This technique is especially useful in binary translators, emulators, and just-in-time compilers, which preferably preserve the register state at the exit of each basic block. Since register renaming generally requires the translator to insert additional instructions into the code, which copies the renamed register back to its original location, it is preferable to only rename registers when it will improve the performance of the code. Therefore, it is a problem in the art that it is not known when the benefits of renaming registers outweigh the cost. The inventive mechanism operates to optimize program efficiency in a two phase process. In the first phase, the mechanism conducts a dependency analysis on the instructions to determine dependency relationships between the various instructions in an instruction window. The mechanism thereby identifies candidates for register renaming and instruction speculation, and provisionally performs the renaming and speculation operations, while preserving information which is preferably used to reverse these operations in the second phase if it is determined that the operations may be effectively rescheduled. In the second phase, the mechanism determines whether the optimizing operations, renaming and speculation, were beneficial in each case. Each instruction for which the mechanism finds the optimizing operation to be beneficial will generally remain in optimized form. Optimizing operations found not be beneficial are generally reversed by the mechanism. The mechanism thus selectively uses renaming and speculation operations so as to ensure that the benefits preferably outweigh the costs of the operation in each case.
format Patent
fullrecord <record><control><sourceid>uspatents_EFH</sourceid><recordid>TN_cdi_uspatents_grants_06526572</recordid><sourceformat>XML</sourceformat><sourcesystem>PC</sourcesystem><sourcerecordid>06526572</sourcerecordid><originalsourceid>FETCH-uspatents_grants_065265723</originalsourceid><addsrcrecordid>eNqNikEKwkAMAPfiQdQ_5AOCVFofIIqX3rxLaLNrYJtdkhTB11vBB3iaYZh16HsanihsE8SiYCX6C5VAKbE56SKCE0sClBFywRGs0jBndC4CLEuHUp0nfpNuwypiNtr9uAlwvdzPt_1sFZ3E7ZEUvzh0bdO1p-b4x_IBvqs3ZA</addsrcrecordid><sourcetype>Open Access Repository</sourcetype><iscdi>true</iscdi><recordtype>patent</recordtype></control><display><type>patent</type><title>Mechanism for software register renaming and load speculation in an optimizer</title><source>USPTO Issued Patents</source><creator>Brauch, Rupert ; Dunn, David A</creator><creatorcontrib>Brauch, Rupert ; Dunn, David A ; Hewlett-Packard Company</creatorcontrib><description>One technique commonly used in program optimization is register renaming, which reduces false dependencies among the instructions, and gives an optimizer greater freedom to reorder instructions. This technique is especially useful in binary translators, emulators, and just-in-time compilers, which preferably preserve the register state at the exit of each basic block. Since register renaming generally requires the translator to insert additional instructions into the code, which copies the renamed register back to its original location, it is preferable to only rename registers when it will improve the performance of the code. Therefore, it is a problem in the art that it is not known when the benefits of renaming registers outweigh the cost. The inventive mechanism operates to optimize program efficiency in a two phase process. In the first phase, the mechanism conducts a dependency analysis on the instructions to determine dependency relationships between the various instructions in an instruction window. The mechanism thereby identifies candidates for register renaming and instruction speculation, and provisionally performs the renaming and speculation operations, while preserving information which is preferably used to reverse these operations in the second phase if it is determined that the operations may be effectively rescheduled. In the second phase, the mechanism determines whether the optimizing operations, renaming and speculation, were beneficial in each case. Each instruction for which the mechanism finds the optimizing operation to be beneficial will generally remain in optimized form. Optimizing operations found not be beneficial are generally reversed by the mechanism. The mechanism thus selectively uses renaming and speculation operations so as to ensure that the benefits preferably outweigh the costs of the operation in each case.</description><language>eng</language><creationdate>2003</creationdate><oa>free_for_read</oa><woscitedreferencessubscribed>false</woscitedreferencessubscribed></display><links><openurl>$$Topenurl_article</openurl><openurlfulltext>$$Topenurlfull_article</openurlfulltext><thumbnail>$$Tsyndetics_thumb_exl</thumbnail><linktopdf>$$Uhttps://image-ppubs.uspto.gov/dirsearch-public/print/downloadPdf/6526572$$EPDF$$P50$$Guspatents$$Hfree_for_read</linktopdf><link.rule.ids>230,308,776,798,881,64015</link.rule.ids><linktorsrc>$$Uhttps://image-ppubs.uspto.gov/dirsearch-public/print/downloadPdf/6526572$$EView_record_in_USPTO$$FView_record_in_$$GUSPTO$$Hfree_for_read</linktorsrc></links><search><creatorcontrib>Brauch, Rupert</creatorcontrib><creatorcontrib>Dunn, David A</creatorcontrib><creatorcontrib>Hewlett-Packard Company</creatorcontrib><title>Mechanism for software register renaming and load speculation in an optimizer</title><description>One technique commonly used in program optimization is register renaming, which reduces false dependencies among the instructions, and gives an optimizer greater freedom to reorder instructions. This technique is especially useful in binary translators, emulators, and just-in-time compilers, which preferably preserve the register state at the exit of each basic block. Since register renaming generally requires the translator to insert additional instructions into the code, which copies the renamed register back to its original location, it is preferable to only rename registers when it will improve the performance of the code. Therefore, it is a problem in the art that it is not known when the benefits of renaming registers outweigh the cost. The inventive mechanism operates to optimize program efficiency in a two phase process. In the first phase, the mechanism conducts a dependency analysis on the instructions to determine dependency relationships between the various instructions in an instruction window. The mechanism thereby identifies candidates for register renaming and instruction speculation, and provisionally performs the renaming and speculation operations, while preserving information which is preferably used to reverse these operations in the second phase if it is determined that the operations may be effectively rescheduled. In the second phase, the mechanism determines whether the optimizing operations, renaming and speculation, were beneficial in each case. Each instruction for which the mechanism finds the optimizing operation to be beneficial will generally remain in optimized form. Optimizing operations found not be beneficial are generally reversed by the mechanism. The mechanism thus selectively uses renaming and speculation operations so as to ensure that the benefits preferably outweigh the costs of the operation in each case.</description><fulltext>true</fulltext><rsrctype>patent</rsrctype><creationdate>2003</creationdate><recordtype>patent</recordtype><sourceid>EFH</sourceid><recordid>eNqNikEKwkAMAPfiQdQ_5AOCVFofIIqX3rxLaLNrYJtdkhTB11vBB3iaYZh16HsanihsE8SiYCX6C5VAKbE56SKCE0sClBFywRGs0jBndC4CLEuHUp0nfpNuwypiNtr9uAlwvdzPt_1sFZ3E7ZEUvzh0bdO1p-b4x_IBvqs3ZA</recordid><startdate>20030225</startdate><enddate>20030225</enddate><creator>Brauch, Rupert</creator><creator>Dunn, David A</creator><scope>EFH</scope></search><sort><creationdate>20030225</creationdate><title>Mechanism for software register renaming and load speculation in an optimizer</title><author>Brauch, Rupert ; Dunn, David A</author></sort><facets><frbrtype>5</frbrtype><frbrgroupid>cdi_FETCH-uspatents_grants_065265723</frbrgroupid><rsrctype>patents</rsrctype><prefilter>patents</prefilter><language>eng</language><creationdate>2003</creationdate><toplevel>online_resources</toplevel><creatorcontrib>Brauch, Rupert</creatorcontrib><creatorcontrib>Dunn, David A</creatorcontrib><creatorcontrib>Hewlett-Packard Company</creatorcontrib><collection>USPTO Issued Patents</collection></facets><delivery><delcategory>Remote Search Resource</delcategory><fulltext>fulltext_linktorsrc</fulltext></delivery><addata><au>Brauch, Rupert</au><au>Dunn, David A</au><aucorp>Hewlett-Packard Company</aucorp><format>patent</format><genre>patent</genre><ristype>GEN</ristype><title>Mechanism for software register renaming and load speculation in an optimizer</title><date>2003-02-25</date><risdate>2003</risdate><abstract>One technique commonly used in program optimization is register renaming, which reduces false dependencies among the instructions, and gives an optimizer greater freedom to reorder instructions. This technique is especially useful in binary translators, emulators, and just-in-time compilers, which preferably preserve the register state at the exit of each basic block. Since register renaming generally requires the translator to insert additional instructions into the code, which copies the renamed register back to its original location, it is preferable to only rename registers when it will improve the performance of the code. Therefore, it is a problem in the art that it is not known when the benefits of renaming registers outweigh the cost. The inventive mechanism operates to optimize program efficiency in a two phase process. In the first phase, the mechanism conducts a dependency analysis on the instructions to determine dependency relationships between the various instructions in an instruction window. The mechanism thereby identifies candidates for register renaming and instruction speculation, and provisionally performs the renaming and speculation operations, while preserving information which is preferably used to reverse these operations in the second phase if it is determined that the operations may be effectively rescheduled. In the second phase, the mechanism determines whether the optimizing operations, renaming and speculation, were beneficial in each case. Each instruction for which the mechanism finds the optimizing operation to be beneficial will generally remain in optimized form. Optimizing operations found not be beneficial are generally reversed by the mechanism. The mechanism thus selectively uses renaming and speculation operations so as to ensure that the benefits preferably outweigh the costs of the operation in each case.</abstract><oa>free_for_read</oa></addata></record>
fulltext fulltext_linktorsrc
identifier
ispartof
issn
language eng
recordid cdi_uspatents_grants_06526572
source USPTO Issued Patents
title Mechanism for software register renaming and load speculation in an optimizer
url https://sfx.bib-bvb.de/sfx_tum?ctx_ver=Z39.88-2004&ctx_enc=info:ofi/enc:UTF-8&ctx_tim=2025-01-24T15%3A04%3A23IST&url_ver=Z39.88-2004&url_ctx_fmt=infofi/fmt:kev:mtx:ctx&rfr_id=info:sid/primo.exlibrisgroup.com:primo3-Article-uspatents_EFH&rft_val_fmt=info:ofi/fmt:kev:mtx:patent&rft.genre=patent&rft.au=Brauch,%20Rupert&rft.aucorp=Hewlett-Packard%20Company&rft.date=2003-02-25&rft_id=info:doi/&rft_dat=%3Cuspatents_EFH%3E06526572%3C/uspatents_EFH%3E%3Curl%3E%3C/url%3E&disable_directlink=true&sfx.directlink=off&sfx.report_link=0&rft_id=info:oai/&rft_id=info:pmid/&rfr_iscdi=true