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

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

?? ocrwblk.c

?? TUSB3410 win9x和win xp 驅(qū)動源代碼,包含開發(fā)測試工具
?? C
?? 第 1 頁 / 共 3 頁
字號:



PURB
BulkUsb_BuildAsyncRequest(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PUSBD_PIPE_INFORMATION PipeHandle,
    IN BOOLEAN Read
    )
/*++

Routine Description:

    Called from BulkUsb_StageReadWrite() for IRP_MJ_READ or IRP_MJ_WRITE

Arguments:

    DeviceObject - pointer to the FDO ( Functional Device Object )

    Irp - A staged IRP allocated and mapped by this driver in BulkUsb_StageReadWrite()
          to perform a single deviceExtension->MaximumTransferSize IO request

    PipeHandle - handle to the endpoint we're reading or writing

    Read - TRUE for reads, FALSE for writes

Return Value:

    ptr to initialized async urb. ( USB Request Block )

--*/
{
    ULONG siz;
    ULONG length;
    PURB urb = NULL;

    length = MmGetMdlByteCount(Irp->MdlAddress);

    siz = sizeof(struct _URB_BULK_OR_INTERRUPT_TRANSFER);
    urb = BULKUSB_ExAllocatePool(NonPagedPool, siz);

    BULKUSB_KdPrint( DBGLVL_MAXIMUM,("Enter BulkUsb_BuildAsyncRequest() len = 0x%x decimal %d \n siz = 0x%x urb 0x%x\n Pipehandle 0x%x\n", length, length, siz, urb, PipeHandle));

    if (urb) {
        RtlZeroMemory(urb, siz);

        urb->UrbBulkOrInterruptTransfer.Hdr.Length = (USHORT) siz;
        urb->UrbBulkOrInterruptTransfer.Hdr.Function =
                    URB_FUNCTION_BULK_OR_INTERRUPT_TRANSFER;
        urb->UrbBulkOrInterruptTransfer.PipeHandle =
                   PipeHandle->PipeHandle;
        urb->UrbBulkOrInterruptTransfer.TransferFlags =
            Read ? USBD_TRANSFER_DIRECTION_IN : 0;

        // short packet is not treated as an error.
        urb->UrbBulkOrInterruptTransfer.TransferFlags |= 
            USBD_SHORT_TRANSFER_OK;            
                
        //
        // not using linked urb's
        //
        urb->UrbBulkOrInterruptTransfer.UrbLink = NULL;

        urb->UrbBulkOrInterruptTransfer.TransferBufferMDL =
            Irp->MdlAddress;
        urb->UrbBulkOrInterruptTransfer.TransferBufferLength =
            length;

        BULKUSB_KdPrint( DBGLVL_MAXIMUM,("BulkUsb_BuildAsyncRequest() Init async urb Length = 0x%x decimal %d, buf = 0x%x\n",
            urb->UrbBulkOrInterruptTransfer.TransferBufferLength,
            urb->UrbBulkOrInterruptTransfer.TransferBufferLength,
            urb->UrbBulkOrInterruptTransfer.TransferBuffer));
    }

    BULKUSB_KdPrint( DBGLVL_MAXIMUM,("exit BulkUsb_BuildAsyncRequest\n"));

    return urb;
}


