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

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

?? ixnpedlnpemgr.c

?? UBOOT 源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/** * @file IxNpeDlNpeMgr.c * * @author Intel Corporation * @date 09 January 2002 * * @brief This file contains the implementation of the private API for the *        IXP425 NPE Downloader NpeMgr module * *  * @par * IXP400 SW Release version 2.0 *  * -- Copyright Notice -- *  * @par * Copyright 2001-2005, Intel Corporation. * All rights reserved. *  * @par * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * 3. Neither the name of the Intel Corporation nor the names of its contributors *    may be used to endorse or promote products derived from this software *    without specific prior written permission. *  * @par * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS'' * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. *  * @par * -- End of Copyright Notice --*//* * Put the user defined include files required. *//* * Put the user defined include files required. */#include "IxOsal.h"#include "IxNpeDl.h"#include "IxNpeDlNpeMgr_p.h"#include "IxNpeDlNpeMgrUtils_p.h"#include "IxNpeDlNpeMgrEcRegisters_p.h"#include "IxNpeDlMacros_p.h"#include "IxFeatureCtrl.h"/* * #defines and macros used in this file. */#define IX_NPEDL_BYTES_PER_WORD                   4/* used to read download map from version in microcode image */#define IX_NPEDL_BLOCK_TYPE_INSTRUCTION           0x00000000#define IX_NPEDL_BLOCK_TYPE_DATA                  0x00000001#define IX_NPEDL_BLOCK_TYPE_STATE                 0x00000002#define IX_NPEDL_END_OF_DOWNLOAD_MAP              0x0000000F/* * masks used to extract address info from State information context * register addresses as read from microcode image  */#define IX_NPEDL_MASK_STATE_ADDR_CTXT_REG         0x0000000F#define IX_NPEDL_MASK_STATE_ADDR_CTXT_NUM         0x000000F0/* LSB offset of Context Number field in State-Info Context Address */#define IX_NPEDL_OFFSET_STATE_ADDR_CTXT_NUM       4/* size (in words) of single State Information entry (ctxt reg address|data) */#define IX_NPEDL_STATE_INFO_ENTRY_SIZE            2 #define IX_NPEDL_RESET_NPE_PARITY  0x0800 #define IX_NPEDL_PARITY_BIT_MASK   0x3F00FFFF #define IX_NPEDL_CONFIG_CTRL_REG_MASK  0x3F3FFFFF/* * Typedefs whose scope is limited to this file. */typedef struct{    UINT32 type;    UINT32 offset;} IxNpeDlNpeMgrDownloadMapBlockEntry;typedef union{    IxNpeDlNpeMgrDownloadMapBlockEntry block;    UINT32 eodmMarker;} IxNpeDlNpeMgrDownloadMapEntry;typedef struct{    /* 1st entry in the download map (there may be more than one) */    IxNpeDlNpeMgrDownloadMapEntry entry[1];} IxNpeDlNpeMgrDownloadMap;/* used to access an instruction or data block in a microcode image */typedef struct{    UINT32 npeMemAddress;    UINT32 size;    UINT32 data[1];} IxNpeDlNpeMgrCodeBlock;/* used to access each Context Reg entry state-information block */typedef struct{    UINT32 addressInfo;    UINT32 value;} IxNpeDlNpeMgrStateInfoCtxtRegEntry;/* used to access a state-information block in a microcode image */typedef struct{    UINT32 size;    IxNpeDlNpeMgrStateInfoCtxtRegEntry ctxtRegEntry[1];} IxNpeDlNpeMgrStateInfoBlock; /* used to store some useful NPE information for easy access */typedef struct{    UINT32 baseAddress;    UINT32 insMemSize;    UINT32 dataMemSize;} IxNpeDlNpeInfo;/* used to distinguish instruction and data memory operations */typedef enum {  IX_NPEDL_MEM_TYPE_INSTRUCTION = 0,  IX_NPEDL_MEM_TYPE_DATA} IxNpeDlNpeMemType;/* used to hold a reset value for a particular ECS register */typedef struct{    UINT32 regAddr;    UINT32 regResetVal;} IxNpeDlEcsRegResetValue;/* prototype of function to write either Instruction or Data memory */typedef IX_STATUS (*IxNpeDlNpeMgrMemWrite) (UINT32 npeBaseAddress,					    UINT32 npeMemAddress,					    UINT32 npeMemData,					    BOOL verify);/* module statistics counters */typedef struct{    UINT32 instructionBlocksLoaded;    UINT32 dataBlocksLoaded;    UINT32 stateInfoBlocksLoaded;    UINT32 criticalNpeErrors;    UINT32 criticalMicrocodeErrors;    UINT32 npeStarts;    UINT32 npeStops;    UINT32 npeResets;} IxNpeDlNpeMgrStats;/* * Variable declarations global to this file only.  Externs are followed by * static variables. */static IxNpeDlNpeInfo ixNpeDlNpeInfo[] ={    {	0,	IX_NPEDL_INS_MEMSIZE_WORDS_NPEA,	IX_NPEDL_DATA_MEMSIZE_WORDS_NPEA    },    {	0,	IX_NPEDL_INS_MEMSIZE_WORDS_NPEB,	IX_NPEDL_DATA_MEMSIZE_WORDS_NPEB    },    {	0,	IX_NPEDL_INS_MEMSIZE_WORDS_NPEC,	IX_NPEDL_DATA_MEMSIZE_WORDS_NPEC    }};/* contains Reset values for Context Store Registers  */static UINT32 ixNpeDlCtxtRegResetValues[] ={    IX_NPEDL_CTXT_REG_RESET_STEVT,    IX_NPEDL_CTXT_REG_RESET_STARTPC,    IX_NPEDL_CTXT_REG_RESET_REGMAP,    IX_NPEDL_CTXT_REG_RESET_CINDEX,};/* contains Reset values for Context Store Registers  */static IxNpeDlEcsRegResetValue ixNpeDlEcsRegResetValues[] ={    {IX_NPEDL_ECS_BG_CTXT_REG_0,    IX_NPEDL_ECS_BG_CTXT_REG_0_RESET},    {IX_NPEDL_ECS_BG_CTXT_REG_1,    IX_NPEDL_ECS_BG_CTXT_REG_1_RESET},    {IX_NPEDL_ECS_BG_CTXT_REG_2,    IX_NPEDL_ECS_BG_CTXT_REG_2_RESET},    {IX_NPEDL_ECS_PRI_1_CTXT_REG_0, IX_NPEDL_ECS_PRI_1_CTXT_REG_0_RESET},    {IX_NPEDL_ECS_PRI_1_CTXT_REG_1, IX_NPEDL_ECS_PRI_1_CTXT_REG_1_RESET},    {IX_NPEDL_ECS_PRI_1_CTXT_REG_2, IX_NPEDL_ECS_PRI_1_CTXT_REG_2_RESET},    {IX_NPEDL_ECS_PRI_2_CTXT_REG_0, IX_NPEDL_ECS_PRI_2_CTXT_REG_0_RESET},    {IX_NPEDL_ECS_PRI_2_CTXT_REG_1, IX_NPEDL_ECS_PRI_2_CTXT_REG_1_RESET},    {IX_NPEDL_ECS_PRI_2_CTXT_REG_2, IX_NPEDL_ECS_PRI_2_CTXT_REG_2_RESET},    {IX_NPEDL_ECS_DBG_CTXT_REG_0,   IX_NPEDL_ECS_DBG_CTXT_REG_0_RESET},    {IX_NPEDL_ECS_DBG_CTXT_REG_1,   IX_NPEDL_ECS_DBG_CTXT_REG_1_RESET},    {IX_NPEDL_ECS_DBG_CTXT_REG_2,   IX_NPEDL_ECS_DBG_CTXT_REG_2_RESET},    {IX_NPEDL_ECS_INSTRUCT_REG,     IX_NPEDL_ECS_INSTRUCT_REG_RESET}};static IxNpeDlNpeMgrStats ixNpeDlNpeMgrStats;/* Set when NPE register memory has been mapped */static BOOL ixNpeDlMemInitialised = FALSE;/* * static function prototypes. */PRIVATE IX_STATUSixNpeDlNpeMgrMemLoad (IxNpeDlNpeId npeId, UINT32 npeBaseAddress,		      IxNpeDlNpeMgrCodeBlock *codeBlockPtr,		      BOOL verify, IxNpeDlNpeMemType npeMemType);PRIVATE IX_STATUSixNpeDlNpeMgrStateInfoLoad (UINT32 npeBaseAddress,			    IxNpeDlNpeMgrStateInfoBlock *codeBlockPtr,			    BOOL verify);PRIVATE BOOLixNpeDlNpeMgrBitsSetCheck (UINT32 npeBaseAddress, UINT32 regOffset,			   UINT32 expectedBitsSet);PRIVATE UINT32ixNpeDlNpeMgrBaseAddressGet (IxNpeDlNpeId npeId);/* * Function definition: ixNpeDlNpeMgrBaseAddressGet */PRIVATE UINT32ixNpeDlNpeMgrBaseAddressGet (IxNpeDlNpeId npeId){    IX_OSAL_ASSERT (ixNpeDlMemInitialised);    return ixNpeDlNpeInfo[npeId].baseAddress;}/* * Function definition: ixNpeDlNpeMgrInit */voidixNpeDlNpeMgrInit (void){    /* Only map the memory once */    if (!ixNpeDlMemInitialised)    {	UINT32 virtAddr;	/* map the register memory for NPE-A */	virtAddr = (UINT32) IX_OSAL_MEM_MAP (IX_NPEDL_NPEBASEADDRESS_NPEA,					    IX_OSAL_IXP400_NPEA_MAP_SIZE); 	IX_OSAL_ASSERT(virtAddr);	ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEA].baseAddress = virtAddr;	/* map the register memory for NPE-B */	virtAddr = (UINT32) IX_OSAL_MEM_MAP (IX_NPEDL_NPEBASEADDRESS_NPEB,					    IX_OSAL_IXP400_NPEB_MAP_SIZE); 	IX_OSAL_ASSERT(virtAddr);	ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEB].baseAddress = virtAddr;	/* map the register memory for NPE-C */	virtAddr = (UINT32) IX_OSAL_MEM_MAP (IX_NPEDL_NPEBASEADDRESS_NPEC,					    IX_OSAL_IXP400_NPEC_MAP_SIZE); 	IX_OSAL_ASSERT(virtAddr);	ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEC].baseAddress = virtAddr;	ixNpeDlMemInitialised = TRUE;    }}/* * Function definition: ixNpeDlNpeMgrUninit */IX_STATUSixNpeDlNpeMgrUninit (void){    if (!ixNpeDlMemInitialised)    {	return IX_FAIL;    }    IX_OSAL_MEM_UNMAP (ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEA].baseAddress);    IX_OSAL_MEM_UNMAP (ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEB].baseAddress);    IX_OSAL_MEM_UNMAP (ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEC].baseAddress);    ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEA].baseAddress = 0;    ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEB].baseAddress = 0;    ixNpeDlNpeInfo[IX_NPEDL_NPEID_NPEC].baseAddress = 0;    ixNpeDlMemInitialised = FALSE;    return IX_SUCCESS;}/* * Function definition: ixNpeDlNpeMgrImageLoad */IX_STATUSixNpeDlNpeMgrImageLoad (    IxNpeDlNpeId npeId,    UINT32 *imageCodePtr,    BOOL verify){    UINT32 npeBaseAddress;    IxNpeDlNpeMgrDownloadMap *downloadMap;    UINT32 *blockPtr;    UINT32 mapIndex = 0;    IX_STATUS status = IX_SUCCESS;        IX_NPEDL_TRACE0 (IX_NPEDL_FN_ENTRY_EXIT,		     "Entering ixNpeDlNpeMgrImageLoad\n");    /* get base memory address of NPE from npeId */    npeBaseAddress = ixNpeDlNpeMgrBaseAddressGet (npeId);    /* check execution status of NPE to verify NPE Stop was successful */    if (!ixNpeDlNpeMgrBitsSetCheck (npeBaseAddress, IX_NPEDL_REG_OFFSET_EXCTL,				    IX_NPEDL_EXCTL_STATUS_STOP))    {	IX_NPEDL_ERROR_REPORT ("ixNpeDlNpeMgrImageDownload - "			       "NPE was not stopped before download\n");	status = IX_FAIL;    }    else    {	/*	 * Read Download Map, checking each block type and calling	 * appropriate function to perform download 	 */	downloadMap = (IxNpeDlNpeMgrDownloadMap *) imageCodePtr;	while ((downloadMap->entry[mapIndex].eodmMarker != 		IX_NPEDL_END_OF_DOWNLOAD_MAP)	       && (status == IX_SUCCESS))	{	    /* calculate pointer to block to be downloaded */	    blockPtr = imageCodePtr +		downloadMap->entry[mapIndex].block.offset;	    switch (downloadMap->entry[mapIndex].block.type)	    {	    case IX_NPEDL_BLOCK_TYPE_INSTRUCTION:		status = ixNpeDlNpeMgrMemLoad (npeId, npeBaseAddress, 					     (IxNpeDlNpeMgrCodeBlock *)blockPtr,					       verify,					       IX_NPEDL_MEM_TYPE_INSTRUCTION);		break;	    case IX_NPEDL_BLOCK_TYPE_DATA:		status = ixNpeDlNpeMgrMemLoad (npeId, npeBaseAddress,                                             (IxNpeDlNpeMgrCodeBlock *)blockPtr,					       verify, IX_NPEDL_MEM_TYPE_DATA);		break;	    case IX_NPEDL_BLOCK_TYPE_STATE:		status = ixNpeDlNpeMgrStateInfoLoad (npeBaseAddress,				       (IxNpeDlNpeMgrStateInfoBlock *) blockPtr,						     verify);		break;	    default:		IX_NPEDL_ERROR_REPORT ("ixNpeDlNpeMgrImageLoad: "				       "unknown block type in download map\n");		status = IX_NPEDL_CRITICAL_MICROCODE_ERR;		ixNpeDlNpeMgrStats.criticalMicrocodeErrors++;		break;	    }	    mapIndex++;	}/* loop: for each entry in download map, while status == SUCCESS */    }/* condition: NPE stopped before attempting download */        IX_NPEDL_TRACE1 (IX_NPEDL_FN_ENTRY_EXIT, 		     "Exiting ixNpeDlNpeMgrImageLoad : status = %d\n",		     status);    return status;}/* * Function definition: ixNpeDlNpeMgrMemLoad */PRIVATE IX_STATUSixNpeDlNpeMgrMemLoad (    IxNpeDlNpeId npeId,    UINT32 npeBaseAddress,    IxNpeDlNpeMgrCodeBlock *blockPtr,    BOOL verify,    IxNpeDlNpeMemType npeMemType){    UINT32 npeMemAddress;    UINT32 blockSize;    UINT32 memSize = 0;    IxNpeDlNpeMgrMemWrite memWriteFunc = NULL;    UINT32 localIndex = 0;    IX_STATUS status = IX_SUCCESS;    IX_NPEDL_TRACE0 (IX_NPEDL_FN_ENTRY_EXIT,		     "Entering ixNpeDlNpeMgrMemLoad\n");        /*     * select NPE EXCTL reg read/write commands depending on memory     * type (instruction/data) to be accessed     */    if (npeMemType == IX_NPEDL_MEM_TYPE_INSTRUCTION)    {	memSize = ixNpeDlNpeInfo[npeId].insMemSize;	memWriteFunc = (IxNpeDlNpeMgrMemWrite) ixNpeDlNpeMgrInsMemWrite;    }    else if (npeMemType == IX_NPEDL_MEM_TYPE_DATA)    {	memSize = ixNpeDlNpeInfo[npeId].dataMemSize;	memWriteFunc = (IxNpeDlNpeMgrMemWrite) ixNpeDlNpeMgrDataMemWrite;    }    /*     * NPE memory is loaded contiguously from each block, so only address     * of 1st word in block is needed     */    npeMemAddress = blockPtr->npeMemAddress;    /* number of words of instruction/data microcode in block to download */    blockSize = blockPtr->size;    if ((npeMemAddress + blockSize) > memSize)    {	IX_NPEDL_ERROR_REPORT ("ixNpeDlNpeMgrMemLoad: "			       "Block size too big for NPE memory\n");	status = IX_NPEDL_CRITICAL_MICROCODE_ERR;	ixNpeDlNpeMgrStats.criticalMicrocodeErrors++;    }    else    {	for (localIndex = 0; localIndex < blockSize; localIndex++)	{	    status = memWriteFunc (npeBaseAddress, npeMemAddress,				   blockPtr->data[localIndex], verify);	    if (status != IX_SUCCESS)	    {		IX_NPEDL_ERROR_REPORT ("ixNpeDlNpeMgrMemLoad: "				       "write to NPE memory failed\n");		status = IX_NPEDL_CRITICAL_NPE_ERR;		ixNpeDlNpeMgrStats.criticalNpeErrors++;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩色在线观看| 欧美少妇xxx| 国产三级一区二区| 国产毛片精品视频| 国产人妖乱国产精品人妖| 国产成人精品免费视频网站| 国产视频一区二区在线| 成人av在线看| 一区二区三区四区蜜桃| 欧美日韩一区国产| 日本少妇一区二区| 国产情人综合久久777777| 不卡一区中文字幕| 亚洲成av人影院在线观看网| 欧美一区二区黄色| 丰满少妇在线播放bd日韩电影| 国产精品久久久久一区二区三区共| 91免费视频网址| 亚洲成av人片| 久久亚洲精华国产精华液| av亚洲精华国产精华| 亚洲一区中文日韩| 欧美成人性战久久| 成人午夜电影网站| 性欧美疯狂xxxxbbbb| 精品国产精品网麻豆系列| 成人听书哪个软件好| 亚洲高清免费视频| 久久综合999| 日本伦理一区二区| 久久精品国产亚洲一区二区三区 | 91蜜桃免费观看视频| 一区二区三区精品| 精品99久久久久久| 欧美色国产精品| 国产高清精品网站| 亚洲电影一区二区三区| 国产婷婷一区二区| 日韩一区二区中文字幕| 成av人片一区二区| 韩国欧美国产一区| 图片区小说区区亚洲影院| 欧美高清在线一区| 7777精品伊人久久久大香线蕉的 | 91麻豆精品秘密| 裸体健美xxxx欧美裸体表演| 亚洲青青青在线视频| 久久人人97超碰com| 欧美老女人在线| 97精品国产露脸对白| 激情综合色播激情啊| 午夜久久久久久| 中文字幕佐山爱一区二区免费| 精品久久久三级丝袜| 欧美视频在线一区| 99riav一区二区三区| 国产自产视频一区二区三区| 偷拍日韩校园综合在线| 亚洲欧美日韩一区二区| 国产色91在线| 精品欧美一区二区在线观看| 欧美日韩精品一区二区三区蜜桃 | 久久亚洲精品国产精品紫薇| 91麻豆精品国产91| 欧美日韩中文字幕一区二区| 色婷婷国产精品| www.久久久久久久久| 国产jizzjizz一区二区| 国产一区二区伦理片| 久久99精品国产.久久久久久| 天堂av在线一区| 午夜精品一区在线观看| 亚洲国产日日夜夜| 亚洲一区二区欧美激情| 亚洲一区二区三区视频在线| 亚洲国产精品影院| 亚洲福利一区二区| 亚洲成a人v欧美综合天堂| 亚洲成人在线网站| 亚洲gay无套男同| 亚洲一区在线看| 一二三四区精品视频| 亚洲成a天堂v人片| 日韩av一级片| 精品亚洲国产成人av制服丝袜| 精品在线亚洲视频| 国产白丝精品91爽爽久久| 东方aⅴ免费观看久久av| 不卡一二三区首页| 99国产精品久久| 一本久久a久久免费精品不卡| 91福利精品第一导航| 欧美日韩成人一区二区| 欧美一区二区福利在线| 久久久久国产成人精品亚洲午夜 | 成人动漫中文字幕| 91首页免费视频| 欧美日韩第一区日日骚| 欧美一区二区女人| 日本一区二区三区视频视频| 亚洲欧洲制服丝袜| 视频精品一区二区| 国产一区二区三区高清播放| 成人av在线观| 欧美人xxxx| 久久久99精品久久| 亚洲精品国久久99热| 爽好久久久欧美精品| 国产综合一区二区| 色欲综合视频天天天| 91精品国产欧美一区二区18| 国产午夜精品在线观看| 亚洲免费观看在线观看| 日韩精彩视频在线观看| 国产精品一卡二| 色综合久久久久网| 日韩欧美亚洲另类制服综合在线| 国产亚洲精品7777| 亚洲国产三级在线| 国产成人精品免费视频网站| 欧美揉bbbbb揉bbbbb| 国产亚洲女人久久久久毛片| 一区二区三区久久久| 激情国产一区二区| 欧美图区在线视频| 久久精品欧美一区二区三区麻豆 | 国产精品麻豆久久久| 亚洲第一福利一区| 成人午夜视频在线| 日韩手机在线导航| 一区二区三区四区高清精品免费观看| 美女视频一区二区| 91国内精品野花午夜精品| 亚洲精品在线免费观看视频| 亚洲一区二区三区四区五区黄 | 成人av网站在线观看| 欧美日韩日本视频| 国产精品国产三级国产普通话蜜臀| 午夜私人影院久久久久| 99精品国产一区二区三区不卡| 欧美一区二区三级| 亚洲精品成人精品456| 国产精品一卡二| 精品乱人伦一区二区三区| 亚洲午夜三级在线| 99国产精品久久久久久久久久久 | 亚洲成在人线在线播放| 99在线视频精品| 国产日韩欧美a| 九九九久久久精品| 欧美一区二区在线播放| 亚洲一区二区综合| 99视频在线精品| 中文字幕一区二区5566日韩| 国产一区二区剧情av在线| 日韩视频免费直播| 日韩—二三区免费观看av| 欧美欧美欧美欧美| 亚洲国产一区二区三区| 色狠狠桃花综合| 中文字幕一区二区三区不卡 | 中文字幕日本乱码精品影院| 国产福利电影一区二区三区| 欧美变态凌虐bdsm| 热久久国产精品| 欧美区一区二区三区| 亚洲小少妇裸体bbw| 在线精品视频免费观看| 一区二区激情小说| 欧美视频精品在线观看| 亚洲午夜精品在线| 7777精品伊人久久久大香线蕉最新版| 亚洲一二三区不卡| 欧美精品 国产精品| 视频一区欧美日韩| 日韩美女一区二区三区四区| 久久er99热精品一区二区| 久久久天堂av| 成人免费三级在线| 亚洲日本中文字幕区| 在线免费观看日韩欧美| 一区二区日韩av| 欧美精品少妇一区二区三区| 日韩电影在线一区二区| 日韩免费观看高清完整版 | 成人美女在线视频| 国产精品高潮呻吟久久| 一本一道久久a久久精品综合蜜臀| 一区二区三区精品在线观看| 欧美一区二区在线看| 国产一区二区三区日韩| 国产精品成人一区二区三区夜夜夜 | 激情深爱一区二区| 国产精品久久久久久一区二区三区| 91视频在线看| 免费成人深夜小野草| 国产精品网站一区| 欧美午夜电影网| 国内精品伊人久久久久av一坑 | 国产精品福利影院|