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

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

?? nand.c

?? 基于sumsung s3c2440a的nboot 源碼
?? C
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.
--*/
#include <string.h>

#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440lib.h"
#include "nand.h"

void __RdPage512(UCHAR *bufPt); 
void __RdPage256(UCHAR *bufPt); 

//  Status bit pattern
#define STATUS_READY                0x40          
#define STATUS_ERROR                0x01

#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); }
#if (K9F1G08_SUPPORT||K9F2G08_SUPPORT||K9F4G08_SUPPORT||K9F8G08_SUPPORT)
#define NF_RDDATA()		((*(volatile unsigned*)0x4E000010) )
#else
#define NF_RDDATA() 	(rNFDATA)
#endif
#define NF_WRDATA(data) {rNFDATA = (data); }
#define NF_WAITRB()     {while(!(rNFSTAT&(1<<0)));} 
#define NF_CLEAR_RB()	{rNFSTAT |= (1<<2); }
#define NF_DETECT_RB()	{while(!(rNFSTAT&(1<<2)));}
#define NF_MECC_UnLock()	{rNFCONT &= ~(1<<5);}
#define NF_MECC_Lock()		{rNFCONT |= (1<<5);}

#define     pNFCONF     rNFCONF 
#define     pNFCMD      rNFCMD  
#define     pNFADDR     rNFADDR 
#define     pNFDATA     rNFDATA 
#define     pNFSTAT     rNFSTAT 
#define     pNFECC      rNFECC0  

#define NF_CE_L()     NF_nFCE_L()
#define NF_CE_H()     NF_nFCE_H()
#define NF_DATA_R()   rNFDATA
#define NF_ECC()      rNFECC0
#define NF_RDDATA8() 		((*(volatile unsigned char*)0x4E000010) )
typedef union _ECCRegVal
{
	DWORD	dwECCVal;
	BYTE	bECCBuf[4];
} ECCRegVal;

#if (K9F1G08_SUPPORT||K9F2G08_SUPPORT||K9F4G08_SUPPORT||K9F8G08_SUPPORT)
#define NFDATA 0x4E000010
#define C_LANG	1
#define DMA		2
#define TRANS_MODE 2
#else
#define AdvFlash        0
#endif
//
//  Reset the chip
//
void NF_Reset()
{                       
    NF_CE_L();
	NF_CLEAR_RB();
    NF_CMD(CMD_RESET);  
    NF_DETECT_RB(); 
    NF_CE_H();          
}

// HCLK=133Mhz
#define TACLS		0
#define TWRPH0		6
#define TWRPH1		0

void NF_Init(void)
{
    rNFCONF = (TACLS<<12)|(TWRPH0<<8)|(TWRPH1<<4)|(0<<0);
    rNFCONT = (0<<13)|(0<<12)|(0<<10)|(0<<9)|(0<<8)|(0<<6)|(0<<5)|(1<<4)|(1<<1)|(1<<0);
    rNFSTAT = 0;
}

#if (NF_READID == 1)
void NF_ReadID()
{
    USHORT  wData1, wData2;

    //  First we enable chip select
    NF_CE_L();
	NF_CLEAR_RB();

    //  Issue commands to the controller
    NF_CMD(CMD_READID);
    NF_ADDR(0x00);

    NF_DETECT_RB();

    wData1 = (BYTE)NF_DATA_R();
    wData2 = (BYTE)NF_DATA_R();

    NF_CE_H();

    Uart_SendString("Nand Mfg: ");
    Uart_SendDWORD((DWORD)wData1, TRUE);
    Uart_SendString("Nand Dev: ");
    Uart_SendDWORD((DWORD)wData2, TRUE);
}
#endif

#ifdef READ_SECTOR_INFO
/* 
 *  NAND_ReadSectorInfo
 *
 *  Read SectorInfo out of the spare area. The current implementation only handles
 *  one sector at a time.
 */
