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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? rwusb.c

?? HomePNA的Usb網(wǎng)卡驅(qū)動
?? C
?? 第 1 頁 / 共 5 頁
字號:
                           0 );

                ASSERT( pRcvBuf->Irp == NULL);
            }        
            
        } // if pending

    } // for


    DEBUGMSG( DBG_FUNC, ("  -CancelPendingReadIo()\n"));

    return (BOOLEAN) cRes;

}


BOOLEAN
CancelPendingWriteIo(
    IN PUSB_DEVICE DeviceExt
    )
/*++



Return Value:

    TRUE if cancelled any, else FALSE

--*/
{
    PUSB_DEVICE device = DeviceExt;
    BOOLEAN cRes = FALSE;
    NTSTATUS timeStat;
    PUSB_CONTEXT pCont;
    ULONGLONG thisContext;  //make ptr arithmetic 64-bit compatible
    int i;

    DEBUGMSG( DBG_FUNC, ("  +CancelPendingWriteIo()\n"));

    ASSERT(KeGetCurrentIrql() < DISPATCH_LEVEL);


    //
    // Free all resources for the SEND buffer queue.
    //


    thisContext = (ULONGLONG) device->pSendContexts;

    for ( i= 0; i < NUM_SEND_CONTEXTS; i++ ) {

        pCont = (PUSB_CONTEXT)thisContext;

        if( TRUE == pCont->fInUse ) {

            // Get the USB_CONTEXT and cancel it's IRP; the completion routine will itself
            // remove it from the HeadPendingSendList and NULL out HeadPendingSendList
            //  when the last IRP on the list has been  cancelled; that's how we exit this loop
            //

            ASSERT( NULL != pCont->Irp );

            DEBUGMSG( DBG_WARN, ("  CancelPendingWriteIo() about to CANCEL a write IRP!\n"));

            // Completion routine ( USBCompleteWrite() )will free irps, mdls, buffers, etc as well
            cRes = IoCancelIrp( pCont->Irp );

            DEBUGCOND( DBG_ERR, !cRes, ("  CancelPendingWriteIo() COULDN'T CANCEL IRP! 0x%x\n", pCont->Irp ));
            DEBUGCOND( DBG_FUNC, cRes, ("  CancelPendingWriteIo() CANCELLED IRP SUCCESS! 0x%x\n\n", pCont->Irp));

            //
            // Sleep 200 microsecs to give cancellation time to work
            //

            NdisMSleep(200);
        }

        thisContext +=  sizeof( USB_CONTEXT );


    } // for
    
    

    DEBUGMSG( DBG_FUNC, ("  -CancelPendingWriteIo()\n"));

    return (BOOLEAN) cRes;

}

BOOLEAN
CancelPendingControlIo(
    IN PUSB_DEVICE DeviceExt,
    IN PIRP  IrpToCancel,
    IN PKEVENT EventToClear

    )
/*++

  Return Value:
    TRUE if cancelled any, else FALSE

  --*/
{
    PUSB_DEVICE device = DeviceExt;
    BOOLEAN cRes = FALSE;
    NTSTATUS timeStat;

    DEBUGMSG( DBG_FUNC, ("  +CancelPendingControlIo()\n"));

    ASSERT(KeGetCurrentIrql() <= DISPATCH_LEVEL );

    //置于非信號態(tài)
    KeClearEvent( EventToClear );
    if(IrpToCancel)
      cRes = IoCancelIrp( IrpToCancel );  //CancelPendingControlIo()

    DEBUGCOND( DBG_ERR, !cRes, ("  CancelPendingControlIo() COULDN'T CANCEL IRP!\n"));
    DEBUGCOND( DBG_FUNC, cRes, ("  CancelPendingControlIo() CANCELLED IRP SUCCESS!\n"));

    if ( cRes ) {
        timeStat = MyKeWaitForSingleObject(
                   device,
                   EventToClear,
                   NULL,  // irp to cancel; we did it above already, so pass NULL
                   0 );
    }


    DEBUGMSG( DBG_FUNC, ("  -CancelPendingControlIo()\n"));

    return (BOOLEAN) cRes;

}


