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

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

?? nand.c

?? 友善ADS.rar
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
 support 512/page NAND Flash only
*/
#include <string.h>

#include "def.h"
#include "2440addr.h"
#include "2440lib.h"
#include "2440slib.h"
#include "Nand.h"

//suppport boot params
#define	GLOBAL_PARAMS
#include "bootpara.h"

#define	EnNandFlash()	(rNFCONT |= 1)
#define	DsNandFlash()	(rNFCONT &= ~1)
#define	NFChipEn()		(rNFCONT &= ~(1<<1))
#define	NFChipDs()		(rNFCONT |= (1<<1))
#define	InitEcc()		(rNFCONT |= (1<<4))
#define	MEccUnlock()	(rNFCONT &= ~(1<<5))
#define	MEccLock()		(rNFCONT |= (1<<5))
#define	SEccUnlock()	(rNFCONT &= ~(1<<6))
#define	SEccLock()		(rNFCONT |= (1<<6))

#define	WrNFDat8(dat)	(rNFDATA8 = (dat))
#define	WrNFDat32(dat)	(rNFDATA = (dat))
#define	RdNFDat8()		(rNFDATA8)	//byte access
#define	RdNFDat32()		(rNFDATA)	//word access

#define	WrNFCmd(cmd)	(rNFCMD = (cmd))
#define	WrNFAddr(addr)	(rNFADDR = (addr))
#define	WrNFDat(dat)	WrNFDat8(dat)
#define	RdNFDat()		RdNFDat8()	//for 8 bit nand flash, use byte access

#define	RdNFMEcc()		(rNFMECC0)	//for 8 bit nand flash, only use NFMECC0
#define	RdNFSEcc()		(rNFSECC)	//for 8 bit nand flash, only use low 16 bits

#define	RdNFStat()		(rNFSTAT)
#define	NFIsBusy()		(!(rNFSTAT&1))
#define	NFIsReady()		(rNFSTAT&1)

//#define	WIAT_BUSY_HARD	1
//#define	ER_BAD_BLK_TEST
//#define	WR_BAD_BLK_TEST

#define	READCMD0	0
#define	READCMD1	1
#define	READCMD2	0x50
#define	ERASECMD0	0x60
#define	ERASECMD1	0xd0
#define	PROGCMD0	0x80
#define	PROGCMD1	0x10
#define	QUERYCMD	0x70
#define	RdIDCMD		0x90

static U16 NandAddr;

// HCLK=100Mhz
#define TACLS		1//7	// 1-clk(0ns) 
#define TWRPH0		4//7	// 3-clk(25ns)
#define TWRPH1		0//7	// 1-clk(10ns)  //TACLS+TWRPH0+TWRPH1>=50ns

static void InitNandCfg(void)
{
	// for S3C2440

	rNFCONF = (TACLS<<12)|(TWRPH0<<8)|(TWRPH1<<4)|(0<<0);	
	// TACLS		[14:12]	CLE&ALE duration = HCLK*TACLS.
	// TWRPH0		[10:8]	TWRPH0 duration = HCLK*(TWRPH0+1)
	// TWRPH1		[6:4]	TWRPH1 duration = HCLK*(TWRPH1+1)
	// AdvFlash(R)	[3]		Advanced NAND, 0:256/512, 1:1024/2048
	// PageSize(R)	[2]		NAND memory page size
	//						when [3]==0, 0:256, 1:512 bytes/page.
	//						when [3]==1, 0:1024, 1:2048 bytes/page.
	// AddrCycle(R)	[1]		NAND flash addr size
	//						when [3]==0, 0:3-addr, 1:4-addr.
	//						when [3]==1, 0:4-addr, 1:5-addr.
	// BusWidth(R/W) [0]	NAND bus width. 0:8-bit, 1:16-bit.
	
	rNFCONT = (0<<13)|(0<<12)|(0<<10)|(0<<9)|(0<<8)|(1<<6)|(1<<5)|(1<<4)|(1<<1)|(1<<0);
	// Lock-tight	[13]	0:Disable lock, 1:Enable lock.
	// Soft Lock	[12]	0:Disable lock, 1:Enable lock.
	// EnablillegalAcINT[10]	Illegal access interupt control. 0:Disable, 1:Enable
	// EnbRnBINT	[9]		RnB interrupt. 0:Disable, 1:Enable
	// RnB_TrandMode[8]		RnB transition detection config. 0:Low to High, 1:High to Low
	// SpareECCLock	[6]		0:Unlock, 1:Lock
	// MainECCLock	[5]		0:Unlock, 1:Lock
	// InitECC(W)	[4]		1:Init ECC decoder/encoder.
	// Reg_nCE		[1]		0:nFCE=0, 1:nFCE=1.
	// NANDC Enable	[0]		operating mode. 0:Disable, 1:Enable.

//	rNFSTAT = 0;
    
//    Nand_Reset();
}

