亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? driver.c

?? Rootkit upload by benina rea
?? C
字號:
/*
 *	PatchFinder for Windows 2000
 *	Joanna Rutkowska, joanna at mailsnare dot net
 *	(c) 2003
 *
 */
#include <ntddk.h>
#include <stdio.h>
#include "driver.h"
#include "sst.h"
#include "interrupt.h"
#include "dbprotect.h"
#include "..\inc\kernel_iface.h"
#include "..\inc\config.h"

PNTPROC serviceTbl;
PCHAR	argumentTbl;
NTPROC origService;
HANDLE traceThreadId;	// id of the thread which will be traced
int origKiSystemService;
int origDebugHandler;
unsigned PF_traps;		// the most important dword...
unsigned PF_traps_frozen;

#ifdef TRACEPATH
volatile int* PF_trace = NULL;
unsigned PF_tracemaxlen = 4*50000;
#endif

int pfsrv_started = 0;	// pfService cannot be restarted!

__declspec(naked) NewKiSystemService()
{
	__asm {
		
		pushad
		push	fs
		mov		bx, 0x30			// kernel fs
		mov		fs, bx
		push	ds
		push	es


		mov		eax, fs:[0x124];	// pETHREAD
		mov		eax, [eax+0x1e4];	// Cid
		cmp		eax, traceThreadId;
		jne		goon;
		
		pushfd;
		pop		eax;
		or		eax, 0x100;
		push	eax;
		popfd;
		nop;
		nop;
		nop;

goon:	
		pop es
		pop ds
		pop fs
		popad
		jmp		origKiSystemService;
	}
}




__declspec(naked) NewDebugHandler2()
{
	__asm {
		cli;
		pushfd;
		push eax;
		mov eax, DR6;
		test ax, 0x100f;	// BD |B3|B2|B1|B0
		jz goon;
							// FIXME: do something more inteligent
		int 3;				// then just crashing the system!
goon:
		push ecx;
		// FIXME: push _KERNEL_DS
#ifdef TRACEPATH
		mov ecx, PF_trace;
		jecxz pf_debug_end;
#endif

		// FIXME: move before 'goon', eax is already set with DR6
		mov eax, DR6;		// check BS (signgle step) bit in DR6
		test ah, 0x40;
		jz pf_debug_end;

#ifdef TRACEPATH
		mov eax, PF_traps;
		shl eax, 2;
		cmp eax, PF_tracemaxlen;
		jg pf_debug_end;

		add ecx, eax;
		// FIXME: esp + X, change X when put some pushes before
		// FIXME: maybe better it'll be to use ebp...
		mov eax, dword ptr [esp + 12];	// get the debug handler retaddr
		
		mov dword ptr [ecx], eax;
#endif		
		inc	PF_traps;
pf_debug_end:	
		pop ecx;
		pop eax;
		popfd;	
		sti;
		iretd;
	}
}


__declspec(naked) NewDebugHandler1()
{
	__asm {
		jmp NewDebugHandler2;
	}
}





void OnUnload( IN PDRIVER_OBJECT DriverObject ) {

#ifdef DR_PROTECTION
	KdPrint(("pf: can not be unloaded!\n"));
	return;
#else
	KdPrint(("pf: unloading...\n"));

	KdPrint(("pf: removing pfServie...\n"));
	serviceTbl [pfServiceNo] = (NTPROC) origService;

	KdPrint(("pf: unhooking int 0x2e...\n"));
	setIntHandler (NT_SYSTEM_SERVICE_INT, origKiSystemService);

	KdPrint(("pf: unhooking debug int...\n"));
	setIntHandler (NT_DEBUG_INT, origDebugHandler);

#ifdef TRACEPATH
	KdPrint(("pf: freeing PF_trace...\n"));
	if (PF_trace) 
		MmFreeNonCachedMemory ((PVOID)PF_trace, PF_tracemaxlen);

	KdPrint(("pf: unloaded\n"));
#endif
#endif
}


