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

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

?? hellowdm.cpp

?? 驅動程序WDM很好的啊,確實不錯的啊沒辦法啊
?? CPP
字號:
/***************************************************************
程序名稱:Hello World for WDM
文件名稱:HelloWDM.cpp
作者:羅聰
日期:2002-8-16
***************************************************************/

//一定要的頭文件,聲明了函數模塊和變量:
#include "HelloWDM.h"
#include "Ioctl.h"


KSPIN_LOCK BufferLock;
PUCHAR	Buffer = NULL;
ULONG	BufferSize = 0;

/***************************************************************
函數名稱:DriverEntry()
功能描述:WDM程序入口
***************************************************************/
//extern "C"是必須的,表示“用C鏈接”。如果你的文件名是HelloWDM.c的話,這句可以省略。
extern "C"
NTSTATUS DriverEntry(    IN PDRIVER_OBJECT DriverObject,
                        IN PUNICODE_STRING RegistryPath)
{
	NTSTATUS StatusL = STATUS_SUCCESS; 
	OBJECT_ATTRIBUTES ObjectAttributesL; 
	UNICODE_STRING UniFileNameL; 
	IO_STATUS_BLOCK IoStatusBlockL;
	HANDLE hFile ; 

	PCWSTR FileName = L"\\\\??\\\\d:\\\\readme.dat";
    DbgPrint("Starting DriverEntry()\n");
    
    //指定“添加設備”消息由函數“HelloWDMAddDevice()”來處理:
    DriverObject->DriverExtension->AddDevice = HelloWDMAddDevice;
    DriverObject->DriverUnload = Wdm1Unload;
    //指定“即插即用”消息由函數“HelloWDMPnp()”來處理:
    DriverObject->MajorFunction[IRP_MJ_PNP] = HelloWDMPnp;
    
    DriverObject->MajorFunction[IRP_MJ_CREATE] = Wdm1Create;
    DriverObject->MajorFunction[IRP_MJ_CLOSE] = Wdm1Close;

	DriverObject->MajorFunction[IRP_MJ_READ] = Wdm1Read;
	DriverObject->MajorFunction[IRP_MJ_WRITE] = Wdm1Write;
	DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = Wdm1DeviceControl;
	
	KeInitializeSpinLock(&BufferLock);
	DbgPrint("DriverEntry completed");    
	
	
	//RtlInitUnicodeString(&UniFileNameL,L"\\\\??\\\\C:\\\\TestDat.dat\");
	RtlInitUnicodeString(&UniFileNameL,FileName);
	InitializeObjectAttributes(&ObjectAttributesL,&UniFileNameL, OBJ_CASE_INSENSITIVE,NULL,NULL); 

	StatusL = ZwCreateFile(&hFile, 
			  GENERIC_WRITE|SYNCHRONIZE|FILE_APPEND_DATA, 
			  &ObjectAttributesL, 
			  &IoStatusBlockL, 
			  0, 
			  FILE_ATTRIBUTE_NORMAL, 
			  FILE_SHARE_DELETE, 
			  FILE_OPEN_IF, 
			  FILE_SYNCHRONOUS_IO_NONALERT, 
			  NULL, 
			  0); 
	if(!NT_SUCCESS(StatusL)) 
	{ 
	    //DbgPrint("Cann\'t ZwCreateFile %s : 0x%x\\n\"); 
	}
	//返回一個NTSTATUS值STATUS_SUCCESS。幾乎所有的驅動程序例程都必須返回一個NTSTATUS值,這些值在NTSTATUS.H DDK頭文件中有詳細的定義。
    return STATUS_SUCCESS;
}

NTSTATUS Wdm1Create(IN PDEVICE_OBJECT fdo,
					IN PIRP Irp)
{
	PIO_STACK_LOCATION IrpStack = IoGetCurrentIrpStackLocation(Irp);
	DbgPrint( "Create File is %T", &(IrpStack->FileObject->FileName));

	// Complete successfully
	return CompleteIrp(Irp,STATUS_SUCCESS,0);
}

