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

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

?? miniport.c

?? NDIS Intermediate Driver
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*++

Copyright (c) 1992-2000  Microsoft Corporation

Module Name:

    miniport.c

Abstract:

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

Author:

Environment:


Revision History:


--*/

#include "precomp.h"
#pragma hdrstop



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
    )
/*++

Routine Description:

    This is the initialize handler which gets called as a result of
    the BindAdapter handler calling NdisIMInitializeDeviceInstanceEx.
    The context parameter which we pass there is the adapter structure
    which we retrieve here.

    Arguments:

    OpenErrorStatus            Not used by us.
    SelectedMediumIndex        Place-holder for what media we are using
    MediumArray                Array of ndis media passed down to us to pick from
    MediumArraySize            Size of the array
    MiniportAdapterHandle    The handle NDIS uses to refer to us
    WrapperConfigurationContext    For use by NdisOpenConfiguration

Return Value:

    NDIS_STATUS_SUCCESS unless something goes wrong

--*/
{
    UINT            i;
    PADAPT          pAdapt;
    NDIS_STATUS     Status = NDIS_STATUS_FAILURE;
    NDIS_MEDIUM     Medium;

    UNREFERENCED_PARAMETER(WrapperConfigurationContext);
    
    do
    {
        //
        // Start off by retrieving our adapter context and storing
        // the Miniport handle in it.
        //
        pAdapt = NdisIMGetDeviceContext(MiniportAdapterHandle);
        pAdapt->MiniportHandle = MiniportAdapterHandle;

        DBGPRINT(("==> Miniport Initialize: Adapt %p\n", pAdapt));

        //
        // Usually we export the medium type of the adapter below as our
        // virtual miniport's medium type. However if the adapter below us
        // is a WAN device, then we claim to be of medium type 802.3.
        //
        Medium = pAdapt->Medium;

        if (Medium == NdisMediumWan)
        {
            Medium = NdisMedium802_3;
        }

        for (i = 0; i < MediumArraySize; i++)
        {
            if (MediumArray[i] == Medium)
            {
                *SelectedMediumIndex = i;
                break;
            }
        }

        if (i == MediumArraySize)
        {
            Status = NDIS_STATUS_UNSUPPORTED_MEDIA;
            break;
        }


        //
        // Set the attributes now. NDIS_ATTRIBUTE_DESERIALIZE enables us
        // to make up-calls to NDIS without having to call NdisIMSwitchToMiniport
        // or NdisIMQueueCallBack. This also forces us to protect our data using
        // spinlocks where appropriate. Also in this case NDIS does not queue
        // packets on our behalf. Since this is a very simple pass-thru
        // miniport, we do not have a need to protect anything. However in
        // a general case there will be a need to use per-adapter spin-locks
        // for the packet queues at the very least.
        //
        NdisMSetAttributesEx(MiniportAdapterHandle,
                             pAdapt,
                             0,                                        // CheckForHangTimeInSeconds
                             NDIS_ATTRIBUTE_IGNORE_PACKET_TIMEOUT    |
                                NDIS_ATTRIBUTE_IGNORE_REQUEST_TIMEOUT|
                                NDIS_ATTRIBUTE_INTERMEDIATE_DRIVER |
                                NDIS_ATTRIBUTE_DESERIALIZE |
                                NDIS_ATTRIBUTE_NO_HALT_ON_SUSPEND,
                             0);

        //
        // Initialize LastIndicatedStatus to be NDIS_STATUS_MEDIA_CONNECT
        //
        pAdapt->LastIndicatedStatus = NDIS_STATUS_MEDIA_CONNECT;
        
        //
        // Initialize the power states for both the lower binding (PTDeviceState)
        // and our miniport edge to Powered On.
        //
        pAdapt->MPDeviceState = NdisDeviceStateD0;

        //
        // Add this adapter to the global pAdapt List
        //
        NdisAcquireSpinLock(&GlobalLock);

        pAdapt->Next = pAdaptList;
        pAdaptList = pAdapt;

        NdisReleaseSpinLock(&GlobalLock);
        
        //
        // Create an ioctl interface
        //
        (VOID)PtRegisterDevice();

        Status = NDIS_STATUS_SUCCESS;
    }
    while (FALSE);

    //
    // If we had received an UnbindAdapter notification on the underlying
    // adapter, we would have blocked that thread waiting for the IM Init
    // process to complete. Wake up any such thread.
    //
    ASSERT(pAdapt->MiniportInitPending == TRUE);
    pAdapt->MiniportInitPending = FALSE;
    NdisSetEvent(&pAdapt->MiniportInitEvent);

    DBGPRINT(("<== Miniport Initialize: Adapt %p, Status %x\n", pAdapt, Status));

    *OpenErrorStatus = Status;
    
    return Status;
}


