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

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

?? flashpic.c

?? umon bootloader source code, support mips cpu.
?? C
字號:
/* flashpic_28f640.c:
    This file contains the portion of the flash driver code that can be
    relocated (pic =  position independent code) to RAM space so that it
    is not executing out of the same flash device that it is operating on.

    This code is specific to a 16-bit configuration of the 28f640, but
    could be made width independent if the need arises.
*/
#include "config.h"
#if INCLUDE_FLASH
typedef 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 "flashpic.h"

extern struct flashinfo Fdev;
extern int FlashProtectWindow;

/* Flasherase():
   Based on the 'snum' value, erase the appropriate sector(s).
   Write the "Erase Setup" and "Erase Confirm" commands...
   Return 0 if success, else -1.
*/
int
Flasherase28F640_16(struct flashinfo *fdev,int snum)
{
    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) {
                Write_20_to_base();             /* setup */
                Write_d0_to_(add);              /* confirm */
                while(!(Read_0000() & WSMS));   /* Wait for SMS ready */
                if (Read_0000() & ECLBS)        /* Check for error */
                    ret = -1;
                Write_50_to_base();             /* Clear status register */
                Write_ff_to_base();             /* Go to read-array mode */
            }
            if (ret == -1)
                break;
        }
        add += fdev->sectors[sector].size;
    }
    return(ret);
}

/* EndFlasherase():
   Function place holder to determine the "end" of the
   sectorerase() function.
*/
void
EndFlasherase28F640_16()
{
}


/* Flashwrite():
    Return 0 if successful, else -1.
    There are two versions of this function.  The currently removed version
    supports the one-word/byte-at-a-time programming mode and it works but
    it is slow.  The currently active version uses the 28F640's write buffer
    mode of programming.  This is much faster, but it requires a bit more
    complexity.  See comments in code.
*/
int
Flashwrite28F640_16(struct flashinfo *fdev,uchar *dest,uchar *src,long bytecnt)
{
    int     tot, 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;
        Flashwrite28F640_16(fdev,dest-1,buf,2);
        dest++; src++; bytecnt--;
    }

    /* This device supports a write-buffer mode.  The buffer is 32 bytes    */
    /* (16 words) and greatly speeds up the programming process.  This      */
    /* This function starts up with the word-at-a-time mode and uses it     */
    /* until the destination address is mod32.  Then for each successive    */
    /* 32-byte block, the write buffer is used. When there is less than 32  */
    /* bytes left, the algorithm falls back to the one-word-at-a-time mode  */
    /* to finish up. */
    ret = 0;
    cnt = bytecnt & ~1;
    src1 = (uchar *)&val;

    for (tot=0;tot<cnt;tot+=2) {
        if (((ulong)dest & 0x1f) == 0)  /* Break out when 5 LSBs are zero */
            break;

        src1[0] = src[0];               /* Just in case src is not aligned... */
        src1[1] = src[1];               

        Write_40_to_(dest);             /* Flash program setup command */
        Fwrite(dest,src1);              /* Write the value */
        while(!(Read_0000() & WSMS));   /* Wait for SMS ready */
        if (Read_0000() & PSLBS)        /* Check for error */
            ret = -1;
        Write_50_to_base();             /* Clear status register */
        Write_ff_to_base();             /* Go to read-array mode */
        dest += 2; 
        src += 2;
    }

    /* If tot is less than cnt, then the upper loop reached a point where   */
    /* the destination address had the 5 LSBs low.  This means that we can  */
    /* use the write-buffer for all remaining blocks of 32 bytes...         */
    if (tot < cnt) {
        while((cnt-tot) >= 32) {
            int i;
            uchar *src2, buf32[32], *base;
    
            src2 = buf32;               /* Copy next buffer's worth of data */
            for(i=0;i<32;i++)           /* into local buffer just in case */
                buf32[i] = *src++;      /* the source is this flash device. */
    
            do { 
                Write_e8_to_(dest);         /* Write-to-buffer command */
            } while (!(Read_0000() & WBS)); /* Write buffer available? */
                
            base = dest;
            Write_0f_to_(dest);         /* Word count is 16 (load 16-1) */
            for(i=0;i<16;i++) {
                src1[0] = src2[0];      /* Just in case src is not aligned... */
                src1[1] = src2[1];              
                Fwrite(dest,src1);      /* Write the value */
                dest += 2; 
                src2 += 2; 
            }
            Write_d0_to_(base);             /* Write-confirm command */
            while(!(Read_0000() & WSMS));   /* Wait for SMS ready */
            Write_ff_to_base();             /* Go to read-array mode */
            tot += 32;
        }
    }

