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

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

?? mmc.c

?? 這個是我調通的在2410下運行文件系統的程序. 用2410驅動sd卡來實現fat文件系統. 歡迎大家來測試. 用法很簡單, 如下 FILE *fp // 文件指針
?? C
?? 第 1 頁 / 共 2 頁
字號:
//////////////////////////////////////////////////////
//  2410 for MMC & SD
// 
//
//
//  ldqmoon
//  2008-6-10
//

#include "def.h"
#include "2410lib.h"
#include "file_sys_cfg.h"
#include "2410addr.h"

#include "mmc.h"

#define INICLK	400000   //400000
#define NORCLK	5000000  //5000000

#define POL	0
#define INT	1
#define DMA	2

int Wide=0; // 0:1bit, 1:4bit
int MMC=0;  // 0:SD  , 1:MMC

int  Maker_ID;
char Product_Name[7]; 
int  Serial_Num;

volatile int RCA;
volatile unsigned int rd_cnt;
volatile unsigned int wt_cnt;
//#define SD_INFO


#ifdef _ALL_SD_CMDS_
uHILO32 OCR_REG;
#endif
uchar _FF_buff[512];
#ifndef _BytsPerSec_512_
uHILO16 BPB_BytsPerSec;
#endif
uchar BPB_SecPerClus;
uHILO16 BPB_RsvdSecCnt;
uHILO16 BPB_RootEntCnt;
uHILO16 BPB_FATSz16;
uchar BPB_FATType;
uHILO32 BS_VolSerial;
uchar BS_VolLab[12];
uint _FF_PART_ADDR;
U32  _FF_ROOT_ADDR;
#ifdef _DIRECTORIES_SUPPORTED_
ulong _FF_DIR_ADDR;
#endif
uint _FF_FAT1_ADDR;
U32 _FF_FAT2_ADDR;
uint FirstDataSector;
uchar _FF_error;
ulong _FF_buff_addr;
uint clus_0_addr, _FF_n_temp;
uint c_counter;
U8 _FF_FULL_PATH[_FF_PATH_LENGTH];

U32 DataClusTot;



// 準備系統fat
uchar initialize_media(void)
{
	//uchar data_temp;
	uchar n;
	ulong _FF_RootDirSectors;
	uHILO16 PT_SecStart;
	uchar BPB_NumFATs;
	uHILO32 BPB_TotSec;


  #ifndef _BytsPerSec_512_
	BPB_BytsPerSec.ival = 512;	// Initialize sector size to 512 (all SD cards have a 512 sector size)
  #endif
    _FF_n_temp = 0;

         
    if(!Mmc_Init())
    {
        return 0;
    }
    

	if (_FF_read(0x0, _FF_buff)==0)
	{
	  #ifdef _DEBUG_ON_
		printf(_FF_RErr_str);
	  #endif
		//_FF_error = INIT_ERR;
		return (0);
	}

	if (!((_FF_buff[510]==0x55)&&(_FF_buff[511]==0xAA)))
	{
	  #ifdef _DEBUG_ON_
		printf(_FF_InvParTbl_str);
	  #endif
		//_FF_error = INV_PARTTABLE_ERR;
		Uart_Printf("INV_PARTTABLE_ERR; wrong\n");
		return (0);
	}
	if (((_FF_buff[0]==0xEB)&&(_FF_buff[2]==0x90))||(_FF_buff[0]==0xE9))
		PT_SecStart.ival = 0;
	else if (_FF_buff[0x1BF])
	{
		PT_SecStart.cval.HI = _FF_buff[0x1C7];
		PT_SecStart.cval.LO = _FF_buff[0x1C6];
	}
	else if (_FF_buff[0x1CF])
	{
		PT_SecStart.cval.HI = _FF_buff[0x1D7];
		PT_SecStart.cval.LO = _FF_buff[0x1D6];
	}
	else if (_FF_buff[0x1DF])
	{
		PT_SecStart.cval.HI = _FF_buff[0x1E7];
		PT_SecStart.cval.LO = _FF_buff[0x1E6];
	}
	else if (_FF_buff[0x1EF])
	{
		PT_SecStart.cval.HI = _FF_buff[0x1F7];
		PT_SecStart.cval.LO = _FF_buff[0x1F6];
	}
	else
	{
	  #ifdef _DEBUG_ON_
		printf(_FF_InvParTbl_str);
	  #endif
		//_FF_error = INV_PARTENTRY_ERR;
		Uart_Printf("INV_PARTTABLE_ERR; wrong 2\n");
		return (0);
	}

 	_FF_PART_ADDR = (ulong) PT_SecStart.ival;
	if (PT_SecStart.ival)
	{
		if (_FF_read(_FF_PART_ADDR, _FF_buff)==0)
		{
		  #ifdef _DEBUG_ON_
			printf(_FF_RErr_str);
		  #endif
			//_FF_error = INIT_ERR;
			Uart_Printf("INIT_ERR wrong   22 \n");
			return (0);
		}
	}

  #ifdef _DEBUG_ON_
	printf(_FF_BSec_str, _FF_buff[0],_FF_buff[1],_FF_buff[2],_FF_buff[510],_FF_buff[511]);
  #endif

    // Get the number of Bytes per Sector (should be 512)
  #ifdef _BytsPerSec_512_
	if((_FF_buff[0xC] != 0x2) || (_FF_buff[0xB]))
		return (0);
  #else
	BPB_BytsPerSec.cval.LO = _FF_buff[0xB];
	BPB_BytsPerSec.cval.HI = _FF_buff[0xC];
  #endif
    // Get the number of Sectors per Cluster
    BPB_SecPerClus = _FF_buff[0xD];
    // Get the number of Reserved Sectors
	BPB_RsvdSecCnt.cval.LO = _FF_buff[0xE];
    BPB_RsvdSecCnt.cval.HI = _FF_buff[0xF];
    // Get the number of FATs (should be 2)
	BPB_NumFATs = _FF_buff[0x10];
	// Get the number of Root Directory entries (should be 512)
	BPB_RootEntCnt.cval.LO = _FF_buff[0x11];
	BPB_RootEntCnt.cval.HI = _FF_buff[0x12];
	// Get the FATSz16 value
	BPB_FATSz16.cval.LO = _FF_buff[0x16];
	BPB_FATSz16.cval.HI = _FF_buff[0x17];
	// Get the number of Total Sectors available
	BPB_TotSec.ival.HI = 0;
	BPB_TotSec.cval.LO = _FF_buff[0x13];
	BPB_TotSec.cval.ML = _FF_buff[0x14];
	if (BPB_TotSec.lval==0)
	{	// If the read value is 0, stored in a different location, read from other location
		BPB_TotSec.cval.LO = _FF_buff[0x20];
		BPB_TotSec.cval.ML = _FF_buff[0x21];
		BPB_TotSec.cval.MH = _FF_buff[0x22];
		BPB_TotSec.cval.HI = _FF_buff[0x23];
	}
	// Get the volume's Serial number
	BS_VolSerial.cval.LO = _FF_buff[0x27];
	BS_VolSerial.cval.ML = _FF_buff[0x28];
	BS_VolSerial.cval.MH = _FF_buff[0x29];
	BS_VolSerial.cval.HI = _FF_buff[0x2A];
	// Store the Volume's label
	for (n=0; n<11; n++)
		BS_VolLab[n] = _FF_buff[0x2B+n];
	BS_VolLab[11] = 0;		// Terminate the string
	// Calculate the Primary FAT table's Address
	_FF_FAT1_ADDR = _FF_PART_ADDR + BPB_RsvdSecCnt.ival;
	// Calculate the Secondary FAT table's Address
	_FF_FAT2_ADDR = _FF_FAT1_ADDR + BPB_FATSz16.ival;
	// Calculate the Address of the Root Directory
	_FF_ROOT_ADDR = ((ulong) BPB_NumFATs * (ulong) BPB_FATSz16.ival) + (ulong) BPB_RsvdSecCnt.ival;
	_FF_ROOT_ADDR += _FF_PART_ADDR;

	// Calculate the number of Total data Clusters
  #ifdef _BytsPerSec_512_
	_FF_RootDirSectors = (((ulong) BPB_RootEntCnt.ival << 5) + 511) >> 9;
  #else
	_FF_RootDirSectors = (((ulong) BPB_RootEntCnt.ival << 5) + BPB_BytsPerSec.ival - 1) / BPB_BytsPerSec.ival;
  #endif
	FirstDataSector = (BPB_NumFATs * BPB_FATSz16.ival) + BPB_RsvdSecCnt.ival + _FF_RootDirSectors;
	DataClusTot = (BPB_TotSec.lval - FirstDataSector) / BPB_SecPerClus;
	clus_0_addr = 0;		// Reset Empty Cluster table location
	c_counter = 1;
	_FF_buff_addr = 0;
#ifdef SD_INFO	
Uart_Printf("DataClusTot=%d\n", DataClusTot);
#endif
	if (DataClusTot < 4085)				// FAT12
		BPB_FATType = 0x32;
	else if (DataClusTot < 65525)		// FAT16
		BPB_FATType = 0x36;
	else
	{
		BPB_FATType = 0;
		//_FF_error = FAT_ERR;
		Uart_Printf("FAT_ERR wrong\n");
		return (0);
	}
  #ifdef _DIRECTORIES_SUPPORTED_
	_FF_DIR_ADDR = _FF_ROOT_ADDR;		// Set current directory to root address
  #endif
	_FF_FULL_PATH[0] = 0x5C;	// a '\'
	_FF_FULL_PATH[1] = 0;

  #ifdef _DEBUG_ON_
   #ifdef _BytsPerSec_512_
	printf(_FF_BS_PA_str, (_FF_PART_ADDR<<9));
	printf(_FF_BPB_BPS_str, 0x200);
   #else
	printf(_FF_BS_PA_str, (_FF_PART_ADDR*BPB_BytsPerSec.ival));
	printf(_FF_BPB_BPS_str, BPB_BytsPerSec.ival);
   #endif
	printf(_FF_BPB_SPC_str, BPB_SecPerClus);
	printf(_FF_BPB_RSC_str, BPB_RsvdSecCnt.ival);
	printf(_FF_BPB_NFAT_str, BPB_NumFATs);
	printf(_FF_BPB_REC_str, BPB_RootEntCnt.ival);
	printf(_FF_BPB_Fz16_str, BPB_FATSz16.ival);
	printf(_FF_BPB_TS16_str, BPB_TotSec.lval);
	printf(_FF_BPB_FT_str);
  #endif
	if ((BPB_FATType != 0x32) && (BPB_FATType != 0x36))
	{
  #ifdef _DEBUG_ON_
		printf(_FF_ERR_str);
  #endif
		return(0);
	}
  #ifdef _DEBUG_ON_
	else
		printf(_FF_1C_str, BPB_FATType);
	printf(_FF_CCnt_str, DataClusTot);
   #ifdef _BytsPerSec_512_
	printf(_FF_RAddr_str, _FF_ROOT_ADDR<<9);
	printf(_FF_F2Addr_str, _FF_FAT2_ADDR<<9);
   #else
	printf(_FF_RAddr_str, _FF_ROOT_ADDR*BPB_BytsPerSec.ival);
	printf(_FF_F2Addr_str, _FF_FAT2_ADDR*BPB_BytsPerSec.ival);
   #endif
	printf(_FF_RDSec_str, _FF_RootDirSectors);
	printf(_FF_FDSec_str, FirstDataSector);
  #endif

	return (1);
}



