• <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>
            隨筆-161  評論-223  文章-30  trackbacks-0
            ​1. 區間圖:用于局部寄存器分配,基本塊內的每個活躍范圍看作一個區間(最早定義位置+最新使用位置),所有活躍范圍構成區間圖。區間圖是一種不精確的沖突圖(因為高估了活躍范圍的范圍而導致偽沖突,比如認為一個復制操作連接的或兩個源相同目標不同的復制操作產生重疊的兩個活躍范圍沖突,但實際沒有沖突),優勢在于著色是P(復雜度O(|V|)或O(|E|))而非NP問題。llvm早期的線性掃描分配器是基于區間圖在全局的擴展,比較適用于JIT編譯(減少編譯時間)
            ​2. 一般圖:用于全局寄存器分配,是一種精確的沖突圖(由一組定義與一組使用構成的網絡)。優勢在于努力最小化溢出活躍范圍而生成高效執行的代碼,但會犧牲編譯時間。llvm的greedy寄存器分配是基于一般圖的代表。編譯器使用的沖突圖可能會將機器約束條件比如多寄存器值/調用約定編碼進去而存在重復邊,導致不滿足圖論中的簡單圖定義,故這里采用一般圖
            ​3. 弦圖:定義詳見https://oi-wiki.org/graph/chord?;陟o態單賦值形式名建立的沖突圖是弦圖。優勢在于可以做到最佳著色(復雜度O(|V|+|E|))而非啟發式(基于一般圖的全局寄存器分配使用啟發式),利于減少寄存器壓力。劣勢在于必須將指派寄存器后的仍然為靜態單賦值代碼轉換為機器碼,而這種轉換可能增加寄存器壓力,以及插入一些可能非必要的復制操作,若復制操作實現的數據流與ssa phi函數對應,則分配器無法合并這種復制,這將破壞弦圖的性質
            ​4. 沖突圖拆分:查找其中的團分割即連通子圖,移除它劃分得到不相交的一些子圖,這樣一來,各子圖可獨立著色(有點類似活躍范圍拆分)而利于減少寄存器壓力,另外實現上還能節省下三角布爾矩陣(用于快速判斷兩結點是否沖突)的規模
            ​#############################
            寄存器分配與圖論的染色理論相關。其它的比如常量傳播與格代數及不動點相關,循環優化與多面體、矩陣相關。這三方面是我目前看到的編譯器所用數學理論
            posted on 2023-10-04 13:08 春秋十二月 閱讀(3872) 評論(0)  編輯 收藏 引用 所屬分類: Compiler
            亚洲综合精品香蕉久久网| 欧美亚洲另类久久综合婷婷| 亚洲国产美女精品久久久久∴| 久久人人爽人人爽人人片av高请| 99久久精品国产一区二区三区 | 久久久91人妻无码精品蜜桃HD| 伊色综合久久之综合久久| 久久99精品久久久久久久不卡| 久久久久无码专区亚洲av| 亚洲精品无码专区久久久| 国产综合成人久久大片91| 久久久久亚洲AV片无码下载蜜桃| 久久99精品久久久久久9蜜桃| 精品久久久无码人妻中文字幕豆芽 | 国内精品久久久久久久97牛牛| 久久综合久久鬼色| 18岁日韩内射颜射午夜久久成人| 久久天天躁夜夜躁狠狠| 欧美精品福利视频一区二区三区久久久精品 | 国产日韩久久久精品影院首页| 伊人久久综合成人网| 一级做a爰片久久毛片免费陪 | 亚洲欧洲日产国码无码久久99| 久久国产精品免费一区二区三区| 亚洲午夜久久久久妓女影院| 精品久久久一二三区| 久久受www免费人成_看片中文 | 99国产欧美久久久精品蜜芽| 久久人人爽人人爽人人片av高请| 久久久久国产精品人妻| 久久99热这里只频精品6| 综合久久一区二区三区 | 亚洲午夜精品久久久久久浪潮| 国产精品免费看久久久香蕉| 久久www免费人成看国产片| 国产午夜福利精品久久| 国产成人精品久久亚洲高清不卡| 青青青国产精品国产精品久久久久 | 亚洲&#228;v永久无码精品天堂久久 | 一级a性色生活片久久无| 亚洲欧美国产精品专区久久 |