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

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

?? save.c

?? 多功能MP3代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
//復制記錄項信息
void CopyDirentruyItem(struct direntry *Desti,struct direntry *Source)
{
	BYTE i;
	for(i=0;i<8;i++)Desti->deName[i] = Source->deName[i];
	for(i=0;i<3;i++)Desti->deExtension[i] = Source->deExtension[i];
	Desti->deAttributes = Source->deAttributes;
	Desti->deLowerCase = Source->deLowerCase;
	Desti->deCHundredth = Source->deCHundredth;
	for(i=0;i<2;i++)Desti->deCTime[i] = Source->deCTime[i];
	for(i=0;i<2;i++)Desti->deCDate[i] = Source->deCDate[i];
	for(i=0;i<2;i++)Desti->deADate[i] = Source->deADate[i];
	Desti->deHighClust = Source->deHighClust;
	for(i=0;i<2;i++)Desti->deMTime[i] = Source->deMTime[i];
	for(i=0;i<2;i++)Desti->deMDate[i] = Source->deMDate[i];
	Desti->deStartCluster = Source->deStartCluster;
	Desti->deFileSize = Source->deFileSize;
} 
   
//search the file , when *count = 0 it will bring the number whole songs, when *cout != 0 the *MusicInfo will bring the infomation of the file
BYTE Search(BYTE *dir,struct direntry *MusicInfo,WORD *Count,BYTE *type)//當COUNT為零時,有它帶回這個目錄下總共有多少首音樂
{                                                                //不為零時有MusicInfo帶回第Count首歌的詳細文件信息
	BYTE *buffer;
	//BYTE buff[3];
	DWORD sector;
	DWORD cluster;
	DWORD tempclust;
	unsigned char cnt;
	unsigned int offset;
	unsigned int i=0;
	unsigned char j;//long name buffer offset;
	unsigned char *p;//long name buffer pointer
	struct direntry *item = 0;
	struct winentry *we =0;
	cluster = FAT_OpenDir(dir);
	if(cluster == 1)return 1;
	if(cluster==0 && FAT32_Enable==0)// root directory
	{
		buffer=malloc(512);//apply memory
		if(buffer==0)return 1;//if failed
		for(cnt=0;cnt<RootDirSectors;cnt++)
		{
			if(SD_ReadSingleBlock(FirstDirSector+cnt,buffer)){free(buffer);return 1;}
			for(offset=0;offset<512;offset+=32)
			{
				item=(struct direntry *)(&buffer[offset]);//pointer convert
				//find a valid item and display it
				if((item->deName[0] != '.') && (item->deName[0] != 0x00) && (item->deName[0] != 0xe5))
				{
					if(item->deAttributes == 0x0f)
					{
						we = (struct winentry *)(&buffer[offset]);
						j = 26 *( (we->weCnt-1) & WIN_CNT);
                        			if(j<MAX_LONG_NAME_SIZE-25)
						{
							p = &LongNameBuffer[j];
							for (j=0;j<10;j++)	*p++ = we->wePart1[j];			
							for (j=0;j<12;j++)	*p++ = we->wePart2[j];
							for (j=0;j<4;j++)	*p++ = we->wePart3[j];	
							if (we->weCnt & 0x40) (*(unsigned int *)p) = 0;				
							if ((we->weCnt & WIN_CNT) == 1) LongNameFlag = 1;	
						}
						LongNameBuffer[MAX_LONG_NAME_SIZE-1] = 0;
						LongNameBuffer[MAX_LONG_NAME_SIZE-2] = 0;
						//p = &LongNameBuffer[j];
						//for (j=0;j<10;j++)	*p++ = we->wePart1[j];			
						//for (j=0;j<12;j++)	*p++ = we->wePart2[j];
						//for (j=0;j<4;j++)	*p++ = we->wePart3[j];	
						//if (we->weCnt & 0x40) (*(unsigned int *)p) = 0;				
						//if ((we->weCnt & WIN_CNT) == 1) LongNameFlag = 1; 
					}	
					else if((item->deExtension[0] == 'M')&&(item->deExtension[1] == 'P')&&(item->deExtension[2] == '3'))
					{
						CopyDirentruyItem(MusicInfo,item);
						*type=1;
						i++;
						if(i==*Count){free(buffer);return 0;}
						else LongNameFlag = 0;	
					}
					else if((item->deExtension[0] == 'W')&&(item->deExtension[1] == 'M')&&(item->deExtension[2] == 'A'))
					{
						CopyDirentruyItem(MusicInfo,item);
						*type=2;
						i++;
						if(i==*Count){free(buffer);return 0;}
						else LongNameFlag = 0;	
					}
					else if((item->deExtension[0] == 'M')&&(item->deExtension[1] == 'I')&&(item->deExtension[2] == 'D'))
					{
						CopyDirentruyItem(MusicInfo,item);
						*type=3;
						i++;
						if(i==*Count){free(buffer);return 0;}
						else LongNameFlag = 0;	
					}
					else if((item->deExtension[0] == 'W')&&(item->deExtension[1] == 'A')&&(item->deExtension[2] == 'V'))
					{
						CopyDirentruyItem(MusicInfo,item);
						*type=4;
						i++;
						if(i==*Count){free(buffer);return 0;}
						else LongNameFlag = 0;	
					}
					else LongNameFlag = 0;
				}
			}
		}
		free(buffer);//release
	}
	else//other folders
	{
		tempclust=cluster;
		while(1)
		{
			sector=FirstDataSector+(DWORD)(tempclust-2)*(DWORD)SectorsPerClust;//calculate the actual sector number
			buffer=malloc(512);//apply memory
			if(buffer==0)return 1;//if failed
			for(cnt=0;cnt<SectorsPerClust;cnt++)
			{
				if(SD_ReadSingleBlock(sector+cnt,buffer)){free(buffer);return 1;}
				for(offset=0;offset<512;offset+=32)
				{
					item=(struct direntry *)(&buffer[offset]);
					if((item->deName[0] != '.') && (item->deName[0] != 0x00) && (item->deName[0] != 0xe5))
					{				
						if(item->deAttributes == 0x0f)
						{
							we = (struct winentry *)(&buffer[offset]);
							j = 26 *( (we->weCnt-1) & WIN_CNT);
                            			if(j<MAX_LONG_NAME_SIZE-25)
						       {
							    p = &LongNameBuffer[j];
							    for (j=0;j<10;j++)	*p++ = we->wePart1[j];			
							    for (j=0;j<12;j++)	*p++ = we->wePart2[j];
							    for (j=0;j<4;j++)	*p++ = we->wePart3[j];	
							    if (we->weCnt & 0x40) (*(unsigned int *)p) = 0;				
							    if ((we->weCnt & WIN_CNT) == 1) LongNameFlag = 1;	
						       }
							LongNameBuffer[MAX_LONG_NAME_SIZE-1] = 0;
							LongNameBuffer[MAX_LONG_NAME_SIZE-2] = 0;
							//p = &LongNameBuffer[j];
							//for (j=0;j<10;j++)	*p++ = we->wePart1[j];			
							//for (j=0;j<12;j++)	*p++ = we->wePart2[j];
							//for (j=0;j<4;j++)	*p++ = we->wePart3[j];	
							//if (we->weCnt & 0x40) (*(unsigned int *)p) = 0;				
							//if ((we->weCnt & WIN_CNT) == 1) LongNameFlag = 1;
						}
						else if((item->deExtension[0] == 'M')&&(item->deExtension[1] == 'P')&&(item->deExtension[2] == '3'))
						{
							CopyDirentruyItem(MusicInfo,item);
							*type = 1;
							i++;
							if(i==*Count){free(buffer);return 0;}
							else LongNameFlag = 0;	
						}
						else if((item->deExtension[0] == 'W')&&(item->deExtension[1] == 'M')&&(item->deExtension[2] == 'A'))
						{
							CopyDirentruyItem(MusicInfo,item);
							*type = 2;
							i++;
							if(i==*Count){free(buffer);return 0;}	
							else LongNameFlag = 0;
						}
						else if((item->deExtension[0] == 'M')&&(item->deExtension[1] == 'I')&&(item->deExtension[2] == 'D'))
						{
							CopyDirentruyItem(MusicInfo,item);
							*type = 3;
							i++;
							if(i==*Count){free(buffer);return 0;}
							else LongNameFlag = 0;	
						}
						else if((item->deExtension[0] == 'W')&&(item->deExtension[1] == 'A')&&(item->deExtension[2] == 'V'))
						{
							CopyDirentruyItem(MusicInfo,item);
							*type=4;
							i++;
							if(i==*Count){free(buffer);return 0;}
							else LongNameFlag = 0;	
						}
						else LongNameFlag = 0;
					}
				}
			}
			free(buffer);//release
			tempclust=FAT_NextCluster(tempclust);//next cluster
			if(tempclust == 0x0fffffff || tempclust == 0x0ffffff8 || (FAT32_Enable == 0 && tempclust == 0xffff))break;
		}
	}
	if(*Count==0)*Count=i;
	return 0;	
}
   
