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

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

?? k9s1208.c

?? 優龍板的nand flash驅動程序
?? C
字號:
//====================================================================
// File Name : k9s1208.c
// Function  : SmartMedia SAMSUNG 64MB (K9S1208) Test Program
// Program   : Weon-Tark Kang (Tark)
// Modify    : On-Pil Shin (SOP)
// Date      : October 23, 2002
// Version   : 0.0
// History
//   0.0 : Programming start -> Tark
//       (20030324) : Added K9S1208 Erase -> SOP
//====================================================================

#include <string.h>
#include "def.h"
#include "option.h"
#include "2410addr.h"
#include "2410lib.h"
#include "2410slib.h" 

#define BAD_CHECK   (1)
#define ECC_CHECK   (0)

//*************** H/W dependent functions ***************
void __RdPage528(U8 *pPage);
void __WrPage528(U8 *pPage);

static U16 NF_CheckId(void);
static int NF_EraseBlock(U32 blockNum);
static int NF_ReadPage(U32 block,U32 page,U8 *buffer);
static int NF_WritePage(U32 block,U32 page,U8 *buffer);
    //buffer size is 512 bytes
static int NF_IsBadBlock(U32 block);
static int NF_MarkBadBlock(U32 block);
static void NF_Reset(void);
static void NF_Init(void);
//*******************************************************

int DownloadData(void);

static void InputTargetBlock(void);

static U32 srcAddress;
static U32 targetBlock;     // Block number (0 ~ 4095)
static U32 targetSize;      // Total byte size 

U32 downloadAddress;
U32 downloadProgramSize=0x0;

void K9S1208_Program(void)
{
//    unsigned long interrupt_reservoir;
    int i;
    int programError=0;
    U8 *srcPt,*saveSrcPt;
    U32 blockIndex;

    downloadAddress=0x31000000;
    Uart_Printf("\n[SMC(K9S1208V0M) NAND Flash writing program]\n");
    //Uart_Printf("The program buffer: 0x30100000~0x31ffffff\n");
/*#if 0
    if(!DownloadData())
    {
        Uart_Printf("Download Fail\n");
        return;
    }
#endif  */

    NF_Init();


    rINTMSK = BIT_ALLMSK;   
    targetSize=downloadProgramSize;
    if(targetSize==0)
    {
        srcAddress=0x31000000; 
        Uart_Printf("the data must be downloaded using ICE from %xh\n",srcAddress);         
    }
    else 
        srcAddress=downloadAddress+4; //to discard the data head for the size
        
    InputTargetBlock();

    Uart_Printf("source base address(0x3100000x)=0x%x\n",srcAddress);
    Uart_Printf("target start block number      =%d\n",targetBlock);
    Uart_Printf("target size        (0x4000*n)  =0x%x\n",targetSize);

    srcPt=(U8 *)srcAddress;
    blockIndex=targetBlock;
    while(1)
    {
        saveSrcPt=srcPt;    

        #if BAD_CHECK       
            if(NF_IsBadBlock(blockIndex))   // 1:bad 0:good
            {
                blockIndex++;   // for next block
                continue;
            }
        #endif
        
        if(!NF_EraseBlock(blockIndex))
        {
            blockIndex++;   // for next block
            continue;
        }
        
        for(i=0;i<32;i++)
        {
            if(!NF_WritePage(blockIndex,i,srcPt))// block num, page num, buffer
            {
                programError=1;
                break;
            }
            #if ECC_CHECK    
                if(!NF_ReadPage(blockIndex,i,srcPt))
                {
                    Uart_Printf("ECC Error(block=%d,page=%d!!!\n",blockIndex,i);
                }
            #endif      
            srcPt+=512; // Increase buffer addr one pase size
            Uart_Printf(".");
            if((U32)srcPt>=(srcAddress+targetSize)) // Check end of buffer
                break;  // Exit for loop
        }
        if(programError==1)
        {
            blockIndex++;
            srcPt=saveSrcPt;
            programError=0;
            continue;
        }
        if((U32)srcPt>=(srcAddress+targetSize))
            break;  // Exit while loop
        blockIndex++;
    }
}

//==================================================================================
void K9S1208_Erase(void)
{
    int i;
    U32 blockIndex=0;

    Uart_Printf("\n[ SMC(K9S1208V0M) NAND Flash Erase Program ]\n");
    Uart_Printf("\nNow NAND Flash Erasing ....\n");    

    NF_Init();

    rINTMSK = BIT_ALLMSK;   

    for(blockIndex=0;blockIndex<4096;blockIndex++)
    {
        #if BAD_CHECK       
            if(NF_IsBadBlock(blockIndex))   // 1:bad 0:good
            {
                blockIndex++;   // for next block
                continue;
            }
        #endif
        
        if(!NF_EraseBlock(blockIndex))
        {
            blockIndex++;   // for next block
            continue;
        }       
    }
    Uart_Printf("\nSMC(K9S1208V0M) NAND Flash Erase Completed !!!\n");    
}


