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

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

?? sdcarddriver.c

?? SPG290 上SD卡讀取寫入程序源代碼
?? C
字號:
#include "..\SysLib_Basic\Include\Sys_Register.h"
#include "Include/SDCardDriver.h"

// SDCard
	    #define DMA_M2P					0x00000000
		#define DMA_P2M					0x00000001
		#define DMA_AUTO				0x00000000
		#define DMA_REQ					0x00000002
		#define DMA_CON					0x00000000
		#define DMA_FIX					0x00000004
		#define DMA_SINGLE_BUF			0x00000000
		#define DMA_DOUBLE_BUF			0x00000008
		#define DMA_8BIT				0x00000000
		#define DMA_16BIT				0x00000010
		#define DMA_32BIT				0x00000020
		#define DMA_32BIT_BURST			0x00000030
		#define DMA_IRQOFF				0x00000000
		#define DMA_IRQON				0x00000040
		#define DMA_OFF					0x00000000
		#define DMA_ON					0x00000080

U32	rca;
S32 	g_sd_dmabusy;
S32 	cardtype;
S32 	ReadSectors(U32 block, U32 blocknum, U8 *outaddr);
S32	WriteSectors(U32 block, U32 blocknum, U8 *outaddr);

S32 WaitSDStatus(U32 pollbit)
{
	S32 i;
 
	i = 0;
	do {
		i = i + 1;
	} while (((*P_SDC_Status & pollbit) == 0) && (i<600000));
	
	if (i==600000) 
		return 1;

	if ((*P_SDC_Status & (MASK_S_RespIdxError|MASK_S_RespCRCError|MASK_S_DataCRCError|MASK_S_TimeOut)) != 0) 
		return 1;
	return 0;
}	

S32 SDCommand(U32 commandset, U32 arg, U32* outaddr)
{
	// Write Argument First
	*P_SDC_Arg = arg;
	*P_SDC_Command = commandset;
	if (WaitSDStatus(MASK_S_CmdComplete)) 
	{
		*P_SDC_Status = MASK_S_ClrAllBits;
		return 1;
	}
	*outaddr = *P_SDC_Resp;
	*P_SDC_Status = MASK_S_ClrAllBits;
	return 0;
}

S32 SDCommandr2(U32 commandset, U32 arg, U32* outaddr)
{
	S32 i;
	
	// Write Argument First
	*P_SDC_Arg = arg;
	*P_SDC_Command = commandset;
	for (i=0;i<4;i++) 
	{
		WaitSDStatus(MASK_S_RespRegFull);
		*outaddr = *P_SDC_Resp;
		outaddr++;
	}
	if (WaitSDStatus(MASK_S_CmdComplete)) 
		return 1;
		
	*P_SDC_Status = MASK_S_ClrAllBits;
	return 0;
}

extern void invalid_cache(U32 addr);

S32 SDDrv_ReadSector(U32 sector, U32 sector_num, U8 *buf)
{
	S32 i, ret;
	for(i=0; i<sector_num; i++)
	{		
		ret = ReadSectors(sector+i, 1, buf+i*512);
		if(ret == 1)		
			return ret;
	}		
	return 0;
}

