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

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

?? ocrwblk.c

?? TUSB3410 win9x和win xp 驅動源代碼,包含開發測試工具
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*++

Copyright (c) 1997-1998  Microsoft Corporation

Module Name:

   OcrwBulk.c

Abstract:

    Bulk USB device driver for Intel 82930 USB test board
    Read/write io test code

Environment:

    kernel mode only

Notes:

  THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
  KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
  PURPOSE.

  Copyright (c) 1997-1998 Microsoft Corporation.  All Rights Reserved.


Revision History:

    11/17/97 : created

--*/


#include "wdm.h"
#include "stdarg.h"
#include "stdio.h"

#define DRIVER 

#include "usbdi.h"
#include "usbdlib.h"
#include "Blk82930.h"



NTSTATUS
BulkUsb_StagedReadWrite(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN BOOLEAN Read
    )
/*++

Routine Description:

    This routine is called by BulkUsb_Read() for IRP_MJ_READ.
    This routine is called by BulkUsb_Write() for IRP_MJ_WRITE.

    Breaks up a read or write in to specified sized chunks,
    as specified by deviceExtension->MaximumTransferSize

Arguments:

    DeviceObject - pointer to our FDO ( Functional Device Object )

    Irp - pointer to the IRP_MJ_READ or IRP_MJ_WRITE

    Read - TRUE for read, FALSE for write


Return Value:

    NT status code

--*/
{
    NTSTATUS ntStatus = STATUS_SUCCESS;
	NTSTATUS resetPipeStatus;
    PFILE_OBJECT fileObject;
    PIO_STACK_LOCATION irpStack, nextStack;
    PURB urb;
    PIRP irp;
    PMDL mdl; 
    PVOID va;
    CHAR stackSize;
    KIRQL OldIrql;
	BOOLEAN fRes;
    NTSTATUS waitStatus;
    ULONG i, nIrps = 0, totalLength = 0, totalIrpsNeeded, used;
    PUSBD_PIPE_INFORMATION pipeHandle = NULL;
    PDEVICE_EXTENSION deviceExtension = DeviceObject->DeviceExtension;
    PUCHAR pCon =  NULL;
	ULONG ChunkSize = deviceExtension->MaximumTransferSize;
	ULONG arraySize;
    PBULKUSB_RW_CONTEXT context = NULL;

    BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("enter BulkUsb_StagedReadWrite()\n"));

    Irp->IoStatus.Information = 0;

    // Can't accept a new io request if:
    //  1) device is removed, 
    //  2) has never been started, 
    //  3) is stopped,
    //  4) has a remove request pending,
    //  5) has a stop device pending
    if ( !BulkUsb_CanAcceptIoRequests( DeviceObject ) ) {
        ntStatus = STATUS_DELETE_PENDING;
        Irp->IoStatus.Status = ntStatus;
		BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() can't accept requests, returning STATUS_INSUFFICIENT_RESOURCES\n"));
        IoCompleteRequest (Irp, IO_NO_INCREMENT );
        return ntStatus;
    }


    irpStack = IoGetCurrentIrpStackLocation (Irp);
    fileObject = irpStack->FileObject;

    pipeHandle =  fileObject->FsContext;

    if (!pipeHandle)
    {
       ntStatus = STATUS_INVALID_HANDLE;
	   BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() Rejecting on invalid pipeHandle 0x%x decimal %d\n",pipeHandle, pipeHandle ));
       Irp->IoStatus.Status = ntStatus;
       IoCompleteRequest (Irp, IO_NO_INCREMENT );
       return ntStatus;
    }

    //
    // submit the request to USB
    //
	BULKUSB_ASSERT( UsbdPipeTypeBulk == pipeHandle->PipeType );


	if ( Irp->MdlAddress )
		totalLength = MmGetMdlByteCount(Irp->MdlAddress);


	BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() totalLength = decimal %d, Irp->MdlAddress = 0x%x\n",totalLength, Irp->MdlAddress ));

    if ( 0 == totalLength ) {
		// allow 0-len read or write; just return success
        ntStatus = STATUS_SUCCESS;
        Irp->IoStatus.Status = ntStatus;
		BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() returning quick success on zero-len read/write request\n"));

        IoCompleteRequest (Irp, IO_NO_INCREMENT );
        return ntStatus;
    }
    

	// more memory than is on our test device?
 	if ( totalLength > BULKUSB_TEST_BOARD_TRANSFER_BUFFER_SIZE )
	{
       ntStatus = STATUS_INVALID_PARAMETER;
	   BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() Rejecting on too large request 0x%x decimal %d\n",totalLength, totalLength ));
       Irp->IoStatus.Status = ntStatus;
       IoCompleteRequest (Irp, IO_NO_INCREMENT );
       return ntStatus;
	}

    // calculate total # of staged irps that will be needed
	totalIrpsNeeded =  totalLength / deviceExtension->MaximumTransferSize ;
	if ( totalLength % deviceExtension->MaximumTransferSize )
		totalIrpsNeeded++;


	BULKUSB_ASSERT( !deviceExtension->PendingIoIrps );  // this should have been cleaned up last time
	BULKUSB_ASSERT( !deviceExtension->BaseIrp );  // this should have been cleaned up last time

    used = 0;
	// alloc one extra for termination
	arraySize =  ( totalIrpsNeeded +1 ) * sizeof(BULKUSB_RW_CONTEXT);

    // allocate space for an array of BULKUSB_RW_CONTEXT structs for the staged irps
    deviceExtension->PendingIoIrps = BULKUSB_ExAllocatePool(NonPagedPool, arraySize );
    
    if ( !deviceExtension->PendingIoIrps ) {
        ntStatus = STATUS_INSUFFICIENT_RESOURCES;
        BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() !deviceExtension->PendingIoIrps STATUS_INSUFFICIENT_RESOURCES\n"));
        Irp->IoStatus.Status = ntStatus;
        IoCompleteRequest (Irp, IO_NO_INCREMENT );
        return ntStatus;
    }

    RtlZeroMemory(deviceExtension->PendingIoIrps, arraySize );

    // init ptr to 1st BULKUSB_RW_CONTEXT struct in array
    pCon =  (PUCHAR) deviceExtension->PendingIoIrps;

    deviceExtension->BaseIrp = Irp; // this is the original user's irp
    deviceExtension->StagedBytesTransferred = 0;
	deviceExtension->StagedPendingIrpCount = totalIrpsNeeded;

    // we need to build a series of irps & urbs to represent 
    // this request.

    while (NT_SUCCESS(ntStatus) ) {
        context =  (PBULKUSB_RW_CONTEXT) pCon;
        irp = NULL;
        urb = NULL;
        mdl = NULL;

        if ( !BulkUsb_CanAcceptIoRequests( DeviceObject ) ) {
            // got sudden remove! ( i.e. plug was yanked )
            ntStatus = STATUS_DELETE_PENDING;
            Irp->IoStatus.Status = ntStatus;
		    BULKUSB_KdPrint ( DBGLVL_MAXIMUM, ("BulkUsb_StagedReadWrite() got sudden remove, breaking out of URB-building loop\n"));
            break;
        }

        stackSize = (CCHAR)(deviceExtension->TopOfStackDeviceObject->StackSize + 1);
        irp = IoAllocateIrp(stackSize, FALSE);
        
        // Get the virtual address for the buffer described by 
        // our original input Irp's MDL. 
        va = MmGetMdlVirtualAddress(Irp->MdlAddress);

        if (irp) {
           // Each new Irp will 'see' the entire buffer, but map it's IO location
           // to a single ChunkSize section within it via IoBuildPartialMdl()
           mdl = IoAllocateMdl(va,
                                totalLength,
                                FALSE,
                                FALSE,
                                irp);
        }                                    
                            
        if (mdl) {        
			// see if we're done yet
			if( ( used + ChunkSize ) > totalLength  ) {
				// make sure to truncate last transfer if neccy
				ChunkSize = totalLength - used;

			}

            // Map the sub-area of the full user buffer this staged Irp will be using for IO
            IoBuildPartialMdl(Irp->MdlAddress, // Points to an MDL describing the original buffer,
                                               // of which a subrange is to be mapped
                              mdl,             // our allocated target mdl
                              (PUCHAR)va + used, // base virtual address of area to be mapped
                              ChunkSize);      // size of area to be mapped

            used+=ChunkSize;
                                              
            urb = BulkUsb_BuildAsyncRequest(DeviceObject,
                                           irp,
                                           pipeHandle,
                                           Read);
        }
        
        if (urb && irp && mdl) {

            context->Urb = urb;
            context->DeviceObject = DeviceObject;
            context->Irp = irp;
			nIrps++;
        
            // IoGetNextIrpStackLocation gives a higher level driver access to the next-lower 
            // driver's I/O stack location in an IRP so the caller can set it up for the lower driver.
            nextStack = IoGetNextIrpStackLocation(irp);
            BULKUSB_ASSERT(nextStack != NULL);
            BULKUSB_ASSERT(DeviceObject->StackSize>1);

            nextStack->MajorFunction = IRP_MJ_INTERNAL_DEVICE_CONTROL;
            nextStack->Parameters.Others.Argument1 = urb;
            nextStack->Parameters.DeviceIoControl.IoControlCode =
                IOCTL_INTERNAL_USB_SUBMIT_URB;

            IoSetCompletionRoutine(irp,
                    BulkUsb_AsyncReadWrite_Complete,
                    context, // pass the context array element to completion routine
                    TRUE,    // invoke on success
                    TRUE,    // invoke on error
                    TRUE);   // invoke on cancellation of the Irp

            BULKUSB_KdPrint ( DBGLVL_MAXIMUM, ("BulkUsb_StagedReadWrite() created staged irp #%d %x\n", nIrps, irp));
                                   
            // We keep an array of all pending read/write Irps; we may have to cancel
            // them explicitly on sudden device removal or other error
			(( PBULKUSB_RW_CONTEXT) pCon)->Irp = irp;

            BulkUsb_IncrementIoCount(DeviceObject);

			ntStatus = IoCallDriver(deviceExtension->TopOfStackDeviceObject,
             (( PBULKUSB_RW_CONTEXT) pCon)->Irp);


        } else {
            ntStatus = STATUS_INSUFFICIENT_RESOURCES;
			BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() Dumped from irp loop on failed Irp or urb allocate\n"));
            break;
        }

        if (used >= totalLength) {
            break;      // we're done
        }


        // point to next BULKUSB_RW_CONTEXT struct
        pCon +=  sizeof(BULKUSB_RW_CONTEXT);

    } // end while


    Irp->IoStatus.Status = ntStatus;

    if (!NT_SUCCESS(ntStatus)) {

        BULKUSB_KdPrint ( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() FAILED, ntStatus = 0x%x\n", ntStatus));

	    // try to reset the pipe on error ( unless device has been suddenly removed )
	    if ( pipeHandle  && BulkUsb_CanAcceptIoRequests( DeviceObject ) ) {

		    resetPipeStatus = BulkUsb_ResetPipe(DeviceObject, pipeHandle );

		    BULKUSB_KdPrint( DBGLVL_DEFAULT, ("BulkUsb_StagedReadWrite() Tried to reset pipe 0x%x, Status = 0x%x\n", pipeHandle, resetPipeStatus));
		    BULKUSB_KdPrintCond ( DBGLVL_DEFAULT, (!NT_SUCCESS(resetPipeStatus)), ("BulkUsb_StagedReadWrite() BulkUsb_ResetPipe() FAILED\n"));

		    if( !NT_SUCCESS(resetPipeStatus) ) {
			    // if can't reset pipe, try to reset device ( parent port )
			    BULKUSB_KdPrint( DBGLVL_DEFAULT, ("Will try to reset device \n"));

			    resetPipeStatus = BulkUsb_ResetDevice(DeviceObject);

			    BULKUSB_KdPrintCond ( DBGLVL_DEFAULT, (!NT_SUCCESS(resetPipeStatus)), ("BulkUsb_StagedReadWrite() BulkUsb_ResetDevice() FAILED\n"));
		    }
	    }
    } // end, if !NT_SUCCESS( ntStatus )


    if ( 0 == nIrps ) {
        // only complete the request here if we created no staged irps
		BULKUSB_KdPrint ( DBGLVL_HIGH, ("BulkUsb_StagedReadWrite() 0 irps staged, completing  base IRP now!\n"));
        IoCompleteRequest (Irp, IO_NO_INCREMENT  );
    } else {
		BULKUSB_KdPrint ( DBGLVL_HIGH, ("BulkUsb_StagedReadWrite() %d irps staged\n", nIrps));

        if ( deviceExtension->BaseIrp ) {
            //
            // Mark the original input Irp pending; it will be completed when the last staged irp
            //  is handled ( in BulkUsb_AsyncReadWrite_Complete() ).
            //
		    BULKUSB_KdPrint ( DBGLVL_HIGH, ("BulkUsb_StagedReadWrite(),marking base IRP  0x%x pending!\n", Irp));
            BULKUSB_ASSERT( Irp == deviceExtension->BaseIrp );
            ntStatus = STATUS_PENDING;
            Irp->IoStatus.Status = ntStatus;
            IoMarkIrpPending(Irp);
        } else {
            // It is possible for BulkUsb_AsyncReadWrite_Complete() to have completed the
            //  original irp before we even get here! 
            // If this happens, it will have NULLED-out deviceExtension->BaseIrp.
            ntStatus = STATUS_SUCCESS;
        }
    }

    BULKUSB_KdPrint ( DBGLVL_HIGH, ("BulkUsb_StagedReadWrite() StagedReadWrite  ntStatus = 0x%x decimal %d\n", ntStatus, ntStatus));
    BULKUSB_KdPrint ( DBGLVL_HIGH, ("EXIT BulkUsb_StagedReadWrite() gExAllocCount = dec %d\n", gExAllocCount ));

    return ntStatus;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
9久草视频在线视频精品| 欧美亚洲自拍偷拍| 亚洲一区二区欧美激情| 日韩视频国产视频| 99国产精品99久久久久久| 麻豆免费看一区二区三区| 亚洲视频综合在线| 久久蜜桃香蕉精品一区二区三区| 在线亚洲一区二区| 国产成都精品91一区二区三| 五月婷婷久久丁香| 亚洲另类春色校园小说| 久久亚洲私人国产精品va媚药| 欧洲生活片亚洲生活在线观看| 成人毛片视频在线观看| 久久丁香综合五月国产三级网站| 亚洲一区在线观看网站| 国产精品狼人久久影院观看方式| 日韩欧美一区二区免费| 欧美日韩激情一区二区三区| av成人免费在线观看| 91浏览器入口在线观看| 国产精品久久久久久久岛一牛影视 | 久久久久国产免费免费| 日本韩国欧美一区| av一区二区三区黑人| 久久国产综合精品| 午夜免费欧美电影| 亚洲一区二区3| 日韩理论电影院| 国产精品视频yy9299一区| 久久久久国产一区二区三区四区| 日韩午夜av电影| 欧美日本一区二区三区| 91行情网站电视在线观看高清版| a级精品国产片在线观看| 丁香激情综合五月| 懂色av一区二区三区蜜臀| 激情图区综合网| 激情伊人五月天久久综合| 麻豆精品一区二区三区| 欧美日韩国产大片| 国产精品美女久久福利网站| 欧美亚洲动漫制服丝袜| 欧美亚洲一区三区| 欧美日韩小视频| 欧美三级电影在线看| 欧美性大战久久久久久久蜜臀| 欧美亚洲一区二区在线| 欧洲av一区二区嗯嗯嗯啊| 色88888久久久久久影院野外| 在线观看一区二区精品视频| 色婷婷国产精品综合在线观看| 色丁香久综合在线久综合在线观看| 色网站国产精品| 欧美日韩国产成人在线91| 欧美老人xxxx18| 欧美刺激午夜性久久久久久久| 精品91自产拍在线观看一区| 久久免费美女视频| 中文字幕一区二区三区av| 亚洲男人都懂的| 亚洲bt欧美bt精品| 精品在线一区二区三区| 国产成人无遮挡在线视频| 国产经典欧美精品| 日本精品视频一区二区三区| 欧美影院精品一区| 26uuu亚洲综合色欧美| 国产精品色呦呦| 亚洲成人动漫一区| 国产一区二区三区在线观看精品 | 成人短视频下载| 94-欧美-setu| 欧美顶级少妇做爰| 久久久久9999亚洲精品| 国产精品第13页| 日韩国产在线观看| 国产成人aaaa| 欧美日韩一区二区三区四区| 精品少妇一区二区三区日产乱码| 日本一区二区视频在线| 亚洲一区二区三区中文字幕| 久久精品国产亚洲a| 成人av综合一区| 777久久久精品| 国产精品素人一区二区| 亚洲动漫第一页| 大尺度一区二区| 91麻豆精品国产91久久久久久| 国产日韩欧美综合在线| 亚洲午夜久久久久中文字幕久| 精品在线一区二区| 欧美群妇大交群中文字幕| 国产区在线观看成人精品| 亚洲va韩国va欧美va| 成人免费av资源| 日韩欧美国产一二三区| 亚洲精品日韩综合观看成人91| 加勒比av一区二区| 欧美精品在线视频| 亚洲欧洲国产日韩| 国产精品一区二区91| 欧美精选一区二区| 亚洲日本va在线观看| 国产福利一区在线| 日韩午夜激情视频| 亚洲一区二区三区四区五区黄 | 国产98色在线|日韩| 欧美高清你懂得| 亚洲欧美福利一区二区| 国产精品一品二品| 日韩美女主播在线视频一区二区三区 | 欧美日产在线观看| 亚洲欧洲国产日韩| 成人午夜视频网站| wwwwxxxxx欧美| 免费看日韩精品| 91精品国产综合久久精品性色| 一区二区三区欧美日| hitomi一区二区三区精品| 久久免费偷拍视频| 麻豆传媒一区二区三区| 欧美日韩高清一区二区| 亚洲精品欧美激情| 91在线观看美女| 中文字幕一区二区三中文字幕| 国产传媒欧美日韩成人| 2021国产精品久久精品| 蜜乳av一区二区| 日韩一区二区三区视频在线 | 国产真实乱对白精彩久久| 4438成人网| 丝袜美腿成人在线| 欧美猛男男办公室激情| 亚洲 欧美综合在线网络| 欧美视频你懂的| 亚洲h精品动漫在线观看| 欧美综合在线视频| 亚洲图片一区二区| 欧美日韩精品福利| 免费精品视频最新在线| 日韩欧美中文字幕精品| 麻豆国产91在线播放| 欧美电影免费提供在线观看| 久久国产精品72免费观看| 亚洲制服丝袜一区| 亚洲人成网站影音先锋播放| 在线电影一区二区三区| 欧美日韩国产乱码电影| 久久一留热品黄| 国产精品1区2区3区在线观看| 2欧美一区二区三区在线观看视频| 黄色小说综合网站| 欧美激情在线看| 99久久精品国产精品久久| 亚洲视频1区2区| 爽好多水快深点欧美视频| 亚洲综合色自拍一区| 日本高清视频一区二区| 亚洲一区二区三区不卡国产欧美| 欧美日本一区二区三区| 美女视频黄频大全不卡视频在线播放| 日韩欧美一区二区久久婷婷| 在线国产亚洲欧美| 久久久久久日产精品| 中文字幕乱码亚洲精品一区| 亚洲欧美二区三区| 亚洲成人www| 一区二区三区国产豹纹内裤在线| 精品国产乱码久久| 欧美一级视频精品观看| 91麻豆精品国产自产在线 | 精品日韩在线观看| 久久精品国产精品亚洲红杏| 久久久久国产精品厨房| 色视频一区二区| 麻豆久久久久久| 中文字幕在线免费不卡| 8x福利精品第一导航| 国产成人免费9x9x人网站视频| 亚洲另类在线视频| 欧美mv日韩mv| 欧美午夜免费电影| 国产电影一区二区三区| 亚洲国产精品天堂| 国产偷v国产偷v亚洲高清| 欧美性猛交xxxx乱大交退制版| 国产自产2019最新不卡| 亚洲国产一区视频| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美在线三级电影| 国产精品一线二线三线| 亚洲电影一区二区| 国产精品久久久久永久免费观看| 91精品国产乱码| 91麻豆视频网站| 国产成人免费视| 欧美a一区二区| 一区二区三区蜜桃|