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

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

?? spi.c

?? samsung 2410 demo源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:

#if 0 // Total
void Test_Spi0_Loopback_poll(void)
{
	char *txStr,*rxStr;

	printf("[SPI Polling Tx/Rx Self-Test]\n");
	printf("Connect SPIMOSI 0 into SPIMISO 0.\n");

	endSpi0Tx=0;
	spi0TxStr="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";	// Tx Data to send
	spi0RxStr=(char *) SPI_BUFFER0;						// Rx Buffer to receive

	txStr=(char *)spi0TxStr;
	rxStr=(char *)spi0RxStr;

	SPI_Port_Init(CH0_POLL_MSTR_TX);
	
	SPI_Baud_Rate_Set(0, 25000000);			// SPI Channel 0, 25MHz
	SPI_Ch_Set(CH0_POLL_MSTR_TX, ACTL_A);	// Active L, Format A

	rSPPIN0=(0<<2)|(1<<1)|(0<<0);//dis-ENMUL,SBO,release

	while(endSpi0Tx==0)
	{
		if(REDY0)   //Check Tx ready state
		{
			if(*spi0TxStr!='\0')
				rSPTDAT0=*spi0TxStr++;
			else {
				endSpi0Tx=1;
				break;
				}

			while(!(REDY0_org));   //Check Rx ready state 
			*spi0RxStr++=rSPRDATB0;
		}
	}
	*spi0RxStr='\0'; // attach End of String(Null)

	printf("Tx Strings:%s\n",txStr);
	printf("Rx Strings:%s :",rxStr);
    
	if(strcmp(rxStr,txStr)==0) printf("O.K.\n");
	else printf("ERROR!!!\n");

	SPI_Port_Return(0);
}

void Test_Spi1_Loopback_poll(void)
{
	U32 i;
	char *txStr,*rxStr;

	printf("[SPI Polling Tx/Rx Self-Test]\n");
	printf("Connect SPIMOSI 1 into SPIMISO 1.\n");

	endSpi1Tx=0;
	spi1TxStr="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";	// Tx Data to send
	spi1RxStr=(char *) SPI_BUFFER1;						// Rx Buffer to receive

	txStr=(char *)spi1TxStr;
	rxStr=(char *)spi1RxStr;

	SPI_Port_Init(CH1_POLL_MSTR_TX);
	
	SPI_Baud_Rate_Set(1, 25000000);			// SPI Channel 0, 1MHz
	SPI_Ch_Set(CH1_POLL_MSTR_TX, ACTL_A);	// Active L, Format A

	rSPPIN1=(0<<2)|(1<<1)|(0<<0);//dis-ENMUL,SBO,release

	while(endSpi1Tx==0)
	{
		if(REDY1)   //Check Tx ready state
		{
			if(*spi1TxStr!='\0')
				rSPTDAT1=*spi1TxStr++;
			else {
				endSpi1Tx=1;
				break;
				}

			while(!(REDY1_org));   //Check Rx ready state 
			*spi1RxStr++=rSPRDATB1;
		}
	}
	*spi1RxStr='\0'; // attach End of String(Null)

	printf("Tx Strings:%s\n",txStr);
	printf("Rx Strings:%s :",rxStr);
    
	if(strcmp(rxStr,txStr)==0) printf("O.K.\n");
	else printf("ERROR!!!\n");

	SPI_Port_Return(1);
}


void Test_Spi0_Loopback_int(void)
{
	char *txStr,*rxStr;

	printf("[SPI Interrupt Tx/Rx Self-Test]\n");
	printf("Connect SPIMOSI 0 into SPIMISO 0.\n");

	endSpi0Tx=0;
	spi0TxStr="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";	// Tx Data to send
	spi0RxStr=(char *) SPI_BUFFER0;						// Rx Buffer to receive

	txStr=(char *)spi0TxStr;
	rxStr=(char *)spi0RxStr;

	SPI_Port_Init(CH0_INT_MSTR_TX);
	
	SPI_Baud_Rate_Set(0, 25000000);			// SPI Channel 0, 25MHz
	SPI_Ch_Set(CH0_INT_MSTR_TX, ACTL_A);	// Active L, Format A

	rSPPIN0=(0<<2)|(1<<1)|(0<<0);//dis-ENMUL,SBO,release

	pISR_SPI0=(unsigned)Spi0_Int;
	rINTMSK&=~(BIT_SPI0);

	while(endSpi0Tx==0);

	*spi0RxStr='\0'; // attach End of String(Null)

	printf("Tx Strings:%s\n",txStr);
	printf("Rx Strings:%s :",rxStr);
    
	if(strcmp(rxStr,txStr)==0) printf("O.K.\n");
	else printf("ERROR!!!\n");

	SPI_Port_Return(0);
}