onemore:
    for (;tot<cnt;tot+=2) {
        src1[0] = src[0];               /* Just in case src is not aligned... */
        src1[1] = src[1];

        Write_40_to_(dest);             /* Flash program setup command */
        Fwrite(dest,src1);              /* Write the value */
        while(!(Read_0000() & WSMS));   /* Wait for SMS ready */
        if (Read_0000() & PSLBS)        /* Check for error */
            ret = -1;
        Write_50_to_base();             /* Clear status register */
        Write_ff_to_base();             /* Go to read-array mode */
        dest += 2; 
        src += 2;
    }

    /* 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;
        tot = 0;
        bytecnt = cnt = 1;
        goto onemore;
    }

    return(ret);
}

/* EndFlashwrite():
    Function place holder to determine the "end" of the
    Flashwrite() function.
*/
void
EndFlashwrite28F640_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.
*/

int
Flashewrite28F640_16(struct flashinfo *fdev,ftype *dest,ftype *src,int bytecnt)
{
    int i, err;
    ulong   add;
    void    (*reset)();
    ftype   *src1;

    err = 0;
    add = (ulong)(fdev->base);
    src1 = src;

    /* 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;
        }

        Write_20_to_base();             /* setup */
        Write_d0_to_(add);              /* confirm */
        while(!(Read_0000() & WSMS));   /* Wait for SMS ready */
        if (Read_0000() & ECLBS)        /* Check for error */
            err = 1;
        Write_50_to_base();             /* Clear status register */
        Write_ff_to_base();             /* Go to read-array mode */
        if (err)
            return(-1);
        add += fdev->sectors[i].size;
    }

    for(i=0;i<bytecnt;i+=fdev->width) {
        
        /* Just in case src is not aligned... */
        src1[0] = src[0];
        src1[1] = src[1];

        Write_40_to_(dest);             /* Flash program setup command */
        Fwrite(dest,src1);              /* Write the value */
        while(!(Read_0000() & WSMS));   /* Wait for SMS ready */
        if (Read_0000() & PSLBS)        /* Check for error */
            err = 1;
        Write_50_to_base();             /* Clear status register */
        Write_ff_to_base();             /* Go to read-array mode */
        if (err)
            return(-1);
        dest++; 
        src++;
    }
    
    /* Wait till flash is readable, then reset: */
    while(1) {
        if (Is_Equal((dest-1),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.
*/
void
EndFlashewrite28F640_16()
{
}

/* Flashtype():
   Use the ReadCOnfiguration command (90H) to read manufacturer code (0000)
   and device id code (0001).
*/

int
Flashtype28F640_16(struct flashinfo *fdev)
{
    ftype   val;
    ushort  man, dev;
    ulong   id;

    val = Read_0000();

    /* Issue the read configuration command: */
    Write_90_to_base();

    man = (ushort)Read_0000();  /* manufacturer ID */
    dev = (ushort)Read_0001();  /* device ID */
    id = man;
    id <<= 16;
    id |= dev;

    fdev->id = id;

    /* Issue the read array command: */
    Write_ff_to_base();
    return((int)(fdev->id));
}

/* EndFlashtype():
    Function place holder to determine the "end" of the
    Flashtype() function.
*/
void
EndFlashtype28F640_16()
{
}
#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美综合在线精品| 奇米色一区二区三区四区| 亚洲国产毛片aaaaa无费看| 精品无人区卡一卡二卡三乱码免费卡| 成人中文字幕电影| 91精品国产美女浴室洗澡无遮挡| 国产亚洲短视频| 日韩黄色小视频| 欧美性受xxxx黑人xyx| 国产精品亲子乱子伦xxxx裸| 美女视频网站久久| 国产精品美女视频| 麻豆中文一区二区| 在线播放日韩导航| 亚洲欧美日韩系列| 成人激情免费网站| 久久久综合精品| 看电影不卡的网站| 欧美一区二区三区免费| 一区二区三区欧美日韩| www.在线欧美| 国产精品三级av| 成人激情小说网站| 欧美激情一区二区三区不卡| 国产一区在线观看视频| 精品国产一区二区三区久久影院| 日产国产欧美视频一区精品 | 亚洲女人****多毛耸耸8| 国产成人免费视频网站 | av动漫一区二区| 国产精品素人一区二区| 国产高清亚洲一区| 国产欧美一区二区精品仙草咪| 国产一区二区三区国产| 欧美mv日韩mv| 国产米奇在线777精品观看| 精品动漫一区二区三区在线观看| 久久9热精品视频| www国产成人| 成av人片一区二区| 亚洲欧美日韩中文播放| 91福利视频网站| 亚洲国产美女搞黄色| 777色狠狠一区二区三区| 日韩国产高清在线| 亚洲精品一区二区三区在线观看| 韩国成人精品a∨在线观看| 国产亚洲欧美日韩日本| 99视频精品全部免费在线| 亚洲乱码中文字幕综合| 欧美精选在线播放| 日本在线不卡一区| 久久久国际精品| 99这里都是精品| 亚洲va国产天堂va久久en| 欧美一区二区三区在线| 国产一区二区三区在线观看免费视频 | 亚洲一区二区视频在线观看| 欧美片网站yy| 狠狠色丁香久久婷婷综| 国产精品国产馆在线真实露脸 | 4438x亚洲最大成人网| 国产伦精品一区二区三区免费迷 | 日韩视频免费观看高清完整版 | 美女视频黄久久| 国产精品五月天| 欧美乱妇20p| 国产91丝袜在线观看| 亚洲精品乱码久久久久久久久| 欧美狂野另类xxxxoooo| 韩国视频一区二区| 一区二区在线观看不卡| 2020国产精品| 欧美亚洲动漫精品| 国产精品一区二区三区四区| 亚洲一线二线三线视频| 国产网红主播福利一区二区| 欧美日韩免费高清一区色橹橹| 国产成人高清视频| 日韩精品一二三| 国产在线一区观看| 亚洲一区二区成人在线观看| 久久综合久久综合久久综合| 日本韩国一区二区| 国产91丝袜在线播放0| 日韩精品色哟哟| 亚洲黄色av一区| 中文字幕免费一区| 欧美精品一区二区在线播放| 欧美综合色免费| 国产高清精品在线| 麻豆精品一区二区av白丝在线| 一区二区三区加勒比av| 中文字幕乱码一区二区免费| 精品国产一区二区三区久久久蜜月| 色av成人天堂桃色av| 高清国产午夜精品久久久久久| 日韩av高清在线观看| 亚洲在线视频免费观看| 国产精品久久福利| 久久精品无码一区二区三区| 日韩精品一区二区三区三区免费| 一本大道久久a久久综合| 懂色中文一区二区在线播放| 国产综合久久久久影院| 蓝色福利精品导航| 蜜桃av一区二区三区| 日韩综合在线视频| 亚洲福中文字幕伊人影院| 一区二区三区**美女毛片| 亚洲欧洲日韩av| 亚洲柠檬福利资源导航| 亚洲天天做日日做天天谢日日欢| 国产精品久线在线观看| 国产精品毛片久久久久久久| 轻轻草成人在线| 香蕉av福利精品导航| 亚洲成a人片综合在线| 婷婷激情综合网| 婷婷丁香久久五月婷婷| 蜜臀久久99精品久久久久宅男| 琪琪一区二区三区| 极品美女销魂一区二区三区 | 天堂久久久久va久久久久| 亚洲国产日韩一级| 奇米888四色在线精品| 美女www一区二区| 国产麻豆一精品一av一免费 | 国产精品久久午夜| 亚洲天堂av老司机| 亚洲电影激情视频网站| 日本一道高清亚洲日美韩| 激情伊人五月天久久综合| 国产盗摄女厕一区二区三区 | 日韩一级片在线播放| 精品噜噜噜噜久久久久久久久试看| 久久久精品免费观看| 亚洲男女一区二区三区| 日韩影视精彩在线| 成人午夜在线视频| 91激情在线视频| 日韩女优制服丝袜电影| 中文字幕第一页久久| 一片黄亚洲嫩模| 亚洲成av人片在线观看| 秋霞影院一区二区| 成人激情小说网站| 制服丝袜亚洲网站| 欧美激情综合在线| 五月天视频一区| 成人自拍视频在线| 欧美一区二区三区的| 国产欧美日韩不卡免费| 亚洲亚洲精品在线观看| 国产精品综合久久| 欧美性一级生活| 中文一区在线播放| 日韩高清一级片| 99久久99精品久久久久久| 日韩欧美精品在线| 一区二区三区中文字幕精品精品 | 精品少妇一区二区三区在线视频 | 美国十次综合导航| k8久久久一区二区三区| 日韩天堂在线观看| 亚洲欧美激情在线| 国产精品一区专区| 欧美日韩精品三区| 欧美激情在线观看视频免费| 麻豆精品蜜桃视频网站| 91国模大尺度私拍在线视频| 国产日本一区二区| 蜜臀精品久久久久久蜜臀| 欧美视频自拍偷拍| 一区二区中文视频| 国产精一品亚洲二区在线视频| 欧美日韩高清在线| 亚洲精品国产第一综合99久久| 国产精品99久久久久久久vr | 欧美日精品一区视频| 国产精品美女一区二区| 欧美日韩在线播放三区四区| 亚洲视频网在线直播| 成人黄色大片在线观看| 国产午夜精品一区二区三区嫩草| 美洲天堂一区二卡三卡四卡视频| 欧美综合视频在线观看| 亚洲精品视频免费观看| gogo大胆日本视频一区| 国产校园另类小说区| 国产精品99久久久久久久女警| 26uuu国产电影一区二区| 青草av.久久免费一区| 日韩一区二区在线观看视频 | 欧美一区二区高清| 热久久久久久久| 欧美不卡激情三级在线观看| 日韩av成人高清| 精品久久久久久久久久久久包黑料 | 亚洲精品成人天堂一二三|