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

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

?? nand_mini.c

?? 這個是在ADS下燒寫K9F1208的工程
?? C
字號:
//====================================================================
// File Name : Nand.c
// Function  : S3C2440 8-bit interface Nand Test program(this program use K9k2g16.c).
// Date      : May xx, 2003
// Version   : 0.0
// History
//   R0.0 (200305xx): Modified for 2440 from 2410. -> DonGo
//====================================================================


/**************** K9s1206 NAND flash ********************/
// 1block=(512+16)bytes x 32pages
// 4096block
// Block: A[23:14], Page: [13:9]
/**************** K9K2G16 NAND flash *******************/
// 1block=(2048+64)bytes x 64pages
// 2048block
// Block: A[23:14], page: [13:9]
/*****************************************************/

#include <string.h>
#include <stdlib.h>
#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440lib.h"
#include "2440slib.h" 

#include "Nand.h"
//#include "k9k2g16.h" 

#define ASM		1
#define C_LANG	2
#define DMA		3
#define TRANS_MODE  3


U32 srcAddress;
U32 targetBlock;	    // Block number (0 ~ 4095)
U32 targetSize;	    // Total byte size 

U32 downloadAddress;
U32 downloadProgramSize=0x0;

//*************************************************
//*************************************************
//**           H/W dependent functions           **
//************************************************* 
//*************************************************

//The code is made for bi-endian mode

// block0: reserved for boot strap
// block1~4095: used for OS image
// badblock SE: xx xx xx xx xx 00 ....
// good block SE: ECC0 ECC1 ECC2 FF FF FF ....


#define NF_MECC_UnLock()         {rNFCONT&=~(1<<5);}
#define NF_MECC_Lock()         {rNFCONT|=(1<<5);}

#define NF_CMD(cmd)			{rNFCMD=cmd;}
#define NF_ADDR(addr)		{rNFADDR=addr;}	
#define NF_nFCE_L()			{rNFCONT&=~(1<<1);}
#define NF_nFCE_H()			{rNFCONT|=(1<<1);}
#define NF_RSTECC()			{rNFCONT|=(1<<4);}
#define NF_RDDATA() 		(rNFDATA8)
#define NF_RDDATA8() 		((*(volatile unsigned char*)0x4E000010) )

#define NF_WRDATA(data) 	{rNFDATA8=data;}

#define NF_WAITRB()    		{while(!(rNFSTAT&(1<<0)));} 
	   						 //wait tWB and check F_RNB pin.
// RnB Signal
#define NF_CLEAR_RB()    		{rNFSTAT |= (1<<2);}	// Have write '1' to clear this bit.
#define NF_DETECT_RB()    		{while(!(rNFSTAT&(1<<2)));}

#define ID_K9S1208V0M	0xec76
#define ID_K9K2G16U0M	0xecca

#define	NF16_BAD_OFFSET		(12)

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

#define TACLS		0	// 1-clk(0ns) 
#define TWRPH0		6	// 3-clk(25ns)
#define TWRPH1		0	// 1-clk(10ns)  //TACLS+TWRPH0+TWRPH1>=50ns


 

static U8 se8Buf[16]={
	0xff,0xff,0xff,0xff,
	0xff,0xff,0xff,0xff,
	0xff,0xff,0xff,0xff,
	0xff,0xff,0xff,0xff
};


extern char *hex2char(int val);



void __RdPage512(U8 *bufPt);  