void Test_Spi1_Loopback_int(void)
{
	char *txStr,*rxStr;

	printf("[SPI Interrupt Tx/Rx Self-Test]\n");
	printf("Connect SPIMOSI 1 into SPIMISO 1.\n");

	endSpi1Tx=0;
	spi1TxStr="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";	// Tx Data to send
	spi1RxStr=(char *) SPI_BUFFER1;						// Rx Buffer to receive

	txStr=(char *)spi1TxStr;
	rxStr=(char *)spi1RxStr;

	SPI_Port_Init(CH1_INT_MSTR_TX);
	
	SPI_Baud_Rate_Set(1, 25000000);			// SPI Channel 0, 25MHz
	SPI_Ch_Set(CH1_INT_MSTR_TX, ACTL_A);	// Active L, Format A

	rSPPIN1=(0<<2)|(1<<1)|(0<<0);//dis-ENMUL,SBO,release

	pISR_SPI1=(unsigned)Spi1_Int;
	rINTMSK&=~(BIT_SPI1);

	while(endSpi1Tx==0);

	*spi1RxStr='\0'; // attach End of String(Null)

	printf("Tx Strings:%s\n",txStr);
	printf("Rx Strings:%s :",rxStr);
    
	if(strcmp(rxStr,txStr)==0) printf("O.K.\n");
	else printf("ERROR!!!\n");

	SPI_Port_Return(1);
}

void __irq Spi0_Int(void)
{
	rINTMSK|=BIT_SPI0;
	ClearPending(BIT_SPI0);

	if(rSPSTA0&0x4||rSPPIN0&0x4) 
		printf("Data Collision or Multi Master Error!!!\n");
	
	if(*spi0TxStr!='\0') {
		rSPTDAT0=*spi0TxStr++;
		rINTMSK&=~BIT_SPI0;
	}
	else {
		endSpi0Tx=1;
		return;
	}

	while(!(REDY0_org));   		//Check ready state
	*spi0RxStr++=rSPRDATB0;	//First Rx data is garbage data
}

void __irq Spi1_Int(void)
{
	rINTMSK|=BIT_SPI1;
	ClearPending(BIT_SPI1);

	if(rSPSTA1&0x4||rSPPIN1&0x4) 
		printf("Data Collision or Multi Master Error!!!\n");
	
	if(*spi1TxStr!='\0') {
		rSPTDAT1=*spi1TxStr++;
		rINTMSK&=~BIT_SPI1;
	}
	else {
		endSpi1Tx=1;
		return;
	}

	while(!(REDY1_org));   		//Check ready state
	*spi1RxStr++=rSPRDATB1;	//First Rx data is garbage data
}

#if 1
void Test_Spi01_MS_Int(void)
{
	char *rx0Str,*tx0Str;
	char *rx1Str,*tx1Str;

	printf("[SPI0(Master), SPI1(Slave) Interrupt Rx/Tx test in 1 Board]\n");

	endSpi0Tx=0;
	endSpi1Tx=0;
	spi0TxStr="!@#$%^&*()_+|<>?:~ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";
	spi1TxStr="1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()_+|<>?:~";

	spi0RxStr=(char *) SPI_BUFFER0;
	spi1RxStr=(char *) SPI_BUFFER1;
	
	tx0Str=(char *)spi0TxStr;
	rx0Str=(char *)spi0RxStr;
	tx1Str=(char *)spi1TxStr;
	rx1Str=(char *)spi1RxStr;

	SPI_Port_Init(CH0_INT_MSTR_TX);
	SPI_Port_Init(CH1_INT_SLV_RX);

	SPI_Baud_Rate_Set(0, 1000000);			// SPI Channel 0, 25MHz
	SPI_Baud_Rate_Set(1, 1000000);			// SPI Channel 1, 25MHz

	SPI_Ch_Set(CH1_INT_SLV_RX, ACTL_A);	// Active L, Format B
	rSPPIN1=(0<<2)|(1<<1)|(1<<0);//dis-ENMUL,SBO,release
	printf("Slave setting end\n");

	SPI_Ch_Set(CH0_INT_MSTR_TX, ACTL_A);	// Active L, Format B
	rSPPIN0=(0<<2)|(1<<1)|(1<<0);//dis-ENMUL,SBO,release
	printf("Master setting end\n");

	pISR_SPI0=(unsigned)Spi01_M_Int;
	pISR_SPI1=(unsigned)Spi01_S_Int;

	Master_nSS_Con0(0);    // Activate nSS 
//	rINTMSK&=~(BIT_SPI0|BIT_SPI1);
//	rSPPIN0 &= ~(1<<1);
	rINTMSK&=~(BIT_SPI1);
	rINTMSK&=~(BIT_SPI0);
	
	while((endSpi1Tx==0)||(endSpi0Tx==0))
		{
		if(Uart_GetKey()) {
			Master_nSS_Con0(1);
			return;
			}
		}

	Master_nSS_Con0(1);
//	rSPPIN0 |= (1<<1);
	rINTMSK |=(BIT_SPI0|BIT_SPI1);	

	*spi0RxStr='\0';//attach End of String(Null)
	*spi1RxStr='\0';//attach End of String(Null)
	printf("SPI0Tx Strings:%s\n",tx0Str);
	printf("SPI0Rx Strings:%s\n",rx0Str+1);//remove first dummy data

	printf("SPI1Tx Strings:%s\n",tx1Str);
	printf("SPI1Rx Strings:%s\n",rx1Str+1);//remove first dummy data

	if(strcmp((rx1Str+1),tx0Str)==0)
		printf("SPI0 test O.K !!!\n");
	if(strcmp((rx0Str+1),tx1Str)==0)
		printf("SPI1 test O.K !!!\n");
	else 
		printf("ERROR!!!\n");

	SPI_Port_Return(0);
	SPI_Port_Return(1);
}

void __irq Spi01_M_Int(void)
{
	rINTMSK|=BIT_SPI0;
	ClearPending(BIT_SPI0); 

	if(*spi0TxStr!='\0') 
		rSPTDAT0=*spi0TxStr++;
  	else {
//		while(!REDY0_org);   //Check ready state
		*spi0RxStr++=rSPRDATB0;    //First Rx data is garbage data

		endSpi0Tx=1;
		return;
	}

	if(rSPSTA0&0x4||rSPPIN0&0x4) 
		printf("Data Collision or Multi Master Error!!!\n");

//	while(!REDY0_org);   //Check ready state
	*spi0RxStr++=rSPRDATB0;    //First Rx data is garbage data

	rINTMSK&=~(BIT_SPI1);
	printf("M");
//	printf("spi0 %s\n",spi0TxStr);
}

