青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 54, comments - 32, trackbacks - 0, articles - 0
在一個(gè)線程出現(xiàn)異常行為時(shí),比如說CPU占用率過高,拋出異常等,你一定想知道這個(gè)線程是由哪個(gè)模塊創(chuàng)建的。因此無論在哪個(gè)操作系統(tǒng)上,獲取線程名稱是診斷線程相關(guān)問題的重要一步。

從線程ID獲取線程名稱通常的方法是,先獲取該線程的入口地址,然后枚舉進(jìn)程內(nèi)所有已加載模塊,最后判斷線程入口地址落在哪個(gè)加載模塊范圍內(nèi)。枚舉進(jìn)程內(nèi)已加載模塊可用Win32標(biāo)準(zhǔn)的CreateToolhelp32Snapshot/Module32First/Module32Next系列ToolHelp API得到。獲取線程入口地址則沒有線程的Win32 API可用。不過在Windows NT based操作系統(tǒng)上(包括Windows NT 4.0/2000/XP/2003,等),有一個(gè)未公開的Native API可用:NtQueryInformationThread。其聲明如下:

DWORD WINAPI NtQueryInformationThread(
                HANDLE ThreadHandle,
                THREAD_INFORMATION_CLASS ThreadInformationClass,
                PVOID ThreadInformation,
                ULONG ThreadInformationLength,
                PULONG ReturnLength
                );

獲取線程入口地址可用:

 

DWORD GetThreadStartAddress(DWORD dwThreadId)
{
    HANDLE hThread 
= OpenThread(THREAD_ALL_ACCESS, FALSE, dwThreadId);
    DWORD retaddr, len, error;
    retaddr 
= len = 0;
    error 
= NtQueryInformationThread( hThread, 9&retaddr, sizeof(retaddr), &len );
    CloseHandle(hThread);
    
if( error != 0 )
        retaddr 
= 0;
    
return retaddr;
}

在Windows CE上就沒這么幸運(yùn)了,沒有任何現(xiàn)成的API可用。官方Windows CE Base Team的blog對(duì)這個(gè)問題的回答是可以用Remote Kernel Tracker,不過這需要你build一個(gè)特殊的kernel image,enable一些profiler功能-這在顯示的問題診斷中顯然是不實(shí)際的。那么有沒有辦法不需要什么特殊的配置就可像Windows桌面操作系統(tǒng)那樣獲得入口地址呢?有是有的,不過需要一些hack手段。仔細(xì)研究CE下的Thread內(nèi)核數(shù)據(jù)結(jié)構(gòu),就會(huì)發(fā)現(xiàn)Thread結(jié)構(gòu)中有一項(xiàng)是記錄線程入口地址的。

 

typedef struct Thread {
    DWORD _1[
3];
    PPROCESS pProc; 
/* 0C: pointer to current process */
    PPROCESS pOwnerProc; 
/* 10: pointer to owner process */
    DWORD _2[
18];
    DWORD dwStartAddr; 
/* 5c: thread PC at creation, used to get thread name */
    DWORD _3[
10];
}
THREAD, *PTHREAD; /* Thread */

因此要做的就是想辦法根據(jù)線程ID或handle得到這個(gè)數(shù)據(jù)。再研究,發(fā)現(xiàn)線程的Thread內(nèi)核數(shù)據(jù)結(jié)構(gòu)可通過句柄得到:

 

PTHREAD pTh = HandleToThread(ThreadHandle);

而且,在Windows CE下,線程ID和其handle的值是一樣的!!因此我們可以寫一個(gè)這樣的函數(shù)從線程ID拿到入口地址:

 

 

DWORD GetThreadStartAddress(DWORD dwThreadId)
{
    DWORD dwStartAddress 
= 0;
    BOOL fOldMode 
= SetKMode(TRUE);
    PTHREAD pTh 
= HandleToThread((HANDLE)dwThreadId);
    
if (pTh)
    
{
        dwStartAddress 
= (DWORD)MapPtrToProcess((LPVOID)pTh->dwStartAddr, pTh->pOwnerProc->hProc);
    }

    
return dwStartAddress;
}

為了使用這些內(nèi)核數(shù)據(jù)結(jié)構(gòu),我們還需要另外一些輔助結(jié)構(gòu)和函數(shù),比較完整的代碼如下。當(dāng)然,官方肯定是不建議這么做的,但是重要的是解決問題,你說呢。

 

typedef struct Process {
    DWORD _1[
2];
    HANDLE hProc; 
/* 08: handle for this process, needed only for SC_GetProcFromPtr */
}
PROCESS, *PPROCESS;
typedef 
struct Thread {
    DWORD _1[
3];
    PPROCESS pProc; 
/* 0C: pointer to current process */
    PPROCESS pOwnerProc; 
/* 10: pointer to owner process */
    DWORD _2[
18];
    DWORD dwStartAddr; 
/* 5c: thread PC at creation, used to get thread name */
    DWORD _3[
10];
}
THREAD, *PTHREAD; /* Thread */