S32 ReadSectors(U32 block, U32 blocknum, U8 *outaddr)
{
	U32 response[4];

	U32 *realaddr;
	
	g_sd_dmabusy = 1;

	SDCommand(MASK_CMD7, rca, response);
	// Write Argument First
	*P_SDC_Arg = block<<9;
	*P_SDC_Command = MASK_CMD18;
//	*P_SDC_Command = MASK_CMD17;

	*P_DMA_AHB_SA1A = (U32)outaddr;
	*P_DMA_AHB_EA1A = (U32)outaddr + (blocknum<<9) - 4;
	*P_DMA_APB_SA1 = 0x88180004;

	//*P_DMA_CR1 = DMA_P2M|DMA_REQ|DMA_FIX|DMA_SINGLE_BUF|DMA_32BIT|DMA_IRQOFF|DMA_ON;
	*P_DMA_CR1 = DMA_P2M|DMA_REQ|DMA_FIX|DMA_SINGLE_BUF|DMA_32BIT_BURST|DMA_IRQOFF|DMA_ON;

	// Loop until DMA interrupt is set
	while ((*P_DMA_INT & 0x1) == 0);

	// Clear Interrupt and Disable DMA channel
	*P_DMA_INT = 0x1;
	*P_DMA_CR1 = 0x0000;
	
	realaddr = (U32 *)((U32)outaddr & 0x8fffffff);
	invalid_cache((U32)realaddr);
	
	if (WaitSDStatus(MASK_S_DataComplete)) 
	{
		*P_SDC_Status = MASK_S_ClrAllBits;
		return 1;
	}
	
	// Stop the controller
	*P_SDC_Command = MASK_CMDSTOP;

	// Loop until controller idle
	while(*P_SDC_Status & MASK_S_ControllerBusy);

	*P_SDC_Status = MASK_S_ClrAllBits;
	
	// Stop the card
	SDCommand(MASK_CMD12, 0x00000000, response);

	do {
		SDCommand(MASK_CMD13, rca, response);
	} while (response[0] != 0x0900);
	SDCommand(MASK_CMD7, rca, response);
/* 	realaddr = (U32)outaddr & 0x8fffffff;
	for(i=0; i<128; i++)
	{
		readdata = *(realaddr+i);
		*(outaddr+4*i) = (readdata & 0xff000000) >> 24;
		*(outaddr+4*i+1) = (readdata & 0x00ff0000) >> 16;
		*(outaddr+4*i+2) = (readdata & 0x0000ff00) >> 8;
		*(outaddr+4*i+3) = (readdata & 0x000000ff);
	}  */
	return 0;
}

S32 SDCommandr3(U32 commandset, U32 arg, U32* outaddr)
{
	
	g_sd_dmabusy = 1;
	
	// Write Argument First
	*P_SDC_Arg = arg;
	*P_SDC_Command = commandset;

	while ((*P_SDC_Status & MASK_S_DataBufFull) == 0);
	
	*outaddr = *P_SDC_DataRx;

	while ((*P_SDC_Status & MASK_S_DataBufFull) == 0);
	
	*(outaddr+1) = *P_SDC_DataRx;
	
	if (WaitSDStatus(MASK_S_DataComplete)) 
	{
		*P_SDC_Status = MASK_S_ClrAllBits;
		return 1;
	}

	*P_SDC_Status = MASK_S_ClrAllBits;
	return 0;
}

S32 SDDrv_WriteSector(U32 block, U32 blocknum, U8 *outaddr)
{
	S32 i, ret;
	for(i=0; i<blocknum; i++)	
	{
		ret = WriteSectors(block+i, 1, outaddr+i*512);
		if(ret == 1)
			return ret;
	}		
	return 0;
	
}
S32 WriteSectors(U32 block, U32 blocknum, U8 *outaddr)
{
	U32 	i;
	U32 	response[4];
	SDCommand(MASK_CMD7, rca, response);
	g_sd_dmabusy = 1;	
	// Write Argument First
	*P_SDC_Arg = block<<9;
	*P_SDC_Command = MASK_CMD25;
	
//	*P_SDC_Command = MASK_CMD24;
	*P_DMA_AHB_SA1A = (U32)outaddr;
	*P_DMA_AHB_EA1A = (U32)outaddr + (blocknum<<9) - 4;
	*P_DMA_APB_SA1 = 0x88180000;
	*P_DMA_CR1 = DMA_M2P|DMA_REQ|DMA_FIX|DMA_SINGLE_BUF|DMA_32BIT_BURST|DMA_IRQOFF|DMA_ON;

	// Loop until DMA interrupt is set
	while ((*P_DMA_INT & 0x1) == 0);

	// Clear Interrupt and Disable DMA channel
	*P_DMA_INT = 0x1;
	*P_DMA_CR1 = 0x0000;

	if (WaitSDStatus(MASK_S_DataComplete)) {
		*P_SDC_Status = MASK_S_ClrAllBits;
		return 1;
	}

	*P_SDC_Status = MASK_S_ClrAllBits;

	// Stop the controller
	*P_SDC_Command = MASK_CMDSTOP;

	// Loop until controller idle
	while(*P_SDC_Status & MASK_S_ControllerBusy);

	*P_SDC_Status = MASK_S_ClrAllBits;

	// Stop the card
	SDCommand(MASK_CMD12, 0x00000000, response);

	i = 0;

	do {
		SDCommand(MASK_CMD13, rca, response);
	} while (response[0] != 0x0900);
	
	SDCommand(MASK_CMD7, rca, response);
	return 0;
}

