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

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

?? cabac.c

?? 文件為H.264編解碼器 僅供參考 包括windows版本和DM642版本
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*****************************************************************************
*
*  T264 AVC CODEC
*
*  Copyright(C) 2004-2005 joylife	<joylife_video@yahoo.com.cn>
*				2004-2005 tricro	<tricro@hotmail.com>
*
*  This program is free software ; you can redistribute it and/or modify
*  it under the terms of the GNU General Public License as published by
*  the Free Software Foundation ; either version 2 of the License, or
*  (at your option) any later version.
*
*  This program is distributed in the hope that it will be useful,
*  but WITHOUT ANY WARRANTY ; without even the implied warranty of
*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
*  GNU General Public License for more details.
*
*  You should have received a copy of the GNU General Public License
*  along with this program ; if not, write to the Free Software
*  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
*
****************************************************************************/

/*****************************************************************************
 * cabac.c: h264 encoder library
 *****************************************************************************
 * Copyright (C) 2003 Laurent Aimar
 *
 * Authors: Laurent Aimar <fenrir@via.ecp.fr>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
 *****************************************************************************/

/*Note: the CABAC routine is currently referenced from x264 temporarily, with adaptation to 
 *the data structure of T264. It should be modified further in the near future.
 *It's can support B slice, but only with MB mode P16x16, P16x8, P8x16, Direct16x16, B_SKIP
 *ie., B8x8 is not support now
*/

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <assert.h>
#include "T264.h"
#include "cabac_engine.h"
#include "inter.h"
/* From ffmpeg
*/
#define T264_SCAN8_SIZE (6*8)
#define T264_SCAN8_0 (4+1*8)

static const int T264_scan8[16+2*4] =
{
	/* Luma */
	VEC_LUMA + 0, VEC_LUMA + 1, VEC_LUMA + 1*8 + 0, VEC_LUMA + 1*8 + 1,
	VEC_LUMA + 2, VEC_LUMA + 3, VEC_LUMA + 1*8 + 2, VEC_LUMA + 1*8 + 3,
	VEC_LUMA + 2*8 + 0, VEC_LUMA + 2*8 + 1, VEC_LUMA + 3*8 + 0, VEC_LUMA + 3*8 + 1,
	VEC_LUMA + 2*8 + 2, VEC_LUMA + 2*8 + 3, VEC_LUMA + 3*8 + 2, VEC_LUMA + 3*8 + 3,

	/* Cb */
	NNZ_CHROMA0 + 0, NNZ_CHROMA0 + 1,
	NNZ_CHROMA0 + 1*8 + 0, NNZ_CHROMA0 + 1*8 + 1,

	/* Cr */
	NNZ_CHROMA1 + 0, NNZ_CHROMA1 + 1,
	NNZ_CHROMA1 + 1*8 + 0, NNZ_CHROMA1 + 1*8 + 1,
};
static const uint8_t block_idx_xy[4][4] =
{
	{ 0, 2, 8,  10},
	{ 1, 3, 9,  11},
	{ 4, 6, 12, 14},
	{ 5, 7, 13, 15}
};

#define IS_INTRA(mode) (mode == I_4x4 || mode == I_16x16)
#define IS_SKIP(type)  ( (type) == P_SKIP || (type) == B_SKIP )
enum {
	INTRA_4x4           = 0,
	INTRA_16x16         = 1,
	INTRA_PCM           = 2,

	P_L0            = 3,
	P_8x81          = 4,
	P_SKIP1         = 5,

	B_DIRECT        = 6,
	B_L0_L0         = 7,
	B_L0_L1         = 8,
	B_L0_BI         = 9,
	B_L1_L0         = 10,
	B_L1_L1         = 11,
	B_L1_BI         = 12,
	B_BI_L0         = 13,
	B_BI_L1         = 14,
	B_BI_BI         = 15,
	B_8x81          = 16,
	B_SKIP1         = 17,
};

