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

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

從線程ID獲取線程名稱(chēng)通常的方法是,先獲取該線程的入口地址,然后枚舉進(jìn)程內(nèi)所有已加載模塊,最后判斷線程入口地址落在哪個(gè)加載模塊范圍內(nèi)。枚舉進(jìn)程內(nèi)已加載模塊可用Win32標(biāo)準(zhǔn)的CreateToolhelp32Snapshot/Module32First/Module32Next系列ToolHelp API得到。獲取線程入口地址則沒(méi)有線程的Win32 API可用。不過(guò)在Windows NT based操作系統(tǒng)上(包括Windows NT 4.0/2000/XP/2003,等),有一個(gè)未公開(kāi)的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上就沒(méi)這么幸運(yùn)了,沒(méi)有任何現(xiàn)成的API可用。官方Windows CE Base Team的blog對(duì)這個(gè)問(wèn)題的回答是可以用Remote Kernel Tracker,不過(guò)這需要你build一個(gè)特殊的kernel image,enable一些profiler功能-這在顯示的問(wèn)題診斷中顯然是不實(shí)際的。那么有沒(méi)有辦法不需要什么特殊的配置就可像Windows桌面操作系統(tǒng)那樣獲得入口地址呢?有是有的,不過(guò)需要一些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)可通過(guò)句柄得到:

 

PTHREAD pTh = HandleToThread(ThreadHandle);

而且,在Windows CE下,線程ID和其handle的值是一樣的!!因此我們可以寫(xiě)一個(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)然,官方肯定是不建議這么做的,但是重要的是解決問(wèn)題,你說(shuō)呢。

 

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獲取線程名稱(chēng)   回復(fù)  更多評(píng)論   

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