NTSTATUS
CallUSBD(
    IN PUSB_DEVICE Device,
    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.

Arguments:

    DeviceExt - pointer to the dev ext

    Urb - pointer to an already-formatted Urb request block

Return Value:

    STATUS_SUCCESS if successful,
    STATUS_UNSUCCESSFUL otherwise

--*/
{
    NTSTATUS ntStatus;
    PDEVICE_OBJECT urbTargetDev;
    PIO_STACK_LOCATION nextStack;
    PMDL mdl;

    DEBUGMSG( DBG_FUNC,(" +CallUSBD\n"));

    ASSERT(KeGetCurrentIrql() == PASSIVE_LEVEL );

    ASSERT( Device );

    ASSERT( NULL == ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb );  //shouldn't be multiple control calls pending

    //
    // issue a synchronous request (we'll wait )
    
    urbTargetDev = Device->pUsbDevObj;

    ASSERT( urbTargetDev );

	// make an irp sending to usbhub?用IoAllocateIrp來創(chuàng)建Irp其StackSize均要+1
    ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb = 
            IoAllocateIrp( (CCHAR)(Device->pUsbDevObj->StackSize +1), FALSE );

    if ( NULL == ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb )
    {
        DEBUGMSG(DBG_ERR, ("  CallUsbd failed to alloc IRP\n"));

        ntStatus = STATUS_INSUFFICIENT_RESOURCES;

        goto done;
    }
//STATUS_NOT_SUPPORTED:
  //	The miniclass driver cannot distinguish the target condition
    ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb->IoStatus.Status = STATUS_NOT_SUPPORTED;
    ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb->IoStatus.Information = 0;

    //
    // Call the class driver to perform the operation.  If the returned status
    // is PENDING, wait for the request to complete.
    
    nextStack = IoGetNextIrpStackLocation(((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb);
    ASSERT(nextStack != NULL);

    //
    // pass the URB to the USB driver stack
    //
    nextStack->Parameters.Others.Argument1 = Urb;

    //
    // pass the URB to the USB driver stack
    //
    nextStack->MajorFunction = IRP_MJ_INTERNAL_DEVICE_CONTROL;
    nextStack->Parameters.Others.Argument1 = Urb;
    nextStack->Parameters.DeviceIoControl.IoControlCode =
        IOCTL_INTERNAL_USB_SUBMIT_URB;


    IoSetCompletionRoutine(
                ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb,      // irp to use
                UsbIoCompleteControl,         // routine to call when irp is done
                DEV_TO_CONTEXT(Device),  // context to pass routine
                TRUE,                      // call on success
                TRUE,                      // call on error
                TRUE);                     // call on cancel
    KeClearEvent(&Device->EventUrb);

    UsbIncIoCount( Device );

    ntStatus =  IoCallDriver( urbTargetDev, ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb );
    DEBUGMSG( DBG_OUT,("CallUSBD () return from IoCallDriver USBD %x\n", ntStatus));

    if ((ntStatus == STATUS_PENDING) || (ntStatus == STATUS_SUCCESS))
	{    //wait  for STATUS_PENDING
        // wait, but dump out on timeout
        if (ntStatus == STATUS_PENDING)
		{
            ntStatus = MyKeWaitForSingleObject( Device, &Device->EventUrb, NULL, 0 );

            if ( ntStatus == STATUS_TIMEOUT )
			{
                DEBUGMSG( DBG_ERR,("CallUSBD () TIMED OUT! return from IoCallDriver USBD %x\n", ntStatus));
                CancelPendingControlIo( Device, ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb, &Device->EventUrb );
            }
        }

    } 
	else
	{
        DEBUGMSG( DBG_ERR, ("CallUSBD IoCallDriver FAILED(%x)\n",ntStatus));
    }

    DEBUGMSG( DBG_OUT,("CallUSBD () URB status = %x  IRP status = %x\n",
        Urb->UrbHeader.Status, ntStatus ));
done:

    ((PUSB_INFO) Device->pUsbInfo)->IrpSubmitUrb = NULL;


    DEBUGCOND( DBG_ERR, !NT_SUCCESS( ntStatus ), ("exit CallUSBD FAILED (%x)\n", ntStatus));

    DEBUGMSG( DBG_FUNC,(" -CallUSBD\n"));

    return ntStatus;
}


/*****************************************************************************
*
*  Function:   UsbIoCompleteControl
*
*  Synopsis:   General completetion routine just to insure cancel-ability of control calls
*              and keep track of pending irp count
*
*  Arguments:  pUsbDevObj - pointer to the  device object which
*                              completed the irp
*              pIrp          - the irp which was completed by the  device
*                              object
*              Context       - dev ext
*
*  Returns:    STATUS_MORE_PROCESSING_REQUIRED - allows the completion routine
*              (IofCompleteRequest) to stop working on the irp.
*
*  This routine is called (by the io manager) in IRQL DISPATCH_LEVEL.
*
*****************************************************************************/

NTSTATUS
UsbIoCompleteControl(
            IN PDEVICE_OBJECT pUsbDevObj,
            IN PIRP           pIrp,
            IN PVOID          Context
            )
{
    PUSB_DEVICE  device;
    NTSTATUS    status;


    DEBUGMSG(DBG_FUNC, ("+UsbIoCompleteControl\n"));

    //
    // The context given to IoSetCompletionRoutine is simply the the ir
    // device object pointer.
    //

    device = CONTEXT_TO_DEV(Context);


    status = pIrp->IoStatus.Status;

    switch (status)
    {
        case STATUS_SUCCESS:
            DEBUGMSG(DBG_OUT, (" UsbIoCompleteControl STATUS_SUCCESS\n"));
            break; // STATUS_SUCCESS

        case STATUS_TIMEOUT:
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_TIMEOUT\n"));

            break;

        case STATUS_PENDING:
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_PENDING\n"));
            break;

        case STATUS_DEVICE_DATA_ERROR:
        // can get during shutdown
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_DEVICE_DATA_ERROR\n"));

            break;

        case STATUS_UNSUCCESSFUL:
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_UNSUCCESSFUL\n"));

            break;

        case STATUS_INSUFFICIENT_RESOURCES:
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_INSUFFICIENT_RESOURCES\n"));
            break;

        case STATUS_INVALID_PARAMETER:
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_INVALID_PARAMETER\n"));
            break;

        case STATUS_CANCELLED:
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_CANCELLED\n"));
            break;

        case STATUS_DEVICE_NOT_CONNECTED:
        // can get during shutdown
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_DEVICE_NOT_CONNECTED\n"));
            break;

        case STATUS_DEVICE_POWER_FAILURE:
        // can get during shutdown
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl STATUS_DEVICE_POWER_FAILURE\n"));
            break;

        default:
            DEBUGMSG(DBG_ERR, (" UsbIoCompleteControl UNKNOWN WEIRD STATUS = 0x%x, dec %d\n",status,status ));
            //ASSERT( 0 );

            break;
    }


    UsbDecIoCount( device );  //we track pending irp count

    if  ( pIrp == ((PUSB_INFO) device->pUsbInfo)->IrpSubmitUrb ) 
	{
        ASSERT( NULL != ((PUSB_INFO) device->pUsbInfo)->IrpSubmitUrb );

        IoFreeIrp( ((PUSB_INFO) device->pUsbInfo)->IrpSubmitUrb );

        device->StatusControl =  status; // save status because can't use irp after completion routine is hit!
        KeSetEvent(&device->EventUrb, 0, FALSE);  //signal we're done

    }
	else
	{
        DEBUGMSG( DBG_ERR, (" UsbIoCompleteControl UNKNOWN IRP\n"));
        ASSERT( 0 );
    }



    DEBUGCOND(DBG_ERR, !( NT_SUCCESS( status ) ), ("UsbIoCompleteControl BAD status = 0x%x\n", status));

    DEBUGMSG(DBG_FUNC, ("-UsbIoCompleteControl\n"));


    // We return STATUS_MORE_PROCESSING_REQUIRED so that the completion
    // routine (IofCompleteRequest) will stop working on the irp.
    //

    status = STATUS_MORE_PROCESSING_REQUIRED;

    return status;
}

//******************************************************************************
//
// ResetPipe()
//
// This will reset the host pipe to Data0 and should also reset the device
// endpoint to Data0 for Bulk and Interrupt pipes by issuing a Clear_Feature
// Endpoint_Stall to the device endpoint.
//
// Must be called at IRQL PASSIVE_LEVEL
//
//******************************************************************************

NTSTATUS
ResetPipe (
    IN PUSB_DEVICE   Device,
    IN HANDLE Pipe
    )
{
    PURB        urb;
    NTSTATUS    ntStatus;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久嫩草精品久久久久| 日韩精品影音先锋| 精品剧情在线观看| 欧美一区二区免费观在线| 欧美精品一区二区在线观看| 国产精品入口麻豆原神| 午夜精品一区二区三区免费视频| 国产主播一区二区三区| 欧美精品一级二级| 国产精品日产欧美久久久久| 免费一区二区视频| 国产成人精品亚洲午夜麻豆| 欧美男生操女生| 中文字幕在线免费不卡| 蜜臀av在线播放一区二区三区| 成人精品视频网站| 精品三级在线看| 天堂一区二区在线| 成人午夜看片网址| 久久精品视频免费| 韩国三级在线一区| 欧美一卡二卡在线| 午夜精品久久久久| 欧美日韩国产美| 亚洲国产另类av| 欧美在线免费观看亚洲| 亚洲欧美电影一区二区| 成人国产精品免费观看动漫| 2023国产精品自拍| 九九久久精品视频| 26uuu久久综合| 理论片日本一区| 日韩亚洲国产中文字幕欧美| 日本美女视频一区二区| 欧美视频中文字幕| 亚洲国产精品久久不卡毛片 | 精品电影一区二区三区| 天天综合色天天综合| 欧美在线|欧美| 亚洲国产三级在线| 欧美怡红院视频| 亚洲成人免费看| 在线成人高清不卡| 奇米888四色在线精品| 日韩欧美激情四射| 国产麻豆精品在线| 亚洲欧美日韩国产手机在线| 粉嫩嫩av羞羞动漫久久久 | 欧美日韩精品一区二区在线播放| 一区二区三区欧美视频| 欧美视频日韩视频| 狂野欧美性猛交blacked| 精品国产伦理网| 成人免费的视频| 一区二区三区在线播| 欧美精品久久99| 韩国三级中文字幕hd久久精品| 国产性做久久久久久| 成人黄色网址在线观看| 亚洲一区在线观看视频| 日韩一区二区不卡| 懂色av一区二区夜夜嗨| 亚洲综合免费观看高清完整版| 欧美日韩黄色影视| 国产激情一区二区三区桃花岛亚洲| 中文字幕av免费专区久久| 色美美综合视频| 日本怡春院一区二区| 欧美激情一区在线观看| 欧美三级电影网| 成人黄色a**站在线观看| 午夜日韩在线电影| 亚洲国产精品ⅴa在线观看| 欧美这里有精品| 国产乱对白刺激视频不卡| 亚洲柠檬福利资源导航| 欧美成人性战久久| 欧美在线观看一区| 国产成人精品亚洲日本在线桃色 | 欧美激情自拍偷拍| 欧美绝品在线观看成人午夜影视| 国产suv精品一区二区883| 三级在线观看一区二区| 中文字幕亚洲电影| 精品少妇一区二区三区在线播放 | 国产99久久久久| 日本欧洲一区二区| 亚洲精品国产品国语在线app| 精品入口麻豆88视频| 在线观看日韩毛片| 成人一区二区三区视频在线观看| 午夜精品福利一区二区三区av| 国产精品免费久久| 久久综合九色综合97婷婷| 欧美日韩日本视频| 99久久精品情趣| 国产精品伊人色| 蜜臀av性久久久久蜜臀aⅴ| 亚洲伊人色欲综合网| 欧美国产丝袜视频| 久久亚洲二区三区| 欧美一级欧美三级| 69堂国产成人免费视频| 欧美综合一区二区| 色婷婷综合中文久久一本| 国产99一区视频免费| 国产一区不卡在线| 狠狠色狠狠色综合| 美腿丝袜亚洲三区| 肉色丝袜一区二区| 亚洲国产欧美日韩另类综合| 亚洲品质自拍视频| 国产精品国产三级国产有无不卡 | 午夜av一区二区三区| 亚洲精品午夜久久久| 中文字幕一区二区三区乱码在线| 国产欧美日韩一区二区三区在线观看| 欧美一二区视频| 日韩免费看网站| 精品少妇一区二区三区在线播放 | 亚洲国产精品精华液ab| 久久精品一区二区| 国产精品区一区二区三| 亚洲国产精品精华液ab| 国产精品久久久久久久久动漫| 国产欧美综合在线观看第十页| 久久人人超碰精品| 中文字幕不卡三区| 亚洲欧美日本韩国| 亚洲福利一区二区| 久久精品久久99精品久久| 国产一区二区在线免费观看| 国产一区二区三区国产| 成人伦理片在线| 91丨九色丨尤物| 精品视频1区2区3区| 日韩一区二区三区四区五区六区| 精品成人佐山爱一区二区| 久久久久久夜精品精品免费| 国产精品视频一二三区| 一区二区三区国产精华| 日韩中文字幕区一区有砖一区| 蜜臀a∨国产成人精品| 国产福利精品一区二区| www.亚洲国产| 欧美日韩精品免费| 欧美成人性福生活免费看| 中文字幕日韩av资源站| 亚洲国产日韩一区二区| 精品亚洲porn| 色琪琪一区二区三区亚洲区| 欧美一级国产精品| 国产精品欧美一区喷水| 五月综合激情网| 99久久久久久| 日韩免费高清视频| 亚洲精品国产第一综合99久久| 日本成人中文字幕在线视频| 国产99久久久精品| 欧美一区二区三区视频在线| 亚洲国产精品传媒在线观看| 亚洲国产一区在线观看| 国产·精品毛片| 7777精品伊人久久久大香线蕉| 国产日本亚洲高清| 日韩高清在线不卡| 99精品国产99久久久久久白柏| 制服丝袜一区二区三区| 亚洲欧洲一区二区在线播放| 日本aⅴ免费视频一区二区三区| 成人免费看黄yyy456| 91精品国产高清一区二区三区| 国产精品激情偷乱一区二区∴| 久久超碰97中文字幕| 欧美视频自拍偷拍| 最新欧美精品一区二区三区| 精品系列免费在线观看| 欧美狂野另类xxxxoooo| 亚洲欧美色图小说| 风间由美性色一区二区三区| 日韩精品一区二区三区在线播放| 亚洲一二三区不卡| 99re在线精品| 国产精品日韩成人| 国产乱码一区二区三区| 日韩精品一区二区三区视频播放| 亚洲午夜私人影院| 91在线一区二区| 中文字幕免费不卡| 91久久人澡人人添人人爽欧美| 久久久久久99久久久精品网站| 日韩黄色小视频| 欧美嫩在线观看| 午夜精品福利在线| 欧美欧美午夜aⅴ在线观看| 亚洲色图另类专区| 色综合天天综合| 玉米视频成人免费看| 91麻豆成人久久精品二区三区| 国产精品热久久久久夜色精品三区|