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

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

?? main.c

?? 好東東
?? C
?? 第 1 頁 / 共 2 頁
字號:
	if( deviceExtension->DosName.Buffer == NULL ){
		DebugPrint(("SERIAL: Couldn't allocate memory for Dos name\n"));
		status =  STATUS_INSUFFICIENT_RESOURCES;
		goto SerialDoExternalNamingError;
	}
	deviceExtension->DosName.Length = 0;
	RtlZeroMemory( deviceExtension->DosName.Buffer, deviceExtension->DosName.MaximumLength );
	RtlAppendUnicodeToString( &deviceExtension->DosName, L"COM" );
	RtlAppendUnicodeStringToString( &deviceExtension->DosName, &instanceStr);
	DebugPrint(("DosName:   %wZ\n", &deviceExtension->DosName ));
	DebugPrint(("DeviceName:    %wZ\n", &deviceExtension->DeviceName ));

	// 生成符號連接,至此本設備對win32應用表現的Dos設備名為 \DosDevices\COMn
	status = IoCreateSymbolicLink( &deviceExtension->SymbolicLinkName, &deviceExtension->DeviceName );
	if( !NT_SUCCESS( status )){
		DebugPrint(("SERIAL:  Couldn't create the symbolic link with error %d\n", status));
		goto SerialDoExternalNamingError;
	}else{
		DebugPrint(("Create the symbolic link OK\n"));
		deviceExtension->CreatedSymbolicLink = TRUE;
	}
	// 在注冊表的 HKEY_LOCAL_MACHINE\HARDWARE\DEVICEMAP\SERIALCOMM 中,添加ComX的鍵值
	// 若不進行這一步,則超級終端程序無法檢測到本虛擬串口設備
	status = RtlWriteRegistryValue(RTL_REGISTRY_DEVICEMAP, SERIAL_DEVICE_MAP,
		deviceExtension->DeviceName.Buffer, REG_SZ,
		deviceExtension->DosName.Buffer,
		deviceExtension->DosName.Length + sizeof(WCHAR));
	if( !NT_SUCCESS( status )){
		DebugPrint(("SERIAL: Couldn't create the device map entry\n------- for port %wZ\n", deviceExtension->DeviceName ));
		goto SerialDoExternalNamingError;
	}
	deviceExtension->ComX = ComX;
	deviceExtension->CreatedSerialCommEntry = TRUE;

SerialDoExternalNamingError:

	if( !NT_SUCCESS( status )){
		if( deviceExtension->DosName.Buffer != NULL ){
			ExFreePool( deviceExtension->DosName.Buffer );
			deviceExtension->DosName.Buffer = NULL;
			deviceExtension->CreatedSerialCommEntry = FALSE;
		}
		if( deviceExtension->CreatedSymbolicLink ){
			IoDeleteSymbolicLink( &deviceExtension->SymbolicLinkName );
			deviceExtension->CreatedSymbolicLink = FALSE;
		}
		if( deviceExtension->SymbolicLinkName.Buffer != NULL ){
			ExFreePool( deviceExtension->SymbolicLinkName.Buffer );
			deviceExtension->SymbolicLinkName.Buffer = NULL;
		}
	}
	return status;
}


BOOLEAN InitializeSerialDevName( PUNICODE_STRING lpDeviceName )
/*++

Routine Description:

	Initialize serial device name. This name is available in Kernel Mode.

Arguments:

    PUNICODE_STRING lpDeviceName - the pointer to device name string.

Return Value:

    return TRUE if it is successful, otherwise return FALSE.

--*/
{

	WCHAR				instanceNumberBuffer[ 4 ];
	UNICODE_STRING		instanceStr;
	static ULONG				currentInstance = 10;
	// 首先處理deviceObjName,這是一個核心態使用的設備名,形如"\\Device\\SiSerial0"
	// Zero out allocated memory pointers so we know if they must be freed
	RtlZeroMemory( lpDeviceName, sizeof(UNICODE_STRING) );
	lpDeviceName->MaximumLength = DEVICE_OBJECT_NAME_LENGTH * sizeof(WCHAR);
	lpDeviceName->Buffer = ExAllocatePool(PagedPool, lpDeviceName->MaximumLength + sizeof(WCHAR));
	if ( lpDeviceName->Buffer == NULL) {
		DebugPrint(("Couldn't allocate memory for device name\n"));
		return FALSE;
	}
	RtlZeroMemory( lpDeviceName->Buffer, lpDeviceName->MaximumLength + sizeof(WCHAR));
	// now, the size of deviceObjName.Buffer is (128 + 1)(WCHAR)
	RtlAppendUnicodeToString( lpDeviceName, DEVICE_NAME);	// L"\\Device\\VSer"
	
	// 處理 lpDeviceName 的后綴序號
	RtlInitUnicodeString(&instanceStr, NULL);
	instanceStr.MaximumLength	= sizeof(instanceNumberBuffer);
	instanceStr.Buffer			= instanceNumberBuffer;	// 20 WCHAR
	currentInstance++;
	RtlIntegerToUnicodeString( currentInstance, 10, &instanceStr);
	RtlAppendUnicodeStringToString( lpDeviceName, &instanceStr);
	DebugPrint(("DeviceName:\n"));
	DebugPrint(("----------- %ws\n", lpDeviceName->Buffer ));
	return TRUE;
}