NTSTATUS
BulkUsb_AsyncReadWrite_Complete(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    )
/*++

Routine Description:

  Completion routine for our staged read/write Irps


Arguments:

    DeviceObject - Pointer to the device object for next lower device
	in the  driver stack; 

    Irp - Irp completed.

    Context - Driver defined context.

Return Value:

    The function value is the final status from the operation.

--*/
{
    NTSTATUS			ntStatus = STATUS_SUCCESS;
    PURB				urb;
    PBULKUSB_RW_CONTEXT context = Context;
    PIO_STACK_LOCATION	irpStack;
    PDEVICE_OBJECT      deviceObject;
	PDEVICE_EXTENSION   deviceExtension;

	// We have to get the deviceObject from the context, since the DeviceObject passed in
	//  here belongs to the next lower driver in the stack because we were invoked via
	//   IoCallDriver in BulkUsb_StagedReadWrite()
    deviceObject = context->DeviceObject;
	deviceExtension = deviceObject->DeviceExtension;

    //  If the lower driver returned PENDING, mark our stack location as pending also.
    if ( Irp->PendingReturned ) {  
        IoMarkIrpPending(Irp);
    }

	BULKUSB_ASSERT( deviceExtension->PendingIoIrps );  
	BULKUSB_ASSERT( deviceExtension->BaseIrp );  

	BULKUSB_ASSERT( context->Irp == Irp ); 
    
    urb = context->Urb;

    
    BULKUSB_KdPrint( DBGLVL_MAXIMUM,  ("\n\n ENTER BulkUsb_AsyncReadWrite_Complete():  Length 0x%08X decimal %d\n   Status 0x%08X\n",
                     urb->UrbBulkOrInterruptTransfer.TransferBufferLength,
                     urb->UrbBulkOrInterruptTransfer.TransferBufferLength,
                     urb->UrbHeader.Status));

    // decrement count of staged pending irps
    deviceExtension->StagedPendingIrpCount--;

    // decrement the driver's overall pending irp count
    BulkUsb_DecrementIoCount(deviceObject);
    
    // 
    // IoCallDriver has been called on this Irp;
    // Set the length based on the TransferBufferLength
    // value in the URB
    //
    Irp->IoStatus.Information =
        urb->UrbBulkOrInterruptTransfer.TransferBufferLength;

    ntStatus = STATUS_MORE_PROCESSING_REQUIRED;

    deviceExtension->StagedBytesTransferred += 
        urb->UrbBulkOrInterruptTransfer.TransferBufferLength; 
    
    BULKUSB_KdPrint ( DBGLVL_MAXIMUM,("BulkUsb_AsyncReadWrite_Complete(): Staged Async Completion %d, bytes = %d\n", 
        deviceExtension->StagedPendingIrpCount,
        deviceExtension->StagedBytesTransferred)); 

    IoFreeIrp(context->Irp);
    context->Irp = NULL; 


    if (deviceExtension->StagedPendingIrpCount == 0) {
        
		BULKUSB_KdPrint ( DBGLVL_HIGH,("BulkUsb_AsyncReadWrite_Complete(): StagedPendingIrpCount == 0, completeting BaseIrp 0x%x\n    Total bytes xferred = 0x%x, decimal %d\n", deviceExtension->BaseIrp, deviceExtension->StagedBytesTransferred, deviceExtension->StagedBytesTransferred));

        deviceExtension->BaseIrp->IoStatus.Status = STATUS_SUCCESS; 

        deviceExtension->BaseIrp->IoStatus.Information = 
            deviceExtension->StagedBytesTransferred;

        IoCompleteRequest(deviceExtension->BaseIrp,
                          IO_NO_INCREMENT);

        BULKUSB_ExFreePool( deviceExtension->PendingIoIrps ); 
		deviceExtension->PendingIoIrps  = NULL;
		deviceExtension->BaseIrp = NULL;

        // the event is only waited on if BulkUsb_CancelPendingIo() has been called
        KeSetEvent(&deviceExtension->StagingDoneEvent, 1, FALSE);
    }
    BULKUSB_ExFreePool(urb);

    BULKUSB_KdPrint ( DBGLVL_HIGH, ("Exit BulkUsb_AsyncReadWrite_Complete() gExAllocCount = dec %d\n", gExAllocCount ));
    BULKUSB_KdPrint ( DBGLVL_MAXIMUM,("Exit BulkUsb_AsyncReadWrite_Complete(), ntStatus = 0x%x\n\n",ntStatus )); 
    return ntStatus;
}





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

Routine Description:

	This is the IRP_MJ_READ routine set in our dispatch table;
	ReadFile() calls from user mode ultimately land here

Arguments:

    DeviceObject - pointer to the device object for this instance of the 82930
                    device.

    IRP - pointer to the IRP_MJ_READ

Return Value:

    NT status code

--*/
{

    NTSTATUS ntStatus = BulkUsb_StagedReadWrite(DeviceObject,
                                  Irp,
                                  TRUE);	// false to write, true to read

    return ntStatus;                                  

}

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

Routine Description:
	This is the IRP_MJ_WRITE routine set in our dispatch table;
	WriteFile() calls from user mode ultimately land here

Arguments:

    DeviceObject - pointer to the device object for this instance of the 82930
                    device.

    IRP - pointer to the IRP_MJ_WRITE

Return Value:

    NT status code

--*/
{

    NTSTATUS ntStatus = BulkUsb_StagedReadWrite(DeviceObject,
                                  Irp,
                                  FALSE);	// false to write, true to read

    return ntStatus;                                  

}



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

Routine Description:

    This is the dispatch table routine for IRP_MJ_CLOSE.
    It handles user mode CloseHandle() calls for a pipe
    It closes the File Object for the pipe handle it represents.

Arguments:

    DeviceObject - pointer to our FDO (Functional Device Object )


Return Value:

    NT status code

