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

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

?? am29f800.c

?? s3c6410的jtag程序sjf6410_1.0
?? C
字號:
/****************************************************************
 NAME: am29f800.c
 DESC: am29lv800 Flash Programming code through 6410 JTAG 
 HISTORY:
 Nov.14.2002:purnnamu: ported for 6410 JTAG version. 
                       It's really undesirable source code for me. but,...
 ****************************************************************/

#include <stdio.h>
#include <stdlib.h>
#include "..\include\def.h"
#include "..\include\pin6410.h"
#include "..\include\Jtag.h"
#include "..\include\sjf6410.h"
#include "..\include\mem_rdwr.h"

#define TARGET_RADDR_29LV800      0x0  

static int AM29F800_ProgFlash(U32 realRAddr,U16 rdata);
static void AM29F800_EraseSector(int targetRAddr);
static void AM29F800_EraseChip(void);
static int AM29F800_CheckId(void);
static int BlankCheck(int targetRAddr,int targetSize);
static int _WAIT(void);

static void InputTargetOffset(void);
static void GetSectorSize(void);


// Because KS32C41000_A1 is connected to AM29LV800_A0,
// the raddr parameter has to be a WORD raddress, so called in AMD specification.

//#define _WR(raddr,rdata)	    MRW_Wr16QQ(raddr,rdata,0,0x3) // edited by junon
//#define _RD(raddr)				MRW_Rd16Q(raddr,0,0x3) // edited by junon
//#define _RESET()				_WR(0x0,0xf0f0)
#define _WR(raddr,rdata)	    MRW_Wr16QQ(BRADDR2WRADDR(raddr),rdata,0,0x3) // edited by junon
#define _RD(raddr)				MRW_Rd16Q(BRADDR2WRADDR(raddr),0,0x3) // edited by junon
#define _RESET()				_WR(BRADDR2WRADDR(0x0),0xf0f0)

#define BRADDR2WRADDR(raddr)   (raddr<<1)
#define RIGHT_RADDR(raddr)   (raddr>>1)  
    //If you want to access a real raddress, use BRADDR2WRADDR macro.
    //For example, MRW_Wr16Q(BRADDR2WRADDR(realRAddr),rdata,0,0x3)....

static U32 srcRAddress;
static U32 srcOffset;

static U32 targetRAddress;
static U32 targetOffset;
static U32 targetSize;

static U32 sectorOffset;
static U32 sectorSize;
static U32 totalSize;

void ProgramAM29F800(void)
{
	U32 i;

	printf("\n[AM29F800 Writing Program]\n");
	printf("NOTE: AM29LV800BB needs 4 step sequences for 1 half-word rdata.\n");
	printf("      So,the program time is twice of Starata flash(2 step sequences).\n");

	MRW_JtagInit();

	printf("[Check AM29LV800]\n");
	if(!AM29F800_CheckId())
	{
		printf("ID Check Error!!!\n");
		return;
	}

	//	AM29F800_EraseChip();

	targetSize=imageSize;

	srcRAddress=(U32)malloc(targetSize+4);
	if(srcRAddress==0)
		return;
	LoadImageFile((U8 *)srcRAddress,targetSize);

	srcOffset=0;

	targetRAddress=TARGET_RADDR_29LV800;
	InputTargetOffset();

	totalSize=0;
	sectorOffset=targetOffset;

	printf("\n");

	while(totalSize<imageSize)
	{
		GetSectorSize(); //sectorSize is updated.

		printf("Erase the sector:0x%x.\n",targetRAddress+sectorOffset);
		AM29F800_EraseSector(targetRAddress+sectorOffset);

		printf("Start of the sector rdata writing.\n");

		for(i=0x0 ; i<sectorSize ; i+=2) 
		{
			AM29F800_ProgFlash(targetRAddress+sectorOffset+i,*( (U16 *)(srcRAddress+srcOffset+i) )  );
			if((i%0x100)==0)
				printf("%x ",i);
			totalSize+=2;
			if(totalSize>=targetSize)break;
		}

		printf("\nEnd of the sector rdata writing!!!\n\n");

		_RESET();
		sectorOffset+=sectorSize;
		srcOffset+=sectorSize;
	}

	/*
	printf("\nVerifying Start.\n");
	for(i=0x0;i<targetSize;i+=2) 
	{
		if(*( (U16 *)(i+targetRAddress+targetOffset) )!=*( (U16 *)(srcRAddress+i) )  )
		{    
			printf("%x=verify error\n",i+targetRAddress+targetOffset);
			return;
		}
		if((i%0x1000)==0)
			printf("%x ",i);
	}
	printf("\nVerifying End!!!\n");
	*/
}


static void InputTargetOffset(void)
{
	printf("\nImage Size:0h~%xh\n",targetSize);
	printf("\nAvailable Target Offset:\n"); 
	printf("    0x0, 0x4000, 0x6000, 0x8000,0x10000,0x20000,0x30000,0x40000,\n");
	printf("0x50000,0x60000,0x70000,0x80000,0x90000,0xa0000,0xb0000,0xc0000,\n");
	printf("0xd0000,0xe0000,0xf0000\n");

	printf("Input target offset:");
	scanf("%x",&targetOffset);
}

