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

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

?? k9s1208.c

?? S3C2443的讀Nand程序
?? C
字號:
//====================================================================
// File Name : K9s1208.c
// Function  : S3C2413 8-bit interface Nand Test program(this program use K9k2g16.c).
// Date      : Sept , 2005
// Version   : 0.0
// History
//   R0.0 (20050923): wooseok.oh
//====================================================================


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

//#include <string.h>
//#include <stdlib.h>
#include "def.h"
#include "option.h"
#include "2443addr.h"
#include "System.h"
#include "Console.h" 

#include "Nand.h"

#define C_LANG	1
#define DMA		2
#define TRANS_MODE 1


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<<7);}
#define NF_MECC_Lock()         {rNFCONT|=(1<<7);}

#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);}

//for debugging
//#define NF_nFCE_L()			{rNFCONT&=~(1<<2);}
//#define NF_nFCE_H()			{rNFCONT|=(1<<2);}

#define NF_RSTECC()			{rNFCONT|=(1<<5|1<<4);}
#define NF_RDDATA() 		(rNFDATA)
#define NF_RDDATA8() 		((*(volatile unsigned char*)0x4E000010) )

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

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

#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		1	// 1-clk(0ns) 
#define TWRPH0		6	// 3-clk(25ns)
#define TWRPH1		2	// 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, Mecc, Secc;
	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_DMA;	// Init DMA src pending.
    rSUBSRCPND=BIT_SUB_DMA0;
    //rDISRC0=rNFDATA; 	// Nand flash data register
    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(!(rSUBSRCPND & BIT_SUB_DMA0));
	
    rSRCPND=BIT_DMA;
    rSUBSRCPND=BIT_SUB_DMA0;

#endif

