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

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

?? usb.c

?? usb to rs232 虛擬RS232串口驅動程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*++

Copyright (c) 2005-2006  E0 Technology,Inc.

Module Name:

	usb.h

Abstract:

	Virtual Com Port Driver for USB to RS232 Converter of E0 Technology,Inc.

Environment:

	Kernel mode

Notes:

Revision History:

    2006/3/1 : 	Adapted from the BulkUsb DDK sample.
--*/

#include "usb2com.h"


NTSTATUS
DriverEntry(
    IN PDRIVER_OBJECT DriverObject,
    IN PUNICODE_STRING RegistryPath
    )
/*++

Routine Description:

    Installable driver initialization entry point.
    This entry point is called directly by the I/O system.

Arguments:

    DriverObject - pointer to the driver object

    RegistryPath - pointer to a unicode string representing the path
                   to driver-specific key in the registry

Return Value:

    STATUS_SUCCESS if successful,
    STATUS_UNSUCCESSFUL otherwise

--*/
{
    NTSTATUS ntStatus = STATUS_SUCCESS;
    PDEVICE_OBJECT deviceObject = NULL;
    BOOLEAN fRes;

#if DBG
	// should be done before any debug output is done.
    // read our debug verbosity level from the registry
    USB2COM_GetRegistryDword( USB2COM_REGISTRY_PARAMETERS_PATH, //absolute registry path
                                     L"DebugLevel",     // REG_DWORD ValueName
                                     &gDebugLevel );    // Value receiver
#endif

    USB2COM_KdPrint( DBGLVL_MINIMUM ,("Entering DriverEntry(), RegistryPath=\n    %ws\n", RegistryPath->Buffer ));
    USB2COM_KdPrint( DBGLVL_DEFAULT ,("Build Date %s %s\n", __DATE__,__TIME__));
    //
    // Create dispatch points for create, close, unload
    DriverObject->MajorFunction[IRP_MJ_CREATE] = USB2COM_Create;
    DriverObject->MajorFunction[IRP_MJ_CLOSE] = USB2COM_Close;
    DriverObject->DriverUnload = USB2COM_Unload;

    // User mode DeviceIoControl() calls will be routed here
    DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = USB2COM_ProcessIOCTL;

    // User mode ReadFile()/WriteFile() calls will be routed here
    DriverObject->MajorFunction[IRP_MJ_WRITE] = USB2COM_Write;
    DriverObject->MajorFunction[IRP_MJ_READ] = USB2COM_Read;

    // routines for handling system PNP and power management requests
    DriverObject->MajorFunction[IRP_MJ_SYSTEM_CONTROL] = USB2COM_ProcessSysControlIrp;
    DriverObject->MajorFunction[IRP_MJ_PNP] = USB2COM_ProcessPnPIrp;
    DriverObject->MajorFunction[IRP_MJ_POWER] = USB2COM_ProcessPowerIrp;

    // The Functional Device Object (FDO) will not be created for PNP devices until 
    // this routine is called upon device plug-in.
    DriverObject->DriverExtension->AddDevice = USB2COM_PnPAddDevice;


    USB2COM_KdPrint( DBGLVL_DEFAULT,("exiting DriverEntry (%x)\n", ntStatus));

    return ntStatus;
}





NTSTATUS
USB2COM_ProcessSysControlIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    )
/*++

Routine Description:

    Main dispatch table routine for IRP_MJ_SYSTEM_CONTROL
	We basically just pass these down to the PDO

Arguments:

    DeviceObject - pointer to FDO device object

    Irp          - pointer to an I/O Request Packet

Return Value:

	Status returned from lower driver


--*/
{

    PIO_STACK_LOCATION irpStack;
    PDEVICE_EXTENSION deviceExtension;
    NTSTATUS ntStatus = STATUS_SUCCESS;
    NTSTATUS waitStatus;
    PDEVICE_OBJECT stackDeviceObject;

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

    //
    // Get a pointer to the current location in the Irp. This is where
    //     the function codes and parameters are located.
    //

    irpStack = IoGetCurrentIrpStackLocation (Irp);

    //
    // Get a pointer to the device extension
    //

    deviceExtension = DeviceObject->DeviceExtension;
    stackDeviceObject = deviceExtension->TopOfStackDeviceObject;

    USB2COM_KdPrint( DBGLVL_HIGH, ( "enter USB2COM_ProcessSysControlIrp()\n") );

    USB2COM_IncrementIoCount(DeviceObject);

    USB2COM_ASSERT( IRP_MJ_SYSTEM_CONTROL == irpStack->MajorFunction );

    IoCopyCurrentIrpStackLocationToNext(Irp);


    ntStatus = IoCallDriver(stackDeviceObject,
                            Irp);

    USB2COM_DecrementIoCount(DeviceObject);

    USB2COM_KdPrint( DBGLVL_HIGH,("USB2COM_ProcessSysControlIrp() Exit USB2COM_ProcessSysControlIrp %x\n", ntStatus));

    return ntStatus;
}