只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   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.17c.com| 久久国产精品99精品国产| 午夜精品免费| 久久夜色精品一区| 嫩草影视亚洲| 国产精品卡一卡二卡三| 国产午夜精品在线| 亚洲高清不卡av| 亚洲午夜视频在线| 欧美一区免费视频| 美女福利精品视频| 最新国产乱人伦偷精品免费网站 | 欧美日韩亚洲综合一区| 国产精品久久波多野结衣| 国产亚洲精品激情久久| 91久久精品国产91性色| 欧美一区二区精品在线| 欧美福利一区二区| 久久不射电影网| 欧美性片在线观看| 伊人精品视频| 久久伊人一区二区| 午夜精品视频| 国产精品视频你懂的| 99re热精品| 伊人天天综合| 欧美专区18| 亚洲专区国产精品| 国产精品另类一区| 9久草视频在线视频精品| 欧美成人网在线| 久久精品国产69国产精品亚洲| 欧美日韩在线另类| 在线视频你懂得一区二区三区| 欧美成ee人免费视频| 久久久精品国产99久久精品芒果| 国产精品福利网| 欧美一区二区三区四区视频| 一区二区三区免费在线观看| 欧美视频精品在线观看| 亚洲一区二区视频在线| 一区二区三区欧美在线| 国产精品入口66mio| 久久久久久香蕉网| 久久综合九色综合欧美就去吻| 亚洲国产精品va在线看黑人动漫| 亚洲成色www8888| 欧美日韩一区二区在线播放| 欧美在线不卡| 欧美成人首页| 久久久水蜜桃av免费网站| 欧美91大片| 久久一区二区视频| 欧美黄污视频| 毛片av中文字幕一区二区| 欧美日韩国产999| 久久免费的精品国产v∧| 欧美区国产区| 欧美激情第二页| 国产日韩精品一区| 这里只有精品丝袜| 牛夜精品久久久久久久99黑人| 亚洲一区二区免费| 欧美看片网站| 欧美国产日本高清在线| 国产一区二区三区在线观看免费 | 亚洲美女毛片| 亚洲国产色一区| 久久久亚洲影院你懂的| 久久精品欧美日韩| 国产日韩欧美综合一区| 在线亚洲+欧美+日本专区| 亚洲巨乳在线| 欧美日韩国产成人在线观看| 亚洲三级免费| 欧美一级视频免费在线观看| 国产精品久久久91| 午夜精品久久久久久久99黑人| 亚洲视频专区在线| 国产精品久久久久免费a∨| 一区二区三区精品视频在线观看| 亚洲视频综合| 国内精品久久久久久久影视麻豆| 亚洲先锋成人| 欧美99在线视频观看| 日韩一区二区精品视频| 国产精品一区二区久久| 免费看的黄色欧美网站| 一本色道久久88综合日韩精品| 欧美亚洲一区二区在线| 亚洲裸体俱乐部裸体舞表演av| 欧美日韩专区| 欧美精品v日韩精品v国产精品| 欧美特黄一区| 99精品国产99久久久久久福利| 黄色亚洲在线| 国产在线精品成人一区二区三区| 欧美在线免费一级片| 欧美成人精品在线| 亚洲欧洲在线免费| 亚洲欧美日韩高清| 136国产福利精品导航| 一二三四社区欧美黄| 亚洲黑丝一区二区| 欧美激情第五页| 日韩图片一区| 国产精品男女猛烈高潮激情| 午夜日韩在线| 亚洲一区二区三区精品动漫| 亚洲高清自拍| 美女主播精品视频一二三四| 午夜亚洲精品| 欧美在线观看网站| 久久精品国产欧美激情| 西西裸体人体做爰大胆久久久| 亚洲精品国久久99热| 亚洲福利国产精品| 亚洲国产精品视频| 国产亚洲精品v| 欧美亚洲不卡| 国产一区深夜福利| 亚洲成色777777女色窝| 1024亚洲| 欧美一区二区三区视频| 久久看片网站| 99av国产精品欲麻豆| 亚洲午夜电影| 欧美在线视频观看| 欧美国产大片| 国产精品美女久久久免费| 国产麻豆成人精品| 亚洲日本中文| 久久久亚洲午夜电影| 亚洲激情视频| 欧美亚洲网站| 国产精品任我爽爆在线播放| 性久久久久久| 亚洲茄子视频| 久久久久www| 国产精品亚洲综合久久| 亚洲第一网站免费视频| 久久国产精品网站| 亚洲永久精品大片| 国产精品久久999| 亚洲激情六月丁香| 久久人人97超碰精品888| 亚洲视频1区| 欧美午夜精品久久久| 一本色道综合亚洲| 日韩视频免费在线| 欧美精品国产一区| 亚洲少妇自拍| 亚洲一级黄色片| 国产精品你懂得| 久久精品一区二区国产| 欧美一级夜夜爽| 韩国精品一区二区三区| 久热精品视频在线观看| 久久综合久久综合久久综合| 亚洲成人原创| 亚洲精品免费在线播放| 国产精品理论片| 噜噜噜在线观看免费视频日韩| 久久久福利视频| 99精品欧美| 性欧美超级视频| 亚洲国产精品一区| 日韩小视频在线观看专区| 国产精品v片在线观看不卡| 午夜精品国产更新| 久久蜜臀精品av| 亚洲一区二区高清| 亚洲综合首页| 亚洲国产高清高潮精品美女| 一本色道综合亚洲| 亚洲精品一品区二品区三品区| 亚洲美女在线视频| 在线观看欧美精品| 亚洲制服欧美中文字幕中文字幕| 激情五月婷婷综合| 亚洲欧美高清| 欧美v国产在线一区二区三区| 午夜精品久久久久99热蜜桃导演| 另类尿喷潮videofree| 久久gogo国模裸体人体| 国产精品福利在线观看网址| 91久久线看在观草草青青| 韩日精品在线| 久久精品91久久香蕉加勒比| 欧美在线观看视频一区二区三区| 国产精品成av人在线视午夜片| 亚洲美女少妇无套啪啪呻吟| 亚洲欧洲日韩在线| 毛片基地黄久久久久久天堂|