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

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

?? b_frame.c

?? Mobile IP VCEG的信道模擬程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
/****************************************************************
 *
 *  File b_frame.c :	B picture Decoding 
 *
 *	Main contributor and Contact Information
 *
 *      Byeong-Moon Jeon			<jeonbm@lge.com>
 *      Yoon-Seong Soh				<yunsung@lge.com>
 *      LG Electronics Inc., Digital Media Research Lab.
 *      16 Woomyeon-Dong, Seocho-Gu, Seoul, 137-724, Korea
 *
 *  Changes:
 *      Thomas Wedi					<wedi@tnt.uni-hannover.de>
 *
 *****************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>

#include "global.h"
#include "b_frame.h"
#include "elements.h"

#define POS 0


/************************************************************************
*
*  Name :       SetLoopfilterStrength_B()
*
*  Description: Set the filter strength for a macroblock of a B-frame
*
************************************************************************/
void SetLoopfilterStrength_B(struct img_par *img)
{
	int i,j;
	int ii,jj;
	int i3,j3,mvDiffX,mvDiffY;
	

    if (img->imod == INTRA_MB_OLD || img->imod == INTRA_MB_NEW)
    {
      for (i=0;i<4;i++)
		  {
			  ii=img->block_x+i;
			  i3=ii/2;
			  for (j=0;j<4;j++)
			  {
				  jj=img->block_y+j;
				  j3=jj/2;
				  loopb[ii+1][jj+1]=3;
				  loopb[ii  ][jj+1]=max(loopb[ii  ][jj+1],2);
				  loopb[ii+1][jj  ]=max(loopb[ii+1][jj  ],2);
				  loopb[ii+2][jj+1]=max(loopb[ii+2][jj+1],2);
				  loopb[ii+1][jj+2]=max(loopb[ii+1][jj+2],2);

				  loopc[i3+1][j3+1]=2;
				  loopc[i3  ][j3+1]=max(loopc[i3  ][j3+1],1);
				  loopc[i3+1][j3  ]=max(loopc[i3+1][j3  ],1);
				  loopc[i3+2][j3+1]=max(loopc[i3+2][j3+1],1);
				  loopc[i3+1][j3+2]=max(loopc[i3+1][j3+2],1);
			  }
		  }
    }


    if (img->imod==B_Forward || img->imod==B_Bidirect) /* inter one direction */
    {
        for (i=0;i<4;i++)
        {
            ii=img->block_x+i;
            i3=ii/2;
            for (j=0;j<4;j++)
            {
                jj=img->block_y+j;
                j3=jj/2;
        
                mvDiffX = img->fw_mv[ii+4][jj][0] - img->fw_mv[ii-1+4][jj][0];
                mvDiffY = img->fw_mv[ii+4][jj][1] - img->fw_mv[ii-1+4][jj][1];

                if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && ii > 0)
                { 
                    loopb[ii  ][jj+1]=max(loopb[ii  ][jj+1],1);
                    loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1); 
                    loopc[i3  ][j3+1]=max(loopc[i3  ][j3+1],1);
                    loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);
                }

                if (jj >0)
                {
                    mvDiffX = img->fw_mv[ii+4][jj][0] - img->fw_mv[ii+4][jj-1][0];
                    mvDiffY = img->fw_mv[ii+4][jj][1] - img->fw_mv[ii+4][jj-1][1];

                    if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && jj > 0)
                    {
                        loopb[ii+1][jj  ]=max(loopb[ii+1][jj  ],1);
                        loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1);
                        loopc[i3+1][j3  ]=max(loopc[i3+1][j3  ],1);
                        loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);
                    }
                }
            }
        }
    }



    if(img->imod==B_Backward || img->imod==B_Bidirect) /* inter other direction */
    {
        for (i=0;i<4;i++)
        {
            ii=img->block_x+i;
            i3=ii/2;
            for (j=0;j<4;j++)
            {
                jj=img->block_y+j;
                j3=jj/2;
        
                mvDiffX = img->bw_mv[ii+4][jj][0] - img->bw_mv[ii-1+4][jj][0];
                mvDiffY = img->bw_mv[ii+4][jj][1] - img->bw_mv[ii-1+4][jj][1];

                if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && ii > 0)
                { 
                    loopb[ii  ][jj+1]=max(loopb[ii  ][jj+1],1);
                    loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1); 
                    loopc[i3  ][j3+1]=max(loopc[i3  ][j3+1],1);
                    loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);                    
                }
                    
                if (jj > 0)
                {
                    mvDiffX = img->bw_mv[ii+4][jj][0] - img->bw_mv[ii+4][jj-1][0];
                    mvDiffY = img->bw_mv[ii+4][jj][1] - img->bw_mv[ii+4][jj-1][1];

                    if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && jj > 0)
                    {
                        loopb[ii+1][jj  ]=max(loopb[ii+1][jj  ],1);
                        loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1);
                        loopc[i3+1][j3  ]=max(loopc[i3+1][j3  ],1);
                        loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);
                    }
                }
            }
        }
    }

    if(img->imod==B_Direct)
    {
        for(j=0;j<MB_BLOCK_SIZE/BLOCK_SIZE;j++)
	    {
		    jj=img->block_y+j;
		    for(i=0;i<MB_BLOCK_SIZE/BLOCK_SIZE;i++)
		    {
			    ii=img->block_x+i;
        	    i3=ii/2;
				j3=jj/2;

				mvDiffX = img->dfMV[ii+4][jj][0] - img->dfMV[ii-1+4][jj][0];
				mvDiffY = img->dfMV[ii+4][jj][1] - img->dfMV[ii-1+4][jj][1];
				if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && ii > 0)
				{ 
					loopb[ii  ][jj+1]=max(loopb[ii  ][jj+1],1);
					loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1); 
					loopc[i3  ][j3+1]=max(loopc[i3  ][j3+1],1);
					loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);                    
				}

			    if (jj > 0)
				{

					mvDiffX = img->dfMV[ii+4][jj][0] - img->dfMV[ii+4][jj-1][0];
					mvDiffY = img->dfMV[ii+4][jj][1] - img->dfMV[ii+4][jj-1][1];
					if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && jj > 0)
					{
						loopb[ii+1][jj  ]=max(loopb[ii+1][jj  ],1);
						loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1);
						loopc[i3+1][j3  ]=max(loopc[i3+1][j3  ],1);
						loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);
					}
				}		

				mvDiffX = img->dbMV[ii+4][jj][0] - img->dbMV[ii-1+4][jj][0];
				mvDiffY = img->dbMV[ii+4][jj][1] - img->dbMV[ii-1+4][jj][1];
				if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && ii > 0)
				{ 
					loopb[ii  ][jj+1]=max(loopb[ii  ][jj+1],1);
					loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1); 
					loopc[i3  ][j3+1]=max(loopc[i3  ][j3+1],1);
					loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);                    
		        }
				if (jj > 0)
				{

					mvDiffX = img->dbMV[ii+4][jj][0] - img->dbMV[ii+4][jj-1][0];
					mvDiffY = img->dbMV[ii+4][jj][1] - img->dbMV[ii+4][jj-1][1];
					if((mvDiffX*mvDiffX >= 16 || mvDiffY*mvDiffY >= 16) && jj > 0)
					{
						loopb[ii+1][jj  ]=max(loopb[ii+1][jj  ],1);
						loopb[ii+1][jj+1]=max(loopb[ii+1][jj+1],1);
						loopc[i3+1][j3  ]=max(loopc[i3+1][j3  ],1);
						loopc[i3+1][j3+1]=max(loopc[i3+1][j3+1],1);
					}
				}
            }
        }
    }
}