//search the file 
BYTE SearchLrc(BYTE *dir,BYTE * longnamebuffer,struct direntry *LrcInfo)
{                                                         
	BYTE *buffer;
	BYTE longbuffertemp[130];
	BYTE * p1, * p2;
	BYTE match = 0;
	DWORD sector;
	DWORD cluster;
	DWORD tempclust;
	unsigned char cnt;
	unsigned int offset;
	//unsigned int i=0;
	unsigned char j;//long name buffer offset;
	unsigned char *p;//long name buffer pointer
	struct direntry *item = 0;
	struct winentry *we =0;
	cluster = FAT_OpenDir(dir);
	if(cluster == 1)return 1;
	if(cluster==0 && FAT32_Enable==0)// root directory
	{
		buffer=malloc(512);//apply memory
		if(buffer==0)return 1;//if failed
		for(cnt=0;cnt<RootDirSectors;cnt++)
		{
			if(SD_ReadSingleBlock(FirstDirSector+cnt,buffer)){free(buffer);return 1;}
			for(offset=0;offset<512;offset+=32)
			{
				item=(struct direntry *)(&buffer[offset]);//pointer convert
				//find a valid item and display it
				if((item->deName[0] != '.') && (item->deName[0] != 0x00) && (item->deName[0] != 0xe5))
				{
					if(item->deAttributes == 0x0f)
					{
						we = (struct winentry *)(&buffer[offset]);
						j = 26 *( (we->weCnt-1) & WIN_CNT);
						if(j<MAX_LONG_NAME_SIZE-25)
						{
							p = &longbuffertemp[j];
							for (j=0;j<10;j++)	*p++ = we->wePart1[j];			
							for (j=0;j<12;j++)	*p++ = we->wePart2[j];
							for (j=0;j<4;j++)	*p++ = we->wePart3[j];	
							if (we->weCnt & 0x40) (*(unsigned int *)p) = 0;				
							if ((we->weCnt & WIN_CNT) == 1) LongNameFlag = 1;	
						}
						longbuffertemp[MAX_LONG_NAME_SIZE-1] = 0;
						longbuffertemp[MAX_LONG_NAME_SIZE-2] = 0;
					}
					else if((item->deExtension[0] == 'L')&&(item->deExtension[1] == 'R')&&(item->deExtension[2] == 'C'))
					{
						CopyDirentruyItem(LrcInfo,item);
						p1 = longnamebuffer;
						p2 = longbuffertemp;
						match = 1; 
						if(LongNameFlag)
						{
							while(*((unsigned int*)p1))
							{
								if(*(unsigned int*)p1 != *(unsigned int*)p2)
								{
									match = 0;
									break;
								}
								p1 += 2;
								p2 += 2;	
							}
						}
						else
						{
							p2 = item->deName;
							while(*p1)
							{
								if(*p1++ != *p2++)
								{
									match = 0;
									break;
								}
							}
						}
						if(match){free(buffer);return 0;}
						else LongNameFlag = 0;	
					}
					else LongNameFlag = 0;
				}
			}
		}
		free(buffer);//release
	}
	else//other folders
	{
		tempclust=cluster;
		while(1)
		{
			sector=FirstDataSector+(DWORD)(tempclust-2)*(DWORD)SectorsPerClust;//calculate the actual sector number
			buffer=malloc(512);//apply memory
			if(buffer==0)return 1;//if failed
			for(cnt=0;cnt<SectorsPerClust;cnt++)
			{
				if(SD_ReadSingleBlock(sector+cnt,buffer)){free(buffer);return 1;}
				for(offset=0;offset<512;offset+=32)
				{
					item=(struct direntry *)(&buffer[offset]);
					if((item->deName[0] != '.') && (item->deName[0] != 0x00) && (item->deName[0] != 0xe5))
					{				
						if(item->deAttributes == 0x0f)
						{
							we = (struct winentry *)(&buffer[offset]);
							j = 26 *( (we->weCnt-1) & WIN_CNT);
							if(j<MAX_LONG_NAME_SIZE-25)
							{
								p = &longbuffertemp[j];
								for (j=0;j<10;j++)	*p++ = we->wePart1[j];			
								for (j=0;j<12;j++)	*p++ = we->wePart2[j];
								for (j=0;j<4;j++)	*p++ = we->wePart3[j];	
								if (we->weCnt & 0x40) (*(unsigned int *)p) = 0;				
								if ((we->weCnt & WIN_CNT) == 1) LongNameFlag = 1;	
							}
							longbuffertemp[MAX_LONG_NAME_SIZE-1] = 0;
							longbuffertemp[MAX_LONG_NAME_SIZE-2] = 0;
						}
						else if((item->deExtension[0] == 'L')&&(item->deExtension[1] == 'R')&&(item->deExtension[2] == 'C'))
						{
							CopyDirentruyItem(LrcInfo,item);
							p1 = longnamebuffer;
							p2 = longbuffertemp;
							match = 1; 
							if(LongNameFlag)
							{
								while(*((unsigned int*)p1))
								{
									if(*(unsigned int*)p1 != *(unsigned int*)p2)
									{
										match = 0;
										break;
									}
									p1 += 2;
									p2 += 2;	
								}
							}
							else
							{
								p2 = item->deName;
								while(*p1)
								{
									if(*p1++ != *p2++)
									{
										match = 0;
										break;
									}
								}
							}
							if(match){free(buffer);return 0;}
							else LongNameFlag = 0;	
						}
						else LongNameFlag = 0;
					}
				}
			}
			free(buffer);//release
			tempclust=FAT_NextCluster(tempclust);//next cluster
			if(tempclust == 0x0fffffff || tempclust == 0x0ffffff8 || (FAT32_Enable == 0 && tempclust == 0xffff))break;
		}
	}
	return 1;	//can't find lrc file
}