static const int T264_mb_partition_listX_table[][2] = 
{
	{0, 0}, //B_DIRECT_8x8 = 100,
	{1, 0}, //B_L0_8x8,
	{0, 1}, //B_L1_8x8,
	{1, 1}, //B_Bi_8x8,
	{1, 0}, //B_L0_8x4,
	{1, 0}, //B_L0_4x8,
	{0, 1}, //B_L1_8x4,
	{0, 1}, //B_L1_4x8,
	{1, 1}, //B_Bi_8x4,
	{1, 1}, //B_Bi_4x8,
	{1, 0}, //B_L0_4x4,
	{0, 1},	//B_L1_4x4,
	{1, 1}	//B_Bi_4x4
};

static const int T264_mb_type_list0_table[18][2] =
{
	{0,0}, {0,0}, {0,0},    /* INTRA */
	{1,1},                  /* P_L0 */
	{0,0},                  /* P_8x8 */
	{1,1},                  /* P_SKIP */
	{0,0},                  /* B_DIRECT */
	{1,1}, {1,0}, {1,1},    /* B_L0_* */
	{0,1}, {0,0}, {0,1},    /* B_L1_* */
	{1,1}, {1,0}, {1,1},    /* B_BI_* */
	{0,0},                  /* B_8x8 */
	{0,0}                   /* B_SKIP */
};
static const int T264_mb_type_list1_table[18][2] =
{
	{0,0}, {0,0}, {0,0},    /* INTRA */
	{0,0},                  /* P_L0 */
	{0,0},                  /* P_8x8 */
	{0,0},                  /* P_SKIP */
	{0,0},                  /* B_DIRECT */
	{0,0}, {0,1}, {0,1},    /* B_L0_* */
	{1,0}, {1,1}, {1,1},    /* B_L1_* */
	{1,0}, {1,1}, {1,1},    /* B_BI_* */
	{0,0},                  /* B_8x8 */
	{0,0}                   /* B_SKIP */
};

