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

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

?? k9s1208.c

?? armer9 s3c2410 平臺
?? C
?? 第 1 頁 / 共 2 頁
字號:
//====================================================================
// 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=0x30100000;
    Uart_Printf("\n[SMC(K9S1208V0M) NAND Flash writing program]\n");
    //Uart_Printf("The program buffer: 0x30100000~0x31ffffff\n");

//tark
#if 0
    if(!DownloadData())
    {
        Uart_Printf("Download Fail\n");
        return;
    }
#endif

    NF_Init();


    rINTMSK = BIT_ALLMSK;   
    targetSize=downloadProgramSize;
    if(targetSize==0)
    {
        srcAddress=0x30100000; 
        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(0x3010000x)=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 :");
    block=Uart_GetIntNum();
    Uart_Printf("Input target page number :");   
    page=Uart_GetIntNum();

    NF_ReadPage(block,page,buffer);
    Uart_Printf("block=%d,page=%d:",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();

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内成人自拍视频| 欧美日本免费一区二区三区| 波多野洁衣一区| 4438x亚洲最大成人网| 国产欧美日韩激情| 欧美aaa在线| 色狠狠一区二区| 中文字幕的久久| 九九精品一区二区| 精品视频在线免费| 亚洲欧美电影院| 国产精品中文字幕欧美| 欧美日韩国产电影| 亚洲黄色av一区| 不卡的av中国片| 国产日韩精品一区二区三区| 蜜桃久久av一区| 日韩一区二区免费视频| 亚洲免费av网站| 成人免费观看av| 国产色综合一区| 国产精品资源在线| 精品对白一区国产伦| 五月天欧美精品| 欧美精品丝袜久久久中文字幕| 亚洲欧美电影院| 一本色道综合亚洲| 亚洲欧美国产三级| 在线精品视频免费播放| 亚洲精品成a人| 日本久久电影网| 亚洲欧美国产高清| 91福利资源站| 亚洲一区在线看| 欧美美女网站色| 青娱乐精品在线视频| 日韩视频国产视频| 久久99热99| 国产欧美日韩综合精品一区二区 | 国产精品自拍一区| 久久精品在线免费观看| 成人免费高清在线| 国产精品国产三级国产aⅴ无密码| 成人中文字幕电影| 亚洲黄色小视频| 在线电影院国产精品| 免费看日韩a级影片| 精品国产91乱码一区二区三区| 韩国三级中文字幕hd久久精品| 国产亚洲va综合人人澡精品 | 久久国产精品无码网站| 26uuu亚洲婷婷狠狠天堂| 国产91精品久久久久久久网曝门| 亚洲国产精品成人综合色在线婷婷 | 国产精品一二二区| 国产精品久久久久久久第一福利 | 国产iv一区二区三区| 国产精品无码永久免费888| 91国产丝袜在线播放| 日本欧美一区二区三区| 国产香蕉久久精品综合网| 91理论电影在线观看| 日韩电影在线观看一区| 久久久国产精华| 欧美日韩一区在线观看| 久久超级碰视频| 亚洲另类中文字| 日韩三级精品电影久久久| 成人免费观看视频| 视频一区在线视频| 国产精品久久久久影院老司 | 国产精品全国免费观看高清 | 亚洲精品伦理在线| 欧美成va人片在线观看| 99久久久国产精品免费蜜臀| 日韩成人免费电影| 亚洲欧美偷拍三级| 欧美不卡一区二区| 欧美色图片你懂的| 国产成人在线观看| 日韩黄色小视频| 中文字幕二三区不卡| 日韩一区二区免费电影| 色一情一乱一乱一91av| 国产成人自拍高清视频在线免费播放| 亚洲成人av在线电影| 亚洲国产岛国毛片在线| 欧美大片免费久久精品三p| 色综合婷婷久久| 国产大陆亚洲精品国产| 久久国产精品99久久久久久老狼| 亚洲精品高清视频在线观看| 久久香蕉国产线看观看99| 欧美日韩国产精品成人| 不卡的av在线播放| 国产福利一区二区三区视频在线 | 欧美不卡一区二区三区四区| 欧美午夜精品一区| 日本高清不卡一区| 成人免费观看av| 国产福利精品导航| 国产乱码精品一品二品| 狠狠色丁香久久婷婷综合丁香| 日韩精品免费视频人成| 午夜一区二区三区视频| 亚洲精品视频免费看| 国产精品免费久久久久| 国产精品女同一区二区三区| 久久九九久久九九| 久久久久国产免费免费| 欧美精品一区二区三区一线天视频| 欧美日韩国产成人在线91| 欧美日韩国产一级二级| 欧美日韩不卡视频| 欧美日韩精品一区二区三区四区| 91国产成人在线| 欧美美女直播网站| 欧美日韩国产一级二级| 欧美妇女性影城| 欧美一区二区三区免费观看视频| 日韩一级片在线播放| 欧美xxxx在线观看| 久久婷婷色综合| 久久色在线视频| 欧美国产精品中文字幕| 亚洲欧美在线视频观看| 亚洲色图丝袜美腿| 亚洲第一搞黄网站| 欧美aaa在线| 色综合久久久久综合体| 色域天天综合网| 欧美日韩国产综合一区二区三区 | 国产欧美日韩视频在线观看| 中文字幕国产一区| 亚洲主播在线观看| 免费在线观看一区二区三区| 久久66热偷产精品| 成人h动漫精品一区二区| 色呦呦日韩精品| 91精品国模一区二区三区| 精品久久久久久亚洲综合网| 国产欧美日韩中文久久| 亚洲一区二区三区国产| 久久狠狠亚洲综合| 9人人澡人人爽人人精品| 在线成人av网站| 国产嫩草影院久久久久| 亚洲国产精品久久久久婷婷884| 青娱乐精品视频在线| 成人国产视频在线观看| 7777精品伊人久久久大香线蕉的| 欧美精品一区二区三区久久久| 欧美激情一区不卡| 肉色丝袜一区二区| av不卡免费电影| 日韩精品中文字幕在线不卡尤物| 国产精品剧情在线亚洲| 日韩va亚洲va欧美va久久| 国产精一区二区三区| 欧美日韩精品系列| 中文字幕亚洲区| 秋霞影院一区二区| 在线视频一区二区免费| 日本一区二区三区视频视频| 日韩国产精品大片| 色综合久久66| 中文字幕精品三区| 寂寞少妇一区二区三区| 欧美亚洲另类激情小说| 国产精品第五页| 国产精品99久久久久久似苏梦涵| 欧美日韩国产免费一区二区 | 日精品一区二区| 在线电影院国产精品| 1区2区3区欧美| 国产成人综合在线播放| 日韩欧美国产三级| 亚洲h在线观看| 91久久国产综合久久| 中文字幕免费不卡在线| 久久99国产精品麻豆| 9191久久久久久久久久久| 亚洲一区在线观看免费观看电影高清| 国产不卡视频一区二区三区| 日韩一区二区在线看片| 污片在线观看一区二区| 欧美亚洲尤物久久| 一区二区三区四区不卡在线| 成人午夜电影小说| 久久精品人人做人人爽人人| 久久国产日韩欧美精品| 日韩欧美激情在线| 久久超级碰视频| 日韩精品一区二区三区视频播放| 天堂影院一区二区| 91精品国产综合久久精品app| 亚洲成人你懂的| 91精品在线免费观看| 免费在线看成人av| 精品福利一区二区三区|