VOID
USB2COM_Unload(
    IN PDRIVER_OBJECT DriverObject
    )
/*++

Routine Description:

    Free all the allocated resources, etc.

Arguments:

    DriverObject - pointer to a driver object

Return Value:


--*/
{
    USB2COM_KdPrint( DBGLVL_HIGH,("enter USB2COM_Unload\n"));

    //
    // Free any global resources allocated
    // in DriverEntry.
	// We have few or none because for a PNP device, almost all
	// allocation is done in PnpAddDevice() and all freeing 
	// while handling IRP_MN_REMOVE_DEVICE:
    //
	USB2COM_ASSERT( gExAllocCount == 0 );

    USB2COM_KdPrint( DBGLVL_DEFAULT,("exit USB2COM_Unload\n"));

}


NTSTATUS
USB2COM_CreateDeviceObject(
    IN PDRIVER_OBJECT DriverObject,
    IN PDEVICE_OBJECT PhysicalDeviceObject,
    IN PDEVICE_OBJECT *DeviceObject
    )
/*++

Routine Description:

    Creates a Functional DeviceObject

Arguments:

    DriverObject - pointer to the driver object for device

    DeviceObject - pointer to DeviceObject pointer to return
                    created device object.

    Instance - instance of the device create.

Return Value:

    STATUS_SUCCESS if successful,
    STATUS_UNSUCCESSFUL otherwise

--*/
{
    NTSTATUS ntStatus = STATUS_SUCCESS;
    UNICODE_STRING deviceObjName;
    WCHAR wszDeviceName[128];
    static ULONG currentInstance = 0;
    PDEVICE_EXTENSION deviceExtension;
    USHORT i;

    USB2COM_KdPrint( DBGLVL_DEFAULT,("enter USB2COM_CreateDeviceObject() \n"));

   RtlZeroMemory(wszDeviceName,sizeof(wszDeviceName));
   RtlZeroMemory(&deviceObjName, sizeof(UNICODE_STRING));

    if (NT_SUCCESS(ntStatus)) {
	for(i=0; i<1000; i++)
	{
		swprintf(wszDeviceName,L"\\Device\\Serial%d",currentInstance++);
		RtlInitUnicodeString(&deviceObjName, wszDeviceName);
   		ntStatus = IoCreateDevice(DriverObject, sizeof(DEVICE_EXTENSION),
                           &deviceObjName, FILE_DEVICE_SERIAL_PORT,
                           FILE_DEVICE_SECURE_OPEN, TRUE, DeviceObject);
		if (ntStatus != STATUS_OBJECT_NAME_EXISTS &&
        	    ntStatus != STATUS_OBJECT_NAME_COLLISION)
        		break; 
	}
        if (NT_SUCCESS(ntStatus))  {
        	deviceExtension = (PDEVICE_EXTENSION) ((*DeviceObject)->DeviceExtension);
             	RtlZeroMemory(&deviceExtension->DeviceName, sizeof(UNICODE_STRING));
		deviceExtension->DeviceName.MaximumLength = deviceObjName.Length + sizeof(WCHAR);
		deviceExtension->DeviceName.Buffer = USB2COM_ExAllocatePool(NonPagedPool, deviceObjName.Length + sizeof(WCHAR));
		RtlZeroMemory(deviceExtension->DeviceName.Buffer,
				deviceObjName.Length+sizeof(WCHAR));
		RtlAppendUnicodeStringToString(&deviceExtension->DeviceName, &deviceObjName);
		//RtlCopyMemory(deviceExtension->DeviceName.Buffer,
		//		deviceObjName.Buffer,deviceObjName.Length);
		//deviceExtension->DeviceName.Length = deviceObjName.Length;
		//USB2COM_KdPrint( DBGLVL_DEFAULT,("deviceObjName: %wZ, DeviceName: %wZ\n",
		//		deviceObjName,deviceExtension->DeviceName));

		USB2COM_KdPrint( DBGLVL_DEFAULT,("deviceObjName: %ws, DeviceName: %ws\n",
				 deviceExtension->DeviceName.Buffer,deviceObjName.Buffer));
        }

        USB2COM_KdPrintCond( DBGLVL_DEFAULT,
                (!(NT_SUCCESS(ntStatus))),
                ("USB2COM_CreateDeviceObject() IoCreateDevice() FAILED\n"));

 
        if (!NT_SUCCESS(ntStatus))  {
             return ntStatus;
        }

	deviceExtension->DeviceObject = *DeviceObject;
        // this event is triggered when there is no pending io of any kind and device is removed
        KeInitializeEvent(&deviceExtension->RemoveEvent, NotificationEvent, FALSE);

        // this event is triggered when self-requested power irps complete
        KeInitializeEvent(&deviceExtension->SelfRequestedPowerIrpEvent, NotificationEvent, FALSE);

        // this event is triggered when there is no pending io  (pending io count == 1 )
        KeInitializeEvent(&deviceExtension->NoPendingIoEvent, NotificationEvent, FALSE);

		// spinlock used to protect inc/dec iocount logic
		KeInitializeSpinLock (&deviceExtension->IoCountSpinLock);
        
        deviceExtension->BaudRate = 19200;
	/* Set line control */
	deviceExtension->SerialLineControl.StopBits = STOP_BIT_1;
	deviceExtension->SerialLineControl.Parity = NO_PARITY;
	deviceExtension->SerialLineControl.WordLength = 8;
	
	deviceExtension->SpecialChars.XonChar = SERIAL_DEF_XON;
   	deviceExtension->SpecialChars.XoffChar = SERIAL_DEF_XOFF;
   	
   	deviceExtension->HandFlow.ControlHandShake = SERIAL_DTR_CONTROL;
   	deviceExtension->HandFlow.FlowReplace      = SERIAL_RTS_CONTROL;
   	deviceExtension->HandFlow.XoffLimit    = 300;
   	deviceExtension->HandFlow.XonLimit     = 100;
	InitializeCircularBuffer(&deviceExtension->InputBuffer, 512);
	InitializeCircularBuffer(&deviceExtension->OutputBuffer, 512);
	KeInitializeSpinLock(&deviceExtension->InputBufferLock);
	KeInitializeSpinLock(&deviceExtension->OutputBufferLock);
	InitializeListHead(&deviceExtension->ReadQueue);
	KeInitializeSpinLock(&deviceExtension->ReadQueueSpinLock);
	InitializeListHead(&deviceExtension->WriteQueue);
	KeInitializeSpinLock(&deviceExtension->WriteQueueSpinLock);
	InitializeListHead(&deviceExtension->PurgeQueue);
	KeInitializeSpinLock(&deviceExtension->PurgeQueueSpinLock);
    }

    return ntStatus;
}