/*!
 *	\fn		write_prev_Pframe()
 *	\brief	Write previous decoded P frame to output file
 */
void write_prev_Pframe(struct img_par *img,	FILE *p_out)
{
	int i,j;

	for(i=0;i<img->height;i++)
		for(j=0;j<img->width;j++)
			fputc(imgY_prev[i][j],p_out);

	for(i=0;i<img->height_cr;i++)
		for(j=0;j<img->width_cr;j++)
			fputc(imgUV_prev[0][i][j],p_out);

	for(i=0;i<img->height_cr;i++)
		for(j=0;j<img->width_cr;j++)
			fputc(imgUV_prev[1][i][j],p_out);
}



/*!
 *	\fn		copy_Pframe()
 *	\brief	Copy decoded P frame to temporary image array
 */
void copy_Pframe(struct img_par *img,	int postfilter)
{
  int i,j;

  /*
   * the mmin, mmax macros are taken out, because it makes no sense due to limited range of data type
   */

  if(postfilter)
    {
      for(i=0;i<img->height;i++)
	for(j=0;j<img->width;j++)
	  {
	    //imgY_prev[i][j] = (byte)mmin(MAX_PIX_VAL,mmax(MIN_PIX_VAL,imgY_pf[i][j]));
	    imgY_prev[i][j] = imgY_pf[i][j];
	  }
      for(i=0;i<img->height_cr;i++)
	for(j=0;j<img->width_cr;j++)
	  {
	    //imgUV_prev[0][i][j] = (byte)mmin(MAX_PIX_VAL,mmax(MIN_PIX_VAL,imgUV_pf[0][i][j]));
	    imgUV_prev[0][i][j] = imgUV_pf[0][i][j];
	  }
      for(i=0;i<img->height_cr;i++)
	for(j=0;j<img->width_cr;j++)
	  {
	    //imgUV_prev[1][i][j] = (byte)mmin(MAX_PIX_VAL,mmax(MIN_PIX_VAL,imgUV_pf[1][i][j]));
	    imgUV_prev[1][i][j] = imgUV_pf[1][i][j];
	  }
    }
  else
    {
      for(i=0;i<img->height;i++)
	for(j=0;j<img->width;j++)
	  {
	    //imgY_prev[i][j] = (byte)mmin(MAX_PIX_VAL,mmax(MIN_PIX_VAL,imgY[i][j]));
	    imgY_prev[i][j] = imgY[i][j];
	  }
      for(i=0;i<img->height_cr;i++)
	for(j=0;j<img->width_cr;j++)
	  {
	    //imgUV_prev[0][i][j] = (byte)mmin(MAX_PIX_VAL,mmax(MIN_PIX_VAL,imgUV[0][i][j]));
	    imgUV_prev[0][i][j] = imgUV[0][i][j];
	  }
      for(i=0;i<img->height_cr;i++)
	for(j=0;j<img->width_cr;j++)
	  {
	    //imgUV_prev[1][i][j] = (byte)mmin(MAX_PIX_VAL,mmax(MIN_PIX_VAL,imgUV[1][i][j]));
	    imgUV_prev[1][i][j] = imgUV[1][i][j];
	  }
    }
}




