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

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

?? nand.c

?? 三星公司的S3C2440uboot代碼(好東西!)
?? 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;
    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;
}


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二三区| 中文久久乱码一区二区| 亚洲一区在线视频观看| 91激情五月电影| 亚洲最大色网站| 7777精品伊人久久久大香线蕉经典版下载| 午夜伊人狠狠久久| 精品第一国产综合精品aⅴ| 韩国v欧美v亚洲v日本v| 中文字幕av一区二区三区| 99精品视频在线免费观看| 亚洲综合无码一区二区| 欧美一区日韩一区| 国产精品一区二区三区网站| 国产精品国产三级国产aⅴ无密码| 99精品久久99久久久久| 午夜电影一区二区| 国产欧美日韩另类视频免费观看| 2024国产精品| 不卡视频一二三四| 亚洲成人精品一区二区| 久久久久久久久久久久电影| 成人97人人超碰人人99| 午夜精品久久久久久久蜜桃app| 日韩欧美一级二级三级久久久| 国产精品一二三区| 亚洲一区二区三区四区五区黄| 精品国产一区二区在线观看| av毛片久久久久**hd| 男女男精品视频网| 亚洲色图在线看| 制服.丝袜.亚洲.中文.综合| 丁香婷婷综合网| 日韩综合一区二区| 最近中文字幕一区二区三区| 欧美一级视频精品观看| www.成人网.com| 久久国产剧场电影| 亚洲综合视频网| 国产午夜精品福利| 欧美日韩三级视频| www.一区二区| 国产一区激情在线| 婷婷久久综合九色综合绿巨人 | 蜜桃在线一区二区三区| 国产精品成人免费| 亚洲精品一区在线观看| 欧美日本一道本在线视频| 成人国产亚洲欧美成人综合网 | 免费成人在线播放| 一区二区三区四区激情| 中文字幕电影一区| 久久综合中文字幕| 日韩午夜在线播放| 欧美日韩免费不卡视频一区二区三区 | 欧美精品在线观看播放| 色综合久久88色综合天天6| 激情小说亚洲一区| 麻豆国产欧美一区二区三区| 亚洲成av人片在www色猫咪| 亚洲欧美二区三区| 中文字幕亚洲综合久久菠萝蜜| 久久久一区二区三区捆绑**| 69av一区二区三区| 91精品婷婷国产综合久久性色 | 日韩黄色片在线观看| 一区二区三区中文字幕| ...中文天堂在线一区| 亚洲国产精品二十页| 久久夜色精品国产噜噜av| 亚洲国产成人91porn| 一区精品在线播放| 国产精品久久久久久久久免费丝袜| 精品国产乱码久久| 久久综合色天天久久综合图片| 欧美电视剧免费观看| 欧美一级搡bbbb搡bbbb| 日韩精品一区二区三区中文不卡 | 亚洲国产精品v| 国产午夜精品一区二区三区嫩草| 欧美精品一区二区高清在线观看| 日韩一区二区三区免费看| 日韩欧美国产小视频| 日韩女优av电影在线观看| 精品久久久久久无| 久久久亚洲精华液精华液精华液| 国产色91在线| 国产精品久久久久一区二区三区| 中文字幕亚洲精品在线观看| 亚洲欧美日韩国产综合| 亚洲图片有声小说| 免费在线观看一区| 国产一区二区福利| 不卡一区二区中文字幕| 欧美中文字幕亚洲一区二区va在线| 欧美午夜片在线观看| 555夜色666亚洲国产免| 欧美大片一区二区| 国产精品视频观看| 艳妇臀荡乳欲伦亚洲一区| 日韩综合小视频| 国内外精品视频| 成人app软件下载大全免费| 色婷婷亚洲精品| 日韩亚洲欧美一区二区三区| 久久午夜老司机| 亚洲精品免费播放| 日本中文一区二区三区| 国产成人av资源| 欧美性猛交xxxx乱大交退制版| 日韩午夜在线影院| 国产精品麻豆网站| 日韩精品乱码免费| 成人av小说网| 欧美一区二视频| 亚洲欧洲美洲综合色网| 日韩二区三区在线观看| 成人综合婷婷国产精品久久蜜臀| 欧美视频一区二区在线观看| 久久一区二区三区国产精品| 亚洲国产欧美日韩另类综合| 国产一区二区影院| 欧美色国产精品| 国产精品色在线观看| 日韩精品一级中文字幕精品视频免费观看 | 色综合天天综合网国产成人综合天 | 日韩欧美高清一区| 亚洲欧洲日本在线| 久久99国产精品成人| 色综合网色综合| 久久久午夜电影| 日av在线不卡| 日本道色综合久久| 国产午夜精品福利| 美日韩一区二区三区| 色域天天综合网| 国产亚洲成aⅴ人片在线观看 | 337p亚洲精品色噜噜狠狠| 国产色91在线| 国内一区二区视频| 日韩一级完整毛片| 亚洲伊人伊色伊影伊综合网| 成人午夜电影网站| 久久综合九色综合久久久精品综合 | 成人国产精品免费观看视频| 日韩欧美的一区| 亚洲1区2区3区4区| 在线观看不卡视频| 日韩美女视频一区| 成人av网站在线| 久久精品综合网| 精品一区二区av| 日韩免费高清视频| 天天操天天综合网| 欧美在线制服丝袜| 一区二区三区欧美激情| 99re这里只有精品首页| 国产精品对白交换视频| 国产91综合网| 中文字幕精品三区| 成人精品免费网站| 国产精品第一页第二页第三页| 国产伦精品一区二区三区免费| 精品欧美乱码久久久久久| 欧美a级理论片| 欧美大片顶级少妇| 国内外成人在线| 久久久久久99久久久精品网站| 激情偷乱视频一区二区三区| 亚洲精品一区二区三区福利| 激情综合网天天干| 国产亚洲精久久久久久| 成人性生交大片免费看视频在线| 中文字幕精品综合| 91色porny| 亚洲成av人综合在线观看| 在线观看www91| 日韩福利电影在线| www成人在线观看| 成人午夜又粗又硬又大| 亚洲欧美另类图片小说| 欧美中文字幕亚洲一区二区va在线| 亚洲成人高清在线| 欧美大白屁股肥臀xxxxxx| 国产一区在线观看视频| 欧美韩日一区二区三区四区| 波多野结衣亚洲一区| 亚洲综合区在线| 日韩一级在线观看| 成人午夜精品在线| 亚洲一区二区中文在线| 日韩一级成人av| 91麻豆精品国产综合久久久久久 | 久久精品欧美日韩精品| 波多野结衣一区二区三区| 亚洲午夜久久久久中文字幕久| 欧美一区二区三区免费视频 | 日韩亚洲欧美在线观看| 国产精品性做久久久久久| 亚洲美女少妇撒尿|