int NF8_ReadPage(U32 block,U32 page,U8 *buffer)
{
    int i;
    unsigned int blockPage;
	U32 ecc;
	U8 *bufPt=buffer;
	U8 se[16], ecc0, ecc1, ecc2, ecc3;
    
    	page=page&0x1f;
    	blockPage=(block<<5)+page;
	NF_RSTECC();    // Initialize ECC
	NF_MECC_UnLock();
    
	NF_nFCE_L();    

	NF_CLEAR_RB();
	NF_CMD(0x00);	// Read command
	NF_ADDR(0); 	// Column = 0
	NF_ADDR(blockPage&0xff);		//
	NF_ADDR((blockPage>>8)&0xff);	// Block & Page num.
	NF_ADDR((blockPage>>16)&0xff);	//
	NF_DETECT_RB();
	 
	
#if TRANS_MODE==C_LANG
    for(i=0;i<512;i++) {
    	*bufPt++=NF_RDDATA8();	// Read one page
    }
#elif TRANS_MODE==DMA
	// Nand to memory dma setting
    rSRCPND=BIT_DMA0;	// Init DMA src pending.
    rDISRC0=NFDATA; 	// Nand flash data register
    rDISRCC0=(0<<1) | (1<<0); //arc=AHB,src_addr=fix
    rDIDST0=(unsigned)bufPt;
    rDIDSTC0=(0<<1) | (0<<0); //dst=AHB,dst_addr=inc;
	rDCON0=(1<<31)|(1<<30)|(1<<29)|(1<<28)|(1<<27)|(0<<23)|(1<<22)|(2<<20)|(512/4/4);
	//Handshake,AHB,interrupt,(4-burst),whole,S/W,no_autoreload,word,count=128;

	// DMA on and start.
    rDMASKTRIG0=(1<<1)|(1<<0);

	while(!(rSRCPND & BIT_DMA0));	// Wait until Dma transfer is done.
	
    rSRCPND=BIT_DMA0;

#elif TRANS_MODE==ASM
    __RdPage512(bufPt);
#endif

 NF_MECC_Lock();


  ecc=rNFMECC0;
	ecc0 = (U8)(ecc &0xff);
	ecc1 = (U8)((ecc>>8) & 0xff);
	ecc2 = (U8)((ecc>>16) & 0xff);
//	ecc3 = (U8)((ecc>>24) & 0xff);
	
	for(i=0;i<16;i++)
    {
    	se[i]=NF_RDDATA8();	// Read spare array
     }



/*
rNFMECCD0_0=NF_RDDATA8();
rNFMECCD0_1=NF_RDDATA8();
rNFMECCD0_2=NF_RDDATA8();
rNFMECCD0_3=rNFMECC0_3;
*/
/*
rNFMECCD0=NF_RDDATA();
rNFMECCD0=((rNFMECCD0&0xffffff)|(rNFMECC0&0xff000000));
*/
NF_nFCE_H();    

/*
if ((rNFESTAT0&0x3) == 0x0) return OK;
return FAIL;
*/

    if(ecc0==se[0] && ecc1==se[1] && ecc2==se[2] )
    {
		//Uart_Printf("[ECC OK:%x,%x,%x,%x]\n",se[0],se[1],se[2],se[3]);
    	return OK;
    }
    else
    {
		//Uart_Printf("[ECC ERROR(RD):read:%x,%x,%x, reg:%x,%x,%x,%x]\n", se[0],se[1],se[2],se[3],ecc0,ecc1,ecc2,ecc3);
    	//return FAIL;
    	return OK;
    }    	

}

void Nand_Reset(void)
{
    int i;
   
	NF_nFCE_L();

	NF_CLEAR_RB();
	NF_CMD(0xFF);	//reset command
	NF_DETECT_RB();
	
	NF_nFCE_H();

}

