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

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

?? flashpic8.c

?? 《嵌入式固件開發》一書的源碼
?? C
字號:
/* flashpic8.c:   This file contains the 8-bit 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"#include "flash8.h"extern struct flashinfo Fdev;extern int FlashProtectWindow;/* Flasherase(): *  Based on the 'snum' value, erase the appropriate sector(s). *  Return 0 if success, else -1. */intFlasherase29F040_8(fdev,snum)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.                 * DQ5 timeout: if DQ7 is 0, and DQ5 == 1, timeout.                 */                for (;;) {                    if (Is_ff(add)) {                        break;                    }                    if (D5_Timeout(add)) {                        if (D7_not_set(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_5555();    }    return(ret);}/* EndFlasherase(): *  Function place holder to determine the "end" of the *  sectorerase() function. */voidEndFlasherase29F040_8(){}/* Flashwrite():   Return 0 if successful, else -1.*/intFlashwrite29F040_8(fdev,dest,src,bytecnt)struct  flashinfo *fdev;uchar   *src, *dest;long    bytecnt;{    int     i, jj, ret;    long    cnt;    uchar   *src1;    ftype   val;    /* 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 2-byte operation.  Once that     * completes, simply increment dest and src by 1 and continue in this     * context.     */    if (NotAligned(dest)) {        uchar buf[2];        buf[0] = *(dest-1);        buf[1] = *src;        Flashwrite29F040_8(fdev,dest-1,buf,2);        dest++; src++; bytecnt--;    }    /* Each pass through this loop writes 'fdev->width' bytes... */    ret = 0;    cnt = bytecnt & ~(fdev->width - 1);    src1 = (uchar *)&val;onemore:    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... */        for (jj = 0; jj < fdev->width; jj++) {            src1[jj] = src[jj];        }        /* Write the value */        Fwrite(dest,src1);        /* Wait for write to complete or timeout. */        while(1) {            if (Is_D7_Equal(dest,src1)) {                break;            }            /* Check D5 for timeout... */            if (D5_Timeout(dest)) {                if (Is_D7_Not_Equal(dest,src1)) {                    ret = -1;                    goto done;                }            }        }        dest += fdev->width;         src += fdev->width;    }    /* If bytecount was odd...     * If cnt != bytecnt then bytecnt is odd and width > 1, so one more     * byte must be written to flash.  To do this, the one byte must     * be combined with the next byte that is already stored in flash;     * then re-written...     */    if (cnt != bytecnt) {        val = (ftype)*dest | ((ftype)(*src) << 8);        src = (uchar *)&val;        bytecnt = cnt = 1;        goto onemore;    }done:    /* Read/reset command: */    Write_f0_to_555();    val = Read_5555();    return(ret);}/* EndFlashwrite(): *  Function place holder to determine the "end" of the *  Flashwrite() function. */voidEndFlashwrite29F040_8(){}/* 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. */intFlashewrite29F040_8(fdev,dest,src,bytecnt)struct  flashinfo *fdev;ftype   *src, *dest;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-1)) < (fdev->sectors[i].begin))) {            add += fdev->sectors[i].size;            continue;        }        /* 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)) {                break;            }            /* 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)) {                if (D7_not_set(add)) {                    /* Read/reset command: */                    Write_f0_to_555();                    val = Read_5555();                    reset = RESETFUNC();                    reset();                    break;                }            }        }        add += fdev->sectors[i].size;    }    /* Read/reset command: */    Write_f0_to_555();    val = Read_5555();    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_D7_Equal(dest,src)) {                break;            }            /* Check D5 for timeout... */            if (D5_Timeout(dest)) {                if (Is_D7_Not_Equal(dest,src)) {                    /* Read/reset command: */                    Write_f0_to_555();                    val = Read_5555();                    return(-1);                }            }        }        dest++;         src++;    }    /* Issue the read/reset command sequence: */    Write_f0_to_555();    val = Read_5555();    /* 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. */voidEndFlashewrite29F040_8(){}/* Flashtype(): *  Use the AUTOSELECT command sequence to determine the type of device. */intFlashtype29F040_8(fdev)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.*/voidEndFlashtype29F040_8(){}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区免费视频| 色天天综合久久久久综合片| 成人免费高清在线观看| 在线观看视频一区二区| 337p日本欧洲亚洲大胆精品| 亚洲一区二区三区四区不卡| 国产一区二区三区电影在线观看| 在线精品亚洲一区二区不卡| 国产性天天综合网| 午夜不卡av在线| 色94色欧美sute亚洲线路一ni| 精品国产一区a| 日日夜夜精品视频免费| 色女孩综合影院| 亚洲欧洲三级电影| 国产91露脸合集magnet| 日韩一区二区电影| 亚洲成人午夜影院| 色综合久久88色综合天天6| 久久久久国产精品厨房| 蓝色福利精品导航| 91精品国产综合久久香蕉麻豆| 亚洲免费观看在线观看| 成人黄色免费短视频| 久久久亚洲精品石原莉奈 | 国产大陆亚洲精品国产| 日韩一区二区三区在线视频| 亚洲大片一区二区三区| 欧美三级电影精品| 亚洲一区二区视频在线观看| 色欲综合视频天天天| 亚洲欧洲精品一区二区三区 | 国产亚洲福利社区一区| 狠狠色丁香婷综合久久| 日韩免费高清视频| 六月丁香婷婷久久| 精品欧美一区二区久久| 国产中文字幕精品| 久久精品视频一区| 国产sm精品调教视频网站| 欧美极品xxx| 波多野结衣的一区二区三区| 国产精品短视频| 91视频你懂的| 一区二区三区四区高清精品免费观看| av网站免费线看精品| 亚洲人成精品久久久久久| 一本到三区不卡视频| 亚洲午夜在线视频| 欧美一区二区在线看| 韩国v欧美v亚洲v日本v| 欧美激情艳妇裸体舞| 91一区二区在线| 亚洲国产欧美在线| 日韩欧美国产一二三区| 国产成人午夜视频| 亚洲精品高清视频在线观看| 精品视频在线免费| 国产自产视频一区二区三区| 国产性天天综合网| 欧美亚洲自拍偷拍| 午夜电影久久久| 国产日韩综合av| 一本高清dvd不卡在线观看| 日韩av一区二区三区| 久久久精品综合| 91成人网在线| 国内精品伊人久久久久av影院| 亚洲国产成人午夜在线一区| 欧美在线制服丝袜| 国产美女在线观看一区| 一区二区三区成人在线视频| 精品国精品国产| 一本在线高清不卡dvd| 久久国产精品露脸对白| 亚洲欧美视频在线观看| 精品久久国产字幕高潮| 91蝌蚪porny| 国产伦精品一区二区三区视频青涩| 国产精品久久久久久久久图文区| 8x福利精品第一导航| 国产99久久久国产精品潘金网站| 亚洲电影中文字幕在线观看| 国产日韩欧美精品综合| 69堂成人精品免费视频| 成人爱爱电影网址| 老司机精品视频线观看86| 一区二区三区免费网站| 国产欧美精品国产国产专区| 日韩亚洲国产中文字幕欧美| 91国在线观看| 成人丝袜18视频在线观看| 看片网站欧美日韩| 夜夜操天天操亚洲| 亚洲欧洲www| 国产亚洲精品中文字幕| 日韩久久精品一区| 欧美日韩国产色站一区二区三区| 不卡一二三区首页| 国产成人av资源| 久久99国产精品麻豆| 日韩精彩视频在线观看| 亚洲综合色噜噜狠狠| 亚洲欧洲精品天堂一级 | a亚洲天堂av| 激情成人综合网| 日本成人超碰在线观看| 亚洲午夜激情网站| 一个色在线综合| 亚洲精品国产品国语在线app| 国产精品视频麻豆| 国产无遮挡一区二区三区毛片日本| 日韩欧美电影一区| 欧美一区二区视频在线观看2022 | av在线综合网| 成人精品小蝌蚪| 岛国一区二区三区| 成人中文字幕电影| 成人网页在线观看| 99久久综合精品| 成人av午夜电影| 91视频在线观看| 欧美视频中文一区二区三区在线观看| 91天堂素人约啪| 精品国产伦一区二区三区观看方式| 91性感美女视频| 色综合久久综合网欧美综合网| 成熟亚洲日本毛茸茸凸凹| 国产成人啪午夜精品网站男同| 精品一区二区三区在线播放视频| 麻豆精品国产传媒mv男同| 日韩和欧美一区二区三区| 日本一不卡视频| 美国毛片一区二区三区| 男女男精品视频网| 蜜臀久久久久久久| 国产高清精品网站| 成人影视亚洲图片在线| av中文一区二区三区| 91在线丨porny丨国产| 色综合欧美在线视频区| 在线观看不卡一区| 欧美美女一区二区三区| 日韩欧美在线不卡| 26uuu国产日韩综合| 国产婷婷色一区二区三区在线| 91网站黄www| 欧美狂野另类xxxxoooo| 欧美一区二区视频在线观看2020| 日韩欧美中文一区| 欧美一级在线视频| 国产精品成人免费在线| 亚洲欧美日韩精品久久久久| 亚洲在线一区二区三区| 青青草成人在线观看| 成人激情综合网站| 精品视频一区二区不卡| 日韩视频免费观看高清完整版 | 一区二区三区久久| 亚洲国产人成综合网站| 美日韩一级片在线观看| 国产精品99久久久久久有的能看| av在线综合网| 91精品国产一区二区| 久久久久久免费网| 国产精品久久久久aaaa| 午夜精品福利视频网站| 国产又粗又猛又爽又黄91精品| 韩国在线一区二区| 99久久精品国产网站| 欧美美女一区二区三区| **欧美大码日韩| 奇米影视一区二区三区| 成人少妇影院yyyy| 8v天堂国产在线一区二区| 亚洲色图都市小说| 国内外精品视频| 欧美久久久久久久久| 国产嫩草影院久久久久| 韩国理伦片一区二区三区在线播放 | 26uuu亚洲综合色| 亚洲福利一区二区三区| 成人高清免费在线播放| 91.成人天堂一区| 亚洲男人的天堂一区二区| 九色|91porny| 色哟哟亚洲精品| 国产欧美一区视频| 奇米精品一区二区三区四区| 99久久国产综合精品色伊| 久久久精品影视| 免费在线看成人av| 在线观看av一区| 国产精品不卡一区| 波多野结衣亚洲一区| 久久久久国产精品厨房| 美洲天堂一区二卡三卡四卡视频 | 26uuu成人网一区二区三区| 亚洲综合视频在线| 成人免费av网站|