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

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

?? am29f800.c

?? 2440 cpu test
?? C
字號:
#include <string.h>
#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440lib.h"
#include "2440slib.h" 
#include "Am29f800.h"

//Revision History
// 2001.8.25:purnnamu:If the data is downloaded by ICE, the writing isn't done correct.
 
int AM29F800_ProgFlash(U32 realAddr,U16 data);
void AM29F800_EraseSector(int targetAddr);
int AM29F800_CheckId(void);
int BlankCheck(int targetAddr,int targetSize);
int _WAIT(void);

static void InputTargetAddr(void);

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

#define _WR(addr,data)	*((U16 *)(addr<<1))=(U16)data
#define _RD(addr)	( *((U16 *)(addr<<1)) )
#define _RESET()	_WR(0x0,0xf0f0)
#define BADDR2WADDR(addr)   (addr>>1)
extern U32 downloadAddress;
extern U32 downloadProgramSize;
static U32 srcAddress;
static U32 srcOffset;
static U32 targetAddress;
static U32 targetSize;


void ProgramAM29F800(void)
{
    int i;

    InputTargetAddr();
    
    if(downloadProgramSize==0)
    {
        Uart_Printf("The data must be downloaded using ICE from %x\n",downloadAddress);
    	srcAddress=downloadAddress;
    }
    else
    	srcAddress=downloadAddress+4; //to discard the data head for the size
    	

    Uart_Printf("[Check AM29LVxxx]\n");
    switch(AM29F800_CheckId())  //04.01.12 junon
    {
	case 1 :
	    Uart_Printf("This device is AM29LV200B!\n");	
	    break;
	case 2 :
	    Uart_Printf("This device is AM29LV400B!\n");	
	    break;
	case 3 :
	    Uart_Printf("This device is AM29LV800B!\n");	
	    break;
	case 4 :
	    Uart_Printf("This device is AM29LV160B!\n");	
	    break;
    	default:
	    Uart_Printf("ID Check Error!!!\n");
	    return;
    }
    
    Uart_Printf("\nErase the sector:0x%x.\n",targetAddress);
    
    AM29F800_EraseSector(targetAddress);
    if(!BlankCheck(targetAddress,targetSize))
    {
	Uart_Printf("Blank Check Error!!!\n");
	return;
    }

    Uart_Printf("\nStart of the data writing.\n");

    for(i=0x0;i<targetSize;i+=2) 
    {
        AM29F800_ProgFlash(  i+targetAddress,*( (U16 *)(srcAddress+srcOffset+i) )  );
        if((i%0x1000)==0)Uart_Printf("%x ",i);
    }
    Uart_Printf("\nEnd of the data writing!!!\n");

    _RESET();

    Uart_Printf("\nVerifying Start.\n");
    for(i=0x0;i<targetSize;i+=2) 
    {
        if(*( (U16 *)(i+targetAddress) )!=*( (U16 *)(srcAddress+srcOffset+i) )  )
	{    
	    Uart_Printf("%x=verify error\n",i+targetAddress);
	    return;
	}
        if((i%0x1000)==0)Uart_Printf("%x ",i);
    }
    Uart_Printf("\nVerifying End!!!\n");

    Uart_Printf("Do you want another programming without additional download? [y/n]\n");
    if(Uart_Getch()=='y')ProgramAM29F800();
}