S32 SDDrv_GetMemSize(void)
{
	U32 response[4];
	
	U32 c_size, mult, capacity, blocklen;

	SDCommand(MASK_CMD7, 0, response);

	SDCommandr2(MASK_CMD9, rca, response);

	blocklen = ((response[1] & 0x000F0000)>>16)-8;
	c_size = ((response[1] & 0x000003FF)<<2) + (response[2]>>30);
	mult = ((response[2] & 0x00030000)>>15) + ((response[2] & 0x0000FFFF)>>15);
	
	capacity = (blocklen*(c_size+1))<<(mult + 2);

 	SDCommand(MASK_CMD7, rca, response);
	return capacity;
}


S32 SDDrv_GetSpeed(void)
{
	U32 response[4], tranunit, timevalue, maxspeed;

	U32 SpeedTable[]={
		0, 10, 12, 13, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 70, 80,		
	};
	
	U32 TranTable[]={
		1, 10, 100, 1000,
	};
	
	SDCommand(MASK_CMD7, 0x00000000, response);
	
	SDCommandr2(MASK_CMD9, rca, response);

	timevalue = ((response[0] & 0x00000078)>>3);
	tranunit=response[0] & 0x00000007;
	
	maxspeed = SpeedTable[timevalue] * TranTable[tranunit] / 100;
	
	if ((timevalue == 0) || (tranunit > 3)) 
		return 1;
	
	SDCommand(MASK_CMD7, rca, response);	
	return maxspeed;
}