#ifdef	WIAT_BUSY_HARD
#define	WaitNFBusy()	while(NFIsBusy())
#else
static U32 WaitNFBusy(void)	// R/B 未接好?
{
	U8 stat;
	
	WrNFCmd(QUERYCMD);
	do {
		stat = RdNFDat();
		//Uart_Printf("%x\n", stat);
	}while(!(stat&0x40));
	WrNFCmd(READCMD0);
	return stat&1;
}
#endif

static U32 ReadChipId(void)
{
	U32 id;
	
	NFChipEn();	
	WrNFCmd(RdIDCMD);
	WrNFAddr(0);
	while(NFIsBusy());	
	id  = RdNFDat()<<8;
	id |= RdNFDat();		
	NFChipDs();		
	
	return id;
}

static U16 ReadStatus(void)
{
	U16 stat;
	
	NFChipEn();	
	WrNFCmd(QUERYCMD);		
	stat = RdNFDat();	
	NFChipDs();
	
	return stat;
}

static U32 EraseBlock(U32 addr)
{
	U8 stat;

	addr &= ~0x1f;
		
	NFChipEn();	
	WrNFCmd(ERASECMD0);		
	WrNFAddr(addr);
	WrNFAddr(addr>>8);
	if(NandAddr)
		WrNFAddr(addr>>16);
	WrNFCmd(ERASECMD1);		
	stat = WaitNFBusy();
	NFChipDs();
	
#ifdef	ER_BAD_BLK_TEST
	if(!((addr+0xe0)&0xff)) stat = 1;	//just for test bad block
#endif
	
	Uart_Printf("Erase block 0x%x %s\n", addr, stat?"fail":"ok");
		
	return stat;
}

//addr = page address
static void ReadPage(U32 addr, U8 *buf)
{
	U16 i;
	
	NFChipEn();
	WrNFCmd(READCMD0);
	WrNFAddr(0);
	WrNFAddr(addr);
	WrNFAddr(addr>>8);
	if(NandAddr)
		WrNFAddr(addr>>16);
	InitEcc();
	WaitNFBusy();
	for(i=0; i<512; i++)
		buf[i] = RdNFDat();
	NFChipDs();
}

static U32 WritePage(U32 addr, U8 *buf)
{
	U32 i, mecc;
	U8 stat, tmp[7];
	
	
	NFChipEn();
	WrNFCmd(PROGCMD0);
	WrNFAddr(0);
	WrNFAddr(addr);
	WrNFAddr(addr>>8);
	if(NandAddr)
		WrNFAddr(addr>>16);
	InitEcc();	//reset mecc and secc
	MEccUnlock();
	for(i=0; i<512; i++)
		WrNFDat(buf[i]);
	MEccLock();
	
	mecc = RdNFMEcc();
		
	tmp[0] = mecc&0xff;
    tmp[1] = (mecc>>8)&0xff;
    tmp[2] = (mecc>>16)&0xff;
    tmp[3] = (mecc>>24)&0xff;
    tmp[5] = 0xff;	//mark good block
    
    SEccUnlock();
	WrNFDat(tmp[0]);
	WrNFDat(tmp[1]);
	WrNFDat(tmp[2]);
	WrNFDat(tmp[3]);
	SEccLock();
	WrNFDat(tmp[4]);
	WrNFDat(tmp[5]);
    	
	WrNFCmd(PROGCMD1);
	stat = WaitNFBusy();
	NFChipDs();
	
#ifdef	WR_BAD_BLK_TEST
	if((addr&0xff)==0x17) stat = 1;	//just for test bad block
#endif
		
	if(stat)
		Uart_Printf("Write nand flash 0x%x fail\n", addr);
	else {	
		U8 RdDat[512];
		
		ReadPage(addr, RdDat);		
		for(i=0; i<512; i++)
			if(RdDat[i]!=buf[i]) {
				Uart_Printf("Check data at page 0x%x, offset 0x%x fail\n", addr, i);
				stat = 1;
				break;
			}
	}
		
	return stat;	
}