//==================================================================================

static void InputTargetBlock(void)
{
    Uart_Printf("\nSource size:0h~%xh\n",downloadProgramSize);
    Uart_Printf("\nAvailable target block number: 0~4095\n");
    Uart_Printf("Input target block number:");
    targetBlock=Uart_GetIntNum();   // Block number(0~4095)
    if(targetSize==0)
    {
        Uart_Printf("Input target size(0x4000*n):");
        targetSize=Uart_GetIntNum();    // Total byte size
    }
}


void K9S1208_PrintBadBlockNum(void)
{
    int i;
    U16 id;

    Uart_Printf("\n[SMC(K9S1208V0M) NAND Flash bad block check]\n");
    
    NF_Init();
    id=NF_CheckId();
    Uart_Printf("ID=%x(0xec76)\n",id);
    if(id!=0xec76)
    return;
    
    for(i=0;i<4096;i++)
    {
    NF_IsBadBlock(i);   // Print bad block
    }
}


void K9S1208_PrintBlock(void)// Printf one page
{
    int i,j;
    U16 id;
    U32 block,page;
    U8  buffer[512];

    Uart_Printf("\n[SMC(K9S1208V0M) NAND Flash block read]\n"); 
    
    NF_Init();
    id=NF_CheckId();
    Uart_Printf("ID=%x(0xec76)\n",id);
    if(id!=0xec76)
    return;

    Uart_Printf("Input target block number(0x) :");
    block=Uart_GetIntNum();
    Uart_Printf("Input target page number(0x) :");   
    page=Uart_GetIntNum();
   Uart_Printf("block=%x,page=%x\n",block,page);
    NF_ReadPage(block,page,buffer);
    Uart_Printf("block=%x,page=%x\n",block,page);
    for(j=0;j<512;j++)
    {
        if(j%16==0)
        Uart_Printf("\n%3xh:",j);
        Uart_Printf("%02x ",buffer[j]);
    }
    Uart_Printf("\n");      
}


//*************************************************
//*************************************************
//**           H/W dependent functions           **
//************************************************* 
//*************************************************

//The code is made for bi-endian mode

// block0: reserved for boot strap
// block1~4095: used for OS image
// badblock SE: xx xx xx xx xx 00 ....
// good block SE: ECC0 ECC1 ECC2 FF FF FF ....

#define WRITEVERIFY  (0)  //verifing is enable at writing.

/*
#define FC_CMD()    {rPDATA|=CLE;rPDATA&=~(ALE|CE);}
#define FC_ADDR()   {rPDATA|=ALE;rPDATA&=~(CLE|CE);}
#define FC_DATA()   {rPDATA&=~(ALE|CLE|CE);}
#define FC_INACTIVE() {rPDATA|=CE;rPDATA&=~(ALE|CLE);}
*/

#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)));} 
        //wait tWB and check F_RNB pin.   

#define ID_K9S1208V0M   0xec76

#if 1
// HCLK=100Mhz
#define TACLS       0  //1clk(0ns) 
#define TWRPH0      3  //3clk(25ns)
#define TWRPH1      0  //1clk(10ns)  //TACLS+TWRPH0+TWRPH1>=50ns
#else
// HCLK=50Mhz
#define TACLS       0  //1clk(0ns)
#define TWRPH0      1  //2clk(25ns)
#define TWRPH1      0  //1clk(10ns)
#endif


static U8 seBuf[16]={0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff};

// 1block=(512+16)bytes x 32pages
// 4096block

// A[23:14][13:9]
//  block   page

static int NF_EraseBlock(U32 block)
{
    U32 blockPage=(block<<5);
    int i;

#if BAD_CHECK
    if(NF_IsBadBlock(block))
    	return 0;
#endif

    NF_nFCE_L();
    
    NF_CMD(0x60);   // Erase one block 1st command

    NF_ADDR(blockPage&0xff);        // Page number=0
    NF_ADDR((blockPage>>8)&0xff);   
    NF_ADDR((blockPage>>16)&0xff);

    NF_CMD(0xd0);   // Erase one blcok 2nd command
    
   for(i=0;i<10;i++); //wait tWB(100ns)//??????

    NF_WAITRB();    // Wait tBERS max 3ms.
    NF_CMD(0x70);   // Read status command

    if (NF_RDDATA()&0x1) // Erase error
    {   
        NF_nFCE_H();
    	Uart_Printf("[ERASE_ERROR:block#=%d]\n",block);
    	NF_MarkBadBlock(block);
    	return 0;
    }
    else 
    {
        NF_nFCE_H();
        return 1;
    }
}


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


