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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? strace.cpp

?? Strace: Webcrazy原來(lái)寫(xiě)的很好的代碼
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
     Programmed By ChenChengQin(tsu00@263.net)!
     Welcome to http://webcrazy.yeah.net for more information!
     History:
             10/05/2000 Initial edition!
                        Portion from internet!
             10/07/2000 Bug fixes about deadlock when new process created!
             10/22/2000 Add thread filter!
*/

extern "C" {
#include "ntddk.h"
#include "windef.h"
}
 
#define NT_DEVICE_NAME      L"\\Device\\Strace"
#define DOS_DEVICE_NAME     L"\\DosDevices\\Strace"
#define SYSNAME             "System"

#include "Stracedef.h"

STRACE_BUF_FIELD * StraceBuf1;
STRACE_BUF_FIELD * StraceBuf2;
LONG StraceBufCount1;
LONG StraceBufCount2;
LONG StraceBufMaxCount1 = 1024;
LONG StraceBufMaxCount2 = 1024;

char *keSDTParameter;
char *w32SDTParameter;

DWORD StracePID=0;
BOOLEAN SpyOn=FALSE;
ULONG ProcessNameOffset;

LONG StraceCurrentBufId; 

WORD ProcessFilterEntriesCount;
WORD *ProcessFilterIdArray;

DWORD filter[6];
STRACE_FILTER* strace_filter;

KEVENT StraceBufOverflowEvent;
FAST_MUTEX StraceBuf1Mutex;
FAST_MUTEX StraceBuf2Mutex;
FAST_MUTEX StraceCountMutex;
FAST_MUTEX StraceFilterMutex;

PVOID OldSystemServiceISR;

NTSTATUS
DriverEntry(
    IN PDRIVER_OBJECT DriverObject,
    IN PUNICODE_STRING RegistryPath
    )
{

    PDEVICE_OBJECT deviceObject = NULL;
    NTSTATUS status;
    UNICODE_STRING lNtNameString;
    UNICODE_STRING lWin32NameString;

    RtlInitUnicodeString( &lNtNameString, NT_DEVICE_NAME );

    status = IoCreateDevice(
                 DriverObject,
                 0,                   
                 &lNtNameString,
                 FILE_DEVICE_UNKNOWN,
                 0,                     
                 FALSE,                
                 &deviceObject
                 );

    if ( NT_SUCCESS(status) )
    {

        DriverObject->MajorFunction[IRP_MJ_CREATE] = StraceOpen;
        DriverObject->MajorFunction[IRP_MJ_CLOSE] = StraceClose;
        DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = StraceDeviceControl;

        DriverObject->DriverUnload = StraceUnload;

        RtlInitUnicodeString( &lWin32NameString, DOS_DEVICE_NAME );
    
        
        status = IoCreateSymbolicLink( &lWin32NameString, &lNtNameString );


	KeInitializeEvent(
		&StraceBufOverflowEvent,
		NotificationEvent,
		FALSE
	);


	ExInitializeFastMutex(&StraceBuf1Mutex);
	ExInitializeFastMutex(&StraceBuf2Mutex);
	ExInitializeFastMutex(&StraceCountMutex);
	ExInitializeFastMutex(&StraceFilterMutex);


	StraceBuf1 = (STRACE_BUF_FIELD *) ExAllocatePool( NonPagedPool, (StraceBufMaxCount1+1)* sizeof(STRACE_BUF_FIELD) );
	StraceBuf2 = (STRACE_BUF_FIELD *) ExAllocatePool( NonPagedPool, (StraceBufMaxCount2+1)* sizeof(STRACE_BUF_FIELD) );

	StraceBufCount1 =0;
	StraceBufCount2 =0;

	StraceCurrentBufId = STRACE_FIRST_BUF ;

	ProcessFilterEntriesCount =0;
	ProcessFilterIdArray =0;
        ProcessNameOffset=GetProcessNameOffset();


	StraceSetSystemServiceHook(TRUE);

    }
    else
    {
        DbgPrint ("Strace: Create the device failure!\n") ;
    }
    return status;
}

NTSTATUS
StraceOpen(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )
{

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;

    IoCompleteRequest( Irp, IO_NO_INCREMENT );

    return STATUS_SUCCESS;
}

NTSTATUS
StraceClose(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )
{

    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;

    IoCompleteRequest( Irp, IO_NO_INCREMENT );

    return STATUS_SUCCESS;
}