--*/
{
    NTSTATUS ntStatus;
	NTSTATUS actStat;
    PFILE_OBJECT fileObject;
    PIO_STACK_LOCATION irpStack;
    PDEVICE_EXTENSION deviceExtension;
    PUSBD_PIPE_INFORMATION pipeHandle = NULL;

    BULKUSB_KdPrint( DBGLVL_DEFAULT,("entering BulkUsb_Close\n"));

    
    BulkUsb_IncrementIoCount(DeviceObject);

    deviceExtension = DeviceObject->DeviceExtension;
    irpStack = IoGetCurrentIrpStackLocation (Irp);
    fileObject = irpStack->FileObject;

    if (fileObject->FsContext) {
        // closing pipe handle
        pipeHandle =  fileObject->FsContext;
		// roms: reset USB pipes (for flushing them)
		//BulkUsb_ResetPipe(DeviceObject, pipeHandle );

		if ( pipeHandle->PipeFlags ) { // set if opneed
			// may have been aborted
			BULKUSB_KdPrint( DBGLVL_DEFAULT,("closing pipe %x\n", pipeHandle));
			deviceExtension->OpenPipeCount--;
			pipeHandle->PipeFlags = 0;
		}
		else {
			// pipe was already closed; this can only be if we got a sudden REMOVE_DEVICE
			BULKUSB_ASSERT(  deviceExtension->DeviceRemoved );
			BULKUSB_KdPrint( DBGLVL_DEFAULT,("Pipe %x was already closed \n", pipeHandle));

		}
    }

	BulkUsb_DecrementIoCount(DeviceObject);
    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;

    ntStatus = Irp->IoStatus.Status;


    IoCompleteRequest (Irp,
                       IO_NO_INCREMENT
                       );
                       
	// try to power down device if this is the last pipe
	actStat = BulkUsb_SelfSuspendOrActivate( DeviceObject, TRUE );

    BULKUSB_KdPrint( DBGLVL_DEFAULT,("exit BulkUsb_Close OpenPipeCount = decimal %d, status %x\n",deviceExtension->OpenPipeCount, ntStatus));

    return ntStatus;
}


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

Routine Description:

    This is the dispatch table routine for IRP_MJ_CREATE.
    It's the entry point for CreateFile() calls
    user mode apps may open "<name genned fron GUID>.\yy"
    where yy is the internal pipe id