NDIS_STATUS
MPSend(
    IN NDIS_HANDLE             MiniportAdapterContext,
    IN PNDIS_PACKET            Packet,
    IN UINT                    Flags
    )
/*++

Routine Description:

    Send Packet handler. Either this or our SendPackets (array) handler is called
    based on which one is enabled in our Miniport Characteristics.

Arguments:

    MiniportAdapterContext    Pointer to the adapter
    Packet                    Packet to send
    Flags                     Unused, passed down below

Return Value:

    Return code from NdisSend

--*/
{
    PADAPT              pAdapt = (PADAPT)MiniportAdapterContext;
    NDIS_STATUS         Status;
    PNDIS_PACKET        MyPacket;
    PVOID               MediaSpecificInfo = NULL;
    ULONG               MediaSpecificInfoSize = 0;

    //
    // The driver should fail the send if the virtual miniport is in low 
    // power state
    //
    if (pAdapt->MPDeviceState > NdisDeviceStateD0)
    {
         return NDIS_STATUS_FAILURE;
    }

#ifdef NDIS51
    //
    // Use NDIS 5.1 packet stacking:
    //
    {
        PNDIS_PACKET_STACK        pStack;
        BOOLEAN                   Remaining;

        //
        // Packet stacks: Check if we can use the same packet for sending down.
        //

        pStack = NdisIMGetCurrentPacketStack(Packet, &Remaining);
        if (Remaining)
        {
            //
            // We can reuse "Packet".
            //
            // NOTE: if we needed to keep per-packet information in packets
            // sent down, we can use pStack->IMReserved[].
            //
            ASSERT(pStack);
            //
            // If the below miniport is going to low power state, stop sending down any packet.
            //
            NdisAcquireSpinLock(&pAdapt->Lock);
            if (pAdapt->PTDeviceState > NdisDeviceStateD0)
            {
                NdisReleaseSpinLock(&pAdapt->Lock);
                return NDIS_STATUS_FAILURE;
            }
            pAdapt->OutstandingSends++;
            NdisReleaseSpinLock(&pAdapt->Lock);
            NdisSend(&Status,
                     pAdapt->BindingHandle,
                     Packet);

            if (Status != NDIS_STATUS_PENDING)
            {
                ADAPT_DECR_PENDING_SENDS(pAdapt);
            }

            return(Status);
        }
    }
#endif // NDIS51

    //
    // We are either not using packet stacks, or there isn't stack space
    // in the original packet passed down to us. Allocate a new packet
    // to wrap the data with.
    //
    //
    // If the below miniport is going to low power state, stop sending down any packet.
    //
    NdisAcquireSpinLock(&pAdapt->Lock);
    if (pAdapt->PTDeviceState > NdisDeviceStateD0)
    {
        NdisReleaseSpinLock(&pAdapt->Lock);
        return NDIS_STATUS_FAILURE;
    
    }
    pAdapt->OutstandingSends++;
    NdisReleaseSpinLock(&pAdapt->Lock);
    
    NdisAllocatePacket(&Status,
                       &MyPacket,
                       pAdapt->SendPacketPoolHandle);

    if (Status == NDIS_STATUS_SUCCESS)
    {
        PSEND_RSVD            SendRsvd;

        //
        // Save a pointer to the original packet in our reserved
        // area in the new packet. This is needed so that we can
        // get back to the original packet when the new packet's send
        // is completed.
        //
        SendRsvd = (PSEND_RSVD)(MyPacket->ProtocolReserved);
        SendRsvd->OriginalPkt = Packet;

        NdisGetPacketFlags(MyPacket) = Flags;

        //
        // Set up the new packet so that it describes the same
        // data as the original packet.
        //
        NDIS_PACKET_FIRST_NDIS_BUFFER(MyPacket) = NDIS_PACKET_FIRST_NDIS_BUFFER(Packet);
        NDIS_PACKET_LAST_NDIS_BUFFER(MyPacket) = NDIS_PACKET_LAST_NDIS_BUFFER(Packet);
#ifdef WIN9X
        //
        // Work around the fact that NDIS does not initialize this
        // to FALSE on Win9x.
        //
        NDIS_PACKET_VALID_COUNTS(MyPacket) = FALSE;
#endif

        //
        // Copy the OOB Offset from the original packet to the new
        // packet.
        //
        NdisMoveMemory(NDIS_OOB_DATA_FROM_PACKET(MyPacket),
                       NDIS_OOB_DATA_FROM_PACKET(Packet),
                       sizeof(NDIS_PACKET_OOB_DATA));

#ifndef WIN9X
        //
        // Copy the right parts of per packet info into the new packet.
        // This API is not available on Win9x since task offload is
        // not supported on that platform.
        //
        NdisIMCopySendPerPacketInfo(MyPacket, Packet);
#endif
        
        //
        // Copy the Media specific information
        //
        NDIS_GET_PACKET_MEDIA_SPECIFIC_INFO(Packet,
                                            &MediaSpecificInfo,
                                            &MediaSpecificInfoSize);

        if (MediaSpecificInfo || MediaSpecificInfoSize)
        {
            NDIS_SET_PACKET_MEDIA_SPECIFIC_INFO(MyPacket,
                                                MediaSpecificInfo,
                                                MediaSpecificInfoSize);
        }

        NdisSend(&Status,
                 pAdapt->BindingHandle,
                 MyPacket);


        if (Status != NDIS_STATUS_PENDING)
        {
#ifndef WIN9X
            NdisIMCopySendCompletePerPacketInfo (Packet, MyPacket);
#endif
            NdisFreePacket(MyPacket);
            ADAPT_DECR_PENDING_SENDS(pAdapt);
        }
    }
    else
    {
        ADAPT_DECR_PENDING_SENDS(pAdapt);
        //
        // We are out of packets. Silently drop it. Alternatively we can deal with it:
        //    - By keeping separate send and receive pools
        //    - Dynamically allocate more pools as needed and free them when not needed
        //
    }

    return(Status);
}