static void T264_cabac_mb_type( T264_t *t )
{
	T264_mb_context_t *mb_ctxs = &(t->rec->mb[0]);
    int32_t mb_mode = t->mb.mb_mode;

    if( t->slice_type == SLICE_I )
    {
        int ctx = 0;
        if( t->mb.mb_x > 0 && mb_ctxs[t->mb.mb_xy-1].mb_mode != I_4x4 )
        {
            ctx++;
        }
        if( t->mb.mb_y > 0 && mb_ctxs[t->mb.mb_xy - t->mb_stride].mb_mode != I_4x4 )
        {
            ctx++;
        }

        if( mb_mode == I_4x4 )
        {
            T264_cabac_encode_decision( &t->cabac, 3 + ctx, 0 );
        }
        else if(mb_mode == I_16x16)   /* I_16x16 */
        {
            T264_cabac_encode_decision( &t->cabac, 3 + ctx, 1 );
            T264_cabac_encode_terminal( &t->cabac, 0 );

            T264_cabac_encode_decision( &t->cabac, 3 + 3, ( t->mb.cbp_y == 0 ? 0 : 1 ));
            if( t->mb.cbp_c == 0 )
            {
                T264_cabac_encode_decision( &t->cabac, 3 + 4, 0 );
            }
            else
            {
                T264_cabac_encode_decision( &t->cabac, 3 + 4, 1 );
                T264_cabac_encode_decision( &t->cabac, 3 + 5, ( t->mb.cbp_c == 1 ? 0 : 1 ) );
            }
            T264_cabac_encode_decision( &t->cabac, 3 + 6, ( (t->mb.mode_i16x16 / 2) ? 1 : 0 ));
            T264_cabac_encode_decision( &t->cabac, 3 + 7, ( (t->mb.mode_i16x16 % 2) ? 1 : 0 ));
        }
		else	/* I_PCM */
		{
			T264_cabac_encode_decision( &t->cabac, 3 + ctx, 1 );
			T264_cabac_encode_terminal( &t->cabac, 1 );
		}
    }
    else if( t->slice_type == SLICE_P )
    {
        /* prefix: 14, suffix: 17 */
        if( mb_mode == P_MODE )
        {
            if( t->mb.mb_part == MB_16x16 )
            {
                T264_cabac_encode_decision( &t->cabac, 14, 0 );
                T264_cabac_encode_decision( &t->cabac, 15, 0 );
                T264_cabac_encode_decision( &t->cabac, 16, 0 );
            }
            else if( t->mb.mb_part == MB_16x8 )
            {
                T264_cabac_encode_decision( &t->cabac, 14, 0 );
                T264_cabac_encode_decision( &t->cabac, 15, 1 );
                T264_cabac_encode_decision( &t->cabac, 17, 1 );
            }
            else if( t->mb.mb_part == MB_8x16 )
            {
                T264_cabac_encode_decision( &t->cabac, 14, 0 );
                T264_cabac_encode_decision( &t->cabac, 15, 1 );
                T264_cabac_encode_decision( &t->cabac, 17, 0 );
            }
			else /* P8x8 mode */
			{
				T264_cabac_encode_decision( &t->cabac, 14, 0 );
				T264_cabac_encode_decision( &t->cabac, 15, 0 );
				T264_cabac_encode_decision( &t->cabac, 16, 1 );
			}
        }
        else if( mb_mode == I_4x4 )
        {
            /* prefix */
            T264_cabac_encode_decision( &t->cabac, 14, 1 );

            T264_cabac_encode_decision( &t->cabac, 17, 0 );
        }
        else if(mb_mode == I_16x16) /* intra 16x16 */
        {
            /* prefix */
            T264_cabac_encode_decision( &t->cabac, 14, 1 );

            /* suffix */
            T264_cabac_encode_decision( &t->cabac, 17, 1 );
            T264_cabac_encode_terminal( &t->cabac, 0 ); /*ctxIdx == 276 */

            T264_cabac_encode_decision( &t->cabac, 17+1, ( t->mb.cbp_y == 0 ? 0 : 1 ));
            if( t->mb.cbp_c == 0 )
            {
                T264_cabac_encode_decision( &t->cabac, 17+2, 0 );
            }
            else
            {
                T264_cabac_encode_decision( &t->cabac, 17+2, 1 );
                T264_cabac_encode_decision( &t->cabac, 17+2, ( t->mb.cbp_c == 1 ? 0 : 1 ) );
            }
            T264_cabac_encode_decision( &t->cabac, 17+3, ( (t->mb.mode_i16x16 / 2) ? 1 : 0 ));
            T264_cabac_encode_decision( &t->cabac, 17+3, ( (t->mb.mode_i16x16 % 2) ? 1 : 0 ));
        }
		else /* I_PCM */
		{
			/* prefix */
			T264_cabac_encode_decision( &t->cabac, 14, 1 );

			T264_cabac_encode_decision( &t->cabac, 17, 1 );
			T264_cabac_encode_terminal( &t->cabac, 1 ); /*ctxIdx == 276 */
		}
    }
    else if( t->slice_type == SLICE_B )
    {
		int ctx = 0;
		if( t->mb.mb_x > 0 && mb_ctxs[t->mb.mb_xy-1].mb_mode != B_SKIP && !mb_ctxs[t->mb.mb_xy-1].is_copy )
		{
			ctx++;
		}
		if( t->mb.mb_y > 0 && mb_ctxs[t->mb.mb_xy - t->mb_stride].mb_mode != B_SKIP && ! mb_ctxs[t->mb.mb_xy - t->mb_stride].is_copy)
		{
			ctx++;
		}
        
        if( t->mb.is_copy)
        {
            T264_cabac_encode_decision( &t->cabac, 27+ctx, 0 );
        }
        else if( t->mb.mb_part == MB_8x8 )
        {
            T264_cabac_encode_decision( &t->cabac, 27+ctx, 1 );
            T264_cabac_encode_decision( &t->cabac, 27+3,   1 );
            T264_cabac_encode_decision( &t->cabac, 27+4,   1 );

            T264_cabac_encode_decision( &t->cabac, 27+5,   1 );
            T264_cabac_encode_decision( &t->cabac, 27+5,   1 );
            T264_cabac_encode_decision( &t->cabac, 27+5,   1 );
        }
        else if( IS_INTRA( mb_mode ) )
        {
            /* prefix */
            T264_cabac_encode_decision( &t->cabac, 27+ctx, 1 );
            T264_cabac_encode_decision( &t->cabac, 27+3,   1 );
            T264_cabac_encode_decision( &t->cabac, 27+4,   1 );

            T264_cabac_encode_decision( &t->cabac, 27+5,   1 );
            T264_cabac_encode_decision( &t->cabac, 27+5,   0 );
            T264_cabac_encode_decision( &t->cabac, 27+5,   1 );

            /* Suffix */
            if( mb_mode == I_4x4 )
            {
                T264_cabac_encode_decision( &t->cabac, 32, 0 );
            }
			else if(mb_mode == I_16x16)
			{
				T264_cabac_encode_decision( &t->cabac, 32, 1 );
				T264_cabac_encode_terminal( &t->cabac,     0 );

				/* TODO */
				T264_cabac_encode_decision( &t->cabac, 32+1, ( t->mb.cbp_y == 0 ? 0 : 1 ));
				if( t->mb.cbp_c == 0 )
				{
					T264_cabac_encode_decision( &t->cabac, 32+2, 0 );
				}
				else
				{
					T264_cabac_encode_decision( &t->cabac, 32+2, 1 );
					T264_cabac_encode_decision( &t->cabac, 32+2, ( t->mb.cbp_c == 1 ? 0 : 1 ) );
				}
				T264_cabac_encode_decision( &t->cabac, 32+3, ( (t->mb.mode_i16x16 / 2) ? 1 : 0 ));
				T264_cabac_encode_decision( &t->cabac, 32+3, ( (t->mb.mode_i16x16 % 2) ? 1 : 0 ));
			}
            else /* I_PCM */
            {
                T264_cabac_encode_decision( &t->cabac, 32, 1 );
                T264_cabac_encode_terminal( &t->cabac,     1 );
            }
            
        }
        else
        {
            static const int i_mb_len[21] =
            {
                3, 6, 6,    /* L0 L0 */
                3, 6, 6,    /* L1 L1 */
                6, 7, 7,    /* BI BI */

                6, 6,       /* L0 L1 */
                6, 6,       /* L1 L0 */
                7, 7,       /* L0 BI */
                7, 7,       /* L1 BI */
                7, 7,       /* BI L0 */
                7, 7,       /* BI L1 */
            };
            static const int i_mb_bits[21][7] =
            {
                { 1, 0, 0, },            { 1, 1, 0, 0, 0, 1, },    { 1, 1, 0, 0, 1, 0, },   /* L0 L0 */
                { 1, 0, 1, },            { 1, 1, 0, 0, 1, 1, },    { 1, 1, 0, 1, 0, 0, },   /* L1 L1 */
                { 1, 1, 0, 0, 0, 0 ,},   { 1, 1, 1, 1, 0, 0 , 0 }, { 1, 1, 1, 1, 0, 0 , 1 },/* BI BI */

                { 1, 1, 0, 1, 0, 1, },   { 1, 1, 0, 1, 1, 0, },     /* L0 L1 */
                { 1, 1, 0, 1, 1, 1, },   { 1, 1, 1, 1, 1, 0, },     /* L1 L0 */
                { 1, 1, 1, 0, 0, 0, 0 }, { 1, 1, 1, 0, 0, 0, 1 },   /* L0 BI */
                { 1, 1, 1, 0, 0, 1, 0 }, { 1, 1, 1, 0, 0, 1, 1 },   /* L1 BI */
                { 1, 1, 1, 0, 1, 0, 0 }, { 1, 1, 1, 0, 1, 0, 1 },   /* BI L0 */
                { 1, 1, 1, 0, 1, 1, 0 }, { 1, 1, 1, 0, 1, 1, 1 }    /* BI L1 */
            };

            const int i_partition = t->mb.mb_part;
            int idx = 0;
            int i, b_part_mode, part_mode0, part_mode1;
			static const int b_part_mode_map[3][3] = {
				{ B_L0_L0, B_L0_L1, B_L0_BI },
				{ B_L1_L0, B_L1_L1, B_L1_BI },
				{ B_BI_L0, B_BI_L1, B_BI_BI }
			};

			switch(t->mb.mb_part)
			{
			case MB_16x16:
				part_mode0 = t->mb.mb_part2[0] - B_L0_16x16;
				b_part_mode = b_part_mode_map[part_mode0][part_mode0];
				break;
			case MB_16x8:
				part_mode0 = t->mb.mb_part2[0] - B_L0_16x8;
				part_mode1 = t->mb.mb_part2[1] - B_L0_16x8;
				b_part_mode = b_part_mode_map[part_mode0][part_mode1];
				break;
			case MB_8x16:
				part_mode0 = t->mb.mb_part2[0] - B_L0_8x16;
				part_mode1 = t->mb.mb_part2[1] - B_L0_8x16;
				b_part_mode = b_part_mode_map[part_mode0][part_mode1];
				break;
			}
            switch( b_part_mode )
            {
                /* D_16x16, D_16x8, D_8x16 */
                case B_BI_BI: idx += 3;
                case B_L1_L1: idx += 3;
                case B_L0_L0:
                    if( i_partition == MB_16x8 )
                        idx += 1;
                    else if( i_partition == MB_8x16 )
                        idx += 2;
                    break;

                /* D_16x8, D_8x16 */
                case B_BI_L1: idx += 2;
                case B_BI_L0: idx += 2;
                case B_L1_BI: idx += 2;
                case B_L0_BI: idx += 2;
                case B_L1_L0: idx += 2;
                case B_L0_L1:
                    idx += 3*3;
                    if( i_partition == MB_8x16 )
                        idx++;
                    break;
                default:
					return;
			}

            T264_cabac_encode_decision( &t->cabac, 27+ctx,                         i_mb_bits[idx][0] );
            T264_cabac_encode_decision( &t->cabac, 27+3,                           i_mb_bits[idx][1] );
            T264_cabac_encode_decision( &t->cabac, 27+(i_mb_bits[idx][1] != 0 ? 4 : 5), i_mb_bits[idx][2] );
            for( i = 3; i < i_mb_len[idx]; i++ )
            {
                T264_cabac_encode_decision( &t->cabac, 27+5,                       i_mb_bits[idx][i] );
            }
        }
    }
    else
    {
		//dummy here
    }
}

