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

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
123下一頁(yè)
最近訪問(wèn)板塊 發(fā)新帖
查看: 23005 | 回復(fù): 26
打印 上一主題 下一主題

調(diào)試KERNEL時(shí),找出當(dāng)前進(jìn)程信息的方法 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2009-12-08 09:08 |只看該作者 |倒序?yàn)g覽
我們知道,一個(gè)常用的內(nèi)核數(shù)據(jù)結(jié)構(gòu)叫做 current. 它指向當(dāng)前的進(jìn)程,包括很多有用的信息,比如PID, 進(jìn)程名等。如果是自己寫內(nèi)核代碼,那么可以直接引用current。 但是如果是調(diào)試的話,直接在GDB里p current是不行的。因?yàn)閏urrent是一個(gè)宏。

那么這時(shí)如何找出current呢?在Linux 2.6版本中,current是放在堆棧(STACK)的最低下。假如內(nèi)核棧是8K。起始地址為0XC100,2000. 那么current就在0XC100,0000 (堆棧是倒著長(zhǎng)的). 根據(jù)這個(gè)情況,可以用如下方法找出current。
1)找出ESP。p $esp. 假設(shè)輸出為0XC123,4566
2) 把esp與上0XFFFF,E000 (低13位置為0)。 得到0XC123,4000. 這個(gè)值就是CURRENT的值了?梢赞D(zhuǎn)換后進(jìn)行使用,比如
3)  p ((* struct thread_info) 0xc1234000)->task->comm

以上方法在X86-32, ARM上都可以。 其他體系結(jié)構(gòu)不太清楚,似乎也可以;蛘吣俏恢赖目梢匝a(bǔ)充。

[ 本帖最后由 accessory 于 2009-12-10 12:01 編輯 ]

評(píng)分

參與人數(shù) 1可用積分 +15 收起 理由
T-Bagwell + 15 精品文章

查看全部評(píng)分

論壇徽章:
36
IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-10 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-16 06:20:0015-16賽季CBA聯(lián)賽之廣東
日期:2016-04-16 19:59:32IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-18 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-19 06:20:00每日論壇發(fā)貼之星
日期:2016-04-19 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-25 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-06 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-08 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-13 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-28 06:20:00每日論壇發(fā)貼之星
日期:2016-05-28 06:20:00
2 [報(bào)告]
發(fā)表于 2009-12-08 10:56 |只看該作者
多謝accessory 兄的好文

論壇徽章:
36
IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-10 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-16 06:20:0015-16賽季CBA聯(lián)賽之廣東
日期:2016-04-16 19:59:32IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-18 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-19 06:20:00每日論壇發(fā)貼之星
日期:2016-04-19 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-25 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-06 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-08 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-13 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-28 06:20:00每日論壇發(fā)貼之星
日期:2016-05-28 06:20:00
3 [報(bào)告]
發(fā)表于 2009-12-08 11:01 |只看該作者
accessory 兄,方便的話,截圖演示一下。。。

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2009-12-08 11:03 |只看該作者
終于我也有了精華貼了。呵呵。

論壇徽章:
36
IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-10 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-16 06:20:0015-16賽季CBA聯(lián)賽之廣東
日期:2016-04-16 19:59:32IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-18 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-19 06:20:00每日論壇發(fā)貼之星
日期:2016-04-19 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-04-25 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-06 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-08 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-13 06:20:00IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-05-28 06:20:00每日論壇發(fā)貼之星
日期:2016-05-28 06:20:00
5 [報(bào)告]
發(fā)表于 2009-12-08 11:09 |只看該作者

回復(fù) #4 accessory 的帖子

呵呵,accessory兄以前發(fā)的帖子也都很有價(jià)值的。

論壇徽章:
5
摩羯座
日期:2014-07-22 09:03:552015元宵節(jié)徽章
日期:2015-03-06 15:50:392015亞冠之大阪鋼巴
日期:2015-06-12 16:01:352015年中國(guó)系統(tǒng)架構(gòu)師大會(huì)
日期:2015-06-29 16:11:2815-16賽季CBA聯(lián)賽之四川
日期:2018-12-17 14:10:21
6 [報(bào)告]
發(fā)表于 2009-12-08 11:28 |只看該作者
原帖由 accessory 于 2009-12-8 11:03 發(fā)表
終于我也有了精華貼了。呵呵。


多發(fā)精華呀

論壇徽章:
3
金牛座
日期:2014-06-14 22:04:062015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:45
7 [報(bào)告]
發(fā)表于 2009-12-08 11:57 |只看該作者

回復(fù) #1 accessory 的帖子

學(xué)習(xí)了,呵呵

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2009-12-08 21:41 |只看該作者
我看大致應(yīng)該是這個(gè)圖的吧:


難度:
1 堆棧起始地址怎么獲得?
2 堆棧大小就是8K么?可擴(kuò)展吧


請(qǐng)多指教!

論壇徽章:
0
9 [報(bào)告]
發(fā)表于 2009-12-09 02:16 |只看該作者
多謝LS貼圖. 第一張圖沒(méi)錯(cuò). 第二張似乎關(guān)系不大.

關(guān)于你說(shuō)的那2個(gè)難度
1 堆棧起始地址怎么獲得?

由于假設(shè)你是在調(diào)試KERNEL,那么應(yīng)該可以獲得ESP的內(nèi)容. 比如在GDB里 P $ESP. 然后把它的低13位置為0就得到CURRENT了. 這個(gè)設(shè)計(jì)是很巧妙的. 因?yàn)镋SP本身是動(dòng)態(tài)的,會(huì)不停變化. 但是LINUX設(shè)計(jì)成它的高5位是不變的.這樣就可以很快速的得到CURRENT.

2 堆棧大小就是8K么?可擴(kuò)展吧

默認(rèn)都是8K. 內(nèi)核堆棧可以擴(kuò)展么?我不太清楚. 有一點(diǎn)值得注意,應(yīng)用程序的堆棧和內(nèi)核的堆棧是分開的. 我覺(jué)得內(nèi)核堆棧似乎不能動(dòng)態(tài)擴(kuò)展. 只有在編譯內(nèi)核的時(shí)候可以指定是4K OR 8K.

論壇徽章:
2
2015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:57:09
10 [報(bào)告]
發(fā)表于 2009-12-09 09:44 |只看該作者

回復(fù) #1 accessory 的帖子

為什么這么麻煩8k對(duì)齊來(lái)取得current呢,直接用current這個(gè)變量就行了。為什么還要去先取它的地址,然后再去用它呢?搞不明白。
您需要登錄后才可以回帖 登錄 | 注冊(cè)

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

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP