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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? nand.c

?? ADS工程
?? 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 "2410addr.h"
#include "2410lib.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()	    {rNFCONF &= ~(1<<11); }
#define NF_nFCE_H()	    {rNFCONF |= (1<<11); }
#define NF_RSTECC()	    {rNFCONF |= (1<<12); }
#define NF_RDDATA() 	(rNFDATA)
#define NF_WRDATA(data) {rNFDATA = (data); }
#define NF_WAITRB()     {while(!(rNFSTAT&(1<<0)));} 

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

#define NF_CE_L()     NF_nFCE_L()
#define NF_CE_H()     NF_nFCE_H()
#define NF_DATA_R()   rNFDATA
#define NF_ECC()      rNFECC

typedef union _ECCRegVal
{
	DWORD	dwECCVal;
	BYTE	bECCBuf[4];
} ECCRegVal;

//
//  Reset the chip
//
void NF_Reset()
{                       
    NF_CE_L();          
    NF_CMD(CMD_RESET);  
    NF_WAITRB();        
    NF_CE_H();          
}


void NF_Init(void)
{
    rNFCONF = NFCONF_INIT;
}

#ifdef NF_READID
void NF_ReadID()
{
    USHORT  wData1, wData2;

    //  First we enable chip select
    NF_CE_L();

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

    NF_WAITRB();

    wData1 = NF_DATA_R();
    wData2 = 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();

    //  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_WAITRB();

    //  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


int NF_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_CMD(0x50);		// Spare array read command
    NF_ADDR(517&0xf);		// Read the mark of bad block in spare array(M addr=5) 
    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]

   for(i=0;i<10;i++);	// wait tWB(100ns) //?????
    
    NF_WAITRB();	// Wait tR(max 12us)
    
    data=NF_RDDATA();

    NF_nFCE_H();    

    if(data!=0xff)
    {
    	//Uart_Printf("[block %d has been marked as a bad block(%x)]\n",block,data);
    	return 1;
    }
    else
    {
    	return 0;
    }
}


//  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;
    }


_retry:
    //  Initialize ECC register
    NF_RSTECC();

    //  Enable the chip
    NF_nFCE_L();   
    
    // Issue Read command
    NF_CMD(CMD_READ);

    //  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_WAITRB();        // wait tR(max 12us)

    // read the data
    __RdPage512(pSectorBuff);
