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

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>
            国产一区二区三区免费在线观看 | 亚洲永久网站| 一本久久综合| 午夜精品一区二区三区在线视| 翔田千里一区二区| 免费在线观看一区二区| 亚洲精品男同| 亚洲专区免费| 在线一区二区视频| 久久综合中文| 国产精品女主播| 亚洲国产精品一区在线观看不卡| 国产免费成人在线视频| 91久久久久| 久久av老司机精品网站导航| 亚洲高清在线观看一区| 亚洲综合99| 欧美剧在线免费观看网站| 国产麻豆精品久久一二三| 久久久999| 亚洲一二三区精品| 欧美国产亚洲视频| 韩日欧美一区二区| 欧美一区二区日韩| 一区二区三区国产精华| 欧美高清在线视频观看不卡| 亚洲一区二区三区久久| 亚洲国产精品久久精品怡红院| 欧美一区二区三区在线视频 | 久久精品一区四区| 国产精品成人久久久久| 99爱精品视频| 亚洲国产人成综合网站| 国产精品电影在线观看| 麻豆精品网站| 久久久久天天天天| 狠狠色丁香久久综合频道| 亚洲国产日韩精品| 国内偷自视频区视频综合| 久久精品在线观看| 欧美日韩另类国产亚洲欧美一级| 在线视频国内自拍亚洲视频| 一区二区成人精品| 精品91久久久久| 久久久久国色av免费看影院| 欧美激情自拍| 一二美女精品欧洲| 久久亚洲影院| 亚洲欧洲另类国产综合| 欧美中文日韩| 亚洲国产精品久久人人爱蜜臀 | 午夜免费日韩视频| 欧美日韩大片一区二区三区| 亚洲神马久久| 亚洲宅男天堂在线观看无病毒| 亚洲美女色禁图| aaa亚洲精品一二三区| 欧美三级小说| 久久九九久久九九| 国产欧美成人| 亚洲第一在线视频| 伊人精品久久久久7777| 亚洲国产精品激情在线观看| 激情综合网激情| 欧美一区二区视频网站| 久久精品人人做人人爽电影蜜月| 美女日韩在线中文字幕| 一区二区三区四区五区精品| 亚洲综合精品四区| 亚洲一区在线视频| 国产精品xvideos88| 麻豆成人在线观看| 黄色精品一区| 猛男gaygay欧美视频| 欧美好吊妞视频| 国产精品视频免费在线观看| 欧美国产在线观看| 亚洲日本中文字幕| 新67194成人永久网站| 亚洲人成亚洲人成在线观看图片 | 亚洲一区二区三区精品动漫| 亚洲电影观看| 欧美激情1区| 一区二区三区你懂的| 欧美一级视频| 在线观看91精品国产麻豆| 欧美成人有码| 欧美+亚洲+精品+三区| 国产精品久久久久久久久久久久 | 久热这里只精品99re8久| 亚洲高清久久| 亚洲欧美日韩一区二区在线| 美日韩精品免费| 亚洲美女视频在线免费观看| 激情五月婷婷综合| 欧美高清在线精品一区| 亚洲一级片在线观看| 久久九九免费视频| 日韩午夜av电影| 国产毛片久久| 欧美精品v日韩精品v韩国精品v| 在线综合欧美| 亚洲电影免费观看高清完整版在线| 亚洲精品日日夜夜| 精品动漫3d一区二区三区| 欧美激情中文字幕一区二区 | 久久gogo国模啪啪人体图| 亚洲国产精品第一区二区三区 | 久久婷婷久久| 亚洲一二三区在线| 亚洲大片一区二区三区| 先锋影音网一区二区| 亚洲精品国产精品乱码不99| 国产欧美大片| 欧美色欧美亚洲高清在线视频| 欧美在线视频不卡| 一本色道久久| 欧美激情日韩| 久久在线免费视频| 一区二区三区在线观看视频| 欧美日韩一区在线观看视频| 久久精品理论片| 亚洲特色特黄| 亚洲人www| 欧美激情视频一区二区三区不卡| 午夜欧美不卡精品aaaaa| 99成人在线| 最近中文字幕mv在线一区二区三区四区 | 亚洲影音先锋| 夜夜精品视频| 亚洲精品黄网在线观看| 男人插女人欧美| 久久综合色婷婷| 久久久久国产精品人| 欧美亚洲视频一区二区| 亚洲午夜女主播在线直播| 亚洲国产精品一区二区第一页| 国产一区 二区 三区一级| 国产精品男gay被猛男狂揉视频| 欧美日韩天堂| 欧美日韩精品免费看| 欧美日韩mv| 欧美日韩亚洲视频| 欧美日韩国产综合视频在线| 欧美激情一区在线| 欧美精品成人在线| 欧美日韩ab片| 国产精品久久久久9999| 国产精品久久久久毛片软件 | 国产一区二区三区在线观看免费| 国产欧美一区二区精品性 | 欧美经典一区二区三区| 欧美精品一区二区视频| 欧美麻豆久久久久久中文| 欧美国产日韩一区二区| 欧美三级乱码| 国产精品乱看| 国产亚洲精久久久久久| 国产有码在线一区二区视频| 亚洲电影观看| 制服丝袜亚洲播放| 欧美一级视频免费在线观看| 久久成人精品无人区| 久久婷婷人人澡人人喊人人爽| 欧美1区视频| 亚洲精品日韩久久| 亚洲免费在线观看视频| 久久精品视频免费播放| 欧美大尺度在线观看| 在线观看国产精品网站| 亚洲国产精品成人一区二区| 一区二区三区精品在线| 欧美一区三区二区在线观看| 久久综合一区二区| 亚洲精品美女久久7777777| 亚洲自拍电影| 美女图片一区二区| 国产精品久久久久久模特 | 国产精品久久久久久久app| 黄色亚洲大片免费在线观看| 亚洲国产精品va在线看黑人 | 亚洲视频免费| 久久婷婷国产综合国色天香| 亚洲激情偷拍| 亚洲东热激情| 午夜精品久久久久久99热软件| 亚洲精一区二区三区| 午夜精品亚洲| 欧美久久电影| 狠狠色噜噜狠狠色综合久 | 国外成人在线| 亚洲伊人色欲综合网| 麻豆精品精品国产自在97香蕉| 日韩网站免费观看| 老司机午夜免费精品视频| 国产精品男gay被猛男狂揉视频| 亚洲电影欧美电影有声小说| 小嫩嫩精品导航| 亚洲蜜桃精久久久久久久| 免费看成人av|