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

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

?? ioctliso.c

?? 這是ARM9開(kāi)發(fā)板上自帶的USB驅(qū)動(dòng)程序
?? C
字號(hào):
/*++

Copyright (c) 1997-1998  Microsoft Corporation

Module Name:

   ioctliso.c

Abstract:

    USB device driver for Intel 82930 USB test board.
    IOCTL handlers

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"


#include "usbdi.h"
#include "usbdlib.h"
#include "Iso82930.h"

#include "IsoUsb.h"
#include "usbdlib.h"



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

Routine Description:

    Dispatch table handler for IRP_MJ_DEVICE_CONTROL; 
    Handle DeviceIoControl() calls  from User mode


Arguments:

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


Return Value:

    NT status code

--*/
{
    PIO_STACK_LOCATION irpStack;
    PVOID ioBuffer;
    ULONG inputBufferLength;
    ULONG outputBufferLength;
    PDEVICE_EXTENSION deviceExtension;
    ULONG ioControlCode;
    NTSTATUS ntStatus;
    ULONG length;
    PUCHAR pch;
    PUSB_CONFIGURATION_DESCRIPTOR configurationDescriptor;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("IRP_MJ_DEVICE_CONTROL\n"));

    IsoUsb_IncrementIoCount(DeviceObject);

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

    deviceExtension = DeviceObject->DeviceExtension;
    

    // 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 ( !IsoUsb_CanAcceptIoRequests( DeviceObject ) ) {
        ntStatus = STATUS_DELETE_PENDING;
        Irp->IoStatus.Status = ntStatus;
        Irp->IoStatus.Information = 0;

        IoCompleteRequest( Irp, IO_NO_INCREMENT );

        IsoUsb_DecrementIoCount(DeviceObject);                          
        return ntStatus;
    }

    irpStack = IoGetCurrentIrpStackLocation (Irp);

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

    // get pointers and lengths of the caller's (user's) IO buffer
    ioBuffer           = Irp->AssociatedIrp.SystemBuffer;
    inputBufferLength  = irpStack->Parameters.DeviceIoControl.InputBufferLength;
    outputBufferLength = irpStack->Parameters.DeviceIoControl.OutputBufferLength;

    ioControlCode = irpStack->Parameters.DeviceIoControl.IoControlCode;

    //
    // Handle Ioctls from User mode
    //

    switch (ioControlCode) {

    case IOCTL_ISOUSB_RESET_PIPE:
        {
            PUSBD_PIPE_INFORMATION pipe;
	        PFILE_OBJECT fileObject;

		    // get our context and see if it is a pipe
	        fileObject = irpStack->FileObject;

		    pipe = (PUSBD_PIPE_INFORMATION) fileObject->FsContext;    

		    if(pipe == NULL) {
			    // error, this is not a pipe
	            ntStatus =
		            Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
		    } else {            
                IsoUsb_ResetPipe(DeviceObject, pipe, FALSE );
            
                ntStatus = Irp->IoStatus.Status = STATUS_SUCCESS;
            }
        }
        break;


     case IOCTL_ISOUSB_GET_CONFIG_DESCRIPTOR:

        //
        // This api returns a copy of the configuration descriptor
        // and all endpoint/interface descriptors.
        //

        //
        // inputs  - none
        // outputs - configuration descriptor plus interface
        //          and endpoint descriptors
        //

        pch = (PUCHAR) ioBuffer;

        configurationDescriptor =
            deviceExtension->UsbConfigurationDescriptor;

        if (configurationDescriptor) {
            
            length = configurationDescriptor->wTotalLength;

            if ( outputBufferLength < length ) { // make sure caller has big enough buffer to receive
                Irp->IoStatus.Information = 0;

                ntStatus = Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
            }
            else {
                RtlCopyMemory(pch,
                              (PUCHAR) configurationDescriptor,
                              length);

                Irp->IoStatus.Information = length;

                ntStatus = Irp->IoStatus.Status = STATUS_SUCCESS;
            }
        }
        else {

            Irp->IoStatus.Information = 0;

            ntStatus = Irp->IoStatus.Status = STATUS_DEVICE_DATA_ERROR;
        }

        break;

     case IOCTL_ISOUSB_START_ISO_STREAM:

		ntStatus = IsoUsb_StartIsoStream(DeviceObject, Irp);
        break;

    case IOCTL_ISOUSB_STOP_ISO_STREAM:

		ntStatus = IsoUsb_StopIsoStream(DeviceObject,
                        *((PVOID *) ioBuffer), // a PISOUSB_STREAM_OBJECT passed as a blind ptr input buff from user mode
                        Irp);
        break;


     case IOCTL_ISOUSB_RESET_DEVICE:
        
		ntStatus = IsoUsb_ResetDevice( DeviceObject );
        break;               

    default:

        ntStatus =
            Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
    }

    IoCompleteRequest (Irp,
                       IO_NO_INCREMENT
                       );

    IsoUsb_DecrementIoCount(DeviceObject);                       

    return ntStatus;

}