void 
NAND_ReadSectorInfo(
    SECTOR_ADDR sectorAddr, 
    PSectorInfo pInfo
    )
{
    //  Chip enable
    NF_CE_L();
	NF_CLEAR_RB();

    //  Write the command
    NF_CMD(CMD_READ2);

    //  Write the address
    NF_ADDR(0x00);
    NF_ADDR(sectorAddr & 0xff);
    NF_ADDR((sectorAddr >> 8) & 0xff);
    
    if (NEED_EXT_ADDR) {
        NF_ADDR((sectorAddr >> 16) & 0xff);
    }

    //  Wait for the Ready bit
    NF_DETECT_RB();

    //  Read the SectorInfo data (we only need to read first 8 bytes) 
    pInfo->dwReserved1  = (DWORD) ((BYTE) NF_DATA_R()) << 24;
    pInfo->dwReserved1 |= (DWORD) ((BYTE) NF_DATA_R()) << 16;
    pInfo->dwReserved1 |= (DWORD) ((BYTE) NF_DATA_R()) << 8;
    pInfo->dwReserved1 |= (DWORD) ((BYTE) NF_DATA_R());

    //  OEM byte
    pInfo->bOEMReserved = (BYTE) NF_DATA_R();

    //  Read the bad block mark
    pInfo->bBadBlock = (BYTE) NF_DATA_R();
    
    //  Second reserved field (WORD)
    pInfo->wReserved2 = ((BYTE) NF_DATA_R() << 8);
    pInfo->wReserved2 |= ((BYTE) NF_DATA_R());

    NF_CE_H();
}
#endif