static void InputTargetAddr(void)
{
    static U32 nextTargetAddr=0,nextSrcOffset=0;
    Uart_Printf("[AM29F800 Writing Program]\n");

    Uart_Printf("\nCAUTION: Check AM29LV800 BYTE#(47) pin is connected to VDD.\n");

    Uart_Printf("\nSource size:0h~%xh\n",downloadProgramSize);
    Uart_Printf("\nAvailable Target/Source Address:\n"); 
    Uart_Printf("    0x0, 0x4000, 0x6000, 0x8000,0x10000,0x20000,0x30000,0x40000,\n");
    Uart_Printf("0x50000,0x60000,0x70000,0x80000,0x90000,0xa0000,0xb0000,0xc0000,\n");
    Uart_Printf("0xd0000,0xe0000,0xf0000\n");

    Uart_Printf("Input source offset[0x%x]:",nextSrcOffset);
    srcOffset=Uart_GetIntNum();
    if(srcOffset==(U32)(-1))srcOffset=nextSrcOffset;
    
    Uart_Printf("Input target address among above addresses[0x%x]:",nextTargetAddr);
    targetAddress=Uart_GetIntNum();
    if(targetAddress==(U32)(-1))targetAddress=nextTargetAddr;
 
    if(targetAddress<0x4000)targetSize=0x4000;
    else if(targetAddress<0x6000)targetSize=0x2000;
    else if(targetAddress<0x8000)targetSize=0x2000;
    else if(targetAddress<0x10000)targetSize=0x8000; 
    else targetSize=0x10000;

    Uart_Printf("source offset=0x%x\n",srcOffset);
    Uart_Printf("target address=0x%x\n",targetAddress);
    Uart_Printf("target block size=0x%x\n",targetSize);
    
    if(srcOffset<0x4000)nextSrcOffset=0x4000;
    else if(srcOffset<0x6000)nextSrcOffset=0x6000;
    else if(srcOffset<0x8000)nextSrcOffset=0x8000;
    else if(srcOffset<0x10000)nextSrcOffset=0x10000; 
    else nextSrcOffset=srcOffset+0x10000;
    
    if(targetAddress<0x4000)nextTargetAddr=0x4000;
    else if(targetAddress<0x6000)nextTargetAddr=0x6000;
    else if(targetAddress<0x8000)nextTargetAddr=0x8000;
    else if(targetAddress<0x10000)nextTargetAddr=0x10000; 
    else nextTargetAddr=targetAddress+0x10000;
 

}




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

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

    if(manId==0x0001 && devId==0x22bf) return 1; // AM29LV200B
    else if(manId==0x0001 && devId==0x22ba) return 2; // AM29LV400B
    else if(manId==0x0001 && devId==0x225b) return 3; // AM29LV800B
    else if(manId==0x0001 && devId==0x2249) return 4; // AM29LV160B        
    else if(manId==0x0004 && devId==0x2249) return 4; // 29LV160B fairchild        
    else return 0;
}




void AM29F800_EraseSector(int targetAddr)
{
        Uart_Printf("Sector Erase is started!\n");

        _RESET();

        _WR(0x555,0xaaaa);
        _WR(0x2aa,0x5555);
        _WR(0x555,0x8080);
        _WR(0x555,0xaaaa);
        _WR(0x2aa,0x5555);
        _WR(BADDR2WADDR(targetAddr),0x3030);
        _WAIT();
        _RESET();
}




int BlankCheck(int targetAddr,int targetSize)
{
    int i,j;
    for(i=0;i<targetSize;i+=2)
    {
	j=*((U16 *)(i+targetAddr));
	if( j!=0xffff)
	{
	    Uart_Printf("E:%x=%x\n",(i+targetAddr),j);
	    return 0;
	}
    }
    return 1;
}




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

	old=*((volatile U16 *)0x0);

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




int AM29F800_ProgFlash(U32 realAddr,U16 data)
{
	volatile U16 *tempPt;

        tempPt=(volatile U16 *)realAddr;
        _WR(0x555,0xaaaa);
        _WR(0x2aa,0x5555);
        _WR(0x555,0xa0a0);
        *tempPt=data;
        
	return _WAIT();

}