NTSTATUS
IsoUsb_ResetDevice(
    IN PDEVICE_OBJECT DeviceObject
    )
/*++

Routine Description:
	Checks port status; if OK, return success and  do no more;
	If bad, attempt reset

Arguments:

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


Return Value:

    NT status code

--*/
{
    NTSTATUS ntStatus;
    ULONG portStatus;

    ISOUSB_KdPrint(DBGLVL_MEDIUM,("Enter IsoUsb_ResetDevice()\n"));
    
    //
    // Check the port state, if it is disabled we will need 
    // to re-enable it
    //
    ntStatus = IsoUsb_GetPortStatus(DeviceObject, &portStatus);

    if (NT_SUCCESS(ntStatus) && !(portStatus & USBD_PORT_ENABLED) &&
        portStatus & USBD_PORT_CONNECTED) {
        //
        // port is disabled, attempt reset
        //
		ISOUSB_KdPrint( DBGLVL_DEFAULT,("IsoUsb_ResetDevice() will reset\n"));
        ntStatus = IsoUsb_ResetParentPort(DeviceObject);
    }
	return ntStatus;
}



NTSTATUS
IsoUsb_GetPortStatus(
    IN PDEVICE_OBJECT DeviceObject,
    IN PULONG PortStatus
    )
/*++

Routine Description:

    returns the port status for our device

Arguments:

Return Value:

    STATUS_SUCCESS if successful,
    STATUS_UNSUCCESSFUL otherwise

--*/
{
    NTSTATUS ntStatus, status = STATUS_SUCCESS;
    PIRP irp;
    KEVENT event;
    IO_STATUS_BLOCK ioStatus;
    PIO_STACK_LOCATION nextStack;
    PDEVICE_EXTENSION deviceExtension;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("enter IsoUsb_GetPortStatus\n"));

    deviceExtension = DeviceObject->DeviceExtension;

    *PortStatus = 0;

    //
    // issue a synchronous request
    //

    KeInitializeEvent(&event, NotificationEvent, FALSE);

    // IoBuildDeviceIoControlRequest allocates and sets up an IRP for a device control request
    irp = IoBuildDeviceIoControlRequest(
                IOCTL_INTERNAL_USB_GET_PORT_STATUS,
                deviceExtension->TopOfStackDeviceObject, //next-lower driver's device object, representing the target device.
                NULL, // no input or output buffers
                0,
                NULL,
                0,
                TRUE, // internal ( use IRP_MJ_INTERNAL_DEVICE_CONTROL )
                &event, // event to be signalled on completion ( we wait for it below )
                &ioStatus);

    //
    // Call the class driver to perform the operation.  If the returned status
    // is PENDING, wait for the request to complete.
    //

    // 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);
    ISOUSB_ASSERT(nextStack != NULL);

    nextStack->Parameters.Others.Argument1 = PortStatus;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("IsoUsb_GetPortStatus() calling USBD port status api\n"));

    ntStatus = IoCallDriver(deviceExtension->TopOfStackDeviceObject,
                            irp);

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("IsoUsb_GetPortStatus() return from IoCallDriver USBD %x\n", ntStatus));

    if (ntStatus == STATUS_PENDING) {

        ISOUSB_KdPrint( DBGLVL_DEFAULT,("Wait for single object\n"));

        status = KeWaitForSingleObject(
                       &event,
                       Suspended,
                       KernelMode,
                       FALSE,
                       NULL);

        ISOUSB_KdPrint( DBGLVL_DEFAULT,("IsoUsb_GetPortStatus() Wait for single object, returned %x\n", status));
        
    } else {
        ioStatus.Status = ntStatus;
    }

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("IsoUsb_GetPortStatus() Port status = %x\n", *PortStatus));

    //
    // USBD maps the error code for us
    //
    ntStatus = ioStatus.Status;

    ISOUSB_KdPrint( DBGLVL_DEFAULT,("Exit IsoUsb_GetPortStatus (%x)\n", ntStatus));

    return ntStatus;
}


NTSTATUS
IsoUsb_ResetParentPort(
    IN IN PDEVICE_OBJECT DeviceObject
    )