static void MarkBadBlk(U32 addr)
{
	addr &= ~0x1f;
	
	NFChipEn();
	
	WrNFCmd(READCMD2);	//point to area c
	
	WrNFCmd(PROGCMD0);
	WrNFAddr(4);		//mark offset 4,5,6,7
	WrNFAddr(addr);
	WrNFAddr(addr>>8);
	if(NandAddr)
		WrNFAddr(addr>>16);
	WrNFDat(0);			//mark with 0
	WrNFDat(0);
	WrNFDat(0);			//mark with 0
	WrNFDat(0);
	WrNFCmd(PROGCMD1);
	WaitNFBusy();		//needn't check return status
	
	WrNFCmd(READCMD0);	//point to area a
		
	NFChipDs();
}

static int CheckBadBlk(U32 addr)
{
	U8 dat;
	
	addr &= ~0x1f;
	
	NFChipEn();
	
	WrNFCmd(READCMD2);	//point to area c
	WrNFAddr(5);		//mark offset 4,5,6,7
	WrNFAddr(addr);
	WrNFAddr(addr>>8);
	if(NandAddr)
		WrNFAddr(addr>>16);
	WaitNFBusy();
	dat = RdNFDat();
	
	WrNFCmd(READCMD0);	//point to area a
	
	NFChipDs();

	return (dat!=0xff);
}

/************************************************************/
struct Partition{
	U32 offset;
	U32 size;
	char *name;
};

static struct Partition NandPart[] = {
	{0, 		 0x00030000, "boot"},		//256K
	{0x00030000, 0x001d0000, "kernel"},
	{0x00200000, 0x02000000, "rootfs"},		//30M
	{0x02000000, 0x02000000, "ext-fs1"},	//32M
	{0,			 0         , 0}
};
/*
static void TestFunc(void)
{
	U32 i;
	U8 buf[512];
	
	if(EraseBlock(0x180))
		return;
	
	for(i=0; i<512; i++)
		buf[i] = i;
		
	WritePage(0x180, buf);	
	for(i=0; i<512; i++)
		buf[i] = 0;
	ReadPage(0x180, buf);
	
	for(i=0; i<512; i++)
		Uart_Printf("%4x", buf[i]);
}
*/
static U32 StartPage, BlockCnt;
extern U32 downloadAddress; 
extern U32 downloadFileSize;


static int NandSelPart(char *info)
{
	U16 i, max_sel;
	struct Partition *ptr = NandPart;
	
	Uart_Printf("Please select which region to %s : Esc to abort\n", info);
	
	for(i=0; ptr->size!=0; i++, ptr++)
		Uart_Printf("%d : offset 0x%-8x, size 0x%-8x [%s]\n", i, ptr->offset, ptr->size, ptr->name);
		
	max_sel = i;
	
	while(1) {
		i = Uart_Getch();
		if(i==0x1b)
			return -1;
		if((i>='0')&&(i<(max_sel+'0'))) {
			i -= '0';
			StartPage = NandPart[i].offset>>9;
			BlockCnt  = NandPart[i].size>>14;
			return i;
		}
	}	
}

static void WrFileToNF(void)
{
	int nf_part, i ,size, skip_blks;
	U32 ram_addr;
	
	nf_part = NandSelPart("write");
	if(nf_part<0)
		return;	
	
	if(downloadFileSize>NandPart[nf_part].size) {
		Uart_Printf("Download file size is more large than selected partition size!!!\n");
//		return;
	}
	
	Uart_Printf("Now write nand flash page 0x%x from ram address 0x%x, filesize = %d\n", StartPage, downloadAddress, downloadFileSize);
	Uart_Printf("Are you sure? [y/n]\n");
	while(1) {
		char c = Uart_Getch();
		if((c=='y')||(c=='Y'))
			break;
		if((c=='n')||(c=='N'))			
			return;
	}
	
	skip_blks = 0;
	ram_addr = downloadAddress;
	size = downloadFileSize;
	for(i=0; size>0; )	{	
		if(!(i&0x1f)) {
			if(EraseBlock(i+StartPage)) {
				NandPart[nf_part].size -= 32<<9;	//partition available size - 1 block size
				if(downloadFileSize>NandPart[nf_part].size) {
					Uart_Printf("Program nand flash fail\n");
					return;
				}
				MarkBadBlk(i+StartPage);
				skip_blks++;				
				i += 32;				
				continue;
			}
		}
		if(WritePage(i+StartPage, (U8 *)ram_addr)) {
			ram_addr -= (i&0x1f)<<9;
			size += (i&0x1f)<<9;
			i &= ~0x1f;
			NandPart[nf_part].size -= 32<<9;	//partition available size - 1 block size
			if(downloadFileSize>NandPart[nf_part].size) {
				Uart_Printf("Program nand flash fail\n");
				return;
			}			
			MarkBadBlk(i+StartPage);
			skip_blks++;			
			i += 32;			
			continue;
		}
		ram_addr += 512;
		size -= 512;
		i++;
	}

	Uart_Printf("Program nand flash partition success\n");
	if(skip_blks)
		Uart_Printf("Skiped %d bad block(s)\n", skip_blks);
}