NTSTATUS Wdm1Close(	IN PDEVICE_OBJECT fdo,
					IN PIRP Irp)
{
	DbgPrint("Wdm1Close");

	// Complete successfully
	return CompleteIrp(Irp,STATUS_SUCCESS,0);
}

NTSTATUS Wdm1DeviceControl(	IN PDEVICE_OBJECT fdo,
							IN PIRP Irp)
{
	PIO_STACK_LOCATION IrpStack = IoGetCurrentIrpStackLocation(Irp);
	NTSTATUS status = STATUS_SUCCESS;
	ULONG BytesTxd = 0;

	ULONG ControlCode = IrpStack->Parameters.DeviceIoControl.IoControlCode;
	ULONG InputLength = IrpStack->Parameters.DeviceIoControl.InputBufferLength;
	ULONG OutputLength = IrpStack->Parameters.DeviceIoControl.OutputBufferLength;

	DbgPrint("DeviceIoControl: Control code %x InputLength %d OutputLength %d",
				ControlCode, InputLength, OutputLength);

	// Get access to the shared buffer
	KIRQL irql;
	KeAcquireSpinLock(&BufferLock,&irql);
	switch( ControlCode)
	{
	///////	Zero Buffer
	case IOCTL_WDM1_ZERO_BUFFER:
		// Zero the buffer
		if( Buffer!=NULL && BufferSize>0)
			RtlZeroMemory(Buffer,BufferSize);
		break;

	///////	Remove Buffer
	case IOCTL_WDM1_REMOVE_BUFFER:
		if( Buffer!=NULL)
		{
			ExFreePool(Buffer);
			Buffer = NULL;
			BufferSize = 0;
		}
		break;

	///////	Get Buffer Size as ULONG
	case IOCTL_WDM1_GET_BUFFER_SIZE:
		if( OutputLength<sizeof(ULONG))
			status = STATUS_INVALID_PARAMETER;
		else
		{
			BytesTxd = sizeof(ULONG);
			RtlCopyMemory(Irp->AssociatedIrp.SystemBuffer,&BufferSize,sizeof(ULONG));
		}
		break;

	///////	Get Buffer
	case IOCTL_WDM1_GET_BUFFER:
		if( OutputLength>BufferSize)
			status = STATUS_INVALID_PARAMETER;
		else
		{
			BytesTxd = OutputLength;
			RtlCopyMemory(Irp->AssociatedIrp.SystemBuffer,Buffer,BytesTxd);
		}
		break;

	///////	Invalid request
	default:
		status = STATUS_INVALID_DEVICE_REQUEST;
	}
	// Release shared buffer
	KeReleaseSpinLock(&BufferLock,irql);

	DbgPrint("DeviceIoControl: %d bytes written",(int)BytesTxd);

	// Complete IRP
	return CompleteIrp(Irp,status,BytesTxd);
}