/************************************************************************
*
*  Name :       init_macroblock_Bframe()
*
*  Description: init macroblock B frames
*
************************************************************************/
void init_macroblock_Bframe(struct img_par *img)
{
	int i,j;
	int fw_predframe_no=0;
    Macroblock *currMB = &img->mb_data[img->current_mb_nr];

    currMB->ref_frame = img->frame_cycle;
    currMB->predframe_no = 0;


	// reset vectors and pred. modes
	for (i=0;i<BLOCK_SIZE;i++)
	{                           
		for(j=0;j<BLOCK_SIZE;j++)
		{
			img->fw_mv[img->block_x+i+4][img->block_y+j][0]=img->fw_mv[img->block_x+i+4][img->block_y+j][1]=0;
			img->bw_mv[img->block_x+i+4][img->block_y+j][0]=img->bw_mv[img->block_x+i+4][img->block_y+j][1]=0;
			img->dfMV[img->block_x+i+4][img->block_y+j][0]=img->dfMV[img->block_x+i+4][img->block_y+j][1]=0;
			img->dbMV[img->block_x+i+4][img->block_y+j][0]=img->dbMV[img->block_x+i+4][img->block_y+j][1]=0;
			img->ipredmode[img->block_x+i+1][img->block_y+j+1] = 0;
		}
	}

	// Set the reference frame information for motion vector prediction 
	if (img->imod==INTRA_MB_OLD || img->imod==INTRA_MB_NEW)
	{
		for (j = 0;j < BLOCK_SIZE;j++)
		{
			for (i = 0;i < BLOCK_SIZE;i++)
			{
				img->fw_refFrArr[img->block_y+j][img->block_x+i] = 
				img->bw_refFrArr[img->block_y+j][img->block_x+i] = -1;
			}
		}
	}
	else if(img->imod == B_Forward)
	{
		for (j = 0;j < BLOCK_SIZE;j++)
		{
			for (i = 0;i < BLOCK_SIZE;i++)
			{
				img->fw_refFrArr[img->block_y+j][img->block_x+i] = fw_predframe_no; // previous P
				img->bw_refFrArr[img->block_y+j][img->block_x+i] = -1;
			}
		}
	}
	else if(img->imod == B_Backward)
	{
		for (j = 0;j < BLOCK_SIZE;j++)
		{
			for (i = 0;i < BLOCK_SIZE;i++)
			{
				img->fw_refFrArr[img->block_y+j][img->block_x+i] = -1;
				img->bw_refFrArr[img->block_y+j][img->block_x+i] = 0; // next P
			}
		}
	}
	else if(img->imod == B_Bidirect)
	{
		for (j = 0;j < BLOCK_SIZE;j++)
		{
			for (i = 0;i < BLOCK_SIZE;i++)
			{
				img->fw_refFrArr[img->block_y+j][img->block_x+i] = fw_predframe_no; // previous P
				img->bw_refFrArr[img->block_y+j][img->block_x+i] = 0; // next P
			}
		}
	}
	else if(img->imod == B_Direct)
	{
		for (j = 0;j < BLOCK_SIZE;j++)
		{
			for (i = 0;i < BLOCK_SIZE;i++)
			{
				img->fw_refFrArr[img->block_y+j][img->block_x+i] = -1; // previous P
				img->bw_refFrArr[img->block_y+j][img->block_x+i] = -1; // next P
			}
		}
	}
}

