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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? flashpic16.c

?? 《嵌入式固件開發(fā)》一書的源碼
?? C
字號:
/* flashpic.c:   This file contains the flash-support code that is relocated to   RAM prior to execution.*/#include "config.h"#if INCLUDE_FLASHtypedef unsigned char uchar;typedef unsigned short ushort;typedef unsigned long ulong;typedef volatile unsigned char vuchar;typedef volatile unsigned short vushort;typedef volatile unsigned long vulong;typedef volatile unsigned int vuint;typedef volatile int vint;#include "cpu.h"#include "flashdev.h"#include "flash.h"#include "flash16.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.*/intFlasherase29F800B_16(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_5555();    }    return(ret);}/* EndFlasherase():   Function place holder to determine the "end" of the   sectorerase() function.*/voidEndFlasherase29F800B_16(){}/* Flashwrite():   Return 0 if successful, else -1.*/intFlashwrite29F800B_16(struct flashinfo *fdev,uchar *dest,uchar *src,long bytecnt){    int     i, 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;        Flashwrite29F800B_16(fdev,dest-1,buf,2);        dest++; src++; bytecnt--;    }    /* Each pass through this loop writes 'fdev->width' bytes... */    ret = 0;    cnt = bytecnt & ~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... */        src1[0] = src[0];        src1[1] = src[1];        /* 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;            }        }        dest += fdev->width;         src += fdev->width;    }    /* If bytecount was odd... */    /* If cnt != bytecnt then bytecnt is odd, 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.*/voidEndFlashwrite29F800B_16(){}/* 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.*/intFlashewrite29F800B_16(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;        }        /* 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;            }            /* 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();            }        }        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_Equal(dest,src)) {                if (Is_Equal(dest,src))                    break;            }            /* Check D5 for timeout... */            if (D5_Timeout(dest)) {                if (Is_Not_Equal(dest,src))                    return(-1);                break;            }        }        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.*/voidEndFlashewrite29F800B_16(){}/* Flashtype():   Use the AUTOSELECT command sequence to determine the type of device.*/intFlashtype29F800B_16(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.*/voidEndFlashtype29F800B_16(){}#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
黄网站免费久久| 国产传媒一区在线| 欧美国产精品久久| 欧美另类videos死尸| 国产精品亚洲成人| 午夜精品久久久久久久99樱桃| 久久久久久久av麻豆果冻| 91在线视频免费观看| 国内精品久久久久影院色| 性久久久久久久久| 亚洲欧美激情在线| 中文在线一区二区| 2017欧美狠狠色| 7777精品久久久大香线蕉| 91福利视频在线| 成人毛片在线观看| 国产麻豆精品在线| 另类调教123区| 日本在线观看不卡视频| 亚洲自拍偷拍综合| 亚洲男人的天堂av| 中文字幕一区二区视频| 国产欧美一区二区三区鸳鸯浴| 欧美www视频| 91精品国产手机| 欧美日韩黄视频| 欧美色中文字幕| 色婷婷亚洲婷婷| 99国产精品久久久| 成人免费视频国产在线观看| 国产在线一区二区综合免费视频| 日本午夜精品视频在线观看| 亚洲成人在线网站| 亚洲一区在线免费观看| 一区二区激情小说| 亚洲精品成a人| 一区二区欧美视频| 亚洲成人动漫在线免费观看| 亚洲国产精品精华液网站| 一区二区在线观看不卡| 亚洲黄色av一区| 亚洲成人在线观看视频| 亚洲成人午夜电影| 日韩国产成人精品| 久久成人免费日本黄色| 国产伦精品一区二区三区视频青涩| 国产一区二区在线免费观看| 国产suv精品一区二区6| 99久久国产免费看| 91福利社在线观看| 欧美日韩国产首页在线观看| 91精品国产91久久久久久最新毛片| 91精品国产综合久久蜜臀| 91麻豆精品久久久久蜜臀| 精品嫩草影院久久| 国产情人综合久久777777| 中文一区二区完整视频在线观看| 国产精品久久久久天堂| 亚洲裸体在线观看| 亚洲gay无套男同| 精品一区二区三区欧美| 国产成人综合亚洲网站| 91浏览器打开| 欧美日韩一区二区在线视频| 日韩写真欧美这视频| 国产人妖乱国产精品人妖| 亚洲色图制服丝袜| 日本午夜一本久久久综合| 麻豆精品国产传媒mv男同| 韩日av一区二区| 成人av电影免费观看| 日本精品视频一区二区三区| 欧美精品第1页| 亚洲国产高清aⅴ视频| 一区二区三区 在线观看视频| 美日韩黄色大片| 9久草视频在线视频精品| 欧美日韩卡一卡二| 国产欧美精品在线观看| 亚洲综合精品自拍| 国产精品123区| 欧美性猛片aaaaaaa做受| 欧美精品一区二区三区在线| 成人免费在线视频观看| 麻豆精品国产传媒mv男同| gogo大胆日本视频一区| 欧美一级二级三级乱码| 亚洲天堂2014| 久久国产精品色| 色88888久久久久久影院野外| 日韩欧美www| 夜夜亚洲天天久久| 国产成人自拍网| 欧美一级黄色录像| 亚洲一级不卡视频| 成人视屏免费看| 激情五月婷婷综合网| 中文字幕久久午夜不卡| 亚洲影院久久精品| 国产一区不卡精品| 91麻豆精品国产无毒不卡在线观看| 国产亚洲精品bt天堂精选| 日韩国产成人精品| 欧亚洲嫩模精品一区三区| 国产性色一区二区| 久久精品国产网站| 91福利社在线观看| ...av二区三区久久精品| 国产一区二区视频在线| 欧美一区二区三区在线电影| 亚洲视频免费在线观看| 国产成人综合自拍| 精品国产伦一区二区三区免费| 午夜视频一区在线观看| 91色九色蝌蚪| 国产精品成人午夜| 国产福利不卡视频| 欧美精品一区二区三区很污很色的 | 亚洲二区视频在线| 国产成人av影院| 日韩精品一区二区三区在线 | 欧美日精品一区视频| 亚洲欧美一区二区在线观看| 国产精品99久久久久久久vr| 日韩欧美国产综合一区 | 久久九九影视网| 国产高清久久久| 久久精品视频网| 国产精品资源站在线| 欧美精品一区二区蜜臀亚洲| 久久国产精品第一页| 欧美精品一区二区三区蜜桃视频| 男女激情视频一区| 欧美xxxxx牲另类人与| 麻豆精品在线看| 2024国产精品视频| 国产在线播放一区| 久久精品网站免费观看| 成人高清在线视频| 亚洲色图色小说| 在线观看三级视频欧美| 亚洲第一成年网| 欧美一区二区三区四区在线观看 | 亚洲国产岛国毛片在线| 成人av资源站| 亚洲精品日产精品乱码不卡| 欧美色涩在线第一页| 视频一区欧美日韩| 日韩欧美国产高清| 精品在线观看视频| 国产精品三级av在线播放| a4yy欧美一区二区三区| 一区二区三区成人| 91麻豆精品久久久久蜜臀 | 欧美日韩的一区二区| 日韩精品亚洲专区| 精品国产91乱码一区二区三区| 国产激情一区二区三区四区 | 日韩综合一区二区| www精品美女久久久tv| 99re成人精品视频| 香蕉av福利精品导航| 午夜精品久久久久久不卡8050| 日韩欧美中文字幕一区| 国产精品自产自拍| 亚洲曰韩产成在线| 精品国产亚洲在线| 99re在线精品| 麻豆91精品91久久久的内涵| 欧美激情一区二区三区不卡| 欧美在线免费视屏| 九九**精品视频免费播放| 中文字幕的久久| 51精品秘密在线观看| 成人黄色小视频| 日韩av不卡一区二区| 国产精品系列在线| 欧美日韩一区三区| 成人三级伦理片| 石原莉奈一区二区三区在线观看| 久久久精品国产99久久精品芒果| 一本大道av伊人久久综合| 久久99精品国产91久久来源| 日韩经典一区二区| 欧美写真视频网站| 免费成人在线影院| 国产精品视频看| 欧美一区2区视频在线观看| 成年人网站91| 老司机精品视频线观看86| 亚洲欧美电影院| 精品播放一区二区| 色狠狠一区二区| 国产麻豆欧美日韩一区| 午夜精品久久久久久久蜜桃app| 中文字幕乱码亚洲精品一区| 日韩一级黄色片| 欧美亚州韩日在线看免费版国语版| 国产在线看一区| 99久久免费精品|