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

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

?? k9f1208.c

?? 在ads調試環境下
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include <stdio.h>
//#include "pin2410.h"
//#include "Jtag.h"
#include "K9S1208.h"
//#include "sjf2410.h"
#include "nand.h"
#include "2440lib.h"
#include "def.h"
#include "2440addr.h"

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

//#define imageSize 0x4000

void Uart_Printf(char *fmt,...);
U32 GETVALUE(char *buf);
 int LoadImageFile(U8 *buf,int size);
//*************** JTAG dependent functions ***************
/*
void K9S1208_JtagInit(void);
static void NF_CMD(U8 cmd);
static void NF_ADDR(U8 addr);
static void NF_nFCE_L(void);
static void NF_nFCE_H(void);
static U8 NF_RDDATA(void);
static void NF_WRDATA(U8 data);
static void NF_WAITRB(void);*/

#define NF_MECC_UnLock()         {rNFCONT&=~(1<<5);}
#define NF_MECC_Lock()         {rNFCONT|=(1<<5);}

#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() 		(rNFDATA8)
#define NF_RDDATA8() 		((*(volatile unsigned char*)0x4E000010) )

#define NF_WRDATA(data) 	{rNFDATA8=data;}//by xh

#define NF_WAITRB()    		{while(!(rNFSTAT&(1<<0)));} 
	   						 //wait tWB and check F_RNB pin.
	   						 
#define TACLS		0	// 1-clk(0ns) 
#define TWRPH0		6	// 3-clk(25ns)
#define TWRPH1		0	// 1-clk(10ns)  //TACLS+TWRPH0+TWRPH1>=50ns
	   						 
// RnB Signal
#define NF_CLEAR_RB()    		{rNFSTAT |= (1<<2);}	// Have write '1' to clear this bit.
#define NF_DETECT_RB()    		{while(!(rNFSTAT&(1<<2)));}

#define ID_K9S1208V0M	0xec76
#define ID_K9K2G16U0M	0xecca

#define	NF16_BAD_OFFSET		(12)

//#define blockBuf ((volatile unsigned char *)0x31000000)
//*************** H/W dependent functions ***************
static U16 NF_CheckId(void);
static int NF_EraseBlock(U32 blockNum);
static int NF_ReadPage(U32 block,U32 page,U8 *buffer,U8 *spareBuf);
static int NF_WritePage(U32 block,U32 page,U8 *buffer,U8 *spareBuf);
	//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);
//*******************************************************

void K9S1208_PrintBlock(void);
void K9S1208_Program(void);


static U32 targetBlock;	    // Block number (0 ~ 4095)
static U32 targetSize;	    // Total byte size 
static U8 blockBuf[0x4000];


static char RCVBUF[10];//by xh
static U32 imageSize;
volatile unsigned char *BufBase;

static void *function[][2]=
{
    (void *)K9S1208_Program,		"K9S1208 Program     ",
    (void *)K9S1208_PrintBlock,		"K9S1208 Pr BlkPage  ",
    (void *)1,			    	"Exit                ",
    0,0
};


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

    Uart_Printf("\n[K9S1208 NAND Flash JTAG Programmer]\n");
    //K9S1208_JtagInit();
    NF_Init();
    //NF8_Init();//by xh

    id=NF_CheckId();
    if(id!=0xec76)
    {
	Uart_Printf("ERROR: K9S1208 is not detected. Detected ID=0x%x.\n",id);
	return;
    }
    else
    {
    	Uart_Printf("K9S1208 is detected. ID=0x%x\n",id);
    }

    while(1)
    {

	i=0;
    	while(1)
	{   //display menu
	    Uart_Printf("%2d:%s",i,function[i][1]);
	    i++;
	    if((int)(function[i][0])==0)
	    {
		Uart_Printf("\n");
		break;
	    }
	    if((i%4)==0)
		Uart_Printf("\n");
	}

	Uart_Printf("Select the function to test :");
	//scanf("%d",&i);// by xh
	i=GETVALUE(RCVBUF);
	if( i>=0 && (i<((sizeof(function)/8)-2)) ) 
	    ( (void (*)(void)) (function[i][0]) )();  
	else
	    break; //Exit menu
	    
    }
}