NTSTATUS pfService(int magic, int cmd, int *tracebuf) {		
#ifdef TRACEPATH
	int nb;
#endif
	// assuming that origService takes at least 2 arguments! (FIXME: autocheck)
	if (magic == serviceMagic) {
		switch (cmd) {
			
			case PF_START:
				traceThreadId = PsGetCurrentThreadId();
				PF_traps = 0;
				PF_traps_frozen = 0;
				KdPrint (("PF_START: threadID = %#x, argSz = %#x\n",
					traceThreadId, argumentTbl[pfServiceNo]));
				return 0;
				// we don't care about 'ret xx', becouse
				// KiSystemService is doing 'mov esp, ebp'
				// after returning from our function. 
			
			case PF_GET_COUNT:
				if (PF_traps_frozen > 0) 
					return PF_traps_frozen;	// to guarantee that
							// (pfStop();...;pfStop()) == pfStop();

				traceThreadId = (HANDLE)0xffffffff;
				PF_traps_frozen = PF_traps;			
				
				KdPrint (("PF_GET_COUNT: PF_traps = %#x, frozen = %#x\n",
					PF_traps, PF_traps_frozen));
				
				return PF_traps_frozen;

			case PF_GET_TRACE:
				
				KdPrint (("PF_GET_TRACE: PF_traps_frozen = %#x\n", PF_traps_frozen));
#ifdef TRACEPATH
				nb = ((unsigned)PF_traps_frozen < (PF_tracemaxlen/sizeof(int))) ? 
				(PF_traps_frozen*sizeof(int)) : PF_tracemaxlen;
				
				KdPrint (("PF_GET_TRACE: tracebuf = %#x, PF_trace = %#x, nb = %#x\n",
					tracebuf, PF_trace, nb));
				memcpy ((char*)tracebuf, (char*)PF_trace, nb);
#endif
				return PF_traps_frozen;

			case PF_QUERY:
				KdPrint (("PF_QUERY\n"));
				return PF_ANSWER;

			case PF_SERVICE_STARTED:
				return pfsrv_started++;

			default:
				KdPrint (("pfService called with unknown cmd\n"));
			
		}
		
		return 0;

	}
	_asm {
		mov		esp, ebp;
		pop		ebp;
		jmp		origService;
	}
	
}






