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

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

?? fat16.c

?? 在s3c44b0下利用SD卡進行WAV文件(FAT16格式)播放的源程序
?? C
?? 第 1 頁 / 共 4 頁
字號:
	{
		for(; i< SectorsPerCluster; i++)
		{
			Cache = GetSectorData(fp->CurrentSectorNum);
			if(Cache == NULL)
				return 0;

			Cache += fp->SectorOffset;
			max_copy_bytes_in_sector = (BytesPerSector - fp->SectorOffset) > (bytes - read_bytes) ? (bytes - read_bytes) : (BytesPerSector- fp->SectorOffset);
			memcpy(ReadBuffer1[i], Cache, max_copy_bytes_in_sector);

			read_bytes += max_copy_bytes_in_sector;
			fp->SectorOffset += max_copy_bytes_in_sector;
			fp->offset += max_copy_bytes_in_sector;
			buffer = (char*)buffer + max_copy_bytes_in_sector;

			if(fp->SectorOffset == BytesPerSector)
			{
				if(i == SectorsPerCluster -1)
				{
					Cluster = GetNextClusterNum(Cluster);
					if(Cluster != 0xffff)
						fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
				}
				else
					fp->CurrentSectorNum ++;

				fp->SectorOffset = 0;
			}

			if(read_bytes == bytes)
			{
				return bytes;
			}
		}
	}
	
	while(Cluster != 0xffff)	//讀取數據簇,直到0xffff
	{
		for(i=0; i< SectorsPerCluster; i++)
		{
			Cache = GetSectorData(fp->CurrentSectorNum);//取得當前扇區數據
			if(Cache == NULL)
				return 0;

			Cache += fp->SectorOffset;//加上要儲存數據的零頭(在最后有用),一個扇區512字節內的一個偏移量,一般為0
			
			//計算最大數據拷貝字節數,在最后計算出要存放的零頭   
			//如果 每扇區需要存放的字節數(一般為512) > 還沒有存放的字節總數    那就等于 還沒有存放的字節總數
			//如果 每扇區需要存放的字節數(一般為512) < 還沒有存放的字節總數    那就等于 每扇區需要存放的字節數(一般為512)
			max_copy_bytes_in_sector = (BytesPerSector- fp->SectorOffset) > (bytes - read_bytes) ? (bytes - read_bytes) : (BytesPerSector- fp->SectorOffset);
			memcpy(ReadBuffer1[j*8+i], Cache, max_copy_bytes_in_sector);//存放到緩存
			
			read_bytes += max_copy_bytes_in_sector;//計算已讀取存放的字節總數
			
			//計算偏移量,如果之前存放的是一整扇區512字節的話,接下去會被清0
			//SectorOffset一般在數據最后才有意義,因為要讀取的數據不一定都是扇區的整數倍
			//SectorOffset就是最后的零頭
			fp->SectorOffset += max_copy_bytes_in_sector;
			
			fp->offset += max_copy_bytes_in_sector;
			buffer = (char*)buffer + max_copy_bytes_in_sector;

			if(fp->SectorOffset == BytesPerSector)//如果之前存放的是一整扇區的話,說明后面還有數據
			{				
				if(i == SectorsPerCluster -1) //如果是一簇中的最后一個扇區
				{
					Cluster = GetNextClusterNum(Cluster); //取得下一個簇號
					if(Cluster != 0xffff)	//如果不是結束標志,則計算當前扇區數
						fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
						
					j++;//將數據緩存往后挪8個扇區,j*8
					if(j == 10) j=0;
				}
				else
					fp->CurrentSectorNum ++; //當前扇區加1

				fp->SectorOffset = 0; //如果之前存放的是一整扇區512字節的話,SectorOffset清0
			}

			if(read_bytes == bytes)
			{
				return bytes;
			}
		}		
	}

	return 0;
}


