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

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

?? usbfx2lk_devctrl.cpp

?? VisualC++寫的一個USB的驅動程序。
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
///////////////////////////////////////////////////////////////////////////////
//
//    (C) Copyright 2005 OSR Open Systems Resources, Inc.
//    All Rights Reserved
//
//    This sofware is supplied for instructional purposes only.
//
//    OSR Open Systems Resources, Inc. (OSR) expressly disclaims any warranty
//    for this software.  THIS SOFTWARE IS PROVIDED  "AS IS" WITHOUT WARRANTY
//    OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION,
//    THE IMPLIED WARRANTIES OF MECHANTABILITY OR FITNESS FOR A PARTICULAR
//    PURPOSE.  THE ENTIRE RISK ARISING FROM THE USE OF THIS SOFTWARE REMAINS
//    WITH YOU.  OSR's entire liability and your exclusive remedy shall not
//    exceed the price paid for this material.  In no event shall OSR or its
//    suppliers be liable for any damages whatsoever (including, without
//    limitation, damages for loss of business profit, business interruption,
//    loss of business information, or any other pecuniary loss) arising out
//    of the use or inability to use this software, even if OSR has been
//    advised of the possibility of such damages.  Because some states/
//    jurisdictions do not allow the exclusion or limitation of liability for
//    consequential or incidental damages, the above limitation may not apply
//    to you.
//
//    OSR Open Systems Resources, Inc.
//    105 Route 101A Suite 19
//    Amherst, NH 03031  (603) 595-6500 FAX: (603) 595-6503
//    email bugs to: bugs@osr.com
//
//
//    MODULE:
//
//      USBFx2LK_DevCtrl.cpp
//
//    ABSTRACT:
//
//      This file contains the routines that handle IRP_MJ_DEVICE_CONTROL processing for the 
//      OSR USB FX2 Learning Kit Device
//
//    AUTHOR(S):
//
//      OSR Open Systems Resources, Inc.
// 
///////////////////////////////////////////////////////////////////////////////
#include "usbfx2lk.h"

#ifdef WPP_TRACING
//
// Include the necessary tmh file - this is 
//  just a matter of course if you're using WPP tracing.
//
extern "C" {
#include "usbfx2lk_devctrl.tmh"
}
#endif

//
// Forward declarations
//
static LPCSTR   IoctlToString(ULONG Ioctl);