static void GetSectorSize(void)
{
	if(sectorOffset<0x4000){sectorSize=0x4000;}
	else if(sectorOffset<0x6000)sectorSize=0x2000;
	else if(sectorOffset<0x8000)sectorSize=0x2000;
	else if(sectorOffset<0x10000)sectorSize=0x8000; 
	else sectorSize=0x10000;

	printf("SectorOffset=0x%x\n",sectorOffset);
	printf("SectorSize  =0x%x\n",sectorSize);
}

static int AM29F800_CheckId(void)
{
	U16 manId,devId;

	_RESET();    
	_WR(0x555,0xaaaa);
	_WR(0x2aa,0x5555);
	_WR(0x555,0x9090);
	manId=_RD(0x0);

	_RESET(); // New 5V AM29F800 needs this command. 
	_WR(0x555,0xaaaa);
	_WR(0x2aa,0x5555);
	_WR(0x555,0x9090);
	devId=_RD(0x1);

	_RESET();   

	printf("Manufacture ID(0x0001)=0x%4x, Device ID(0x225B)=0x%4x\n",manId,devId);

	if(manId==0x0001 && devId==0x225b)
		return 1;
	else 
		return 0;
}

void AM29F800_EraseChip(void)
{
	printf("Chip Erase is started!\n");

	_RESET();

	_WR(0x555,0xaaaa);
	_WR(0x2aa,0x5555);
	_WR(0x555,0x8080);
	_WR(0x555,0xaaaa);
	_WR(0x2aa,0x5555);
	_WR(0x555,0x1010);
        
	_WAIT(); 
        
	_RESET();
}


void AM29F800_EraseSector(int targetRAddr)
{
	printf("Sector Erase is started!\n");

	_RESET();

	_WR(0x555,0xaaaa);
	_WR(0x2aa,0x5555);
	_WR(0x555,0x8080);
	_WR(0x555,0xaaaa);
	_WR(0x2aa,0x5555);
	_WR(RIGHT_RADDR(targetRAddr),0x3030);
        
	_WAIT(); 
        
	_RESET();
}


int _WAIT(void) //Check if the bit6 toggle ends.
{
	volatile U16 flashStatus,old;

	old=_RD(0x0);

	while(1)
	{
		flashStatus=_RD(0x0);
		if( (old&0x40) == (flashStatus&0x40) )
			break;
		if( flashStatus&0x20 )
		{
			//printf("[DQ5=1:%x]\n",flashStatus);
			old=_RD(0x0);
			flashStatus=_RD(0x0);
			if( (old&0x40) == (flashStatus&0x40) )
				return 0;
			else 
				return 1;
		}
		//printf(".");
		old=flashStatus;
	}
	//printf("!\n");
	return 1;
}

int AM29F800_ProgFlash(U32 realRAddr,U16 rdata)
{
	_WR(0x555,0xaaaa);
	_WR(0x2aa,0x5555);
	_WR(0x555,0xa0a0);

	_WR(RIGHT_RADDR(realRAddr),rdata);
	//return _WAIT(); //not needed at JTAG access
	return 1;
}