static int NF_MarkBadBlock(U32 block)
{
    int i;
    U32 blockPage=(block<<5);
 
    seBuf[0]=0xff;
    seBuf[1]=0xff;    
    seBuf[2]=0xff;    
    seBuf[5]=0x44;   // Bad blcok mark=0
    
    NF_nFCE_L(); 
    NF_CMD(0x50);   //????
    NF_CMD(0x80);   // Write 1st command
    
    NF_ADDR(0x0);           // The mark of bad block is 
    NF_ADDR(blockPage&0xff);        // marked 5th spare array 
    NF_ADDR((blockPage>>8)&0xff);   // in the 1st page.
    NF_ADDR((blockPage>>16)&0xff);  //
    
    for(i=0;i<16;i++)
    {
    NF_WRDATA(seBuf[i]);    // Write spare array
    }

    NF_CMD(0x10);   // Write 2nd command
    
    for(i=0;i<10;i++);  //tWB = 100ns. ///???????

    NF_WAITRB();      // Wait tPROG(200~500us)
  
    NF_CMD(0x70);
    
    for(i=0;i<3;i++);  //twhr=60ns////??????
    
    if (NF_RDDATA()&0x1) // Spare arrray write error
    {   
        NF_nFCE_H();
        Uart_Printf("[Program error is occurred but ignored]\n");
    }
    else 
    {
        NF_nFCE_H();
    }

    Uart_Printf("[block #%d is marked as a bad block]\n",block);
    return 1;
}


