• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-162  評論-223  文章-30  trackbacks-0
            1. 作為指令高速緩層優化的一種重要技術,它根據CFG流圖邊的執行頻率將頻繁執行的基本塊排列在一起,并布局那些基本塊在下降分支路徑,而不在一起的也就是很少執行的基本塊布局在轉移分支路徑。這樣做一來可以使取到I-cache中的指令實際被執行的比例較高,二來對于某些體系結構上轉移和下降路徑延遲不等的分支指令,可以降低跳轉延遲

            2. 實現過程內代碼置放有以下幾個環節:
            a)獲取剖析數據:編譯器可以先在基本塊出口處插入代碼以統計到其后繼基本塊的執行次數,作為CFG流圖邊的權重,然后編譯生成可執行文件,輸入代表性數據運行它,結果輸出一個數據文件,用于第二次編譯,這次編譯實施過程內代碼置放優化
            b)以鏈的形式構建熱路徑:熱路徑是CFG路徑的一個集合,其中包括頻繁執行的那些邊,每條路徑是一個或多個基本塊按邊的方向構成的鏈,每個鏈關聯一個優先級,用于布局代碼的先后順序。初始時,每個基本塊構成一個只有它本身的鏈,其優先級為CFG流圖邊的數量或者更大值;接下來,在CFG中按權重降序遍歷每條邊<x,y>(x不等于y),若x是某個鏈a的尾結點且y是某鏈b的頭結點,則把b合并到a后面,更新a的優先級為a原來優先級、b優先級、P三者的最小值,同時遞增P,其中P為鏈合并操作的計數器,用于決定鏈的相對次序由低到高排列,初值為0。當遍歷結束時,所有熱路徑構建完成
            c)進行代碼布局:經過前一環節,就得到了鏈的集合。首先從鏈集合找出含有入口基本塊的鏈t,將t加入工作表WL;然后從WL移出一個優先級最低的鏈c,按序(構建鏈時加入基本塊的順序)遍歷c的每個基本塊x,把x放在過程可執行代碼體的末端,對于邊<x,y>,將包含y的鏈t加入WL(若t不在WL中),重復該過程直至WL為空
            posted on 2023-09-06 23:15 春秋十二月 閱讀(74) 評論(0)  編輯 收藏 引用 所屬分類: Compiler
            韩国三级中文字幕hd久久精品 | 久久天天躁狠狠躁夜夜96流白浆 | 伊人久久精品无码av一区| 99久久精品国产毛片| 亚洲国产成人久久综合区| 亚洲精品综合久久| 亚洲av日韩精品久久久久久a| 久久精品国产一区二区电影| 久久久久亚洲av毛片大| 欧美伊人久久大香线蕉综合69 | 久久综合中文字幕| 欧美午夜精品久久久久久浪潮| 看全色黄大色大片免费久久久| 日韩久久久久中文字幕人妻| 99国内精品久久久久久久| 久久国产成人午夜aⅴ影院| 亚洲精品美女久久久久99小说| 久久香综合精品久久伊人| 国产亚州精品女人久久久久久| 人妻精品久久久久中文字幕| 久久人人爽人人爽人人片AV不| 久久婷婷久久一区二区三区 | 久久免费大片| 久久久无码人妻精品无码| 久久亚洲国产成人影院| 国产人久久人人人人爽 | 中文无码久久精品| 亚洲欧美久久久久9999| 日本高清无卡码一区二区久久| 99久久精品国产一区二区| 久久亚洲av无码精品浪潮| 国产精品99久久久久久宅男 | 久久久久国产亚洲AV麻豆| 久久99国内精品自在现线| 久久国产色AV免费看| 亚洲午夜久久久影院| 无遮挡粉嫩小泬久久久久久久 | 久久久久精品国产亚洲AV无码| 久久精品亚洲乱码伦伦中文| 久久久久亚洲AV综合波多野结衣 | 久久精品一区二区国产|