99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一文了解Prelink的特點和機理

如意 ? 來源:CSDN ? 作者:CaspianSea ? 2020-06-20 11:54 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、What is Prelink?

1.1 Prelink 簡介

Prelink 是 Red Hat 開發(fā)者 Jakub Jelinek 所設(shè)計的工具。正如其名字所示,Prelink 利用事先鏈接代替運行時鏈接的方法來加速共享庫的加載。它不僅可以加快起動速度,還可以減少部分內(nèi)存開銷,是各種 Linux 架構(gòu)上用于減少程序加載時間、縮短系統(tǒng)啟動時間和加快應(yīng)用程序啟動的很受歡迎的一個工具。

Linux 系統(tǒng)運行時的動態(tài)鏈接尤其是重定位 (Relocation) 的開銷,對于大型系統(tǒng)來說是很大的。相比之下,早期 UNIX 下的 a.out 格式的老式鏈接方法在速度和占用內(nèi)存方面有明顯的優(yōu)勢(但不如ELF格式更靈活,能方便的構(gòu)建動態(tài)共享庫)。Prelink 工具是試圖在保持一部分靈活性的基礎(chǔ)上,借鑒 a.out 格式在速度和占用內(nèi)存方面的優(yōu)點,對 ELF 文件進行一些改進。

Prelink 工具的原理主要基于這樣一個事實:動態(tài)鏈接和加載的過程開銷很大,并且在大多數(shù)的系統(tǒng)上,函數(shù)庫并不會常常被更動,每次程序被執(zhí)行時所進行的鏈接動作都是完全相同的,對于嵌入式系統(tǒng)來說尤其如此。因此,這一過程可以改在運行時之前就可以預(yù)先處理好,即花一些時間利用 Prelink 工具對動態(tài)共享庫和可執(zhí)行文件進行處理,修改這些二進制文件并加入相應(yīng)的重定位等信息,節(jié)約了本來在程序啟動時的比較耗時的查詢函數(shù)地址等工作,這樣可以減少程序啟動的時間,同時也減少了內(nèi)存的耗用。

Prelink 的這種做法當然也有代價:每次更新動態(tài)共享庫時,相關(guān)的可執(zhí)行文件都需要重新執(zhí)行一遍 Prelink 才能保證有效,因為新的共享庫中的符號信息、地址等很可能與原來的已經(jīng)不同了。這種代價對于嵌入式系統(tǒng)的開發(fā)者來說可能稍微帶來一些復(fù)雜度,不過好在對用戶來說幾乎是可以忽略的。

很多 Linux 發(fā)行版上已經(jīng)預(yù)裝了或者已經(jīng)使用了 Prelink 工具,不過我們需要適用于嵌入式平臺,比如 ARM 的版本,這樣我們需要到下載 Prelink 的源代碼并重新編譯。

1.2 Prelink 機理

從我們最熟悉的 hello world 程序開始分析:

#include 《stdio.h》

int main(int argc, const char* argv[]) {

printf(“Hello, World!\n”);

return 0;

}

我們知道,printf 是在 c語言運行庫 libc 中定義的。如果不使用動態(tài)庫,也就是使用glibc 的靜態(tài)庫版本,鏈接到 a.out 中的話,那么 printf 函數(shù)的地址在運行之前就是已知的,很簡單的一句地址轉(zhuǎn)移就可以完成了。

可是使用動態(tài)庫的話,在程序編譯階段,我們是無法得知 printf 的函數(shù)地址,因為動態(tài)庫的加載的內(nèi)存地址是隨機的。那么對于動態(tài)庫的情況,針對 printf 是如何尋址的呢?

在程序啟動時,當調(diào)用 printf 的時候,程序會將處理權(quán)交給 loader,由其負責(zé)在進程以及其鏈接的動態(tài)庫中查找 printf 的函數(shù)地址。由于 loader 不知道 printf 是在哪個動態(tài)庫,所以它將在整個進程和動態(tài)庫的范圍內(nèi)查找。更糟糕的是在 C++ 程序中,符號的命名是類名+函數(shù)名,這導(dǎo)致在做字符串比較時,往往直到字符串的結(jié)尾才能獲得結(jié)果。

這就導(dǎo)致了,在進程啟動過程中,符號查找往往占據(jù)了大部分時間。據(jù)統(tǒng)計,在 Linux 的 KDE 進程中啟動過程中,符號查找表竟占據(jù)了進程啟動 80% 的時間。有沒有辦法來改進呢?