void K9S1208_Program(void)
{
    int i;
    int programError=0;
    U32 blockIndex;
    int noLoad=0;
    U8 spareBuf[16]=
	{0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff};
    U8 *srcPt;
    U32 progSize=0;

    Uart_Printf("\n[SMC(K9S1208V0M) NAND Flash Writing Program]\n");
    
    Uart_Printf("\nPlease input code size:");//by xhe
    imageSize = GETVALUE(RCVBUF);
    
    Uart_Printf("\nSource size:0h~%xh\n",imageSize-1);
    
    Uart_Printf("\nAvailable target block number: 0~4095\n");
    Uart_Printf("Input target block number:");
    //scanf("%d",&targetBlock);// by xh
    targetBlock = GETVALUE(RCVBUF);
    targetSize=((imageSize+0x4000-1)/0x4000)*0x4000;
    Uart_Printf("target start block number     =%d\n",targetBlock);
    Uart_Printf("target size        (0x4000*n) =0x%x\n",targetSize);
    Uart_Printf("STATUS:");
    blockIndex=targetBlock;
    BufBase = ((volatile unsigned char *)0x31000000);
    while(1)
    {
	if(noLoad==0)
	{
	    LoadImageFile(blockBuf,0x4000);
	}
	noLoad=0;
	
#if BAD_CHECK       
	if(NF_IsBadBlock(blockIndex) && blockIndex!=0 )	// 1:bad 0:good
        {
	    blockIndex++;   // for next block
	    noLoad=1;
	    continue;
	}
#endif
	if(!NF_EraseBlock(blockIndex))
	{
	    blockIndex++;   // for next block
	    noLoad=1;
	    continue;
	}

	Uart_Printf("E");
	srcPt=blockBuf;
	//srcPt = ((U8 *)0x31000000);//by xh

	for(i=0;i<32;i++)
	{
	    if(!NF_WritePage(blockIndex,i,srcPt,NULL/*spareBuf*/))// block num, page num, buffer
	    {
	        programError=1;
	        break;
	    }

	    srcPt+=512;	// Increase buffer addr one pase size
	    Uart_Printf("p");
	}
	Uart_Printf("\n");

        if(programError==1)
	{
	    blockIndex++;
	    noLoad=1;
	    programError=0;
	    continue;
	}
	progSize+=0x4000;
	if(progSize>=imageSize)
	    break;	// Exit while loop
	blockIndex++;
    }
}




void K9S1208_PrintBlock(void)// Printf one page
{
    int i,j,ecc;
    U16 id;
    U32 block,page;
    U8	buffer[512+16];
    //volatile unsigned char buffer[512+16];

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

    Uart_Printf("Input target block number:");
    //scanf("%d",&block);//by xh
    block = GETVALUE(RCVBUF);
    Uart_Printf("Input target page number:");   
    //scanf("%d",&page);// by xh
    page = GETVALUE(RCVBUF);
    
    NF_ReadPage(block,page,buffer,buffer+512);
    
    Uart_Printf("block=%d,page=%d:",block,page);
    for(i=0;i<512;i++)
    {
        if(i%16==0)
	    Uart_Printf("\n%3xh:",i);
        Uart_Printf("%02x ",buffer[i]);
        for(j=0;j<100;j++);//by xh
    }
    Uart_Printf("\nS.A.:",i);

    for(i=512;i<512+16;i++)
    {
        Uart_Printf("%02x ",buffer[i]);
        for(j=0;j<100;j++);//by xh
    }

    Uart_Printf("\n");    	
}

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