//  FMD_ReadSector
//
//  Read the content of the sector.
//
//  startSectorAddr: Starting page address
//  pSectorBuff  : Buffer for the data portion
//  pSectorInfoBuff: Buffer for Sector Info structure
//  dwNumSectors : Number of sectors
//
BOOL 
FMD_ReadSector(
    SECTOR_ADDR startSectorAddr, 
    LPBYTE pSectorBuff,
    PSectorInfo pSectorInfoBuff, 
    DWORD dwNumSectors
    )
{
    DWORD   i, r = 0;
    BYTE   ecc0,ecc1,ecc2;
    BOOL   rc = TRUE;
    ECCRegVal eccRegVal;

    //  BUGBUGBUG: I need to come back to support dwNumSectors > 1
    //
    //  Sanity check
    if (!pSectorBuff && !pSectorInfoBuff || dwNumSectors > 1 || !pSectorBuff) {
//        Uart_SendString("ERROR_INVALID_PARAMETER\n");
        return FALSE;
    }

//    Uart_SendString("R: ");
//    Uart_SendDWORD(startSectorAddr, TRUE);

    //  Initialize ECC register
    NF_RSTECC();
	NF_MECC_UnLock();

    //  Enable the chip
    NF_nFCE_L();   
	NF_CLEAR_RB();

    // Issue Read command
    NF_CMD(CMD_READ);
#if (K9F1G08_SUPPORT||K9F2G08_SUPPORT||K9F4G08_SUPPORT||K9F8G08_SUPPORT)
	NF_ADDR(0);	// Column (A[7:0]) = 0
	NF_ADDR(0);		// A[11:8]
	NF_ADDR((startSectorAddr)&0xff);	// A[19:12]
	NF_ADDR((startSectorAddr>>8)&0xff);	// A[27:20]
	#if(!K9F1G08_SUPPORT)	//if the flash is not K9F1G08,then need the 3thd row address.
	NF_ADDR((startSectorAddr>>16)&0xff);	// A[30:28]
	#endif	  
	 NF_CMD(0x30);	// 2'nd command
	 NF_DETECT_RB();
		
      #if TRANS_MODE==C_LANG
			for(i=0;i<2048;i++) {
				*pSectorBuff++=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)pSectorBuff;
			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)|(2048/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;
	
      #endif
	
	  	 NF_MECC_Lock();
	
	
	//	 NF_RDDATA8();
	//	 Mecc=NF_RDDATA();
	//	 rNFECC=((Mecc&0xff00)<<8)|(Mecc&0xff);
	//	 rNFMECCD1=((Mecc&0xff000000)>>8)|((Mecc&0xff0000)>>16);
		
	
		 NF_nFCE_H();	 
	
	//	 if ((rNFESTAT0&0x3) == 0x0){			
			return TRUE;
	//	 }
	//	 else {
	//		   return FALSE;
	//	 }
#else
    //  Set up address
    NF_ADDR(0x00);
    NF_ADDR((startSectorAddr) & 0xff);
    NF_ADDR((startSectorAddr >> 8) & 0xff);
    if (NEED_EXT_ADDR) {
        NF_ADDR((startSectorAddr >> 16) & 0xff);
    }

    for (i = 0; i < 5; i++);   // wait tWB(100ns)

    NF_DETECT_RB();        // wait tR(max 12us)

    // read the data
    __RdPage512(pSectorBuff);

	NF_MECC_Lock();


	//	Read the ECC from ECC Register
	eccRegVal.dwECCVal = NF_ECC();

	//	Skip first 8 bytes
	for(i=0; i<8; i++){
		ecc0 = (BYTE)NF_DATA_R();
	}
	
	ecc0 = (BYTE)NF_DATA_R();
	ecc1 = (BYTE)NF_DATA_R();
	ecc2 = (BYTE)NF_DATA_R();
	
    NF_nFCE_H();
    
    if ( startSectorAddr < 0x120 ) // NO ECC Check about EBOOT
    {
    	rc = TRUE;
    }
    else
    {
	if(	ecc0 != eccRegVal.bECCBuf[0] ||
		ecc0 != eccRegVal.bECCBuf[0] ||
		ecc0 != eccRegVal.bECCBuf[0] )  {
//		Uart_SendString("ECC mismatch for Sector: ");
//		Uart_SendDWORD(startSectorAddr, TRUE);
		rc = FALSE;
	}
    }
#endif
    return rc;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
韩国女主播成人在线观看| 亚洲黄色性网站| 久久99热狠狠色一区二区| 日韩美女视频在线| 紧缚奴在线一区二区三区| 国产喂奶挤奶一区二区三区| 成人一区二区视频| 亚洲精品国久久99热| 欧美日韩精品一区二区在线播放| 午夜视频一区在线观看| 精品国产免费人成电影在线观看四季 | 中文字幕av一区二区三区高| 成人一区二区三区在线观看| 一区二区在线观看免费视频播放| 欧美在线一区二区| 久久99日本精品| 成人免费小视频| 4438x成人网最大色成网站| 久久9热精品视频| 成人免费在线观看入口| 51精品国自产在线| 亚洲精品成a人| 久久青草欧美一区二区三区| 国产盗摄女厕一区二区三区| 中文字幕一区二区三区在线播放| 色婷婷综合久久久久中文一区二区 | 国产精品国产三级国产普通话99| 在线观看亚洲精品视频| 国产在线精品一区二区三区不卡| 亚洲欧美在线高清| 日韩精品一区二区三区四区视频| eeuss国产一区二区三区| 奇米精品一区二区三区四区| 最新不卡av在线| 亚洲资源在线观看| 欧美系列日韩一区| 国产91精品久久久久久久网曝门| 国产精品第一页第二页第三页| 在线不卡免费av| 成a人片亚洲日本久久| 免费成人你懂的| 亚洲精品国产精品乱码不99 | 久久久www成人免费毛片麻豆| 欧美优质美女网站| 成人理论电影网| 久久国产剧场电影| 亚洲成在线观看| 最新日韩av在线| 久久精品网站免费观看| 69堂亚洲精品首页| 日本韩国一区二区三区| 国产91精品欧美| 国产一区二区三区在线观看免费视频 | 高潮精品一区videoshd| 亚洲欧美日韩综合aⅴ视频| 欧美一区日韩一区| 色老汉一区二区三区| 国产精品中文字幕日韩精品| 日本亚洲视频在线| 亚洲免费毛片网站| 国产欧美日韩三级| 国产午夜精品一区二区三区嫩草 | 亚洲在线观看免费视频| 中文字幕一区二区三区视频| 久久久不卡影院| 久久久久久亚洲综合| 日韩一区二区免费电影| 欧美美女一区二区在线观看| 欧美日韩一区二区在线观看视频| 色婷婷av一区二区三区gif | 粉嫩绯色av一区二区在线观看| 日本怡春院一区二区| 美女www一区二区| 午夜亚洲国产au精品一区二区| 亚洲精品伦理在线| 亚洲欧美日韩在线不卡| 国产精品国产自产拍高清av| 国产精品久久二区二区| 自拍视频在线观看一区二区| 亚洲欧美区自拍先锋| 亚洲专区一二三| 丝袜美腿高跟呻吟高潮一区| 日本亚洲免费观看| 国产一区免费电影| 成人午夜免费av| a在线播放不卡| 色婷婷综合视频在线观看| 欧美影院午夜播放| 69精品人人人人| 日韩久久久精品| 日本一区二区三区视频视频| 亚洲视频在线观看三级| 亚洲精品大片www| 日日摸夜夜添夜夜添国产精品 | 亚洲视频在线观看三级| 日韩毛片精品高清免费| 亚洲一二三区在线观看| 三级精品在线观看| 国内不卡的二区三区中文字幕| 国产一区二区在线影院| 99国产精品视频免费观看| 欧美日韩国产大片| 久久综合中文字幕| 国产精品国产三级国产aⅴ入口| 一区二区免费看| 激情综合网激情| 91丨九色丨蝌蚪丨老版| 717成人午夜免费福利电影| 久久久www免费人成精品| 一区二区三区毛片| 久久精品72免费观看| 99久久综合狠狠综合久久| 欧美日韩视频专区在线播放| 久久新电视剧免费观看| 成人欧美一区二区三区黑人麻豆 | 在线免费一区三区| 精品久久久三级丝袜| 亚洲欧美综合另类在线卡通| 欧美精三区欧美精三区| 精品99999| 亚洲欧美另类综合偷拍| 紧缚奴在线一区二区三区| 成人精品一区二区三区中文字幕| 欧美日韩国产不卡| 亚洲国产精品激情在线观看| 亚洲午夜激情网页| 国产成a人亚洲精| 91精品福利在线一区二区三区| 国产精品久久国产精麻豆99网站| 日本亚洲电影天堂| 欧美综合在线视频| 国产欧美一区二区三区在线老狼| 日本va欧美va精品| 日本高清免费不卡视频| 中文字幕 久热精品 视频在线| 国产美女精品在线| 91精品国产综合久久久久久久 | 国产丝袜在线精品| 天堂av在线一区| 色综合久久久久综合| 国产日韩一级二级三级| 9l国产精品久久久久麻豆| 91视频国产资源| 久久久久久久久久久99999| 亚洲国产日韩一区二区| av在线不卡观看免费观看| 26uuu久久天堂性欧美| 日本欧美一区二区| 欧美影片第一页| 亚洲最大的成人av| 91在线免费视频观看| 亚洲国产精华液网站w| 国产一区二区三区日韩| 日韩精品专区在线| 蜜臀国产一区二区三区在线播放| 欧美日韩一区视频| 亚洲成人在线网站| 欧美性猛片aaaaaaa做受| 亚洲欧美日韩久久| 91视频你懂的| 一区二区三区在线播| 色狠狠一区二区三区香蕉| 专区另类欧美日韩| 91麻豆.com| 亚洲精品高清在线| 欧美视频中文字幕| 五月天丁香久久| 日韩一级成人av| 免播放器亚洲一区| 精品久久久久久最新网址| 另类小说图片综合网| 日韩免费观看高清完整版| 91.成人天堂一区| 成人国产精品视频| 欧美高清一级片在线观看| 国产美女av一区二区三区| 欧美xxxxx牲另类人与| 九九精品视频在线看| 精品国内二区三区| 国产超碰在线一区| 亚洲免费在线电影| 制服丝袜一区二区三区| 激情欧美日韩一区二区| 欧美国产综合一区二区| 99re8在线精品视频免费播放| 亚洲三级小视频| 欧美电影一区二区| 韩国女主播成人在线观看| 中文字幕人成不卡一区| 在线区一区二视频| 免费成人在线视频观看| 欧美极品少妇xxxxⅹ高跟鞋 | 欧美高清hd18日本| 美女被吸乳得到大胸91| 国产精品伦理在线| 91高清视频在线| 激情综合五月婷婷| 亚洲免费在线视频一区 二区| 91精品国产综合久久久久久漫画| 国产高清不卡一区|