static void T264_cabac_mb_intra4x4_pred_mode( T264_t *t, int i_pred, int i_mode )
{
    if( i_pred == i_mode )
    {
        /* b_prev_intra4x4_pred_mode */
        T264_cabac_encode_decision( &t->cabac, 68, 1 );
    }
    else
    {
        /* b_prev_intra4x4_pred_mode */
        T264_cabac_encode_decision( &t->cabac, 68, 0 );
        if( i_mode > i_pred  )
        {
            i_mode--;
        }
        T264_cabac_encode_decision( &t->cabac, 69, (i_mode     )&0x01 );
        T264_cabac_encode_decision( &t->cabac, 69, (i_mode >> 1)&0x01 );
        T264_cabac_encode_decision( &t->cabac, 69, (i_mode >> 2)&0x01 );
    }
}

static void T264_cabac_mb_intra8x8_pred_mode( T264_t *t )
{
    const int i_mode  = t->mb.mb_mode_uv;
	T264_mb_context_t *mb_ctxs = &(t->rec->mb[0]);

	int ctx = 0;
	if( t->mb.mb_x > 0 && mb_ctxs[t->mb.mb_xy-1].mb_mode_uv != Intra_8x8_DC)
	{
		ctx++;
	}
	if( t->mb.mb_y > 0 && mb_ctxs[t->mb.mb_xy - t->mb_stride].mb_mode_uv != Intra_8x8_DC )
	{
		ctx++;
	}
	
    if( i_mode == Intra_8x8_DC )
    {
        T264_cabac_encode_decision( &t->cabac, 64 + ctx, Intra_8x8_DC );
    }
    else
    {
        T264_cabac_encode_decision( &t->cabac, 64 + ctx, 1 );
        T264_cabac_encode_decision( &t->cabac, 64 + 3, ( i_mode == 1 ? 0 : 1 ) );
        if( i_mode > 1 )
        {
            T264_cabac_encode_decision( &t->cabac, 64 + 3, ( i_mode == 2 ? 0 : 1 ) );
        }
    }
}

