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

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

?? modbus.c

?? modbus 通信協議在dsp2407中的應用代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:

#include "main.h"

//unsigned int  	GwRxCount;  			// GwSciRxBuffer[]數組的下標
//unsigned int 		GwTxCount;  			// GwSciTxBuffer[]數組的下標

//unsigned char  	GwRxFlag; 			// 接收標志  1: 準備接收; 0: 接收結束
//unsigned char  	GwTxFlag; 			// 發送標志  1: 準備發送; 0: 發送結束
unsigned char  	GwSciTxBuffer[32],GwSciRxBuffer[32];
unsigned int   	GwSciTxBytes; 			// 每幀信息中發送字節總數
unsigned int   	GwSciRxBytes; 			// 每幀信息中接收字節總數

int GwSciRxFlag = 0;			//SCI接收中斷標志,'1'表示接收中斷發生


static unsigned char	CRCHi[] = {
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81,
0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01,
0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81,
0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01,
0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81,
0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01,
0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81,
0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0,
0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01,
0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81, 0x40, 0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41,
0x00, 0xC1, 0x81, 0x40, 0x01, 0xC0, 0x80, 0x41, 0x01, 0xC0, 0x80, 0x41, 0x00, 0xC1, 0x81,
0x40
};
static unsigned char	CRCLo[] = {
0x00, 0xC0, 0xC1, 0x01, 0xC3, 0x03, 0x02, 0xC2, 0xC6, 0x06, 0x07, 0xC7, 0x05, 0xC5, 0xC4,
0x04, 0xCC, 0x0C, 0x0D, 0xCD, 0x0F, 0xCF, 0xCE, 0x0E, 0x0A, 0xCA, 0xCB, 0x0B, 0xC9, 0x09,
0x08, 0xC8, 0xD8, 0x18, 0x19, 0xD9, 0x1B, 0xDB, 0xDA, 0x1A, 0x1E, 0xDE, 0xDF, 0x1F, 0xDD,
0x1D, 0x1C, 0xDC, 0x14, 0xD4, 0xD5, 0x15, 0xD7, 0x17, 0x16, 0xD6, 0xD2, 0x12, 0x13, 0xD3,
0x11, 0xD1, 0xD0, 0x10, 0xF0, 0x30, 0x31, 0xF1, 0x33, 0xF3, 0xF2, 0x32, 0x36, 0xF6, 0xF7,
0x37, 0xF5, 0x35, 0x34, 0xF4, 0x3C, 0xFC, 0xFD, 0x3D, 0xFF, 0x3F, 0x3E, 0xFE, 0xFA, 0x3A,
0x3B, 0xFB, 0x39, 0xF9, 0xF8, 0x38, 0x28, 0xE8, 0xE9, 0x29, 0xEB, 0x2B, 0x2A, 0xEA, 0xEE,
0x2E, 0x2F, 0xEF, 0x2D, 0xED, 0xEC, 0x2C, 0xE4, 0x24, 0x25, 0xE5, 0x27, 0xE7, 0xE6, 0x26,
0x22, 0xE2, 0xE3, 0x23, 0xE1, 0x21, 0x20, 0xE0, 0xA0, 0x60, 0x61, 0xA1, 0x63, 0xA3, 0xA2,
0x62, 0x66, 0xA6, 0xA7, 0x67, 0xA5, 0x65, 0x64, 0xA4, 0x6C, 0xAC, 0xAD, 0x6D, 0xAF, 0x6F,
0x6E, 0xAE, 0xAA, 0x6A, 0x6B, 0xAB, 0x69, 0xA9, 0xA8, 0x68, 0x78, 0xB8, 0xB9, 0x79, 0xBB,
0x7B, 0x7A, 0xBA, 0xBE, 0x7E, 0x7F, 0xBF, 0x7D, 0xBD, 0xBC, 0x7C, 0xB4, 0x74, 0x75, 0xB5,
0x77, 0xB7, 0xB6, 0x76, 0x72, 0xB2, 0xB3, 0x73, 0xB1, 0x71, 0x70, 0xB0, 0x50, 0x90, 0x91,
0x51, 0x93, 0x53, 0x52, 0x92, 0x96, 0x56, 0x57, 0x97, 0x55, 0x95, 0x94, 0x54, 0x9C, 0x5C,
0x5D, 0x9D, 0x5F, 0x9F, 0x9E, 0x5E, 0x5A, 0x9A, 0x9B, 0x5B, 0x99, 0x59, 0x58, 0x98, 0x88,
0x48, 0x49, 0x89, 0x4B, 0x8B, 0x8A, 0x4A, 0x4E, 0x8E, 0x8F, 0x4F, 0x8D, 0x4D, 0x4C, 0x8C,
0x44, 0x84, 0x85, 0x45, 0x87, 0x47, 0x46, 0x86, 0x82, 0x42, 0x43, 0x83, 0x41, 0x81, 0x80,
0x40
};