/********************************************************************************************************************
** 函數名稱: unsigned int fat_read1
** 功能描述: 從SD/MMC卡中讀取一個文件,按簇讀取(實際是單塊讀取)	
** 輸   入: int handle		: 句柄		
			 void* buffer   : 接收緩沖區	
** 輸    出: 0:   成功    >0:  錯誤碼			
*********************************************************************************************************************/
unsigned int fat_read1(int handle, void* buffer)
{
	BYTE* Cache;
	_FILE *fp;
	WORD Cluster;
	int i,j=0;
	int k=0;

	if(handle <0 || handle >= sizeof(handles)/sizeof(_FILE))
		return 0;

	fp = &handles[handle];	//裝入文件句柄(由之前fat_open帶回的x),handles為指向_FILE的數組

	Cluster = SectorNum2ClusterNum(fp->CurrentSectorNum);//根據當前扇區算出數據起始簇

	i = (fp->CurrentSectorNum - FirstDataSector) % SectorsPerCluster;//計算是否有不是一整簇的扇區

	if(i != 0)	//讀取不滿一簇的數據扇區
	{
		for(; i< SectorsPerCluster; i++)
		{
			Cache = GetSectorData(fp->CurrentSectorNum);
			if(Cache == NULL)
				return 0;

			memcpy(ReadBuffer1[j*8+i], Cache, 512);

			if(i == SectorsPerCluster -1)
			{
				Cluster = GetNextClusterNum(Cluster);
				if(Cluster != 0xffff)
					fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
			}
			else
			fp->CurrentSectorNum ++;
		}
	}
	
	while(Cluster != 0xffff)	//讀取數據簇,直到0xffff
	{
		for(i=0; i< SectorsPerCluster; i++)
		{
			Cache = GetSectorData(fp->CurrentSectorNum);//取得當前扇區數據
			if(Cache == NULL)
				return 0;
				
			memcpy(ReadBuffer1[j*8+i], Cache, 512);//存放到緩存
			//if(k==0) memcpy(ReadBuffer2[0], Cache, 512);//保存第一扇區內容
			k++;
			
			if(i == SectorsPerCluster -1) //如果是一簇中的最后一個扇區
			{
				Cluster = GetNextClusterNum(Cluster); //取得下一個簇號
				if(Cluster != 0xffff)	//如果不是結束標志,則計算當前扇區數
					fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
				else
				{
					m=i;
					n=j;
				}
						
				j++;//將數據緩存往后挪8個扇區,j*8
				if(j == 10) j=0;
			}
			else
			fp->CurrentSectorNum ++; //當前扇區加1
		}		
	}
	return 0;
}


/********************************************************************************************************************
** 函數名稱: unsigned int fat_read2
** 功能描述: 從SD/MMC卡中讀取一個文件,按簇讀取(實際是多塊--以簇為單位讀取)	
** 輸   入: int handle		: 句柄		
			 void* buffer   : 接收緩沖區	
** 輸    出: 0:   成功    >0:  錯誤碼			
*********************************************************************************************************************/