// 初始化 mmc
S8 Mmc_Init(void)
{
//-- SD controller & card initialize 
    int i;

    RCA=0;
    MMC=0;

    rGPEUP  = 0xf83f;     // The pull up
    rGPECON = 0xaaaaaaaa;
    
    /* Important notice for MMC test condition */
    /* Cmd & Data lines must be enabled pull up resister */

    rSDIPRE=PCLK/(2*INICLK)-1;	// 400KHz
    rSDICON=(1<<4)|(1<<1)|1;	// Type B, FIFO reset, clk enable
    rSDIBSIZE=0x200;		// 512byte(128word)
    rSDIDTIMER=0xffff;		// Set timeout count

    for(i=0;i<0x1000;i++);  // Wait 74SDCLK for MMC card

    //Uart_Printf("rSDIRSP0=0x%x\n",rSDIRSP0);
    CMD0();
  #ifdef SD_INFO
    Uart_Printf("\nIn idle\n");
  #endif

    //-- Check MMC card OCR
    if(Chk_MMC_OCR()) 
    {
	Uart_Printf("\nIn MMC ready\n");
	MMC=1;
	goto RECMD2;
    }

    //Uart_Printf("MMC check end!!\n");
    //-- Check SD card OCR
    if(Chk_SD_OCR()) 
    {
       #ifdef SD_INFO
        Uart_Printf("\nIn SD ready\n");
       #endif
    }
    else
    {
       #ifdef SD_INFO
	    Uart_Printf("\nInitialize fail\nNo Card assertion\n");
	   #endif
        return 0;
    }

RECMD2:
    //-- Check attaced cards, it makes card identification state
    rSDICARG=0x0;   // CMD2(stuff bit)
    rSDICCON=(0x1<<10)|(0x1<<9)|(0x1<<8)|0x42; //lng_resp, wait_resp, start, CMD2

    //-- Check end of CMD2
    if(!Chk_CMDend(2, 1)) 
	goto RECMD2;
    //rSDICSTA=0xa00;	// Clear cmd_end(with rsp)

    #ifdef SD_INFO
    Uart_Printf("\nEnd id\n");
    #endif

RECMD3:
    //--Send RCA
    rSDICARG=MMC<<16;	    // CMD3(MMC:Set RCA, SD:Ask RCA-->SBZ)
    rSDICCON=(0x1<<9)|(0x1<<8)|0x43;	// sht_resp, wait_resp, start, CMD3

    //-- Check end of CMD3
    if(!Chk_CMDend(3, 1)) 
	goto RECMD3;
    //rSDICSTA=0xa00;	// Clear cmd_end(with rsp)

    //--Publish RCA
    if(MMC) 
	RCA=1;
    else 
	RCA=( rSDIRSP0 & 0xffff0000 )>>16;
#ifdef SD_INFO
    Uart_Printf("RCA=0x%x\n",RCA);
#endif

    //--State(stand-by) check
    if( rSDIRSP0 & 0x1e00!=0x600 )  // CURRENT_STATE check
	goto RECMD3;
    #ifdef SD_INFO
    Uart_Printf("\nIn stand-by\n");
    #endif
    
  //  rSDIPRE=PCLK/(2*NORCLK)-1;	// Normal clock=25MHz
rSDIPRE=PCLK/(3*NORCLK)-1;
    Card_sel_desel(1);	// Select

    if(!MMC)
	Set_4bit_bus();
    else
	Set_1bit_bus();

    return 1;
    
}


