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

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

?? adapter.c

?? ndis windows網絡驅動程序的范例
?? C
?? 第 1 頁 / 共 3 頁
字號:


    //
    // initialize the corresponding device instance associated with the underlying
    // miniport. NdisIMInitializeDeviceInstanceEx doesn't want the \Device part of
    // the name so we strip that off
    //

    NdisInitUnicodeString( &IMDevName, &Adapter->IMDeviceName.Buffer[ 8 ] );


    //
    // temporarily stuff the adapter pointer into a global so we can find it when
    // MiniportInitialize is called.
    CurrentAdapter = Adapter;

    Status = NdisIMInitializeDeviceInstance( LMDriverHandle, &IMDevName );

    if ( !NT_SUCCESS( Status )) {
        
#if BINARY_COMPATIBLE
        ImDbgOut(DBG_FAILURE, DBG_PROTOCOL,
                 ("(%08X) ProcessLowerMPOpenAdapter: can't init IM device %s (%08X)\n",
                  Adapter, IMDevName.Buffer, Status));
#else
        ImDbgOut(DBG_FAILURE, DBG_PROTOCOL,
                 ("(%08X) ProcessLowerMPOpenAdapter: can't init IM device %ws (%08X)\n",
                  Adapter, IMDevName.Buffer, Status));
#endif

        ErrorLogData[ 0 ] = IM_ERROR_CANT_INITIALIZE_IMSAMP_DEVICE;
        ErrorLogData[ 1 ] = Status;

        NdisWriteErrorLogEntry(Adapter->LowerMPHandle,
                               NDIS_ERROR_CODE_DRIVER_FAILURE,
                               2,
                               ErrorLogData);

        goto ErrorExit;
    }

    Adapter->ShutdownMask |= SHUTDOWN_DEINIT_DEV_INSTANCE;

    return;

    //
    // when things go wrong...
    //

ErrorExit:

    DerefAdapter( Adapter );

} // ProcessLowerMPOpenAdapter


VOID
LowerMPOpenAdapterComplete(
    IN  PADAPTER Adapter,
    IN  NDIS_STATUS Status,
    IN  NDIS_STATUS OpenErrorStatus
    )

/*++

Routine Description:

    Signal that the binding on the lower miniport is complete

Arguments:

    see the DDK

Return Values:

    None

--*/

{
    NTSTATUS EventStatus;
    PWSTR SecondaryName;
    NDIS_HARDWARE_STATUS HWStatus;
    NDIS_MEDIA_STATE MediaState = 0xFFFFFFFF;
    NDIS_STRING PSDevName;
    ULONG MacOptions;
    ULONG ErrorLogData[2];
    PWCHAR StringData[2];
    PVOID DumpData;

    ImDbgOut(DBG_TRACE, DBG_PROTOCOL, ("(%08X) LowerMPOpenAdapterComplete\n", Adapter));

    //
    // stuff the final status in the Adapter block and signal the bind handler to continue
    //

    Adapter->FinalStatus = Status;
    NdisSetEvent( &Adapter->BlockingEvent );

} // LowerMPOpenAdapterComplete


STATIC NDIS_STATUS
AllocatePacketPool(
    PADAPTER Adapter                   
    )

/*++

Routine Description:

    Allocate the packet pool. Note there are no buffers associated with this pool.

Arguments:

    Adapter - pointer to adapter context block

Return Value:

    None

--*/

{
    NDIS_STATUS Status;
    PNDIS_PACKET Packet;
    ULONG ErrorLogData[2];
    ULONG i;
    ULONG ProtoReservedSize;

    NdisInitializeSListHead( &Adapter->PacketSList );
    NdisAllocateSpinLock( &Adapter->PacketSListLock );

    //
    // figure the amount of space we need in the protocol reserved area.
    //

    ProtoReservedSize =  sizeof( IM_PACKET_CONTEXT );

    NdisAllocatePacketPool(&Status,
                           &Adapter->PacketPoolHandle,
                           ConfigData.PacketPoolSize,
                           ProtoReservedSize);

    if ( NT_SUCCESS( Status )) {

        Adapter->ShutdownMask |= SHUTDOWN_DEALLOC_PACKET_POOL;

        for ( i = 0; i < ConfigData.PacketPoolSize; ++i ) {

            NdisAllocatePacket( &Status, &Packet, Adapter->PacketPoolHandle );

            if ( !NT_SUCCESS( Status )) {

                ErrorLogData[ 0 ] = IM_ERROR_PACKET;
                ErrorLogData[ 1 ] = Status;

                NdisWriteErrorLogEntry(Adapter->LowerMPHandle,
                                       NDIS_ERROR_CODE_OUT_OF_RESOURCES,
                                       2,
                                       ErrorLogData);

                return Status;
            }

            IMSetTag( IM_PACKET_CONTEXT_FROM_PACKET( Adapter, Packet ), PacketContext );
            NdisInterlockedPushEntrySList(&Adapter->PacketSList,
                                          (PSINGLE_LIST_ENTRY)Packet->ProtocolReserved,
                                          &Adapter->PacketSListLock);
        }
    } else {

        ErrorLogData[ 0 ] = IM_ERROR_PACKET_POOL;
        ErrorLogData[ 1 ] = Status;

        NdisWriteErrorLogEntry(Adapter->LowerMPHandle,
                               NDIS_ERROR_CODE_OUT_OF_RESOURCES,
                               2,
                               ErrorLogData);
    }

    return Status;

}   // AllocatePacketPool


STATIC NDIS_STATUS
AllocateReceiveBufferPools(
    PADAPTER Adapter
    )

/*++

Routine Description:

    Allocate two buffer pools, one used for header and lookahead data and the other
    for residual lookahead data

Arguments:

    Adapter - pointer to adapter context block

Return Value:

    None

--*/

{
    NDIS_STATUS Status;
    ULONG i;
    PVOID SysBuffer;
    PNDIS_BUFFER NdisBuffer;
    PIM_BUFFER_CONTEXT BufContext;
    ULONG HeaderSize;
    ULONG FrameSize;            // doesn't include the header
    NDIS_ERROR_CODE ErrorCode;
    ULONG ErrorLogData[2];

    //
    // max amount of data w/o the MAC header
    //

    Status = MakeLocalNdisRequest(Adapter,
                                  OID_GEN_MAXIMUM_FRAME_SIZE,
                                  &FrameSize,
                                  sizeof( FrameSize ),
                                  NULL);

    if ( !NT_SUCCESS( Status )) {

        ImDbgOut(DBG_FAILURE, DBG_PROTOCOL,
                 ("(%08X) AllocateReceiveBufferPool: Can't get frame size - Status %08X\n",
                  Adapter, Status));
        
        ErrorCode = NDIS_ERROR_CODE_MISSING_CONFIGURATION_PARAMETER;
        ErrorLogData[ 0 ] = IM_ERROR_MISSING_OID;
        ErrorLogData[ 1 ] = OID_GEN_MAXIMUM_FRAME_SIZE;

        goto ErrorExit;
    }

    //
    // this one includes the header
    //

    Status = MakeLocalNdisRequest(Adapter,
                                  OID_GEN_MAXIMUM_TOTAL_SIZE,
                                  &Adapter->TotalSize,
                                  sizeof( Adapter->TotalSize ),
                                  NULL);

    if ( !NT_SUCCESS( Status )) {

        ImDbgOut(DBG_FAILURE, DBG_PROTOCOL,
                 ("(%08X) AllocateReceiveBufferPool: Can't get total size - Status %08X\n",
                  Adapter, Status));
        
        ErrorCode = NDIS_ERROR_CODE_MISSING_CONFIGURATION_PARAMETER;
        ErrorLogData[ 0 ] = IM_ERROR_MISSING_OID;
        ErrorLogData[ 1 ] = OID_GEN_MAXIMUM_TOTAL_SIZE;

        goto ErrorExit;
    }

    //
    // figure the real header size
    //

    HeaderSize = Adapter->TotalSize - FrameSize;

    Status = MakeLocalNdisRequest(Adapter,
                                  OID_GEN_MAXIMUM_LOOKAHEAD,
                                  &Adapter->LookaheadBufferSize,
                                  sizeof( Adapter->LookaheadBufferSize ),
                                  NULL);

    if ( !NT_SUCCESS( Status )) {

        ImDbgOut(DBG_FAILURE, DBG_PROTOCOL,
                 ("(%08X) AllocateReceiveBufferPool: Can't get lookahead size - Status %08X\n",
                  Adapter, Status));
        
        ErrorCode = NDIS_ERROR_CODE_MISSING_CONFIGURATION_PARAMETER;
        ErrorLogData[ 0 ] = IM_ERROR_MISSING_OID;
        ErrorLogData[ 1 ] = OID_GEN_MAXIMUM_LOOKAHEAD;

        goto ErrorExit;
    }

    //
    // figure the buffer size for the lookahead buffers, which also include
    // the header. The residual buffer size is the total size, since the MP
    // can indicate less than the max lookahead buffer size, we need to be
    // prepared to receive the whole frame in the residual buffer. On the
    // other hand, the MP can indicate more than the lookahead size, so we
    // might bypass the lookahead buffer and just use a residual buffer on
    // the receive.
    //

    Adapter->LookaheadBufferSize += HeaderSize;

    //
    // init the lookahead buffer pool
    //

    NdisInitializeSListHead( &Adapter->LookaheadSList );
    NdisAllocateSpinLock( &Adapter->LookaheadSListLock );

    NdisAllocateBufferPool(&Status,
                           &Adapter->LookaheadPoolHandle,
                           ConfigData.LookaheadPoolSize);

    if ( !NT_SUCCESS( Status )) {

        ErrorCode = NDIS_ERROR_CODE_OUT_OF_RESOURCES;
        ErrorLogData[ 0 ] = IM_ERROR_LOOKAHEAD_POOL;
        ErrorLogData[ 1 ] = Status;

        goto ErrorExit;
    }

    Adapter->ShutdownMask |= SHUTDOWN_DEALLOC_LOOKAHEAD_POOL;

    for ( i = 0; i < ConfigData.LookaheadPoolSize; ++i ) {

        IMAllocatePoolNoStructTag( SysBuffer, Adapter->LookaheadBufferSize, LookaheadBuffer );

        if ( SysBuffer == NULL ) {

            ErrorCode = NDIS_ERROR_CODE_OUT_OF_RESOURCES;
            ErrorLogData[ 0 ] = IM_ERROR_VM_LOOKAHEAD_BUFFER;
            ErrorLogData[ 1 ] = (ULONG)NDIS_STATUS_RESOURCES;

            goto ErrorExit;
        }

        NdisAllocateBuffer(&Status,
                           &NdisBuffer,
                           Adapter->LookaheadPoolHandle,
                           SysBuffer,
                           Adapter->LookaheadBufferSize);

        if ( !NT_SUCCESS( Status )) {

            ErrorCode = NDIS_ERROR_CODE_OUT_OF_RESOURCES;
            ErrorLogData[ 0 ] = IM_ERROR_LOOKAHEAD_BUFFER;
            ErrorLogData[ 1 ] = Status;

            goto ErrorExit;
        }

        //
        // use the VM area to store a pointer back to the NDIS buffer and link it
        // onto the S List.
        //

        BufContext = (PIM_BUFFER_CONTEXT)SysBuffer;
        BufContext->NdisBuffer = NdisBuffer;

        NdisInterlockedPushEntrySList(&Adapter->LookaheadSList,
                                      &BufContext->SListEntry,
                                      &Adapter->LookaheadSListLock);
    }

    //
    // same thing for the residual buffer pool
    //

    NdisInitializeSListHead( &Adapter->ResidualSList );
    NdisAllocateSpinLock( &Adapter->ResidualSListLock );

    NdisAllocateBufferPool(&Status,
                           &Adapter->ResidualPoolHandle,
                           ConfigData.ResidualPoolSize);

    if ( !NT_SUCCESS( Status )) {

        ErrorCode = NDIS_ERROR_CODE_OUT_OF_RESOURCES;
        ErrorLogData[ 0 ] = IM_ERROR_RESIDUAL_POOL;
        ErrorLogData[ 1 ] = Status;

        goto ErrorExit;
    }

    Adapter->ShutdownMask |= SHUTDOWN_DEALLOC_RESIDUAL_POOL;

    for ( i = 0; i < ConfigData.ResidualPoolSize; ++i ) {

        IMAllocatePoolNoStructTag( SysBuffer, Adapter->TotalSize, ResidualBuffer );

        if ( SysBuffer == NULL ) {

            ErrorCode = NDIS_ERROR_CODE_OUT_OF_RESOURCES;
            ErrorLogData[ 0 ] = IM_ERROR_VM_RESIDUAL_BUFFER;
            ErrorLogData[ 1 ] = (ULONG)NDIS_STATUS_RESOURCES;

            goto ErrorExit;
        }

        NdisAllocateBuffer(&Status,
                           &NdisBuffer,
                           Adapter->ResidualPoolHandle,
                           SysBuffer,
                           Adapter->TotalSize);

        if ( !NT_SUCCESS( Status )) {

            ErrorCode = NDIS_ERROR_CODE_OUT_OF_RESOURCES;
            ErrorLogData[ 0 ] = IM_ERROR_RESIDUAL_BUFFER;
            ErrorLogData[ 1 ] = Status;

            goto ErrorExit;
        }

        //
        // use the VM area to store a pointer back to the NDIS buffer and link it
        // onto the S List.
        //

        BufContext = (PIM_BUFFER_CONTEXT)SysBuffer;
        BufContext->NdisBuffer = NdisBuffer;

        NdisInterlockedPushEntrySList(&Adapter->ResidualSList,
                                      &BufContext->SListEntry,
                                      &Adapter->ResidualSListLock);
    }

    return Status;

    //
    // when things go awry
    //

ErrorExit:

    NdisWriteErrorLogEntry( Adapter->LowerMPHandle, ErrorCode, 2, ErrorLogData );
    return Status;

}   // AllocateReceiveBufferPool






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:

    Imsample's device initialization routine. The list of media types is
    checked to be sure it is one that we support. If so, match up the name of
    the device being opened with one of the adapters to which we've bound.