///////////////////////////////////////////////////////////////////////////////
//
// UsbFx2LkDeviceControl
//
//  This routine is called by the IO Manager to process a IRP_MJ_DEVICE_CONTROL
//  Irp.
//
//
//  INPUTS:
//
//      DeviceObject  -  One of our Device Objects.
//      Irp  -  The Irp to process.
//
//  OUTPUTS:
//
//      None
//
//  RETURNS:
//
//      None
//
//  IRQL:
//
//      IRQL == PASSIVE_LEVEL
//
//  CONTEXT:
//
//      User Context
//
//  NOTES:
//
///////////////////////////////////////////////////////////////////////////////
NTSTATUS UsbFx2LkDeviceControl(PDEVICE_OBJECT DeviceObject,PIRP Irp)
{
    PIO_STACK_LOCATION ioStack = IoGetCurrentIrpStackLocation(Irp);
    PUSBFX2LK_EXT devExt = (PUSBFX2LK_EXT)DeviceObject->DeviceExtension;
    ULONG ioctl;
    NTSTATUS status = STATUS_UNSUCCESSFUL;
    ULONG inputBufferLength;
    ULONG outputBufferLength;
    ULONG bytesReturned;
    KIRQL oldIrql;

    OsrTracePrint(TRACE_LEVEL_VERBOSE,OSRDBG_IOCTL_INFO,("UsbFx2LkDeviceControl: Entered\n"));

    //
    // We treat this routine as pageable
    //
    PAGED_CODE();

    //
    // Increment the count of outstanding IOs.
    //
    OsrIncrementOutstandingIoCount(devExt,__FILE__,__LINE__);

    //
    // See what sort of state we're in. 
    //
    KeAcquireSpinLock(&devExt->IoStateLock,&oldIrql);
    if (devExt->DevicePnPState < STATE_ALL_BELOW_FAIL) {

        KeReleaseSpinLock(&devExt->IoStateLock,oldIrql);
        OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                ("UsbFx2LkDeviceControl: Failing  request due to Pnp State! Current PnP state - %s\n",
                  OsrPrintState(devExt)));

        Irp->IoStatus.Status = STATUS_INVALID_DEVICE_STATE;
        Irp->IoStatus.Information = 0;
        IoCompleteRequest(Irp, IO_NO_INCREMENT);

        //
        // We're done with this request
        //
        OsrDecrementOutstandingIoCount(devExt,__FILE__,__LINE__);
        return STATUS_INVALID_DEVICE_STATE;

    }
    KeReleaseSpinLock(&devExt->IoStateLock,oldIrql);

    //
    // See which IOCTL the caller has sent us
    //
    ioctl = ioStack->Parameters.DeviceIoControl.IoControlCode;

    //
    // And get the buffer lengths.
    //
    inputBufferLength  = ioStack->Parameters.DeviceIoControl.InputBufferLength;
    outputBufferLength = ioStack->Parameters.DeviceIoControl.OutputBufferLength;
        

    OsrTracePrint(TRACE_LEVEL_INFORMATION,OSRDBG_IOCTL_INFO, ("UsbFx2LkDeviceControl: Entered with IRP: 0x%p, IOCTL: 0x%x (%s)\n", 
        Irp, ioctl, IoctlToString(ioctl)));

    switch (ioctl) {

        case IOCTL_OSRUSBFX2_GET_BAR_GRAPH_DISPLAY: {

            //
            // This IOCTL doesn't use an input
            //  buffer. Make sure that the caller knows that
            //  and is playing by the rules.
            //
            if (inputBufferLength) {

                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User passed an input buffer - Incorrect usage for this IOCTL\n"));

                status = STATUS_INVALID_PARAMETER;
                bytesReturned = 0;
                break;

            }

            //
            // Make sure the caller's output buffer is large enough
            //  to hold the state of the bar graph
            //
            if (outputBufferLength < sizeof(BAR_GRAPH_STATE)) {

                //
                // Let the user know how big the buffer was
                //  supposed to be
                //
                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User's output buffer is too small for this IOCTL, expecting an BAR_GRAPH_STATE\n"));

                status = STATUS_BUFFER_TOO_SMALL;
                bytesReturned = sizeof(BAR_GRAPH_STATE);
                break;

            }


            //
            // Post the IRP off to the get bar graph code. 
            //  This request may pend while the device powers up,
            //  so just return whatever SubmitGetBarGraphState
            //  returns to us and don't touch the IRP
            //
            status = SubmitGetBarGraphState(devExt, Irp);

            OsrTracePrint(TRACE_LEVEL_INFORMATION,OSRDBG_SELECTIVE_SUSPEND,
               ("UsbFx2LkDeviceControl: SubmitGetBarGraphState returned "\
                                                    "0x%x (%s). Exiting...\n",
                status,OsrNtStatusToString(status)));


            return status;
        }
        case IOCTL_OSRUSBFX2_SET_BAR_GRAPH_DISPLAY: {

            //
            // This IOCTL doesn't use an output
            //  buffer. Make sure that the caller knows that
            //  and is playing by the rules.
            //
            if (outputBufferLength) {

                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User passed an output buffer - Incorrect usage for this IOCTL\n"));

                status = STATUS_INVALID_PARAMETER;
                bytesReturned = 0;
                break;

            }

            //
            // Make sure the caller's input buffer is of the right size
            //
            if (inputBufferLength < sizeof(BAR_GRAPH_STATE)) {

                //
                // Let the user know how big the buffer was
                //  supposed to be
                //
                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User's input buffer is too small for this IOCTL, expecting an BAR_GRAPH_STATE\n"));

                status = STATUS_BUFFER_TOO_SMALL;
                bytesReturned = sizeof(BAR_GRAPH_STATE);
                break;

            }

            //
            // Post the IRP off to the set bar graph code. 
            //  This request may pend while the device powers up,
            //  so just return whatever SubmitSetBarGraphState
            //  returns to us and don't touch the IRP
            //
            status = SubmitSetBarGraphState(devExt, Irp);

            OsrTracePrint(TRACE_LEVEL_INFORMATION,OSRDBG_SELECTIVE_SUSPEND,
               ("UsbFx2LkDeviceControl: SubmitSetBarGraphState returned "\
                                                    "0x%x (%s). Exiting...\n",
                status,OsrNtStatusToString(status)));

            return status;

        }
        case IOCTL_OSRUSBFX2_GET_7_SEGMENT_DISPLAY: {

            //
            // This IOCTL doesn't use an input
            //  buffer. Make sure that the caller knows that
            //  and is playing by the rules.
            //
            if (inputBufferLength) {

                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User passed an input buffer - Incorrect usage for this IOCTL\n"));

                status = STATUS_INVALID_PARAMETER;
                bytesReturned = 0;
                break;

            }

            //
            // Make sure the caller's output buffer is large enough
            //  to hold the state of the 7 segment
            //
            if (outputBufferLength < sizeof(UCHAR)) {

                //
                // Let the user know how big the buffer was
                //  supposed to be
                //
                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User's output buffer is too small for this IOCTL, expecting an UCHAR\n"));

                status = STATUS_BUFFER_TOO_SMALL;
                bytesReturned = sizeof(UCHAR);
                break;

            }

            //
            // Post the IRP off to the get seven segment code. 
            //  This request may pend while the device powers up,
            //  so just return whatever SubmitGetSevenSegmentState
            //  returns to us and don't touch the IRP
            //
            status = SubmitGetSevenSegmentState(devExt, Irp);

            OsrTracePrint(TRACE_LEVEL_INFORMATION,OSRDBG_SELECTIVE_SUSPEND,
               ("UsbFx2LkDeviceControl: SubmitGetSevenSegmentState returned "\
                                                    "0x%x (%s). Exiting...\n",
                status,OsrNtStatusToString(status)));

            return status;

        }
        case IOCTL_OSRUSBFX2_SET_7_SEGMENT_DISPLAY: {

            //
            // This IOCTL doesn't use an output
            //  buffer. Make sure that the caller knows that
            //  and is playing by the rules.
            //
            if (outputBufferLength) {

                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User passed an output buffer - Incorrect usage for this IOCTL\n"));

                status = STATUS_INVALID_PARAMETER;
                bytesReturned = 0;
                break;

            }

            //
            // Make sure the caller's input buffer is of the right size
            //
            if (inputBufferLength < sizeof(UCHAR)) {

                //
                // Let the user know how big the buffer was
                //  supposed to be
                //
                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User's input buffer is too small for this IOCTL, expecting an UCHAR\n"));

                status = STATUS_BUFFER_TOO_SMALL;
                bytesReturned = sizeof(UCHAR);
                break;

            }

            //
            // Post the IRP off to the set seven segment code. 
            //  This request may pend while the device powers up,
            //  so just return whatever SubmitSetSevenSegmentState
            //  returns to us and don't touch the IRP
            //
            status = SubmitSetSevenSegmentState(devExt, Irp);

            OsrTracePrint(TRACE_LEVEL_INFORMATION,OSRDBG_SELECTIVE_SUSPEND,
               ("UsbFx2LkDeviceControl: SubmitSetSevenSegmentState returned "\
                                                    "0x%x (%s). Exiting...\n",
                status,OsrNtStatusToString(status)));

            return status;
        }
        case IOCTL_OSRUSBFX2_READ_SWITCHES: {


            //
            // This IOCTL doesn't use an input
            //  buffer. Make sure that the caller knows that
            //  and is playing by the rules.
            //
            if (inputBufferLength) {

                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User passed an input buffer - Incorrect usage for this IOCTL\n"));

                status = STATUS_INVALID_PARAMETER;
                bytesReturned = 0;
                break;

            }

            //
            // Make sure the caller's output buffer is large enough
            //  to hold the state of the switches
            //
            if (outputBufferLength < sizeof(SWITCH_STATE)) {

                //
                // Let the user know how big the buffer was
                //  supposed to be
                //
                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User's output buffer is too small for this IOCTL, expecting a SWITCH_STATE\n"));

                status = STATUS_BUFFER_TOO_SMALL;
                bytesReturned = sizeof(SWITCH_STATE);
                break;

            }

            //
            // Post the IRP off to the get switch state code. 
            //  This request may pend while the device powers up,
            //  so just return whatever SubmitGetSwitchState
            //  returns to us and don't touch the IRP
            //
            status = SubmitGetSwitchState(devExt, Irp);

            OsrTracePrint(TRACE_LEVEL_INFORMATION,OSRDBG_SELECTIVE_SUSPEND,
               ("UsbFx2LkDeviceControl: SubmitGetSwitchState returned "\
                                                    "0x%x (%s). Exiting...\n",
                status,OsrNtStatusToString(status)));

            return status;

        }
        case IOCTL_OSRUSBFX2_RESET_PIPE: {

            USBFX2_PIPE_ENUM whichPipe;

            //
            // This IOCTL uses no output  buffer. Make sure 
            //  that the caller knows that and is playing by the rules.
            //
            if (outputBufferLength) {

                OsrTracePrint(TRACE_LEVEL_ERROR,OSRDBG_IOCTL_INFO, 
                    ("UsbFx2LkDeviceControl: User passed an output buffer - Incorrect usage for this IOCTL\n"));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩美女在线视频| 一区二区在线观看不卡| 亚洲综合色噜噜狠狠| 粉嫩久久99精品久久久久久夜| 欧美肥妇bbw| 蜜臀va亚洲va欧美va天堂 | 精品在线亚洲视频| 91.xcao| 亚洲一区电影777| 91精品国产91综合久久蜜臀| 洋洋成人永久网站入口| 一本久久a久久精品亚洲| 国产蜜臀av在线一区二区三区| 亚洲一区二区三区中文字幕| 欧洲国内综合视频| 午夜欧美一区二区三区在线播放| 91成人在线免费观看| 舔着乳尖日韩一区| 久久久久国色av免费看影院| 国产一区二区三区综合| 日韩一区二区三区在线视频| 国产精品99久久久久久久女警| 亚洲婷婷在线视频| 精品99一区二区| 91国产免费观看| 日本一区中文字幕| 亚洲人成在线观看一区二区| 欧美一级一级性生活免费录像| 成人中文字幕合集| caoporn国产一区二区| 午夜久久久影院| 国产午夜亚洲精品羞羞网站| 欧美日韩国产精选| 一本色道a无线码一区v| 国产在线精品免费| 天天做天天摸天天爽国产一区| 国产区在线观看成人精品| 欧美欧美欧美欧美首页| 91在线小视频| 成人性色生活片免费看爆迷你毛片| 偷拍日韩校园综合在线| 亚洲一区二区成人在线观看| 国产精品乱人伦| 日韩欧美一级精品久久| 91极品视觉盛宴| 91蝌蚪porny| 不卡av电影在线播放| 国产成人精品一区二| 韩日av一区二区| 麻豆91免费看| 国产一区二区精品久久99| 蜜桃av一区二区在线观看| 亚洲国产精品久久久久婷婷884 | 国产精品无人区| 久久欧美一区二区| 久久久久久久久久久黄色| 欧美成人精品高清在线播放| 精品美女一区二区| 欧美精品一区二区三区四区| 欧美不卡视频一区| 精品久久久久久综合日本欧美| 久久久久9999亚洲精品| 亚洲精品一线二线三线无人区| 欧美sm极限捆绑bd| 久久午夜电影网| 国产精品久久久爽爽爽麻豆色哟哟| 国产精品美女久久久久久久久久久 | 色吊一区二区三区| 欧美亚洲国产一区二区三区| 99re8在线精品视频免费播放| 97se狠狠狠综合亚洲狠狠| 91麻豆精品国产91久久久更新时间| 精品久久久久久亚洲综合网| 国产精品乱子久久久久| 亚洲欧美另类小说| 久88久久88久久久| 色婷婷精品久久二区二区蜜臂av| 欧美一级搡bbbb搡bbbb| 中文久久乱码一区二区| 亚洲在线成人精品| 狠狠狠色丁香婷婷综合久久五月| 在线一区二区三区四区五区 | 亚洲一区在线播放| 国产精品一区二区三区四区| 欧美午夜精品久久久久久孕妇| 2020国产成人综合网| 亚洲风情在线资源站| av网站免费线看精品| 久久这里只精品最新地址| 亚洲在线免费播放| 91丨九色丨尤物| 欧美激情一区在线观看| 精品一区在线看| 欧美一区二区视频免费观看| 一区二区三区不卡视频| 日本国产一区二区| 亚洲免费视频成人| 91久久人澡人人添人人爽欧美| 日本一区二区三级电影在线观看 | 免费成人你懂的| 欧美视频完全免费看| 欧美激情综合网| 国产乱子伦视频一区二区三区| 日韩欧美色电影| 卡一卡二国产精品| 精品国产免费人成电影在线观看四季| 亚洲国产精品麻豆| 日韩一级免费观看| 国产乱人伦精品一区二区在线观看| 精品免费日韩av| 99精品视频中文字幕| 一区二区三区四区中文字幕| 欧美日韩一级黄| 国产精品一二三区在线| 国产精品久久久久久久久免费丝袜| 免费美女久久99| 日韩欧美国产精品一区| 成人看片黄a免费看在线| 一区二区三区欧美视频| 日韩一区二区三区观看| 精品一区二区三区的国产在线播放| 欧美成人vps| 91小视频在线观看| 麻豆91免费观看| 亚洲综合激情另类小说区| 欧美电影免费观看完整版| 99久久精品免费观看| 精品一区二区三区蜜桃| 亚洲成人在线观看视频| 久久久精品tv| 日韩写真欧美这视频| 日本福利一区二区| 国产精品羞羞答答xxdd| 日韩精品乱码免费| 亚洲欧洲另类国产综合| 精品福利视频一区二区三区| 日本高清免费不卡视频| 99久久精品国产观看| 丁香网亚洲国际| 粗大黑人巨茎大战欧美成人| 日韩 欧美一区二区三区| 亚洲国产一区二区视频| 亚洲视频综合在线| 自拍偷拍欧美激情| 国产精品成人免费| 中文字幕在线观看不卡| 中文字幕的久久| 亚洲天堂av一区| 国产精品电影一区二区| 综合久久久久久久| 尤物在线观看一区| 亚洲午夜精品网| 亚洲 欧美综合在线网络| 一区二区三区四区视频精品免费| 国产精品国产a| 亚洲美女在线国产| 偷窥国产亚洲免费视频 | 精品久久人人做人人爽| 日本一二三不卡| 亚洲美女淫视频| 丝袜亚洲另类欧美综合| 日韩av电影免费观看高清完整版| 奇米精品一区二区三区四区| 狠狠v欧美v日韩v亚洲ⅴ| 成人免费不卡视频| 色天使色偷偷av一区二区| 精品视频一区二区不卡| 亚洲精品在线免费观看视频| 国产欧美日韩视频在线观看| 国产精品国产三级国产| 天天影视涩香欲综合网 | 加勒比av一区二区| 日本欧美韩国一区三区| 成人黄动漫网站免费app| 欧美在线综合视频| 国产日本欧美一区二区| 亚洲一本大道在线| 国产精品99久久久久久有的能看| 精品视频全国免费看| 国产亚洲女人久久久久毛片| 国产精品久久久久久久久图文区| 青青草视频一区| 欧美午夜一区二区三区 | 日韩欧美国产一区在线观看| 亚洲精品中文字幕在线观看| 国产精品一区在线观看你懂的| 91精品久久久久久久久99蜜臂| 久久久精品免费免费| 秋霞电影网一区二区| 欧美在线免费观看亚洲| 久久色在线观看| 蜜桃免费网站一区二区三区 | 午夜精品久久久久久久久久久 | 国产.欧美.日韩| 精品欧美黑人一区二区三区| 日本美女一区二区三区| 欧美亚男人的天堂| 亚洲国产精品精华液网站| 97成人超碰视| 精品国免费一区二区三区|