unsigned int fat_read2(int handle)
{
	BYTE* Cache;
	_FILE *fp;
	WORD Cluster;
	int i,j=0;
	int k=0,buf1_busy=0,buf2_busy=0;
	unsigned long int aa1=0,aa2=0;

	
	if(handle <0 || handle >= sizeof(handles)/sizeof(_FILE))
		return 0;

	fp = &handles[handle];	//裝入文件句柄(由之前fat_open帶回的x),handles為指向_FILE的數組

	Cluster = SectorNum2ClusterNum(fp->CurrentSectorNum);//根據當前扇區算出數據起始簇

	i = (fp->CurrentSectorNum - FirstDataSector) % SectorsPerCluster;//計算是否有不是一整簇的扇區

	if(i != 0)	//讀取不滿一簇的數據扇區
	{
		for(; i< SectorsPerCluster; i++)
		{
			Cache = GetSectorData(fp->CurrentSectorNum);
			if(Cache == NULL)
				return 0;

			memcpy(ReadBuffer1[j*8+i], Cache, 512);

			if(i == SectorsPerCluster -1)
			{
				Cluster = GetNextClusterNum(Cluster);
				if(Cluster != 0xffff)
					fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
			}
			else
			fp->CurrentSectorNum ++;
		}
	}
	
	aa1 = (1<<30)+(1<<28)+(int)( (unsigned char *)ReadBuffer1 + 0x30 );
	aa2 = (1<<30)+(1<<28)+(int)( (unsigned char *)ReadBuffer2 + 0x30 );
	
	while(Cluster != 0xffff)	//讀取數據簇,直到0xffff
	{
		//for(i=0; i<50; i++)
		//{
			SD_ReadMultiBlock1(Cluster, ReadBuffer1+j);	//讀取一整簇的數據
			Cluster = GetNextClusterNum(Cluster); //取得下一個簇號
    		//rBDISRC0 = aa1;
    		j=j+8;
		//}
		
    	//rIISCON |=0x1;

		
		//SD_ReadMultiBlock1(Cluster, ReadBuffer2);	//讀取一整簇的數據
		//Cluster = GetNextClusterNum(Cluster); //取得下一個簇號
    	//rBDISRC0 = aa2;


	}
	return 0;
}


unsigned int fat_write(int handle, const char* buffer, unsigned int bytes)
{
	BYTE* Cache;
	unsigned int write_bytes =0;
	unsigned int max_write_bytes_in_sector;
	_FILE *fp;
	WORD Cluster;
	WORD PrevCluster;
	int i;

	if(handle <0 || handle >= sizeof(handles)/sizeof(_FILE))
		return 0;

	fp = &handles[handle];

	Cluster = SectorNum2ClusterNum(fp->CurrentSectorNum);
	PrevCluster = Cluster;

	i = (fp->CurrentSectorNum - FirstDataSector) % SectorsPerCluster;

	if(i != 0)
	{
		for(; i< SectorsPerCluster; i++)
		{
			Cache = GetSectorData(fp->CurrentSectorNum);
			if(Cache == NULL)
				return 0;

			Cache += fp->SectorOffset;
			max_write_bytes_in_sector = (BytesPerSector- fp->SectorOffset) > (bytes - write_bytes) ? (bytes - write_bytes) : (BytesPerSector - fp->SectorOffset);
			memcpy(Cache, buffer, max_write_bytes_in_sector);
			Flush();

			write_bytes += max_write_bytes_in_sector;
			fp->SectorOffset += max_write_bytes_in_sector;
			fp->offset += max_write_bytes_in_sector;
			buffer = (char*)buffer + max_write_bytes_in_sector;
			fp->dir.deFileSize +=  max_write_bytes_in_sector;

			if(fp->SectorOffset == BytesPerSector)
			{
				if(i == SectorsPerCluster -1)
				{
					PrevCluster = Cluster;
					Cluster = GetNextClusterNum(Cluster);
					if(Cluster != 0xffff)
						fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
					else
					{
						Cluster = AllocCluster(PrevCluster);
						if(Cluster == 0xffff)
							return 0;
						
						fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
					}
				}
				else
					fp->CurrentSectorNum ++;

				fp->SectorOffset = 0;
			}

			if(write_bytes == bytes)
			{
				return bytes;
			}
		}
	}

	for(;;)
	{
		for(i=0; i< SectorsPerCluster; i++)
		{
			Cache = GetSectorData(fp->CurrentSectorNum);
			if(Cache == NULL)
				return 0;

			Cache += fp->SectorOffset;
			max_write_bytes_in_sector = (BytesPerSector - fp->SectorOffset) > (bytes - write_bytes) ? (bytes - write_bytes) : (BytesPerSector - fp->SectorOffset);
			memcpy(Cache, buffer, max_write_bytes_in_sector);
			Flush();

			write_bytes += max_write_bytes_in_sector;
			fp->SectorOffset += max_write_bytes_in_sector;
			fp->offset += max_write_bytes_in_sector;
			buffer = (char*)buffer + max_write_bytes_in_sector;
			fp->dir.deFileSize +=  max_write_bytes_in_sector;

			if(fp->SectorOffset == BytesPerSector)
			{
				if(i == SectorsPerCluster -1)
				{
					PrevCluster = Cluster;
					Cluster = GetNextClusterNum(Cluster);
					if(Cluster != 0xffff)
						fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
					else
					{
						Cluster = AllocCluster(PrevCluster);
						if(Cluster == 0xffff)
							return 0;
						
						fp->CurrentSectorNum = ClusterNum2SectorNum(Cluster);
					}
				}
				else
					fp->CurrentSectorNum ++;

				fp->SectorOffset = 0;
			}

			if(write_bytes == bytes)
			{
				return bytes;
			}
		}
	}

	// we can not reach here.
	return 0;
}