static int NF_ReadPage(U32 block,U32 page,U8 *buffer)
{									//將某page的數據讀取到制定的內存緩沖區
    int i;
    unsigned int blockPage;
    U8 ecc0,ecc1,ecc2;
    U8 *bufPt=buffer;
    U8 se[16];     
    
    page=page&0x1f;
    blockPage=(block<<5)+page;
    NF_RSTECC();    // Initialize ECC
    
    NF_nFCE_L();    
    NF_CMD(0x00);   // Read command
    NF_ADDR(0);     // Column = 0
    NF_ADDR(blockPage&0xff);        //
    NF_ADDR((blockPage>>8)&0xff);   // Block & Page num.
    NF_ADDR((blockPage>>16)&0xff);  //

    for(i=0;i<10;i++); //wait tWB(100ns)/////??????
    
    NF_WAITRB();    // Wait tR(max 12us)直到flash memory ready to operate
    for(i=0;i<512;i++)
    {//當我們給定了讀取的起始位置后,讀操作將從該位置開始,連續讀取到本Page的最后一個Byte為止
        *bufPt++=NF_RDDATA();   // Read one page一字節字節地讀,讀到內存中

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区在线免费观看| 午夜精品视频一区| 亚洲午夜日本在线观看| 日韩二区在线观看| 成人精品高清在线| 91麻豆精品国产91久久久资源速度 | 国产精品你懂的| 亚洲主播在线播放| 韩国av一区二区| 91精品1区2区| 久久久久久久免费视频了| 亚洲人成网站色在线观看 | 欧美日韩一本到| 精品第一国产综合精品aⅴ| 日韩一区有码在线| 精品一区二区三区免费毛片爱| 成人丝袜高跟foot| 日韩精品自拍偷拍| 一区二区三区久久久| 国产九色精品成人porny| 欧美日韩黄色一区二区| 精品国产乱码久久久久久图片| 国产精品久久久久久久久免费相片| 亚洲精品国产品国语在线app| 久久电影网站中文字幕 | 韩国成人在线视频| 日本韩国精品一区二区在线观看| 国产精品嫩草久久久久| 成人综合日日夜夜| 国产欧美一区二区精品秋霞影院| 日本一道高清亚洲日美韩| 色老头久久综合| 国产精品高清亚洲| 国产精品一区二区久久精品爱涩 | 日韩av电影天堂| 91美女片黄在线观看91美女| 久久美女艺术照精彩视频福利播放| 午夜精品一区在线观看| 97久久人人超碰| 国产精品情趣视频| 国产精品中文字幕一区二区三区| 欧美一区国产二区| 午夜国产精品一区| 欧美在线观看一区| 中文字幕免费不卡| 国产精品资源在线观看| 久久综合色8888| 韩国精品免费视频| 日本一区二区三区在线不卡| 国产做a爰片久久毛片| 久久人人爽爽爽人久久久| 老鸭窝一区二区久久精品| 日韩一区二区三区视频在线| 免费成人美女在线观看| 欧美大胆一级视频| 国内欧美视频一区二区| 亚洲丝袜美腿综合| 一本大道久久a久久综合婷婷| 国产精品入口麻豆九色| 91同城在线观看| 亚洲综合视频网| 欧美一级精品在线| 国产成人8x视频一区二区| 亚洲欧洲精品一区二区三区 | 91影视在线播放| 综合久久久久久久| 成人免费视频视频在线观看免费 | 亚洲乱码中文字幕| 91成人国产精品| 日本亚洲三级在线| 久久综合九色综合欧美亚洲| 色婷婷综合久久久中文一区二区 | 在线播放欧美女士性生活| 日韩精品一卡二卡三卡四卡无卡| 日韩一级欧美一级| 岛国av在线一区| 一区二区三区成人| 久久日一线二线三线suv| 91在线你懂得| 日本vs亚洲vs韩国一区三区二区 | 久久精品国产免费看久久精品| 欧美精品一区二区精品网| 成人福利视频在线看| 洋洋av久久久久久久一区| 精品蜜桃在线看| 播五月开心婷婷综合| 丝袜亚洲另类欧美| 国产精品毛片高清在线完整版 | 精品无人码麻豆乱码1区2区| 欧美激情中文字幕| 欧美日韩另类一区| 色吧成人激情小说| 国产成人在线看| 亚洲一区二区三区在线看| 久久丝袜美腿综合| 欧美嫩在线观看| 99久久亚洲一区二区三区青草| 五月婷婷久久丁香| 最新国产成人在线观看| 精品久久久久久无| 欧美日韩不卡一区二区| 97国产精品videossex| 毛片av一区二区三区| 一区二区三区精品在线| 久久精品免视看| 欧美一区二区三区电影| 91丨国产丨九色丨pron| 国产乱人伦偷精品视频不卡| 亚洲va中文字幕| 国产欧美中文在线| 精品国产一区二区亚洲人成毛片| 91精品91久久久中77777| 成人在线综合网站| 国产精品白丝jk白祙喷水网站| 三级精品在线观看| 亚洲丰满少妇videoshd| 1000精品久久久久久久久| 国产精品青草久久| 日本一区二区综合亚洲| 久久久亚洲欧洲日产国码αv| 欧美一区二视频| 制服丝袜激情欧洲亚洲| 欧美日韩免费电影| 欧美三级欧美一级| 欧美日韩国产精品成人| 欧美私人免费视频| 色婷婷精品久久二区二区蜜臀av| 国产一区二区三区久久久 | 不卡区在线中文字幕| 国产精品一级在线| 国产伦精品一区二区三区免费| 免费视频最近日韩| 美女视频免费一区| 久草这里只有精品视频| 狠狠色综合日日| 高清不卡在线观看av| 经典一区二区三区| 黄色小说综合网站| 久久精品免费观看| 亚洲精品国产无天堂网2021| 亚洲欧美电影院| 亚洲最大成人综合| 日韩av中文字幕一区二区三区| 日本中文字幕一区二区视频| 日韩精品电影一区亚洲| 狠狠色综合日日| 成人白浆超碰人人人人| 一本色道久久综合亚洲91| 欧美性大战久久久久久久蜜臀 | 在线视频欧美精品| 在线91免费看| 久久精品亚洲一区二区三区浴池| 久久精品视频网| 亚洲精品欧美专区| 偷拍亚洲欧洲综合| 视频一区视频二区中文字幕| 麻豆一区二区三区| 无吗不卡中文字幕| 国产一区免费电影| 成人精品电影在线观看| 日本高清视频一区二区| 欧美一区二区视频网站| 中文无字幕一区二区三区| 亚洲精品成人精品456| 日韩精品一二三四| 成人av在线观| 欧美在线观看视频一区二区三区| 日韩欧美亚洲另类制服综合在线| 国产日韩欧美不卡| 亚洲第一在线综合网站| 黑人精品欧美一区二区蜜桃| 色综合天天狠狠| 91精选在线观看| 国产欧美va欧美不卡在线| 一区av在线播放| 国产精品66部| 欧美日韩精品系列| 国产精品丝袜一区| 日韩精品电影一区亚洲| 不卡视频免费播放| 日韩久久免费av| 亚洲超碰97人人做人人爱| 国产a精品视频| 日韩欧美亚洲一区二区| 一区二区三区在线免费视频| 国产一区二区三区蝌蚪| 欧美偷拍一区二区| 一区二区三区四区在线免费观看 | 国产乱子伦一区二区三区国色天香| 欧美视频一二三区| 亚洲图片一区二区| 色欧美片视频在线观看在线视频| 久久精品一区四区| 国产成人在线视频播放| 国产夜色精品一区二区av| 国产乱淫av一区二区三区| 久久精品视频网| av在线这里只有精品| 国产精品久久久爽爽爽麻豆色哟哟| 国产精品996|