NTSTATUS
SerialUndoExternalNaming(
	IN PDEVICE_EXTENSION	deviceExtension
	)
/*++

Routine Description:

	Delete or unregister external name, SymbolicLinkName and DOS name.

Arguments:

    deviceExtension - pointer to a device object extension.

Return Value:

    NT status code.

--*/
{
	NTSTATUS	status = STATUS_SUCCESS;
	if( deviceExtension->CreatedSymbolicLink ){
		IoDeleteSymbolicLink( &deviceExtension->SymbolicLinkName );
		ExFreePool( deviceExtension->SymbolicLinkName.Buffer );
		deviceExtension->SymbolicLinkName.Buffer = NULL;
		deviceExtension->CreatedSymbolicLink = FALSE;
	}else{
		ASSERT( deviceExtension->SymbolicLinkName.Buffer == NULL );
	}
	ASSERT( deviceExtension->DeviceName.Buffer != NULL );
	if( deviceExtension->CreatedSerialCommEntry ){
		status = RtlDeleteRegistryValue( RTL_REGISTRY_DEVICEMAP, SERIAL_DEVICE_MAP, deviceExtension->DeviceName.Buffer );
		if( !NT_SUCCESS( status ) ){
			DebugPrint(("RtlDeleteRegistryValue device map failed\n"));
		}
		ExFreePool( deviceExtension->DosName.Buffer );
		deviceExtension->DosName.Buffer = NULL;
		deviceExtension->CreatedSerialCommEntry = FALSE;
	}else{
		ASSERT( deviceExtension->DosName.Buffer == NULL );
	}
	return status;
}

NTSTATUS
SerialRemoveDevObj(IN PDEVICE_OBJECT PDevObj)
/*++

Routine Description:

    Removes a serial device object from the system.

Arguments:

    PDevObj - A pointer to the Device Object we want removed.

Return Value:

    Always TRUE

--*/
{
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)PDevObj->DeviceExtension;
	PAGED_CODE();
	
	DebugPrint(("SERIAL: Enter SerialRemoveDevObj\n"));
	
	
	//
	// Free memory allocated in the extension
	//
	
	if (pDevExt->DeviceName.Buffer != NULL) {
		ExFreePool(pDevExt->DeviceName.Buffer);
	}
	
	if (pDevExt->SymbolicLinkName.Buffer != NULL) {
		ExFreePool(pDevExt->SymbolicLinkName.Buffer);
	}
	
	if (pDevExt->DosName.Buffer != NULL) {
		ExFreePool(pDevExt->DosName.Buffer);
	}
	DebugPrint(("SERIAL: Leave SerialRemoveDevObj\n"));

	return STATUS_SUCCESS;
}

NTSTATUS CompleteRequest(IN PIRP Irp, IN NTSTATUS status, IN ULONG info)
{
    Irp->IoStatus.Status = status;
    Irp->IoStatus.Information = info;
    IoCompleteRequest(Irp, IO_NO_INCREMENT);
    return status;
}
    
VOID
Unload(
    IN PDRIVER_OBJECT DriverObject
    )
/*++

Routine Description:

    Free all the allocated resources in DriverEntry, etc.

Arguments:

    DriverObject - pointer to a driver object.

Return Value:

    VOID.

--*/
{
    PAGED_CODE ();

    //
    // The device object(s) should be NULL now
    // (since we unload, all the devices objects associated with this
    // driver must be deleted.
    //
	DebugPrint( ("Is unloading......\n") );
    ASSERT(DriverObject->DeviceObject == NULL);
    
    //
    // We should not be unloaded until all the devices we control 
    // have been removed from our queue.  
    //
    DebugPrint (("Unload:  unload\n"));

    return;
}

