CompilerDev 板


LINE

如標題 我發現一個優化演算法為 division-by-constant 當除數為常數時 他可以把除法轉換成乘法+算數右移 但他卻是在 backend 階段才應用的 為什麼他不是在 LLVM IR 階段實作? 我猜可能是乘法的 cost 根據硬體可能不一定比除法 cheap 因此我在猜應該能在 LLVM IR 階段拿到相關資訊 如 TargetTransforminfo 之類的分析 Pass 但我查一查發現都沒有 但是在 DAGCombiner.cpp 有找到類似的 function 叫做 `isIntDivCheap`,結果裡面判定是否比較 "Cheap" 的方法是根據優化目的 若以 code size 為優化目的,則 division 比 mul+shr還便宜沒錯 前者只要一個指令,後者兩個,明顯便宜一點 但是如果是以速度為目的的話,mul+shr比較便宜(該 function 只做這些判斷) 我自己推導成->不論何種硬體,後者速度比前者(除法)快 那為什麼該優化演算法不是實作在 LLVM IR 上? --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.160.190.187 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/CompilerDev/M.1649590913.A.8C4.html ※ 編輯: shane87123 (1.160.190.187 臺灣), 04/10/2022 22:05:55 ※ 編輯: shane87123 (1.160.190.187 臺灣), 04/10/2022 22:06:22
1F:推 LPH66: 我猜數制問題? 實際乘和移的數字應該跟目標是二補還是其他 04/11 06:55
2F:→ LPH66: 有關, 所以無法貿然在 IR 上直接轉換 04/11 06:55
其實經過轉換後都是一些 magic number, 如果 IR 階段能拿到一些硬體資訊然後做轉換,應該還行吧?
3F:→ Lipraxde: IR 表示語意,codegen 的時候決定怎麼生不是嗎? 04/11 09:05
4F:→ Lipraxde: 你問為什麼不是實作在 LLVM IR 上,我猜是指 InstCombi 04/11 09:14
5F:→ Lipraxde: ne?理論上有拿到 target 資訊當然都可以做,可是提前 04/11 09:14
不一定是 InstCombine(? 可以是另一個 Pass 之類的
6F:→ Lipraxde: 做有特別的好處?進到 codegen 階段時在做順理成章的拿 04/11 09:14
7F:→ Lipraxde: 資訊,也只需要看是不是 div by const,做在後面應該是 04/11 09:14
8F:→ Lipraxde: 蠻合理的選擇 04/11 09:14
我的想法是,如果所有硬體都會因此提升效能的話 做在 LLVM IR 不是有更好的模組性嗎? ※ 編輯: shane87123 (1.160.190.187 臺灣), 04/11/2022 11:15:56 ※ 編輯: shane87123 (1.160.190.187 臺灣), 04/11/2022 11:20:35
9F:→ Lipraxde: 有更好嗎,我不確定XD,不過看你回說會乘 magic number 04/11 12:27
10F:→ Lipraxde: ,我想到有沒有可能是因為會有 poison value 的關係? 04/11 12:27
我想那應該跟硬體資訊有關? 多少位元會 overflow 之類的 但這些資訊 IR 應該是得的到的 經過這番思考後,我覺得我對 LLVM IR 的出現有很深的誤會(? 我以為對所有硬體都有優化效果的都會實作在 LLVM IR 上 如:peephole, constant folding, loop unroll, loop vectorize 之類的 但似乎不是 有看過一個說法是一個 division 比較好分析和優化,比起multiplication+bitwise ※ 編輯: shane87123 (1.160.190.187 臺灣), 04/11/2022 19:08:14
11F:→ Lipraxde: #1U-Edzwa (CompilerDev)#1V0N0xoL (CompilerDev) 04/12 13:39
12F:→ Lipraxde: ...優化是有分 target-dependent/independent,有各自 04/12 13:39
13F:→ Lipraxde: 的分類,不過我是覺得不必那麼考究,在哪方便做就在哪 04/12 13:39
14F:→ Lipraxde: 做。像是你這篇的例子,如果不會遇到些數值計算上的問 04/12 13:39
15F:→ Lipraxde: 題,要當 peephole 來做應該也沒什麼不行 04/12 13:39
好吧~ 可能我太刁鑽於實作在哪塊了 謝謝大大解惑 ※ 編輯: shane87123 (114.43.60.48 臺灣), 04/12/2022 16:02:20
16F:推 eopXD: 推推 好問題 04/13 15:13







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:iOS站內搜尋

TOP