?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美无乱码久久久免费午夜一区| 日韩一级二级三级| 日韩视频免费直播| 综合久久给合久久狠狠狠97色| 日韩福利视频导航| 在线欧美日韩精品| 国产精品久久久久久久久久免费看| 亚洲成a人v欧美综合天堂 | av高清不卡在线| 日韩精品中文字幕在线一区| 一区二区三区国产精品| 国产99久久精品| 欧美精品一区二区三区久久久| 五月天亚洲精品| 色婷婷亚洲精品| 国产精品每日更新在线播放网址| 久久精品国产77777蜜臀| 欧美色综合网站| 亚洲欧美日韩综合aⅴ视频| 国产精品自在在线| 久久久午夜精品| 国产精品18久久久久久vr| 欧美一级久久久久久久大片| 午夜婷婷国产麻豆精品| 波多野结衣的一区二区三区| 日本一区二区视频在线| 精品一区二区三区在线观看国产| 欧美一区二区三区婷婷月色| 亚洲午夜久久久| 欧美视频中文字幕| 日韩 欧美一区二区三区| 欧美日韩的一区二区| 亚洲在线中文字幕| 欧美久久一二区| 日韩国产高清影视| 91麻豆精品国产自产在线 | 亚洲天堂av老司机| 成人avav在线| 亚洲久本草在线中文字幕| 不卡的电影网站| 尤物在线观看一区| 在线视频欧美区| 奇米精品一区二区三区四区| 宅男噜噜噜66一区二区66| 久久草av在线| 国产精品久久久久久久久久免费看| jlzzjlzz亚洲日本少妇| 亚洲丝袜美腿综合| 91国模大尺度私拍在线视频| 亚洲综合久久av| 欧美精品乱码久久久久久按摩| 日韩高清一级片| 欧美mv日韩mv国产网站app| 精品写真视频在线观看| 久久婷婷国产综合国色天香 | 蜜臀av一区二区三区| 欧美精品一区二| 99精品国产一区二区三区不卡| 一区二区三区av电影| 欧美日韩国产bt| 国产一区二区按摩在线观看| 自拍偷自拍亚洲精品播放| 日本道精品一区二区三区| 日韩成人一区二区| 中文字幕久久午夜不卡| 精品视频免费在线| 国产麻豆91精品| 亚洲午夜久久久久久久久电影院| 精品美女一区二区三区| 成+人+亚洲+综合天堂| 香蕉久久一区二区不卡无毒影院| 精品三级av在线| 色伊人久久综合中文字幕| 热久久免费视频| 国产精品毛片大码女人| 欧美三级午夜理伦三级中视频| 激情图区综合网| 夜色激情一区二区| 国产欧美日韩激情| 日韩免费视频线观看| 色综合色综合色综合| 国产一区二区在线看| 亚洲成在人线免费| 综合激情成人伊人| 久久久久国产精品厨房| 91精品国产综合久久久久久久| 国产91高潮流白浆在线麻豆| 首页国产欧美久久| 亚洲另类春色校园小说| 国产精品伦理一区二区| 日韩免费在线观看| 制服丝袜av成人在线看| 色婷婷狠狠综合| 国产成人免费视频网站| 美女视频黄频大全不卡视频在线播放| 亚洲色欲色欲www| 国产欧美日韩亚州综合| 精品入口麻豆88视频| 欧美精品自拍偷拍| 欧美视频三区在线播放| 91亚洲国产成人精品一区二区三 | 日日骚欧美日韩| 一区二区三区不卡视频在线观看| 国产精品久久久久久久久图文区| 久久亚洲春色中文字幕久久久| 欧美老肥妇做.爰bbww视频| 日本高清成人免费播放| 91网站最新地址| 99视频一区二区| 蜜臀av一级做a爰片久久| 在线观看www91| 日本高清无吗v一区| 欧美电视剧在线看免费| 日韩欧美中文字幕精品| 日韩三级视频中文字幕| 欧美日韩国产一级二级| 亚洲精品日韩综合观看成人91| 中文在线资源观看网站视频免费不卡 | 欧洲一区二区av| 欧美亚洲禁片免费| 日韩视频在线一区二区| 久久女同精品一区二区| 香港成人在线视频| 久久精品国产亚洲高清剧情介绍| 色诱视频网站一区| 欧美一级黄色大片| 2020国产成人综合网| 国产精品麻豆网站| 国产美女视频91| 欧美亚洲日本国产| 久久先锋影音av鲁色资源网| 日韩欧美一级在线播放| 久久蜜桃av一区精品变态类天堂| 色婷婷综合久久| 成人精品国产福利| 欧美裸体bbwbbwbbw| 精品国产亚洲一区二区三区在线观看 | 成人夜色视频网站在线观看| 欧美午夜精品一区二区蜜桃| 精品999久久久| 麻豆视频观看网址久久| 91麻豆高清视频| 亚洲一区二区综合| www.日韩大片| 亚洲精品欧美专区| jlzzjlzz欧美大全| 国产精品欧美一区二区三区| 亚洲成人av中文| 99麻豆久久久国产精品免费 | 亚洲大型综合色站| 色综合天天综合网天天狠天天| 久久久久久久久97黄色工厂| 日韩高清中文字幕一区| 欧美色综合天天久久综合精品| 国产精品成人免费精品自在线观看| 久久成人免费网站| 欧美一区二区三区视频免费播放| 亚洲欧美激情小说另类| 国产a区久久久| 久久久久久综合| 精品午夜久久福利影院| 日韩一区二区在线看片| 日韩一区精品视频| 4438x亚洲最大成人网| 亚洲国产精品久久艾草纯爱| 色婷婷综合久久久久中文 | 韩国成人精品a∨在线观看| 欧美三级日韩三级国产三级| 亚洲美女视频一区| 色丁香久综合在线久综合在线观看| 国产精品久久久久婷婷| a级高清视频欧美日韩| 中文字幕一区二区三区四区不卡| 成人夜色视频网站在线观看| 中文字幕av一区二区三区高 | 一区二区三区电影在线播| 91视频国产观看| 亚洲午夜精品在线| 欧美一区二区三区四区五区| 日韩高清一区在线| 久久久亚洲国产美女国产盗摄 | 99久久99久久久精品齐齐| 中文字幕日本乱码精品影院| 91蜜桃婷婷狠狠久久综合9色| 亚洲欧美日韩在线| 欧美喷潮久久久xxxxx| 日韩主播视频在线| www精品美女久久久tv| 成人深夜在线观看| 亚洲精品国产精华液| 在线日韩av片| 青青草91视频| 国产日韩欧美麻豆| 色婷婷综合五月| 另类中文字幕网| 亚洲人成在线观看一区二区| 欧美视频在线播放| 国产盗摄一区二区| 亚洲一区二区四区蜜桃| 欧美成人女星排行榜|