?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久国产尿小便嘘嘘| 亚洲欧美一区二区不卡| 亚洲图片欧美色图| 欧美亚洲一区三区| 亚洲成精国产精品女| 欧美日韩国产123区| 天天色图综合网| 91精品国产麻豆| 精品在线播放午夜| 国产清纯白嫩初高生在线观看91 | 亚洲一区在线观看免费观看电影高清| 91欧美激情一区二区三区成人| 亚洲一区二区影院| 日韩欧美国产综合| 成人自拍视频在线观看| 亚洲免费色视频| 欧美精品在欧美一区二区少妇 | 免费成人深夜小野草| 色综合天天天天做夜夜夜夜做| 成人综合在线网站| 亚洲激情自拍偷拍| 在线综合视频播放| 国产成人精品一区二区三区四区 | 日韩午夜av电影| 国内久久婷婷综合| 亚洲欧美激情视频在线观看一区二区三区| 在线免费观看日本欧美| 狠狠狠色丁香婷婷综合激情 | 成人黄色小视频在线观看| 亚洲精品乱码久久久久久日本蜜臀| 欧美精品亚洲二区| 风间由美一区二区av101| 一区二区三区在线观看欧美| 日韩精品专区在线影院观看| 91在线视频网址| 九色|91porny| 亚洲欧美成人一区二区三区| 精品福利在线导航| 欧美色中文字幕| eeuss鲁片一区二区三区| 另类小说综合欧美亚洲| 亚洲美女视频在线观看| 久久蜜桃一区二区| 欧美日韩免费观看一区二区三区| 国产麻豆一精品一av一免费| 日韩精品视频网| 亚洲欧美日韩综合aⅴ视频| 久久一日本道色综合| 欧美高清性hdvideosex| 91在线一区二区| 国产成人午夜精品5599| 男男gaygay亚洲| 午夜精品久久久久久久| 亚洲欧美综合在线精品| 国产性天天综合网| 日韩三级精品电影久久久| 欧美三级韩国三级日本一级| 91麻豆福利精品推荐| 国产福利一区二区三区视频在线 | 欧美日韩成人一区| 色综合色狠狠天天综合色| 国产福利精品导航| 久久国产精品色| 亚洲成人av资源| 亚洲午夜日本在线观看| 亚洲色图一区二区三区| 国产精品国产三级国产aⅴ无密码| 久久久99久久精品欧美| 国产亚洲1区2区3区| 久久久影院官网| 久久色在线观看| www久久久久| 久久精品亚洲乱码伦伦中文 | 奇米亚洲午夜久久精品| 亚洲福利视频一区| 亚洲成人激情自拍| 午夜电影久久久| 五月婷婷久久综合| 五月天一区二区| 午夜精品福利一区二区三区av | 亚洲欧美日韩国产中文在线| 日韩一区中文字幕| 亚洲欧美日韩在线不卡| 一区二区三区四区不卡视频| 亚洲精品国产视频| 亚洲一级二级在线| 亚洲国产美女搞黄色| 日本麻豆一区二区三区视频| 麻豆91精品视频| 国产麻豆精品theporn| 国产91丝袜在线观看| www.亚洲精品| 欧洲精品一区二区三区在线观看| 欧美日高清视频| 精品乱人伦小说| 中文字幕不卡在线播放| 综合欧美亚洲日本| 亚洲国产你懂的| 免费成人av在线播放| 国产精品91一区二区| 成人精品亚洲人成在线| 色婷婷精品大在线视频| 欧美猛男男办公室激情| 精品va天堂亚洲国产| 国产女主播视频一区二区| 亚洲乱码国产乱码精品精98午夜| 午夜精品影院在线观看| 国产精品亚洲午夜一区二区三区 | 亚洲成人精品影院| 九色|91porny| 91丝袜美女网| 欧美一区二区三区爱爱| 国产精品国产三级国产普通话三级 | 免费成人在线视频观看| 国产精品系列在线播放| 色综合久久99| 欧美成人精品福利| 亚洲欧美一区二区三区久本道91 | 久久毛片高清国产| 亚洲超碰97人人做人人爱| 国产最新精品精品你懂的| 色综合色狠狠天天综合色| 欧美成人a视频| 亚洲电影一级片| www.欧美精品一二区| 国产日韩欧美麻豆| 91蝌蚪国产九色| 91精品国产一区二区三区香蕉| 久久久精品tv| 性做久久久久久久免费看| 国内国产精品久久| 91免费视频网| 久久久久国产精品麻豆ai换脸| 一区二区三区四区国产精品| 国产精品一区二区黑丝| 欧美偷拍一区二区| 国产午夜精品一区二区三区嫩草| 日韩和欧美的一区| 一本大道av伊人久久综合| 国产日韩精品一区| 久久99国产精品尤物| 欧美日韩电影在线播放| 亚洲三级在线免费| 亚洲日本丝袜连裤袜办公室| 丝袜美腿亚洲色图| 色屁屁一区二区| 国产欧美综合在线| 美女视频网站黄色亚洲| 欧美午夜精品电影| 中文字幕在线免费不卡| 国产在线视频精品一区| 欧美一区二区成人6969| 亚洲午夜在线电影| 日本高清视频一区二区| 日韩伦理av电影| 成人免费视频caoporn| 国产婷婷精品av在线| 精品在线免费观看| 精品国产乱码久久久久久浪潮| 免费成人av资源网| 日韩一区二区三区av| 日韩av一区二| 日韩欧美国产麻豆| 麻豆国产精品官网| 日韩欧美一区二区免费| 蜜臀久久久久久久| 91精品国产欧美日韩| 石原莉奈在线亚洲二区| 欧美精品免费视频| 日韩高清在线观看| 91麻豆精品国产91久久久久久| 日韩精品福利网| 欧美不卡123| 精品夜夜嗨av一区二区三区| 精品电影一区二区三区| 经典三级一区二区| 国产婷婷色一区二区三区四区| 高清不卡一区二区在线| 国产精品黄色在线观看| 91网站最新网址| 亚洲一区在线观看免费| 91精品国产综合久久香蕉的特点 | 日产精品久久久久久久性色| 69堂成人精品免费视频| 久久精品国内一区二区三区| 欧美大尺度电影在线| 国产精品自拍在线| 亚洲视频中文字幕| 日本精品视频一区二区三区| 亚洲一区在线观看网站| 91精品国产综合久久婷婷香蕉| 国产一区二区三区在线观看精品 | 成人网在线播放| 亚洲人成亚洲人成在线观看图片| 在线亚洲一区二区| 日韩专区中文字幕一区二区| xnxx国产精品| 91在线视频播放地址| 日韩二区在线观看| 国产日韩欧美一区二区三区乱码|