/************************************************************************
*
*  Name :       readMotionInfoFromNAL_Bframe()
*
*  Description: Get for a given MB of a B picture the reference frame 
*			    parameter and the motion vectors from the NAL 
*
************************************************************************/
void readMotionInfoFromNAL_Bframe(struct img_par *img,struct inp_par *inp)
{
	int i,j,ii,jj,ie,j4,i4,k,pred_vec=0;
	int vec;
	int ref_frame;
	int fw_predframe_no=0, bw_predframe_no;     /* frame number which current MB is predicted from */
	int fw_blocktype=0, bw_blocktype=0, blocktype=0;
    int l,m;

	/* keep track of neighbouring macroblocks available for prediction */
	int mb_nr = img->current_mb_nr;
	int mb_width = img->width/16;
	int mb_available_up = (img->mb_y == 0) ? 0 : (img->slice_numbers[mb_nr] == img->slice_numbers[mb_nr-mb_width]);
	int mb_available_left = (img->mb_x == 0) ? 0 : (img->slice_numbers[mb_nr] == img->slice_numbers[mb_nr-1]);
	int mb_available_upleft  = (img->mb_x == 0 || img->mb_y == 0) ? 0 : (img->slice_numbers[mb_nr] == img->slice_numbers[mb_nr-mb_width-1]);
	int mb_available_upright = (img->mb_x >= mb_width-1 || img->mb_y == 0) ? 0 : (img->slice_numbers[mb_nr] == img->slice_numbers[mb_nr-mb_width+1]);

	/* keep track of neighbouring blocks available for motion vector prediction */
	int block_available_up, block_available_left, block_available_upright, block_available_upleft;
	int mv_a, mv_b, mv_c, mv_d;
	int mvPredType, rFrameL, rFrameU, rFrameUR;

	SyntaxElement THEcurrSE;
	SyntaxElement *currSE = &THEcurrSE;

    Macroblock *currMB = &img->mb_data[img->current_mb_nr];
	Slice *currSlice = img->currentSlice;
	DataPartition *dp;
	int *partMap = assignSE2partition[inp->partition_mode];

	bw_predframe_no=0;


	///////////////////////////////////////////////////////////////
	// find fw_predfame_no 
	///////////////////////////////////////////////////////////////
	if(img->imod==B_Forward || img->imod==B_Bidirect)
	{
		if(img->type==B_IMG_MULT)
		{

#if TRACE
			sprintf(currSE->tracestring, "B_fw_Reference frame no  ");
#endif				
			currSE->type = SE_REFFRAME;
			dp = &(currSlice->partArr[partMap[SE_BFRAME]]);

			if (inp->symbol_mode == UVLC)
				currSE->mapping = linfo;
			else
		    currSE->reading = readRefFrameFromBuffer_CABAC;

			dp->readSyntaxElement(	currSE, img, inp, dp);
			fw_predframe_no = currSE->value1;


			if (fw_predframe_no > img->buf_cycle)
			{
				set_ec_flag(SE_REFFRAME);
				fw_predframe_no = 1;
			}

			ref_frame=(img->frame_cycle+img->buf_cycle-fw_predframe_no) % img->buf_cycle;

			if (ref_frame > img->number)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品白丝av| 日本成人在线看| 亚洲欧洲综合另类| 日韩av网站在线观看| 成人免费不卡视频| 国产精品理伦片| 91麻豆精品秘密| 亚洲成人久久影院| 欧美va天堂va视频va在线| 国产美女视频一区| 国产精品久久久久aaaa樱花| 日本在线观看不卡视频| 精品国产99国产精品| 国产69精品久久久久毛片| 亚洲免费观看高清完整版在线观看熊 | 懂色av一区二区三区免费看| 欧美日韩久久不卡| 久久激情五月婷婷| ...中文天堂在线一区| 欧美日高清视频| 国产成人在线视频网站| 一区二区三区中文在线| 日韩女优视频免费观看| 99久久精品国产导航| 日韩国产精品久久| 国产欧美日韩另类一区| 欧美日韩性生活| 国产91色综合久久免费分享| 一区二区三区欧美日韩| 精品国产一区久久| 91在线精品一区二区三区| 免费亚洲电影在线| 国产精品免费视频观看| 91麻豆精品国产| 亚洲成人激情综合网| 久久久久久久综合| 欧美三级三级三级| 日韩国产欧美在线观看| 五月激情综合婷婷| 中文在线资源观看网站视频免费不卡| 韩国三级在线一区| 亚洲成人777| 国产精品麻豆欧美日韩ww| 99久久精品国产观看| 国产一区二区三区四| 国产午夜精品一区二区三区嫩草 | 91女神在线视频| 久久国内精品自在自线400部| 欧美一区二区精品| 精品一区二区国语对白| 久久久91精品国产一区二区三区| 国产乱淫av一区二区三区| 午夜精品一区二区三区免费视频 | 色av一区二区| 国产精品亚洲一区二区三区妖精| 国产精品日日摸夜夜摸av| 日韩一区二区三区视频在线观看| 精品在线一区二区| 国产亚洲美州欧州综合国| 91精品国产综合久久蜜臀| 欧美在线观看视频在线| av电影一区二区| 成人午夜视频福利| 国产激情视频一区二区三区欧美 | 婷婷国产在线综合| 久久一区二区视频| 精品三级av在线| 日韩视频一区在线观看| 国产电影一区二区三区| 国产一区二区精品在线观看| 亚洲三级电影网站| 亚洲欧洲日韩一区二区三区| 国产三级一区二区三区| 国产视频不卡一区| 国产精品视频一二| 亚洲视频在线一区| 亚洲精品乱码久久久久| 亚洲一区二区在线播放相泽| 亚洲综合清纯丝袜自拍| 亚洲成人一二三| 日韩二区三区在线观看| 蜜臀av一区二区在线观看| 麻豆91免费观看| 国产麻豆9l精品三级站| 成人国产精品免费观看动漫| av亚洲产国偷v产偷v自拍| 色婷婷综合久久久久中文| 色天使色偷偷av一区二区| 欧美在线不卡一区| 欧美一区二区三区在| 久久久久久久精| 欧美日韩和欧美的一区二区| 成人永久免费视频| 奇米影视在线99精品| 国产一区二区三区精品视频| 亚洲国产成人高清精品| 奇米精品一区二区三区在线观看| 亚洲日韩欧美一区二区在线| 精品捆绑美女sm三区| 天堂久久一区二区三区| 美国十次了思思久久精品导航| 亚洲六月丁香色婷婷综合久久| 欧美国产日韩在线观看| 亚洲免费观看高清完整版在线| 久久精品网站免费观看| 亚洲天堂福利av| 奇米影视一区二区三区| 国产成人精品综合在线观看 | 老司机精品视频在线| 国产一区二区h| 一本到不卡免费一区二区| 精品污污网站免费看| 在线看日本不卡| 99re亚洲国产精品| 国产.欧美.日韩| 欧美亚洲一区三区| 欧美精品一区二| 日韩三级中文字幕| 欧美福利视频一区| 欧美激情在线一区二区| 亚洲一本大道在线| 国产成人免费网站| 欧美疯狂性受xxxxx喷水图片| 在线观看国产日韩| 91丝袜高跟美女视频| 日韩午夜电影在线观看| 亚洲天天做日日做天天谢日日欢| 一区在线播放视频| 久久不见久久见免费视频1| eeuss鲁片一区二区三区| 成人h精品动漫一区二区三区| 成人综合在线观看| 日韩美女主播在线视频一区二区三区| 4hu四虎永久在线影院成人| 中文字幕中文字幕一区二区| 日本中文字幕一区二区视频| 91在线视频播放地址| 欧美刺激脚交jootjob| 欧美一区二区三区在线电影 | www日韩大片| 欧美aaaaaa午夜精品| 另类成人小视频在线| 欧美午夜电影网| 亚洲欧洲成人精品av97| 国产精品综合久久| 亚洲午夜一区二区| 成人免费视频网站在线观看| 精品播放一区二区| 久久精品国产在热久久| 国产大陆精品国产| 久久久久国产精品麻豆ai换脸 | 亚洲天堂2016| 成人激情av网| 国产精品丝袜一区| 一区二区三区四区视频精品免费 | 日韩欧美一级二级| 日本欧美加勒比视频| 欧美少妇一区二区| 一区二区三区日韩欧美| 91麻豆国产自产在线观看| 一区在线观看免费| jlzzjlzz亚洲日本少妇| 国产欧美精品国产国产专区| 国产91在线|亚洲| 国产偷国产偷精品高清尤物| 国产一区欧美一区| 国产网红主播福利一区二区| 懂色av噜噜一区二区三区av | 91精品国产色综合久久| 偷窥少妇高潮呻吟av久久免费| 精品一区二区在线视频| 久久久久国产精品麻豆 | 欧美国产成人精品| 丁香婷婷综合网| 国产精品久久久久9999吃药| 日本不卡一区二区| 欧美日韩综合一区| 蜜桃免费网站一区二区三区| 欧美精品一区二区三区视频| 国内精品伊人久久久久av影院| 日本韩国一区二区| 午夜伊人狠狠久久| 夜夜精品视频一区二区| 国产精品一区在线观看乱码| 中文字幕免费在线观看视频一区| 亚洲成av人片| 99久久国产综合精品女不卡| 亚洲精品欧美在线| 91精品国产乱码| 国产伦精品一区二区三区视频青涩| 欧美日韩一区二区在线观看视频| 久久久午夜精品理论片中文字幕| 午夜亚洲国产au精品一区二区| 成人免费视频一区| 亚洲一区精品在线| 精品久久久久久久久久久久久久久久久 | 五月婷婷久久丁香| 精品久久久久av影院| 成人app软件下载大全免费| 日韩午夜在线影院|