void WriteFolderCluster(WORD addr,DWORD cluster)
{
#if FAT_DEBUG
	printf("\r\nWrite EEPROM address:%d with value:%ld",addr,cluster);
#endif
	eeprom_write_byte(addr,cluster>>24);
	eeprom_write_byte(addr+1,cluster>>16);
	eeprom_write_byte(addr+2,cluster>>8);
	eeprom_write_byte(addr+3,cluster>>0);
}

DWORD GetFolderCluster(WORD addr)
{
	DWORD temp;
	temp = eeprom_read_byte(addr);
	temp <<= 8;
	temp += eeprom_read_byte(addr+1);
	temp <<= 8;
	temp += eeprom_read_byte(addr+2);
	temp <<= 8;
	temp += eeprom_read_byte(addr+3);
#if FAT_DEBUG
	printf_P(PSTR("\r\nRead EEPROM address: %d value is: %ld"),addr,temp);
#endif
	return temp;
}

BYTE SearchFolder(DWORD cluster,WORD *addr)
{
	BYTE *buffer;
	//BYTE buff[3];
	DWORD sector;
	//DWORD cluster;
	DWORD tempclust;
	unsigned char cnt;
	unsigned int offset;
	//unsigned int i=0;
	//unsigned char j;//long name buffer offset;
//	unsigned char *p;//long name buffer pointer
	struct direntry *item = 0;
	//struct winentry *we =0;
	
	if(cluster==0 && FAT32_Enable==0)// root directory
	{	
		buffer=malloc(512);//apply memory
		if(buffer==0)return 1;//if failed
		for(cnt=0;cnt<RootDirSectors;cnt++)
		{
			if(SD_ReadSingleBlock(FirstDirSector+cnt,buffer)){free(buffer);return 1;}
			for(offset=0;offset<512;offset+=32)
			{
				item=(struct direntry *)(&buffer[offset]);//pointer convert
				//find a valid item and display it
				if((item->deName[0] != '.') && (item->deName[0] != 0x00) && (item->deName[0] != 0xe5))
				{
					if(item->deAttributes & ATTR_DIRECTORY )
					{
						#if FAT_DEBUG
							printf_P(PSTR("\r\nFound a folder!"));
						#endif
						if(*addr==RECORD_ADDR_END)return 0;
						else
						{
							WriteFolderCluster(*addr,item->deStartCluster+(((unsigned long)item->deHighClust)<<16));
							*addr+=4;
						}
					}
				}
			}
		}
		free(buffer);//release
	}
	else//other folders
	{
		tempclust=cluster;
		while(1)
		{
			sector=FirstDataSector+(DWORD)(tempclust-2)*(DWORD)SectorsPerClust;//calculate the actual sector number
			buffer=malloc(512);//apply memory
			if(buffer==0)return 1;//if failed
			for(cnt=0;cnt<SectorsPerClust;cnt++)
			{
				if(SD_ReadSingleBlock(sector+cnt,buffer)){free(buffer);return 1;}
				for(offset=0;offset<512;offset+=32)
				{
					item=(struct direntry *)(&buffer[offset]);
					if((item->deName[0] != '.') && (item->deName[0] != 0x00) && (item->deName[0] != 0xe5))
					{				
						if(item->deAttributes & ATTR_DIRECTORY )
						{
							#if FAT_DEBUG
								printf_P(PSTR("\r\nFound a folder!"));
							#endif
							if(*addr==RECORD_ADDR_END)return 0;
							else
							{
								WriteFolderCluster(*addr,item->deStartCluster+(((unsigned long)item->deHighClust)<<16));
								*addr+=4;
							}
						}
					}
				}
			}
			free(buffer);//release
			tempclust=FAT_NextCluster(tempclust);//next cluster
			if(tempclust == 0x0fffffff || tempclust == 0x0ffffff8 || (FAT32_Enable == 0 && tempclust == 0xffff))break;
		}
	}
	return 0;		
}

	