NTSTATUS
StraceDeviceControl(
    PDEVICE_OBJECT DeviceObject,
    PIRP Irp
    )

{

    PIO_STACK_LOCATION  irpStack;
    PVOID               inputBuffer;
    PVOID               outputBuffer;
    ULONG               inputBufferLength;
    ULONG               outputBufferLength;
    ULONG               ioControlCode;

    Irp->IoStatus.Status      = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;

    irpStack = IoGetCurrentIrpStackLocation (Irp);

    inputBuffer     = Irp->AssociatedIrp.SystemBuffer;
    inputBufferLength   = irpStack->Parameters.DeviceIoControl.InputBufferLength;
    outputBuffer    = Irp->AssociatedIrp.SystemBuffer;
    outputBufferLength  = irpStack->Parameters.DeviceIoControl.OutputBufferLength;
    ioControlCode   = irpStack->Parameters.DeviceIoControl.IoControlCode;

    switch (irpStack->MajorFunction) {

    case IRP_MJ_DEVICE_CONTROL:

        if( Irp->MdlAddress ) {

            outputBuffer = MmGetSystemAddressForMdl( Irp->MdlAddress );
        }

        Irp->IoStatus.Status = StraceProcessDeviceControl(inputBuffer, inputBufferLength, 
                    outputBuffer, outputBufferLength,
                    ioControlCode,&Irp->IoStatus.Information);
        break;
    }

    IoCompleteRequest( Irp, IO_NO_INCREMENT );
    return STATUS_SUCCESS;   

}

VOID
StraceUnload(
    IN PDRIVER_OBJECT DriverObject
    )
{
       StraceSetSystemServiceHook(FALSE);

       ExFreePool(StraceBuf1);
       ExFreePool(StraceBuf2);
       if(keSDTParameter) ExFreePool(keSDTParameter);
       if(w32SDTParameter) ExFreePool(w32SDTParameter);
       if(ProcessFilterIdArray) ExFreePool(ProcessFilterIdArray);

       UNICODE_STRING lWin32NameString;

       RtlInitUnicodeString( &lWin32NameString, DOS_DEVICE_NAME );
       
       IoDeleteSymbolicLink( &lWin32NameString );

       IoDeleteDevice( DriverObject->DeviceObject );
}


