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

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

?? ixnpedlnpemgr.c

?? 友善mini2440嵌入式
?? 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++;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二区三区在线观看| 91女人视频在线观看| 夜夜亚洲天天久久| 亚洲人午夜精品天堂一二香蕉| 欧美成人在线直播| 欧美成人一区二区三区| 日韩亚洲欧美一区| 精品对白一区国产伦| 久久综合色综合88| 国产农村妇女毛片精品久久麻豆| 久久久国产午夜精品| 亚洲国产精品t66y| 欧美国产日韩精品免费观看| 国产精品嫩草影院com| 国产精品午夜在线观看| 亚洲激情在线播放| 亚洲尤物在线视频观看| 蜜桃视频第一区免费观看| 久久不见久久见免费视频1| 麻豆成人91精品二区三区| 国产乱人伦精品一区二区在线观看 | 免费观看91视频大全| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲aaa精品| 老色鬼精品视频在线观看播放| 久久91精品久久久久久秒播| 成人国产精品免费观看视频| 91国偷自产一区二区开放时间| 欧美绝品在线观看成人午夜影视| 日韩一区二区三区电影在线观看 | 一本一本久久a久久精品综合麻豆| 91麻豆国产香蕉久久精品| 欧美高清精品3d| 久久一夜天堂av一区二区三区| 国产精品福利一区| 亚洲欧美精品午睡沙发| 日韩电影在线观看一区| www.在线欧美| 日韩免费性生活视频播放| 国产精品久久久久三级| 婷婷国产在线综合| 国产91丝袜在线18| 欧美精品色综合| 国产精品麻豆一区二区| 午夜国产精品影院在线观看| 成人一区二区三区中文字幕| 欧美精品少妇一区二区三区| 国产精品久久久久一区 | 韩国av一区二区三区在线观看| 波多野结衣视频一区| 91精品麻豆日日躁夜夜躁| 欧美国产乱子伦| 美女在线一区二区| 欧美日本韩国一区二区三区视频| 亚洲国产精华液网站w| 日韩高清在线电影| 日本丰满少妇一区二区三区| 精品福利一二区| 日韩国产欧美在线观看| 91黄色小视频| 国产精品色婷婷| 狠狠色丁香婷婷综合久久片| 欧美日韩不卡一区二区| 亚洲精品国产品国语在线app| 国产尤物一区二区在线| 欧美一区二区视频在线观看2020| 一区二区高清在线| 色香蕉成人二区免费| 欧美国产精品v| 国产精品一区二区你懂的| 欧美一区二区三区视频在线| 亚洲在线视频一区| 在线观看欧美日本| 亚洲欧美影音先锋| 波多野结衣中文一区| 国产欧美视频一区二区| 久久69国产一区二区蜜臀| 欧美不卡一区二区三区四区| 日产国产高清一区二区三区 | 无吗不卡中文字幕| 亚洲va韩国va欧美va| 在线视频中文字幕一区二区| 亚洲人成在线播放网站岛国| 91色综合久久久久婷婷| 亚洲欧美综合在线精品| 91在线免费视频观看| 中文字幕欧美一区| 91小视频免费观看| 亚洲激情六月丁香| 欧美三级乱人伦电影| 亚洲国产美国国产综合一区二区| 欧美巨大另类极品videosbest | 日韩欧美一级特黄在线播放| 香蕉加勒比综合久久| 欧美熟乱第一页| 视频一区二区欧美| 日韩一级片网址| 久久99九九99精品| 国产午夜精品在线观看| 97精品久久久久中文字幕| 夜夜爽夜夜爽精品视频| 欧美一区二区三区的| 激情图区综合网| 国产精品理论在线观看| 在线欧美一区二区| 美腿丝袜亚洲三区| 亚洲欧美影音先锋| 欧美老女人第四色| 国产黑丝在线一区二区三区| 国产精品国产精品国产专区不蜜| 一本色道综合亚洲| 蜜臀久久99精品久久久久宅男 | 欧美日韩二区三区| 精品在线观看免费| 综合欧美亚洲日本| 91精品欧美久久久久久动漫| 国产精品1024| 日韩国产欧美在线视频| 国产精品视频麻豆| 欧美男同性恋视频网站| 成人精品小蝌蚪| 天天色综合成人网| 中文字幕欧美区| 5566中文字幕一区二区电影| 国产suv精品一区二区三区| 首页综合国产亚洲丝袜| 中文字幕免费观看一区| 欧美日本精品一区二区三区| 成人免费毛片app| 蜜桃av一区二区| 亚洲动漫第一页| 亚洲国产精品黑人久久久| 91麻豆精品国产91久久久 | 日韩免费视频一区二区| 97成人超碰视| 国产资源在线一区| 亚洲成a人片在线不卡一二三区| 国产色91在线| 精品福利av导航| 制服丝袜亚洲精品中文字幕| 99久久久久久99| 国产精品羞羞答答xxdd| 全部av―极品视觉盛宴亚洲| 亚洲精品亚洲人成人网| 中文字幕欧美国产| 久久久亚洲高清| 欧美一卡二卡在线观看| 精品视频在线免费| 91一区二区三区在线观看| 国产精品一区二区黑丝| 久久se精品一区精品二区| 日韩中文字幕av电影| 欧美日韩成人综合在线一区二区| 在线免费不卡视频| 91猫先生在线| 色又黄又爽网站www久久| 99r精品视频| 99re亚洲国产精品| hitomi一区二区三区精品| 国产毛片一区二区| 国产呦萝稀缺另类资源| 狠狠狠色丁香婷婷综合激情| 久久不见久久见免费视频1| 狂野欧美性猛交blacked| 美国一区二区三区在线播放| 另类小说图片综合网| 精品影视av免费| 国产一区二区三区在线观看免费视频| 美女视频免费一区| 精品一区二区在线视频| 精久久久久久久久久久| 午夜久久久影院| 久久精品国产**网站演员| 极品少妇xxxx精品少妇| 韩日欧美一区二区三区| 国产mv日韩mv欧美| 99久久久无码国产精品| 在线免费观看成人短视频| 欧美日韩国产综合一区二区| 宅男噜噜噜66一区二区66| 日韩精品最新网址| 国产日产欧产精品推荐色| 中文字幕一区二区三区在线观看 | 亚洲国产精品成人综合| 亚洲视频图片小说| 一区二区成人在线| 免费欧美高清视频| 国产成人8x视频一区二区| 99精品欧美一区二区三区小说| 日本精品一区二区三区高清| 91精品国产丝袜白色高跟鞋| 久久久久国色av免费看影院| 亚洲欧洲韩国日本视频 | 亚洲精品视频免费观看| 亚洲香肠在线观看| 国内成人免费视频| 欧美色电影在线| 久久一夜天堂av一区二区三区| 亚洲三级小视频| 秋霞成人午夜伦在线观看|