// 功能	 :對SCI模塊進行初始化,與油氣分離單元進行通信以串口為硬件接口,采用MODBUS協議
// 返回	 :無
// 形參  : 無	

void SciInit(void)
{
	MCRA=MCRA|0x0003;		            // IOPA0(SCITXD), IOPA1(SCIRXD)為串口
	SCICCR=0x67;                      	// 1位停止位,使能偶校驗功能,數據字為8位長度
	SCICTL1=0x03;                     	// 不使能接收錯誤中斷,軟件復位,使能發送和接收,SLEEP位為0		
										// TXWAKE=0,沒有選定的發送特征
	//todo:暫不采用中斷方式接收
	//SCICTL2=0x02;  		            //接收中斷使能,不使能發送中斷,發送采用置軟件標志位方法
	SCIPRI=0x00;   		            	//高優先級中斷,使用INT1,INT1(高優先級中斷)還是INT5(低優先級中斷)
	SCIHBAUD=0x01; 		            	//波特率設置為19200bit/s
	SCILBAUD=0x03;
	SCICTL1=0x23;  		            	//SW位置1,串口初始化完成									
}


// 功能	 :生成MODBUA協議中的CRC校驗碼(16位)
// 返回	 :CRC校驗碼(16位)
// 形參  : 指向待發送或已接收到的數組的指針,數組長度	

unsigned int CRC16( const unsigned char *buf, int len)
{
	unsigned char	Hi=0xFF;
	unsigned char	Lo=0xFF;
	unsigned short	index;

	if (buf == 0 || len <= 0)
		return(0);

	while (len--) 
	{
		index = Hi ^ (unsigned char)*buf++;
		Hi = Lo ^ CRCHi[index];
     	Lo = CRCLo[index] ;
	}
	
	index=(Hi<<8)|Lo;
	
	return(index);
}

// 功能  :對接收的數據進行CRC校驗,與發送來的CRC校驗值(在所接收的數據中)進行比較
// 返回  :如果CRC校驗值與接收到的CRC校驗值相等,則返回1,否則返回0
// 形參  : 

unsigned char CheckCRC(unsigned char *crctmp,unsigned int length)
{
	unsigned int crc_result, crc_tmp;
	
	//取接收到數據中的CRC值
    crc_tmp = *(crctmp + length-2);                  	// CRC高字節
    crc_tmp = crc_tmp << 8 + *( crctmp+length-1);    	// CRC高字節左移8位+CRC低字節 = CRC 值
    //crc_tmp = crc_tmp * 256 + *( crctmp+length-1);    // CRC高字節左移8位+CRC低字節 = CRC 值
    
    crc_result = CRC16(crctmp, length-2);         	 	// 根據接收到的數據計算CRC 值                    
    if ( crc_tmp != crc_result ) 					 	// 比較CRC值
      	return(0);
    else
    	return(1);
}    

// 功能  :把按MODBUS協議規定的數據形式組織好的數據發給油氣分離單元
// 返回  :無
// 形參  : 無