NTSTATUS Wdm1Read(IN PDEVICE_OBJECT fdo,
				  IN PIRP Irp)
{
	PIO_STACK_LOCATION IrpStack = IoGetCurrentIrpStackLocation(Irp);
	NTSTATUS status = STATUS_SUCCESS;
	LONG BytesTxd = 0;

	// Get call parameters
	LONGLONG FilePointer = IrpStack->Parameters.Read.ByteOffset.QuadPart;
	ULONG ReadLen = IrpStack->Parameters.Read.Length;
	DbgPrint("Read %d bytes from file pointer %d",(int)ReadLen,(int)FilePointer);

	// Get access to the shared buffer
	KIRQL irql;
	KeAcquireSpinLock(&BufferLock,&irql);

	// Check file pointer
	if( FilePointer<0)
		status = STATUS_INVALID_PARAMETER;
	if( FilePointer>=(LONGLONG)BufferSize)
		status = STATUS_END_OF_FILE;

	if( status==STATUS_SUCCESS)
	{
		// Get transfer count
		if( ((ULONG)FilePointer)+ReadLen>BufferSize)
		{
			BytesTxd = BufferSize - (ULONG)FilePointer;
			if( BytesTxd<0) BytesTxd = 0;
		}
		else
			BytesTxd = ReadLen;

		// Read from shared buffer
		if( BytesTxd>0 && Buffer!=NULL)
			RtlCopyMemory( Irp->AssociatedIrp.SystemBuffer, Buffer+FilePointer, BytesTxd);
	}

	// Release shared buffer
	KeReleaseSpinLock(&BufferLock,irql);

	DbgPrint("Read: %d bytes returned",(int)BytesTxd);

	// Complete IRP
	return CompleteIrp(Irp,status,BytesTxd);
}

NTSTATUS Wdm1Write(	IN PDEVICE_OBJECT fdo,
					IN PIRP Irp)
{
	PIO_STACK_LOCATION IrpStack = IoGetCurrentIrpStackLocation(Irp);
	NTSTATUS status = STATUS_SUCCESS;
	LONG BytesTxd = 0;

	// Get call parameters
	LONGLONG FilePointer = IrpStack->Parameters.Write.ByteOffset.QuadPart;
	ULONG WriteLen = IrpStack->Parameters.Write.Length;
	DbgPrint("Write %d bytes from file pointer %d",(int)WriteLen,(int)FilePointer);

	if( FilePointer<0)
		status = STATUS_INVALID_PARAMETER;
	else
	{
		// Get access to the shared buffer
		KIRQL irql;
		KeAcquireSpinLock(&BufferLock,&irql);

		BytesTxd = WriteLen;

		// (Re)allocate buffer if necessary
		if( ((ULONG)FilePointer)+WriteLen>BufferSize)
		{
			ULONG NewBufferSize = ((ULONG)FilePointer)+WriteLen;
			PVOID NewBuffer = ExAllocatePool(NonPagedPool,NewBufferSize);
			if( NewBuffer==NULL)
			{
				BytesTxd = BufferSize - (ULONG)FilePointer;
				if( BytesTxd<0) BytesTxd = 0;
			}
			else
			{
				RtlZeroMemory(NewBuffer,NewBufferSize);
				if( Buffer!=NULL)
				{
					RtlCopyMemory(NewBuffer,Buffer,BufferSize);
					ExFreePool(Buffer);
				}
				Buffer = (PUCHAR)NewBuffer;
				BufferSize = NewBufferSize;
			}
		}

		// Write to shared memory
		if( BytesTxd>0 && Buffer!=NULL)
			RtlCopyMemory( Buffer+FilePointer, Irp->AssociatedIrp.SystemBuffer, BytesTxd);

		// Release shared buffer
		KeReleaseSpinLock(&BufferLock,irql);
	}

	DbgPrint("Write: %d bytes written",(int)BytesTxd);

	// Complete IRP
	return CompleteIrp(Irp,status,BytesTxd);
}




NTSTATUS CompleteIrp( PIRP Irp, NTSTATUS status, ULONG info)
{
	Irp->IoStatus.Status = status;
	Irp->IoStatus.Information = info;
	IoCompleteRequest(Irp,IO_NO_INCREMENT);
	return status;
}



