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

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

?? request.c

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

Copyright (c) 1999  Microsoft Corporation

Module Name:

    request.c  | usb NDIS Miniport Driver

Abstract:

    Query and Set information 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) 1999 Microsoft Corporation.  All Rights Reserved.


Revision History:


--*/
#define BINARY_COMPATIBLE 1 // for win9x compatibility with ndis.h

#define DOBREAKS    // enable debug breaks

#include <ndis.h>
#include <ntddndis.h>  // defines OID's

#include "debug.h"
#include "common.h"
#include "USBNDIS.h"
//
//  These are the OIDs we support 
//


UINT supportedOIDs[] =
{
    //
    // General required OIDs.
    //

    OID_GEN_SUPPORTED_LIST,
    OID_GEN_HARDWARE_STATUS,
    OID_GEN_MEDIA_SUPPORTED,
    OID_GEN_MEDIA_IN_USE,
    OID_GEN_MAXIMUM_LOOKAHEAD,
    OID_GEN_MAXIMUM_FRAME_SIZE,
    OID_GEN_LINK_SPEED,
    OID_GEN_TRANSMIT_BUFFER_SPACE,
    OID_GEN_RECEIVE_BUFFER_SPACE,
    OID_GEN_TRANSMIT_BLOCK_SIZE,
    OID_GEN_RECEIVE_BLOCK_SIZE,
    OID_GEN_VENDOR_ID,
    OID_GEN_VENDOR_DESCRIPTION,
    OID_GEN_CURRENT_PACKET_FILTER,
    OID_GEN_CURRENT_LOOKAHEAD,
    OID_GEN_DRIVER_VERSION,
    OID_GEN_MAXIMUM_TOTAL_SIZE,
    OID_GEN_PROTOCOL_OPTIONS,
    OID_GEN_MAC_OPTIONS,
    OID_GEN_MEDIA_CONNECT_STATUS,
    OID_GEN_MAXIMUM_SEND_PACKETS,
    OID_GEN_VENDOR_DRIVER_VERSION,

    //
    // Required statistical OIDs.
    //

    OID_GEN_XMIT_OK,
    OID_GEN_RCV_OK,
    OID_GEN_XMIT_ERROR,
    OID_GEN_RCV_ERROR,
    OID_GEN_RCV_NO_BUFFER,


    OID_PNP_CAPABILITIES/*,
    OID_PNP_SET_POWER,  
    OID_PNP_QUERY_POWER,
    OID_PNP_ENABLE_WAKE_UP
    OID_PNP_ADD_WAKE_UP_PATTERN        
    OID_PNP_REMOVE_WAKE_UP_PATTERN    
    OID_PNP_WAKE_UP_PATTERN_LIST    
    OID_PNP_WAKE_UP_OK        
    OID_PNP_WAKE_UP_ERROR    */

}; 



//
//    PnP and PM OIDs
//

#define    OID_PNP_CAPABILITIES                    0xFD010100
#define    OID_PNP_SET_POWER                        0xFD010101
#define    OID_PNP_QUERY_POWER                        0xFD010102
#define OID_PNP_ADD_WAKE_UP_PATTERN                0xFD010103
#define OID_PNP_REMOVE_WAKE_UP_PATTERN            0xFD010104
#define    OID_PNP_WAKE_UP_PATTERN_LIST            0xFD010105
#define    OID_PNP_ENABLE_WAKE_UP                    0xFD010106

//
//    PnP/PM Statistics (Optional).
//
#define    OID_PNP_WAKE_UP_OK                        0xFD020200
#define    OID_PNP_WAKE_UP_ERROR                    0xFD020201







/*****************************************************************************
*
*  Function:   MiniportQueryInformation
*
*  Synopsis:   Queries the capabilities and status of the miniport driver.
*
*  Arguments:  MiniportAdapterContext  - miniport context area (PUSB_DEVICE)
*              Oid                     - system defined OID_Xxx
*              InformationBuffer       - where to return Oid specific info
*              InformationBufferLength - specifies size of InformationBuffer
*              BytesWritten            - bytes written to InformationBuffer
*              BytesNeeded             - addition bytes required if
*                                        InformationBufferLength is less than
*                                        what the Oid requires to write
*
*  Returns:    NDIS_STATUS_SUCCESS       - success
*              NDIS_STATUS_PENDING       - will complete asynchronously and
*                                          call NdisMQueryInformationComplete
*              NDIS_STATUS_INVALID_OID   - don't recognize the Oid
*              NDIS_STATUS_INVALID_LENGTH- InformationBufferLength does not
*                                          match length for the Oid
*              NDIS_STATUS_NOT_ACCEPTED  - failure
*              NDIS_STATUS_NOT_SUPPORTED - do not support an optional Oid
*              NDIS_STATUS_RESOURCES     - failed allocation of resources
*
*  Notes:
*       See list of Supported OIDs at the top of this module in the supportedOIDs[] array
*
*
*****************************************************************************/