NTSTATUS DriverEntry( IN PDRIVER_OBJECT driverObject,
		      IN PUNICODE_STRING registryPath ) {
    
	KdPrint (("pf: loading...\n"));
	
	serviceTbl = KeServiceDescriptorTable->ntoskrnl.ServiceTable;
	argumentTbl = KeServiceDescriptorTable->ntoskrnl.ArgumentTable;
	driverObject->DriverUnload  = OnUnload; 
	traceThreadId = (HANDLE)0xffffffff;


	KdPrint (("pf: installing at service no. %#x...\n", pfServiceNo));
    origService = serviceTbl [pfServiceNo];
	serviceTbl [pfServiceNo] = (NTPROC) pfService;
	KdPrint (("pf: servTbl[%#x] at %#x\n",
		pfServiceNo, &serviceTbl[pfServiceNo] ));

	
	KdPrint (("pf: hooking int 0x2e...\n"));
	origKiSystemService = getIntHandler (NT_SYSTEM_SERVICE_INT);
	setIntHandler (NT_SYSTEM_SERVICE_INT, (int)NewKiSystemService);
	

	KdPrint (("pf: hooking debug int...\n"));
	origDebugHandler = getIntHandler (NT_DEBUG_INT);
	setIntHandler (NT_DEBUG_INT, (int)NewDebugHandler1);
	KdPrint (("pf: idt[%d] at %#x\n",
		NT_DEBUG_INT, getIntGateAddr(NT_DEBUG_INT) ));


#ifdef TRACEPATH
	KdPrint (("pf: allocating memory for PF_trace buffer (%d bytes)\n",
		PF_tracemaxlen));
	PF_trace = MmAllocateNonCachedMemory (PF_tracemaxlen);	// FIXME
	
	KdPrint (("pf: PF_trace at %#x\n", PF_trace));
#endif
	
#ifdef DR_PROTECTION	
	KdPrint (("pf: setting hardware protection...\n"));

	dbProtect (DB_DR0, (int)getIntGateAddr(NT_DEBUG_INT), DB_LEN_4B, DB_PROT_WRITE);
	dbProtect (DB_DR1, (int)getIntGateAddr(NT_DEBUG_INT)+4, DB_LEN_4B, DB_PROT_WRITE);
	dbProtect (DB_DR2, (int)NewDebugHandler1, DB_LEN_4B, DB_PROT_RW);
	dbSetGeneralProtection ();
#endif

	
	
	
	KdPrint (("pf: loaded succesfully.\n"));
	return 0;	
}



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
综合网在线视频| 久久成人麻豆午夜电影| 秋霞午夜av一区二区三区| 国产一区二区三区四区五区入口| 日本高清视频一区二区| 久久综合给合久久狠狠狠97色69| 亚洲免费在线视频| 国产美女av一区二区三区| 日本韩国欧美一区| 亚洲国产精品精华液2区45| 日韩电影在线观看一区| 91麻豆精品在线观看| wwww国产精品欧美| 日韩va亚洲va欧美va久久| 色综合网色综合| 国产精品久久久久婷婷二区次| 免费成人在线播放| 欧美精品色综合| 亚洲午夜私人影院| 一本高清dvd不卡在线观看| 久久久噜噜噜久久人人看| 日韩和欧美的一区| 欧美日韩亚洲综合在线| 亚洲人xxxx| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 亚洲一区二区黄色| 91免费视频观看| 国产精品沙发午睡系列990531| 狠狠色狠狠色合久久伊人| 91精品国产欧美一区二区成人| 亚洲高清在线视频| 欧美性生活久久| 亚洲第一狼人社区| 精品污污网站免费看| 亚洲精品高清在线观看| 91麻豆福利精品推荐| 中文字幕一区二区日韩精品绯色| 国产电影一区在线| 亚洲国产精品二十页| 成人av网址在线| 综合分类小说区另类春色亚洲小说欧美| 国产一区二区三区av电影 | 欧美精品丝袜中出| 日韩精品福利网| 欧美电影免费提供在线观看| 日韩在线卡一卡二| 精品国产免费一区二区三区香蕉 | 亚洲人成7777| 欧美夫妻性生活| 另类的小说在线视频另类成人小视频在线 | 色综合网站在线| 亚洲第一主播视频| 久久尤物电影视频在线观看| 国产不卡在线视频| 亚洲国产sm捆绑调教视频| 91精品久久久久久久99蜜桃| 久久精品国产**网站演员| 欧美国产日韩一二三区| 91丨porny丨国产| 日韩电影在线一区二区三区| 久久精品欧美一区二区三区麻豆| 成人精品视频.| 亚洲福利视频三区| 欧美不卡一区二区三区四区| 亚洲一区二区视频| 日韩欧美成人一区| 国产白丝精品91爽爽久久| 国产日韩欧美精品综合| 成人h精品动漫一区二区三区| 中文字幕中文字幕一区| 91麻豆蜜桃一区二区三区| 国产精品久久精品日日| 91在线精品一区二区三区| 亚洲国产视频一区二区| 欧美一区二区人人喊爽| 国产一区二区在线观看视频| 国产欧美精品一区二区色综合朱莉| 国产成人免费视频网站| 中文字幕综合网| 欧美精品一二三| 国产精品综合视频| 专区另类欧美日韩| 国产日韩精品一区二区三区| 91色porny蝌蚪| 免费人成网站在线观看欧美高清| 精品国一区二区三区| 国产剧情av麻豆香蕉精品| 亚洲欧美一区二区三区极速播放 | 色哟哟日韩精品| 一片黄亚洲嫩模| 国产清纯白嫩初高生在线观看91 | 狠狠网亚洲精品| 亚洲日本在线看| 日韩一区二区在线看| 丰满少妇在线播放bd日韩电影| 亚洲精品视频自拍| 日韩一区二区免费在线观看| av电影在线观看一区| 捆绑紧缚一区二区三区视频| 中文字幕在线不卡视频| 5月丁香婷婷综合| 99久久精品一区| 久久精品国产免费| 亚洲午夜视频在线| 国产精品久久久久aaaa樱花 | 国产网站一区二区| 欧美区视频在线观看| 成人app在线| 另类专区欧美蜜桃臀第一页| 国产精品乱码一区二三区小蝌蚪| 欧美一区二区精品在线| 99久久国产综合精品麻豆| 狂野欧美性猛交blacked| 亚洲小少妇裸体bbw| 国产精品全国免费观看高清| 日韩一区二区三免费高清| 日本道在线观看一区二区| 成人免费看黄yyy456| 久久爱另类一区二区小说| 麻豆一区二区99久久久久| 亚洲主播在线播放| 中文字幕一区二区三| 欧美一区二区精品久久911| 欧美日韩亚洲另类| 欧美午夜精品一区| 欧美中文字幕久久| 91精品办公室少妇高潮对白| 95精品视频在线| 成人动漫一区二区在线| 国产一区二区三区日韩| 粉嫩av一区二区三区| 成人永久看片免费视频天堂| 美女视频黄a大片欧美| 日日摸夜夜添夜夜添国产精品 | 在线观看91视频| 在线观看成人免费视频| 欧美在线三级电影| 在线观看一区日韩| 欧美自拍偷拍午夜视频| 欧美三级视频在线| 欧美伦理视频网站| 欧美精品一区二区三区视频| 日韩精品一区二区三区视频播放 | 成人app软件下载大全免费| 成人午夜精品在线| www.亚洲色图.com| 91老司机福利 在线| 色狠狠色狠狠综合| 欧美日韩综合不卡| 欧美日韩国产影片| 日韩欧美的一区| 久久这里只有精品首页| 久久精品欧美一区二区三区麻豆| 国产欧美日韩综合| 中文字幕在线不卡一区| 亚洲精品免费在线观看| 亚洲成a人片在线不卡一二三区| 天天亚洲美女在线视频| 精品一区二区三区视频在线观看| 成人免费视频播放| 在线免费观看日本一区| 欧美一区二区三区白人| 日韩欧美国产小视频| 亚洲欧美福利一区二区| 亚洲制服丝袜av| 国模少妇一区二区三区| 91在线小视频| 日韩一区二区三区免费看| 国产欧美精品一区二区色综合朱莉| 欧美男女性生活在线直播观看| 国产欧美一区二区精品性| 夜夜嗨av一区二区三区四季av| 首页亚洲欧美制服丝腿| 国产成人在线网站| 欧美性一二三区| 久久先锋资源网| 亚洲激情在线激情| 亚洲同性gay激情无套| 国产精品一区二区三区网站| 在线观看免费一区| 久久九九久久九九| 午夜激情一区二区三区| 岛国av在线一区| 欧美日韩1234| 日韩欧美在线综合网| 午夜精品久久久久久久99樱桃| 国产一区二区精品久久| 欧美日韩精品一二三区| 国产精品久久久久久久久动漫 | 国产精品人人做人人爽人人添| 丝袜脚交一区二区| 色吊一区二区三区| 亚洲欧洲成人av每日更新| 久久99国产精品久久99| 欧美日韩成人在线一区| 亚洲人成在线播放网站岛国| 国产成人精品影视| 精品福利一区二区三区| 亚洲资源中文字幕| 欧美日韩一二三区|