#define LINUX_PAGE_SHIFT	12
#define LINUX_PAGE_SIZE		(1<<LINUX_PAGE_SHIFT)
#define COMMAND_LINE_SIZE 	1024

struct param_struct {
    union {
	struct {
	    unsigned long page_size;			/*  0 */
	    unsigned long nr_pages;				/*  4 */
	    unsigned long ramdisk_size;			/*  8 */
	    unsigned long flags;				/* 12 */
#define FLAG_READONLY	1
#define FLAG_RDLOAD		4
#define FLAG_RDPROMPT	8
	    unsigned long rootdev;				/* 16 */
	    unsigned long video_num_cols;		/* 20 */
	    unsigned long video_num_rows;		/* 24 */
	    unsigned long video_x;				/* 28 */
	    unsigned long video_y;				/* 32 */
	    unsigned long memc_control_reg;		/* 36 */
	    unsigned char sounddefault;			/* 40 */
	    unsigned char adfsdrives;			/* 41 */
	    unsigned char bytes_per_char_h;		/* 42 */
	    unsigned char bytes_per_char_v;		/* 43 */
	    unsigned long pages_in_bank[4];		/* 44 */
	    unsigned long pages_in_vram;		/* 60 */
	    unsigned long initrd_start;			/* 64 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久亚洲一级片| 亚洲国产日韩a在线播放| 国产精品久久久久久久久晋中| 国产精品久久久久久久浪潮网站| 亚洲福利一二三区| 不卡免费追剧大全电视剧网站| 欧美日韩一卡二卡| 国产精品国产自产拍高清av| 麻豆成人久久精品二区三区红 | 欧美日韩三级视频| 中文字幕av一区二区三区高| 麻豆精品一区二区三区| 欧美综合在线视频| 欧美国产乱子伦 | 日韩欧美成人一区| 亚洲主播在线观看| 色综合天天狠狠| 久久精品人人做| 国产在线观看免费一区| 欧美一级日韩不卡播放免费| 亚洲午夜私人影院| 欧美在线你懂的| 亚洲男人电影天堂| 99久久精品国产观看| 中文一区一区三区高中清不卡| 激情亚洲综合在线| 26uuu另类欧美| 久久99国产乱子伦精品免费| 日韩一级完整毛片| 麻豆精品视频在线| 26uuu久久天堂性欧美| 蜜臀久久99精品久久久久久9| 8x8x8国产精品| 日韩不卡一二三区| 日韩欧美国产麻豆| 韩国精品免费视频| 国产亚洲美州欧州综合国| 国产一区欧美一区| 中文字幕不卡在线播放| 99视频在线观看一区三区| 亚洲视频你懂的| 91国产成人在线| 天堂成人免费av电影一区| 欧美日韩精品一区二区在线播放| 亚洲成人久久影院| 欧美一区二区三区小说| 久久91精品久久久久久秒播| 久久综合色鬼综合色| 国产高清精品网站| 亚洲视频你懂的| 欧美日韩国产色站一区二区三区| 亚洲高清免费在线| 精品三级在线观看| 成人av网址在线观看| 一区二区三区中文字幕电影| 欧美精品一卡两卡| 国内精品国产成人国产三级粉色| 中文欧美字幕免费| 在线观看日产精品| 精品亚洲porn| 亚洲天堂免费看| 欧美一区二区大片| 91麻豆国产香蕉久久精品| 夜夜嗨av一区二区三区四季av| 911精品产国品一二三产区| 国产麻豆精品一区二区| 中文字幕亚洲欧美在线不卡| 欧美日韩国产综合久久 | 一区二区三区精品| 欧美电影免费观看高清完整版在线观看| 国产伦精品一区二区三区免费迷 | 91超碰这里只有精品国产| 国产一区二区按摩在线观看| 亚洲欧美偷拍另类a∨色屁股| 宅男噜噜噜66一区二区66| 国产成人午夜视频| 三级影片在线观看欧美日韩一区二区| 26uuu成人网一区二区三区| 日本大香伊一区二区三区| 久久福利视频一区二区| 亚洲欧美日韩中文播放| 精品sm捆绑视频| 欧美日韩中字一区| 成人app在线| 久久99精品久久久久久| 亚洲一区成人在线| 国产精品私人影院| 精品久久国产老人久久综合| 欧洲在线/亚洲| 成人在线视频首页| 紧缚奴在线一区二区三区| 午夜影院久久久| 亚洲美女少妇撒尿| 中文字幕成人av| 26uuu亚洲婷婷狠狠天堂| 欧美日本乱大交xxxxx| 91在线一区二区| 成人免费毛片a| 国产激情一区二区三区| 久久9热精品视频| 另类综合日韩欧美亚洲| 偷拍亚洲欧洲综合| 亚洲一二三四在线| 亚洲黄色小视频| 亚洲欧美另类久久久精品2019| 国产精品天天摸av网| 久久精品视频一区二区| 久久亚洲精品小早川怜子| 欧美电视剧在线观看完整版| 欧美另类久久久品| 久久影院午夜片一区| 欧美一区在线视频| 制服视频三区第一页精品| 欧美日韩一区二区欧美激情| 色综合色综合色综合色综合色综合| 成人一道本在线| 成人av免费观看| k8久久久一区二区三区| 成人av网站在线观看| 99久久99久久免费精品蜜臀| 99久免费精品视频在线观看| 99精品欧美一区二区三区综合在线| 成人激情午夜影院| 91一区在线观看| 欧美无砖砖区免费| 91精品国产综合久久婷婷香蕉| 69堂精品视频| 精品国产一区二区国模嫣然| 久久久久久久久久久电影| 国产日产欧美精品一区二区三区| 日本一区二区三区四区| 国产精品久久久久久久久快鸭| 综合久久综合久久| 亚洲一区二区视频| 美美哒免费高清在线观看视频一区二区 | 一色桃子久久精品亚洲| 亚洲欧洲在线观看av| 一区二区三区高清| 美女看a上一区| jlzzjlzz亚洲女人18| 欧美日韩一区中文字幕| 日韩精品在线一区| 国产精品色哟哟网站| 亚洲综合av网| 国内外成人在线| 色婷婷综合中文久久一本| 正在播放一区二区| 国产精品毛片久久久久久| 亚洲成人免费在线| 国产·精品毛片| 欧美三级电影网| 久久久久久麻豆| 亚洲国产va精品久久久不卡综合| 久久99精品视频| 色八戒一区二区三区| 精品国产91乱码一区二区三区| 综合在线观看色| 极品少妇xxxx精品少妇偷拍| 色悠悠久久综合| 精品国偷自产国产一区| 一区二区三区四区五区视频在线观看| 美腿丝袜在线亚洲一区| 色婷婷狠狠综合| 久久久99免费| 日日噜噜夜夜狠狠视频欧美人 | 日本久久电影网| 亚洲精品一区在线观看| 亚洲一区在线视频观看| 成人午夜视频免费看| 日韩视频一区二区三区在线播放| 国产精品久久久久影院| 国产一区二区三区香蕉| 国产嫩草影院久久久久| 麻豆一区二区三| 欧美绝品在线观看成人午夜影视| 国产视频一区不卡| 美女视频黄 久久| 欧美三级视频在线观看| 最新热久久免费视频| 国产九九视频一区二区三区| 制服丝袜激情欧洲亚洲| 亚洲综合色自拍一区| caoporen国产精品视频| 国产亚洲短视频| 精品一区二区三区视频在线观看 | 亚洲午夜久久久久久久久电影院| 成人精品国产一区二区4080| 久久蜜桃一区二区| 精品一区二区三区影院在线午夜 | 色欧美88888久久久久久影院| 国产欧美日本一区二区三区| 狠狠色狠狠色综合系列| 欧美乱妇一区二区三区不卡视频| 一区二区三区视频在线观看| 成人aa视频在线观看| 国产精品毛片a∨一区二区三区| 国产麻豆91精品| 国产清纯美女被跳蛋高潮一区二区久久w | 麻豆成人91精品二区三区| 91精品国产欧美一区二区成人 |