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

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

?? ioctliso.c

?? Pc板與DNW的USB驅動
?? C
字號:
/*++

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;
}





?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区小说| 国内成人精品2018免费看| 人人狠狠综合久久亚洲| 丁香婷婷深情五月亚洲| 欧美男人的天堂一二区| 亚洲国产精品成人综合| 青椒成人免费视频| 在线亚洲+欧美+日本专区| 国产无人区一区二区三区| 日韩电影免费在线观看网站| 99亚偷拍自图区亚洲| ww久久中文字幕| 美女爽到高潮91| 欧美日韩国产精品成人| 亚洲色图视频网| 成人免费视频caoporn| 亚洲精品一区二区三区精华液| 亚洲国产成人av网| 91免费看片在线观看| 国产校园另类小说区| 韩国欧美国产一区| 精品日韩99亚洲| 精品综合免费视频观看| 欧美一区二区三区喷汁尤物| 亚洲va欧美va人人爽午夜| 色国产精品一区在线观看| 国产精品国产自产拍高清av王其| 国产一区二区三区黄视频| 精品av久久707| 激情另类小说区图片区视频区| 欧美一区二区三区日韩视频| 香港成人在线视频| 欧美美女喷水视频| 亚洲二区在线视频| 欧美理论电影在线| 亚洲1区2区3区4区| 欧美一区二区在线免费播放| 蜜臀av性久久久久蜜臀aⅴ| 欧美一区二区三区四区在线观看 | 午夜精品久久久久| 欧美三级一区二区| 五月天网站亚洲| 欧美一区二区三区视频免费播放| 蜜桃视频在线观看一区| 欧美mv和日韩mv的网站| 国产福利91精品一区| 国产精品免费免费| 欧洲色大大久久| 日本美女一区二区三区视频| 精品久久一区二区| eeuss鲁片一区二区三区 | 欧美成人官网二区| 国产老妇另类xxxxx| 亚洲视频一区二区在线观看| 欧洲激情一区二区| 极品少妇一区二区| 中文无字幕一区二区三区 | 亚洲美女免费视频| 3751色影院一区二区三区| 精品无码三级在线观看视频| 国产亚洲1区2区3区| 在线免费观看一区| 久久精品国产一区二区| 综合久久久久综合| 日韩欧美国产综合| 97久久超碰国产精品| 偷窥国产亚洲免费视频| 国产女人18毛片水真多成人如厕| 日本高清不卡一区| 国产麻豆欧美日韩一区| 亚洲一区二区三区爽爽爽爽爽| 日韩午夜小视频| 91浏览器在线视频| 国产美女视频一区| 午夜免费久久看| 久久精品男人的天堂| 4438x成人网最大色成网站| 99re免费视频精品全部| 毛片一区二区三区| 亚洲一区二区三区中文字幕 | 欧美久久久久久久久| 国产电影一区在线| 日韩激情中文字幕| 一区精品在线播放| 久久综合网色—综合色88| 91高清视频免费看| 成人激情免费视频| 精品一二三四区| 视频一区欧美精品| 亚洲你懂的在线视频| 亚洲欧美日韩中文字幕一区二区三区| 欧美午夜一区二区三区免费大片| 国产麻豆精品一区二区| 日本免费新一区视频| 亚洲一区日韩精品中文字幕| 中文文精品字幕一区二区| 精品久久久久久久人人人人传媒 | 精品日韩欧美一区二区| 欧美日韩极品在线观看一区| 99re视频精品| av网站免费线看精品| 国产高清在线精品| 国产中文一区二区三区| 美腿丝袜亚洲色图| 青青草伊人久久| 日韩精品成人一区二区三区| 偷拍与自拍一区| 亚洲妇女屁股眼交7| 亚洲一区在线播放| 亚洲影视在线播放| 亚洲成人av一区| 亚洲超碰97人人做人人爱| 亚洲线精品一区二区三区 | 午夜精品久久久久久久蜜桃app| 亚洲男人的天堂一区二区| 中文字幕亚洲欧美在线不卡| 国产精品天美传媒| 最新国产の精品合集bt伙计| 中文字幕一区二区在线观看| 成人免费小视频| 亚洲精品视频在线观看免费| 一区二区三区在线不卡| 性欧美疯狂xxxxbbbb| 日韩电影免费在线观看网站| 久草这里只有精品视频| 国内精品伊人久久久久av一坑| 国产一区二区三区四| 国产成人在线观看| 91香蕉视频mp4| 欧美中文字幕亚洲一区二区va在线| 欧美体内she精高潮| 91精品综合久久久久久| 精品久久久久久无| 一区精品在线播放| 五月天丁香久久| 精品一二三四区| 99久久精品免费看国产| 欧美日免费三级在线| 欧美电影免费观看高清完整版在| 国产欧美一区二区三区鸳鸯浴| 国产精品高潮久久久久无| 午夜影院久久久| 极品销魂美女一区二区三区| 99久久精品费精品国产一区二区| 欧美色国产精品| 久久亚洲综合av| 亚洲一区二区三区精品在线| 开心九九激情九九欧美日韩精美视频电影| 国产一区二区不卡| 在线精品亚洲一区二区不卡| 精品国产一区二区三区不卡| 最新热久久免费视频| 天天综合天天综合色| 国产成人免费视频网站| 色av成人天堂桃色av| 26uuu欧美日本| 亚洲最新在线观看| 国产成人精品影视| 欧美日韩精品久久久| 国产精品网站一区| 蜜桃一区二区三区在线观看| a级精品国产片在线观看| 欧美一二三区在线| 亚洲精品日韩专区silk| 国产一区二区三区免费看 | 亚洲成在人线在线播放| 国产91富婆露脸刺激对白| 欧美军同video69gay| 最新久久zyz资源站| 国产在线播放一区| 欧美日韩国产片| 亚洲欧洲无码一区二区三区| 国模套图日韩精品一区二区 | 欧美va天堂va视频va在线| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 91视频观看视频| 欧美精品一区二区在线观看| 亚洲国产精品久久不卡毛片| 成人av网址在线| 久久综合久久综合亚洲| 日韩专区在线视频| 色94色欧美sute亚洲线路二 | www.欧美.com| 欧美国产欧美综合| 激情综合色丁香一区二区| 在线播放中文字幕一区| 亚洲综合自拍偷拍| 91免费观看国产| 日韩美女精品在线| 国产成人小视频| 国产午夜精品在线观看| 久久se精品一区精品二区| 91精品国产一区二区三区蜜臀| 亚洲一二三四区不卡| 在线看日韩精品电影| 亚洲一区在线观看视频| 欧美偷拍一区二区| 亚洲成av人**亚洲成av**| 欧美日韩一区二区欧美激情| 亚洲伊人伊色伊影伊综合网|