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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? flashpic.c

?? 《嵌入式固件開(kāi)發(fā)》一書(shū)的源碼
?? C
字號(hào):
/* flashpic.c:   This file contains the flash-support code that is relocated to   RAM prior to execution.*/#include "config.h"#if INCLUDE_FLASH#include "stddefs.h"#include "cpu.h"#include "flashdev.h"#include "flash.h"/* Flasherase():   Based on the 'snum' value, erase the appropriate sector(s).   Return 0 if success, else -1.*/intFLASHERASE(struct flashinfo *fdev,int snum){    ftype   val;    ulong   add;    int ret, sector;    ret = 0;    add = (ulong)(fdev->base);    /* Erase the request sector(s): */    for (sector=0;sector<fdev->sectorcnt;sector++) {        if ((!FlashProtectWindow) &&            (fdev->sectors[sector].protected)) {            add += fdev->sectors[sector].size;            continue;        }        if ((snum == ALL_SECTORS) || (snum == sector)) {            register ulong *lp, *lp1;            int noterased;            /* See if the sector is already erased: */            noterased = 0;            lp = (ulong *)fdev->sectors[sector].begin;             lp1 = (ulong *)((char *)lp + fdev->sectors[sector].size);             while(lp < lp1) {                if (*lp++ != 0xffffffff) {                    noterased = 1;                    break;                }            }            if (noterased) {                /* Issue the sector erase command sequence: */                Write_aa_to_555();                Write_55_to_2aa();                Write_80_to_555();                Write_aa_to_555();                Write_55_to_2aa();                Write_30_to_(add);                /* Wait for sector erase to complete or timeout.. */                /* DQ7 polling: wait for D7 to be 1. */                /* DQ6 toggling: wait for D6 to not toggle. */                /* DQ5 timeout: if DQ7 is 0, and DQ5 = 1, timeout. */                while(1) {                    if (Is_ff(add)) {                        if (Is_ff(add))                            break;                    }                    if (D5_Timeout(add)) {                        if (Is_not_ff(add))                            ret = -1;                        break;                    }                }            }        }        add += fdev->sectors[sector].size;    }    /* If the erase failed for some reason, then issue the read/reset */    /* command sequence prior to returning... */    if (ret == -1) {        Write_f0_to_555();        val = Read_555();    }    return(ret);}/* EndFlasherase():   Function place holder to determine the "end" of the   sectorerase() function.*/voidENDFLASHERASE(){}/* Flashwrite():   Return 0 if successful, else -1.*/intFLASHWRITE(struct flashinfo *fdev,uchar *dest,uchar *src,long bytecnt){    ftype   val;    long    cnt;    int     i, ret, offby;    uchar   *src1, *tdest, buf[4];    /* If destination address is not properly aligned, then build a fake   */    /* source buffer based on the current value in dest[-1] and src[0].    */    /* Then call this function to do that 4-byte operation.  Once that     */    /* completes, simply increment dest and src by 1 and continue in this  */    /* context. */    offby = NotAligned(dest);    if (offby) {        tdest = dest - offby;        for(i=0;i<offby;i++)            buf[i] = tdest[i];        for(i=offby;i<4 && bytecnt;i++,bytecnt--)            buf[i] = *src++;        while(i<4)            buf[i] = tdest[i++];        if (FLASHWRITE(fdev,tdest,buf,4) < 0)            return(-1);        dest += (4-offby);    }    /* Each pass through this loop writes 'fdev->width' bytes... */    ret = 0;    cnt = bytecnt & ~3;    src1 = (uchar *)&val;    for (i=0;i<cnt;i+=fdev->width) {        /* Flash write command */        Write_aa_to_555();        Write_55_to_2aa();        Write_a0_to_555();                /* Just in case src is not aligned... */        src1[0] = src[0];        src1[1] = src[1];        src1[2] = src[2];        src1[3] = src[3];        /* Write the value */        Fwrite(dest,src1);        /* Wait for write to complete or timeout. */        while(1) {            if (Is_Equal(dest,src1)) {                if (Is_Equal(dest,src1))                    break;            }            /* Check D5 for timeout... */            if (D5_Timeout(dest)) {                if (Is_Not_Equal(dest,src1)) {                    ret = -1;                    goto done;                }                break;            }        }        dest += fdev->width;         src += fdev->width;    }    /* If bytecount was not mod4... */    /* If cnt != bytecnt then bytecnt is wasn't mod4, so one more pass must */    /* be made.  To do this, the additional bytes must be combined with */    /* the next bytes already stored in flash; then re-written... */    if (cnt != bytecnt) {        offby = bytecnt - cnt;        src1 = (uchar *)&val;        src1[0] = dest[0];        src1[1] = dest[1];        src1[2] = dest[2];        src1[3] = dest[3];                for(i=0;i<offby;i++)            src1[i] = src[i];                if (FLASHWRITE(fdev,dest,src1,4) < 0)            return(-1);    }done:    /* Read/reset command: */    Write_f0_to_555();    val = Read_555();    return(ret);}/* EndFlashwrite():    Function place holder to determine the "end" of the    Flashwrite() function.*/voidENDFLASHWRITE(){}/* Ewrite():   Erase all sectors that are part of the address space to be written,   then write the data to that address space.  This is basically a   concatenation of flasherase and flashwrite done in one step.  This is   necessary primarily for re-writing the bootcode; because after the boot   code is erased, there is nowhere to return so the re-write must be done   while executing out of ram also.*/intFLASHEWRITE(struct flashinfo *fdev,ftype *dest,ftype *src,int bytecnt){    int i;    ulong   add;    void    (*reset)();    ftype   val, *src1, *dest1;    add = (ulong)(fdev->base);    src1 = src;    dest1 = dest;    /* For each sector, if it overlaps any of the destination space */    /* then erase that sector. */    for (i=0;i<fdev->sectorcnt;i++) {        if ((((uchar *)dest) > (fdev->sectors[i].end)) ||            (((uchar *)dest+bytecnt) < (fdev->sectors[i].begin))) {            add += fdev->sectors[i].size;            continue;        }        /* inline putchar...        while((*(ushort *)TXBD0_0 & 0x8000));        xbuf[0] = (uchar)(0x41+i);        *(ushort *)TXBD0_0 |= 0x8000;        */        /* Sector erase command: */        Write_aa_to_555();        Write_55_to_2aa();        Write_80_to_555();        Write_aa_to_555();        Write_55_to_2aa();        Write_30_to_(add);        /* Wait for sector erase to complete or timeout.. */        /* DQ7 polling: wait for D7 to be 1. */        /* DQ6 toggling: wait for D6 to not toggle. */        /* DQ5 timeout: if DQ7 is 0, and DQ5 = 1, timeout. */        while(1) {            if (Is_ff(add)) {                if (Is_ff(add))                    break;            }#if 0            /* Check D5 for timeout... */            /* In this case, there is nothing to return to */            /* because the flash was just erased, so just break.*/            if (D5_Timeout(add)) {                reset = RESETFUNC();                reset();            }#endif        }        add += fdev->sectors[i].size;    }    /* inline putchar...    while((*(ushort *)TXBD0_0 & 0x8000));    xbuf[0] = (uchar)'!';    *(ushort *)TXBD0_0 |= 0x8000;    */    /* Read/reset command: */    Write_f0_to_555();    val = Read_555();    for(i=0;i<bytecnt;i+=fdev->width) {        /* Write command: */        Write_aa_to_555();        Write_55_to_2aa();        Write_a0_to_555();        Fwrite(dest,src);        while(1) {            if (Is_Equal(dest,src)) {                if (Is_Equal(dest,src))                    break;            }#if 0            /* Check D5 for timeout... */            if (D5_Timeout(dest)) {                if (Is_Not_Equal(dest,src))                    return(-1);                break;            }#endif        }        dest++;         src++;    }    /* Issue the read/reset command sequence: */    Write_f0_to_555();    val = Read_555();    /* Wait till flash is readable, or timeout: */    for(i=0;i<FLASH_TIMEOUT;i++) {        if (Is_Equal(dest1,src1))            break;    }    /* Now that the re-programming of flash is complete, reset: */    reset = RESETFUNC();    reset();    return(0);  /* won't get here */}/* EndFlashewrite():    Function place holder to determine the "end" of the    FlashEraseAndWrite() function.*/voidENDFLASHEWRITE(){}/* Flashtype():   Use the AUTOSELECT command sequence to determine the type of device.*/intFLASHTYPE(struct flashinfo *fdev){    ftype   val;    ushort  man, dev;    ulong   id;    val = Read_0000();    /* Issue the autoselect command sequence: */    Write_aa_to_555();    Write_55_to_2aa();    Write_90_to_555();    man = (ushort)Read_0000();  /* manufacturer ID */    dev = (ushort)Read_0001();  /* device ID */    id = man;    id <<= 16;    id |= dev;    fdev->id = id;    /* Issue the read/reset command sequence: */    Write_f0_to_555();    val = Read_0000();    return((int)(fdev->id));}/* EndFlashtype():    Function place holder to determine the "end" of the    Flashtype() function.*/voidENDFLASHTYPE(){}#endif

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
3atv一区二区三区| 婷婷夜色潮精品综合在线| 亚洲国产日韩精品| 国产美女在线精品| 欧美午夜寂寞影院| 亚洲欧美在线另类| 国产一区二区三区观看| 在线播放中文一区| 亚洲精品欧美在线| 成人高清视频免费观看| www亚洲一区| 久久er精品视频| 欧美剧在线免费观看网站| 亚洲欧美国产三级| 成人黄色在线网站| 国产三级精品三级| 韩国欧美国产一区| 日韩亚洲欧美中文三级| 亚洲国产欧美在线| 在线亚洲免费视频| 亚洲婷婷在线视频| 97久久超碰国产精品| 国产精品无遮挡| 国产成人精品综合在线观看| 精品国产精品网麻豆系列| 轻轻草成人在线| 7777精品伊人久久久大香线蕉超级流畅| 亚洲日穴在线视频| 色拍拍在线精品视频8848| 国产精品久久久久久久久久久免费看 | 亚洲六月丁香色婷婷综合久久 | 国产乱子轮精品视频| 欧美一卡2卡3卡4卡| 琪琪久久久久日韩精品| 日韩一区二区免费在线电影| 麻豆国产欧美一区二区三区| 精品电影一区二区三区| 国模大尺度一区二区三区| 久久影院午夜论| 国产精品亚洲人在线观看| 国产欧美精品一区二区三区四区| 国产成人综合亚洲网站| 欧美激情一区二区三区在线| 成人v精品蜜桃久久一区| 一区视频在线播放| 欧洲色大大久久| 日日夜夜免费精品| 2021中文字幕一区亚洲| 成人黄色在线网站| 亚洲国产精品久久久久婷婷884| 欧美日韩久久久一区| 蜜臀久久久久久久| 久久久99精品免费观看不卡| 97国产一区二区| 一区二区欧美国产| 日韩精品一区在线观看| 国产精品一二三区| 夜夜夜精品看看| 日韩欧美国产一区二区三区| 国产v综合v亚洲欧| 亚洲一区二区三区四区五区黄| 日韩欧美国产电影| 97精品超碰一区二区三区| 日韩电影在线一区二区| 国产精品视频线看| 欧美剧情电影在线观看完整版免费励志电影 | 一区二区三区资源| 日韩欧美一区二区视频| 不卡一区中文字幕| 视频一区在线视频| 国产精品电影一区二区| 欧美日韩精品一区视频| 成人精品免费视频| 青青青爽久久午夜综合久久午夜| 中文字幕第一区| 欧美一区二区大片| 91年精品国产| 国产精品小仙女| 日本成人在线网站| 洋洋成人永久网站入口| 国产丝袜美腿一区二区三区| 欧美一区二区福利在线| 欧洲生活片亚洲生活在线观看| 国产成人免费视频网站| 麻豆精品国产91久久久久久| 亚洲国产精品久久一线不卡| 亚洲色大成网站www久久九九| 久久综合狠狠综合久久激情| 欧美久久免费观看| 色婷婷综合久久久中文一区二区| 国产精一品亚洲二区在线视频| 一区二区三区不卡视频| 欧美激情一区二区在线| www精品美女久久久tv| 777奇米四色成人影色区| 欧美亚洲综合久久| 色一情一乱一乱一91av| 成人午夜看片网址| 国产传媒日韩欧美成人| 国产麻豆午夜三级精品| 激情综合网最新| 美国毛片一区二区| 日本麻豆一区二区三区视频| 亚洲3atv精品一区二区三区| 亚洲影院在线观看| 一区二区三区在线视频观看58| 亚洲欧洲色图综合| 国产精品电影一区二区| 国产精品国产精品国产专区不蜜 | 日韩精品一区二| 日韩欧美aaaaaa| 亚洲精品一区在线观看| 精品国产露脸精彩对白 | 一区二区三区四区不卡视频| 一区二区在线观看av| 一区二区视频在线| 亚洲国产欧美日韩另类综合| 亚洲国产精品视频| 午夜精品成人在线| 蜜桃av一区二区在线观看| 精品一区二区在线视频| 国产.欧美.日韩| av亚洲精华国产精华精华| 色诱视频网站一区| 欧美视频日韩视频在线观看| 91精品国产麻豆国产自产在线| 91精品国产91久久久久久最新毛片| 欧美日韩你懂得| 精品美女在线观看| 国产拍揄自揄精品视频麻豆| 亚洲少妇屁股交4| 亚洲地区一二三色| 久久国产剧场电影| www.亚洲精品| 欧美精品tushy高清| 欧美哺乳videos| 成人欧美一区二区三区白人| 亚洲国产美国国产综合一区二区| 男人的天堂久久精品| 国产91精品在线观看| 欧美在线色视频| 精品国产乱码久久久久久浪潮| 国产精品乱码一区二三区小蝌蚪| 一区二区高清在线| 麻豆国产精品官网| 97精品超碰一区二区三区| 欧美丰满少妇xxxbbb| 中文幕一区二区三区久久蜜桃| 亚洲小说欧美激情另类| 国产综合色精品一区二区三区| 91免费小视频| 日韩精品一区二区三区视频播放 | 欧美国产精品专区| 亚洲午夜在线视频| 国产成人综合自拍| 欧美另类videos死尸| 国产色一区二区| 无吗不卡中文字幕| 国产69精品久久99不卡| 亚洲裸体在线观看| 免费看日韩a级影片| 99久久婷婷国产综合精品 | 麻豆freexxxx性91精品| 97久久精品人人做人人爽| 欧美mv和日韩mv的网站| 亚洲激情欧美激情| 国产91对白在线观看九色| 日韩欧美国产一区二区三区 | 欧美疯狂性受xxxxx喷水图片| 亚洲国产精品av| 麻豆精品视频在线观看| 色哟哟欧美精品| 国产精品网站一区| 国产制服丝袜一区| 欧美一卡2卡三卡4卡5免费| 亚洲国产综合视频在线观看| 成人一区在线看| 久久久久九九视频| 麻豆91在线观看| 日韩视频免费观看高清完整版在线观看 | 蜜桃久久精品一区二区| 欧美日韩亚洲综合| 亚洲一区二区三区四区五区黄| 99在线热播精品免费| 欧美国产精品中文字幕| 国产福利一区二区三区视频在线| 欧美一级一级性生活免费录像| 亚洲丰满少妇videoshd| 色嗨嗨av一区二区三区| 亚洲精品第1页| 色狠狠一区二区| 一区二区免费在线| 欧美色图天堂网| 亚洲成av人片在线观看无码| 在线观看日韩精品| 亚洲午夜日本在线观看| 欧美日韩一区二区三区不卡| 亚洲影院在线观看| 欧美日本一道本在线视频| 午夜精品久久久久久久|