typedef 
struct cinfo {
    
char acName[4]; /* 00: object type ID string */
    uchar disp; 
/* 04: type of dispatch */
    uchar type; 
/* 05: api handle type */
    
ushort cMethods; /* 06: # of methods in dispatch table */
    
const PFNVOID *ppfnMethods;/* 08: ptr to array of methods (in server address space) */
    
const DWORD *pdwSig; /* 0C: ptr to array of method signatures */
    PPROCESS pServer; 
/* 10: ptr to server process */
}
 CINFO; /* cinfo */
typedef CINFO 
*PCINFO;

typedef 
struct _HDATA HDATA, *PHDATA;
struct _HDATA {
    DWORD _1[
2]; /* 00: links for active handle list */
    HANDLE hValue; 
/* 08: Current value of handle (nonce) */
    DWORD 
lock/* 0C: access information */
    DWORD 
ref/* 10: reference information */
    
const CINFO *pci; /* 14: ptr to object class description structure */
    PVOID pvObj; 
/* 18: ptr to object */
    DWORD dwInfo; 
/* 1C: extra handle info */
}
/* 20: sizeof(HDATA) */

#ifdef x86
struct KDataStruct {
    LPDWORD lpvTls; 
/* 0x000 Current thread local storage pointer */
    HANDLE ahSys[NUM_SYS_HANDLES]; 
/* 0x004 If this moves, change kapi.h */
    DWORD _1[
4];
    
ulong handleBase; /* 0x094 base address of handle table */
}
/* KDataStruct */
#endif
#ifdef ARM
struct KDataStruct {
    LPDWORD lpvTls; 
/* 0x000 Current thread local storage pointer */
    HANDLE ahSys[NUM_SYS_HANDLES]; 
/* 0x004 If this moves, change kapi.h */
    DWORD _1[
6];
    
ulong handleBase; /* 0x09c handle table base address */
}
/* KDataStruct */
#endif

#define HandleToThread(h) ((THREAD *)GetObjectPtrByType((h),SH_CURTHREAD))
#define HANDLE_ADDRESS_MASK 0x1ffffffc

void h2p(HANDLE h, PHDATA& phdRet)
{
    
if ((ulong)h < NUM_SYS_HANDLES+SYS_HANDLE_BASE && (ulong)h >= SYS_HANDLE_BASE)
        h 
= ((KDataStruct*)PUserKData)->ahSys[(uint)h-SYS_HANDLE_BASE];
    
if (h)
    
{
        phdRet 
= (PHDATA)(((ulong)h & HANDLE_ADDRESS_MASK) + ((KDataStruct*)PUserKData)->handleBase);
        
if (phdRet->hValue != h)
            phdRet 
= 0;
    }

    
else
        phdRet 
= 0;
}


PVOID GetObjectPtrByType(HANDLE h, 
int type)
{
    PHDATA phd;
    h2p(h, phd);
    
return (phd && phd->pci && phd->pci->type==type) ? phd->pvObj : 0;
}


extern "C" LPVOID WINAPI MapPtrToProcess(LPVOID lpv, HANDLE hProc);
extern "C" BOOL WINAPI SetKMode(BOOL fMode);

DWORD GetThreadStartAddress(DWORD dwThreadId)
{
    DWORD dwStartAddress 
= 0;
    BOOL fOldMode 
= SetKMode(TRUE);
    PTHREAD pTh 
= HandleToThread((HANDLE)dwThreadId);
    
if (pTh)
    
{
        dwStartAddress 
= (DWORD)MapPtrToProcess((LPVOID)pTh->dwStartAddr, pTh->pOwnerProc->hProc);
    }

    
return dwStartAddress;
}

Feedback

# re: [轉(zhuǎn)載]Hacking Windows CE: 如何從線程ID獲取線程名稱   回復(fù)  更多評(píng)論   