/*++

Routine Description:

    Reset the our parent port

Arguments:

Return Value:

    STATUS_SUCCESS if successful,
    STATUS_UNSUCCESSFUL otherwise

--*/
{
    NTSTATUS ntStatus, status = STATUS_SUCCESS;
    PIRP irp;
    KEVENT event;
    IO_STATUS_BLOCK ioStatus;
    PIO_STACK_LOCATION nextStack;
    PDEVICE_EXTENSION deviceExtension;

    ISOUSB_KdPrint( DBGLVL_HIGH,("enter IsoUsb_ResetParentPort\n"));

    deviceExtension = DeviceObject->DeviceExtension;

    //
    // issue a synchronous request
    //

    KeInitializeEvent(&event, NotificationEvent, FALSE);

    irp = IoBuildDeviceIoControlRequest(
                IOCTL_INTERNAL_USB_RESET_PORT,
                deviceExtension->TopOfStackDeviceObject,
                NULL,
                0,
                NULL,
                0,
                TRUE, // internal ( use IRP_MJ_INTERNAL_DEVICE_CONTROL )
                &event,
                &ioStatus);

    //
    // Call the class driver to perform the operation.  If the returned status
    // is PENDING, wait for the request to complete.
    //

    nextStack = IoGetNextIrpStackLocation(irp);
    ISOUSB_ASSERT(nextStack != NULL);

    ISOUSB_KdPrint( DBGLVL_HIGH,("IsoUsb_ResetParentPort() calling USBD enable port api\n"));

    ntStatus = IoCallDriver(deviceExtension->TopOfStackDeviceObject,
                            irp);
                            
    ISOUSB_KdPrint( DBGLVL_HIGH,("IsoUsb_ResetParentPort() return from IoCallDriver USBD %x\n", ntStatus));

    if (ntStatus == STATUS_PENDING) {

        ISOUSB_KdPrint( DBGLVL_HIGH,("IsoUsb_ResetParentPort() Wait for single object\n"));

        status = KeWaitForSingleObject(
                       &event,
                       Suspended,
                       KernelMode,
                       FALSE,
                       NULL);

        ISOUSB_KdPrint( DBGLVL_HIGH,("IsoUsb_ResetParentPort() Wait for single object, returned %x\n", status));
        
    } else {
        ioStatus.Status = ntStatus;
    }

    //
    // USBD maps the error code for us
    //
    ntStatus = ioStatus.Status;

    ISOUSB_KdPrint( DBGLVL_HIGH,("Exit IsoUsb_ResetPort (%x)\n", ntStatus));

    return ntStatus;
}