LONG
SampleIoIncrement(
    IN OUT PDEVICE_EXTENSION DeviceExtension
    )
/* ++
 
Routine Description:

	Increment deviceExtension->OutStandingIO within the scope of IOCountLock.

Arguments:

	deviceExtension - pointer to a device object extension.

Return Value:

	deviceExtension->OutStandingIO

--*/
{
    LONG  result = 0;
    KIRQL oldIrql;

    KeAcquireSpinLock(&DeviceExtension->IOCountLock, &oldIrql);

    result = InterlockedIncrement(&DeviceExtension->OutStandingIO);

    //
    // when OutStandingIO bumps from 1 to 2, clear the StopEvent
    //

    if(result == 2) {

        KeClearEvent(&DeviceExtension->StopEvent);
    }

    KeReleaseSpinLock(&DeviceExtension->IOCountLock, oldIrql);
	DebugPrint(("SampleIncrement: %d\n", result));

    return result;
}

LONG
SampleIoDecrement(
    IN OUT PDEVICE_EXTENSION DeviceExtension
    )
/*++
 
Routine Description:
	
	  Decrement deviceExtension->OutStandingIO within the scope of IOCountLock.

Arguments:

	deviceExtension - pointer to a device object extension.

Return Value:

	deviceExtension->OutStandingIO

--*/
{
    LONG  result = 0;
    KIRQL oldIrql;

    KeAcquireSpinLock(&DeviceExtension->IOCountLock, &oldIrql);

    result = InterlockedDecrement(&DeviceExtension->OutStandingIO);

    if(result == 1) {

        KeSetEvent(&DeviceExtension->StopEvent, IO_NO_INCREMENT, FALSE);
    }

    if(result == 0) {

        ASSERT(Removed == DeviceExtension->DevicePnPState);

        KeSetEvent(&DeviceExtension->RemoveEvent, IO_NO_INCREMENT, FALSE);
    }

    KeReleaseSpinLock(&DeviceExtension->IOCountLock, oldIrql);
	DebugPrint(("SampleIoDecrement: %d\n", result));


    return result;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本视频在线一区| 日本一区二区三区视频视频| 色哟哟一区二区三区| 精品视频在线看| 久久精品一区二区| 亚洲一区二区三区四区在线| 亚洲成av人影院在线观看网| 国产精品1区2区3区| 欧美另类z0zxhd电影| 久久久av毛片精品| 五月婷婷综合在线| 91免费视频观看| 欧美极品aⅴ影院| 免费在线看一区| 欧美伊人久久久久久午夜久久久久| 精品久久国产老人久久综合| 亚洲愉拍自拍另类高清精品| 成人精品视频一区二区三区尤物| 日韩一二在线观看| 午夜视频在线观看一区二区| 色欧美片视频在线观看| 日韩成人精品在线| 日本v片在线高清不卡在线观看| 日韩av电影天堂| 韩国视频一区二区| 97久久超碰国产精品| 91国偷自产一区二区开放时间| 欧美日韩精品是欧美日韩精品| 婷婷中文字幕一区三区| 国产精品影视网| 久久人人97超碰com| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩精品在线网站| 三级欧美在线一区| 欧美影视一区在线| 亚洲丰满少妇videoshd| 色婷婷综合五月| 亚洲综合丁香婷婷六月香| 99re视频这里只有精品| 久久精品在这里| 国产精品一二三| 久久精品人人做人人爽人人| 国产美女视频91| 3d成人动漫网站| 日本麻豆一区二区三区视频| 777xxx欧美| 日本特黄久久久高潮| 欧美一卡二卡在线| 免费成人你懂的| 精品精品国产高清一毛片一天堂| 蜜臀精品久久久久久蜜臀| 精品国精品国产| 国产精品亚洲第一区在线暖暖韩国| 精品国精品国产| 99久久免费视频.com| 亚洲久本草在线中文字幕| 91日韩一区二区三区| 亚洲高清在线精品| 日韩欧美区一区二| 国产一区不卡视频| 综合色天天鬼久久鬼色| 欧美日韩国产综合一区二区三区| 日本亚洲一区二区| 国产精品丝袜91| 欧美日韩一区不卡| 国产在线视频精品一区| 中文字幕一区二区三区不卡在线| 欧美午夜视频网站| 国产精品资源在线| 亚洲高清免费视频| 国产偷v国产偷v亚洲高清| 色又黄又爽网站www久久| 免费看欧美美女黄的网站| 国产精品欧美久久久久无广告 | 成人国产一区二区三区精品| 亚洲精品亚洲人成人网在线播放| 欧美电影在线免费观看| 国产精品白丝av| 性久久久久久久久久久久| 欧美成人一区二区三区片免费| 日韩一区二区在线看| 成人黄色大片在线观看| 欧美国产精品中文字幕| 日韩一区二区在线观看| 日本网站在线观看一区二区三区| 亚洲天堂精品视频| 91精品国产综合久久精品麻豆| 99久久精品免费看国产| 亚洲综合精品自拍| 中文字幕五月欧美| 欧美一区二区三区免费| 91九色最新地址| 视频一区欧美日韩| 懂色av中文字幕一区二区三区| 亚洲午夜激情网站| 欧美精品一区二区三区蜜臀| 欧美亚洲一区二区在线观看| 日韩国产在线观看一区| 亚洲乱码日产精品bd| 日韩三区在线观看| 88在线观看91蜜桃国自产| 国产乱人伦精品一区二区在线观看| 亚洲高清免费一级二级三级| 国产精品免费网站在线观看| 蜜桃精品视频在线| 亚洲国产精品精华液2区45| 欧美一级视频精品观看| 国产凹凸在线观看一区二区| 国产精品女同一区二区三区| 日韩一区二区三区视频| 色综合色狠狠天天综合色| 日韩精品每日更新| 日韩欧美资源站| 宅男噜噜噜66一区二区66| 国产成人精品一区二区三区四区| 精品一区二区三区免费播放 | 精品久久久久99| 精品视频1区2区| 欧美视频中文一区二区三区在线观看| 国产一区二区导航在线播放| 精品无人码麻豆乱码1区2区| 亚洲欧美偷拍三级| 洋洋成人永久网站入口| 国产精品久久久久aaaa| 国产精品美女久久久久久| 日韩午夜在线播放| 精品久久一二三区| 5566中文字幕一区二区电影| 欧美一级二级在线观看| 日本韩国欧美在线| 欧美日韩国产首页| 在线精品观看国产| 欧美精品日韩一本| 色噜噜狠狠色综合中国| 欧美日韩免费高清一区色橹橹| 97久久超碰精品国产| 欧美日韩国产一二三| 一本久久a久久精品亚洲| 美女被吸乳得到大胸91| 日韩中文字幕麻豆| 日本三级韩国三级欧美三级| 一卡二卡三卡日韩欧美| 亚洲一区在线播放| 亚洲蜜臀av乱码久久精品| 欧美经典一区二区| 91精品国产综合久久婷婷香蕉| 欧美在线免费观看亚洲| 在线观看亚洲专区| 欧美老年两性高潮| 欧美女孩性生活视频| 欧美精品日韩精品| 日韩欧美色综合网站| 日韩亚洲欧美中文三级| 日韩美女一区二区三区四区| 精品国产乱码久久久久久久久 | 91精品国产一区二区人妖| 成人av在线看| 久久久99免费| 在线观看日韩电影| 欧美一二三区在线| 久久久精品日韩欧美| 国产欧美日韩精品在线| 亚洲欧美乱综合| 亚洲综合在线免费观看| 亚洲成人一区在线| 蜜臀av国产精品久久久久| 精品一区二区国语对白| 国产精品一区二区久久精品爱涩| 国产精品一二三四区| 日本国产一区二区| 91精品在线麻豆| 欧美一区二区三区系列电影| 国产色综合一区| 一区二区视频在线| 婷婷中文字幕综合| 成人午夜激情在线| 精品1区2区3区| 欧美sm极限捆绑bd| 国产精品久久久久四虎| 亚洲综合偷拍欧美一区色| 日韩国产一二三区| 成人污视频在线观看| 欧美在线观看视频在线| 91香蕉国产在线观看软件| 国产69精品久久99不卡| 欧美巨大另类极品videosbest | 国产精品视频一二| 久久综合色天天久久综合图片| 亚洲综合自拍偷拍| 国产成人av自拍| 欧美大片顶级少妇| 婷婷激情综合网| 色94色欧美sute亚洲线路一久| 久久精品视频网| 麻豆精品精品国产自在97香蕉| 欧美视频一区二区三区四区 | 久久男人中文字幕资源站| 亚洲欧美日韩中文字幕一区二区三区| 国产乱人伦偷精品视频不卡| wwww国产精品欧美|