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

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

?? ixnpedlnpemgr.c

?? 友善mini2440嵌入式
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/** * @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
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天使萌一区二区三区免费观看| 午夜精品一区二区三区电影天堂| 在线亚洲一区观看| 青娱乐精品视频在线| 国产精品国产自产拍高清av| 欧美日韩国产经典色站一区二区三区 | 日本韩国精品在线| 久久黄色级2电影| 亚洲精品成人精品456| 久久一夜天堂av一区二区三区| 欧美在线999| 成人一区二区三区| 久久精品国产99国产精品| 亚洲色图制服丝袜| 久久久久久毛片| 欧美一区二区三区免费大片| 97国产精品videossex| 国产精品系列在线播放| 日av在线不卡| 亚洲成人黄色影院| 亚洲精品国产高清久久伦理二区| 视频在线在亚洲| 中文字幕在线一区二区三区| 亚洲精品一区二区三区在线观看| 欧美亚洲国产怡红院影院| 国产69精品一区二区亚洲孕妇 | 高清日韩电视剧大全免费| 毛片av中文字幕一区二区| 亚洲一区二区三区影院| 国产精品久久久久9999吃药| 久久久精品国产99久久精品芒果| 日韩欧美成人一区二区| 欧美日韩免费一区二区三区| 欧洲精品在线观看| 91浏览器入口在线观看| 99精品热视频| 色综合中文综合网| 粉嫩av亚洲一区二区图片| 国产又粗又猛又爽又黄91精品| 日日夜夜精品视频免费| 日韩电影在线免费| 奇米影视一区二区三区| 日韩av电影免费观看高清完整版 | 中文字幕色av一区二区三区| 国产欧美精品国产国产专区| 久久这里都是精品| 国产亚洲女人久久久久毛片| 国产欧美日韩精品一区| 欧美激情艳妇裸体舞| 欧美激情中文字幕| 国产精品久久久久久久久久免费看| 亚洲国产精品99久久久久久久久| 中文字幕精品一区| 亚洲丝袜自拍清纯另类| 亚洲精品国产a| 亚洲一二三四久久| 午夜久久电影网| 日本aⅴ精品一区二区三区| 麻豆精品视频在线观看| 狠狠色丁香九九婷婷综合五月| 国内精品免费**视频| 成人免费看黄yyy456| 91视频免费播放| 欧美日本在线看| 日韩三级免费观看| 国产日韩欧美麻豆| 一区二区三区四区精品在线视频| 五月天亚洲婷婷| 久久精品国产久精国产爱| 风间由美一区二区三区在线观看 | 蜜桃视频一区二区| 国产最新精品精品你懂的| 国产成人av一区二区三区在线| 成人av在线电影| 欧美三级在线视频| 2020国产精品自拍| 中文字幕一区二区三区四区 | 亚洲同性gay激情无套| 亚洲超碰精品一区二区| 精品一区二区三区影院在线午夜| av一区二区三区| 欧美日韩国产一级| 国产肉丝袜一区二区| 亚洲卡通欧美制服中文| 麻豆成人综合网| 91啦中文在线观看| 欧美v国产在线一区二区三区| 国产精品久久久久精k8 | 岛国一区二区在线观看| 欧美在线不卡一区| 久久蜜桃一区二区| 亚洲第一福利视频在线| 懂色中文一区二区在线播放| 欧美精品乱码久久久久久| 日本一区二区免费在线观看视频 | 欧美日韩国产a| 久久精品人人做人人爽97| 一区二区三区四区在线播放| 国内精品伊人久久久久av一坑| 在线视频你懂得一区二区三区| 久久午夜免费电影| 天天色图综合网| 99久久精品99国产精品| 欧美zozozo| 亚洲国产婷婷综合在线精品| 国产成人免费网站| 欧美一区二区成人| 一区二区三区精品在线| 高清免费成人av| 精品对白一区国产伦| 亚洲午夜av在线| 色综合一区二区| 国产精品人妖ts系列视频| 精油按摩中文字幕久久| 91精品国产一区二区三区蜜臀| 一区二区三区**美女毛片| 成人小视频免费观看| 久久综合狠狠综合| 久久99精品久久只有精品| 欧美日韩色综合| 一二三区精品视频| 99精品视频一区二区| 国产精品欧美综合在线| 国产大陆亚洲精品国产| 精品国产乱码久久久久久牛牛| 免费在线观看精品| 777午夜精品视频在线播放| 一区二区不卡在线播放| 91在线看国产| 1区2区3区精品视频| 久久网站热最新地址| 国产在线精品一区二区三区不卡| 日韩你懂的在线观看| 日韩成人一区二区| 7777精品伊人久久久大香线蕉超级流畅 | 欧美三级中文字幕在线观看| 亚洲精品视频在线观看免费| 91蝌蚪porny九色| 亚洲黄色性网站| 欧美中文字幕一区二区三区| 一区二区三区不卡视频| 欧美色精品在线视频| 亚洲v中文字幕| 51精品秘密在线观看| 日韩不卡一二三区| 日韩精品一区二区在线| 久久精品国产色蜜蜜麻豆| 欧美精品一区二区三区四区 | 豆国产96在线|亚洲| 国产精品无人区| 99视频一区二区| 亚洲免费视频中文字幕| 日本久久一区二区| 亚洲第一激情av| 日韩午夜三级在线| 国产在线国偷精品免费看| 国产日产精品一区| 97se亚洲国产综合自在线| 亚洲一本大道在线| 日韩欧美国产精品一区| 国产精品综合视频| 国产精品白丝在线| 欧美日韩国产小视频| 九九视频精品免费| 中文字幕精品—区二区四季| 色呦呦网站一区| 久久国产三级精品| 国产精品二区一区二区aⅴ污介绍| 一本色道久久综合精品竹菊| 日韩电影免费在线| 国产精品天美传媒沈樵| 欧美午夜精品一区| 精品在线免费视频| 亚洲人吸女人奶水| 日韩午夜激情视频| 99精品久久只有精品| 日韩中文字幕不卡| 国产日韩成人精品| 欧美浪妇xxxx高跟鞋交| 国产aⅴ综合色| 亚洲午夜免费福利视频| 欧美va在线播放| 日本丰满少妇一区二区三区| 久久超碰97中文字幕| 亚洲老妇xxxxxx| 久久综合九色综合久久久精品综合 | 亚洲第一精品在线| 久久久精品欧美丰满| 日本久久一区二区三区| 国产最新精品免费| 亚洲成人一区在线| 久久国产精品色| 亚洲综合一区二区三区| 久久久久99精品国产片| 日本韩国精品在线| 大白屁股一区二区视频| 日本91福利区| 亚洲国产欧美日韩另类综合| 国产欧美在线观看一区| 日韩欧美色综合网站|