亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 3241 | 回復(fù): 2
打印 上一主題 下一主題

[C] 動態(tài)鏈接如何獲得共享庫函數(shù)地址(位置無關(guān)代碼) [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2012-09-14 20:05 |只看該作者 |倒序瀏覽
請問這么一個問題,困擾了我很久很久。csapp第7章講鏈接的時候講到了PIC函數(shù)調(diào)用問題(中文版p472),代碼如下:
#include <stdio.h>
#include "vector.h"

int x[2] = {1, 2};
int y[2] = {3, 4};
int z[2];

int main()
{
addvec(x, y, z, 2);
printf("z = [%d %d]\n", z[0], z[1]);
return 0;
}
然后這個程序運行的時候有自己的GOT和PLT,如
0x8049684 GOT[4] 0804846a PLT[2]中push1的地址(addvec),這是addvec對應(yīng)的GOT內(nèi)容,他的PLT比較長就不列出了。
PLT[2] <addvec>
8048464 jmp 0x8049684(GOT[4])
當(dāng)addvec第一次被調(diào)用時,轉(zhuǎn)到PLT[2]第一條指令,通過GOT[4]執(zhí)行一個間接跳轉(zhuǎn),也就是執(zhí)行下一條指令push1 addvec_id,講addvec的ID壓入棧中,然后又跳到PLT[0]等等。。。其實就是一個問題,動態(tài)鏈接如何獲得addvec函數(shù)的地址?

論壇徽章:
4
戌狗
日期:2013-08-15 18:22:43技術(shù)圖書徽章
日期:2013-08-21 13:48:45巨蟹座
日期:2013-09-26 17:06:39處女座
日期:2013-12-25 11:26:10
2 [報告]
發(fā)表于 2012-09-15 22:47 |只看該作者
初始化: GOT.PLT節(jié)中,全部GOT[...]均初始化為resolver32這個函數(shù)的絕對地址。 resolver32這個函數(shù)的輸入是一個地址未知的symbol;其功能是查找到這個symbol的絕對地址;而且這個函數(shù)沒有返回,本應(yīng)該返回時,它會修改GOT[x]里的地址值,然后直接跳轉(zhuǎn)到GOT[x]里的地址值。

第一次addvec : 跳轉(zhuǎn)至PLT2,PLT2處的第一條指令是跳轉(zhuǎn)至GOT[4]里的地址值。GOT[4]處現(xiàn)在是resolver32的絕對地址,故通過resolver32找到addvec的絕對地址,將addvec的絕對地址填寫至GOT[4],然后直接跳轉(zhuǎn)到addvec。

第二次addvec : 跳轉(zhuǎn)至PLT2,PLT2處的第一條指令是跳轉(zhuǎn)至GOT[4]里的地址值。GOT[4]處現(xiàn)在是addvec的絕對地址,故一切正常運行

論壇徽章:
3
15-16賽季CBA聯(lián)賽之山東
日期:2016-10-30 08:47:3015-16賽季CBA聯(lián)賽之佛山
日期:2016-12-17 00:06:31CU十四周年紀(jì)念徽章
日期:2017-12-03 01:04:02
3 [報告]
發(fā)表于 2012-09-18 22:06 |只看該作者
回復(fù) 2# 塑料袋


    頂垃圾袋.
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP