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

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

?? pppmuxadapter.c

?? 這是全套的PPP協議的源碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
/* pppMuxAdapter.c - MUX Adapter component for PPP over END devices *//* Copyright 2003 Wind River Systems, Inc. */#include "copyright_wrs.h"/*modification history--------------------02e,10jun03,ijm use STACK_NAME to distinguish network stacks02d,14may03,ijm fixed diab compiler warning02c,29oct02,ijm use PPP_MUX_ADAPTER_MAX_BINDS, instead of muxMaxBinds,                for IPv4/IPv6 stack02b,27aug02,ijm fixed gnu warnings02a,20aug02,ijm fixed diab compiler warnings01z,15jul02,rp  rfc2233 counters not getting correctly updated SPR 7374601y,17jul02,ijm discontinue use of NET_PROTOCOL01x,15jul02,rp  multi-service support and muxCookie changes01w,12apr01,sj  added muxL2SvcType parameter01v,12mar01,ijm added mutual exclusion to slot selection in muxAdptrStackAdd                and muxAdptrStackDel01u,07mar01,ijm muxAdptrBindInfoFind should not increase bindInfo reference count01t,30jan01,sj  protocol may bind only once across all framework stacks              	if FRAMING_COMPONENT_STACK_RESOLVE interface is not provided01s,21dec00,sj  release state only if locked01r,20dec00,sj  on failure to lock state in RestartRtn delete node from list01q,17dec00,sj  add stacks to txBlockedList on END_ERR_BLOCKED01p,17dec00,sj  raise PPP_SUB_LAYER_TX_BLOCKED event on END_ERR_BLOCKED and                 undo blocked condition by raising PPP_SUB_LAYER_TX_UNBLOCKED01o,29sep00,sj  Merging in and reorganizing RFC2233 instrumentation01n,29sep00,sj  merging with TOR2_0-WINDNET_PPP-CUM_PATCH_201m,06sep00,cn   free dstAddr string in muxAdptrStackDataDestruct () SPR# 34219.01l,02aug00,adb  Merging in LAC modifications01k,01aug00,adb  Merging with openstack view except RFC 223301j,31jul00,md  initializes collectPppAttributesEvent01i,28jul00,md  initialize ppp attributes to a default value01h,11jul00,md  subscribed COLLECT_PPP_ATTRIBUTES_EVENT01g,10mar00,sj  interfaceReferenceDelete needs to be done only once01f,16nov99,sj  increment bindInfo refCount for each attempt to bind01e,14sep99,sj  adding events01d,12aug99,sj  reworked for generic framework; 01c,19jul99,sj  disabled loopback mode added macros for freeing packets01b,19jul99,sj  successfully tested PPPOE under loopback mode01a,02jul99,sj 	created*//*DESCRIPTIONThis component enables PPP sessions over END/NPT devices via the MUX. BeforePPP sessions over the END/NPT devices can be established, this adapter componentmust be added to the PPP framework.This component provides a generic interface to the MUX for the PPP frameworkto communicate via END/NPT devices in the system.INCLUDE FILES:  muxLib.h muxTkLib.h*/#include "vxWorks.h"#include "pfw/pfw.h"#include "logLib.h"#include "errnoLib.h"#include "stdio.h"#include "stdlib.h"#include "string.h"#include "ctype.h"#include "memLib.h"#include "semLib.h"#include "sllLib.h"#include "inetLib.h"#include "hostLib.h"#include "end.h"#include "muxLib.h"#include "netBufLib.h"#include "private/muxLibP.h"#include "muxTkLib.h"#include "pfw/pfwStack.h"#include "pfw/pfwProfile.h"#include "pfw/pfwComponent.h"#include "pfw/pfwEvent.h"#include "pfw/pfwLayer.h"#include "pfw/pfwInterface.h"#include "pfw/pfwMemory.h"#include "ppp/kppp.h"#include "ppp/pppLacStructures.h"#include "ppp/pppMuxAdapter.h"#include "ppp/interfaces/framingComponentInterfaces.h"#include "ppp/interfaces/adapterComponentInterfaces.h"#include "ppp/interfaces/pppInterfacesGroupInterfaces.h"/* defines *//* max number of protocols per stack that this adapter has to deal with*/#define MAX_MUX_ADPTR_SERVICES 6#define MUX_FREE_PKT netMblkClChainFree#define MUX_STACK_ADD_DONE(state)\	{\	MUX_ADPTR_STACK_DATA * stack =(MUX_ADPTR_STACK_DATA *)state->stackData;\	\	if (stack->callbacks && stack->callbacks->stackAddComplete)\	    (*stack->callbacks->stackAddComplete) (stack->callbacks,state);\	}#define MUX_STACK_DELETE_DONE(state)\	{\	MUX_ADPTR_STACK_DATA * stack =(MUX_ADPTR_STACK_DATA *)state->stackData;\	\	if (stack->callbacks && stack->callbacks->stackDeleteComplete)\	    (*stack->callbacks->stackDeleteComplete) (stack->callbacks,state);\	}#define MUX_ADPTR_STACK_ADD_ERROR(state)\	{\	MUX_ADPTR_STACK_DATA * stack =(MUX_ADPTR_STACK_DATA *)state->stackData;\	\	if (stack->callbacks && stack->callbacks->stackAddError)\	    (*stack->callbacks->stackAddError)\				    (stack->callbacks,state);\	}/* typedefs */typedef struct muxAdptrBindInfo    {    int refCount;                              /* number of stacks using this */    void * cookie;		               /* binding instance handle */    PFW_INTERFACE_STATE_PAIR stackObjResolver; /* stack resolver data */    PFW_PLUGIN_OBJ * pluginObj;                /* reference to this component*/    SL_LIST          txBlockedList;            /* stacks blocked for send */    ULONG            portId;                   /* port id for adapterPortIdGet */    long             netSvcType;               /* network service type */    int              unitNo;                   /* unit number of the device */    char             devName[END_NAME_MAX];    /* device name */    } MUX_ADPTR_BIND_INFO;/* MUX adapter profile data */typedef struct muxAdptrProfileData    {    char muxDevName[END_NAME_MAX];    int muxDevUnit;    int muxNumSvcs;    UINT32 muxL2SvcType;    UINT32 muxSvcType[MAX_MUX_ADPTR_SERVICES];    } MUX_ADPTR_PROFILE_DATA;/* MUX adapter connection data */typedef struct muxAdptrStackData    {    SL_NODE node;           /* this is how we stay on txBlocked List */    MUX_ADPTR_BIND_INFO * bindInfoCache;/* bind info cache for currently */                                        /* sending protocol */    UINT32 nboProtocol;     /* protocol number in network byte order */    char * destAddr;        /* current send destination */    UINT32 destAddrLen;     /* current send destination add length*/    PFW_INTERFACE_STATE_PAIR resolverInterface; /* stack resolver data */    PFW_PLUGIN_OBJ_CALLBACKS * callbacks;    PFW_PLUGIN_OBJ_STATE * state; /* back pointer to state */    int bindInfoIndex[MAX_MUX_ADPTR_SERVICES]; /* bind info for each protocol */    BOOL            txBlocked; /* set when muxTkSend returns END_ERR_BLOCKED */    PFW_EVENT_OBJ *collectPppAttributesEvent;    PFW_EVENT_OBJ * txBlockedEvent;     PFW_EVENT_OBJ * txUnblockedEvent;     ULONG           portId;    /* auxiliary variables aiding RFC 2233 counters's implementation */    int    pfwAuxIfId;    PFW_INTERFACE_STATE_PAIR pfwRFC2233CountPair;    BOOL   pfwRFC2233CountTest;    } MUX_ADPTR_STACK_DATA;LOCAL STATUS muxPPPAttributesEventHandler    (    PFW_PLUGIN_OBJ_STATE * state,    void *eventData    );typedef struct muxAdptrParams    {    char * name;    PFW_PARAMETER_HANDLER handler;    } MUX_ADPTR_PARAMS;typedef struct muxAdptrComponent    {    PFW_COMPONENT_OBJ component;    int muxMaxBinds;    SEM_ID muxAdptrMutex;       MUX_ADPTR_BIND_INFO * bindInfo;    ADAPTER_DESTINATION_AND_PROTOCOL_SET_INTERFACE adapterInterface;    ADAPTER_INFO_GET_INTERFACE adapterInfoGetInterface;    }MUX_ADPTR_COMPONENT;/* externs */#if (!((defined STACK_NAME) && (STACK_NAME == STACK_NAME_V4_V6)))IMPORT int muxMaxBinds; /* maximum number of binds configured in the system */#endif /* (!((defined STACK_NAME) && (STACK_NAME == STACK_NAME_V4_V6))) *//* globals *//* forward declarations *//* component interface */LOCAL STATUS muxAdptrProfileDataConstruct (PFW_OBJ *,void *);LOCAL STATUS muxAdptrStackDataConstruct (PFW_OBJ *,void *stackData,							void * profileData);LOCAL STATUS muxAdptrStackDataDestruct (PFW_OBJ *, void *stackData,							void * profileData);LOCAL STATUS muxAdptrStackAdd(PFW_PLUGIN_OBJ_STATE*,PFW_PLUGIN_OBJ_CALLBACKS *);LOCAL STATUS muxAdptrStackDel (PFW_PLUGIN_OBJ_STATE *);LOCAL STATUS muxAdptrSend (PFW_PLUGIN_OBJ_STATE *, M_BLK_ID *);LOCAL STATUS muxAdptrStackDataShow (PFW_PLUGIN_OBJ_STATE *);LOCAL STATUS muxAdptrInterfaceBind (PFW_PLUGIN_OBJ *);/* paramter handlers */LOCAL STATUS muxAdptr_muxDevName(PFW_OBJ *, PFW_PARAMETER_OPERATION_TYPE,								void *, char *);LOCAL STATUS muxAdptr_muxDevUnit(PFW_OBJ *,PFW_PARAMETER_OPERATION_TYPE,								void *, char *);LOCAL STATUS muxAdptr_muxSvcType(PFW_OBJ *,PFW_PARAMETER_OPERATION_TYPE,								void *, char *);LOCAL STATUS muxAdptr_muxL2SvcType(PFW_OBJ *,PFW_PARAMETER_OPERATION_TYPE,								void *, char *);/* MUX NPT callback routines */LOCAL BOOL muxAdptrRecvRtn (void *, long, M_BLK_ID, void *);LOCAL STATUS muxAdptrShutdownRtn (void *);LOCAL STATUS muxAdptrTxRestartRtn (void *);LOCAL void muxAdptrErrorRtn (void *, END_ERR *);/* MUX END callback routines */LOCAL BOOL muxAdptrEndRecvRtn (void * cookie, long, M_BLK_ID, LL_HDR_INFO *,								void* pSpare);LOCAL STATUS muxAdptrEndShutdownRtn (void* cookie, void * pSpare);LOCAL STATUS muxAdptrEndTxRestartRtn  (void * cookie, void * pSpare);LOCAL void muxAdptrEndErrorRtn (END_OBJ * cookie, END_ERR *, void * pSpare);/* utilities */LOCAL int muxAdptrBindInfoFind (MUX_ADPTR_COMPONENT *,						char * devName, int unit,						int protocol);LOCAL STATUS muxAdptrBindInfoClear ( MUX_ADPTR_BIND_INFO *pBindInfo,				     MUX_ADPTR_STACK_DATA *pStackData);    /* interfaces */LOCAL STATUS destAddrAndProtocolSet			   (			    PFW_PLUGIN_OBJ_STATE *adapterState,			    char * destAddr,			    UINT32 addrLength,			    char * protocol,			    UINT32 protocolLength			   );LOCAL STATUS adapterPortIdGet                          (                          PFW_PLUGIN_OBJ_STATE * pAdapterState,                          ULONG *                pPortId                          );/* locals */LOCAL MUX_ADPTR_PARAMS muxAdptrParams[] = 			{{"muxDevName",muxAdptr_muxDevName},			 {"muxDevUnit",muxAdptr_muxDevUnit},		     {"muxL2SvcType",muxAdptr_muxL2SvcType},			 {"muxSvcType",muxAdptr_muxSvcType}};LOCAL int numMuxAdptrParams = NELEMENTS (muxAdptrParams);/******************************************************************************** muxAdapterCreate - add the MUX adapter component to the PPP framework** This function should be called to add the MUX adapter to the PPP framework* if PPP connections have to be established over END/NPT devices.* This adapter is a generic component which interfaces the PPP framework with* any END/NPT device in the system** RETURNS: OK on success and ERROR otherwise*/STATUS muxAdapterCreate    (    PFW_OBJ * pfw	/* framework we are adding ourselves to */    )    {    int i = 0;    MUX_ADPTR_COMPONENT *pComponent;    PFW_PLUGIN_OBJ * muxAdptrPluginObj = NULL;    int pppMuxMaxBinds;    if (pfw == NULL)	{        logMsg ("muAdapterCreate: Framework is NULL\n",                 1,2,3,4,5,6);	return ERROR;	}    /* allocate the component object */    if ( (pComponent = pfwMalloc(pfw,sizeof(MUX_ADPTR_COMPONENT))) == NULL)        {        logMsg ("muxAptrCreate: Could not malloc memory for MUX ADAPTER component\n",                 1,2,3,4,5,6);	return ERROR;        }    bzero((void *)pComponent,sizeof(MUX_ADPTR_COMPONENT));    if ((pComponent->muxAdptrMutex = semMCreate(SEM_Q_PRIORITY)) == NULL)        {        pfwFree (pComponent);        logMsg ("muxAptrCreate: Could not create semaphore for MUX ADAPTER component\n",                 1,2,3,4,5,6);        return ERROR;        }    muxAdptrPluginObj = (PFW_PLUGIN_OBJ *)&(pComponent->component);    /* initialize our component object */    bzero(muxAdptrPluginObj->name, PFW_MAX_NAME_LENGTH);    strncpy(muxAdptrPluginObj->name,"MUX_ADAPTER",	    (PFW_MAX_NAME_LENGTH -1));    muxAdptrPluginObj->pfwObj = pfw;    muxAdptrPluginObj->profileDataSize = sizeof (MUX_ADPTR_PROFILE_DATA);    muxAdptrPluginObj->stackDataSize = sizeof (MUX_ADPTR_STACK_DATA);    muxAdptrPluginObj->profileDataConstruct = muxAdptrProfileDataConstruct;    muxAdptrPluginObj->profileDataCopy = NULL;    muxAdptrPluginObj->profileDataDestruct = NULL;    muxAdptrPluginObj->stackDataConstruct = muxAdptrStackDataConstruct;    muxAdptrPluginObj->stackDataDestruct = muxAdptrStackDataDestruct;    muxAdptrPluginObj->interfaceBind = muxAdptrInterfaceBind;    muxAdptrPluginObj->receive = NULL;    muxAdptrPluginObj->send = muxAdptrSend;    muxAdptrPluginObj->stackAdd = muxAdptrStackAdd;    muxAdptrPluginObj->stackDelete = muxAdptrStackDel;    muxAdptrPluginObj->stackDataShow = muxAdptrStackDataShow;    pComponent->component.protocol = 0;    pComponent->component.layerObj = pfwLayerObjGet(pfw, "ADAPTER_LAYER");    /* register this component with the framework */    if (pfwComponentAdd (&pComponent->component) == ERROR)        {        logMsg ("muxAdapterCreate: Could not add MUX ADAPTER component\n",                 1,2,3,4,5,6);        semDelete (pComponent->muxAdptrMutex);        pfwFree (pComponent);        return (ERROR);        }    /* add our parameters to the framework */    for (i = 0; i < numMuxAdptrParams ; i++)	{        if (pfwParameterAdd ((PFW_PLUGIN_OBJ *)pComponent,			muxAdptrParams[i].name, muxAdptrParams[i].handler)			== ERROR)	    {	    logMsg ("muxAdapterCreate - Parameter %s could not be added\n",	    (int)muxAdptrParams[i].name,2,3,4,5,6);	    return (ERROR);	    }	}    /* allocate memory for the bindInfo Array */#if ((defined STACK_NAME) && (STACK_NAME == STACK_NAME_V4_V6))    pppMuxMaxBinds = PPP_MUX_ADAPTER_MAX_BINDS;#else    pppMuxMaxBinds = muxMaxBinds;#endif /* ((defined STACK_NAME) && (STACK_NAME == STACK_NAME_V4_V6)) */    if ((pComponent->bindInfo = (MUX_ADPTR_BIND_INFO *) pfwMalloc		(pfw,pppMuxMaxBinds * sizeof(MUX_ADPTR_BIND_INFO))) == NULL)        {        logMsg ("muxAdapterCreate: Could not malloc memory for bindInfo\n",                 1,2,3,4,5,6);	return ERROR;        }    bzero((void *)pComponent->bindInfo, 		pppMuxMaxBinds * sizeof(MUX_ADPTR_BIND_INFO));    pComponent->muxMaxBinds = pppMuxMaxBinds;    return OK;    }/******************************************************************************** muxAdapterDelete - delete the MUX adapter component from the framework** The MUX_ADAPTER plug-in component object allocated by muxAdapterCreate() is * freed if there are no references to this object from a * Stack or Profile object in the framework.** RETURNS: OK or ERROR*/STATUS muxAdapterDelete    (    PFW_OBJ * pfw	/* framework we are deleting this from */    )    {    PFW_COMPONENT_OBJ *pComponent;    MUX_ADPTR_COMPONENT * muxComponent;    pComponent = pfwComponentObjGetByName(pfw,"MUX_ADAPTER");    if (pComponent == NULL)	return ERROR;    if (pfwComponentDelete(pComponent) != OK)	return ERROR;    muxComponent = (MUX_ADPTR_COMPONENT *)pComponent;    pfwFree(muxComponent->bindInfo);    semDelete (muxComponent->muxAdptrMutex);    pfwFree(pComponent);    return OK;    }/******************************************************************************** muxAdptrProfileDataConstruct - initialize component parameter default values** This function is called by the framework to get default values for the* parameters managed and supported by this component** RETURNS: OK on success and ERROR otherwise*/LOCAL STATUS muxAdptrProfileDataConstruct    (    PFW_OBJ *pfw,    void * pProfileData 	/* reference to this component's profile data */    )    {    MUX_ADPTR_PROFILE_DATA * pMuxAdptrData = 					(MUX_ADPTR_PROFILE_DATA *)pProfileData;    /* start with a clean slate */    bzero ((void *)pMuxAdptrData, sizeof(MUX_ADPTR_PROFILE_DATA));    return OK;    }/******************************************************************************** muxAdptrStackDataDestruct - clean up stack data** This function is called by the framework at the time this component* is being removed from a stack for the purpose of cleaning up the stack Data* which includes freeing of any memory that may have been allocated** RETURNS: OK on success and ERROR otherwise

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美中文字幕一二三区视频| 99国产精品视频免费观看| 日韩一区欧美一区| 国产精品国产成人国产三级 | 成人黄色免费短视频| 国产一区91精品张津瑜| 国产久卡久卡久卡久卡视频精品| 久久精品国产免费| 久久国产精品无码网站| 日本美女一区二区三区| 美女国产一区二区三区| 久久爱www久久做| 精品一区免费av| 丰满岳乱妇一区二区三区| 99视频一区二区三区| 91久久久免费一区二区| 91精品国产手机| 久久影视一区二区| 欧美一区二区精品在线| 麻豆精品国产91久久久久久| 久久久久高清精品| 久久久99免费| 制服丝袜中文字幕亚洲| 久热成人在线视频| 国产毛片精品一区| 色屁屁一区二区| 日本一区二区三级电影在线观看| 国产欧美一区二区三区网站| 中文字幕中文字幕在线一区| 一区二区三区在线影院| 蜜臀久久久99精品久久久久久| 国产精品白丝jk黑袜喷水| 99久久久精品| 欧美一级在线免费| 国产精品久久久久久一区二区三区| 亚洲欧美自拍偷拍色图| 日本不卡视频一二三区| 国产麻豆视频一区| 欧美怡红院视频| 中文字幕乱码日本亚洲一区二区| 亚洲综合色婷婷| 国产一区二区电影| 欧美人成免费网站| 国产精品久久久久久久久果冻传媒 | 国产欧美日韩在线看| 玉米视频成人免费看| 国产伦精品一区二区三区视频青涩| 91国偷自产一区二区使用方法| 26uuu色噜噜精品一区| 亚洲午夜电影在线| 99免费精品视频| 久久久亚洲精华液精华液精华液| 粉嫩aⅴ一区二区三区四区五区| 欧美视频日韩视频在线观看| 国产精品―色哟哟| 国产在线日韩欧美| 3atv一区二区三区| 亚洲国产成人91porn| 色av成人天堂桃色av| 国产精品国产三级国产普通话三级| 日本伊人午夜精品| 在线观看国产精品网站| 国产精品久久久久桃色tv| 国产综合久久久久久鬼色 | 欧美在线观看视频在线| 亚洲三级电影全部在线观看高清| 极品销魂美女一区二区三区| 日韩一区二区三区免费观看| 亚洲中国最大av网站| 91免费精品国自产拍在线不卡| 国产婷婷色一区二区三区四区| 韩国中文字幕2020精品| 在线成人免费视频| 亚洲sss视频在线视频| 在线免费不卡视频| 夜夜精品浪潮av一区二区三区 | 精品国产第一区二区三区观看体验| 亚洲一区免费在线观看| 欧美日韩一区二区三区视频| 亚洲成人动漫在线观看| 欧美区视频在线观看| 丝袜美腿亚洲综合| 欧美久久一二三四区| 天堂va蜜桃一区二区三区漫画版| 欧美色图片你懂的| 日本aⅴ亚洲精品中文乱码| 日韩欧美国产午夜精品| 国精产品一区一区三区mba视频| 久久久久久99精品| 成人av免费观看| 亚洲精品一二三| 欧美日韩高清一区二区三区| 一二三区精品福利视频| 欧美福利电影网| 国产真实乱子伦精品视频| 国产色婷婷亚洲99精品小说| 99热这里都是精品| 偷拍一区二区三区四区| 久久久九九九九| 色综合一个色综合| 日韩av在线发布| 亚洲国产精品传媒在线观看| 97aⅴ精品视频一二三区| 亚洲国产精品一区二区久久 | 日本va欧美va精品| 国产欧美精品一区aⅴ影院| 色婷婷国产精品| 另类人妖一区二区av| 中文字幕日本乱码精品影院| 欧美在线影院一区二区| 麻豆精品视频在线观看| 国产精品美日韩| 欧美自拍偷拍一区| 国产麻豆9l精品三级站| 亚洲天堂免费在线观看视频| 欧美日韩精品二区第二页| 国产精品1区二区.| 亚洲一区二区高清| 国产日韩欧美麻豆| 69堂成人精品免费视频| 国产精品18久久久久久久久久久久| 亚洲欧美成aⅴ人在线观看| 日韩欧美中文字幕一区| 日本伦理一区二区| 国产凹凸在线观看一区二区| 三级久久三级久久| 亚洲男同1069视频| 中文幕一区二区三区久久蜜桃| 欧美肥胖老妇做爰| 欧美亚洲综合网| 91原创在线视频| 国产91丝袜在线播放九色| 九九视频精品免费| 蜜桃在线一区二区三区| 亚洲va欧美va天堂v国产综合| 18欧美乱大交hd1984| 中文字幕高清一区| 久久精品一区二区三区不卡| 日韩一区二区在线播放| 欧美三级视频在线播放| 91成人在线观看喷潮| 不卡高清视频专区| 99久久国产综合精品麻豆| 成人夜色视频网站在线观看| 国产精品正在播放| 国产 日韩 欧美大片| 国产成人超碰人人澡人人澡| 国产精品香蕉一区二区三区| 美女一区二区视频| 精品一区二区在线免费观看| 精品一区二区三区不卡| 国产另类ts人妖一区二区| 国产一区二区免费在线| 国产精品一区二区在线观看网站| 国产精品综合在线视频| 国产传媒欧美日韩成人| 大桥未久av一区二区三区中文| 国产成人免费高清| 91日韩一区二区三区| 欧美性videosxxxxx| 91精品在线免费| 精品国产伦一区二区三区观看体验 | 中文字幕一区二区三区四区不卡| 久久综合国产精品| 亚洲国产精品精华液ab| 欧美极品xxx| 最新国产精品久久精品| 国产精品久久毛片| 亚洲欧洲综合另类在线| 亚洲午夜成aⅴ人片| 久久66热偷产精品| av亚洲精华国产精华精| 色综合欧美在线| 制服丝袜中文字幕一区| 久久色.com| 国产精品理论片| 石原莉奈在线亚洲二区| 国产盗摄视频一区二区三区| 不卡视频在线观看| 制服丝袜亚洲色图| 国产精品免费免费| 丝袜诱惑制服诱惑色一区在线观看| 蜜臀av在线播放一区二区三区| 成人亚洲精品久久久久软件| 欧美日韩在线一区二区| 久久久午夜精品理论片中文字幕| 亚洲人被黑人高潮完整版| 免费成人你懂的| 色综合天天天天做夜夜夜夜做| 欧美一二三在线| 亚洲三级在线看| 激情丁香综合五月| 欧美性一区二区| 国产精品免费视频一区| 免费观看在线综合| 一本大道久久a久久综合婷婷 | 国产精品视频免费| 免费观看91视频大全| 91丨九色丨蝌蚪丨老版| 久久影院视频免费|