NTSTATUS
USB2COM_CallUSBD(
    IN PDEVICE_OBJECT DeviceObject,
    IN PURB Urb
    )
/*++

Routine Description:

    Passes a URB to the USBD class driver
	The client device driver passes USB request block (URB) structures 
	to the class driver as a parameter in an IRP with Irp->MajorFunction
	set to IRP_MJ_INTERNAL_DEVICE_CONTROL and the next IRP stack location 
	Parameters.DeviceIoControl.IoControlCode field set to 
	IOCTL_INTERNAL_USB_SUBMIT_URB. 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月天激情综合网| 一区精品在线播放| 91黄色免费网站| 懂色一区二区三区免费观看 | 国产高清精品久久久久| 日产国产欧美视频一区精品| 亚洲二区视频在线| 亚洲成人午夜影院| 天堂在线亚洲视频| 首页国产丝袜综合| 美女免费视频一区| 国产一区二区免费看| 国产一区二区三区蝌蚪| 国产激情一区二区三区四区 | 国产精品成人午夜| 成人免费一区二区三区在线观看| 国产精品理伦片| 亚洲人成精品久久久久久| ...av二区三区久久精品| 尤物av一区二区| 亚洲成人中文在线| 久久丁香综合五月国产三级网站| 国内外精品视频| 国产成人鲁色资源国产91色综| 成人性生交大片免费看在线播放| 91蜜桃网址入口| 欧美乱妇23p| 久久精品无码一区二区三区| 国产精品免费视频一区| 亚洲制服丝袜av| 久草在线在线精品观看| 成人性生交大片免费看中文网站| 91福利在线免费观看| 日韩精品一区二区在线观看| 久久精品人人做人人爽人人| 亚洲一区二区中文在线| 精品伊人久久久久7777人| 成人国产精品免费网站| 欧美午夜精品久久久久久孕妇| 欧美一级免费大片| 国产精品国产三级国产普通话三级 | 成人aaaa免费全部观看| 欧美午夜精品一区二区三区| 精品国产免费久久| 亚洲综合偷拍欧美一区色| 久久成人精品无人区| 91麻豆国产精品久久| 欧美大白屁股肥臀xxxxxx| 亚洲人成网站精品片在线观看 | 国产成人综合网站| 337p亚洲精品色噜噜狠狠| 国产精品丝袜久久久久久app| 日本美女一区二区三区视频| 91在线丨porny丨国产| 精品国产乱码91久久久久久网站| 一区二区三区在线免费观看| 国产精品资源网| 日韩欧美国产不卡| 亚洲福利视频一区| 91日韩在线专区| 国产日产精品1区| 免费成人小视频| 欧美日韩一级视频| 一区二区三区四区五区视频在线观看| 国产麻豆欧美日韩一区| 51精品国自产在线| 天天色图综合网| 日本久久一区二区| 国产精品久久99| av电影在线观看完整版一区二区| 精品国精品自拍自在线| 免费在线一区观看| 在线不卡一区二区| 五月天中文字幕一区二区| 欧美伊人久久久久久久久影院| 国产精品电影一区二区三区| 大胆亚洲人体视频| 中文字幕精品—区二区四季| 顶级嫩模精品视频在线看| 久久精品亚洲精品国产欧美 | 国产精品免费丝袜| eeuss鲁一区二区三区| 欧美国产日韩精品免费观看| 国产成人av福利| 国产精品免费aⅴ片在线观看| 福利电影一区二区| 中文字幕 久热精品 视频在线 | 美腿丝袜在线亚洲一区| 91精品国产欧美日韩| 日本在线观看不卡视频| 欧美r级电影在线观看| 极品尤物av久久免费看| 国产欧美日韩视频在线观看| 成人小视频在线观看| 日韩美女视频一区二区| 欧美视频在线观看一区| 五月天网站亚洲| 久久综合五月天婷婷伊人| 国产米奇在线777精品观看| 国产免费成人在线视频| 色香蕉成人二区免费| 爽好多水快深点欧美视频| 久久久三级国产网站| 91丨九色丨国产丨porny| 一区二区激情视频| 日韩欧美国产一区二区三区| 国产精品自拍网站| 亚洲一区二区三区中文字幕 | 精品在线一区二区三区| 国产精品美女www爽爽爽| 91福利在线导航| 精品影视av免费| 亚洲精品免费在线观看| 日韩写真欧美这视频| www.在线欧美| 奇米精品一区二区三区在线观看一| 精品动漫一区二区三区在线观看 | 亚洲久草在线视频| 欧美一区二区三区视频在线| 成人国产电影网| 日韩1区2区日韩1区2区| |精品福利一区二区三区| 欧美不卡在线视频| 色狠狠色噜噜噜综合网| 国产一区二区不卡| 丝袜诱惑亚洲看片| 亚洲欧美日韩国产一区二区三区| 欧美一区二区三区四区五区| 成人av高清在线| 精品一区二区精品| 日本伊人精品一区二区三区观看方式| 国产精品私房写真福利视频| 欧美大片一区二区| 欧美日韩综合一区| 一本色道久久综合亚洲aⅴ蜜桃 | 6080午夜不卡| 91论坛在线播放| 国产精品一二三四区| 日本一区中文字幕| 亚洲天堂2014| 国产精品每日更新在线播放网址| 日韩视频在线观看一区二区| 欧美亚洲另类激情小说| 不卡av免费在线观看| 国产成人av影院| 精品亚洲免费视频| 久久精品国产秦先生| 青青草国产精品97视觉盛宴 | 日日摸夜夜添夜夜添国产精品| 日韩一区日韩二区| 欧美国产一区二区在线观看| 久久久久国产精品麻豆ai换脸| 欧美电影免费观看高清完整版在线观看 | 国产精品一级片在线观看| 麻豆成人久久精品二区三区小说| 日韩精品视频网| 青青青伊人色综合久久| 美脚の诱脚舐め脚责91| 久久国产精品72免费观看| 男男gaygay亚洲| 韩国视频一区二区| 国产一区91精品张津瑜| k8久久久一区二区三区| a美女胸又www黄视频久久| 色哟哟一区二区| 欧美视频自拍偷拍| 91精品国产乱| 精品日韩欧美一区二区| 久久久久国产精品麻豆| 欧美激情一区二区三区四区| 中文字幕日韩av资源站| 亚洲久草在线视频| 奇米精品一区二区三区四区 | 91网页版在线| 91黄色小视频| 在线成人av影院| 精品91自产拍在线观看一区| 久久久精品天堂| 一区二区三区四区亚洲| 日韩福利电影在线| 国产乱国产乱300精品| 99国内精品久久| 欧美日韩国产经典色站一区二区三区| 欧美乱熟臀69xxxxxx| 精品国产凹凸成av人网站| 国产精品剧情在线亚洲| 亚洲午夜精品在线| 黄色精品一二区| 91婷婷韩国欧美一区二区| 欧美二区在线观看| 国产精品欧美综合在线| 亚洲sss视频在线视频| 国产精品88av| 欧美日韩精品久久久| 欧美国产日韩亚洲一区| 国产成人综合在线| 欧美久久久影院| 欧美精彩视频一区二区三区| 亚洲成人av电影| 成人h动漫精品|