static void T264_cabac_mb_cbp_luma( T264_t *t )
{
    /* TODO: clean up and optimize */
	T264_mb_context_t *mb_ctxs = &(t->rec->mb[0]);
    int i8x8;
    for( i8x8 = 0; i8x8 < 4; i8x8++ )

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕乱码日本亚洲一区二区 | 秋霞午夜av一区二区三区| 日韩av午夜在线观看| 成人午夜av电影| 91麻豆精品国产91| 亚洲视频在线观看三级| 老司机一区二区| 在线观看欧美日本| 国产女人18毛片水真多成人如厕| 婷婷成人激情在线网| 色综合色综合色综合色综合色综合| 欧美tickling网站挠脚心| 亚洲一区二区av在线| 不卡一区二区中文字幕| 精品国产三级电影在线观看| 婷婷综合另类小说色区| 在线观看不卡一区| 亚洲日本青草视频在线怡红院| 粉嫩av一区二区三区粉嫩| 日韩欧美的一区| 日韩国产成人精品| 欧美嫩在线观看| 亚洲电影你懂得| 欧洲色大大久久| 亚洲黄色av一区| 色香蕉成人二区免费| 一区二区三区中文字幕精品精品 | 久久综合精品国产一区二区三区| 亚洲国产美女搞黄色| 色婷婷av一区二区三区大白胸| 国产精品黄色在线观看| 粉嫩绯色av一区二区在线观看| 久久精品人人做人人综合| 国产精品羞羞答答xxdd| www国产精品av| 国产乱码精品1区2区3区| 久久亚洲免费视频| 国产成人午夜视频| 国产精品久久久久婷婷二区次| 成人国产精品视频| 亚洲欧美激情插| 欧美在线观看18| 五月综合激情网| 精品国产乱码久久久久久久久| 韩日精品视频一区| 亚洲国产成人在线| 91视频一区二区三区| 亚洲一区在线观看网站| 91精品国产麻豆国产自产在线 | 亚洲精品久久嫩草网站秘色| 欧美视频一区在线| 美女任你摸久久| 久久久一区二区| 91小视频在线观看| 丝袜美腿亚洲综合| 精品国产乱码久久久久久图片| 国产精品白丝jk黑袜喷水| 亚洲天堂免费在线观看视频| 欧美日韩电影在线| 国内精品伊人久久久久av一坑| 国产欧美日韩亚州综合| 欧美曰成人黄网| 久久福利视频一区二区| 亚洲四区在线观看| 5858s免费视频成人| 福利一区二区在线| 成人精品视频一区| 亚洲女与黑人做爰| 日韩精品一区二区三区在线 | 26uuu国产一区二区三区| 成人免费不卡视频| 亚洲国产一区二区a毛片| 久久久美女毛片| 欧美午夜精品久久久久久孕妇| 国产在线观看一区二区| 亚洲精品国久久99热| 精品成人一区二区三区四区| 色综合久久综合| 国产剧情一区二区三区| 亚洲国产精品尤物yw在线观看| 精品国产乱码久久久久久老虎 | 高潮精品一区videoshd| 性做久久久久久| 懂色av一区二区三区免费观看| 欧美成人免费网站| 91美女视频网站| 国产成人在线视频播放| 午夜成人在线视频| 日韩码欧中文字| 国产欧美日韩久久| 欧美一级高清片在线观看| 99久久综合狠狠综合久久| 国产一区二区在线观看免费| 日韩中文欧美在线| 亚洲欧美另类图片小说| 国产视频一区二区在线观看| 欧美精三区欧美精三区| 在线看一区二区| voyeur盗摄精品| 福利视频网站一区二区三区| 久草在线在线精品观看| 日韩国产欧美在线视频| 一级中文字幕一区二区| 综合在线观看色| 国产精品女主播在线观看| 久久久精品日韩欧美| 精品粉嫩超白一线天av| 欧美一区二区视频在线观看2022 | 日韩av电影免费观看高清完整版在线观看| 欧美激情在线观看视频免费| 日韩免费视频线观看| 6080亚洲精品一区二区| 69堂亚洲精品首页| 777亚洲妇女| 日韩视频免费观看高清完整版在线观看| 在线观看亚洲a| 色94色欧美sute亚洲线路二| 色综合激情五月| 在线影视一区二区三区| 欧美影片第一页| 欧美日韩国产首页在线观看| 欧美美女视频在线观看| 欧美体内she精视频| 欧美美女网站色| 日韩欧美第一区| 国产天堂亚洲国产碰碰| 国产精品国产三级国产专播品爱网 | 成人黄色电影在线 | 中文字幕久久午夜不卡| 国产欧美日韩不卡| 综合色中文字幕| 亚洲一区二区高清| 婷婷夜色潮精品综合在线| 男人的天堂久久精品| 国模大尺度一区二区三区| 国产91综合网| 色94色欧美sute亚洲线路一ni| 欧美日韩一区二区三区高清| 日韩一区二区精品| 国产日韩精品一区| 一区二区三区在线免费播放| 日韩高清一区二区| 国产99久久久国产精品潘金| 色狠狠色狠狠综合| 精品奇米国产一区二区三区| 国产精品视频线看| 亚洲成人在线观看视频| 国产毛片一区二区| 91高清视频免费看| 亚洲精品一区二区在线观看| 亚洲欧美影音先锋| 日韩高清电影一区| 国产成人亚洲精品狼色在线| 欧美色倩网站大全免费| 国产性色一区二区| 亚洲不卡在线观看| 国产乱码一区二区三区| 色哟哟精品一区| 久久一二三国产| 亚洲大片在线观看| 成人黄色在线视频| 欧美一卡二卡在线| 亚洲欧美日韩一区| 国产激情一区二区三区桃花岛亚洲 | 91精品在线免费| 国产精品久久久久久久久免费丝袜 | 国产精品女同互慰在线看| 午夜成人免费视频| 91视频在线看| 久久精品亚洲精品国产欧美| 午夜精品视频在线观看| 床上的激情91.| 精品久久久久久无| 婷婷久久综合九色综合绿巨人 | 蜜桃视频一区二区三区在线观看| 91亚洲资源网| 中文字幕久久午夜不卡| 韩日欧美一区二区三区| 7777精品伊人久久久大香线蕉超级流畅| 国产精品少妇自拍| 国产在线不卡一卡二卡三卡四卡| 欧美日韩国产高清一区二区三区| 最新不卡av在线| 成人黄色777网| 国产女人18毛片水真多成人如厕| 久久精品国产一区二区三| 欧美伊人久久久久久午夜久久久久| 国产精品视频一二| 国产成人aaa| 国产色婷婷亚洲99精品小说| 另类小说图片综合网| 欧美人体做爰大胆视频| 一区二区三区电影在线播| 日本高清不卡视频| 亚洲精品菠萝久久久久久久| 99re这里都是精品| 成人免费在线视频观看| 94色蜜桃网一区二区三区| 国产精品久久一卡二卡| av一区二区三区|