int fat_remove( const char *filename)
{
	DWORD SectorNum;
	_FILE file;

	//locate
	SectorNum = fat_locate(filename, &file);
	if(SectorNum == 0xffffffff)
		return 4;

	// is it a dir ?
	if(file.dir.deAttributes & ATTR_DIRECTORY)
		return 6;

	if(DeleteDir(&file) != 0)
		return 5;

	FreeCluster(file.dir.deStartCluster);

	return 0;
}

int fat_get_stat( const char *filename, _STAT * stat)
{
	DWORD SectorNum;
	_FILE file;

	//locate
	SectorNum = fat_locate(filename, &file);
	if(SectorNum == 0xffffffff)
		return 1;

	stat->Attr = file.dir.deAttributes;
	stat->CrtDate = file.dir.CrtDate;
	stat->CrtTime = file.dir.CrtTime;
	stat->CrtTimeTenth = file.dir.CrtTimeTenth;
	stat->FileSize = file.dir.deFileSize;
	stat->LstAccDate = file.dir.LstAccDate;
	stat->WrtDate = file.dir.WrtDate;
	stat->WrtTime = file.dir.WrtTime;

	return 0;
}

int fat_set_stat( const char *filename, _STAT * stat)
{
	DWORD SectorNum;
	_FILE file;
	BYTE* Cache;
	DIRENTRY *dir;

	//locate
	SectorNum = fat_locate(filename, &file);
	if(SectorNum == 0xffffffff)
		return 1;

	file.dir.deAttributes = stat->Attr;
	file.dir.CrtDate = stat->CrtDate;
	file.dir.CrtTime = stat->CrtTime;
	file.dir.CrtTimeTenth = stat->CrtTimeTenth;
	file.dir.deFileSize = stat->FileSize;
	file.dir.LstAccDate = stat->LstAccDate;
	file.dir.WrtDate = stat->WrtDate;
	file.dir.WrtTime = stat->WrtTime;

	Cache = GetSectorData(file.DirSectorNum);
	if(Cache == NULL)
		return 2;

	dir = (DIRENTRY *)Cache;
	dir += file.DirIndex;

	memcpy((BYTE *)dir, (BYTE *)&file.dir, sizeof(DIRENTRY));
	Flush();

	return 0;
}


