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

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

?? passthru.h

?? NDIS Intermediate Driver
?? H
字號:
/*++

Copyright (c) 1992-2000  Microsoft Corporation

Module Name:

    passthru.h

Abstract:

    Ndis Intermediate Miniport driver sample. This is a passthru driver.

Author:

Environment:


Revision History:

 
--*/

#ifdef NDIS51_MINIPORT
#define PASSTHRU_MAJOR_NDIS_VERSION            5
#define PASSTHRU_MINOR_NDIS_VERSION            1
#else
#define PASSTHRU_MAJOR_NDIS_VERSION            4
#define PASSTHRU_MINOR_NDIS_VERSION            0
#endif

#ifdef NDIS51
#define PASSTHRU_PROT_MAJOR_NDIS_VERSION    5
#define PASSTHRU_PROT_MINOR_NDIS_VERSION    0
#else
#define PASSTHRU_PROT_MAJOR_NDIS_VERSION    4
#define PASSTHRU_PROT_MINOR_NDIS_VERSION    0
#endif

#define MAX_BUNDLEID_LENGTH 50

#define TAG 'ImPa'
#define WAIT_INFINITE 0



//advance declaration
typedef struct _ADAPT ADAPT, *PADAPT;

extern
NTSTATUS
DriverEntry(
    IN PDRIVER_OBJECT            DriverObject,
    IN PUNICODE_STRING           RegistryPath
    );

NTSTATUS
PtDispatch(
    IN PDEVICE_OBJECT            DeviceObject,
    IN PIRP                      Irp
    );

NDIS_STATUS
PtRegisterDevice(
    VOID
    );

NDIS_STATUS
PtDeregisterDevice(
    VOID
   );

VOID
PtUnloadProtocol(
    VOID
    );

//
// Protocol proto-types
//
extern
VOID
PtOpenAdapterComplete(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN NDIS_STATUS                Status,
    IN NDIS_STATUS                OpenErrorStatus
    );

extern
VOID
PtCloseAdapterComplete(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN NDIS_STATUS                Status
    );

extern
VOID
PtResetComplete(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN NDIS_STATUS                Status
    );

extern
VOID
PtRequestComplete(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN PNDIS_REQUEST              NdisRequest,
    IN NDIS_STATUS                Status
    );

extern
VOID
PtStatus(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN NDIS_STATUS                GeneralStatus,
    IN PVOID                      StatusBuffer,
    IN UINT                       StatusBufferSize
    );

extern
VOID
PtStatusComplete(
    IN NDIS_HANDLE                ProtocolBindingContext
    );

extern
VOID
PtSendComplete(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN PNDIS_PACKET               Packet,
    IN NDIS_STATUS                Status
    );

extern
VOID
PtTransferDataComplete(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN PNDIS_PACKET               Packet,
    IN NDIS_STATUS                Status,
    IN UINT                       BytesTransferred
    );

extern
NDIS_STATUS
PtReceive(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN NDIS_HANDLE                MacReceiveContext,
    IN PVOID                      HeaderBuffer,
    IN UINT                       HeaderBufferSize,
    IN PVOID                      LookAheadBuffer,
    IN UINT                       LookaheadBufferSize,
    IN UINT                       PacketSize
    );

extern
VOID
PtReceiveComplete(
    IN NDIS_HANDLE                ProtocolBindingContext
    );

extern
INT
PtReceivePacket(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN PNDIS_PACKET               Packet
    );

extern
VOID
PtBindAdapter(
    OUT PNDIS_STATUS              Status,
    IN  NDIS_HANDLE               BindContext,
    IN  PNDIS_STRING              DeviceName,
    IN  PVOID                     SystemSpecific1,
    IN  PVOID                     SystemSpecific2
    );

extern
VOID
PtUnbindAdapter(
    OUT PNDIS_STATUS              Status,
    IN  NDIS_HANDLE               ProtocolBindingContext,
    IN  NDIS_HANDLE               UnbindContext
    );
    
VOID
PtUnload(
    IN PDRIVER_OBJECT             DriverObject
    );



extern 
NDIS_STATUS
PtPNPHandler(
    IN NDIS_HANDLE                ProtocolBindingContext,
    IN PNET_PNP_EVENT             pNetPnPEvent
    );