void __irq Spi01_S_Int(void)
{
	rINTMSK|=BIT_SPI1;
	ClearPending(BIT_SPI1); 

	if(rSPSTA1&0x4||rSPPIN1&0x4) 
		printf("Data Collision or Multi Master Error!!!\n");

//	while(!REDY1_org);   //Check ready state
	*spi1RxStr++=rSPRDATB1;    //First Rx data is garbage data

	if(*spi1TxStr!='\0') 
		rSPTDAT1=*spi1TxStr++;
  	else {
		endSpi1Tx=1;
		return;
	}

	rINTMSK&=~(BIT_SPI0);
	printf("S");
//	printf("spi1 %s\n",spi1TxStr);
}
#else
void Test_Spi01_MS_Int(void)
{
	char *rx0Str,*tx0Str;
	char *rx1Str,*tx1Str;

	printf("[SPI0(Master), SPI1(Slave) Interrupt Rx/Tx test in 1 Board]\n");

	endSpi0Tx=0;
	endSpi1Tx=0;
	spi0TxStr="!@#$%^&*()_+|<>?:~ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";
	spi1TxStr="1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ!@#$%^&*()_+|<>?:~";

	spi0RxStr=(char *) SPI_BUFFER0;
	spi1RxStr=(char *) SPI_BUFFER1;
	
	tx0Str=(char *)spi0TxStr;
	rx0Str=(char *)spi0RxStr;
	tx1Str=(char *)spi1TxStr;
	rx1Str=(char *)spi1RxStr;

	SPI_Port_Init(CH0_INT_MSTR_TX);
	SPI_Port_Init(CH1_INT_SLV_RX);

	SPI_Baud_Rate_Set(0, 5000000);			// SPI Channel 0, 25MHz
	SPI_Baud_Rate_Set(1, 5000000);			// SPI Channel 0, 25MHz

	SPI_Ch_Set(CH1_INT_SLV_RX, ACTL_A);	// Active L, Format A
	rSPPIN1=(0<<2)|(1<<1)|(0<<0);//dis-ENMUL,SBO,release
	printf("Slave setting end\n");

	SPI_Ch_Set(CH0_INT_MSTR_TX, ACTL_A);	// Active L, Format A
	rSPPIN0=(0<<2)|(1<<1)|(0<<0);//dis-ENMUL,SBO,release
	printf("Master setting end\n");

	pISR_SPI0=(unsigned)Spi01_M_Int;
//	pISR_SPI1=(unsigned)Spi01_S_Int;

	Master_nSS_Con0(0);    // Activate nSS 
//	rINTMSK&=~(BIT_SPI0|BIT_SPI1);
//	rINTMSK&=~(BIT_SPI1);
	rINTMSK&=~(BIT_SPI0);
	
	while((endSpi1Tx==0)||(endSpi0Tx==0))
		{
		if(Uart_GetKey()) {
			Master_nSS_Con0(1);
			return;
			}
		}

	Master_nSS_Con0(1);
//	rINTMSK |=(BIT_SPI0|BIT_SPI1);	
	rINTMSK |=(BIT_SPI0);	

	*spi0RxStr='\0';//attach End of String(Null)
	*spi1RxStr='\0';//attach End of String(Null)
	printf("SPI0Tx Strings:%s\n",tx0Str);
	printf("SPI0Rx Strings:%s\n",rx0Str+1);//remove first dummy data

	printf("SPI1Tx Strings:%s\n",tx1Str);
	printf("SPI1Rx Strings:%s\n",rx1Str+1);//remove first dummy data

	if(strcmp((rx1Str+1),tx0Str)==0)
		printf("SPI0 test O.K !!!\n");
	if(strcmp((rx0Str+1),tx1Str)==0)
		printf("SPI1 test O.K !!!\n");
	else 
		printf("ERROR!!!\n");

	SPI_Port_Return(0);
	SPI_Port_Return(1);
}

void __irq Spi01_M_Int(void)
{
	rINTMSK|=BIT_SPI0;
	ClearPending(BIT_SPI0); 

	if(*spi0TxStr!='\0') 
		rSPTDAT0=*spi0TxStr++;
  	else {
		while(!REDY0_org);   //Check ready state
		*spi0RxStr++=rSPRDATB0;    //First Rx data is garbage data

		endSpi0Tx=1;
		return;
	}

	if(rSPSTA0&0x4||rSPPIN0&0x4) 
		printf("Data Collision or Multi Master Error!!!\n");

	while(!REDY0_org);   //Check ready state
	*spi0RxStr++=rSPRDATB0;    //First Rx data is garbage data

	rINTMSK&=~(BIT_SPI1);
}

#endif