// NAND Flash Memory Commands
#define	SEQ_DATA_INPUT			(0x80)
#define	READ_ID				(0x90)
#define	RESET				(0xFF)
#define	READ_1_1			(0x00)
#define	READ_1_2			(0x01)
#define	READ_2				(0x50)
#define	PAGE_PROGRAM			(0x10)
#define	BLOCK_ERASE			(0x60)
#define	BLOCK_ERASE_CONFIRM		(0xD0)
#define	READ_STATUS			(0x70)


// 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 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

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

#if BAD_CHECK
    if(NF_IsBadBlock(block) && block!=0) //block #0 can't be bad block for NAND boot
	return 0;
#endif

    NF_nFCE_L();
    //NF_CLEAR_RB();
    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
    
    Delay(1); //wait tWB(100ns)

    NF_WAITRB();    // Wait tBERS max 3ms.
    //NF_DETECT_RB();//by xh

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
老司机午夜精品| 久久久国产午夜精品| 99精品在线观看视频| 欧美中文字幕亚洲一区二区va在线 | 亚洲激情欧美激情| 日日摸夜夜添夜夜添精品视频 | 色噜噜狠狠成人中文综合| 99re成人精品视频| 欧美videos中文字幕| 亚洲欧洲国产日韩| 蜜桃av一区二区三区电影| 一本色道久久综合亚洲aⅴ蜜桃| 欧美色综合影院| 亚洲视频你懂的| 国产精品综合二区| 色婷婷久久99综合精品jk白丝| 91精品久久久久久久99蜜桃| 中文成人综合网| 国产高清久久久久| 久久色在线视频| 国产一区 二区| 日韩午夜激情av| 捆绑调教美女网站视频一区| 在线亚洲一区二区| 天使萌一区二区三区免费观看| 欧美日韩亚洲综合在线| 日韩有码一区二区三区| 3751色影院一区二区三区| 午夜影院在线观看欧美| 欧美影院一区二区三区| 五月激情六月综合| 欧美一区二区成人| 高潮精品一区videoshd| 国产精品成人一区二区三区夜夜夜 | 国产麻豆精品久久一二三| 久久久久久免费网| 99re成人精品视频| 日本不卡123| 欧美国产禁国产网站cc| 在线免费一区三区| 春色校园综合激情亚洲| 亚洲自拍偷拍麻豆| 国产亚洲综合性久久久影院| 日本久久电影网| 日本大胆欧美人术艺术动态| 国产视频一区在线观看| 69久久夜色精品国产69蝌蚪网| 国产一区二区日韩精品| 亚洲国产aⅴ天堂久久| 欧美国产视频在线| 91精品国产入口| 91国偷自产一区二区三区观看 | 精品国内片67194| 欧美日韩免费高清一区色橹橹| 精品一区二区三区在线观看 | 亚洲午夜一区二区| 亚洲男女一区二区三区| 国产精品免费视频网站| 久久精品人人做| 欧美伊人久久久久久午夜久久久久| 国产精品911| 成人综合婷婷国产精品久久免费| 亚洲18影院在线观看| 亚洲成人自拍网| 三级在线观看一区二区| 日本成人中文字幕| 激情偷乱视频一区二区三区| 久久国产福利国产秒拍| 国产又黄又大久久| 国产精品自拍av| 懂色av中文一区二区三区| 精品午夜久久福利影院| 国产剧情av麻豆香蕉精品| 福利电影一区二区| 在线一区二区视频| 91精品国产福利| 国产精品国产a| 亚洲h精品动漫在线观看| 免费看欧美女人艹b| 99久久久国产精品免费蜜臀| 91色综合久久久久婷婷| 欧美日韩aaa| 国产精品欧美久久久久一区二区| 亚洲久草在线视频| 国产精品一区专区| 欧美日韩成人综合在线一区二区| 精品久久久久99| 三级欧美韩日大片在线看| 国产酒店精品激情| 欧美日韩国产电影| 国产精品美女久久久久久久久| 成人免费毛片片v| jizz一区二区| 一本大道久久a久久综合| 日本久久一区二区三区| 国产精品久久久久久久久快鸭 | 欧美午夜电影在线播放| 久久综合九色欧美综合狠狠| 亚洲人成伊人成综合网小说| 国产精品一区二区在线观看网站| 欧美日韩另类一区| 一区二区欧美国产| 色婷婷久久久综合中文字幕 | 美洲天堂一区二卡三卡四卡视频| 欧美三级视频在线观看| 亚洲最大的成人av| 777午夜精品视频在线播放| 午夜精品久久一牛影视| 69堂国产成人免费视频| 看片的网站亚洲| 国产清纯白嫩初高生在线观看91| 国产一区欧美二区| 国产精品久久久久久久岛一牛影视| 粉嫩久久99精品久久久久久夜| 国产精品久久毛片av大全日韩| 成人高清伦理免费影院在线观看| 中文字幕中文字幕一区| 色呦呦国产精品| 美女免费视频一区| 国产精品久久久久久亚洲毛片| 欧美无人高清视频在线观看| 美女一区二区三区在线观看| 国产无遮挡一区二区三区毛片日本 | 亚洲免费毛片网站| 欧美精品一区二区久久婷婷| 成人成人成人在线视频| 亚洲视频在线观看三级| 精品视频在线免费观看| 国产999精品久久| 蜜桃av噜噜一区| 亚洲综合视频在线| 亚洲视频在线观看一区| 欧美国产综合色视频| 精品日韩一区二区三区| 在线成人av影院| 欧美日韩电影在线播放| 色偷偷88欧美精品久久久| 高清日韩电视剧大全免费| 另类小说综合欧美亚洲| 蜜桃精品视频在线观看| 免费在线观看不卡| 日韩福利视频网| 国内精品久久久久影院色| 日本在线不卡视频一二三区| 三级在线观看一区二区| 午夜伦理一区二区| 精品一区二区久久久| 麻豆精品久久精品色综合| 国产高清久久久久| 精品国产乱码久久久久久图片| 欧美一区二区视频在线观看2022| 欧美一级黄色录像| 中文字幕中文字幕在线一区| 亚洲一区中文日韩| 蜜臀av性久久久久蜜臀aⅴ| 国产一区999| 欧美美女直播网站| 欧美国产日韩一二三区| 欧美国产一区视频在线观看| 亚洲欧洲综合另类在线| 免费人成在线不卡| 91丨porny丨首页| 久久精品日产第一区二区三区高清版| 欧美国产精品久久| 国内精品免费**视频| 欧美美女网站色| 亚洲麻豆国产自偷在线| 韩国女主播成人在线观看| 欧美色倩网站大全免费| 国产亚洲精品福利| 精品一二三四在线| 欧美丰满少妇xxxbbb| 一区二区三区成人| 99精品视频在线观看| 久久久天堂av| 久久69国产一区二区蜜臀| 欧美日韩一区 二区 三区 久久精品| 日韩一区二区三区av| 老司机精品视频在线| 91精品国产一区二区人妖| 亚洲一区二区欧美激情| 欧美亚洲国产一区二区三区| 亚洲九九爱视频| 欧美三级欧美一级| 日本v片在线高清不卡在线观看| 欧美日韩综合在线免费观看| 亚洲二区在线视频| 日韩欧美一区二区三区在线| 欧美a级理论片| 国产拍欧美日韩视频二区| 成人深夜福利app| 亚洲va天堂va国产va久| 91精品在线麻豆| 国产成人在线影院| 亚洲人成小说网站色在线| 7777精品伊人久久久大香线蕉超级流畅| 亚洲成人先锋电影| 国产亲近乱来精品视频| 欧美日韩精品欧美日韩精品一| 精品制服美女丁香|