S32 SDDrv_Initial(void)
{
	S32 	i, loopcnt=0;
	U32 	response[4];
	
	U32 	tranunit, timevalue;
	U32 	maxspeed;
	U32 	SpeedTable[]={
		0, 10, 12, 13, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 70, 80,		
	};
	U32 	TranTable[]={
		1, 10, 100, 1000,
	};

	// Disable All SD Interrupt
	*P_SDC_IntEn = 0x0000;

	// Step 1, Reset SD Controller
	*P_SDC_Control = MASK_C_BlockLen_512bytes|INIT_ClockSpeedFactor1|MASK_C_ENSDBus|MASK_C_DMAMode;

	// Clear All Command
	*P_SDC_Command = MASK_CMDSTOP;
	while (*P_SDC_Status & 0x1);
	
	// Clear All Status
	*P_SDC_Status = MASK_S_ClrAllBits;
	
	loopcnt = 0;

	// Step 2, Start 64 cycles on SD Clk Bus
	*P_SDC_Command = MASK_ClockCycle74;

	if (WaitSDStatus(MASK_S_CmdComplete)) 
		return 1;

	*P_SDC_Status = MASK_S_ClrAllBits;

	// Step 3, Reset Command, Should be no response
	SDCommand(MASK_CMD0, 0x00000000, response);

	//////////////////////////////////////////////////////////////////
	//		SECTION 2.  CARD IDEN									//
	//////////////////////////////////////////////////////////////////

	loopcnt = 0;
	cardtype = SDCARD;

	// Step 4, Run ACMD 41 until card finish power up sequence
	do
	{
		if (cardtype == SDCARD) 
		{
			if (SDCommand(MASK_CMD55, 0x00000000, response)) 
				cardtype = MMCCARD;
		}
			
		if (cardtype == SDCARD) 
			// ACMD 41
			SDCommand(MASK_ACMD41, 0x00200000, response);	// SD Card
		else
			SDCommand(MASK_CMD1, 0x00200000, response);	// MMC Card
	
		// Check until Bit 31 in OCR register is set
		loopcnt = loopcnt + 1;
	} while (((response[0] & 0x80000000) == 0) && loopcnt < 20000);

	if (loopcnt == 20000) 
		return 0;

	// Step 5, CMD 2 Read CID Register
	SDCommandr2(MASK_CMD2, 0x00000000, response);
	
	if (cardtype == SDCARD)
	{
		// Step 6, CMD 3 Read New RCA, SD will generate RCA itself
		SDCommand(MASK_CMD3, 0x00000000, response);	
		rca = response[0];
	} else {
		// Step 6, CMD 3 Set New RCA, MMC need to be assigned a new RCA
		SDCommand(MASK_CMD3, 0xFFFF0000, response);	
		rca = 0xFFFF0000;
	}

	SDCommand(MASK_CMD13, rca, response);

	if (response[0] != 0x0700) 
		return 1;

	//////////////////////////////////////////////////////////////////
	//		SECTION 3.  SET BUSWIDTH AND CLOCK SPEED				//
	//////////////////////////////////////////////////////////////////

	// Step 7, CMD 9 Read CSD Register
	for (i=0;i<4;i++) 
		response[i] = 0;
	SDCommandr2(MASK_CMD9, rca, response);

	timevalue 	= ((response[0] & 0x00000078)>>3);
	tranunit	= response[0] & 0x00000007;
	
	maxspeed 	= SpeedTable[timevalue] * TranTable[tranunit] / 100;
	
	if((timevalue == 0) || (tranunit > 3))
		return 1;

	if (maxspeed > 24)
		//Increase Clock Speed
		*P_SDC_Control = MASK_C_BlockLen_512bytes|MIN_ClockSpeedFactor|MASK_C_ENSDBus|MASK_C_DMAMode;
	else 
		//Increase Clock Speed
		*P_SDC_Control = MASK_C_BlockLen_512bytes|MMC_ClockSpeedFactor|MASK_C_ENSDBus|MASK_C_DMAMode;
	
	SDCommand(MASK_CMD13, rca, response);
	SDCommand(MASK_CMD7, rca, response);

	// Only SD has 4 bits mode
	if (cardtype == SDCARD)
	{
		//Short block size to 8 bytes
	    *P_SDC_Control = MASK_C_BlockLen_8bytes|(*P_SDC_Control&0xffff);
		
		//ACMD 51
		SDCommand(MASK_CMD55, rca, response);
		SDCommandr3(MASK_ACMD51, rca, response);
		
		if (response[0] == 0xa500)
		{
			//Set Bus width to 4 bits
			SDCommand(MASK_CMD55, rca, response);
			SDCommand(MASK_ACMD6, 0x00000002, response);
			*P_SDC_Control = MASK_C_BlockLen_512bytes|MIN_ClockSpeedFactor|MASK_C_ENSDBus|MASK_C_DMAMode|MASK_C_BUSWIDTH_4;
		}
	}
	else
		*P_SDC_Control = MASK_C_BlockLen_512bytes|MIN_ClockSpeedFactor|MASK_C_ENSDBus|MASK_C_DMAMode;

	SDCommand(MASK_CMD13, rca, response);

	*P_SDC_Control = MASK_C_BlockLen_512bytes|(*P_SDC_Control&0xffff);
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91蜜桃视频在线| 久久亚洲精华国产精华液| 欧美一二三在线| 亚洲欧美日韩人成在线播放| 日韩制服丝袜av| 波多野结衣91| wwwwww.欧美系列| 日本特黄久久久高潮| 欧美在线观看一区| 中文一区一区三区高中清不卡| 免费欧美在线视频| 91黄色小视频| 亚洲欧美一区二区在线观看| 国产麻豆视频精品| 精品精品欲导航| 日韩专区欧美专区| 欧美日韩精品系列| 亚洲高清免费在线| 欧美在线视频你懂得| 亚洲日韩欧美一区二区在线| 高清成人免费视频| 国产清纯在线一区二区www| 久久99国产乱子伦精品免费| 在线综合亚洲欧美在线视频| 亚洲在线免费播放| 欧美色图激情小说| 亚洲成人av福利| 欧美三级视频在线| 亚洲国产日韩在线一区模特| 色88888久久久久久影院野外| 亚洲欧洲另类国产综合| 不卡免费追剧大全电视剧网站| 欧美国产精品v| 波多野结衣视频一区| 一区在线观看视频| 91免费版在线看| 亚洲卡通动漫在线| 欧美午夜电影网| 亚洲成人动漫在线观看| 欧美精品123区| 久久国产精品一区二区| 久久网站热最新地址| 国内外成人在线| 国产欧美日本一区二区三区| 成人美女视频在线看| 中文字幕日韩一区| 在线观看中文字幕不卡| 午夜国产不卡在线观看视频| 欧美一区二区在线播放| 国产精品主播直播| 亚洲欧洲三级电影| 欧美色图免费看| 韩日av一区二区| 国产精品素人视频| 欧日韩精品视频| 久久99国产精品麻豆| 国产欧美日本一区视频| 在线国产电影不卡| 精品一区二区在线观看| 国产精品久久久久久久第一福利| 91亚洲国产成人精品一区二三| 亚洲国产精品久久人人爱| 日韩精品资源二区在线| 波多野结衣在线一区| 亚洲国产你懂的| 久久久久久免费网| 欧美影视一区二区三区| 国产一区二区三区综合| 亚洲色图20p| 久久综合九色综合久久久精品综合| 成人的网站免费观看| 亚洲成av人片在线| 亚洲国产精品精华液2区45| 欧美日韩精品欧美日韩精品一综合| 国内外精品视频| 午夜久久电影网| 国产精品久久福利| 精品国产不卡一区二区三区| 色吧成人激情小说| 国产麻豆91精品| 无吗不卡中文字幕| 亚洲欧洲成人自拍| 久久一区二区三区国产精品| 日本道免费精品一区二区三区| 国产一区二区三区香蕉 | 欧美在线一二三四区| 韩国v欧美v亚洲v日本v| 亚洲成人在线免费| 亚洲欧美一区二区久久| 久久伊人中文字幕| 日韩视频永久免费| 色妞www精品视频| 成人污污视频在线观看| 麻豆91在线播放| 日韩精品乱码av一区二区| 亚洲三级在线看| 国产精品免费久久久久| 久久―日本道色综合久久| 欧美一卡2卡三卡4卡5免费| 在线免费观看成人短视频| av网站免费线看精品| 国产露脸91国语对白| 久久精品国产精品青草| 日本中文字幕一区二区有限公司| 亚洲一区二区在线观看视频| 国产精品第一页第二页第三页| www国产亚洲精品久久麻豆| 日韩欧美第一区| 日韩欧美精品三级| 91精品国产美女浴室洗澡无遮挡| 欧美性猛片xxxx免费看久爱| 色综合久久久久久久久| 色婷婷综合久久久中文一区二区| 不卡免费追剧大全电视剧网站| 成人激情文学综合网| 成人精品一区二区三区四区| 成人不卡免费av| 成人app软件下载大全免费| 成人黄色电影在线| 99精品视频一区| 在线免费观看成人短视频| 欧日韩精品视频| 欧美丰满少妇xxxbbb| 欧美一区二视频| 久久久久久夜精品精品免费| 久久久精品2019中文字幕之3| 久久精品一区二区三区四区| 久久精品人人做人人爽97| 国产精品伦理一区二区| 亚洲精品久久久久久国产精华液| 亚洲综合网站在线观看| 日韩av中文字幕一区二区| 蜜桃视频在线观看一区| 国产精品一区二区三区99| 国产很黄免费观看久久| www.亚洲国产| 欧美午夜免费电影| 精品sm捆绑视频| 亚洲同性gay激情无套| 午夜激情久久久| 国产精品自拍毛片| 日本乱人伦aⅴ精品| 日韩欧美国产麻豆| 亚洲欧洲精品一区二区精品久久久 | 国产精品久久777777| 亚洲一二三区在线观看| 老司机午夜精品99久久| 成人国产精品免费观看| 欧美精品色一区二区三区| 久久久精品中文字幕麻豆发布| 亚洲人成在线播放网站岛国| 丝袜诱惑亚洲看片| 不卡视频免费播放| 欧美一区二区播放| 亚洲天堂免费看| 久久99精品国产.久久久久| 99re这里只有精品首页| 欧美一三区三区四区免费在线看| 国产亚洲综合在线| 亚洲国产日韩精品| 99久久综合色| 精品久久一区二区三区| 亚洲综合色丁香婷婷六月图片| 国产主播一区二区三区| 欧美亚洲禁片免费| 国产精品久久久久桃色tv| 琪琪久久久久日韩精品| 色av一区二区| 国产精品久久久久久一区二区三区| 日韩一区精品字幕| 91麻豆免费看片| 国产喷白浆一区二区三区| 欧美aaaaa成人免费观看视频| 99久久国产免费看| 久久久不卡网国产精品二区| 香蕉影视欧美成人| 99麻豆久久久国产精品免费优播| 精品久久久久久久久久久久久久久 | 亚洲视频一区在线观看| 国产福利91精品一区| 91精品国产手机| 午夜婷婷国产麻豆精品| 91麻豆福利精品推荐| 国产精品三级电影| 国产精品一二三区在线| 精品国产百合女同互慰| 美国av一区二区| 欧美一区二区播放| 日韩av网站免费在线| 在线不卡免费av| 亚洲成人777| 欧美色图激情小说| 亚洲成人午夜影院| 在线电影国产精品| 午夜精品aaa| 欧美一二三四区在线| 免费观看一级特黄欧美大片| 5858s免费视频成人| 欧美a一区二区| 欧美电影免费观看高清完整版在线|