void SPI_Ch_Set(U32 mode, U32 format)
{
	U32 SMOD,ENSCK,MSSEL,TAGD,CPOL,CPHA;

	if(mode&0x100) SMOD=0;		// Polling
	else if(mode&0x200) SMOD=1;	// Interrupt
	else if(mode&0x400) SMOD=2;	// Buffer DMA using TXFIFO
	else SMOD=3;				// Buffer DMA using RXFIFO

	if(mode&0x10) {	// Master
		ENSCK=1;
		MSSEL = 1;
		if(mode&0x1) { TAGD=0; }
		else { TAGD=1; }	// Master Rx Auto Garbage Mode
		}
	else {	// Slave
		ENSCK=0;
		MSSEL = 0;
		TAGD=0;
		}

#if 0
	switch(format) {
		case ACTL_A :
			CPOL=1;
			CPHA=0;
			break;
		case ACTL_B :
			CPOL=1;
			CPHA=1;
			break;
		case ACTH_A :
			CPOL=0;
			CPHA=0;
			break;
		case ACTH_B :
			CPOL=0;
			CPHA=1;
			break;
		}
#else
	if (format==ACTL_A) {
		CPOL=1;
		CPHA=0;
		}
	else if (format==ACTL_B) {
		CPOL=1;
		CPHA=1;
		}
	else if (format==ACTH_A) {
		CPOL=0;
		CPHA=0;
		}
	else {
		CPOL=0;
		CPHA=1;
		}

#endif
	
	if(mode&0x1000)	 {// Channel 0
		rSPCON0 &= ~(0x7f);
		rSPCON0 |= (SMOD<<5)|(ENSCK<<4)|(MSSEL<<3)|(CPOL<<2)|(CPHA<<1)|(TAGD);
		printf("rSPCON0 [0x%08x]\n",rSPCON0);
		}
	else	 {	// Channel 1
		rSPCON1 &= ~(0x7f);
		rSPCON1 |= (SMOD<<5)|(ENSCK<<4)|(MSSEL<<3)|(CPOL<<2)|(CPHA<<1)|(TAGD);
		printf("rSPCON1 [0x%08x]\n",rSPCON1);
		}
	
}

void SPI_Baud_Rate_Set(U32 ch, float BaudRate)
{
	U32 PrescalerVal;

	if(BaudRate>25000000) {
		printf("SPI Baud Rate is too big (<25MHz)\n");
		while(1);
		}
	
	SystemCLK();
	PrescalerVal = (U32)(PCLK/2/BaudRate-1);

	if(ch) {
		rSPPRE1 = PrescalerVal;
		printf("rSPPRE1 [0x%08x]\n",rSPPRE1);
		}
	else {
		rSPPRE0 = PrescalerVal;
		printf("rSPPRE0 [0x%08x]\n",rSPPRE0);
		}
}

void SPI_Port_Init(U32 mode)
{
	if (mode&0x2000) {
		spi1_rGPGCON=rGPGCON;
		spi1_rGPGDAT=rGPGDAT;
		spi1_rGPGDN=rGPGDN;
		
		rGPGCON |= (0x3f<<10);	// GPG7,6,5 = SPICLK1,SPIMOSI1,SPIMISO1
		rGPGDN |= (0x7<<5);			// Pull-down Disable

		if (mode&0x10) {	// Master
			rGPGDAT=rGPGDAT&~(1<<3)|(1<<3);
			rGPGCON &= ~(0x3<<6);
			rGPGCON |= (0x1<<6);	// GPG3 = Output fot chip select pin
//			rGPGCON |= (0x3<<6);	// GPG3 = Output fot chip select pin
		}
		else {	// Slave
			rGPGCON &= ~(0x3<<6);
			rGPGCON |= (0x3<<6); // GPG3 = nSS1 when SPI1 is in slave mode
		}
	}
	else {
		spi0_rGPECON=rGPECON;
		spi0_rGPEDAT=rGPEDAT;
		spi0_rGPEDN=rGPEDN;
		
		rGPECON &= ~(0x3f<<22);
		rGPECON |= (0x2a<<22); 	// GPE13,12,11 = SPICLK0,SPIMOSI0,SPIMISO0
		rGPEDN |= (0x7<<11);		// Pull-down Disable
				
		if (mode&0x10) {	// Master
			rGPGDAT=rGPGDAT&~(1<<2)|(1<<2);
			rGPGCON &= ~(0x3<<4);
			rGPGCON |= (0x1<<4);	// GPG2 = Output fot chip select pin
//			rGPGCON |= (0x3<<4);	// GPG2 = nSS0 fot chip select pin
		}
		else {	// Slave
			rGPGCON &= ~(0x3<<4);
			rGPGCON |= (0x3<<4); // GPG2 = nSS0 when SPI0 is in slave mode
		}
	}

	if (mode&0x2000) {
		printf("mode [0x%08x]\n",mode);
		printf("rGPGCON [0x%08x]\n",rGPGCON);
		printf("rGPGDAT [0x%08x]\n",rGPGDAT);
		}
	else {
		printf("mode [0x%08x]\n",mode);
		printf("rGPECON [0x%08x]\n",rGPECON);
		printf("rGPEDAT [0x%08x]\n",rGPEDAT);
		}

	rSPCON0 = 0;
	rSPPIN0 = 0x2;
	rSPPRE0 = 0;

	rSPCON1 = 0;
	rSPPIN1 = 0x2;
	rSPPRE1 = 0;
}