Arguments:

    See the DDK...

Return Values:

    None

--*/

{
    NDIS_HANDLE ConfigHandle;
    NDIS_STATUS Status;
    NDIS_STRING IMInstanceNumberKey = NDIS_STRING_CONST( "InstanceNumber" );
    PNDIS_CONFIGURATION_PARAMETER ConfigParam;
    ULONG IMInstanceNumber;
    PLIST_ENTRY NextAdapter;
    PADAPTER AdapterInList;
    ULONG ErrorLogData[2];

    ImDbgOut(DBG_TRACE, DBG_MINIPORT, ("MPInitialize: Enter\n"));

    //
    // open registry and look at keys in the MP device instance. we need to figure out
    // which instance we're initializing. The setup junk put in InstanceNumber so we
    // can figure this out at this time. We pick up other instance specific info at
    // this time. We have to do this locally, since we don't have a pointer to the
    // adapter context struct that is associated with this initialization
    //

    NdisOpenConfiguration( &Status, &ConfigHandle, WrapperConfigurationContext );

    if ( !NT_SUCCESS( Status )) {

        return Status;
    }

  
 // Read the instance number. For example, if we are initializing ImSampMP4, then this should return
 // the number stores in CurrentControlSet/Services/ImSampMP4/Parameters/InstanceNumber, which should be a 4
  
    NdisReadConfiguration(&Status,
                          &ConfigParam,
                          ConfigHandle,
                          &IMInstanceNumberKey,
                          NdisParameterInteger);


    if ( !NT_SUCCESS( Status )) {

        ImDbgOut(DBG_FAILURE, DBG_MINIPORT | DBG_INIT,
                 ("MPInitialize: Missing InstanceNumber key\n"));

        ErrorLogData[ 0 ] = IM_ERROR_BAD_REGISTRY_DATA;
        ErrorLogData[ 1 ] = IM_ERROR_MISSING_IMSAMP_MP_INSTANCE_KEY;

        NdisWriteErrorLogEntry(MiniportAdapterHandle,
                               NDIS_ERROR_CODE_MISSING_CONFIGURATION_PARAMETER,
                               2,
                               ErrorLogData);

        NdisCloseConfiguration( ConfigHandle );
        return NDIS_STATUS_FAILURE;
    }

    IMInstanceNumber = ConfigParam->ParameterData.IntegerData;

    NdisCloseConfiguration( ConfigHandle );

    // We now know which adapter we are initializing (say ImSampMP4, for example)
    // look through our adapter list and match based on device instance
    // The adapter list is created when the protocol section opens the existing adapters below us.

    NdisAcquireSpinLock( &AdapterListLock );

    NextAdapter = AdapterList.Flink;
    while ( NextAdapter != &AdapterList ) {

        AdapterInList = CONTAINING_RECORD( NextAdapter, ADAPTER, Linkage );

        if ( AdapterInList->DevInstance == IMInstanceNumber ) {

            break;
        }

        NextAdapter = NextAdapter->Flink;
    }

    NdisReleaseSpinLock( &AdapterListLock );

    //
    // check that we really found a matching adapter
    //

    if ( NextAdapter == &AdapterList ) {

        // This means we have an IM MP entry that does not match up with an actual adapter. This is bad.   
        ImDbgOut(DBG_FAILURE, DBG_MINIPORT | DBG_INIT, ("Can't find adapter for MP dev # %d\n",
                                                        IMInstanceNumber));

        ErrorLogData[ 0 ] = IM_ERROR_BAD_REGISTRY_DATA;
        ErrorLogData[ 1 ] = IM_ERROR_INVALID_IMSAMP_MP_INSTANCE;

        NdisWriteErrorLogEntry(MiniportAdapterHandle,
                               NDIS_ERROR_CODE_MISSING_CONFIGURATION_PARAMETER,
                               2,
                               ErrorLogData);

        return NDIS_STATUS_FAILURE;
    }

    //
    // lookup our media type in the supplied media array
    //

    for (--MediumArraySize ; MediumArraySize > 0; ) {

        if ( MediumArray[ MediumArraySize ] == AdapterInList->MediaType ) {

            break;
        }

        if ( MediumArraySize == 0 ) {

            break;
        }

        --MediumArraySize;
    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕欧美激情一区| 国产98色在线|日韩| 久久91精品久久久久久秒播| 欧美国产精品久久| 亚洲三级在线免费| 欧美96一区二区免费视频| 国产成人在线观看| 欧美日韩中文另类| 久久久久久久久97黄色工厂| 玉米视频成人免费看| 日本美女一区二区| www.亚洲在线| 另类小说色综合网站| 99在线精品观看| 欧美成人激情免费网| 中文字幕欧美国产| 婷婷中文字幕综合| 成人毛片在线观看| 欧美一区二区三区免费在线看| 中日韩av电影| 免费看精品久久片| 91福利视频久久久久| 久久婷婷久久一区二区三区| 一区二区视频在线看| 精品夜夜嗨av一区二区三区| 在线一区二区三区| 国产精品丝袜久久久久久app| 日韩中文字幕不卡| 一本一道久久a久久精品| 欧美成人猛片aaaaaaa| 懂色av一区二区在线播放| 欧美精品在线一区二区三区| 国产精品久久久久久久久久久免费看 | 国产精品网站在线| 蜜臀91精品一区二区三区| 欧美综合天天夜夜久久| 中文字幕av不卡| 国内精品国产成人| 欧美另类变人与禽xxxxx| 亚洲精品免费在线播放| 国产成人鲁色资源国产91色综| 日韩一区二区三区在线| 亚洲影院在线观看| 91在线观看高清| 中文字幕欧美国产| 国产精一品亚洲二区在线视频| 69成人精品免费视频| 亚洲综合免费观看高清完整版在线| 国产99精品在线观看| 久久综合精品国产一区二区三区 | 欧美日韩一区二区三区不卡| 国产日韩精品视频一区| 国内偷窥港台综合视频在线播放| 欧美欧美欧美欧美| 亚洲www啪成人一区二区麻豆| 91麻豆国产在线观看| 自拍偷拍欧美精品| 成人av中文字幕| 中文字幕乱码一区二区免费| 国产综合色在线| 精品国免费一区二区三区| 麻豆精品视频在线观看免费 | 美女视频一区二区三区| 欧美精品精品一区| 五月婷婷综合在线| 欧美日韩国产综合一区二区| 亚洲综合久久久| 欧美中文字幕久久| 亚洲一区二区成人在线观看| 在线一区二区观看| 亚洲国产另类av| 欧美日韩久久久久久| 亚洲成人在线免费| 欧美一区日韩一区| 精品一区免费av| 久久综合中文字幕| 国产成人在线电影| 中文av字幕一区| 99国产精品久久| 亚洲欧美激情一区二区| 欧美性猛交一区二区三区精品| 亚洲精品日韩综合观看成人91| 色婷婷综合久久久久中文| 亚洲精品成a人| 欧美日本在线播放| 裸体一区二区三区| 久久精品夜色噜噜亚洲a∨| 成人一区在线看| 亚洲黄色免费网站| 69成人精品免费视频| 黑人精品欧美一区二区蜜桃 | 国产高清成人在线| 亚洲日本免费电影| 88在线观看91蜜桃国自产| 韩国v欧美v亚洲v日本v| 国产精品久久久久久久久果冻传媒 | 欧美v国产在线一区二区三区| 国产在线看一区| 免费高清成人在线| 久久精品视频免费| 97se亚洲国产综合自在线观| 亚洲制服欧美中文字幕中文字幕| 69av一区二区三区| 高清国产午夜精品久久久久久| 亚洲精品福利视频网站| 日韩美女在线视频| www.欧美日韩| 天天综合网 天天综合色| 久久久久久久性| 色国产精品一区在线观看| 美女被吸乳得到大胸91| 国产精品福利电影一区二区三区四区| 欧美视频完全免费看| 国产麻豆一精品一av一免费| 一区二区视频免费在线观看| 精品少妇一区二区三区在线播放| www.亚洲色图.com| 美女视频黄a大片欧美| 国产精品久线在线观看| 91精品黄色片免费大全| a4yy欧美一区二区三区| 美女视频黄免费的久久| 亚洲日本欧美天堂| 欧美精品一区二区蜜臀亚洲| 欧美在线看片a免费观看| 韩国中文字幕2020精品| 亚洲一区二区三区四区在线免费观看 | 一区二区三区免费| 欧美精品一区二区三区蜜桃| 日本韩国一区二区| 国产伦精品一区二区三区视频青涩 | aaa亚洲精品| 激情图片小说一区| 亚洲国产成人tv| 国产精品久久久久久久久果冻传媒 | 亚洲六月丁香色婷婷综合久久| 欧美一区二区不卡视频| 日本道精品一区二区三区 | 国产日韩精品一区| 日韩免费在线观看| 欧美日韩中文字幕精品| av中文字幕不卡| 国产精品一区在线观看乱码| 日本免费在线视频不卡一不卡二| 中文字幕一区二区三区四区| 精品国产一区二区国模嫣然| 欧美日韩免费高清一区色橹橹 | 国产精品成人网| 久久综合精品国产一区二区三区| 欧美精品免费视频| 欧美视频日韩视频在线观看| 99热99精品| 成人福利视频在线| 国产河南妇女毛片精品久久久| 毛片一区二区三区| 图片区日韩欧美亚洲| 亚洲最大的成人av| 亚洲欧美一区二区三区极速播放 | 97精品国产97久久久久久久久久久久 | 欧美日韩视频一区二区| 色婷婷av一区二区| www.日韩精品| 成人h版在线观看| 国产成人在线免费观看| 激情综合色综合久久| 久久电影国产免费久久电影| 免费成人在线视频观看| 日韩高清不卡一区二区| 性久久久久久久| 午夜激情一区二区| 丝袜脚交一区二区| 五月天丁香久久| 日本一区中文字幕| 日韩电影在线一区| 日本视频在线一区| 捆绑紧缚一区二区三区视频| 奇米777欧美一区二区| 狂野欧美性猛交blacked| 另类小说欧美激情| 国产美女av一区二区三区| 国产一区二区在线免费观看| 国内精品伊人久久久久av一坑| 韩国精品主播一区二区在线观看| 九色综合狠狠综合久久| 黑人精品欧美一区二区蜜桃 | 国产精品久久久久婷婷| 国产精品久久久久久久久图文区| 成人欧美一区二区三区视频网页| ...xxx性欧美| 亚洲一二三四在线| 亚洲成av人片在线| 欧美aaaaaa午夜精品| 经典三级视频一区| 精品一区二区三区日韩| 国产精品影视天天线| heyzo一本久久综合| 色一情一伦一子一伦一区| 欧美色图在线观看| 欧美日韩成人一区| 久久综合久色欧美综合狠狠|