NF_MECC_Lock();

 
 	Mecc=NF_RDDATA();
 	rNFMECCD0=((Mecc&0xff00)<<8)|(Mecc&0xff);
 	rNFMECCD1=((Mecc&0xff000000)>>8)|((Mecc&0xff0000)>>16);

 
	NF_nFCE_H();    

	 if ((rNFECCERR0&0x3) == 0x0){
	//       printf("ECC OK!\n");
		return 1;
	 }
	 else {
	// 	printf("ECC FAIL!\n");
	//	printf("NFECCERR0: 0x%x\n", rNFECCERR0);
	
	    return 0;
	 }


}



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 S3C2413

	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<<17)|(0<<16)|(0<<10)|(0<<9)|(0<<8)|(1<<7)|(1<<6)|(1<<5)|(1<<4)|(1<<1)|(1<<0);
	rNFCONT = (0<<17)|(0<<16)|(0<<10)|(0<<9)|(0<<8)|(1<<7)|(1<<6)|(1<<5)|(1<<4)|(0x3<<1)|(1<<0);
	// Lock-tight	[17]	0:Disable lock, 1:Enable lock.
	// Soft Lock	[16]	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	[7]		0:Unlock, 1:Lock
	// MainECCLock	[6]		0:Unlock, 1:Lock
	// InitMECC(W)	[5]		1:Init main area ECC decoder/encoder.
	// InitSECC(W)	[4]		1:Init spare area ECC decoder/encoder.
	// Reg_nCE1		[2]		0:nFCE=0, 1:nFCE=1.
	// Reg_nCE0		[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 0;
    else  	return 1;
    
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜不卡在线观看免费| 日本高清不卡视频| www.99精品| 日韩一区二区三区在线观看| 国产精品久久久久永久免费观看 | 91女厕偷拍女厕偷拍高清| 91麻豆精品91久久久久同性| 中文字幕在线不卡一区| 韩国av一区二区三区| 精品视频一区 二区 三区| 国产精品嫩草99a| 久久99国产精品尤物| 欧美日韩一区二区三区在线| 国产精品传媒在线| 国产成人精品免费看| 国产精品久久久久久亚洲毛片 | 欧美嫩在线观看| 日韩一区有码在线| 成人av影视在线观看| 久久美女艺术照精彩视频福利播放| 视频一区在线视频| 欧美手机在线视频| 亚洲一区二区三区视频在线播放 | 国产精品一区在线观看你懂的| 欧美夫妻性生活| 午夜精品久久久| 欧美精品久久天天躁| 日日夜夜免费精品| 欧美一区二区高清| 美女尤物国产一区| 精品国产乱码久久久久久久| 麻豆国产精品官网| 精品日韩av一区二区| 久久99久久久久| 精品福利视频一区二区三区| 韩国v欧美v日本v亚洲v| 国产日韩欧美精品在线| 国产a视频精品免费观看| 国产欧美综合在线| 北条麻妃国产九九精品视频| 亚洲精品视频在线观看网站| 在线精品视频免费观看| 亚洲6080在线| 日韩一二三区不卡| 国产一区二区美女| 亚洲特黄一级片| 久久网站最新地址| 国产黄色91视频| 日韩一区在线播放| 欧美人xxxx| 精品一区二区三区久久| 国产亚洲污的网站| 91丨porny丨中文| 午夜精品久久一牛影视| 精品日韩欧美在线| 波多野结衣精品在线| 亚洲男帅同性gay1069| 欧美日本一区二区三区| 国模少妇一区二区三区| 国产成人99久久亚洲综合精品| 国产日韩影视精品| 亚洲一区在线观看网站| 欧美视频在线观看一区二区| 青青国产91久久久久久| 亚洲精品一区二区精华| 91麻豆国产自产在线观看| 亚洲成人在线网站| 久久精品一区二区三区不卡牛牛| 播五月开心婷婷综合| 亚洲成在人线在线播放| 久久久亚洲国产美女国产盗摄 | 91国偷自产一区二区开放时间 | 91天堂素人约啪| 蜜臂av日日欢夜夜爽一区| 国产欧美精品一区二区色综合| 色一情一伦一子一伦一区| 麻豆精品久久久| 亚洲免费毛片网站| 国产日韩欧美一区二区三区综合| 欧洲亚洲国产日韩| 高清国产一区二区| 日本伊人精品一区二区三区观看方式 | 欧美成人欧美edvon| 99国产一区二区三精品乱码| 美女精品自拍一二三四| 国产69精品久久99不卡| 国产精品视频第一区| 国产原创一区二区| 中文字幕在线一区二区三区| 成人午夜在线播放| 久久久精品综合| 国产九色精品成人porny| 日韩欧美自拍偷拍| 男女性色大片免费观看一区二区 | 东方aⅴ免费观看久久av| 亚洲色图20p| 国产欧美日韩在线视频| 日韩一区二区在线免费观看| 色狠狠综合天天综合综合| 国产69精品久久久久毛片| 久久超碰97中文字幕| 午夜精品久久久久久久久久久| 成人免费在线观看入口| 久久免费电影网| 精品国产成人在线影院| 欧美一区二区黄色| 6080国产精品一区二区| 欧美亚洲一区二区三区四区| 色婷婷久久一区二区三区麻豆| 成人精品一区二区三区中文字幕| 国模套图日韩精品一区二区 | 亚洲一区二区三区激情| 一区二区视频在线| 亚洲欧美另类图片小说| 1区2区3区国产精品| 亚洲乱码国产乱码精品精98午夜| 国产精品日日摸夜夜摸av| 中文字幕av一区二区三区| 中文字幕第一区综合| 国产精品理论在线观看| 国产精品久久精品日日| 国产精品午夜电影| 亚洲欧美日韩系列| 依依成人综合视频| 亚洲第一综合色| 日韩黄色免费网站| 精品一区二区成人精品| 激情av综合网| 国产99久久久精品| 色综合天天天天做夜夜夜夜做| 97久久精品人人澡人人爽| 欧美自拍丝袜亚洲| 在线不卡a资源高清| 日韩亚洲国产中文字幕欧美| 久久夜色精品国产噜噜av| 久久精品欧美一区二区三区麻豆| 国产精品视频免费看| 亚洲男人电影天堂| 日韩av在线发布| 国产成人自拍高清视频在线免费播放 | 成人国产视频在线观看| 欧美无砖专区一中文字| 91精品国产色综合久久久蜜香臀| 久久新电视剧免费观看| 国产精品久久久久久久久晋中 | 国产精品看片你懂得| 亚洲一区在线看| 国产一区二区在线视频| av在线不卡免费看| 欧美色男人天堂| 国产午夜精品在线观看| 亚洲资源在线观看| 国产美女视频一区| 欧美私人免费视频| 久久久不卡网国产精品二区| 夜夜爽夜夜爽精品视频| 激情成人综合网| 欧美午夜精品理论片a级按摩| 精品福利一二区| 亚洲成人综合视频| 欧美性色黄大片| 久久亚洲综合色| 午夜久久久久久久久久一区二区| 久久99久国产精品黄毛片色诱| 99视频在线精品| 久久综合久色欧美综合狠狠| 亚洲影院免费观看| 不卡影院免费观看| 久久久www成人免费毛片麻豆| 亚洲午夜一区二区三区| 成人av资源网站| 久久婷婷一区二区三区| 日本vs亚洲vs韩国一区三区二区 | 激情综合一区二区三区| 欧美日韩三级一区二区| 最新中文字幕一区二区三区| 国产主播一区二区三区| 欧美老年两性高潮| 一区二区三区免费看视频| 成人综合在线观看| 欧美精品一区二区三区一线天视频| 亚洲电影中文字幕在线观看| 色综合亚洲欧洲| 国产精品欧美久久久久无广告 | 91视视频在线直接观看在线看网页在线看| 欧美福利视频一区| 亚洲成人在线网站| 在线观看免费一区| 亚洲精品乱码久久久久久久久| 成人激情综合网站| 国产视频一区在线观看| 国产一区91精品张津瑜| 精品国产精品一区二区夜夜嗨| 日本aⅴ精品一区二区三区| 欧美区一区二区三区| 日韩在线观看一区二区| 欧美福利视频一区| 美女视频网站黄色亚洲| 精品区一区二区| 黑人精品欧美一区二区蜜桃|