BYTE SearchInit()
{	
	WORD addr = RECORD_ADDR_START;
	WORD temp_addr;
	DWORD cluster;
	
#if FAT_DEBUG

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久99久久久精品齐齐| 美国av一区二区| 色综合久久99| 亚洲第一福利一区| 欧美tk—视频vk| 国产激情精品久久久第一区二区| 国产日产欧美精品一区二区三区| 成人美女视频在线观看18| 亚洲女人小视频在线观看| 在线观看av不卡| 免费在线欧美视频| 久久精品视频在线看| 一本大道综合伊人精品热热| 亚洲aaa精品| 国产人成亚洲第一网站在线播放| 97精品电影院| 美腿丝袜亚洲色图| 日本一区二区在线不卡| 欧美视频自拍偷拍| 国产一区二区网址| 亚洲精品五月天| 欧美成人bangbros| 91美女片黄在线| 老司机免费视频一区二区三区| 国产精品色在线观看| 欧美久久久久久久久| 成人一区二区三区视频在线观看| 亚洲永久免费av| 久久久久成人黄色影片| 欧美三级韩国三级日本一级| 国产很黄免费观看久久| 亚洲午夜在线观看视频在线| 久久久国产精华| 欧美精品久久久久久久多人混战 | 日韩欧美中文字幕制服| 国产盗摄精品一区二区三区在线 | 精品国产91乱码一区二区三区| 色婷婷综合久色| 精一区二区三区| 午夜精品福利一区二区蜜股av| 国产精品天干天干在观线| 欧美一区欧美二区| 在线视频一区二区三区| 国产91高潮流白浆在线麻豆| 日韩高清一级片| 亚洲激情中文1区| 欧美国产激情二区三区| 日韩免费高清av| 欧美精品久久久久久久多人混战 | 国产成人综合在线观看| 无吗不卡中文字幕| 亚洲精品国产第一综合99久久 | 亚洲国产日韩a在线播放 | 亚洲主播在线播放| 国产精品美女一区二区| 久久综合九色欧美综合狠狠| 日韩一区和二区| 宅男噜噜噜66一区二区66| 91行情网站电视在线观看高清版| 成人h版在线观看| 国产精品456| 国产一区欧美二区| 青青草成人在线观看| 日韩成人一区二区三区在线观看| 午夜精品福利一区二区三区av | 日本不卡一二三区黄网| 亚洲bt欧美bt精品777| 亚洲一区二区综合| 一区二区三区在线不卡| 亚洲精品免费在线观看| 亚洲欧美日韩国产手机在线| 亚洲视频你懂的| 亚洲另类在线制服丝袜| 亚洲男人的天堂网| 亚洲精品国产成人久久av盗摄| 亚洲欧美一区二区三区国产精品 | 亚洲第一福利一区| 午夜精品福利一区二区三区av | 99精品1区2区| 色哟哟欧美精品| 91久久国产最好的精华液| 欧美亚男人的天堂| 欧美私模裸体表演在线观看| 欧美日韩精品免费| 日韩视频一区在线观看| 久久中文娱乐网| 国产精品久久午夜夜伦鲁鲁| 亚洲欧美一区二区三区国产精品| 亚洲宅男天堂在线观看无病毒| 亚洲电影在线免费观看| 人人狠狠综合久久亚洲| 国产麻豆精品视频| 成人免费av资源| 欧美伊人久久大香线蕉综合69| 欧美三级韩国三级日本三斤| 日韩欧美综合一区| 国产精品免费av| 亚洲午夜电影在线观看| 免费的国产精品| 国产91精品露脸国语对白| 91丨porny丨中文| 91精品蜜臀在线一区尤物| 日韩欧美黄色影院| 国产精品久线观看视频| 亚洲综合成人在线| 韩国v欧美v日本v亚洲v| 99久久99精品久久久久久| 7777精品伊人久久久大香线蕉完整版 | 欧美日韩视频在线第一区| 精品久久久久久久久久久院品网 | 亚洲免费在线观看| 日韩avvvv在线播放| 成人亚洲一区二区一| 91久久免费观看| 久久青草国产手机看片福利盒子 | 国产不卡在线视频| 欧美午夜精品理论片a级按摩| 日韩欧美国产综合在线一区二区三区| 国产清纯美女被跳蛋高潮一区二区久久w | 久久综合九色综合欧美亚洲| 亚洲男女一区二区三区| 久草中文综合在线| 91网站最新地址| www国产亚洲精品久久麻豆| 一区二区三区精品在线| 国产精品一区二区视频| 欧美日韩不卡一区二区| 一区在线播放视频| 激情综合网最新| 欧美日韩午夜精品| 综合在线观看色| 国产一区日韩二区欧美三区| 欧美日韩一级黄| 久久精品一级爱片| 国产精品一区二区黑丝| 亚洲青青青在线视频| 九色综合狠狠综合久久| 欧美日免费三级在线| 国产精品亚洲一区二区三区妖精| 午夜久久福利影院| 成人动漫一区二区| 亚洲精品一区二区三区影院 | 亚洲三级电影网站| 国产欧美一区二区三区沐欲| 国产欧美一区二区三区在线老狼 | 国产喂奶挤奶一区二区三区| 成人国产视频在线观看| 精品一区在线看| 99视频一区二区三区| 欧美肥大bbwbbw高潮| 亚洲国产成人高清精品| 日韩一二三四区| 中文字幕av一区二区三区高 | 美女视频免费一区| 精品精品欲导航| 色综合久久99| 欧美日韩在线直播| 国产精品一二三区| 久久久另类综合| 国产精品九色蝌蚪自拍| 91免费视频观看| 99久久综合国产精品| 成人免费三级在线| kk眼镜猥琐国模调教系列一区二区| 欧美tickling网站挠脚心| 三级精品在线观看| 国产乱色国产精品免费视频| 欧美va亚洲va国产综合| 日韩一本二本av| 久久精品99国产精品| 日韩女同互慰一区二区| 久久国产乱子精品免费女| 欧美变态凌虐bdsm| 国产麻豆视频精品| 国产精品国产自产拍高清av| 94-欧美-setu| 亚洲成人av一区二区三区| 欧美男男青年gay1069videost| 日本三级韩国三级欧美三级| 欧美一卡二卡在线| 国产乱子轮精品视频| 国产精品久久久久精k8| 色视频成人在线观看免| 天天综合天天做天天综合| 日韩一级二级三级| 懂色av一区二区夜夜嗨| 有坂深雪av一区二区精品| 欧美精品色综合| 国产精品综合一区二区三区| 国产精品欧美综合在线| 色久优优欧美色久优优| 日韩在线一区二区三区| 2023国产精品视频| 99v久久综合狠狠综合久久| 香蕉加勒比综合久久| 欧美α欧美αv大片| 99久久国产综合精品色伊| 天天色综合成人网| 国产日韩欧美精品一区| 在线免费观看不卡av|