2014-12-17 10:30 by 獵頭招聘
這篇文章我找了很久,很實(shí)用,收下了。

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国产精品一区二区| 久久综合亚州| 国产日韩欧美夫妻视频在线观看| 在线免费精品视频| 国内精品久久久久久久影视麻豆| 在线成人www免费观看视频| 国产精品久在线观看| 国产精品三级视频| 国内不卡一区二区三区| 在线电影一区| 一区二区三区产品免费精品久久75| 欧美三级午夜理伦三级中视频| 亚洲一区二区欧美日韩| 亚洲欧美中文日韩在线| 久久9热精品视频| 久久久久国内| 欧美日韩亚洲综合| 狠狠色狠狠色综合人人| 亚洲精品国产精品久久清纯直播| 国产视频一区在线| 亚洲第一中文字幕在线观看| 一本色道久久综合亚洲精品不卡| 国产一区二区三区丝袜| 亚洲人被黑人高潮完整版| 亚洲影院在线| 欧美大尺度在线观看| 亚洲视频在线一区观看| 麻豆精品传媒视频| 国产精品久久久久免费a∨| 狠狠色综合一区二区| 在线视频欧美一区| 欧美成人资源| 香蕉亚洲视频| 欧美午夜精品电影| 亚洲精品在线观看免费| 久久夜色精品国产欧美乱极品 | 久久国产视频网站| 欧美激情精品久久久久久| 国产精品你懂的在线欣赏| 亚洲国产精品va在看黑人| 午夜精品在线观看| 亚洲人成在线播放| 久久精品人人做人人综合| 国产精品久久久久天堂| 亚洲区中文字幕| 男女激情视频一区| 欧美一二三区精品| 国产婷婷精品| 久久99在线观看| 亚洲一区在线观看免费观看电影高清| 亚洲视频在线看| 欧美久久久久久久久久| 亚洲精品美女在线观看播放| 老司机精品导航| 久久国产精品亚洲va麻豆| 国产欧美一区二区视频| 亚洲免费小视频| 夜夜嗨av一区二区三区网页| 欧美日韩高清在线播放| 中文国产成人精品久久一| 亚洲日本久久| 99国产精品99久久久久久| 欧美91福利在线观看| 亚洲国产影院| 亚洲三级电影在线观看 | 欧美一二三区精品| 欧美日韩一区高清| 亚洲午夜一区二区三区| 一区二区三区久久网| 国产精品视频久久一区| 欧美一区在线直播| 久久精品国产欧美亚洲人人爽| 欧美精品久久久久久久久久| 亚洲精品乱码久久久久久| 亚洲国产精品第一区二区三区| 亚洲——在线| 国产亚洲成av人片在线观看桃| 在线观看福利一区| 亚洲第一综合天堂另类专| 欧美久久久久久久| 亚洲网站视频| 午夜精品区一区二区三| 在线看无码的免费网站| 亚洲人成毛片在线播放女女| 国产精品极品美女粉嫩高清在线| 亚洲国产片色| 一区二区三区福利| 国产亚洲欧美激情| 亚洲国产欧美在线| 欧美日韩一区二区三区四区五区 | 亚洲自啪免费| 国内精品嫩模av私拍在线观看 | 亚洲一区国产| 狠狠综合久久| 一区二区三区四区蜜桃| 国产伦精品一区二区三区视频黑人| 日韩午夜av| 亚洲影视在线播放| 亚洲看片网站| 欧美在线在线| 亚洲一区二区伦理| 久久婷婷人人澡人人喊人人爽| 国产美女一区二区| 亚洲大胆av| 亚洲一区在线观看免费观看电影高清| 欧美一区观看| 看片网站欧美日韩| 欧美在线观看日本一区| 欧美日韩国产一中文字不卡| 久久久精品国产免大香伊| 欧美日韩网址| 亚洲国产精品久久久久秋霞影院| 欧美aaa级| 久久精品国产视频| 欧美精品乱码久久久久久按摩| 91久久精品一区二区三区| 亚洲一区图片| 欧美色图一区二区三区| 欧美国产日韩xxxxx| 国产一区二区三区的电影| 一区二区三区.www| 最新国产の精品合集bt伙计| 久久国产精品72免费观看| 欧美怡红院视频| 国产精品日韩欧美一区二区| 一区二区成人精品| 亚洲一二三区视频在线观看| 欧美精品日韩www.p站| 欧美国产精品久久| 亚洲第一综合天堂另类专| 久久在线精品| 欧美二区不卡| 91久久精品一区| 欧美好吊妞视频| 亚洲人成网站999久久久综合| 国产精品二区二区三区| 欧美激情bt| 亚洲精品在线免费| 欧美国产亚洲精品久久久8v| 欧美激情精品| 99精品99| 国产精品国码视频| 亚洲欧美日韩国产成人精品影院| 激情亚洲网站| 久久精品麻豆| 欧美激情第10页| 日韩视频永久免费| 欧美精品在线观看| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲精品一级| 日韩视频一区二区三区| 欧美日韩日日夜夜| 亚洲图片欧洲图片av| 欧美中文字幕在线| 影音先锋亚洲精品| 欧美交受高潮1| 在线亚洲高清视频| 久久久久一区| 亚洲精选久久| 国产乱码精品1区2区3区| 久久久久久欧美| 亚洲精品在线视频观看| 午夜亚洲精品| 亚洲国产电影| 国产精品国产亚洲精品看不卡15 | 亚洲精品乱码久久久久久日本蜜臀| 欧美另类在线观看| 亚洲欧美成人网| 欧美激情1区2区| 欧美在线一级va免费观看| 亚洲激情图片小说视频| 国产精品成人一区二区三区吃奶 | 亚洲影院在线| 蜜乳av另类精品一区二区| 99日韩精品| 黑人巨大精品欧美一区二区| 欧美日韩精品一区二区在线播放 | 国产日韩精品一区二区| 久久精品视频导航| 日韩亚洲在线| 免费精品99久久国产综合精品| 国产精品你懂得| 欧美成人tv| 久久av一区二区三区亚洲| 亚洲美女免费视频| 欧美超级免费视 在线| 欧美在线播放一区| 夜色激情一区二区| 亚洲国产成人一区| 一区二区三区在线观看欧美| 国产精品美腿一区在线看 | 黄色欧美日韩| 欧美三区美女| 欧美国产1区2区| 久久综合狠狠综合久久激情| 亚洲视频你懂的| 一本久道久久久| 亚洲欧洲一区二区三区久久| 久久嫩草精品久久久精品| 欧美影院一区|