NDIS_STATUS
MiniportQueryInformation(
            IN  NDIS_HANDLE MiniportAdapterContext,
            IN  NDIS_OID    Oid,
            IN  PVOID       InformationBuffer,
            IN  ULONG       InformationBufferLength,
            OUT PULONG      BytesWritten,
            OUT PULONG      BytesNeeded
            )
{
    PUSB_DEVICE      device;
    NDIS_STATUS     status;
    UINT            speeds;
    UINT            i;
    UINT            infoSizeNeeded;
    UINT            *infoPtr;
    ULONG           OidCategory = Oid & 0xFF000000;
    BOOLEAN            fBusy;

    static char vendorDesc[] = "Usb Infrared Port";

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

    device = CONTEXT_TO_DEV(MiniportAdapterContext);

    ASSERT( NULL != device ); 
    ASSERT( NULL != BytesWritten );
    ASSERT( NULL != BytesNeeded );

    status = NDIS_STATUS_SUCCESS;

    NdisGetCurrentSystemTime( &device->LastQueryTime ); //used by check for hang handler
    device->fQuerypending = TRUE;

    //DUMP_STATS_SEC( device, 180 ); // dump statistics every n seconds if debugging

    if ( NULL == InformationBuffer && InformationBufferLength > 0 ) { // Should be impossible but it happened on an MP system!

        DEBUGMSG(DBG_ERR, ("    MiniportQueryInformation() NULL info buffer passed!,InformationBufferLength = dec %d\n",InformationBufferLength));
        status = NDIS_STATUS_NOT_ACCEPTED;
        *BytesNeeded =0;
        *BytesWritten = 0;
        goto done;
 
    }


    //
    // Figure out buffer size needed.
    // Most OIDs just return a single UINT, but there are exceptions.
    //

    switch (Oid)
    {
        case OID_GEN_SUPPORTED_LIST:
            infoSizeNeeded = sizeof(supportedOIDs);

            break;
        case OID_PNP_CAPABILITIES:
            infoSizeNeeded = sizeof(NDIS_PNP_CAPABILITIES);
            break;

        case OID_GEN_DRIVER_VERSION:
            infoSizeNeeded = sizeof(USHORT);

            break;

        case OID_GEN_VENDOR_DESCRIPTION:
            infoSizeNeeded = sizeof(vendorDesc);

            break;

        default:
            infoSizeNeeded = sizeof(UINT);

            break;
    }

    //
    // If the protocol provided a large enough buffer, we can go ahead
    // and complete the query.
    //

    if (InformationBufferLength >= infoSizeNeeded)
    {
        //
        // Set default results.
        //

        *BytesWritten = infoSizeNeeded;
        *BytesNeeded = 0;

        switch (Oid)
        {
            //
            // Generic OIDs.
            //

            case OID_GEN_SUPPORTED_LIST:
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_SUPPORTED_LIST)\n"));
/*
                Specifies an array of OIDs for objects that the underlying
                 driver or its device supports. Objects include general, media-specific,
                 and implementation-specific objects.

                The underlying driver should order the OID list it returns 
                in increasing numeric order. NDIS forwards a subset of the returned 
                list to protocols that make this query. That is, NDIS filters
                any supported statistics OIDs out of the list since protocols
                never make statistics queries subsequentlly. 

*/
                NdisMoveMemory(
                            InformationBuffer,
                            (PVOID)supportedOIDs,
                            sizeof(supportedOIDs)
                            );

                break;

            case OID_GEN_HARDWARE_STATUS:
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_HARDWARE_STATUS)\n"));

                //
                // If we can be called with a context, then we are
                // initialized and ready.
                //

                *(UINT *)InformationBuffer = NdisHardwareStatusReady;

                break;

            case OID_GEN_MEDIA_SUPPORTED:
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_MEDIA_SUPPORTED)\n"));

                *(UINT *)InformationBuffer = NdisMedium802_3;

                break;

            case OID_GEN_MEDIA_IN_USE:
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_MEDIA_IN_USE)\n"));

                *(UINT *)InformationBuffer = NdisMedium802_3;

                break;

            case OID_GEN_TRANSMIT_BUFFER_SPACE: 
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_TRANSMIT_BUFFER_SPACE)\n"));
/*
                The amount of memory, in bytes, on the device available 
                for buffering transmit data.  

*/
                *(UINT *)InformationBuffer = MAX_PACKET_SIZE+2;

                break;

            case OID_GEN_RECEIVE_BUFFER_SPACE: 
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_RECEIVE_BUFFER_SPACE)\n"));
/*
                The amount of memory on the device available 
                for buffering receive data.
*/
                
                *(UINT *)InformationBuffer = MAX_PACKET_SIZE+4;

                break;

            case OID_GEN_TRANSMIT_BLOCK_SIZE: 
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_TRANSMIT_BLOCK_SIZE)\n"));
/*

                The minimum number of bytes that a single net packet 
                occupies in the transmit buffer space of the device.
                For example, on some devices the transmit space is 
                divided into 256-byte pieces so such a device's 
                transmit block size would be 256. To calculate 
                the total transmit buffer space on such a device, 
                its driver multiplies the number of transmit 
                buffers on the device by its transmit block size.

                For other devices, the transmit block size is
                identical to its maximum packet size. 

*/
                 *(UINT *)InformationBuffer = MAX_PACKET_SIZE+2;

                break;

            case OID_GEN_RECEIVE_BLOCK_SIZE: 
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_RECEIVE_BLOCK_SIZE)\n"));
/*
                The amount of storage, in bytes, that a single packet
                occupies in the receive buffer space of the device

*/
                 *(UINT *)InformationBuffer = MAX_PACKET_SIZE+4;
 
                break;

            case OID_GEN_MAXIMUM_LOOKAHEAD: 
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_MAXIMUM_LOOKAHEAD)\n"));
/*
                The maximum number of bytes the device can always provide as lookahead data.
                If the underlying driver supports multipacket receive indications,
                bound protocols are given full net packets on every indication. 
                Consequently, this value is identical to that 
                returned for OID_GEN_RECEIVE_BLOCK_SIZE. 

*/
                 *(UINT *)InformationBuffer = MAX_PACKET_SIZE+4;

                break;

            case OID_GEN_CURRENT_LOOKAHEAD: 
                DEBUGONCE(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_CURRENT_LOOKAHEAD)\n"));