?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美中文一区二区| 精品国产乱码久久久久久1区2区| 色综合天天综合网天天狠天天| 欧美日韩免费高清一区色橹橹| 91麻豆精品国产综合久久久久久 | 久久99国产精品成人| 国产v综合v亚洲欧| 91精品啪在线观看国产60岁| 中文字幕乱码亚洲精品一区| 亚洲大片精品永久免费| 成人国产一区二区三区精品| 欧美男女性生活在线直播观看| 国产视频一区二区三区在线观看| 一区二区三区在线影院| 激情五月激情综合网| 欧美日韩一二三区| 欧美国产成人在线| 久久精品国产一区二区三| 一本久道久久综合中文字幕| 久久久久久久国产精品影院| 免费成人av在线| 色老汉av一区二区三区| 国产午夜精品美女毛片视频| 日本麻豆一区二区三区视频| 日本高清视频一区二区| 久久久国际精品| 久久不见久久见免费视频7| 欧美视频日韩视频在线观看| 国产欧美精品一区| 久久丁香综合五月国产三级网站| 一本色道久久综合精品竹菊| 国产午夜精品福利| 精品在线观看免费| 51精品秘密在线观看| 亚洲精品福利视频网站| 色婷婷综合久久久久中文| 亚洲欧洲综合另类在线| 国产成人日日夜夜| 精品久久久久av影院| 美女性感视频久久| 日韩欧美精品三级| 国产在线看一区| 日韩欧美国产一区在线观看| 日韩国产欧美在线视频| 欧美色精品天天在线观看视频| 亚洲精品福利视频网站| 色一情一乱一乱一91av| 亚洲精品欧美综合四区| 91在线观看地址| 亚洲欧美另类久久久精品| 色综合天天综合| 亚洲综合成人在线| 欧美性色黄大片手机版| 婷婷中文字幕综合| 日韩网站在线看片你懂的| 看电影不卡的网站| 日韩精品中文字幕一区| 久久国产剧场电影| 久久精品亚洲一区二区三区浴池| 成人一区二区在线观看| 一区二区三区四区不卡视频 | 3atv一区二区三区| 久久精品国产精品亚洲综合| 久久久www成人免费毛片麻豆| 99久久久久免费精品国产| 亚洲欧美日韩人成在线播放| 欧美精品vⅰdeose4hd| 国产精品羞羞答答xxdd| 一区二区三区在线观看网站| 欧美老女人在线| 国产ts人妖一区二区| 亚洲欧美日韩国产成人精品影院| 欧美理论片在线| 成人黄色综合网站| 日韩中文欧美在线| 中文一区在线播放 | zzijzzij亚洲日本少妇熟睡| 亚洲一区二区综合| 久久先锋影音av鲁色资源| 91行情网站电视在线观看高清版| 日韩激情在线观看| 欧美国产日韩a欧美在线观看| 欧美日韩一级黄| 成人动漫av在线| 日本午夜一区二区| 一区二区在线观看视频在线观看| 日韩亚洲欧美中文三级| 99国产精品久久久久久久久久| 蜜桃视频一区二区三区在线观看| 国产精品女同一区二区三区| 欧美日韩二区三区| k8久久久一区二区三区| 日日摸夜夜添夜夜添亚洲女人| 欧美激情综合在线| 日韩一区国产二区欧美三区| 色老头久久综合| 成人午夜视频在线| 久久se精品一区二区| 亚洲资源在线观看| 国产精品灌醉下药二区| 久久婷婷国产综合精品青草| 欧美人与z0zoxxxx视频| 欧美手机在线视频| 91视频观看免费| 不卡av免费在线观看| 国产精品一区在线| 日韩av电影免费观看高清完整版 | 欧美日韩精品欧美日韩精品 | 国产精品美女久久福利网站| 欧美大黄免费观看| 51精品国自产在线| 欧美日本国产视频| 国产综合色在线视频区| 一区二区视频免费在线观看| 国产精品三级电影| 久久久精品国产免大香伊 | 91丨九色丨黑人外教| 国产乱色国产精品免费视频| 激情偷乱视频一区二区三区| 日韩av高清在线观看| 美女任你摸久久| 蜜臀av性久久久久av蜜臀妖精| 日韩电影在线观看电影| 手机精品视频在线观看| 亚洲香蕉伊在人在线观| 亚洲一区二区三区视频在线| 亚洲高清视频中文字幕| 日本v片在线高清不卡在线观看| 香蕉久久夜色精品国产使用方法| 亚洲成人自拍网| 国内精品不卡在线| 亚洲成av人**亚洲成av**| 丁香激情综合五月| 高清久久久久久| 大胆亚洲人体视频| 91免费看`日韩一区二区| 91成人免费在线视频| 欧美丝袜丝交足nylons| 91精品国产综合久久精品性色| 日韩一区二区三区视频在线观看| 欧美草草影院在线视频| 国产人成一区二区三区影院| 亚洲欧洲无码一区二区三区| 一区二区成人在线视频| 奇米一区二区三区| 国产成人精品午夜视频免费| 99久久久久久99| 欧美精品aⅴ在线视频| 欧美精品一区二区精品网| 国产精品三级在线观看| 亚洲午夜激情网站| 精品午夜久久福利影院| av动漫一区二区| 欧美一区二区高清| 中文字幕av在线一区二区三区| 一区二区三区在线视频播放| 蜜臀va亚洲va欧美va天堂| 亚洲高清免费视频| 老司机精品视频导航| 久久不见久久见中文字幕免费| 国产一区二区三区免费看| 91丨九色丨国产丨porny| 6080午夜不卡| 国产精品久久久久久久久搜平片| 亚洲成人资源网| 成人一区二区三区在线观看| 欧美羞羞免费网站| 中文字幕av资源一区| 日韩电影免费在线看| 99国内精品久久| 欧美xxx久久| 亚洲综合在线第一页| 国产91高潮流白浆在线麻豆| 欧美一区二区三区免费大片| 国产精品免费视频网站| 久久国产精品色| 欧美日韩一二区| 亚洲私人黄色宅男| 国产乱码精品一品二品| 欧美一级夜夜爽| 亚洲卡通欧美制服中文| 懂色一区二区三区免费观看| 欧美一卡2卡3卡4卡| 五月综合激情网| 欧美羞羞免费网站| 成人免费在线视频| 国产精品77777| 精品久久国产97色综合| 亚洲成人在线免费| 在线看国产一区| 中文字幕一区日韩精品欧美| 国产成人三级在线观看| 久久久综合九色合综国产精品| 日韩成人午夜电影| 欧美精品 日韩| 午夜影院久久久| 欧美日高清视频| 亚洲成人自拍偷拍| 欧美老人xxxx18| 日韩精品亚洲专区|