/***************************************************************
函數名稱:HelloWDMAddDevice()
功能描述:處理“添加設備”消息
***************************************************************/
NTSTATUS HelloWDMAddDevice(IN PDRIVER_OBJECT DriverObject,
                           IN PDEVICE_OBJECT PhysicalDeviceObject)
{
    //定義一個NTSTATUS類型的返回值:
    NTSTATUS status;
    //定義一個功能設備對象(Functional Device Object):
    PDEVICE_OBJECT fdo;

	UNICODE_STRING ntDeviceName; 
	UNICODE_STRING win32DeviceName; 
	RtlInitUnicodeString(&ntDeviceName, L"\\Device\\Twdm1");
	RtlInitUnicodeString(&win32DeviceName, L"\\DosDevices\\Twdm1");    
    
    DbgPrint("Starting AddDevice()\n");

    //創建我們的功能設備對象,并儲存到fdo中:
    status = IoCreateDevice(
        DriverObject,                //驅動程序對象
        sizeof(DEVICE_EXTENSION),    //要求的設備擴展的大小
        &ntDeviceName,                        //設備名稱,這里為NULL
        FILE_DEVICE_UNKNOWN,        //設備的類型,在標準頭文件WDM.H或NTDDK.H中列出的FILE_DEVICE_xxx值之一
        0,                            //各種常量用OR組合在一起,指示可刪除介質、只讀等。
        FALSE,                        //如果一次只有一個線程可以訪問該設備,為TRUE,否則為FALSE
        &fdo);                        //返回的設備對象

    //NT_SUCCESS宏用于測試IoCreateDevice內核是否成功完成。不要忘記檢查對內核的所有調用是否成功。
    //NT_ERROR宏不等同于!NT_SUCCESS,最好使用!NT_SUCCESS,因為除了錯誤外,它還截獲警告信息。
    if( !NT_SUCCESS(status))
    {
    	DbgPrint("AddDevice(): IoCreateDevice failed!");
        return status;
    }
    else
    {
    	DbgPrint("AddDevice(): IoCreateDevice OK!");
    }

	status = IoCreateSymbolicLink( &win32DeviceName, &ntDeviceName ); 
	if (!NT_SUCCESS(status)) 
	{ 
		DbgPrint("TWDM: IoCreateSymbolicLink() faild ! \n"); 
	} 
	else 
	{ 
		DbgPrint("TWDM: IoCreateSymbolicLink() ok ! \n"); 
	} 

    //創建一個設備擴展對象dx,用于存儲指向fdo的指針:
    PDEVICE_EXTENSION dx = (PDEVICE_EXTENSION)fdo->DeviceExtension;
    dx->fdo = fdo;

    //用IoAttachDeviceToDeviceStack函數把HelloWDM設備掛接到設備棧:
    dx->NextStackDevice = IoAttachDeviceToDeviceStack(fdo, PhysicalDeviceObject);

    //設置fdo的flags。有兩個“位”是必須改變的,一個是必須清除DO_DEVICE_INITIALIZING標志,如果在DriverEntry例程中調用IoCreateDevice(),就不需要清除這個標志位。還有一個是必須設置DO_BUFFER_IO標志位:
    fdo->Flags |= DO_BUFFERED_IO | DO_POWER_PAGABLE;
    fdo->Flags &= ~DO_DEVICE_INITIALIZING;
    
    DbgPrint("AddDevice() OK!\n");

    //返回值:
    return STATUS_SUCCESS;
}


/***************************************************************
函數名稱:HelloWDMPnp()
功能描述:處理“即插即用”消息
***************************************************************/
NTSTATUS HelloWDMPnp(IN PDEVICE_OBJECT fdo,
                        IN PIRP Irp)
{
    //創建一個設備擴展對象dx,用于存儲指向fdo的指針:
    PDEVICE_EXTENSION dx=(PDEVICE_EXTENSION)fdo->DeviceExtension;
	UNICODE_STRING win32DeviceName; 
    //首先要通過函數IoGetCurrentIrpStackLocation()得到當前的IRP,并由此得到Minor Function:
    PIO_STACK_LOCATION IrpStack = IoGetCurrentIrpStackLocation(Irp);
    ULONG MinorFunction = IrpStack->MinorFunction;

    //然后把這個Minor Function傳遞給下一個設備棧:
    IoSkipCurrentIrpStackLocation(Irp);
    NTSTATUS status = IoCallDriver( dx->NextStackDevice, Irp);

    //處理“即插即用”次功能代碼:
    //當Minor Function等于IRP_MN_REMOVE_DEVICE時,說明有設備被拔出或卸下,這時要取消資源分配并刪除設備:
    if( MinorFunction==IRP_MN_REMOVE_DEVICE)
    {
        //取消設備接口:
      RtlInitUnicodeString(&win32DeviceName, L"\\DosDevices\\Twdm1"); 
	  IoDeleteSymbolicLink(&win32DeviceName); 


        //調用IoDetachDevice()把fdo從設備棧中脫開:
        if (dx->NextStackDevice)
            IoDetachDevice(dx->NextStackDevice);
        //刪除fdo:
        IoDeleteDevice(fdo);
    }

    //返回值:
    return status;
}