void SciSend(void)
{   
    //開始發送,后續數據在中斷中繼續發送  
    //GwTxFlag = 1;	//準備發送,發送完成后清零
    unsigned int wTempSciRxBuf = 0;
    
    unsigned int wTxCount = 0;		//發送計數器初始化  
        
	// 在開始發送之前先清接收緩沖區(實際是清SCIRXST的RXRDY位),以保證SCIRXBUF中沒有新數據(即未讀過的數據)
	
	wTempSciRxBuf = SCIRXBUF;	// 通過讀SCIRXBUF可以清SCIRXST的RXRDY位
	
    // 開始發送數據      
    while (wTxCount < GwSciTxBytes)
    {
	    SCITXBUF = GwSciTxBuffer[wTxCount]; 		//發送數據,寫SCITXBUF會清除TXRDY位,即表示此時SCITXBUF滿
	    
	    while((SCICTL2 & 0x80) == 0);     			//等待TXRDY位變"1",即SCITXBUF為空,可以接收下一個數據
	             
	    wTxCount ++;
    }  	  		   	 
}

// 功能  :接收響應
// 返回  :無
// 形參  : 無

void SciReceive(void)
{
   	//GwRxFlag = 1;						//準備接收,接收完成后清零 
	//GwRxCount = 0; 					//接收指針清零,保證數據從緩沖區的首地址處開始存放 
	unsigned int wDelayCount = 0;		//等待接收的延時
	
	unsigned int wRxCount = 0;			//接收計數器初始化	
	
	while (wRxCount < GwSciRxBytes)	//等待接收完成,數據在中斷服務程序中接收,GwRxCount在中斷服務程序中累加
	{
		if (GwForceInitFlag == 1)		//如果強制命令發生
		{
			wRxCount = GwSciRxBytes;
		}
			
		//等待SCIRXST的RXRDY位置'1',RXRDY位為'0'時wDelayCount++,以便超時退出	
		while ((SCIRXST & BIT6) == 0)	//如果SCIRXBUF中沒有新數據(SCIRXST的RXRDY位為'0',代表沒有新數據)
		{
			wDelayCount ++;
			
			//todo:延時多少次為宜,等待接收的延時	
			if (wDelayCount > 50000) 
			{
				wRxCount = GwSciRxBytes;
				
				break;	//跳出while ((SCIRXST & BIT6) == 0)循環			
			}				
		}		
		
		wDelayCount = 0;						//就馬上對計數清零		
		
		GwSciRxBuffer[wRxCount] = SCIRXBUF;		//讀緩沖區內的數據(如果是由于超時退出的,則這里讀到是上一次的數據)	
			
		wRxCount ++;							//字節數計數加'1'			
	}   	
}


// 功能  :構建RTU模式幀,RTU模式的ADU
// 返回  :無
// 形參	 :


void ConstructRtuFrame (unsigned char *dst_buf,unsigned char *src_buf,unsigned char lenth)
{
    unsigned int crc_tmp;
    
    crc_tmp = CRC16(src_buf, lenth);    	//對二進制串,計算getCRC16校驗    
    *(src_buf+lenth) = crc_tmp >> 8;  		//CRC 高字節在前
    *(src_buf+lenth+1) = crc_tmp & 0xff;  	//CRC 低字節在后    
    lenth++;
    lenth++;

    while ( lenth--) //形成Modbus通信的RTU串
    {
      *dst_buf = *src_buf;
      dst_buf++;
      src_buf++;    
    }
}