NDIS_STATUS
PtPnPNetEventReconfigure(
    IN PADAPT            pAdapt,
    IN PNET_PNP_EVENT    pNetPnPEvent
    );    

NDIS_STATUS 
PtPnPNetEventSetPower (
    IN PADAPT                    pAdapt,
    IN PNET_PNP_EVENT            pNetPnPEvent
    );
    

//
// Miniport proto-types
//
NDIS_STATUS
MPInitialize(
    OUT PNDIS_STATUS             OpenErrorStatus,
    OUT PUINT                    SelectedMediumIndex,
    IN PNDIS_MEDIUM              MediumArray,
    IN UINT                      MediumArraySize,
    IN NDIS_HANDLE               MiniportAdapterHandle,
    IN NDIS_HANDLE               WrapperConfigurationContext
    );

VOID
MPSendPackets(
    IN NDIS_HANDLE                MiniportAdapterContext,
    IN PPNDIS_PACKET              PacketArray,
    IN UINT                       NumberOfPackets
    );

NDIS_STATUS
MPSend(
    IN NDIS_HANDLE                MiniportAdapterContext,
    IN PNDIS_PACKET               Packet,
    IN UINT                       Flags
    );

NDIS_STATUS
MPQueryInformation(
    IN NDIS_HANDLE                MiniportAdapterContext,
    IN NDIS_OID                   Oid,
    IN PVOID                      InformationBuffer,
    IN ULONG                      InformationBufferLength,
    OUT PULONG                    BytesWritten,
    OUT PULONG                    BytesNeeded
    );

NDIS_STATUS
MPSetInformation(
    IN NDIS_HANDLE                MiniportAdapterContext,
    IN NDIS_OID                   Oid,
    IN PVOID                      InformationBuffer,
    IN ULONG                      InformationBufferLength,
    OUT PULONG                    BytesRead,
    OUT PULONG                    BytesNeeded
    );

VOID
MPReturnPacket(
    IN NDIS_HANDLE                MiniportAdapterContext,
    IN PNDIS_PACKET               Packet
    );

NDIS_STATUS
MPTransferData(
    OUT PNDIS_PACKET              Packet,
    OUT PUINT                     BytesTransferred,
    IN NDIS_HANDLE                MiniportAdapterContext,
    IN NDIS_HANDLE                MiniportReceiveContext,
    IN UINT                       ByteOffset,
    IN UINT                       BytesToTransfer
    );

VOID
MPHalt(
    IN NDIS_HANDLE                MiniportAdapterContext
    );


VOID
MPQueryPNPCapabilities(  
    OUT PADAPT                    MiniportProtocolContext, 
    OUT PNDIS_STATUS              Status
    );


NDIS_STATUS
MPSetMiniportSecondary ( 
    IN PADAPT                    Secondary, 
    IN PADAPT                    Primary
    );

#ifdef NDIS51_MINIPORT

VOID
MPCancelSendPackets(
    IN NDIS_HANDLE            MiniportAdapterContext,
    IN PVOID                  CancelId
    );

VOID
MPAdapterShutdown(
    IN NDIS_HANDLE                MiniportAdapterContext
    );

VOID
MPDevicePnPEvent(
    IN NDIS_HANDLE                MiniportAdapterContext,
    IN NDIS_DEVICE_PNP_EVENT      DevicePnPEvent,
    IN PVOID                      InformationBuffer,
    IN ULONG                      InformationBufferLength
    );

#endif // NDIS51_MINIPORT

VOID
MPFreeAllPacketPools(
    IN PADAPT                    pAdapt
    );

NDIS_STATUS 
MPPromoteSecondary ( 
    IN PADAPT                    pAdapt 
    );


NDIS_STATUS 
MPBundleSearchAndSetSecondary (
    IN PADAPT                    pAdapt 
    );

VOID
MPProcessSetPowerOid(
    IN OUT PNDIS_STATUS          pNdisStatus,
    IN PADAPT                    pAdapt,
    IN PVOID                     InformationBuffer,
    IN ULONG                     InformationBufferLength,
    OUT PULONG                   BytesRead,
    OUT PULONG                   BytesNeeded
    );