/*
                The number of bytes of received packet data, 
                excluding the header, that will be indicated 
                to the protocol driver. For a query, 
                NDIS returns the largest lookahead size from 
                among all the bindings. A protocol driver can 
                set a suggested value for the number of bytes 
                to be used in its binding; however, 
                the underlying device driver is never required 
                to limit its indications to the value set. 

                If the underlying driver supports multipacket
                receive indications, bound protocols are given
                full net packets on every indication. Consequently,
                this value is identical to that returned for OID_GEN_RECEIVE_BLOCK_SIZE. 

*/

                 *(UINT *)InformationBuffer =  MAX_PACKET_SIZE+4;

                break;

            case OID_GEN_MAXIMUM_FRAME_SIZE:
                DEBUGMSG(DBG_FUNC, ("    MiniportQueryInformation(OID_GEN_MAXIMUM_FRAME_SIZE)\n"));
/*
                The maximum network packet size in bytes 
                the device supports, not including a header. 
                For a binding emulating another medium type, 
                the device driver must define the maximum frame 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜不卡视频| 亚洲蜜桃精久久久久久久| 国产午夜精品一区二区三区视频 | 欧美日本乱大交xxxxx| 日韩欧美国产精品一区| 亚洲免费观看高清完整版在线观看熊| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲va欧美va人人爽午夜| 免费成人av资源网| 国产99精品国产| 精品少妇一区二区三区在线播放| 亚洲日本青草视频在线怡红院 | 亚洲视频一区二区免费在线观看| 日韩在线a电影| 91精品办公室少妇高潮对白| 中文字幕第一区第二区| 精品一区二区三区的国产在线播放 | 一区二区三区四区乱视频| 国产精品一区二区黑丝| 欧美一区二区在线看| 亚洲一区二区av电影| 99视频国产精品| 欧美经典一区二区| 狠狠色丁香婷综合久久| 6080亚洲精品一区二区| 亚洲精品写真福利| 成人免费看黄yyy456| 欧美国产一区二区| 成人一区二区三区视频| 国产婷婷色一区二区三区| 日韩精品亚洲专区| 欧美精品tushy高清| 日韩国产一区二| 欧美日韩一区中文字幕| 国产精品国产三级国产普通话99 | 黄色小说综合网站| 日韩视频在线你懂得| 亚洲成a人v欧美综合天堂下载| 国产91精品精华液一区二区三区| 欧美mv和日韩mv国产网站| 天天综合色天天| 欧美色手机在线观看| 亚洲bt欧美bt精品| 欧美精品少妇一区二区三区| 日韩精品一级二级| 精品久久久久久久久久久久久久久 | 中文字幕中文字幕一区二区| 日韩精品一二区| 欧美日韩黄视频| 日韩精品三区四区| 欧美成人vps| 国产麻豆精品95视频| 欧美国产精品一区二区三区| 成人av影院在线| 欧美优质美女网站| 日韩精品国产欧美| 精品国内二区三区| jlzzjlzz亚洲女人18| 一区二区三区高清| 日韩一区二区三区观看| 国内精品伊人久久久久av影院 | 国产酒店精品激情| 国产精品三级av| 欧美日韩高清不卡| 国产乱一区二区| 亚洲乱码精品一二三四区日韩在线 | 国产精品色眯眯| 色94色欧美sute亚洲线路二| 日本美女一区二区三区| 国产亚洲欧美在线| 色猫猫国产区一区二在线视频| 三级亚洲高清视频| 国产午夜精品理论片a级大结局| 99久久国产免费看| 日本aⅴ精品一区二区三区| 久久欧美一区二区| 欧美色大人视频| 国产黄人亚洲片| 午夜影院在线观看欧美| 国产丝袜在线精品| 欧美精品亚洲二区| 91色视频在线| 国产九色sp调教91| 性欧美疯狂xxxxbbbb| 久久久国际精品| 欧美色综合影院| 丰满少妇久久久久久久| 日本va欧美va精品| 亚洲精品视频在线观看免费| 精品国产123| 欧美色视频一区| 国产精品1区二区.| 蜜臀av性久久久久蜜臀av麻豆| 国产精品视频一二| 久久久一区二区三区捆绑**| 日本高清不卡视频| 韩国精品在线观看| 日韩黄色免费网站| 亚洲一卡二卡三卡四卡无卡久久| 国产精品欧美一级免费| 欧美大片一区二区| 欧美精三区欧美精三区| 色嗨嗨av一区二区三区| 91小视频在线| 99亚偷拍自图区亚洲| 国产成人无遮挡在线视频| 免费成人性网站| 天堂蜜桃91精品| 亚洲福利一区二区三区| 一区二区三区在线视频观看58| 亚洲国产成人私人影院tom| 精品理论电影在线| 日韩精品一区国产麻豆| 884aa四虎影成人精品一区| 91成人国产精品| 色综合av在线| 在线观看网站黄不卡| 在线观看不卡视频| 在线观看av不卡| 欧美系列在线观看| 精品视频一区二区不卡| 欧美日韩亚洲高清一区二区| 日本道精品一区二区三区| 欧美在线一二三四区| 欧美视频一区二区三区| 欧美私模裸体表演在线观看| 欧美挠脚心视频网站| 日韩欧美国产综合一区| 26uuu久久天堂性欧美| 欧美精品一区二区三区蜜桃视频| 久久综合色天天久久综合图片| 久久日韩精品一区二区五区| 国产欧美日韩视频在线观看| 国产精品免费aⅴ片在线观看| 国产精品福利一区| 一区二区三区四区在线播放| 亚洲超碰97人人做人人爱| 日日摸夜夜添夜夜添国产精品| 日韩和欧美一区二区| 天堂av在线一区| 国产精品一区二区视频| 国产乱码精品一区二区三区忘忧草| 不卡欧美aaaaa| 在线免费观看日本欧美| 欧美一区二区人人喊爽| 国产欧美精品一区二区三区四区 | 日韩精品一区二区三区视频播放| 欧美一级日韩一级| 日韩午夜在线观看| 欧美国产精品中文字幕| 午夜精品免费在线观看| 国产精品自在在线| 精品视频在线免费| 国产女人18水真多18精品一级做| 中文字幕制服丝袜一区二区三区 | 99国产精品久久久久久久久久| 欧美日韩精品二区第二页| 精品国产sm最大网站免费看| 亚洲欧美日韩成人高清在线一区| 视频一区免费在线观看| 国产成人综合自拍| 制服丝袜国产精品| 国产精品麻豆视频| 青青国产91久久久久久| 99久久99久久精品国产片果冻| 日韩亚洲欧美中文三级| 国产精品理论片在线观看| 日韩国产高清影视| 91亚洲精华国产精华精华液| 久久一日本道色综合| 1区2区3区精品视频| 精品一区二区成人精品| 91色乱码一区二区三区| 久久久欧美精品sm网站| 五月天一区二区| 91在线观看视频| 久久久久久久久岛国免费| 三级成人在线视频| 99久久99久久免费精品蜜臀| 久久久夜色精品亚洲| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美亚洲日本国产| 国产精品久久久久aaaa| 国产麻豆视频一区二区| 日韩午夜在线观看视频| 亚洲一区在线观看视频| av午夜精品一区二区三区| 久久美女艺术照精彩视频福利播放 | 毛片基地黄久久久久久天堂| 欧洲一区在线观看| 《视频一区视频二区| 丰满白嫩尤物一区二区| 久久久综合网站| 国产尤物一区二区| 欧美成人官网二区| 男男成人高潮片免费网站| 91超碰这里只有精品国产| 亚洲精品久久久久久国产精华液 | 激情亚洲综合在线| 欧美一区二区国产|