char ProcessMasterRTU( unsigned int  *dest, unsigned char *src,unsigned int start_address, unsigned int fr_lenth)
{
    unsigned int crc_result, crc_tmp;
    unsigned char i, j, shift;
  
    crc_tmp = *(src + fr_lenth-2); 					// crc  第一字節
    crc_tmp = crc_tmp * 256 + *( src+fr_lenth-1); 	// CRC 值
    crc_result = CRC16(src, fr_lenth-2); 			// 計算CRC 值  
    
    if ( crc_tmp != crc_result ) 
    {
      	return CRC_ERR;								// CRC 校驗錯誤
    }
    
    switch ( *(src+1) ) 							// 功能碼
    {
	    case READ_COIL:								//讀取繼電器狀態 01
      	{
          	for ( i=0; i<*( src+2); i++)
          	{
                shift = 1;
                for ( j=0; j<8; j++)
                { 
                    *(dest+start_address+i*8+j) = shift & *( src+3+i);
                    *( src+3+i) >>= 1;              
            	}
	    	}
          break;
      	}
      	
      	case READ_DI:								//讀取開關量輸入 02
      	{
          	for ( i=0; i<*( src+2); i++)
          	{
                shift = 1;
                for (j=0; j<8; j ++)
                { 
                     *(dest+start_address+i*8+j) = shift & *( src+3+i);
                     *( src+3+i)>>=1;                  
                }
          	}
          break;
      	}
	      
	    case READ_HLD_REGs:							//讀取多個保持寄存器 03
	    {
          	for ( i=0; i<*( src+2); i+=2)
          	{
                //todo: 這個式子是否正確
                *(dest + start_address+ i/2)= *(src+i+3)*256 + *(src+i+4) ;            
          	}
          	break ;
        }
	      
        case READ_AI:								//讀取模擬量輸入 04
        {
        	for ( i=0; i<*( src+2); i+=2)
	        {
	        	*(dest + start_address+ i/2) = *( src+i+3)*256 +  *( src+i+4) ;            
	        } 
	        break;
	   	}
			
		case SET_COIL:								//05強制單個線圈進行
		{
			break;	
		}
			
		case SET_HLD_REG:							//06寫單個寄存器
		{
			break;	
		}	
			
		case SET_COILs:								//15強制多個線圈進行
		{
			break;	
		}	
			
		case SET_HLD_REGs: 							//16寫多個寄存器
		{
			break;	
		}	
			
		case READ_SET_HLD_REGs:						//23讀寫多個寄存器
		{
			break;	
		}	      
      	
      	default: 									//功能碼錯誤
      		return(CMD_ERR);
      	  	break;
    }
    return(1);
}


// 功能  :讀取繼電器狀態:CMD == 1 
// 返回  :成功返回1,否則返回0

// 請求命令:[設備地址] [命令號01] [起始寄存器地址高8位] [低8位] [讀取的線圈數高8位] [低8位] [CRC校驗的高8位] [CRC校驗的低8位]
// 設備響應:[設備地址] [命令號01] [返回的字節個數][數據1][數據2]...[數據n][CRC校驗的高8位] [CRC校驗的低8位]
// tmmp存放讀回寄存器的狀態
char ReadCoilStatus(unsigned int *pwCoilState, unsigned char DeviceID,unsigned int start_address,unsigned int lenth) 
{
    unsigned char tmp[64],tmp_lenth;
    
    tmp[0] = DeviceID; 								//從設備地址
    tmp[1] = 0x01; 									//命令
    tmp[2] = start_address>>8;						//起始地址 高字節
    tmp[3] = start_address & 0xFF;					//起始地址 低字節
    tmp[4] = lenth>>8;								//讀取數據量 高字節
    tmp[5] = lenth & 0xFF;							//讀取數據量 低字節
    tmp_lenth = 6; 									//二進制包長度
  
	ConstructRtuFrame(GwSciTxBuffer,tmp,tmp_lenth);  	
	GwSciTxBytes = tmp_lenth+2;
	if(lenth % 8==0)	//如果余數為零
	{
		GwSciRxBytes=(lenth/8)+3+2; // lenth/8線圈狀態的字節數,3為地址碼,功能碼,字節數,2為兩個CRC字節
	}
	else
	{
		GwSciRxBytes=(lenth/8+1)+3+2;
	}
	
	
  
  	SciSend();										//發送請求
  	SciReceive();									//接收設備響應
  	
  	
  	 		             
    if(GwSciRxBuffer[1] == 0x01) 					//通信正常,數據處理
    {
       	  
       	  ProcessMasterRTU(pwCoilState,GwSciRxBuffer,0,GwSciRxBytes);
       	                 	
    }
    else 			//通信異常0x83,查詢異常碼,可重新發送請求或作其他處理
   	{
		return(CMD_ERR);
    }       
    
}