//
// There should be no DbgPrint's in the Free version of the driver
//
#if DBG

#define DBGPRINT(Fmt)                                        \
    {                                                        \
        DbgPrint("Passthru: ");                                \
        DbgPrint Fmt;                                        \
    }

#else // if DBG

#define DBGPRINT(Fmt)                                            

#endif // if DBG 

#define    NUM_PKTS_IN_POOL    256

//
// Protocol reserved part of a sent packet that is allocated by us.
//
typedef struct _SEND_RSVD
{
    PNDIS_PACKET    OriginalPkt;
} SEND_RSVD, *PSEND_RSVD;

//
// Miniport reserved part of a received packet that is allocated by
// us. Note that this should fit into the MiniportReserved space
// in an NDIS_PACKET.
//
typedef struct _RECV_RSVD
{
    PNDIS_PACKET    OriginalPkt;
} RECV_RSVD, *PRECV_RSVD;

C_ASSERT(sizeof(RECV_RSVD) <= sizeof(((PNDIS_PACKET)0)->MiniportReserved));

//
// Event Codes related to the PassthruEvent Structure
//

typedef enum 
{
    Passthru_Invalid,
    Passthru_SetPower,
    Passthru_Unbind

} PASSSTHRU_EVENT_CODE, *PPASTHRU_EVENT_CODE; 

//
// Passthru Event with  a code to state why they have been state
//

typedef struct _PASSTHRU_EVENT
{
    NDIS_EVENT Event;
    PASSSTHRU_EVENT_CODE Code;

} PASSTHRU_EVENT, *PPASSTHRU_EVENT;

#define MAX_RECEIVE_PACKET_ARRAY_SIZE           40

//
// Structure used by both the miniport as well as the protocol part of the intermediate driver
// to represent an adapter and its corres. lower bindings
//
typedef struct _ADAPT
{
    struct _ADAPT *                Next;
    
    NDIS_HANDLE                    BindingHandle;    // To the lower miniport
    NDIS_HANDLE                    MiniportHandle;    // NDIS Handle to for miniport up-calls
    NDIS_HANDLE                    SendPacketPoolHandle;
    NDIS_HANDLE                    RecvPacketPoolHandle;
    NDIS_STATUS                    Status;            // Open Status
    NDIS_EVENT                     Event;            // Used by bind/halt for Open/Close Adapter synch.
    NDIS_MEDIUM                    Medium;
    NDIS_REQUEST                   Request;        // This is used to wrap a request coming down
                                                // to us. This exploits the fact that requests
                                                // are serialized down to us.
    PULONG                         BytesNeeded;
    PULONG                         BytesReadOrWritten;
    BOOLEAN                        IndicateRcvComplete;
    
    BOOLEAN                        OutstandingRequests;      // TRUE iff a request is pending
                                                        // at the miniport below
    BOOLEAN                        QueuedRequest;            // TRUE iff a request is queued at
                                                        // this IM miniport

    BOOLEAN                        StandingBy;                // True - When the miniport or protocol is transitioning from a D0 to Standby (>D0) State
    BOOLEAN                        UnbindingInProcess;
    NDIS_SPIN_LOCK                 Lock;
                                                        // False - At all other times, - Flag is cleared after a transition to D0

    NDIS_DEVICE_POWER_STATE        MPDeviceState;            // Miniport's Device State 
    NDIS_DEVICE_POWER_STATE        PTDeviceState;            // Protocol's Device State 
    NDIS_STRING                    DeviceName;                // For initializing the miniport edge
    NDIS_EVENT                     MiniportInitEvent;        // For blocking UnbindAdapter while
                                                        // an IM Init is in progress.
    BOOLEAN                        MiniportInitPending;    // TRUE iff IMInit in progress
    NDIS_STATUS                    LastIndicatedStatus;    // The last indicated media status
    NDIS_STATUS                    LatestUnIndicateStatus; // The latest suppressed media status
    ULONG                          OutstandingSends;
    PNDIS_PACKET                   ReceivedPackets[MAX_RECEIVE_PACKET_ARRAY_SIZE];
    ULONG                          ReceivedPacketCount;
    

} ADAPT, *PADAPT;

