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

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

?? nand.c

?? s3c2440 nboot啟動(dòng)源碼 SDRAM=64M flash=NAND flash 64M
?? C
字號(hào):
//
// 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;
    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:
    //  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);
    NF_MECC_Lock();

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

    return rc;
}


?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲aⅴ怡春院| 国产精品影视天天线| 日韩免费高清电影| 91美女在线观看| 国产精品原创巨作av| 亚洲香蕉伊在人在线观| 久久精品人人做人人爽97| 欧美日韩一区不卡| 93久久精品日日躁夜夜躁欧美| 日韩一区精品视频| 亚洲久草在线视频| 日本一区二区三区四区| 制服.丝袜.亚洲.中文.综合| 91理论电影在线观看| 国产主播一区二区三区| 午夜精品久久久久久不卡8050| 国产精品天美传媒沈樵| 久久久久久久免费视频了| 91精品国产综合久久国产大片 | 国产**成人网毛片九色| 日韩中文欧美在线| 亚洲精品免费一二三区| 国产精品天天看| 欧美激情一区二区三区全黄| 日韩亚洲电影在线| 欧美男同性恋视频网站| 欧美色综合天天久久综合精品| 99视频有精品| www.在线成人| 972aa.com艺术欧美| 成人精品一区二区三区四区| 国产99久久久国产精品| 国产剧情一区二区| 国产美女精品在线| 国产精品一级二级三级| 久久国产精品露脸对白| 麻豆中文一区二区| 蜜桃91丨九色丨蝌蚪91桃色| 蜜臀a∨国产成人精品| 麻豆一区二区三| 久久精工是国产品牌吗| 美脚の诱脚舐め脚责91| 久久精品国产**网站演员| 九一九一国产精品| 极品少妇一区二区三区精品视频| 久草精品在线观看| 国产麻豆91精品| 国产成人精品综合在线观看| 国产精品一区二区三区网站| 国产精品1024久久| 国产精品乡下勾搭老头1| 国产mv日韩mv欧美| 波多野结衣亚洲| 色婷婷久久久久swag精品 | 欧美丝袜丝nylons| 欧美日韩一区成人| 日韩欧美一级精品久久| 2023国产精品自拍| 国产精品免费av| 伊人夜夜躁av伊人久久| 亚洲国产精品久久艾草纯爱| 三级在线观看一区二区| 久久99精品国产.久久久久| 国产乱码精品1区2区3区| 国产精品亚洲人在线观看| 成人免费高清在线| 91麻豆国产自产在线观看| 欧美日韩国产综合草草| 精品三级在线看| 国产免费成人在线视频| 亚洲免费毛片网站| 丝袜诱惑亚洲看片| 国产在线一区二区综合免费视频| 不卡视频一二三四| 欧美日韩免费一区二区三区| 欧美成人三级在线| 日韩理论片网站| 午夜精品一区二区三区电影天堂| 蜜臀99久久精品久久久久久软件| 国产v日产∨综合v精品视频| 在线观看亚洲一区| 欧美大黄免费观看| 亚洲视频在线观看一区| 捆绑紧缚一区二区三区视频| 成人午夜免费av| 欧美三级三级三级爽爽爽| 久久综合久久综合九色| 亚洲免费高清视频在线| 久久www免费人成看片高清| 99精品久久99久久久久| 在线成人av网站| 欧美高清在线精品一区| 丝袜诱惑亚洲看片| 播五月开心婷婷综合| 91麻豆精品国产91| 国产精品热久久久久夜色精品三区| 亚洲午夜一区二区三区| 福利一区二区在线观看| 91精品国产91久久久久久一区二区 | 亚洲愉拍自拍另类高清精品| 韩国av一区二区三区在线观看| 色综合久久久网| 久久影院电视剧免费观看| 一区二区三区在线播放| 国产剧情在线观看一区二区| 欧美日韩高清影院| 亚洲欧美色一区| 国产精品一卡二卡在线观看| 717成人午夜免费福利电影| 中文字幕一区二区三| 久久av老司机精品网站导航| 欧美性猛交xxxx黑人交| 国产精品国产a| 激情综合色综合久久| 欧美精品日日鲁夜夜添| 洋洋av久久久久久久一区| 成人av免费在线播放| 久久久久久久久久久久久夜| 蜜芽一区二区三区| 欧美精品一级二级| 亚洲精品写真福利| 成人精品一区二区三区中文字幕| 久久色在线观看| 日韩精品1区2区3区| 欧美亚洲国产怡红院影院| 国产精品国产三级国产普通话99| 国产综合色在线视频区| 日韩午夜电影av| 天天操天天色综合| 欧美巨大另类极品videosbest | 91.com视频| 天堂久久久久va久久久久| 欧美午夜精品一区| 一区二区三区免费看视频| 91网站黄www| 中文字幕一区二区三区蜜月 | 6080yy午夜一二三区久久| 亚洲伊人伊色伊影伊综合网| 色综合久久久久久久久| 亚洲欧洲av色图| 91免费小视频| 亚洲免费观看高清完整版在线观看 | 免费美女久久99| 日韩欧美色综合| 久久不见久久见免费视频7| 精品国产一区二区三区久久影院| 久久国产麻豆精品| 26uuu精品一区二区| 国产盗摄一区二区三区| 中文av字幕一区| 91网页版在线| 午夜精品aaa| 欧美zozo另类异族| 国产精品正在播放| 1024成人网| 在线观看日韩av先锋影音电影院| 亚洲综合成人在线视频| 欧美日韩国产一区二区三区地区| 日韩高清电影一区| 精品国产人成亚洲区| 国产91在线|亚洲| 亚洲免费三区一区二区| 制服.丝袜.亚洲.中文.综合| 久久99精品久久久| 最新国产の精品合集bt伙计| 色噜噜久久综合| 美女脱光内衣内裤视频久久网站 | 欧美性猛片aaaaaaa做受| 欧美精品在线视频| 国产精品小仙女| 亚洲日本青草视频在线怡红院| 欧美日韩亚洲高清一区二区| 美女视频黄久久| 中文字幕综合网| 91精品国产一区二区人妖| 国产精品一区二区不卡| 一区二区三区四区国产精品| 日韩西西人体444www| 成人理论电影网| 亚洲国产精品久久一线不卡| 久久影院午夜论| 在线观看成人小视频| 国产在线精品一区二区夜色| 亚洲欧洲成人av每日更新| 日韩一区二区在线观看| 成人av第一页| 美女任你摸久久| 亚洲摸摸操操av| 久久久国产午夜精品| 欧美三级日韩三级国产三级| 国产91丝袜在线观看| 五月激情综合色| 亚洲三级电影网站| 精品处破学生在线二十三| 欧洲在线/亚洲| 不卡免费追剧大全电视剧网站| 老司机午夜精品99久久| 亚洲综合一二区| 国产精品欧美一级免费| 精品奇米国产一区二区三区|