VOID
MPSendPackets(
    IN NDIS_HANDLE             MiniportAdapterContext,
    IN PPNDIS_PACKET           PacketArray,
    IN UINT                    NumberOfPackets
    )
/*++

Routine Description:

    Send Packet Array handler. Either this or our SendPacket handler is called
    based on which one is enabled in our Miniport Characteristics.

Arguments:

    MiniportAdapterContext     Pointer to our adapter
    PacketArray                Set of packets to send
    NumberOfPackets            Self-explanatory

Return Value:

    None

--*/
{
    PADAPT              pAdapt = (PADAPT)MiniportAdapterContext;
    NDIS_STATUS         Status;
    UINT                i;
    PVOID               MediaSpecificInfo = NULL;
    UINT                MediaSpecificInfoSize = 0;
    

    for (i = 0; i < NumberOfPackets; i++)
    {
        PNDIS_PACKET    Packet, MyPacket;

        Packet = PacketArray[i];
        //
        // The driver should fail the send if the virtual miniport is in low 
        // power state
        //
        if (pAdapt->MPDeviceState > NdisDeviceStateD0)
        {
            NdisMSendComplete(ADAPT_MINIPORT_HANDLE(pAdapt),
                            Packet,
                            NDIS_STATUS_FAILURE);
            continue;
        }

#ifdef NDIS51

        //
        // Use NDIS 5.1 packet stacking:
        //
        {
            PNDIS_PACKET_STACK        pStack;
            BOOLEAN                   Remaining;

            //
            // Packet stacks: Check if we can use the same packet for sending down.
            //
            pStack = NdisIMGetCurrentPacketStack(Packet, &Remaining);
            if (Remaining)
            {
                //
                // We can reuse "Packet".
                //
                // NOTE: if we needed to keep per-packet information in packets
                // sent down, we can use pStack->IMReserved[].
                //
                ASSERT(pStack);
                //
                // If the below miniport is going to low power state, stop sending down any packet.
                //
                NdisAcquireSpinLock(&pAdapt->Lock);
                if (pAdapt->PTDeviceState > NdisDeviceStateD0)
                {
                    NdisReleaseSpinLock(&pAdapt->Lock);
                    NdisMSendComplete(ADAPT_MINIPORT_HANDLE(pAdapt),
                                        Packet,
                                        NDIS_STATUS_FAILURE);
                }
                else
                {
                    pAdapt->OutstandingSends++;
                    NdisReleaseSpinLock(&pAdapt->Lock);
                
                    NdisSend(&Status,
                              pAdapt->BindingHandle,
                              Packet);
        
                    if (Status != NDIS_STATUS_PENDING)
                    {
                        NdisMSendComplete(ADAPT_MINIPORT_HANDLE(pAdapt),
                                            Packet,
                                            Status);
                   
                        ADAPT_DECR_PENDING_SENDS(pAdapt);
                    }
                }
                continue;
            }
        }
#endif
        do 
        {
            NdisAcquireSpinLock(&pAdapt->Lock);
            //
            // If the below miniport is going to low power state, stop sending down any packet.
            //

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色婷婷av一区二区| 午夜影院在线观看欧美| 最新成人av在线| 一区二区国产盗摄色噜噜| 婷婷六月综合亚洲| 精品一区二区三区av| www.久久精品| 欧美日韩国产影片| 精品久久国产字幕高潮| 国产精品久久久久久久久图文区| 亚洲女女做受ⅹxx高潮| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产一区二区三区视频在线播放| 成人av电影免费观看| 欧美巨大另类极品videosbest| 久久综合视频网| 亚洲黄色av一区| 久久99精品久久只有精品| 91麻豆视频网站| 日韩欧美在线网站| 国产精品久久久99| 日韩福利视频导航| 成人app软件下载大全免费| 在线观看国产91| 精品国产伦一区二区三区观看方式| 国产精品久久久久久一区二区三区 | 色婷婷综合久久久| 日韩美女主播在线视频一区二区三区 | 99视频在线精品| 欧美人与z0zoxxxx视频| 日本一区二区三区dvd视频在线| 亚洲激情六月丁香| 国产成人免费在线| 欧美日韩成人综合天天影院 | 日本中文字幕一区| 99国产精品久| 精品91自产拍在线观看一区| 亚洲精品中文在线观看| 看国产成人h片视频| 欧美性xxxxxx少妇| 国产精品入口麻豆原神| 免费在线看成人av| 在线观看三级视频欧美| 国产目拍亚洲精品99久久精品| 日韩国产欧美三级| 欧美中文一区二区三区| 中文字幕av一区二区三区免费看 | 日韩精品一区二区三区在线观看| 亚洲精品乱码久久久久久久久| 国模套图日韩精品一区二区| 911国产精品| 一区二区三区在线不卡| 国产不卡视频在线播放| 91麻豆精品国产91久久久久| 一区二区三区四区亚洲| 波多野结衣一区二区三区| 精品国产3级a| 青青草精品视频| 欧美日韩国产高清一区二区 | 成人福利视频在线看| 26uuu精品一区二区| 青草av.久久免费一区| 色婷婷国产精品综合在线观看| 国产精品妹子av| 国产综合色产在线精品| 欧美一级欧美一级在线播放| 亚洲动漫第一页| 91小视频在线| 亚洲天堂网中文字| 色综合中文综合网| 欧美午夜影院一区| 亚洲精品免费一二三区| www.欧美.com| 亚洲另类春色校园小说| 色综合久久综合网97色综合| 亚洲丝袜另类动漫二区| 99re亚洲国产精品| 亚洲欧美日韩中文字幕一区二区三区| 国产成人午夜精品影院观看视频| 久久九九久精品国产免费直播| 精品一区二区三区影院在线午夜| 日韩三区在线观看| 蜜臀久久99精品久久久画质超高清| 欧美欧美午夜aⅴ在线观看| 亚洲成人先锋电影| 欧美日韩精品系列| 男人操女人的视频在线观看欧美 | 精一区二区三区| 久久综合色一综合色88| 国产一区二区福利| 久久精品一区蜜桃臀影院| 国产福利一区二区三区视频| 国产亚洲欧美激情| 97超碰欧美中文字幕| 一区二区三区四区精品在线视频| 欧美日韩在线精品一区二区三区激情| 视频一区免费在线观看| 日韩欧美国产三级| 国产成人aaa| 亚洲欧美自拍偷拍| 欧美日韩黄色影视| 九九久久精品视频 | 成人开心网精品视频| 亚洲人快播电影网| 欧美一区二区视频在线观看2022| 麻豆91在线看| 国产欧美一区二区精品性| voyeur盗摄精品| 亚洲妇女屁股眼交7| 久久综合九色欧美综合狠狠| 国产超碰在线一区| 亚洲一区电影777| 欧美一级欧美三级| 成人天堂资源www在线| 一区二区激情小说| 精品国产91洋老外米糕| 99re8在线精品视频免费播放| 亚洲午夜视频在线观看| 欧美精品一区视频| 一本色道综合亚洲| 免费观看一级特黄欧美大片| 国产人伦精品一区二区| 欧美中文字幕不卡| 国产激情视频一区二区三区欧美 | 国产一区二区在线观看视频| 国产精品久久影院| 91精品麻豆日日躁夜夜躁| 国产suv精品一区二区三区| 一区二区三区中文字幕在线观看| 精品久久久久久久人人人人传媒| 91丨九色porny丨蝌蚪| 日本不卡一区二区| 亚洲色欲色欲www| 欧美精品一区二区久久婷婷| 一本色道久久加勒比精品| 麻豆成人91精品二区三区| 亚洲欧洲av在线| 精品国产1区二区| 欧美视频一区二区| 成人性生交大合| 青娱乐精品视频| 亚洲影院免费观看| 国产目拍亚洲精品99久久精品| 欧美日韩国产精品成人| 成人免费黄色大片| 免费成人美女在线观看| 亚洲精品国产精品乱码不99| 久久精品夜夜夜夜久久| 5月丁香婷婷综合| 色综合久久久久综合体| 国产精品亚洲一区二区三区妖精| 性感美女极品91精品| 成人欧美一区二区三区1314| 欧美α欧美αv大片| 欧美性三三影院| av资源网一区| 国内精品久久久久影院色| 日产精品久久久久久久性色 | 欧美日韩一区二区三区视频| 成人性生交大片免费看在线播放| 美女视频黄免费的久久| 亚洲国产精品一区二区尤物区| 综合久久久久久久| 久久精品视频在线免费观看| 精品国产乱码久久久久久图片 | 亚洲一二三区在线观看| 国产精品久久久久久久久图文区| 337p粉嫩大胆噜噜噜噜噜91av| 欧美日韩成人高清| 91久久精品一区二区二区| 成人app软件下载大全免费| 国产精品18久久久久| 国精产品一区一区三区mba桃花 | 欧美一级专区免费大片| 欧美日韩久久久一区| 欧美影院一区二区三区| a4yy欧美一区二区三区| 丁香婷婷综合色啪| 成人综合激情网| 国产成人av一区二区三区在线| 久88久久88久久久| 激情都市一区二区| 国内精品写真在线观看| 激情成人午夜视频| 国产美女久久久久| 国产精品一区二区果冻传媒| 国产综合色精品一区二区三区| 久久99精品一区二区三区三区| 麻豆视频一区二区| 麻豆国产精品777777在线| 激情综合色丁香一区二区| 久久99精品国产麻豆婷婷洗澡| 久久99国产精品成人| 韩国成人精品a∨在线观看| 国产一区二区三区视频在线播放| 国产精品91一区二区| 成人午夜电影网站| 91麻豆文化传媒在线观看| 在线日韩av片| 宅男在线国产精品|