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

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

?? save.c

?? 基于stm32的MP3播放器
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
//復(fù)制記錄項(xiàng)信息
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)//當(dāng)COUNT為零時(shí),有它帶回這個(gè)目錄下總共有多少首音樂(lè)
{                                                                //不為零時(shí)有MusicInfo帶回第Count首歌的詳細(xì)文件信息
	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

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www国产成人| 亚洲国产欧美一区二区三区丁香婷| 欧美日韩一卡二卡| 在线欧美日韩国产| 色综合天天天天做夜夜夜夜做| 欧美精品在线观看一区二区| 日本道在线观看一区二区| 成人国产免费视频| 不卡高清视频专区| 99久久国产免费看| 91精品福利视频| 欧洲精品一区二区| 欧美三级乱人伦电影| 7777精品伊人久久久大香线蕉经典版下载| 欧美色爱综合网| 欧美日韩1区2区| 欧美一二三四区在线| 精品电影一区二区三区| 日本一区二区三区视频视频| 国产精品三级电影| 一区二区三区免费在线观看| 亚洲国产一区在线观看| 日本欧美一区二区三区乱码| 久久精品国产一区二区三区免费看 | 国产成人丝袜美腿| 99久久免费视频.com| 欧美性色aⅴ视频一区日韩精品| 欧美日韩精品高清| 精品精品国产高清a毛片牛牛| 亚洲h在线观看| 蜜臀av一级做a爰片久久| 国产精品亚洲午夜一区二区三区| 波多野结衣中文字幕一区二区三区 | 一区二区三区成人| 天天av天天翘天天综合网| 精品一区二区三区日韩| 99久久99精品久久久久久| 欧美三级一区二区| 久久综合久久综合九色| 亚洲视频免费看| 日本aⅴ亚洲精品中文乱码| 狠狠色狠狠色合久久伊人| eeuss鲁片一区二区三区在线观看| 欧洲中文字幕精品| 欧美成人乱码一区二区三区| 国产精品久久久久久久久晋中| 亚洲超碰精品一区二区| 国产精品一区二区黑丝| 欧洲av在线精品| 久久精品视频在线免费观看| 亚洲午夜精品在线| 国产福利视频一区二区三区| 欧美影院午夜播放| 久久伊人蜜桃av一区二区| 亚洲一区二区三区四区不卡| 国产一区不卡精品| 欧美羞羞免费网站| 欧美激情中文不卡| 日韩1区2区日韩1区2区| 91原创在线视频| 欧美mv日韩mv| 一区二区三区美女视频| 国产成人免费高清| 欧美一二三区在线| 一区二区三区高清| 成人激情免费网站| 日韩欧美高清在线| 亚洲韩国精品一区| 91视频xxxx| 国产欧美日韩综合精品一区二区| 视频一区在线播放| 色婷婷综合久久久中文一区二区| 久久综合久久综合亚洲| 日韩电影免费在线看| 色吊一区二区三区| 亚洲国产精品精华液2区45| 另类小说图片综合网| 在线观看欧美精品| 亚洲少妇30p| 丁香激情综合五月| 久久在线免费观看| 麻豆专区一区二区三区四区五区| 欧美三级欧美一级| 亚洲男人电影天堂| voyeur盗摄精品| 国产欧美日本一区二区三区| 精品在线你懂的| 日韩视频一区二区在线观看| 偷拍一区二区三区四区| 欧洲精品在线观看| 一区二区在线电影| 91视频你懂的| √…a在线天堂一区| 国产成人在线免费观看| 久久久久久久久久久久久女国产乱 | 日本中文字幕一区二区有限公司| 一本在线高清不卡dvd| 国产精品二区一区二区aⅴ污介绍| 国产成人综合在线播放| 久久综合色播五月| 国产精品性做久久久久久| 精品国产网站在线观看| 久久超碰97中文字幕| 日韩精品一区在线| 九九**精品视频免费播放| 日韩你懂的在线播放| 麻豆精品在线视频| 精品国产一区a| 国产美女精品在线| 国产三级精品在线| 成人国产精品免费网站| 最新不卡av在线| 色婷婷av一区二区三区大白胸| 亚洲久草在线视频| 欧美在线不卡视频| 亚洲sss视频在线视频| 欧美剧情电影在线观看完整版免费励志电影| 亚洲综合丁香婷婷六月香| 欧美视频精品在线| 奇米亚洲午夜久久精品| 欧美成人一区二区| 国产福利一区在线| 亚洲三级视频在线观看| 在线观看91精品国产入口| 天天综合天天综合色| 精品国产髙清在线看国产毛片 | 欧美军同video69gay| 蜜芽一区二区三区| 久久亚洲一级片| 99久久久免费精品国产一区二区| 一区二区三区在线视频免费| 欧美精品xxxxbbbb| 极品销魂美女一区二区三区| 欧美激情一区二区三区四区| 91丨九色丨尤物| 五月天亚洲精品| 久久久精品综合| 91农村精品一区二区在线| 偷拍一区二区三区| 久久久久久久久久久黄色| 99re这里只有精品首页| 日韩精品一级二级 | 中文一区二区在线观看| 欧美在线播放高清精品| 捆绑变态av一区二区三区| 国产精品视频一二| 欧美日韩久久一区| 国产九九视频一区二区三区| 亚洲美女屁股眼交3| 日韩视频123| 91玉足脚交白嫩脚丫在线播放| 日本欧美肥老太交大片| 中文字幕va一区二区三区| 精品视频一区二区三区免费| 国产另类ts人妖一区二区| 一区二区三区欧美视频| 久久尤物电影视频在线观看| 欧美在线视频全部完| 国产麻豆午夜三级精品| 亚洲午夜私人影院| 国产欧美一区二区精品性色超碰| 欧美日韩视频一区二区| 懂色一区二区三区免费观看| 三级欧美在线一区| 国产精品电影一区二区| 欧美v日韩v国产v| 在线看国产一区二区| 国产成人精品影院| 免费成人你懂的| 亚洲综合在线视频| 国产丝袜美腿一区二区三区| 欧美高清激情brazzers| eeuss鲁片一区二区三区在线看| 免费欧美高清视频| 亚洲伊人色欲综合网| 国产精品伦一区二区三级视频| 欧美一级片免费看| 在线观看亚洲a| 99久久久国产精品免费蜜臀| 国产一区二区福利| 欧美aa在线视频| 午夜电影网亚洲视频| 尤物av一区二区| 国产精品美日韩| 久久久噜噜噜久噜久久综合| 日韩午夜av一区| 欧美精品久久99久久在免费线 | 久久这里只精品最新地址| 91精品国产色综合久久不卡电影| 在线观看视频一区二区欧美日韩| heyzo一本久久综合| 国产在线日韩欧美| 卡一卡二国产精品 | 丝袜a∨在线一区二区三区不卡| 亚洲人成在线观看一区二区| 国产精品久久久久久久浪潮网站 | 欧美国产成人在线| 久久日韩精品一区二区五区| 精品剧情在线观看| 精品三级av在线|