如果進程在運行前,就能獲知動態(tài)庫的加載地址,那么函數(shù)調(diào)用的地址就應(yīng)該是已知的,我們就可以通過修改執(zhí)行程序,來避免符號的查找。從而節(jié)省進程啟動的時間。

實際上 Prelink 正是這么做的。Prelink 最早是在 Redhat 中引用的,用來加速 KDE 的啟動速度。那時侯 Prelink 作為系統(tǒng)的一個進程,不定期的啟動,對系統(tǒng)中的進程和動態(tài)庫進行優(yōu)化,這在系統(tǒng)中進程和動態(tài)庫不怎么變化的情況下非常有用。

在做 Prelink 時,需要為其指定需要做 Prelink 的進程和動態(tài)庫的目錄。Prelink 需要做以下幾件事情:

分析所有的進程和動態(tài)庫,為每個動態(tài)庫指定一塊唯一的(虛擬)內(nèi)存地址;

分析進程和動態(tài)庫中,所有需要重定位的函數(shù)、全局變量等,用 loader 進行符號查找,對齊地址進行解析;

修改進程中和動態(tài)庫的二進制文件;

眾所周知,在 32 位 Linux 操作系統(tǒng)上有 4G 的地址空間,3G 以上為操作系統(tǒng)使用,0000000~4000000 歸進程的代碼段、數(shù)據(jù)段和堆段使用,從 3G 往下歸棧段使用。基本上我們可以認為從 1G~3G 的地址空間可以用來指定動態(tài)庫的加載地址,地址空間還是很豐富的。

凡事總有萬一,如果地址空間不夠怎么辦呢?Prelink 關(guān)于這個問題,做了兩個約定:

總是一同出現(xiàn)的動態(tài)庫,其動態(tài)庫的加載地址一定不能重疊;

總是不同時間段出現(xiàn)的動態(tài)庫,其動態(tài)庫的加載地址可以重疊;