//    __RdPage256(pSectorBuff);

	//	Read the ECC from ECC Register
	eccRegVal.dwECCVal = NF_ECC();
	
	//	Skip first 8 bytes
	for(i=0; i<8; i++){
		ecc0 = NF_DATA_R();
	}
	
	ecc0 = NF_DATA_R();
	ecc1 = NF_DATA_R();
	ecc2 = NF_DATA_R();
	
    NF_nFCE_H();

    if ( !rc && r++ < 3 ) {
        Uart_SendString("FMD_ReadSector: ");
        Uart_SendDWORD(startSectorAddr, TRUE);

        NF_Reset();
        
        for (i = 0; i < 5; i++);   // delay

        rc = TRUE;
        
        goto _retry;
    }
    
	/*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;
	}*/

    return rc;
}


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美婷婷六月丁香综合色| 不卡高清视频专区| 97久久精品人人做人人爽| 日韩免费观看高清完整版| 国产精品国产三级国产aⅴ原创| 奇米影视一区二区三区| 91福利视频在线| 久久久亚洲高清| 国产精品小仙女| 2020国产成人综合网| 丝袜国产日韩另类美女| 欧美无砖专区一中文字| 中文字幕一区二区日韩精品绯色| 韩国一区二区视频| 欧美va天堂va视频va在线| 午夜私人影院久久久久| 51精品秘密在线观看| 天天综合色天天综合色h| 69堂国产成人免费视频| 亚洲高清不卡在线观看| 国产美女精品在线| 不卡电影免费在线播放一区| a4yy欧美一区二区三区| 99久久伊人精品| 亚洲国产欧美另类丝袜| 国产精品久久久一区麻豆最新章节| 国产传媒欧美日韩成人| 亚洲精品视频在线观看网站| 在线观看日韩国产| 国产精品对白交换视频| 亚洲国产欧美在线| 国产精品99久久久久久宅男| 欧美性xxxxxx少妇| 亚洲精品一区二区三区精华液| 国产亚洲欧洲一区高清在线观看| 亚洲色图都市小说| 久草热8精品视频在线观看| 99久久综合色| 久久伊人中文字幕| 五月婷婷激情综合| 色哟哟一区二区在线观看| 国产午夜精品理论片a级大结局| 亚洲国产日韩综合久久精品| 99久久伊人精品| 亚洲国产中文字幕在线视频综合| 日韩中文字幕91| 欧美亚洲综合网| 亚洲欧美一区二区三区孕妇| 国产毛片精品一区| 久久久精品国产免费观看同学| 亚洲.国产.中文慕字在线| 欧美亚洲一区二区在线| 亚洲乱码国产乱码精品精小说| 成人午夜大片免费观看| 中文字幕+乱码+中文字幕一区| 国产乱人伦偷精品视频不卡| 69堂国产成人免费视频| 久久不见久久见免费视频7| 欧美大片在线观看| 国产精品一区一区| 中文字幕的久久| 欧美丝袜第三区| 肉色丝袜一区二区| 日本伊人午夜精品| 蜜桃av一区二区在线观看| 午夜一区二区三区视频| 日本va欧美va精品发布| 久久精品国产亚洲5555| 国产在线精品不卡| 99久久精品国产网站| 91免费国产在线| 成人激情黄色小说| 99久久精品国产毛片| 在线亚洲一区观看| 日韩免费看的电影| 色婷婷综合久久| 国产综合色精品一区二区三区| 国产精品久久久久久久久图文区| 91精品1区2区| 成人激情午夜影院| 国内成人免费视频| 日韩欧美你懂的| 国产精品看片你懂得| 亚洲欧美另类小说| 日韩精品电影在线观看| 国产综合久久久久久鬼色| 国产91在线|亚洲| 色成年激情久久综合| 欧美日本一道本| 欧美高清在线一区二区| 一区二区三区国产| 国产在线看一区| 一本大道久久a久久精二百| 欧美一卡二卡三卡四卡| 国产欧美日韩麻豆91| 天天综合网天天综合色| 成人国产精品免费观看视频| 欧美久久一二三四区| 国产精品久久久久7777按摩 | 久久精品一区二区三区不卡| 亚洲欧洲一区二区在线播放| 麻豆久久久久久久| 欧美三日本三级三级在线播放| 欧美中文一区二区三区| 暴力调教一区二区三区| 欧美一级免费观看| 亚洲精品中文字幕在线观看| 国产在线精品一区二区不卡了 | 亚洲综合激情小说| 国产精品全国免费观看高清 | 不卡在线观看av| 国产高清精品在线| 亚洲精品乱码久久久久| 日韩欧美在线一区二区三区| 日韩电影一二三区| 欧美一级二级三级乱码| 偷拍一区二区三区| 精品日韩成人av| 成人丝袜18视频在线观看| 国产色婷婷亚洲99精品小说| 国产一区二区福利| 国产精品色呦呦| 欧美在线看片a免费观看| 日韩福利电影在线| 久久久一区二区三区| av一区二区三区在线| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美日韩国产小视频在线观看| 亚洲高清免费观看高清完整版在线观看| 欧美在线观看18| 国产在线视视频有精品| 亚洲欧美色综合| 国产日韩欧美精品在线| 色老头久久综合| 粉嫩av一区二区三区在线播放| 亚洲免费在线视频一区 二区| 欧美一区二区视频观看视频| 国产aⅴ综合色| 国产一二精品视频| 蜜臀99久久精品久久久久久软件| 粉嫩av一区二区三区| 国产精品免费免费| 国产精品成人在线观看| 欧美系列日韩一区| 麻豆精品在线观看| 精品美女一区二区| 国产成人综合网站| 3d动漫精品啪啪| 国产日产欧美一区二区三区| 综合精品久久久| 美腿丝袜一区二区三区| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | eeuss鲁片一区二区三区在线看| 激情成人综合网| 国产成人8x视频一区二区| 亚洲资源在线观看| 久久这里都是精品| 欧美成人猛片aaaaaaa| 欧美三区在线观看| 欧美午夜一区二区三区免费大片| 视频一区中文字幕国产| 性做久久久久久久免费看| 国产精品不卡在线观看| 中文字幕制服丝袜成人av| 欧美一级久久久| 国产日韩欧美一区二区三区乱码| 久久综合资源网| 国产精品欧美一区喷水| 日韩欧美色电影| 亚洲国产精品精华液2区45| 精品美女一区二区| 久久综合色8888| 日韩亚洲欧美成人一区| 日韩欧美专区在线| 精品区一区二区| 国产亚洲精品bt天堂精选| 久久美女艺术照精彩视频福利播放| 在线观看三级视频欧美| 91网站黄www| 久久久久亚洲蜜桃| 久久精品一二三| 蜜臀av性久久久久蜜臀aⅴ流畅| 精品亚洲欧美一区| 欧美日本一区二区三区四区| 久久久国产午夜精品| 亚洲大型综合色站| 成人看片黄a免费看在线| 国内精品久久久久影院色| 成人免费视频免费观看| 在线播放视频一区| 欧美少妇性性性| 中文字幕av一区二区三区| 激情六月婷婷久久| 3d动漫精品啪啪一区二区竹菊| 国产一区二区三区| 亚洲成人资源在线| 中文字幕在线一区| 日韩视频在线观看一区二区| 国产一区视频在线看| 久久久久久久久久电影|