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

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

?? cabac.c

?? H264EncPlayer,H264協(xié)議解碼與播放代碼
?? 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++ )

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日韩亚州综合| 欧美影院午夜播放| 色综合久久精品| 欧美视频一区在线观看| 欧美sm极限捆绑bd| 国产精品无码永久免费888| 亚洲男女毛片无遮挡| 天堂成人国产精品一区| 国产乱码字幕精品高清av| 91麻豆精品秘密| 欧美大度的电影原声| 国产精品国产三级国产aⅴ原创| 亚洲综合偷拍欧美一区色| 久久99精品久久久久久久久久久久 | 亚洲综合一区二区三区| 久久精品国内一区二区三区| av激情综合网| 精品免费国产一区二区三区四区| 国产精品家庭影院| 美国十次了思思久久精品导航| 成人午夜视频网站| 欧美一区二区三区系列电影| 欧美韩日一区二区三区四区| 日日夜夜免费精品| av在线一区二区| 精品少妇一区二区三区在线播放| 国产精品久久久久久久久久免费看 | 国产成人综合在线| 欧美日韩另类国产亚洲欧美一级| 国产嫩草影院久久久久| 天天影视色香欲综合网老头| 成人免费高清在线| 日韩视频一区二区在线观看| 亚洲激情图片qvod| 成人精品gif动图一区| 日韩欧美在线观看一区二区三区| 自拍偷拍国产精品| 国产成人免费视频精品含羞草妖精| 欧美日本在线一区| 亚洲欧美色图小说| 顶级嫩模精品视频在线看| 日韩欧美高清dvd碟片| 亚洲欧美韩国综合色| 国产精品亚洲一区二区三区在线 | 麻豆极品一区二区三区| 欧美在线播放高清精品| 国产精品萝li| 国产成人aaa| 精品久久久久久久久久久久包黑料 | 国产69精品久久777的优势| 日韩一二三区不卡| 亚洲午夜久久久久| 色嗨嗨av一区二区三区| 国产精品久久影院| 国产99久久久久久免费看农村| 日韩区在线观看| 日韩成人精品在线| 欧美久久久久中文字幕| 亚洲综合在线观看视频| 91在线视频播放| 一区在线观看免费| av中文一区二区三区| 中文字幕第一区| 国产成人av影院| 久久久久88色偷偷免费| 国产又粗又猛又爽又黄91精品| 精品剧情v国产在线观看在线| 男女男精品视频| 91精品国产91久久久久久一区二区 | 国产在线精品一区二区| 日韩欧美在线123| 免费人成在线不卡| 欧美一二三区精品| 麻豆91在线播放免费| 精品区一区二区| 久久se精品一区二区| 精品美女一区二区| 国产一区二区主播在线| 久久综合999| 国产做a爰片久久毛片| 久久天天做天天爱综合色| 国产在线视视频有精品| 国产日韩欧美高清| 91在线观看成人| 亚洲一区二区三区美女| 欧美美女激情18p| 免费成人你懂的| 精品国产一区二区三区久久久蜜月| 狠狠色狠狠色合久久伊人| 久久久99免费| 成人爱爱电影网址| 亚洲精品免费播放| 欧美日韩精品欧美日韩精品一综合| 秋霞电影一区二区| 久久久精品国产免大香伊| 成人毛片老司机大片| 一区二区视频在线看| 欧美久久高跟鞋激| 韩国成人精品a∨在线观看| 欧美国产国产综合| 91麻豆精品一区二区三区| 亚洲高清免费一级二级三级| 日韩久久免费av| 成人高清免费在线播放| 一区二区三区丝袜| 欧美一区二区三区在线视频| 国产精品99久久久久久有的能看| 国产精品久久久久一区二区三区共 | 国产女主播一区| 色88888久久久久久影院按摩| 视频一区视频二区中文字幕| 久久精品一区二区三区不卡牛牛| 99久久精品久久久久久清纯| 五月婷婷激情综合| 国产偷国产偷精品高清尤物| 色婷婷久久久亚洲一区二区三区| 秋霞午夜av一区二区三区| 中文字幕 久热精品 视频在线| 精品1区2区3区| 国产黑丝在线一区二区三区| 悠悠色在线精品| 亚洲精品一区二区三区蜜桃下载| 99国产精品久久久久久久久久久| 免费高清成人在线| 亚洲品质自拍视频| 2023国产精品| 欧美日韩一二三区| 岛国一区二区三区| 美女性感视频久久| 一级精品视频在线观看宜春院 | 成人国产精品免费观看视频| 午夜成人在线视频| 国产精品人成在线观看免费| 欧美老肥妇做.爰bbww| 国产.欧美.日韩| 热久久一区二区| 亚洲国产日韩综合久久精品| 中文字幕第一页久久| 日韩午夜电影在线观看| 在线观看三级视频欧美| 国产.欧美.日韩| 久久精品国产99国产| 一区二区三区在线观看网站| 久久精品亚洲精品国产欧美| 欧美一区二区三区在线电影| 在线视频欧美区| 菠萝蜜视频在线观看一区| 麻豆成人免费电影| 亚洲va欧美va人人爽| 亚洲色图在线看| 亚洲国产精品v| 久久色.com| 日韩欧美国产三级| 欧美伦理电影网| 91国偷自产一区二区开放时间 | 18欧美亚洲精品| 久久九九全国免费| 日韩精品综合一本久道在线视频| 欧美亚一区二区| 色av综合在线| 91免费小视频| av不卡免费电影| 成人午夜精品一区二区三区| 国产自产2019最新不卡| 麻豆精品在线视频| 日本成人在线电影网| 天天影视涩香欲综合网| 亚洲mv在线观看| 亚洲一区二区三区四区的| 亚洲丝袜另类动漫二区| 中文字幕亚洲欧美在线不卡| 中文字幕成人网| 欧美国产日产图区| 国产欧美日韩综合| 国产欧美精品一区| 国产精品三级av| 中文字幕欧美激情一区| 欧美国产国产综合| 国产精品久久久久久久岛一牛影视| 亚洲国产成人一区二区三区| 中文字幕欧美三区| 中文字幕一区二区三区不卡| 亚洲欧美在线aaa| 综合网在线视频| 亚洲综合图片区| 午夜精品福利一区二区三区av | 日韩欧美激情一区| 欧美mv和日韩mv的网站| 精品国产伦一区二区三区观看体验| 日韩欧美在线网站| 久久久久一区二区三区四区| 欧美激情在线一区二区| 国产精品二三区| 亚洲欧美偷拍另类a∨色屁股| 一区二区三区成人| 图片区小说区区亚洲影院| 日本中文字幕一区二区视频 | 欧美tk—视频vk| 国产亚洲污的网站| 亚洲欧洲无码一区二区三区|