void SPI_Port_Return(U32 ch)
{
	if (ch) {
		rGPGCON=spi1_rGPGCON;
		rGPGDAT=spi1_rGPGDAT;
		rGPGDN=spi1_rGPGDN;
	}
	else {
		rGPECON=spi0_rGPECON;
		rGPEDAT=spi0_rGPEDAT;
		rGPEDN=spi0_rGPEDN;
	}
}

void Master_nSS_Con0(int Set)
{
	rGPGDAT=rGPGDAT&~(1<<2)|(Set<<2);
	printf("Chip Select nSS0 [%d]\n",Set);
}


void Master_nSS_Con1(int Set)
{
	rGPGDAT=rGPGDAT&~(1<<3)|(Set<<3);
	printf("Chip Select nSS1 [%d]\n",Set);
}
#endif // Total

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
youjizz国产精品| 精品少妇一区二区三区| 91麻豆精品国产综合久久久久久 | 日韩精品一区二区在线| 国产欧美一区二区三区沐欲| 亚洲高清三级视频| 国产成人三级在线观看| 91麻豆精品国产91久久久更新时间 | 亚洲综合免费观看高清完整版| 久久99国产精品尤物| 欧美在线免费播放| 成人免费小视频| 丰满白嫩尤物一区二区| 日韩精品一区二区三区蜜臀| 亚洲一区在线视频| 91在线国内视频| 亚洲国产精品精华液2区45| 久久国产麻豆精品| 7777女厕盗摄久久久| 亚洲第一福利一区| 欧美网站一区二区| 亚洲国产精品一区二区尤物区| 不卡av在线免费观看| 国产日韩欧美电影| 国产高清在线精品| 精品国产露脸精彩对白| 久久精品国内一区二区三区| 337p亚洲精品色噜噜噜| 亚洲成人动漫av| 欧美日韩国产一级片| 亚洲国产成人精品视频| 欧美日韩专区在线| 日韩电影在线观看一区| 91精品婷婷国产综合久久性色| 午夜欧美一区二区三区在线播放| 欧美午夜视频网站| 偷拍一区二区三区| 精品免费视频.| 激情综合亚洲精品| 国产精品色哟哟| www.激情成人| 亚洲精品v日韩精品| 在线观看日韩电影| 日本中文字幕一区二区视频| 欧美一区二区性放荡片| 国产在线国偷精品产拍免费yy| 久久夜色精品一区| 不卡一区二区在线| 一区二区免费视频| 日韩欧美在线网站| 国产乱码精品一区二区三区av| 久久精品视频一区二区三区| kk眼镜猥琐国模调教系列一区二区| 国产精品欧美经典| 欧美在线三级电影| 美女视频网站久久| 国产目拍亚洲精品99久久精品| 99在线精品观看| 亚洲午夜久久久久久久久电影网 | 午夜精品福利一区二区三区蜜桃| 91麻豆精品国产91久久久久久久久| 麻豆91在线播放免费| 国产精品乱码人人做人人爱 | 成人aaaa免费全部观看| 一级特黄大欧美久久久| 日韩一区二区电影网| www.亚洲精品| 免费成人小视频| 国产精品精品国产色婷婷| av在线播放成人| 热久久一区二区| 亚洲免费色视频| 91精品国产91久久综合桃花| 成人爱爱电影网址| 麻豆视频一区二区| 亚洲视频在线观看三级| 日韩美女主播在线视频一区二区三区| 成人精品视频一区二区三区尤物| 亚洲一区在线视频| 国产清纯美女被跳蛋高潮一区二区久久w| 色综合欧美在线视频区| 久久精品国产一区二区| 悠悠色在线精品| 久久久久久久综合色一本| 欧美色图12p| av电影在线观看不卡| 久草这里只有精品视频| 亚洲一区二区三区美女| 日本一区二区三区在线不卡 | 精品成人a区在线观看| eeuss鲁片一区二区三区| 久久99精品久久久久久动态图| 亚洲一区二区三区自拍| 国产精品免费久久| 国产日韩精品一区| 亚洲精品一区二区精华| 欧美一二三在线| 色婷婷综合久久久| 91亚洲永久精品| 国产成人在线影院| 国产美女精品在线| 国产一区二三区好的| 精品一二三四区| 蜜桃视频在线一区| 奇米888四色在线精品| 亚洲午夜久久久久中文字幕久| 亚洲丝袜另类动漫二区| 欧美国产精品一区二区三区| 久久麻豆一区二区| 国产亚洲欧美色| 国产免费成人在线视频| 欧美国产亚洲另类动漫| 久久色视频免费观看| xf在线a精品一区二区视频网站| 日韩欧美国产三级电影视频| 欧美一区在线视频| 日韩一区二区在线免费观看| 日韩欧美在线观看一区二区三区| 欧美精品成人一区二区三区四区| 欧美综合天天夜夜久久| 欧美日韩在线播放| 欧美精品日韩综合在线| 欧美一级艳片视频免费观看| 3d动漫精品啪啪一区二区竹菊| 51精品国自产在线| 亚洲精品在线观看网站| 欧美国产日本视频| 中文字幕欧美一| 一区二区三区四区在线播放 | av亚洲精华国产精华精华| 国产精品一区二区久激情瑜伽| 国产福利视频一区二区三区| 成人午夜视频免费看| 91蜜桃视频在线| 欧美日韩国产首页| 亚洲精品在线电影| 国产精品美女视频| 亚洲国产精品视频| 精品一区二区三区免费观看| 国产黄色成人av| 在线国产电影不卡| 欧美一区二区三区白人| 久久天天做天天爱综合色| 亚洲天天做日日做天天谢日日欢| 亚州成人在线电影| 国产综合色视频| 91亚洲精品乱码久久久久久蜜桃 | 亚洲综合一区二区精品导航| 午夜精品影院在线观看| 国产成人免费视频网站高清观看视频| 成人激情小说乱人伦| 欧美日韩情趣电影| 国产欧美一区二区精品忘忧草| 亚洲欧美一区二区三区孕妇| 五月天激情综合网| 国产99久久久精品| 7878成人国产在线观看| 国产精品久久久久毛片软件| 日韩黄色片在线观看| k8久久久一区二区三区| 欧美xxxxx牲另类人与| 亚洲色图一区二区| 国产精品自在在线| 欧美精品九九99久久| 国产精品国产三级国产专播品爱网| 亚洲国产成人高清精品| 99久久99久久精品免费看蜜桃| 日韩你懂的在线播放| 一区av在线播放| 懂色av一区二区三区免费观看| 777亚洲妇女| 亚洲自拍另类综合| 99精品视频免费在线观看| 2024国产精品视频| 日韩电影网1区2区| 欧美亚洲国产一卡| 亚洲视频在线观看三级| 成人综合在线视频| 欧美成人猛片aaaaaaa| 亚洲国产aⅴ成人精品无吗| 成人性色生活片| 久久久久青草大香线综合精品| 奇米精品一区二区三区四区 | 日韩精品欧美精品| 欧美综合在线视频| 一区二区三区精品| av不卡在线播放| 中文字幕av一区二区三区免费看| 日本成人中文字幕| 欧美日韩国产综合一区二区| 一区二区三区在线视频免费| 97精品超碰一区二区三区| 亚洲欧洲成人精品av97| 成人免费毛片片v| 国产午夜精品福利| 国产成人一区在线| 中文字幕精品在线不卡| 丰满岳乱妇一区二区三区| 国产人久久人人人人爽| 成人精品免费视频|