int fat_rename( const char *oldname, const char *newname )
{
	DIRENTRY dir;
	char path[512];
	char newpath[512];
	char name[11];
	char new_name[11];
	char *p;
	DWORD ParentDirSectorNum;
	_FILE old_file;

	//
	//check oldname file
	//

	// is path format correct ?
	p = get_valid_format(oldname);
	if(p == NULL)
		return -2;

	//if exist this file ?
	if(fat_locate(oldname, &old_file) == 0xffffffff)
		return -3;

	//separate path into parent and name
	strncpy(name, &p[strlen(p)-11], 11);

	strcpy(path, oldname);
	p = strrchr(path, '\\');
	*p = '\0';


	//
	//check newname file
	//

	if(strchr(newname, '\\') != NULL)
		return -2;

	sprintf(newpath, "%s\\%s", path, newname);

	// is path format correct ?
	p = get_valid_format(newpath);
	if(p == NULL)
		return -2;

	//if exist this file ?
	if(fat_locate(newpath, NULL) != 0xffffffff)
		return -3;

	//separate path into parent and name
	strncpy(new_name, &p[strlen(p)-11], 11);



	//locate parent path
	ParentDirSectorNum = fat_locate(path, NULL);
	if(ParentDirSectorNum == 0xffffffff)
		return -4;

	//fill dir attributes
	memcpy((BYTE *)&dir,(BYTE *)(&old_file.dir), sizeof(DIRENTRY));
	memcpy((BYTE *)dir.deName, new_name, 11);

	//alloc one dir
	if(AllocDir(ParentDirSectorNum, &dir, NULL) != 0)
		return -5;

	//delete old one
	if(DeleteDir(&old_file) != 0)
		return -6;

	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成a人亚洲精| 亚洲综合精品自拍| 国产一区不卡在线| 国产亚洲欧美激情| 国产成人免费在线观看不卡| 国产拍欧美日韩视频二区| 成人综合在线网站| 亚洲免费av观看| 911精品国产一区二区在线| 麻豆精品一二三| 久久九九国产精品| 91丨九色丨尤物| 午夜av一区二区三区| 欧美大片在线观看一区二区| 国产成人在线视频免费播放| 亚洲欧美综合网| 538prom精品视频线放| 国产老妇另类xxxxx| 亚洲日本护士毛茸茸| 欧美精选在线播放| 国产九九视频一区二区三区| 中文字幕一区二区三区av| 欧美日韩午夜在线视频| 国内精品视频666| 亚洲三级在线免费| 欧美一卡二卡在线| 成a人片亚洲日本久久| 视频一区免费在线观看| 国产亚洲人成网站| 欧美性受xxxx| 国产成人亚洲综合a∨婷婷| 亚洲精品日产精品乱码不卡| 精品久久久影院| 在线观看亚洲成人| 国产主播一区二区| 一区二区三区四区在线免费观看| 日韩三级高清在线| 91国模大尺度私拍在线视频| 久久se这里有精品| 亚洲国产日日夜夜| 中文一区一区三区高中清不卡| 日本高清不卡视频| 懂色av一区二区三区免费看| 日韩专区一卡二卡| ...xxx性欧美| 国产亚洲精品久| 制服.丝袜.亚洲.另类.中文| 91免费版在线看| 国产成人在线视频播放| 日本不卡123| 亚洲国产日韩精品| 中文字幕在线观看不卡| 精品国产免费人成电影在线观看四季| 在线亚洲免费视频| 99精品1区2区| 岛国精品在线播放| 国产精品2024| 久久99久久久久| 日韩二区在线观看| 午夜精品久久久久| 一区二区三区日本| 亚洲日穴在线视频| 欧美国产亚洲另类动漫| 久久久久久久久久久电影| 日韩一区二区三区免费看 | 岛国av在线一区| 国产在线国偷精品产拍免费yy| 日韩成人av影视| 午夜不卡av在线| 婷婷国产v国产偷v亚洲高清| 亚洲一区二区免费视频| 18欧美乱大交hd1984| 国产精品久久久久影院老司| 久久精品免费在线观看| 久久久亚洲精品一区二区三区| 精品日韩一区二区三区免费视频| 日韩三级中文字幕| 精品国产自在久精品国产| 精品免费视频一区二区| 精品国产精品网麻豆系列| 精品久久久久久久人人人人传媒| 欧美一区二区三区思思人| 宅男在线国产精品| 日韩精品一区在线观看| 26uuu精品一区二区在线观看| 日韩欧美一级二级| 欧美精品一区二区高清在线观看| 26uuu精品一区二区| 欧美韩国日本不卡| 国产精品久久久久久亚洲伦| 亚洲欧美经典视频| 亚洲国产精品欧美一二99| 日韩制服丝袜av| 久久精品国产一区二区三| 国产一区二区免费看| 粉嫩aⅴ一区二区三区四区五区| 99久久综合99久久综合网站| 在线亚洲精品福利网址导航| 不卡的av网站| 国产色产综合产在线视频| 亚洲国产精品二十页| 亚洲欧美综合网| 午夜电影一区二区三区| 精品在线视频一区| 久久99精品久久久久久国产越南| 午夜av区久久| 国产一区二区三区美女| 91婷婷韩国欧美一区二区| 国产精品情趣视频| 亚洲欧洲日韩综合一区二区| 亚洲一区二区三区四区在线观看| 丁香一区二区三区| 2020国产精品久久精品美国| 性做久久久久久久免费看| 97se亚洲国产综合自在线| 国产欧美日韩亚州综合| 精品在线播放午夜| 日韩欧美一区二区三区在线| 亚洲第一在线综合网站| 色狠狠色噜噜噜综合网| 中文字幕日韩精品一区| 成人毛片视频在线观看| 国产色91在线| 国产精品88av| 国产免费成人在线视频| 国产一区二区0| 久久久国际精品| 国产乱码精品一品二品| 国产亚洲人成网站| 国产精品77777| 久久九九影视网| 国产成人精品亚洲午夜麻豆| 久久久激情视频| 丁香桃色午夜亚洲一区二区三区| 国产亚洲精久久久久久| 国产精品一区二区黑丝| 国产欧美精品在线观看| 成人午夜在线视频| 1000精品久久久久久久久| 99riav久久精品riav| 亚洲麻豆国产自偷在线| 在线观看日韩电影| 视频一区二区三区入口| 日韩一区二区视频| 国产又粗又猛又爽又黄91精品| 久久综合色播五月| 成人伦理片在线| 尤物av一区二区| 欧美精品1区2区| 久久精品久久久精品美女| 久久这里只有精品首页| 国产成人精品1024| 综合精品久久久| 欧美午夜视频网站| 麻豆国产精品视频| 中文字幕av一区二区三区免费看| 99国产精品久久| 亚洲国产人成综合网站| 日韩欧美一卡二卡| 粉嫩一区二区三区在线看| 中文字幕一区在线观看视频| 欧美亚洲综合久久| 久久精品国产精品亚洲综合| 久久九九影视网| 91福利国产成人精品照片| 青娱乐精品在线视频| 国产日韩欧美精品综合| 色婷婷激情综合| 蜜臀va亚洲va欧美va天堂| 国产精品午夜在线| 欧美日韩一二区| 国产精品亚洲一区二区三区在线| 亚洲天天做日日做天天谢日日欢| 欧美日韩免费电影| 国产精品一二三四五| 亚洲影视在线观看| 亚洲国产一区在线观看| 精品久久久久久久久久久久久久久久久| 国产福利一区在线| 亚洲成人av在线电影| 国产欧美日韩综合| 欧美日韩一级视频| 成人免费精品视频| 奇米精品一区二区三区四区| 国产视频一区在线播放| 欧美男人的天堂一二区| 国产 欧美在线| 性做久久久久久免费观看欧美| 国产区在线观看成人精品| 欧美精品在线视频| www.综合网.com| 久久国产福利国产秒拍| 亚洲永久免费av| 中文字幕不卡一区| 亚洲精品一区二区三区福利| 在线国产亚洲欧美| 不卡av在线免费观看| 精品在线一区二区三区| 亚洲成av人片一区二区| 亚洲私人黄色宅男|