void __fastcall StraceInterceptSystemCall()
{

	unsigned int CallNumber;
	int status;
        int ParameterTable;

	__asm{
		mov CallNumber,eax;
                mov ParameterTable,edx
	}

        if(!SpyOn) return;

	KIRQL OldIrql;

	if(CallNumber<strace_filter->ServiceIDFrom||CallNumber>strace_filter->ServiceIDTo)
		return;

        if(ParameterTable<0x80000000&&strace_filter->CallFrom==CALLFROMKERNEL)
             return;
        if(ParameterTable>0x80000000&&strace_filter->CallFrom==CALLFROMUSER)
             return;
	DWORD ProcessId,ThreadId,IsInFilter = 0;
        if((ProcessId=(unsigned int)PsGetCurrentProcessId())==(DWORD)StracePID) return;
        ThreadId=(unsigned int)PsGetCurrentThreadId();
        if(strace_filter->Thrd1!=0||strace_filter->Thrd2!=0||strace_filter->Thrd1!=0){
           if(strace_filter->Thrd1!=0&&ThreadId==strace_filter->Thrd1) IsInFilter=TRUE;
           if(strace_filter->Thrd2!=0&&ThreadId==strace_filter->Thrd2) IsInFilter=TRUE;
           if(strace_filter->Thrd3!=0&&ThreadId==strace_filter->Thrd3) IsInFilter=TRUE;
           if(!IsInFilter) return;
        }
        
	IsInFilter = 0;

        KeRaiseIrql(DISPATCH_LEVEL, &OldIrql);
	ExAcquireFastMutex(&StraceFilterMutex);
        if(ProcessFilterEntriesCount==0) IsInFilter=TRUE;
        else 
            for(register i=0;i < ProcessFilterEntriesCount;i++)
		{
			if( ProcessFilterIdArray[i] == ProcessId )
			{
				IsInFilter = TRUE;
				break;
			}
		}
	ExReleaseFastMutex(&StraceFilterMutex);
	if(!IsInFilter){
	    KeLowerIrql(OldIrql);
            return ;
	}

	ExAcquireFastMutex(&StraceCountMutex);
	if( StraceBufCount1 > StraceBufMaxCount1 )
	{
		StraceBufCount1 = StraceBufMaxCount1;
		StraceBufCount2 =0;
		StraceCurrentBufId = STRACE_SECOND_BUF;
		KeSetEvent(
			&StraceBufOverflowEvent,
			0,
			FALSE
			);
	}
	else if( StraceBufCount2 > StraceBufMaxCount2 )
	{
		StraceBufCount2 = StraceBufMaxCount2;
		StraceBufCount1 =0;
		StraceCurrentBufId = STRACE_FIRST_BUF;
		KeSetEvent(
			&StraceBufOverflowEvent,
			0,
			FALSE
			);
			
	}
	ExReleaseFastMutex(&StraceCountMutex);
	if(StraceCurrentBufId == STRACE_FIRST_BUF){
		ExAcquireFastMutex(&StraceBuf1Mutex);
		StraceBuf1[StraceBufCount1].CallNumber = (WORD)CallNumber;
		KeQuerySystemTime(&(StraceBuf1[StraceBufCount1].Time));
		StraceBuf1[StraceBufCount1].ProcessId = (WORD)ProcessId;
		StraceBuf1[StraceBufCount1].ThreadId = (WORD)ThreadId;
                StraceBuf1[StraceBufCount1].ParameterTable = ParameterTable;
                GetProcessName(StraceBuf1[StraceBufCount1].ProcessName);

                if(CallNumber<SERVICEIDUSERFROM)
	  	   StraceBuf1[StraceBufCount1].ParameterNumbers=(*(char *)((int)keSDTParameter+CallNumber))/4;
                else 
		   StraceBuf1[StraceBufCount1].ParameterNumbers=(*(char *)((int)w32SDTParameter+CallNumber-SERVICEIDUSERFROM))/4;

                for(CallNumber=0;CallNumber<StraceBuf1[StraceBufCount1].ParameterNumbers;CallNumber++)
                   StraceBuf1[StraceBufCount1].Parameter[CallNumber]=*(DWORD *)(ParameterTable+CallNumber*sizeof(DWORD));

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲黄色录像片| 久久精品国产亚洲aⅴ| 精品久久一二三区| 色久优优欧美色久优优| 国内精品免费**视频| 亚洲综合视频在线观看| 日本一区二区免费在线| 欧美一级生活片| 欧美在线三级电影| 成人免费毛片app| 国产一区二区三区四区五区美女| 亚洲成av人片在www色猫咪| 国产精品麻豆久久久| 亚洲精品一区在线观看| 欧美日韩国产乱码电影| 97成人超碰视| 丁香婷婷综合色啪| 国产在线国偷精品免费看| 婷婷开心久久网| 夜夜嗨av一区二区三区中文字幕 | 久久er99精品| 五月天久久比比资源色| 亚洲欧美日本在线| 国产精品不卡一区二区三区| 久久男人中文字幕资源站| 91精品福利在线一区二区三区| 欧洲一区二区av| 色一情一伦一子一伦一区| 不卡的av电影在线观看| 国产成人免费在线观看| 国产高清视频一区| 国产精品一区在线观看乱码| 国产麻豆精品在线| 国产成人综合亚洲网站| 国产乱一区二区| 国产高清精品久久久久| 国产91丝袜在线18| 国产99精品在线观看| 成人一道本在线| av成人老司机| 91麻豆自制传媒国产之光| 99re在线精品| 色综合久久久久综合体桃花网| 99精品在线免费| 91视频在线看| 欧美色精品在线视频| 欧美日韩高清一区| 日韩一区二区免费视频| 欧美va日韩va| 国产亚洲一区二区三区在线观看| 久久亚洲综合色一区二区三区| 久久麻豆一区二区| 欧美国产一区二区在线观看| 国产精品久久久久久久久图文区 | 91在线精品一区二区三区| 色婷婷综合久色| 欧美日韩国产区一| 精品欧美乱码久久久久久 | 色悠悠久久综合| 欧美日韩精品一区二区三区四区| 欧美日韩性生活| 欧美高清视频www夜色资源网| 日韩午夜在线观看| 国产亚洲短视频| 一区二区三区在线观看视频 | 亚洲成人免费av| 久久超级碰视频| 成人黄色免费短视频| 色综合久久综合网| 日韩一级片网址| 国产欧美精品区一区二区三区| 亚洲欧洲三级电影| 五月婷婷另类国产| 国产老女人精品毛片久久| 99精品视频一区二区| 欧美理论在线播放| 久久精品日产第一区二区三区高清版| 国产精品久久久久aaaa樱花| 亚洲国产aⅴ成人精品无吗| 九九**精品视频免费播放| 不卡高清视频专区| 91精品国产品国语在线不卡| 国产嫩草影院久久久久| 香蕉av福利精品导航| 国产精品正在播放| 欧美女孩性生活视频| 国产精品免费av| 卡一卡二国产精品| 日本精品裸体写真集在线观看| 日韩欧美国产综合| 亚洲美女一区二区三区| 久久se精品一区二区| 欧美在线观看你懂的| 精品国产91亚洲一区二区三区婷婷| 亚洲少妇中出一区| 国产成人免费在线视频| 欧美一区二区女人| 亚洲精品ww久久久久久p站| 国产精品自拍网站| 欧美一区二区精品| 一区二区三区在线观看网站| 国产一区二区在线观看免费| 欧美人伦禁忌dvd放荡欲情| 国产精品国产三级国产aⅴ无密码| 麻豆精品视频在线观看免费| 欧美中文一区二区三区| 国产精品麻豆一区二区| 国产一区二区看久久| 欧美电影在线免费观看| 亚洲美女视频在线观看| 成人激情文学综合网| 精品国产一区二区三区四区四| 一区二区三区美女| 色综合久久中文字幕综合网| 欧美国产视频在线| 国产精品一二三区在线| 精品精品欲导航| 日韩av一区二| 在线综合+亚洲+欧美中文字幕| 国产精品国模大尺度视频| 国产一区二区三区在线观看精品| 日韩视频一区在线观看| 亚洲成人三级小说| 欧美三级三级三级爽爽爽| 亚洲精品日韩一| 91热门视频在线观看| 国产精品久久久久9999吃药| 成人av在线资源网站| 国产亚洲欧美一区在线观看| 国内精品国产成人国产三级粉色 | 久久国产成人午夜av影院| 制服丝袜国产精品| 午夜精品久久久久久| 欧美日韩国产区一| 日韩av电影免费观看高清完整版 | 91浏览器在线视频| 亚洲精品五月天| 欧美视频完全免费看| 亚洲综合清纯丝袜自拍| 欧美日韩一区二区欧美激情| 亚洲一区二区三区四区的| 欧美色图在线观看| 丝袜亚洲另类欧美| 日韩免费一区二区三区在线播放| 免费在线观看视频一区| 日韩欧美成人一区二区| 国产在线精品免费| 国产精品视频在线看| 成人黄色电影在线 | 天天综合色天天| 日韩午夜小视频| 国产在线精品不卡| 中文字幕中文乱码欧美一区二区| 成人va在线观看| 亚洲美女在线一区| 91精品国产91久久久久久一区二区 | 国产日韩欧美制服另类| 国产98色在线|日韩| 亚洲色图第一区| 欧美日韩亚洲综合| 极品尤物av久久免费看| 国产欧美一二三区| 91久久精品一区二区二区| 日韩一区欧美二区| www一区二区| 色偷偷久久一区二区三区| 日韩电影网1区2区| 国产精品女主播av| 在线播放中文字幕一区| 国产精品亚洲午夜一区二区三区 | 精品一区二区综合| 最新日韩在线视频| 这里只有精品视频在线观看| 国产精品一区二区三区乱码| 亚洲精品亚洲人成人网| 日韩欧美在线影院| 99久久精品国产一区| 日韩一区欧美二区| |精品福利一区二区三区| 91精品国产综合久久福利| 国产成人精品免费一区二区| 亚洲成人自拍偷拍| 欧美韩国日本综合| 欧美一区二区三区精品| 色综合一区二区| 伦理电影国产精品| 亚洲免费成人av| 久久蜜桃一区二区| 欧美精品色一区二区三区| 成人免费精品视频| 久久99精品久久久久| 亚洲综合无码一区二区| 久久久久久**毛片大全| 777色狠狠一区二区三区| jizzjizzjizz欧美| 狠狠色狠狠色综合系列| 五月婷婷综合在线| 一区二区三区影院| 国产精品国产自产拍高清av| 日韩欧美激情一区|