extern    NDIS_HANDLE                        ProtHandle, DriverHandle;
extern    NDIS_MEDIUM                        MediumArray[4];
extern    PADAPT                             pAdaptList;
extern    NDIS_SPIN_LOCK                     GlobalLock;

#ifndef NDIS_PACKET_FIRST_NDIS_BUFFER
#define NDIS_PACKET_FIRST_NDIS_BUFFER(_Packet)      ((_Packet)->Private.Head)
#endif

#ifndef NDIS_PACKET_LAST_NDIS_BUFFER
#define NDIS_PACKET_LAST_NDIS_BUFFER(_Packet)       ((_Packet)->Private.Tail)
#endif

#ifndef NDIS_PACKET_VALID_COUNTS
#define NDIS_PACKET_VALID_COUNTS(_Packet)           ((_Packet)->Private.ValidCounts)
#endif

#define ADAPT_MINIPORT_HANDLE(_pAdapt)    ((_pAdapt)->MiniportHandle)
#define ADAPT_DECR_PENDING_SENDS(_pAdapt)     \
    {                                         \
        NdisAcquireSpinLock(&(_pAdapt)->Lock);   \
        (_pAdapt)->OutstandingSends--;           \
        NdisReleaseSpinLock(&(_pAdapt)->Lock);   \
    }

//
// Custom Macros to be used by the passthru driver 
//
/*
BOOLEAN
IsIMDeviceStateOn(
   PADAPT 
   )

*/
#define IsIMDeviceStateOn(_pP)        ((_pP)->MPDeviceState == NdisDeviceStateD0 && (_pP)->PTDeviceState == NdisDeviceStateD0 ) 


VOID
PtQueueReceivedPacket(
    IN PADAPT       pAdapt,
    IN PNDIS_PACKET Packet,
    IN BOOLEAN      DoIndicate
    );