S8 Mmc_Read_Sector(U32 addr,U8 *Buffer)
{
    int status;
    int i;
    U32 Rx_buffer[128];	
    rd_cnt=0;    
#ifdef SD_INFO
Uart_Printf("addr is 0x%x", addr);
#endif

    rSDICON |= rSDICON|(1<<1);	// FIFO reset

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩理论片网站| 国产欧美精品一区| 91视频免费看| 日韩精品成人一区二区三区| 一区二区免费在线播放| 亚洲精品视频自拍| 国产精品电影一区二区| 国产欧美一区二区在线观看| 久久综合成人精品亚洲另类欧美| 欧美一区二区女人| 欧美一级精品大片| 日韩午夜激情视频| 日韩免费观看高清完整版在线观看| 欧美日本一道本| 欧美日韩久久一区二区| 3751色影院一区二区三区| 51精品秘密在线观看| 精品动漫一区二区三区在线观看| 欧美精品一区二区蜜臀亚洲| 久久久久久一二三区| 国产亚洲欧美一级| 国产精品亲子伦对白| 国产精品久久久久一区二区三区 | 国内精品国产成人| 狠狠色狠狠色综合系列| 成人性生交大片| 91网站在线观看视频| 在线观看免费亚洲| 欧美日本在线一区| 久久久九九九九| 亚洲精品视频一区二区| 亚洲成人综合在线| 美女国产一区二区三区| 激情av综合网| 91豆麻精品91久久久久久| 这里只有精品视频在线观看| 精品女同一区二区| 亚洲欧美在线观看| 日韩国产高清影视| 成人美女视频在线观看18| 在线一区二区三区四区| 日韩女优制服丝袜电影| 国产精品久线观看视频| 亚洲成av人片一区二区三区 | 国产在线精品一区二区夜色 | 日本高清无吗v一区| 日韩欧美一区在线| 亚洲三级在线看| 精品一区二区在线播放| 91黄视频在线观看| 欧美v日韩v国产v| 亚洲精品视频自拍| 国产在线不卡一卡二卡三卡四卡| 91丨九色丨尤物| 精品黑人一区二区三区久久| 亚洲视频免费观看| 国内外成人在线| 91精品免费在线观看| 亚洲免费在线看| 国产成人免费av在线| 日韩精品一区二区三区三区免费 | 一区二区三区91| 国产精品一区二区三区四区| 欧美日韩dvd在线观看| 自拍偷拍国产精品| 国产精品一区专区| 日韩视频在线你懂得| 亚洲国产精品久久艾草纯爱| 懂色av一区二区三区免费观看 | 国产情人综合久久777777| 青椒成人免费视频| 在线观看国产日韩| 亚洲美女少妇撒尿| 91香蕉视频在线| 亚洲人快播电影网| 91免费版pro下载短视频| 欧美激情一区二区三区不卡 | 日韩一区有码在线| 岛国一区二区三区| 欧美国产日韩精品免费观看| 国产在线精品一区二区三区不卡| 欧美精品一区二区三区很污很色的| 日本麻豆一区二区三区视频| 欧美日本一区二区三区| 日本系列欧美系列| 日韩视频在线观看一区二区| 久久99热99| 国产三级精品视频| 成人精品一区二区三区四区| 国产精品无人区| 成人三级伦理片| 欧美国产日韩在线观看| 韩国毛片一区二区三区| 日韩欧美www| 伊人一区二区三区| 51久久夜色精品国产麻豆| 亚洲第一电影网| 欧美日韩亚洲综合一区二区三区| 亚洲精品免费在线| 91精品福利在线| 亚洲一区二区视频在线| 日韩视频国产视频| 久久99国产精品免费网站| 日韩午夜在线观看| 久久99国产精品免费| 久久老女人爱爱| 国产a精品视频| 精品国产乱码久久久久久免费| 国产美女精品一区二区三区| 久久久国产一区二区三区四区小说| 精品在线视频一区| 久久久99久久精品欧美| 国产91精品一区二区麻豆网站 | 欧美最猛黑人xxxxx猛交| 日韩毛片视频在线看| 91色在线porny| 亚洲国产精品一区二区尤物区| 色噜噜狠狠色综合中国| 婷婷中文字幕一区三区| 亚洲精品一区二区三区在线观看| 蜜臂av日日欢夜夜爽一区| 精品国产制服丝袜高跟| 成人免费观看视频| 亚洲国产成人porn| 欧美一区二区三区性视频| 国模无码大尺度一区二区三区| 精品久久久久99| 欧美性大战久久久久久久 | 韩国三级在线一区| 国产精品天干天干在观线| 91蜜桃视频在线| 亚洲妇女屁股眼交7| 国产欧美日韩在线| 欧美曰成人黄网| 麻豆成人在线观看| ...xxx性欧美| 欧美一级黄色片| 色综合久久久久久久久久久| 蜜桃视频第一区免费观看| 国产精品不卡在线观看| 7777精品伊人久久久大香线蕉经典版下载 | 国内精品嫩模私拍在线| 亚洲丝袜自拍清纯另类| 欧美一区二区视频在线观看2022 | 精品亚洲成a人| 亚洲视频一二三| 久久久99精品免费观看不卡| 欧美四级电影在线观看| 国产成人免费高清| 一区二区三区产品免费精品久久75| 中文一区二区完整视频在线观看| 欧美男男青年gay1069videost| 大胆欧美人体老妇| 狠狠色丁香久久婷婷综合丁香| 一区二区日韩电影| 中文字幕一区二区三区视频| 欧美zozozo| 欧美日韩精品一区二区天天拍小说| 91天堂素人约啪| 成人av网站在线| 国产自产v一区二区三区c| 日韩国产欧美视频| 五月天激情综合网| 亚洲国产精品精华液网站| 午夜精彩视频在线观看不卡| 亚洲欧美在线另类| 国产欧美日韩卡一| 2023国产精品视频| 精品国产一区二区国模嫣然| 91精品国产91久久久久久最新毛片| 99综合电影在线视频| 色婷婷精品大在线视频| 北条麻妃一区二区三区| 成人黄色免费短视频| 大白屁股一区二区视频| 国产在线观看一区二区| 国产毛片精品国产一区二区三区| 免费人成黄页网站在线一区二区| 亚洲综合丝袜美腿| 亚洲电影一级黄| 亚洲电影视频在线| 日韩国产一二三区| 久久精品国产网站| 国产综合久久久久久鬼色| 韩国v欧美v日本v亚洲v| 国产福利一区二区| 国产91富婆露脸刺激对白| 成人在线视频一区二区| 大美女一区二区三区| 国产伦精品一区二区三区在线观看| 成人app软件下载大全免费| gogo大胆日本视频一区| 国产成人综合在线| 不卡影院免费观看| 在线影视一区二区三区| 日韩免费视频线观看| 国产日韩精品一区二区浪潮av| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲va欧美va国产va天堂影院| 蜜桃av噜噜一区二区三区小说|