// 功能  :讀取開關量輸入:CMD == 2 
// 返回  :成功返回1,否則返回0
// 備注  :全局變量Modbus_mode,GwSciTxBuffer[],GwSciTxBytes,GwSciRxBuffer[],GwSciRxBytes
// 請求命令:[設備地址] [命令號02] [起始寄存器地址高8位] [低8位] [讀取的寄存器數高8位] [低8位] [CRC校驗的高8位] [CRC校驗的低8位]  
// 設備響應:[設備地址] [命令號02] [返回的字節個數][數據1][數據2]...[數據n][CRC校驗的高8位] [CRC校驗的低8位]

char ReadInStatus(unsigned int *pwInState, unsigned char DeviceID, unsigned int start_address, unsigned int lenth) 
{
    unsigned char tmp[64], tmp_lenth;
//    int tmmp[256];
    
    tmp[0] = DeviceID;								//從設備地址
    tmp[1] = 0x02; 									//命令

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产伦精一区二区三区| 日本视频一区二区| 欧美一区二区三区在线观看| 国产麻豆精品95视频| 亚洲成人先锋电影| 中文字幕在线观看不卡视频| 制服丝袜在线91| 91视频.com| 国产一区二区三区电影在线观看 | 欧美成va人片在线观看| 99国产麻豆精品| 国产精品一级在线| 青青草精品视频| 亚洲无线码一区二区三区| 国产精品久久久久久久久免费丝袜| 欧美一区二区在线观看| 日本高清成人免费播放| 国产成人免费av在线| 久久精品99国产精品| 天堂蜜桃一区二区三区| 亚洲在线中文字幕| 亚洲三级理论片| 日本一区二区成人| 久久久久高清精品| 久久久久久久国产精品影院| 欧美一区二区三区视频免费| 欧美日韩中文精品| 在线亚洲欧美专区二区| av午夜精品一区二区三区| 国产电影一区在线| 国产精品一区二区果冻传媒| 狠狠v欧美v日韩v亚洲ⅴ| 日本不卡不码高清免费观看| 亚洲成人av福利| 午夜av区久久| 午夜视频一区在线观看| 性久久久久久久久久久久| 亚洲蜜桃精久久久久久久| 亚洲黄色片在线观看| 亚洲无线码一区二区三区| 亚洲主播在线播放| 五月婷婷综合网| 日本美女视频一区二区| 热久久国产精品| 国模娜娜一区二区三区| 国产另类ts人妖一区二区| 国产福利一区在线| av影院午夜一区| 91麻豆精品一区二区三区| 91免费版pro下载短视频| 欧美艳星brazzers| 69堂国产成人免费视频| 亚洲精品在线观| 国产精品成人网| 亚洲一区二区视频| 日本成人在线一区| 国产成a人亚洲| av网站免费线看精品| 在线观看区一区二| 欧美一级一区二区| 欧美国产日本视频| 一区二区三区中文字幕| 日韩av一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| aaa欧美色吧激情视频| 欧美性猛交xxxxxx富婆| 日韩欧美国产一区在线观看| 国产色产综合产在线视频| 樱花影视一区二区| 青娱乐精品视频在线| 成人综合激情网| 91福利视频网站| 日韩精品中午字幕| 国产精品狼人久久影院观看方式| 亚洲九九爱视频| 久久99精品网久久| 在线影院国内精品| 精品99久久久久久| 一区二区三区免费观看| 蜜臀久久99精品久久久画质超高清| 国产精品综合在线视频| 欧美色精品天天在线观看视频| 欧美xxxxx裸体时装秀| 亚洲视频在线一区| 美女脱光内衣内裤视频久久影院| 成人看片黄a免费看在线| 欧美一区二区三区喷汁尤物| 国产精品久久久久影院亚瑟 | 久久久久国产精品厨房| 亚洲一二三四区不卡| 国产寡妇亲子伦一区二区| 欧美日韩国产高清一区二区三区 | av影院午夜一区| 欧美一区二区三区公司| 亚洲女同一区二区| 国产精品一区一区三区| 911精品国产一区二区在线| 国产精品久久久久久久裸模| 日韩电影在线观看电影| 色呦呦国产精品| 欧美国产1区2区| 狠狠久久亚洲欧美| 717成人午夜免费福利电影| 亚洲欧美日韩久久精品| 国产成人精品免费| 欧美成人vps| 日韩有码一区二区三区| 色婷婷久久久综合中文字幕| 国产亚洲一区二区三区在线观看| 五月婷婷综合在线| 欧美亚洲国产bt| 一区二区三区精品在线| 国产91高潮流白浆在线麻豆| 日韩视频一区二区三区在线播放| 亚洲一区二区三区美女| 色婷婷亚洲婷婷| 一区在线中文字幕| 丰满放荡岳乱妇91ww| 久久蜜桃av一区二区天堂| 九九视频精品免费| 欧美大度的电影原声| 秋霞成人午夜伦在线观看| 在线观看91精品国产麻豆| 亚洲在线视频一区| 欧亚洲嫩模精品一区三区| 亚洲视频一二三区| 91猫先生在线| 亚洲免费伊人电影| 91丨porny丨国产入口| 亚洲视频一二三| 色先锋资源久久综合| 亚洲欧美乱综合| 91福利资源站| 亚洲成人在线观看视频| 欧美日韩国产一级| 亚洲a一区二区| 在线不卡免费av| 久久国产日韩欧美精品| 精品欧美一区二区在线观看| 国产一区二区三区观看| 国产三级精品视频| av在线播放不卡| 亚洲美女淫视频| 欧美日韩一区二区在线观看| 丝袜美腿成人在线| 欧美电影免费提供在线观看| 久久66热偷产精品| 国产情人综合久久777777| jlzzjlzz国产精品久久| 亚洲精品成人a在线观看| 欧美三级蜜桃2在线观看| 视频一区二区国产| 精品国产sm最大网站| 成人动漫一区二区在线| 尤物视频一区二区| 日韩欧美一级精品久久| 国产一区二区91| 国产精品久久久久久久久搜平片| 色94色欧美sute亚洲13| 免费成人深夜小野草| 国产欧美一区视频| 欧美性感一类影片在线播放| 免费成人深夜小野草| 麻豆精品视频在线观看| 国产午夜精品久久久久久久 | 蜜臀久久久99精品久久久久久| 2021久久国产精品不只是精品| 成人禁用看黄a在线| 亚洲一区二区三区不卡国产欧美| 日韩一区二区三区在线| 不卡一二三区首页| 日本亚洲天堂网| 国产精品热久久久久夜色精品三区| 色综合久久综合网97色综合| 视频一区二区三区中文字幕| 国产网站一区二区三区| 欧美在线免费视屏| 紧缚奴在线一区二区三区| 亚洲激情图片qvod| 国产性天天综合网| 欧美在线三级电影| 成人毛片老司机大片| 美女视频网站久久| 一区二区三区欧美日| 久久久久国产精品人| 欧美精品电影在线播放| 成人性生交大片免费 | 一本一道久久a久久精品综合蜜臀| 日韩精品国产精品| 亚洲色图视频网| 精品99一区二区三区| 欧美日韩国产综合一区二区| 成人av电影在线| 麻豆成人av在线| 亚洲一区二区三区在线| 国产精品久久久久久久岛一牛影视 | 欧美激情在线看| 欧美一级搡bbbb搡bbbb| 亚洲色欲色欲www在线观看| 日韩一本二本av|