VOID
PtFlushReceiveQueue(
    IN PADAPT       pAdapt
    );


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99精品热视频| 国产不卡在线一区| 欧美人狂配大交3d怪物一区| 一区二区三区免费在线观看| 日本高清成人免费播放| 亚洲网友自拍偷拍| 91精品国产欧美一区二区| 日本成人在线不卡视频| 精品久久久久久久久久久久包黑料| 久久se这里有精品| 国产精品拍天天在线| 91福利资源站| 免费av网站大全久久| 久久久久99精品一区| 9l国产精品久久久久麻豆| 一区二区在线观看av| 91精品国产综合久久精品图片| 久久综合综合久久综合| 国产精品久久久久永久免费观看| 色爱区综合激月婷婷| 日韩精品成人一区二区三区| 久久蜜桃一区二区| 欧美曰成人黄网| 国产一区视频在线看| 亚洲老妇xxxxxx| 日韩视频123| 99视频在线精品| 免费一级片91| 自拍偷拍国产精品| 欧美成人性战久久| 91免费版在线| 狠狠色狠狠色合久久伊人| 亚洲欧美视频在线观看视频| 欧美成人免费网站| 欧洲国产伦久久久久久久| 国产一区二区在线看| 亚洲一区二区av在线| 欧美精品一区男女天堂| 在线免费观看成人短视频| 国产制服丝袜一区| 丝袜美腿成人在线| 一区二区在线免费| 国产精品理论在线观看| 日韩精品影音先锋| 欧美日韩一区久久| 91首页免费视频| 国产精品888| 另类小说欧美激情| 日韩中文字幕区一区有砖一区| 亚洲欧洲国产专区| 久久亚洲综合色一区二区三区 | 国产丝袜欧美中文另类| 在线观看91精品国产麻豆| 99精品一区二区| 国产精品一二三| 精品无码三级在线观看视频| 三级不卡在线观看| 亚洲综合精品久久| 夜夜精品视频一区二区| 亚洲视频在线观看三级| 欧美激情在线看| 精品国产乱码91久久久久久网站| 欧美天堂一区二区三区| 色www精品视频在线观看| 波多野结衣91| 99久久综合精品| a在线欧美一区| 99麻豆久久久国产精品免费优播| 国产69精品久久777的优势| 国产盗摄一区二区三区| 国产成a人亚洲| 国产精品羞羞答答xxdd| 国产成人8x视频一区二区| 国产精品一区二区视频| 国产精品中文字幕一区二区三区| 韩国在线一区二区| 国产在线不卡视频| 国产精品自拍av| 从欧美一区二区三区| 91天堂素人约啪| 色婷婷狠狠综合| 欧美日韩中文另类| 欧美一区二区三区在线观看| 日韩一区二区在线看| 日韩西西人体444www| 精品久久一区二区| 久久久久97国产精华液好用吗| 久久精品亚洲麻豆av一区二区| 国产欧美精品一区二区色综合| 国产精品久久久久永久免费观看| 自拍偷拍亚洲激情| 午夜影院久久久| 久久99日本精品| 成人免费av在线| 欧美影院一区二区| 日韩一区二区影院| 中文字幕精品一区| 一区二区三区中文字幕在线观看| 亚洲第一福利一区| 美女视频网站久久| 成人免费视频视频在线观看免费| 色综合久久中文综合久久97 | 美女国产一区二区| 国产99一区视频免费| 91亚洲大成网污www| 欧美男女性生活在线直播观看| 日韩欧美专区在线| 最新中文字幕一区二区三区| 亚洲国产日韩一级| 国产精品一区不卡| 欧美在线你懂得| 久久伊99综合婷婷久久伊| 一区二区三区蜜桃网| 韩国v欧美v日本v亚洲v| av爱爱亚洲一区| 日韩一级免费一区| 亚洲天堂免费看| 色综合久久中文字幕综合网| 欧美美女一区二区在线观看| 久久久久成人黄色影片| 亚洲chinese男男1069| 国产91丝袜在线播放0| 91精品啪在线观看国产60岁| 自拍偷拍国产精品| 国产综合成人久久大片91| 欧美日韩高清不卡| 自拍偷自拍亚洲精品播放| 韩国av一区二区| 欧美日韩国产免费一区二区| 亚洲欧美一区二区视频| 久久99国产精品久久99果冻传媒| 一本一本大道香蕉久在线精品 | 免费成人av资源网| 在线视频中文字幕一区二区| 久久亚洲免费视频| 日本成人在线电影网| 在线看国产日韩| 国产精品无人区| 美国毛片一区二区| 制服丝袜亚洲网站| 亚洲黄色性网站| 不卡电影一区二区三区| 久久久亚洲精品石原莉奈| 奇米在线7777在线精品| 欧美在线free| 一区二区三区影院| 99国产精品99久久久久久| 欧美韩国日本一区| 国产成人精品aa毛片| 日韩欧美久久久| 人人超碰91尤物精品国产| 欧美人xxxx| 婷婷开心激情综合| 欧美日韩黄色影视| 午夜久久久久久久久| 欧美亚洲丝袜传媒另类| 亚洲精品免费在线| 日本韩国欧美国产| 亚洲曰韩产成在线| 日本精品视频一区二区三区| 亚洲猫色日本管| 97精品国产露脸对白| 亚洲人午夜精品天堂一二香蕉| aaa国产一区| 亚洲色图欧洲色图| 色婷婷香蕉在线一区二区| 亚洲另类中文字| 91成人国产精品| 亚洲国产精品久久艾草纯爱| 欧美日韩国产大片| 日本不卡免费在线视频| 精品国产精品一区二区夜夜嗨| 麻豆精品蜜桃视频网站| 精品国精品自拍自在线| 国产99久久久久久免费看农村| 国产精品五月天| 日本黄色一区二区| 亚洲成人第一页| 日韩欧美一区在线| 国产高清成人在线| 中文一区一区三区高中清不卡| 成人av手机在线观看| 亚洲黄色免费电影| 欧美日韩电影一区| 久久精品国产第一区二区三区| 久久嫩草精品久久久久| av在线这里只有精品| 亚洲18色成人| 久久免费视频一区| 一本大道av伊人久久综合| 亚洲国产成人av| 精品国产乱子伦一区| 99精品视频在线免费观看| 亚洲国产精品欧美一二99| 欧美一区二区国产| 国产成人精品在线看| 樱桃国产成人精品视频| 欧美一区二区二区| 成人天堂资源www在线| 亚洲国产美女搞黄色|