VOID Wdm1Unload(IN PDRIVER_OBJECT DriverObject)
{
	// Free buffer (do not need to acquire spin lock)
	if( Buffer!=NULL)
		ExFreePool(Buffer);

	DbgPrint("Wdm1Unload");
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区视频在线| 91久久久免费一区二区| 色综合久久88色综合天天| 3751色影院一区二区三区| 亚洲欧洲日韩av| 另类的小说在线视频另类成人小视频在线| 成人自拍视频在线| 久久网站热最新地址| 亚洲国产精品久久一线不卡| 国产91精品精华液一区二区三区| 欧美一区二区三区在线看| 亚洲国产视频网站| aaa亚洲精品一二三区| 久久久精品国产免大香伊| 久久精品国产999大香线蕉| 欧美日韩视频在线第一区| 亚洲欧美日本在线| 91网址在线看| 亚洲视频香蕉人妖| jlzzjlzz国产精品久久| 中文字幕免费在线观看视频一区| 极品少妇一区二区| 日韩免费电影一区| 久久疯狂做爰流白浆xx| 日韩精品专区在线影院观看| 日本女人一区二区三区| 欧美一区二区三区四区在线观看| 亚洲va欧美va人人爽| 欧美日韩三级一区| 日韩精品亚洲专区| 欧美一区二区三区免费观看视频 | 久久精品国产77777蜜臀| 7777精品伊人久久久大香线蕉经典版下载| 一片黄亚洲嫩模| 欧美性猛交一区二区三区精品| 亚洲综合色成人| 欧美日韩一区 二区 三区 久久精品| 一区二区三区不卡在线观看| 欧美日韩三级视频| 日韩成人av影视| 久久久综合网站| www.日韩精品| 一区二区三区高清在线| 56国语精品自产拍在线观看| 久久se这里有精品| 国产日本欧美一区二区| 色哟哟一区二区| 婷婷综合另类小说色区| 2017欧美狠狠色| 91视频观看视频| 男男视频亚洲欧美| 国产日韩影视精品| 色婷婷国产精品| 久久www免费人成看片高清| 国产精品久久久久三级| 欧美日韩在线精品一区二区三区激情| 人人精品人人爱| 国产欧美精品区一区二区三区 | 久久网站最新地址| 91视视频在线观看入口直接观看www | 国产精品沙发午睡系列990531| 成人的网站免费观看| 亚洲第一精品在线| 久久久亚洲高清| 91精品福利在线| 精品一区二区三区免费观看 | 一本大道久久a久久综合婷婷| 亚洲国产精品麻豆| 欧美国产综合一区二区| 在线不卡中文字幕播放| 高清不卡在线观看| 日韩和欧美一区二区| 国产网站一区二区| 91精选在线观看| 色婷婷综合久久久| 国产精品一区一区| 亚洲国产成人va在线观看天堂| 久久亚洲私人国产精品va媚药| 91丨porny丨首页| 国产精品白丝jk黑袜喷水| 亚洲观看高清完整版在线观看| 久久久不卡网国产精品二区| 欧美日韩国产综合视频在线观看| 懂色av一区二区在线播放| 日日骚欧美日韩| 一区二区高清在线| 国产精品的网站| 久久久精品免费观看| 日韩三级在线免费观看| 欧美亚洲一区二区在线观看| 成人动漫视频在线| 国产成人亚洲综合a∨婷婷图片| 蜜臀久久久久久久| 亚洲国产视频直播| 亚洲一区二区三区自拍| 中文字幕五月欧美| 国产欧美日韩在线观看| 久久久久久久久久看片| 欧美一级在线视频| 欧美性色欧美a在线播放| 91麻豆国产在线观看| caoporm超碰国产精品| 国产精品1024久久| 国产精品一品视频| 国产在线精品不卡| 国产一区在线观看麻豆| 国产在线视频精品一区| 国产主播一区二区三区| 国产精品影音先锋| 国产999精品久久久久久绿帽| 国产一区二区三区国产| 国内精品久久久久影院色| 国产中文一区二区三区| 国产成人综合在线播放| 国产精品69毛片高清亚洲| 国产91丝袜在线18| 99riav一区二区三区| 色综合天天综合网国产成人综合天| 成人福利视频在线看| 93久久精品日日躁夜夜躁欧美| www.日韩av| 欧美午夜片在线看| 欧美一区二区三区视频免费| 欧美一区二区高清| 久久免费的精品国产v∧| 国产精品午夜在线观看| 中文字幕一区二区三| 一区二区视频免费在线观看| 亚洲观看高清完整版在线观看| 五月天激情小说综合| 捆绑调教美女网站视频一区| 精久久久久久久久久久| 成人免费观看男女羞羞视频| www.成人在线| 欧美日韩黄色一区二区| 精品噜噜噜噜久久久久久久久试看| 久久久久99精品一区| 亚洲欧美视频一区| 蜜桃av一区二区| 国产成a人无v码亚洲福利| 91精彩视频在线| 日韩一级黄色片| 国产精品伦理一区二区| 香蕉影视欧美成人| 国产成人在线网站| 欧美日韩色综合| 国产欧美日韩视频在线观看| 亚洲一区在线视频| 精品综合久久久久久8888| 91同城在线观看| 日韩免费视频一区| 一区二区三区国产| 国产成人免费在线视频| 欧美三级电影在线看| 国产亚洲精品bt天堂精选| 亚洲国产日韩av| 懂色av一区二区三区免费观看 | 久久精品亚洲乱码伦伦中文| 亚洲欧美一区二区不卡| 国产在线看一区| 欧洲精品视频在线观看| 日本一区二区高清| 男男视频亚洲欧美| 色综合中文字幕国产| 欧美一区二区三区免费| 亚洲综合色噜噜狠狠| 国产成人av一区二区三区在线 | 久久国产精品区| 色哟哟一区二区在线观看| 国产亚洲成aⅴ人片在线观看| 日韩综合在线视频| 色天天综合久久久久综合片| 亚洲国产岛国毛片在线| 国产在线播放一区| 欧美久久久久久久久久| 洋洋成人永久网站入口| 播五月开心婷婷综合| 欧美大片一区二区三区| 性欧美大战久久久久久久久| 91蜜桃视频在线| 国产精品女主播av| 国产91精品露脸国语对白| 精品国产乱码久久| 看片的网站亚洲| 欧美日韩另类一区| 亚洲综合区在线| 在线一区二区三区四区五区| 国产精品久久夜| 成人免费看片app下载| 久久久精品国产99久久精品芒果 | 久久婷婷成人综合色| 美女视频黄a大片欧美| 欧美一区二区三区人| 五月婷婷欧美视频| 欧美男男青年gay1069videost| 亚洲成人免费影院| 欧美一级黄色片| 麻豆精品新av中文字幕| 日韩精品一区二区三区三区免费 | 成人美女视频在线观看18|