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

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

?? nand.c

?? wince bootlaoaer for 2440
?? 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); }
#define NF_RDDATA() 	(rNFDATA)
#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

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

//
//  Reset the chip
//
void NF_Reset()
{                       
    NF_CE_L();
	NF_CLEAR_RB();
    NF_CMD(CMD_RESET);  
    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;
}

#ifdef NF_READID
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);

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

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

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

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

//	for ( i = 0; i < 512; i++ )
//		Uart_SendByte(*(pSectorBuff+i));


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

    return rc;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美高清dvd| 欧美老女人在线| 亚洲成av人片| 亚洲国产精品传媒在线观看| 欧美亚洲综合一区| 国产一区二区电影| 奇米在线7777在线精品| 亚洲欧美日韩综合aⅴ视频| 精品国产91乱码一区二区三区| 91丨porny丨国产| 国产乱码精品1区2区3区| 午夜电影网一区| 国产精品成人一区二区艾草 | 国产农村妇女毛片精品久久麻豆 | 在线视频国内一区二区| 国产精品亚洲视频| 蜜桃av一区二区在线观看| 一区二区三区中文字幕在线观看| 2019国产精品| 337p亚洲精品色噜噜狠狠| 色婷婷久久久久swag精品 | 中文字幕一区三区| 国产亚洲成av人在线观看导航| 7777女厕盗摄久久久| 欧洲国内综合视频| 99久久精品免费看国产免费软件| 国模套图日韩精品一区二区| 婷婷综合五月天| 无码av免费一区二区三区试看| 亚洲视频在线一区| 亚洲色欲色欲www| 国产精品美女一区二区三区| 久久久久久久久久电影| 精品国产乱码久久久久久久久| 91麻豆精品国产无毒不卡在线观看| 在线免费观看日本欧美| 在线观看日韩一区| 欧美午夜宅男影院| 欧美日韩美少妇| 欧美三级视频在线播放| 欧美在线综合视频| 欧美日韩另类一区| 51久久夜色精品国产麻豆| 7777精品伊人久久久大香线蕉完整版 | 国产亚洲精品久| 欧美激情资源网| 国产精品视频第一区| 中文字幕国产一区二区| 成人免费一区二区三区在线观看 | 成人欧美一区二区三区1314| 亚洲国产精品精华液ab| 日本一区二区视频在线观看| 国产日韩欧美亚洲| 国产精品视频你懂的| 亚洲欧洲精品一区二区精品久久久| 国产精品久久久久一区| 亚洲精品视频在线看| 亚洲国产精品久久久久秋霞影院| 亚洲一区二区av电影| 免费成人在线观看| 国产精品资源在线看| 成人av综合在线| 色视频欧美一区二区三区| 欧美日韩1234| 久久久久久电影| 国产精品久久毛片av大全日韩| 亚洲靠逼com| 欧美96一区二区免费视频| 国产高清在线观看免费不卡| 91麻豆产精品久久久久久| 欧美三区在线观看| 久久久久亚洲综合| 一区二区视频免费在线观看| 蜜臀av性久久久久蜜臀aⅴ| 国产成人一区在线| 欧美午夜理伦三级在线观看| 欧美一二三区在线| 国产精品美女久久久久久久久| 亚洲国产视频在线| 国产精品自在在线| 在线视频你懂得一区二区三区| 欧美mv日韩mv国产网站| 亚洲欧洲日韩一区二区三区| 日本欧美一区二区在线观看| 国产乱码精品一区二区三区忘忧草 | 中文在线一区二区| 亚洲综合精品久久| 紧缚奴在线一区二区三区| 波多野结衣精品在线| 91精品国产综合久久久久久久| 久久夜色精品国产噜噜av| 亚洲精品综合在线| 国产一区二区导航在线播放| 精品视频一区二区不卡| 国产精品女同一区二区三区| 亚洲v精品v日韩v欧美v专区| 成人一区二区三区视频在线观看| 欧美日韩国产首页| 中文字幕在线视频一区| 麻豆一区二区在线| 欧美日韩一区二区三区在线| 亚洲国产精品黑人久久久| 蜜臀av一区二区在线免费观看| 972aa.com艺术欧美| 久久婷婷色综合| 日韩在线a电影| 欧美羞羞免费网站| 国产精品嫩草99a| 激情文学综合插| 91精品国产黑色紧身裤美女| 亚洲欧美视频在线观看视频| 国产精品一区2区| 欧美一区二区女人| 亚洲自拍偷拍图区| 91丨九色丨蝌蚪富婆spa| 久久久久国产精品厨房| 免费在线一区观看| 7878成人国产在线观看| 亚洲国产欧美另类丝袜| 一本一道波多野结衣一区二区| 国产亚洲精品aa| 国产风韵犹存在线视精品| 精品久久久久一区二区国产| 日韩av一区二区三区四区| 欧美三级电影一区| 亚洲成人av福利| 欧美日韩在线精品一区二区三区激情| 日韩一区在线免费观看| 国产成人自拍网| 久久精品夜夜夜夜久久| 国内精品久久久久影院色 | 中文字幕在线观看一区二区| 国产传媒一区在线| 中文字幕av免费专区久久| 成人免费看视频| 18成人在线视频| 日本韩国欧美一区二区三区| 国产精品电影院| 色综合欧美在线视频区| 亚洲精品免费在线观看| 欧美伊人久久久久久午夜久久久久| 日韩一区中文字幕| 在线观看日韩国产| 石原莉奈在线亚洲三区| 555www色欧美视频| 久久黄色级2电影| 久久综合色天天久久综合图片| 国产原创一区二区三区| 欧美国产1区2区| 91麻豆国产在线观看| 亚洲国产精品久久久久秋霞影院| 欧美日韩精品一二三区| 久久国产剧场电影| 欧美激情中文不卡| 色婷婷久久久亚洲一区二区三区 | 欧美日本一区二区| 久久精品国产一区二区三| 久久久久亚洲蜜桃| 91丨porny丨首页| 日韩电影免费一区| 久久综合九色欧美综合狠狠| 国产在线精品免费| 自拍偷自拍亚洲精品播放| 欧美主播一区二区三区| 狂野欧美性猛交blacked| 欧美激情自拍偷拍| 欧美亚洲综合色| 国产一区二区91| 一区二区欧美精品| 欧美成人性福生活免费看| 成人高清免费在线播放| 性久久久久久久| 国产三级一区二区三区| 一本大道av一区二区在线播放 | 免费人成精品欧美精品| 国产欧美日产一区| 欧美女孩性生活视频| 国产大陆精品国产| 午夜成人免费视频| 国产欧美一区二区三区沐欲| 欧美视频一二三区| 国产成人综合视频| 日韩精品一区第一页| 国产精品色在线| 欧美一级生活片| 99国产精品久久久久| 麻豆精品新av中文字幕| 一区二区三区中文字幕| 久久久久综合网| 7799精品视频| 色94色欧美sute亚洲线路一久 | 久久99热99| 亚洲一区二区四区蜜桃| 精品av久久707| 欧美在线短视频| 成人黄色免费短视频| 久久国产精品99精品国产| 一区二区三区四区高清精品免费观看| 久久婷婷色综合| 欧美一级片在线观看|