Arguments:

    DeviceObject - pointer to our FDO ( Functional Device Object )

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品伦理精品一区| 成人午夜电影久久影院| 国产精品1区2区3区| 亚洲成人免费看| 国产精品久久久久aaaa樱花| 久久网这里都是精品| 欧美精选午夜久久久乱码6080| 亚洲精品精品亚洲| 久久久高清一区二区三区| 6080午夜不卡| 男女视频一区二区| 亚洲麻豆国产自偷在线| 国产偷v国产偷v亚洲高清| 欧美不卡一区二区三区四区| 67194成人在线观看| 精品一区二区日韩| 午夜电影网一区| 男人操女人的视频在线观看欧美| www激情久久| 国产亚洲污的网站| 国产精品系列在线| 亚洲欧美视频在线观看视频| 欧美一区二区久久| 精品国产乱码久久久久久夜甘婷婷 | 精品88久久久久88久久久| 日韩欧美第一区| 91亚洲精品久久久蜜桃网站| 欧美在线免费观看亚洲| 欧美精品乱码久久久久久| 国产成人午夜片在线观看高清观看| 中文字幕欧美一| 精品国产1区二区| 国产精品青草综合久久久久99| 欧美日韩一区中文字幕| 欧美一区午夜视频在线观看| 欧美精品一区二区三区久久久| 欧美日韩综合色| 欧美大片在线观看| 欧美日本韩国一区二区三区视频| 成人av电影观看| 亚洲乱码国产乱码精品精98午夜| 日韩欧美国产精品一区| 国产精品污网站| 麻豆成人91精品二区三区| 亚洲成av人片在线观看无码| 国产精品一二三四五| 欧美专区在线观看一区| 久久在线免费观看| 精品国产电影一区二区| 亚洲黄色性网站| 国产91精品免费| 久久先锋影音av| 视频一区中文字幕| 色综合中文综合网| 91国产视频在线观看| 久久久久久久综合日本| 免费国产亚洲视频| 欧美三区在线视频| 亚洲欧美电影一区二区| 北岛玲一区二区三区四区| 欧美精品一区男女天堂| 日韩精彩视频在线观看| 国产精品乱码妇女bbbb| 懂色av一区二区夜夜嗨| 99re亚洲国产精品| 色又黄又爽网站www久久| 国产精品大尺度| 色婷婷综合久久久中文一区二区| 欧美综合欧美视频| 午夜天堂影视香蕉久久| 欧美人与性动xxxx| 美女mm1313爽爽久久久蜜臀| 日韩限制级电影在线观看| 久久国产婷婷国产香蕉| 精品国产乱码久久久久久浪潮 | 91精品国产一区二区人妖| 日韩欧美一级精品久久| 国产成人夜色高潮福利影视| 色婷婷激情久久| 日韩av中文在线观看| 久久久国产一区二区三区四区小说 | 国产精品乱人伦中文| 91免费精品国自产拍在线不卡| 欧美理论片在线| 久久精品国产免费| 日韩毛片一二三区| 精品一区二区av| 欧美激情中文字幕| 欧美性猛片xxxx免费看久爱 | 欧美tickle裸体挠脚心vk| 国产91丝袜在线观看| 日韩欧美不卡在线观看视频| 成人久久久精品乱码一区二区三区| 欧美中文字幕一区二区三区亚洲| 国产视频一区在线播放| 欧美又粗又大又爽| 久久99久久精品| 欧美大胆一级视频| 午夜精品福利久久久| 国产色综合久久| 91精品国产综合久久久久久久| 亚洲国产三级在线| 国产日本欧洲亚洲| 91精品黄色片免费大全| 色悠悠亚洲一区二区| 国产福利一区二区三区视频在线| 精品国产精品网麻豆系列| 麻豆精品视频在线| 性久久久久久久久| 亚洲四区在线观看| 精品视频在线视频| 91色在线porny| 91麻豆文化传媒在线观看| 国产精品1区2区| 国产成人一区在线| 精品夜夜嗨av一区二区三区| 麻豆一区二区99久久久久| 久久成人免费日本黄色| 天天射综合影视| 五月婷婷欧美视频| 日本欧美肥老太交大片| 看电视剧不卡顿的网站| 国产精品久久久久7777按摩| 中文字幕免费观看一区| 国产精品毛片a∨一区二区三区| 91国偷自产一区二区开放时间 | 亚洲欧洲美洲综合色网| 亚洲色图视频免费播放| 亚洲永久免费视频| 日本不卡一二三| 综合精品久久久| 亚洲一区二区五区| 国产女人水真多18毛片18精品视频| 99re热视频精品| 欧美日本一道本| 国产精品网站一区| 午夜精品一区二区三区免费视频| 中文字幕乱码一区二区免费| 亚洲免费在线电影| 日韩av一区二区在线影视| 国产精品一区免费在线观看| 91视频免费看| 精品欧美久久久| 亚洲一区二区免费视频| 成人免费小视频| 麻豆精品在线观看| 在线观看国产精品网站| 欧美v日韩v国产v| 成人性色生活片| 国产一区999| 91精品国产综合久久精品性色 | 亚洲综合色网站| 成人午夜碰碰视频| 精品sm捆绑视频| 亚洲国产综合人成综合网站| 狠狠狠色丁香婷婷综合激情| 在线观看中文字幕不卡| 欧美经典一区二区三区| 久草这里只有精品视频| 韩国毛片一区二区三区| 狠狠色丁香久久婷婷综合丁香| 奇米精品一区二区三区四区| 精品影视av免费| 欧美绝品在线观看成人午夜影视| 欧美精品123区| 成人黄色软件下载| 久久人人爽爽爽人久久久| 国产中文字幕一区| 成人精品国产福利| 久久久国产一区二区三区四区小说 | 欧美一区二区女人| 久久久美女毛片| 1000部国产精品成人观看| 99免费精品在线观看| 亚洲自拍偷拍av| 日韩亚洲国产中文字幕欧美| 久久99久久99小草精品免视看| 色综合久久中文综合久久97| 国产精品久久久久aaaa樱花| 日本高清无吗v一区| 欧美成人官网二区| 极品少妇xxxx精品少妇| 国产清纯白嫩初高生在线观看91| 一区二区三区资源| 欧美另类久久久品| 国产成人亚洲综合a∨婷婷图片| 欧美日韩三级视频| 色婷婷综合久久久久中文 | 高清免费成人av| 亚洲视频资源在线| 欧美日本视频在线| 丰满放荡岳乱妇91ww| 亚洲一区二区三区免费视频| 精品国产乱码久久久久久免费| 亚洲电影第三页| 成人a级免费电影| 日韩激情一区二区| 亚洲欧美日韩系列| 精品播放一区二区| 欧美老肥妇做.爰bbww视频|