有了這兩個約定之后,基本上就可以保證,為每個動態(tài)庫指定加載地址,從而在運行前就能獲知函數(shù)和全局變量等符號的地址。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11511

    瀏覽量

    213837
  • Ha-VIS preLink
    +關(guān)注

    關(guān)注

    0

    文章

    2

    瀏覽量

    1605
  • 權(quán)重定位
    +關(guān)注

    關(guān)注

    0

    文章

    2

    瀏覽量

    1326
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    了解什么是 BQB 認證

    在藍牙產(chǎn)品快速普及的今天,無論是藍牙耳機、音箱、手表,還是智能家居、車載設(shè)備,只要你的產(chǎn)品宣稱使用了藍牙技術(shù),就必須通過BQB認證。那么,BQB認證是什么?為什么它如此重要?該怎么做?本文為你
    的頭像 發(fā)表于 07-18 14:53 ?35次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>什么是 BQB 認證

    了解微型電機及其特點

    以前看過不少關(guān)于微電機的資訊,如微電機應(yīng)用、微電機原理等等,那么什么是微電機呢?目前還是有不少人對微電機不了解,很多人覺得就是小電機,實際上微電機除了體積小之外,還具有普通電機不具備的優(yōu)點。微電機
    的頭像 發(fā)表于 07-17 08:46 ?84次閱讀

    了解電壓諧波

    我們經(jīng)常會聽到諧波,到底什么是諧波,怎么定義的?為什么要關(guān)注諧波?什么時候關(guān)注諧波?諧波如何計算或標準規(guī)定的諧波的算法是怎樣的?GB關(guān)于電壓諧波又是如何評估的?帶著諸多的問題,我們一起來了解。
    的頭像 發(fā)表于 06-28 17:23 ?1279次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>電壓諧波

    車用鋰離子電池機理建模與并聯(lián)模組不致性研究

    車用鋰離子電池機理建模與并聯(lián)模組不致性研究
    發(fā)表于 05-16 21:02

    帶你了解工業(yè)計算機尺寸

    項艱巨的任務(wù)。本博客將指導(dǎo)您了解關(guān)鍵的工業(yè)計算機尺寸、使用案例。關(guān)鍵工業(yè)計算機外形要素及其使用案例、工業(yè)微型PC尺寸范圍:寬度:100毫米-180毫米深度:10
    的頭像 發(fā)表于 04-24 13:35 ?301次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>帶你<b class='flag-5'>了解</b>工業(yè)計算機尺寸

    詳解半導(dǎo)體集成電路的失效機理

    半導(dǎo)體集成電路失效機理中除了與封裝有關(guān)的失效機理以外,還有與應(yīng)用有關(guān)的失效機理。
    的頭像 發(fā)表于 03-25 15:41 ?697次閱讀
    詳解半導(dǎo)體集成電路的失效<b class='flag-5'>機理</b>

    IGBT的導(dǎo)熱機理詳解

    影響其性能和壽命。因此,了解IGBT的導(dǎo)熱機理對于確保其長期穩(wěn)定運行至關(guān)重要。本文將詳細探討IGBT的導(dǎo)熱機理,包括熱量產(chǎn)生、傳導(dǎo)路徑、散熱材料以及熱管理策略等方面。
    的頭像 發(fā)表于 02-03 14:26 ?637次閱讀

    了解Highcharts

    標題 描述圖表的文本。通常位于圖表的頂部。 系列 圖表上顯示的個或多個數(shù)據(jù)序列。 提示框 將鼠標懸停在圖表上的序列或點上時,您可以獲得描述圖表特定部分中的值的工具提示。 傳說 圖例在圖表中顯示數(shù)據(jù)
    的頭像 發(fā)表于 01-06 11:33 ?699次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>Highcharts

    了解Android UDP通信

    、了解UDP通信協(xié)議 UDP(User Datagram Protocol,用戶數(shù)據(jù)報協(xié)議)是種無連接、不可靠的傳輸層協(xié)議。它提供簡單的數(shù)據(jù)傳輸服務(wù),無需在發(fā)送方和接收方之間建立連接。每個UDP
    發(fā)表于 12-30 10:56

    了解射頻功率

    。無論您是初學(xué)者還是有經(jīng)驗的工程師,相信通過閱讀本文,您將對射頻功率有更清晰的認識,并能夠在射頻電路設(shè)計中更好地應(yīng)用和優(yōu)化。、射頻功率的定義在低頻電路中,信號的大
    的頭像 發(fā)表于 12-24 10:40 ?1096次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>射頻功率

    了解高性能碳纖維的典型制造工藝及其主要特點

    盡管許多復(fù)合材料用戶會使用碳纖維,但不少人卻不了解碳纖維的制造方法,因為碳纖維生產(chǎn)商會對自己產(chǎn)品的生產(chǎn)方式保守秘密。每個生產(chǎn)商的碳纖維都與其競爭對手的產(chǎn)品不同,而賦予每個品牌標志性特征的加工細節(jié)則被
    的頭像 發(fā)表于 12-06 10:29 ?1295次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>高性能碳纖維的典型制造工藝及其主要<b class='flag-5'>特點</b>

    帶你了解SCP快充協(xié)議

    SCP快充協(xié)議作為華為公司自主研發(fā)的種快充技術(shù),以其高效、安全、穩(wěn)定的特點贏得了廣大用戶的認可和喜愛。隨著技術(shù)的不斷進步和應(yīng)用場景的拓展,SCP快充協(xié)議將繼續(xù)在快充領(lǐng)域發(fā)揮重要作用。
    的頭像 發(fā)表于 10-27 09:19 ?4217次閱讀

    了解激光測距傳感器

    來源:SonneWay 編輯:感知芯視界 Link 在工業(yè)自動化中,激光測距傳感器是最常見的傳感器之。不過,您對它真的了解嗎?本文將讓您了解
    的頭像 發(fā)表于 09-09 09:03 ?769次閱讀

    帶你了解半導(dǎo)體公司的各個崗位

    定的了解,能夠理解產(chǎn)品的技術(shù)特點,并能夠與客戶就技術(shù)問題進行溝通。2.客戶溝通,芯片公司的客戶通常是其他科技公司,比如電子產(chǎn)品制造商、通信設(shè)備制造商等。銷售崗位需要與這
    的頭像 發(fā)表于 08-08 16:28 ?6359次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>帶你<b class='flag-5'>了解</b>半導(dǎo)體公司的各個崗位

    了解MySQL索引機制

    的呢?起靜下心來,耐心看完這篇文章吧,干貨不啰嗦,相信你定會有所收獲。 、索引模型 模型也就是數(shù)據(jù)結(jié)構(gòu),常見的三種模型分別是哈希表、有序數(shù)組和搜索樹。 了解MySQL的朋友已經(jīng)知
    的頭像 發(fā)表于 07-25 14:05 ?571次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>MySQL索引機制