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

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

?? k9s1208.c

?? S3C2410_TEST.rar
?? 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一区二区三区免费野_久草精品视频
欧洲亚洲精品在线| 欧美一区二区在线免费观看| 亚洲午夜私人影院| 精品国产a毛片| 欧美中文字幕不卡| 国产精品资源网站| 日韩专区一卡二卡| 日韩美女视频一区二区| 2023国产精华国产精品| 一本大道久久a久久精品综合| 久久精品久久精品| 五月天久久比比资源色| 成人免费在线播放视频| 久久久久久一二三区| 欧美日本国产视频| 色综合一区二区三区| 国产成人综合亚洲网站| 狠狠色狠狠色综合系列| 日韩va亚洲va欧美va久久| 亚洲综合成人在线视频| 亚洲欧美一区二区三区国产精品| 国产性色一区二区| 三级欧美韩日大片在线看| 国产精品久久久久9999吃药| 久久综合资源网| 日韩欧美在线影院| 欧美群妇大交群的观看方式| 色婷婷综合久色| 91影院在线观看| 成人黄色免费短视频| 毛片av一区二区三区| 日产国产欧美视频一区精品| 亚洲h动漫在线| 亚洲精品欧美专区| 亚洲视频精选在线| 亚洲乱码日产精品bd| 亚洲日韩欧美一区二区在线| 国产精品久久久久久久午夜片| 国产日本亚洲高清| 中文字幕va一区二区三区| 国产婷婷色一区二区三区四区| 久久久久久一二三区| 国产日韩成人精品| 中文字幕国产精品一区二区| 国产日产欧美一区| 中文字幕中文字幕一区| 亚洲男人的天堂在线观看| 亚洲免费视频成人| 午夜av电影一区| 美女在线视频一区| 国产精品456露脸| 99久久久久久| 欧洲激情一区二区| 69av一区二区三区| 日韩欧美aaaaaa| 久久精品一区八戒影视| 国产精品第13页| 亚洲高清一区二区三区| 奇米在线7777在线精品| 国产一区二区三区日韩| 成人激情动漫在线观看| 日本乱人伦aⅴ精品| 欧美日本不卡视频| 久久久久国产精品免费免费搜索| 中文字幕 久热精品 视频在线| 亚洲丝袜美腿综合| 日本最新不卡在线| 国产成人精品影视| 欧美色大人视频| 久久久99精品久久| 亚洲一区二区成人在线观看| 蜜臀精品久久久久久蜜臀| 国产不卡免费视频| 欧美性一区二区| xfplay精品久久| 一区二区三区免费网站| 久久99精品国产| 色哟哟日韩精品| 精品电影一区二区| 一区二区三区蜜桃网| 免费高清在线视频一区·| 粗大黑人巨茎大战欧美成人| 欧美日韩综合一区| 国产日韩欧美激情| 日韩**一区毛片| 99久久国产综合精品麻豆| 在线成人小视频| 18欧美亚洲精品| 久久国产乱子精品免费女| 91免费在线视频观看| 欧美成人国产一区二区| 一区二区激情小说| 国产剧情一区二区三区| 91麻豆精品国产91久久久久久久久 | 日韩一级黄色片| 亚洲三级在线免费| 国产米奇在线777精品观看| 欧美视频一区二区三区在线观看| 国产日产亚洲精品系列| 日本人妖一区二区| 欧美视频日韩视频| 国产精品白丝在线| 国产精品一二三四| 精品久久久久久久久久久院品网| 亚洲婷婷综合久久一本伊一区| 老司机免费视频一区二区三区| 色偷偷久久一区二区三区| 欧美韩国日本不卡| 久久成人久久鬼色| 91精品视频网| 亚洲h精品动漫在线观看| 91麻豆国产香蕉久久精品| 欧美激情综合五月色丁香| 国产一区激情在线| 欧美一区二区三区四区高清| 亚洲制服丝袜在线| 色伊人久久综合中文字幕| 国产精品久久国产精麻豆99网站| 精品一区二区久久| 日韩欧美中文字幕一区| 日一区二区三区| 欧美人成免费网站| 丝袜美腿亚洲综合| 欧美日韩在线播放一区| 亚洲综合色在线| 在线亚洲一区二区| 亚洲午夜精品在线| 欧美日韩国产在线观看| 亚洲综合免费观看高清完整版在线 | 欧美一区二区三区视频在线| 亚洲国产综合在线| 欧美日韩1区2区| 午夜影院久久久| 欧美日韩成人综合| 视频精品一区二区| 日韩欧美国产一区在线观看| 日韩高清不卡在线| 91精品免费在线观看| 免费观看久久久4p| 久久这里只精品最新地址| 国产真实乱子伦精品视频| 欧美大片国产精品| 国产伦精一区二区三区| 久久久亚洲综合| 成年人午夜久久久| 亚洲精品久久久蜜桃| 欧美日韩视频在线观看一区二区三区| 亚洲动漫第一页| 欧美一区二区视频在线观看2020 | 亚洲精品少妇30p| 在线视频国内自拍亚洲视频| 夜夜亚洲天天久久| 欧美一区二区三区系列电影| 精品伊人久久久久7777人| 国产欧美一区二区精品久导航| 国产成a人亚洲| 一区二区三区色| 欧美大片在线观看| 成人国产一区二区三区精品| 亚洲精品你懂的| 日韩视频一区二区三区| 国产sm精品调教视频网站| 1024精品合集| 91麻豆精品国产91| 粉嫩av一区二区三区在线播放| 亚洲三级久久久| 欧美一级二级三级蜜桃| 成人久久视频在线观看| 亚洲国产综合在线| 久久久久久久久久久久电影| 色综合久久六月婷婷中文字幕| 午夜国产不卡在线观看视频| 久久亚洲私人国产精品va媚药| av中文字幕一区| 免费人成黄页网站在线一区二区| 久久久精品tv| 欧美美女视频在线观看| 国产成人精品免费| 午夜精品久久久久久久99樱桃| 2欧美一区二区三区在线观看视频| 91原创在线视频| 黄色精品一二区| 亚洲一区中文在线| 久久精品亚洲麻豆av一区二区| 91老师国产黑色丝袜在线| 老司机免费视频一区二区三区| 亚洲欧美一区二区久久 | 亚洲精品久久久久久国产精华液| 欧美成人性战久久| 91黄视频在线| 国产成人午夜电影网| 日本欧美一区二区在线观看| 亚洲视频一区在线| 亚洲精品一区二区三区四区高清| 欧美熟乱第一页| 成人动漫一区二区在线| 狠狠色丁香久久婷婷综合丁香| 亚洲成av人片在线| 亚洲欧洲99久久| 国产日韩综合av|