void NF8_Init(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)|(0<<6)|(0<<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();
}


 int NF8_IsBadBlock(U32 block)
{
    int i;
    unsigned int blockPage;
	U8 data;
    
    
    	blockPage=(block<<5);	// For 2'nd cycle I/O[7:5] 
    
	NF_nFCE_L();
	NF_CLEAR_RB();

	NF_CMD(0x50);		 // Spare array read command
	NF_ADDR((512+5)&0xf);		 // Read the mark of bad block in spare array(M addr=5), A4-A7:Don't care

	NF_ADDR(blockPage&0xff);	 // The mark of bad block is in 0 page
	NF_ADDR((blockPage>>8)&0xff);	 // For block number A[24:17]
	NF_ADDR((blockPage>>16)&0xff);  // For block number A[25]
	 
	NF_DETECT_RB();	 // Wait tR(max 12us)

   	 data=NF_RDDATA();

	NF_nFCE_H();    

    if(data!=0xff) 	return FAIL;
    else  	return OK;
    
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
爽爽淫人综合网网站| 欧美丝袜丝交足nylons图片| 99精品视频免费在线观看| 欧美精品1区2区3区| 中文字幕在线不卡一区| 蜜桃av噜噜一区| 欧美亚洲国产bt| 中文字幕巨乱亚洲| 精品一区二区三区在线播放视频 | 色婷婷精品久久二区二区蜜臂av | 国产精品99久久久久久久女警| 色婷婷亚洲婷婷| 中文在线一区二区 | 国产成人在线网站| 91精品综合久久久久久| 亚洲视频一区在线| 成人污视频在线观看| 2022国产精品视频| 美腿丝袜亚洲三区| 777亚洲妇女| 亚洲成人免费视| 色成年激情久久综合| 国产精品欧美一区喷水| 国产一区二区三区四区在线观看| 欧美日产在线观看| 香蕉成人伊视频在线观看| 91色综合久久久久婷婷| 国产精品久久久久久久蜜臀| 在线观看不卡一区| 中文字幕中文在线不卡住| 成人免费视频网站在线观看| 久久久99精品久久| 国产成人综合在线| 久久精品在这里| 国产成人亚洲综合a∨婷婷| 精品国产一区二区三区忘忧草| 免费观看一级特黄欧美大片| 欧美一区二区三区影视| 美女一区二区三区| 精品1区2区在线观看| 国产一区二区三区| 国产无人区一区二区三区| 国产成人在线视频免费播放| 国产亚洲精品7777| 成人激情电影免费在线观看| 亚洲国产精品ⅴa在线观看| 成人免费视频免费观看| 国产精品高潮呻吟| 色综合久久九月婷婷色综合| 亚洲精品欧美激情| 欧美精三区欧美精三区| 免费观看久久久4p| 中文字幕欧美日本乱码一线二线| av午夜一区麻豆| 一区二区三区日韩欧美| 91精品欧美久久久久久动漫| 激情综合网av| 亚洲欧洲色图综合| 欧美吻胸吃奶大尺度电影| 日韩精品国产欧美| 久久久久国产免费免费| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 国产91丝袜在线播放0| 国产精品灌醉下药二区| 欧美性生活影院| 久久99深爱久久99精品| 国产日产欧美一区| 欧美影视一区在线| 国内精品久久久久影院色| 中文字幕在线观看不卡| 6080亚洲精品一区二区| 顶级嫩模精品视频在线看| 亚洲一区二区三区小说| 久久综合九色综合97婷婷| 91久久一区二区| 国产乱妇无码大片在线观看| 亚洲综合一区二区三区| 久久久美女艺术照精彩视频福利播放| 99久久精品国产网站| 蜜桃在线一区二区三区| 一区免费观看视频| 精品毛片乱码1区2区3区| 91在线观看一区二区| 蜜桃一区二区三区在线观看| 国产精品第五页| 欧美一级免费大片| 91精品国产色综合久久ai换脸| 高清国产一区二区| 欧美a一区二区| 亚洲第一主播视频| 136国产福利精品导航| 精品99一区二区三区| 欧美日韩国产成人在线免费| 成人免费毛片嘿嘿连载视频| 久久99国产精品免费| 一区二区三区视频在线观看| 中文字幕精品一区二区精品绿巨人 | 日韩精品一区二区三区视频 | 国产精品丝袜久久久久久app| 欧美精品一级二级三级| 色婷婷亚洲婷婷| 成人精品gif动图一区| 精品一区二区三区不卡| 青青草国产成人av片免费| 亚洲精品久久久蜜桃| 亚洲欧美一区二区在线观看| 久久久99久久| 久久久精品中文字幕麻豆发布| 日韩视频在线你懂得| 欧美日韩久久久久久| 欧美性一区二区| 91黄视频在线观看| 色综合一个色综合| 色婷婷av久久久久久久| 色综合久久久久| 色悠悠久久综合| 欧美午夜电影网| 欧美日韩免费观看一区三区| 欧美色图一区二区三区| 欧美亚洲国产bt| 欧美精品久久一区| 91精品国产福利在线观看| 91麻豆精品91久久久久久清纯| 欧美日韩国产美女| 日韩一区二区三区在线| 欧美一区二区三区免费| 日韩精品一区二区三区视频播放| 精品国产精品网麻豆系列| 精品国产污污免费网站入口 | 亚洲婷婷综合色高清在线| 亚洲欧美一区二区久久 | 色综合久久久久久久久久久| 色悠悠亚洲一区二区| 欧美色图一区二区三区| 欧美精品少妇一区二区三区| 日韩午夜小视频| 久久一夜天堂av一区二区三区| 久久精品一区二区三区av| 国产精品视频你懂的| 亚洲欧美日韩系列| 日韩精品一级中文字幕精品视频免费观看 | 亚洲男人的天堂在线观看| 夜夜嗨av一区二区三区四季av| 五月天中文字幕一区二区| 久久成人综合网| 成人免费看的视频| 精品视频资源站| 日韩精品一区二区三区蜜臀| 国产精品久99| 日韩中文字幕亚洲一区二区va在线| 另类小说视频一区二区| 成人18视频在线播放| 欧美日韩综合在线免费观看| 欧美精品一区二区三区很污很色的| 国产精品高潮呻吟| 青青青伊人色综合久久| 波多野结衣亚洲| 欧美一区二区福利视频| 亚洲日穴在线视频| 久久99久久99| 色婷婷亚洲一区二区三区| 2023国产一二三区日本精品2022| 亚洲女与黑人做爰| 国产在线播放一区二区三区| 欧美亚洲日本一区| 国产精品嫩草99a| 捆绑变态av一区二区三区 | 国产美女视频一区| 欧美写真视频网站| 中文字幕欧美国产| 毛片av一区二区| 色狠狠色噜噜噜综合网| 国产欧美日韩综合精品一区二区| 亚洲成人免费在线观看| 成人av资源下载| 2022国产精品视频| 日本美女视频一区二区| 在线观看91精品国产入口| 中国av一区二区三区| 激情久久久久久久久久久久久久久久| 一本大道久久a久久精二百| 久久综合久久综合久久| 美腿丝袜亚洲三区| 777午夜精品免费视频| 一区二区在线观看视频 | 欧美男女性生活在线直播观看| 国产精品视频线看| 国产麻豆精品在线| 精品福利av导航| 久久精品国产精品青草| 欧美丰满少妇xxxbbb| 亚洲电影在线免费观看| 色狠狠一区二区三区香蕉| 国产精品动漫网站| 成人aa视频在线观看| 国产精品你懂的在线欣赏| 国产99久久久国产精品免费看| 日韩免费电影网站| 久久91精品国产91久久小草| 欧美一区二区视频在线观看|