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

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

?? strace.cpp

?? Strace: Webcrazy原來寫的很好的代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
     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));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美tk—视频vk| 国产在线播精品第三| 久久久三级国产网站| 日韩一区二区三区视频| 欧美乱妇一区二区三区不卡视频| 9色porny自拍视频一区二区| av中文字幕不卡| 成年人午夜久久久| 9久草视频在线视频精品| 91亚洲永久精品| 91免费在线播放| 在线视频一区二区三区| 91久久奴性调教| 在线亚洲高清视频| 91精品国产黑色紧身裤美女| 日韩丝袜美女视频| 久久精品亚洲精品国产欧美kt∨ | 中文字幕一区二区三区在线不卡| 久久精品视频在线免费观看| 国产婷婷色一区二区三区在线| 国产欧美一区二区在线观看| 国产精品美女视频| 亚洲人精品一区| 亚洲午夜国产一区99re久久| 日韩黄色免费电影| 久久99国产精品尤物| 国产九色sp调教91| 91亚洲精品久久久蜜桃网站 | 国产精品女主播av| 亚洲精品视频在线观看网站| 亚洲成va人在线观看| 久久er99热精品一区二区| 国产精品资源在线看| 91丝袜美腿高跟国产极品老师| 欧美日韩一区精品| www国产亚洲精品久久麻豆| 中文字幕免费一区| 亚洲国产一区二区视频| 蜜臂av日日欢夜夜爽一区| 国产丶欧美丶日本不卡视频| 91丝袜国产在线播放| 欧美裸体一区二区三区| 久久综合久久久久88| 亚洲人成在线播放网站岛国| 日韩和欧美的一区| 国产成人三级在线观看| 99精品视频在线观看免费| 国产成人夜色高潮福利影视| 国产精品亚洲综合一区在线观看| 成人av第一页| 欧美日韩第一区日日骚| 亚洲国产经典视频| 性欧美疯狂xxxxbbbb| 国产成人av一区二区三区在线观看| 91免费观看在线| 日韩免费视频线观看| 日本特黄久久久高潮| 成人性生交大合| 欧美一区二区日韩一区二区| 国产精品国产三级国产普通话蜜臀| 日日夜夜精品视频免费| 成人免费黄色大片| 日韩欧美亚洲另类制服综合在线| 亚洲日本丝袜连裤袜办公室| 另类调教123区| 欧美图片一区二区三区| 国产欧美日韩不卡| 日韩精品一二三| 在线一区二区视频| 精品国产一区二区三区忘忧草 | 亚洲激情av在线| 韩国av一区二区三区四区| 国产精品一区二区免费不卡| 欧洲生活片亚洲生活在线观看| 久久久久久久综合| 视频在线观看91| 色先锋aa成人| 中文字幕的久久| 激情综合色综合久久| 欧美日韩国产一级| 亚洲三级小视频| 国产91精品久久久久久久网曝门| 欧美一级日韩一级| 午夜精品一区二区三区电影天堂 | 88在线观看91蜜桃国自产| 一区在线中文字幕| 国产高清在线精品| 精品日韩一区二区三区免费视频| 午夜欧美在线一二页| 色婷婷狠狠综合| 国产精品久久久久精k8| 国产精品一区二区在线观看不卡| 日韩亚洲欧美在线观看| 午夜成人在线视频| 欧美三级资源在线| 亚洲一区二区三区在线播放| 91蜜桃传媒精品久久久一区二区| 国产精品网站导航| 国产不卡视频一区二区三区| 久久这里只有精品6| 精品午夜久久福利影院| 精品少妇一区二区三区在线播放| 免费看欧美美女黄的网站| 欧美三级三级三级| 亚洲不卡一区二区三区| 精品视频一区二区三区免费| 亚洲图片有声小说| 欧美日韩在线亚洲一区蜜芽| 亚洲一区二区视频在线观看| 91九色最新地址| 亚洲一二三区视频在线观看| 欧美日韩精品福利| 日韩av中文字幕一区二区三区| 欧美一区二区福利在线| 美女精品一区二区| 精品国产免费视频| 国产suv精品一区二区6| 亚洲欧洲韩国日本视频| 91黄色免费看| 性欧美大战久久久久久久久| 日韩欧美国产一区二区在线播放 | 91精品国产综合久久久久久| 青草av.久久免费一区| 精品国偷自产国产一区| 欧美一区二区福利在线| 久久爱www久久做| 国产精品网友自拍| 欧美性大战久久久久久久蜜臀| 午夜a成v人精品| 精品国产乱码久久| 成人在线一区二区三区| 亚洲欧美一区二区三区极速播放| 欧美亚洲国产一区二区三区| 日本欧美一区二区三区乱码| 久久久久九九视频| 91伊人久久大香线蕉| 午夜精品一区二区三区三上悠亚| 日韩欧美国产一区二区在线播放| 成人综合日日夜夜| 亚洲一区av在线| 精品sm在线观看| 色综合天天综合在线视频| 亚洲图片自拍偷拍| 久久久精品国产免费观看同学| 91网址在线看| 久久99精品久久久久久动态图| 国产精品毛片无遮挡高清| 欧美日产国产精品| 国产精品影音先锋| 一区二区免费看| 久久综合九色综合欧美98| 91丨九色丨黑人外教| 美日韩一区二区| 亚洲欧洲美洲综合色网| 日韩精品中午字幕| 色综合久久88色综合天天| 毛片av一区二区| 亚洲男人的天堂网| 精品国产乱码久久久久久1区2区| 一本久久a久久精品亚洲| 久久66热re国产| 亚洲伊人色欲综合网| 欧美韩日一区二区三区四区| 7777精品伊人久久久大香线蕉完整版| 国产99久久久精品| 日本视频免费一区| 综合激情网...| 国产欧美一区二区在线| 日韩欧美一区二区三区在线| 色88888久久久久久影院野外| 国产一区二区三区最好精华液| 一区二区高清免费观看影视大全| 久久精品人人做人人爽人人| 欧美精品乱码久久久久久| 99精品热视频| 国产激情一区二区三区| 免播放器亚洲一区| 亚洲曰韩产成在线| 中文字幕中文乱码欧美一区二区| 欧美草草影院在线视频| 欧美日韩高清一区二区不卡| 91在线免费视频观看| 国产成人啪午夜精品网站男同| 久久99精品国产.久久久久| 亚洲mv大片欧洲mv大片精品| 亚洲精品视频一区二区| 亚洲国产精品ⅴa在线观看| 亚洲精品在线网站| 欧美一区二区三区精品| 欧美精选午夜久久久乱码6080| 色先锋aa成人| 一本大道久久a久久综合婷婷| heyzo一本久久综合| 国产精品18久久久久久久久 | 在线免费视频一区二区| www.性欧美| 成人听书哪个软件好| 国产成人一区在线| 国产成人亚洲综合a∨猫咪| 国产一区二区h|