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

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

?? atimach64accel.c

?? x.org上有關ati系列顯卡最新驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* $XFree86: xc/programs/Xserver/hw/xfree86/drivers/ati/atimach64accel.c,v 1.1 2003/04/23 21:51:28 tsi Exp $ *//* * Copyright 2003 through 2004 by Marc Aurele La France (TSI @ UQV), tsi@xfree86.org * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that * the above copyright notice appear in all copies and that both that copyright * notice and this permission notice appear in supporting documentation, and * that the name of Marc Aurele La France not be used in advertising or * publicity pertaining to distribution of the software without specific, * written prior permission.  Marc Aurele La France makes no representations * about the suitability of this software for any purpose.  It is provided * "as-is" without express or implied warranty. * * MARC AURELE LA FRANCE DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.  IN NO * EVENT SHALL MARC AURELE LA FRANCE BE LIABLE FOR ANY SPECIAL, INDIRECT OR * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR * PERFORMANCE OF THIS SOFTWARE. *//* * Copyright 1999-2000 Precision Insight, Inc., Cedar Park, Texas. * All Rights Reserved. * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to * deal in the Software without restriction, including without limitation the * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or * sell copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice (including the next * paragraph) shall be included in all copies or substantial portions of the * Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.  IN NO EVENT SHALL * PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. *//*  * DRI support by: *    Manuel Teira *    Leif Delgass <ldelgass@retinalburn.net> */#ifdef HAVE_CONFIG_H#include "config.h"#endif#include "ati.h"#include "atichip.h"#include "atimach64accel.h"#include "atimach64io.h"#include "atipriv.h"#include "atiregs.h"#ifdef XF86DRI_DEVEL#include "mach64_common.h"#endif#include "miline.h"/* Used to test MMIO cache integrity in ATIMach64Sync() */#define TestRegisterCaching(_Register)                   \    if (RegisterIsCached(_Register) &&                   \        (CacheSlot(_Register) != inm(_Register)))        \    {                                                    \        UncacheRegister(_Register);                      \        xf86DrvMsg(pScreenInfo->scrnIndex, X_WARNING,    \            #_Register " MMIO write cache disabled!\n"); \    }/* * X-to-Mach64 mix translation table. */CARD8 ATIMach64ALU[16] ={    MIX_0,                       /* GXclear */    MIX_AND,                     /* GXand */    MIX_SRC_AND_NOT_DST,         /* GXandReverse */    MIX_SRC,                     /* GXcopy */    MIX_NOT_SRC_AND_DST,         /* GXandInverted */    MIX_DST,                     /* GXnoop */    MIX_XOR,                     /* GXxor */    MIX_OR,                      /* GXor */    MIX_NOR,                     /* GXnor */    MIX_XNOR,                    /* GXequiv */    MIX_NOT_DST,                 /* GXinvert */    MIX_SRC_OR_NOT_DST,          /* GXorReverse */    MIX_NOT_SRC,                 /* GXcopyInverted */    MIX_NOT_SRC_OR_DST,          /* GXorInverted */    MIX_NAND,                    /* GXnand */    MIX_1                        /* GXset */};/* * ATIMach64ValidateClip -- * * This function ensures the current scissor settings do not interfere with * the current draw request. */voidATIMach64ValidateClip(    ATIPtr pATI,    int    sc_left,    int    sc_right,    int    sc_top,    int    sc_bottom){    if ((sc_left < (int)pATI->sc_left) || (sc_right > (int)pATI->sc_right))    {        outf(SC_LEFT_RIGHT, pATI->sc_left_right);        pATI->sc_left = pATI->NewHW.sc_left;        pATI->sc_right = pATI->NewHW.sc_right;    }    if ((sc_top < (int)pATI->sc_top) || (sc_bottom > (int)pATI->sc_bottom))    {        outf(SC_TOP_BOTTOM, pATI->sc_top_bottom);        pATI->sc_top = pATI->NewHW.sc_top;        pATI->sc_bottom = pATI->NewHW.sc_bottom;    }}static __inline__ void TestRegisterCachingDP(ScrnInfoPtr pScreenInfo);static __inline__ void TestRegisterCachingXV(ScrnInfoPtr pScreenInfo);/* * ATIMach64Sync -- * * This is called to wait for the draw engine to become idle. */voidATIMach64Sync(    ScrnInfoPtr pScreenInfo){    ATIPtr pATI = ATIPTR(pScreenInfo);#ifdef XF86DRI_DEVEL    if ( pATI->directRenderingEnabled && pATI->NeedDRISync )    {	ATIHWPtr pATIHW = &pATI->NewHW;	CARD32 offset;	if (pATI->OptionMMIOCache) {	    /* "Invalidate" the MMIO cache so the cache slots get updated */	    UncacheRegister(SRC_CNTL);	    UncacheRegister(SCALE_3D_CNTL);	    UncacheRegister(HOST_CNTL);	    UncacheRegister(PAT_CNTL);	    UncacheRegister(SC_LEFT_RIGHT);	    UncacheRegister(SC_TOP_BOTTOM);	    UncacheRegister(DP_BKGD_CLR);	    UncacheRegister(DP_FRGD_CLR);	    UncacheRegister(DP_PIX_WIDTH);	    UncacheRegister(DP_MIX);	    UncacheRegister(CLR_CMP_CNTL);	    UncacheRegister(TEX_SIZE_PITCH);	}	ATIDRIWaitForIdle(pATI);	outr( BUS_CNTL, pATIHW->bus_cntl );	/* DRI uses GUI_TRAJ_CNTL, which is a composite of 	 * src_cntl, dst_cntl, pat_cntl, and host_cntl	 */	outf( SRC_CNTL, pATIHW->src_cntl );	outf( DST_CNTL, pATIHW->dst_cntl );	outf( PAT_CNTL, pATIHW->pat_cntl );	outf( HOST_CNTL, pATIHW->host_cntl );	outf( DST_OFF_PITCH, pATIHW->dst_off_pitch );	outf( SRC_OFF_PITCH, pATIHW->src_off_pitch );	outf( DP_SRC, pATIHW->dp_src );	outf( DP_MIX, pATIHW->dp_mix );	outf( DP_FRGD_CLR,  pATIHW->dp_frgd_clr );	outf( DP_WRITE_MASK, pATIHW->dp_write_mask );	outf( DP_PIX_WIDTH, pATIHW->dp_pix_width );	outf( CLR_CMP_CNTL, pATIHW->clr_cmp_cntl );	offset = TEX_LEVEL(pATIHW->tex_size_pitch);	ATIMach64WaitForFIFO(pATI, 6);	outf( ALPHA_TST_CNTL, 0 );	outf( Z_CNTL, 0 );	outf( SCALE_3D_CNTL, pATIHW->scale_3d_cntl );	outf( TEX_0_OFF + offset, pATIHW->tex_offset );	outf( TEX_SIZE_PITCH, pATIHW->tex_size_pitch );	outf( TEX_CNTL, pATIHW->tex_cntl );	ATIMach64WaitForFIFO(pATI, 2);	outf( SC_LEFT_RIGHT,	      SetWord(pATIHW->sc_right, 1) | SetWord(pATIHW->sc_left, 0) );	outf( SC_TOP_BOTTOM,	      SetWord(pATIHW->sc_bottom, 1) | SetWord(pATIHW->sc_top, 0) );	if (pATI->OptionMMIOCache) {	    /* Now that the cache slots reflect the register state, re-enable MMIO cache */	    CacheRegister(SRC_CNTL);	    CacheRegister(SCALE_3D_CNTL);	    CacheRegister(HOST_CNTL);	    CacheRegister(PAT_CNTL);	    CacheRegister(SC_LEFT_RIGHT);	    CacheRegister(SC_TOP_BOTTOM);	    CacheRegister(DP_BKGD_CLR);	    CacheRegister(DP_FRGD_CLR);	    CacheRegister(DP_PIX_WIDTH);	    CacheRegister(DP_MIX);	    CacheRegister(CLR_CMP_CNTL);	    CacheRegister(TEX_SIZE_PITCH);	}	ATIMach64WaitForIdle(pATI);	if (pATI->OptionMMIOCache && pATI->OptionTestMMIOCache) {	  	    /* Only check registers we didn't restore */	    TestRegisterCaching(PAT_REG0);            TestRegisterCaching(PAT_REG1);            TestRegisterCaching(CLR_CMP_CLR);            TestRegisterCaching(CLR_CMP_MSK);	    TestRegisterCachingXV(pScreenInfo);         }	pATI->NeedDRISync = FALSE;    }    else#endif /* XF86DRI_DEVEL */    {      ATIMach64WaitForIdle(pATI);            if (pATI->OptionMMIOCache && pATI->OptionTestMMIOCache)      {        /*         * For debugging purposes, attempt to verify that each cached register         * should actually be cached.         */        TestRegisterCachingDP(pScreenInfo);        TestRegisterCachingXV(pScreenInfo);      }    }#ifdef USE_EXA    /* EXA sets pEXA->needsSync to FALSE on its own */#endif#ifdef USE_XAA    if (pATI->pXAAInfo)        pATI->pXAAInfo->NeedToSync = FALSE;#endif    if (pATI->Chip >= ATI_CHIP_264VTB)    {        /*         * Flush the read-back cache (by turning on INVALIDATE_RB_CACHE),         * otherwise the host might get stale data when reading through the         * aperture.         */        outr(MEM_BUF_CNTL, pATI->NewHW.mem_buf_cntl);    }    /*     * Note:     * Before actually invalidating the read-back cache, the mach64 driver     * was using the trick below which is buggy. The code is left here for     * reference, DRI uses this trick and needs updating.     *     * For VTB's and later, the first CPU read of the framebuffer will return     * zeroes, so do it here.  This appears to be due to some kind of engine     * caching of framebuffer data I haven't found any way of disabling, or     * otherwise circumventing.  Thanks to Mark Vojkovich for the suggestion.     *     * pATI = *(volatile ATIPtr *)pATI->pMemory;     */}static __inline__ voidTestRegisterCachingDP(ScrnInfoPtr pScreenInfo){    ATIPtr pATI = ATIPTR(pScreenInfo);    TestRegisterCaching(SRC_CNTL);    if (pATI->Chip >= ATI_CHIP_264GTPRO)    {        TestRegisterCaching(SCALE_3D_CNTL);    }    TestRegisterCaching(HOST_CNTL);    TestRegisterCaching(PAT_REG0);    TestRegisterCaching(PAT_REG1);    TestRegisterCaching(PAT_CNTL);    if (RegisterIsCached(SC_LEFT_RIGHT) &&      /* Special case */        (CacheSlot(SC_LEFT_RIGHT) !=         (SetWord(inm(SC_RIGHT), 1) | SetWord(inm(SC_LEFT), 0))))    {        UncacheRegister(SC_LEFT_RIGHT);        xf86DrvMsg(pScreenInfo->scrnIndex, X_WARNING,            "SC_LEFT_RIGHT write cache disabled!\n");    }    if (RegisterIsCached(SC_TOP_BOTTOM) &&      /* Special case */        (CacheSlot(SC_TOP_BOTTOM) !=         (SetWord(inm(SC_BOTTOM), 1) | SetWord(inm(SC_TOP), 0))))    {        UncacheRegister(SC_TOP_BOTTOM);        xf86DrvMsg(pScreenInfo->scrnIndex, X_WARNING,            "SC_TOP_BOTTOM write cache disabled!\n");    }    TestRegisterCaching(DP_BKGD_CLR);    TestRegisterCaching(DP_FRGD_CLR);    TestRegisterCaching(DP_PIX_WIDTH);    TestRegisterCaching(DP_MIX);    TestRegisterCaching(CLR_CMP_CLR);    TestRegisterCaching(CLR_CMP_MSK);    TestRegisterCaching(CLR_CMP_CNTL);    if (pATI->Chip >= ATI_CHIP_264GTPRO)    {        TestRegisterCaching(TEX_SIZE_PITCH);    }}static __inline__ voidTestRegisterCachingXV(ScrnInfoPtr pScreenInfo){    ATIPtr pATI = ATIPTR(pScreenInfo);    if (!pATI->Block1Base)        return;    TestRegisterCaching(OVERLAY_Y_X_START);    TestRegisterCaching(OVERLAY_Y_X_END);    TestRegisterCaching(OVERLAY_GRAPHICS_KEY_CLR);    TestRegisterCaching(OVERLAY_GRAPHICS_KEY_MSK);    TestRegisterCaching(OVERLAY_KEY_CNTL);    TestRegisterCaching(OVERLAY_SCALE_INC);    TestRegisterCaching(OVERLAY_SCALE_CNTL);    TestRegisterCaching(SCALER_HEIGHT_WIDTH);    TestRegisterCaching(SCALER_TEST);    TestRegisterCaching(VIDEO_FORMAT);    if (pATI->Chip < ATI_CHIP_264VTB)    {        TestRegisterCaching(BUF0_OFFSET);        TestRegisterCaching(BUF0_PITCH);        TestRegisterCaching(BUF1_OFFSET);        TestRegisterCaching(BUF1_PITCH);        return;    }    TestRegisterCaching(SCALER_BUF0_OFFSET);    TestRegisterCaching(SCALER_BUF1_OFFSET);    TestRegisterCaching(SCALER_BUF_PITCH);    TestRegisterCaching(OVERLAY_EXCLUSIVE_HORZ);    TestRegisterCaching(OVERLAY_EXCLUSIVE_VERT);    if (pATI->Chip < ATI_CHIP_264GTPRO)        return;    TestRegisterCaching(SCALER_COLOUR_CNTL);    TestRegisterCaching(SCALER_H_COEFF0);    TestRegisterCaching(SCALER_H_COEFF1);    TestRegisterCaching(SCALER_H_COEFF2);    TestRegisterCaching(SCALER_H_COEFF3);    TestRegisterCaching(SCALER_H_COEFF4);    TestRegisterCaching(SCALER_BUF0_OFFSET_U);    TestRegisterCaching(SCALER_BUF0_OFFSET_V);    TestRegisterCaching(SCALER_BUF1_OFFSET_U);    TestRegisterCaching(SCALER_BUF1_OFFSET_V);}#ifdef USE_XAA/* * ATIMach64SetupForScreenToScreenCopy -- * * This function sets up the draw engine for a series of screen-to-screen copy * operations. */static voidATIMach64SetupForScreenToScreenCopy(    ScrnInfoPtr  pScreenInfo,    int          xdir,    int          ydir,    int          rop,    unsigned int planemask,    int          TransparencyColour){    ATIPtr pATI = ATIPTR(pScreenInfo);    ATIDRISync(pScreenInfo);    ATIMach64WaitForFIFO(pATI, 3);    outf(DP_WRITE_MASK, planemask);    outf(DP_SRC, DP_MONO_SRC_ALLONES |        SetBits(SRC_BLIT, DP_FRGD_SRC) | SetBits(SRC_BKGD, DP_BKGD_SRC));    outf(DP_MIX, SetBits(ATIMach64ALU[rop], DP_FRGD_MIX));#ifdef AVOID_DGA    if (TransparencyColour == -1)#else /* AVOID_DGA */    if (!pATI->XAAForceTransBlit && (TransparencyColour == -1))#endif /* AVOID_DGA */    {        outf(CLR_CMP_CNTL, CLR_CMP_FN_FALSE);    }    else    {        ATIMach64WaitForFIFO(pATI, 2);        outf(CLR_CMP_CLR, TransparencyColour);        outf(CLR_CMP_CNTL, CLR_CMP_FN_EQUAL | CLR_CMP_SRC_2D);    }    pATI->dst_cntl = 0;    if (ydir > 0)        pATI->dst_cntl |= DST_Y_DIR;    if (xdir > 0)        pATI->dst_cntl |= DST_X_DIR;    if (pATI->XModifier == 1)        outf(DST_CNTL, pATI->dst_cntl);    else        pATI->dst_cntl |= DST_24_ROT_EN;}/* * ATIMach64SubsequentScreenToScreenCopy -- * * This function performs a screen-to-screen copy operation. */static voidATIMach64SubsequentScreenToScreenCopy(    ScrnInfoPtr pScreenInfo,    int         xSrc,    int         ySrc,    int         xDst,    int         yDst,    int         w,    int         h){    ATIPtr pATI = ATIPTR(pScreenInfo);    xSrc *= pATI->XModifier;    xDst *= pATI->XModifier;    w    *= pATI->XModifier;    ATIDRISync(pScreenInfo);    /* Disable clipping if it gets in the way */    ATIMach64ValidateClip(pATI, xDst, xDst + w - 1, yDst, yDst + h - 1);    if (!(pATI->dst_cntl & DST_X_DIR))    {        xSrc += w - 1;        xDst += w - 1;    }    if (!(pATI->dst_cntl & DST_Y_DIR))    {        ySrc += h - 1;        yDst += h - 1;    }    if (pATI->XModifier != 1)        outf(DST_CNTL, pATI->dst_cntl | SetBits((xDst / 4) % 6, DST_24_ROT));    ATIMach64WaitForFIFO(pATI, 4);    outf(SRC_Y_X, SetWord(xSrc, 1) | SetWord(ySrc, 0));    outf(SRC_WIDTH1, w);    outf(DST_Y_X, SetWord(xDst, 1) | SetWord(yDst, 0));    outf(DST_HEIGHT_WIDTH, SetWord(w, 1) | SetWord(h, 0));    /*     * On VTB's and later, the engine will randomly not wait for a copy     * operation to commit its results to video memory before starting the next     * one.  The probability of such occurrences increases with GUI_WB_FLUSH     * (or GUI_WB_FLUSH_P) setting, bitsPerPixel and/or CRTC clock.  This     * would point to some kind of video memory bandwidth problem were it noti     * for the fact that the problem occurs less often (but still occurs) when     * copying larger rectangles.     */    if ((pATI->Chip >= ATI_CHIP_264VTB) && !pATI->OptionDevel)        ATIMach64Sync(pScreenInfo);}/* * ATIMach64SetupForSolidFill -- * * This function sets up the draw engine for a series of solid fills. */static void

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美另类久久久精品| 国产精品香蕉一区二区三区| 韩国一区二区三区| 色婷婷激情综合| 欧美成人video| 亚洲永久精品大片| av电影一区二区| 日韩欧美三级在线| 亚洲成av人片在线| 日本精品一区二区三区四区的功能| 欧美成人激情免费网| 青草av.久久免费一区| 欧美日韩国产成人在线免费| 亚洲日本在线天堂| 成人免费毛片片v| 欧美精品一区二区精品网| 天堂一区二区在线免费观看| 在线免费亚洲电影| 亚洲视频在线观看一区| av中文字幕一区| 国产精品三级电影| 成人小视频免费观看| 国产亚洲精品超碰| 精品一二三四区| 久久综合九色综合97婷婷女人 | 亚洲欧美日韩在线播放| 国产成人精品在线看| 亚洲精品一区在线观看| 精品亚洲成a人在线观看| 欧美精品第1页| 日韩电影在线一区| 欧美一区二区三区四区五区| 天堂午夜影视日韩欧美一区二区| 在线播放亚洲一区| 免费在线一区观看| 精品国产一二三区| 国产馆精品极品| 亚洲国产精品传媒在线观看| 国产盗摄精品一区二区三区在线| 国产日韩欧美综合在线| 成人精品一区二区三区四区| 国产精品久久久久久久久免费桃花| 国产成人av一区| 亚洲人成精品久久久久| 欧美自拍偷拍午夜视频| 免费成人性网站| 久久久久久久久久久99999| 国产91在线观看| 亚洲免费在线观看| 91麻豆精品国产综合久久久久久| 久久成人综合网| 国产精品久久久久久久久搜平片 | 欧美日韩一区二区三区高清| 秋霞影院一区二区| 久久精品一区二区三区av| 丁香婷婷综合激情五月色| 亚洲精品视频在线| 日韩色在线观看| av电影天堂一区二区在线| 夜夜操天天操亚洲| 欧美电影免费观看高清完整版在线观看| 久久国产三级精品| 亚洲精品中文字幕乱码三区| 91麻豆精品国产自产在线观看一区 | 国产aⅴ综合色| 亚洲视频综合在线| 亚洲精品在线免费播放| 91丝袜美女网| 美日韩一区二区| 国产精品超碰97尤物18| 欧美一区二区三区日韩视频| 成人污视频在线观看| 日韩avvvv在线播放| 国产精品国产三级国产三级人妇| 欧美精品第一页| 成人开心网精品视频| 视频一区二区三区在线| 久久久蜜臀国产一区二区| 日本韩国欧美国产| 国内偷窥港台综合视频在线播放| 亚洲黄色片在线观看| 久久精品视频免费| 91精品国产高清一区二区三区蜜臀| 国产高清精品在线| 蜜臀av一级做a爰片久久| 日韩一区在线免费观看| 精品国产乱码久久久久久浪潮| 色成人在线视频| 成人在线一区二区三区| 极品少妇xxxx精品少妇| 五月婷婷欧美视频| 一区二区在线观看免费视频播放| 久久久一区二区| 日韩一卡二卡三卡| 欧美日韩不卡一区| 在线日韩av片| 91久久奴性调教| 本田岬高潮一区二区三区| 国产资源在线一区| 美女视频黄a大片欧美| 天堂午夜影视日韩欧美一区二区| 亚洲美女在线一区| 国产精品国产三级国产普通话蜜臀 | 久久 天天综合| 日本成人中文字幕| 午夜国产精品影院在线观看| 亚洲精品福利视频网站| 亚洲桃色在线一区| 亚洲精品视频观看| 亚洲欧美激情插| 成人欧美一区二区三区| 中文字幕一区二区三区在线观看| 国产亚洲欧美一区在线观看| 久久九九影视网| 亚洲精品一区二区三区99| 欧美videos大乳护士334| 精品久久久网站| 久久久久88色偷偷免费| 国产午夜精品美女毛片视频| 国产三级欧美三级日产三级99 | 91美女片黄在线观看91美女| 97久久久精品综合88久久| 一本久久精品一区二区| 色欧美片视频在线观看在线视频| 色国产精品一区在线观看| 欧美三片在线视频观看| 欧美一区二区三区在线视频 | 国产永久精品大片wwwapp| 国产做a爰片久久毛片| 国产91对白在线观看九色| av在线播放成人| 在线视频观看一区| 日韩欧美123| 中文字幕乱码亚洲精品一区 | 精品一区二区免费在线观看| 激情成人综合网| 高清成人在线观看| 色婷婷激情综合| 日韩欧美一区二区在线视频| 久久蜜桃av一区二区天堂| 亚洲色图丝袜美腿| 欧美a一区二区| 成人国产精品免费网站| 精品视频一区二区三区免费| 精品日韩一区二区| 亚洲乱码国产乱码精品精98午夜 | 99久久精品国产网站| 欧美区在线观看| 国产日韩欧美高清| 亚洲综合在线五月| 国产一区二区三区四| 一本大道久久a久久精品综合| 日韩一区二区电影网| 国产精品久久久久四虎| 亚洲图片欧美视频| 国产精品亚洲第一区在线暖暖韩国| 91美女在线看| 国产清纯在线一区二区www| 亚洲国产精品视频| 国产91精品露脸国语对白| 欧美日韩国产大片| 综合激情成人伊人| 九九**精品视频免费播放| 色av成人天堂桃色av| 国产日韩亚洲欧美综合| 日韩成人一级片| 欧美视频三区在线播放| 久久综合99re88久久爱| 午夜视频一区在线观看| 99久久国产免费看| 国产亚洲一区二区三区四区| 日韩精品欧美成人高清一区二区| av网站一区二区三区| 久久久久久久久久看片| 日韩精品一区第一页| 色播五月激情综合网| 中文字幕av一区 二区| 精品一区二区三区的国产在线播放| 欧美性色综合网| 亚洲三级电影网站| av亚洲精华国产精华| 久久精品免费在线观看| 久久成人免费网站| 欧美一区日韩一区| 亚洲v精品v日韩v欧美v专区| 欧洲在线/亚洲| 一区二区三区精品视频| 99国产欧美久久久精品| 国产亚洲精品aa午夜观看| 韩国精品一区二区| 日韩网站在线看片你懂的| 日韩国产欧美一区二区三区| 欧美日韩精品久久久| 亚洲国产一区视频| 欧美色综合网站| 亚洲va国产天堂va久久en| 欧美午夜免费电影| 亚洲综合网站在线观看| 欧美性大战久久久| 亚洲电影第三页|