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

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

?? pflash_cfi01.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/* *  CFI parallel flash with Intel command set emulation * *  Copyright (c) 2006 Thorsten Zitterell *  Copyright (c) 2005 Jocelyn Mayer * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA *//* * For now, this code can emulate flashes of 1, 2 or 4 bytes width. * Supported commands/modes are: * - flash read * - flash write * - flash ID read * - sector erase * - CFI queries * * It does not support timings * It does not support flash interleaving * It does not implement software data protection as found in many real chips * It does not implement erase suspend/resume commands * It does not implement multiple sectors erase * * It does not implement much more ... */#include "hw.h"#include "flash.h"#include "block.h"#include "qemu-timer.h"#define PFLASH_BUG(fmt, args...) \do { \    printf("PFLASH: Possible BUG - " fmt, ##args); \    exit(1); \} while(0)/* #define PFLASH_DEBUG */#ifdef PFLASH_DEBUG#define DPRINTF(fmt, args...)                      \do {                                               \        printf("PFLASH: " fmt , ##args);           \} while (0)#else#define DPRINTF(fmt, args...) do { } while (0)#endifstruct pflash_t {    BlockDriverState *bs;    target_ulong base;    target_ulong sector_len;    target_ulong total_len;    int width;    int wcycle; /* if 0, the flash is read normally */    int bypass;    int ro;    uint8_t cmd;    uint8_t status;    uint16_t ident[4];    uint8_t cfi_len;    uint8_t cfi_table[0x52];    target_ulong counter;    QEMUTimer *timer;    ram_addr_t off;    int fl_mem;    void *storage;};static void pflash_timer (void *opaque){    pflash_t *pfl = opaque;    DPRINTF("%s: command %02x done\n", __func__, pfl->cmd);    /* Reset flash */    pfl->status ^= 0x80;    if (pfl->bypass) {        pfl->wcycle = 2;    } else {        cpu_register_physical_memory(pfl->base, pfl->total_len,                        pfl->off | IO_MEM_ROMD | pfl->fl_mem);        pfl->wcycle = 0;    }    pfl->cmd = 0;}static uint32_t pflash_read (pflash_t *pfl, target_ulong offset, int width){    target_ulong boff;    uint32_t ret;    uint8_t *p;    ret = -1;    offset -= pfl->base;    boff = offset & 0xFF; /* why this here ?? */    if (pfl->width == 2)        boff = boff >> 1;    else if (pfl->width == 4)        boff = boff >> 2;    DPRINTF("%s: reading offset " TARGET_FMT_lx " under cmd %02x\n",            __func__, boff, pfl->cmd);    switch (pfl->cmd) {    case 0x00:        /* Flash area read */        p = pfl->storage;        switch (width) {        case 1:            ret = p[offset];            DPRINTF("%s: data offset " TARGET_FMT_lx " %02x\n",                    __func__, offset, ret);            break;        case 2:#if defined(TARGET_WORDS_BIGENDIAN)            ret = p[offset] << 8;            ret |= p[offset + 1];#else            ret = p[offset];            ret |= p[offset + 1] << 8;#endif            DPRINTF("%s: data offset " TARGET_FMT_lx " %04x\n",                    __func__, offset, ret);            break;        case 4:#if defined(TARGET_WORDS_BIGENDIAN)            ret = p[offset] << 24;            ret |= p[offset + 1] << 16;            ret |= p[offset + 2] << 8;            ret |= p[offset + 3];#else            ret = p[offset];            ret |= p[offset + 1] << 8;            ret |= p[offset + 1] << 8;            ret |= p[offset + 2] << 16;            ret |= p[offset + 3] << 24;#endif            DPRINTF("%s: data offset " TARGET_FMT_lx " %08x\n",                    __func__, offset, ret);            break;        default:            DPRINTF("BUG in %s\n", __func__);        }        break;    case 0x20: /* Block erase */    case 0x50: /* Clear status register */    case 0x60: /* Block /un)lock */    case 0x70: /* Status Register */    case 0xe8: /* Write block */        /* Status register read */        ret = pfl->status;        DPRINTF("%s: status %x\n", __func__, ret);        break;    case 0x98: /* Query mode */        if (boff > pfl->cfi_len)            ret = 0;        else            ret = pfl->cfi_table[boff];        break;    default:        /* This should never happen : reset state & treat it as a read */        DPRINTF("%s: unknown command state: %x\n", __func__, pfl->cmd);        pfl->wcycle = 0;        pfl->cmd = 0;    }    return ret;}/* update flash content on disk */static void pflash_update(pflash_t *pfl, int offset,                          int size){    int offset_end;    if (pfl->bs) {        offset_end = offset + size;        /* round to sectors */        offset = offset >> 9;        offset_end = (offset_end + 511) >> 9;        bdrv_write(pfl->bs, offset, pfl->storage + (offset << 9),                   offset_end - offset);    }}static void pflash_write (pflash_t *pfl, target_ulong offset, uint32_t value,                          int width){    target_ulong boff;    uint8_t *p;    uint8_t cmd;    /* WARNING: when the memory area is in ROMD mode, the offset is a       ram offset, not a physical address */    cmd = value;    if (pfl->wcycle == 0)        offset -= (target_ulong)(long)pfl->storage;    else        offset -= pfl->base;    DPRINTF("%s: offset " TARGET_FMT_lx " %08x %d wcycle 0x%x\n",            __func__, offset, value, width, pfl->wcycle);    /* Set the device in I/O access mode */    cpu_register_physical_memory(pfl->base, pfl->total_len, pfl->fl_mem);    boff = offset & (pfl->sector_len - 1);    if (pfl->width == 2)        boff = boff >> 1;    else if (pfl->width == 4)        boff = boff >> 2;    switch (pfl->wcycle) {    case 0:        /* read mode */        switch (cmd) {        case 0x00: /* ??? */            goto reset_flash;        case 0x20: /* Block erase */            p = pfl->storage;            offset &= ~(pfl->sector_len - 1);            DPRINTF("%s: block erase at " TARGET_FMT_lx " bytes "                    TARGET_FMT_lx "\n",                    __func__, offset, pfl->sector_len);            memset(p + offset, 0xff, pfl->sector_len);            pflash_update(pfl, offset, pfl->sector_len);            pfl->status |= 0x80; /* Ready! */            break;        case 0x50: /* Clear status bits */            DPRINTF("%s: Clear status bits\n", __func__);            pfl->status = 0x0;            goto reset_flash;        case 0x60: /* Block (un)lock */            DPRINTF("%s: Block unlock\n", __func__);            break;        case 0x70: /* Status Register */            DPRINTF("%s: Read status register\n", __func__);            pfl->cmd = cmd;            return;        case 0x98: /* CFI query */            DPRINTF("%s: CFI query\n", __func__);            break;        case 0xe8: /* Write to buffer */            DPRINTF("%s: Write to buffer\n", __func__);            pfl->status |= 0x80; /* Ready! */            break;        case 0xff: /* Read array mode */            DPRINTF("%s: Read array mode\n", __func__);            goto reset_flash;        default:            goto error_flash;        }        pfl->wcycle++;        pfl->cmd = cmd;        return;    case 1:        switch (pfl->cmd) {        case 0x20: /* Block erase */        case 0x28:            if (cmd == 0xd0) { /* confirm */                pfl->wcycle = 1;                pfl->status |= 0x80;            } if (cmd == 0xff) { /* read array mode */                goto reset_flash;            } else                goto error_flash;            break;        case 0xe8:            DPRINTF("%s: block write of %x bytes\n", __func__, cmd);            pfl->counter = cmd;            pfl->wcycle++;            break;        case 0x60:            if (cmd == 0xd0) {                pfl->wcycle = 0;                pfl->status |= 0x80;            } else if (cmd == 0x01) {                pfl->wcycle = 0;                pfl->status |= 0x80;            } else if (cmd == 0xff) {                goto reset_flash;            } else {                DPRINTF("%s: Unknown (un)locking command\n", __func__);                goto reset_flash;            }            break;        case 0x98:            if (cmd == 0xff) {                goto reset_flash;            } else {                DPRINTF("%s: leaving query mode\n", __func__);            }            break;        default:            goto error_flash;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国模少妇一区二区三区| 国产综合色产在线精品| 亚洲欧美一区二区视频| 中文成人综合网| 亚洲自拍与偷拍| 日本不卡一区二区| 国产福利精品导航| 欧美色偷偷大香| 精品国产污网站| 亚洲三级在线免费观看| 日韩精品91亚洲二区在线观看 | 国产精品自产自拍| 国产乱理伦片在线观看夜一区| 99久精品国产| 日韩欧美国产综合在线一区二区三区| 国产欧美一区视频| 午夜精品免费在线| 国产99久久久国产精品免费看| 欧美中文字幕一区二区三区 | 激情都市一区二区| 91丨九色丨黑人外教| 日韩欧美在线不卡| 亚洲色图欧洲色图婷婷| 久久66热re国产| 欧洲精品视频在线观看| 久久女同性恋中文字幕| 亚洲国产精品一区二区久久| 国产伦精品一区二区三区免费 | 午夜精品一区二区三区免费视频 | 国产精品久久久久久妇女6080 | 91精品国产综合久久婷婷香蕉| 国产精品蜜臀av| 麻豆freexxxx性91精品| 在线观看免费视频综合| 久久精品欧美日韩| 男女性色大片免费观看一区二区 | 夜夜操天天操亚洲| 风间由美一区二区三区在线观看| 欧美片网站yy| 亚洲精品国产第一综合99久久| 国产精品99久久不卡二区| 欧美人伦禁忌dvd放荡欲情| 自拍偷拍欧美精品| 国产成人精品一区二区三区四区 | 裸体一区二区三区| 欧美午夜精品久久久久久孕妇| 国产欧美一区二区精品性| 麻豆专区一区二区三区四区五区| 欧美色图天堂网| 亚洲欧洲精品天堂一级| 夫妻av一区二区| 久久精品夜夜夜夜久久| 久久电影网站中文字幕| 欧美久久高跟鞋激| 亚洲一区二区三区中文字幕在线| www.日韩在线| 国产精品久久毛片a| 国产精品自拍在线| 久久免费的精品国产v∧| 麻豆91精品视频| 日韩你懂的在线播放| 日韩av电影免费观看高清完整版 | 丝袜亚洲精品中文字幕一区| 91久久一区二区| 亚洲欧洲精品一区二区三区| 北条麻妃一区二区三区| 欧美激情综合在线| 成人免费看黄yyy456| 欧美激情中文不卡| 国产91在线看| 国产精品大尺度| 色综合天天综合| 亚洲一二三四久久| 欧美吻胸吃奶大尺度电影| 一区二区日韩av| 欧美日韩一区二区在线观看视频| 亚洲成人三级小说| 欧美久久久影院| 三级亚洲高清视频| 日韩午夜中文字幕| 韩国三级在线一区| 久久在线免费观看| 成人精品视频一区| 最新热久久免费视频| 91污在线观看| 亚洲网友自拍偷拍| 欧美日韩在线三区| 日本亚洲欧美天堂免费| 欧美大片一区二区三区| 久久99蜜桃精品| 久久九九久精品国产免费直播| 国产精品1区二区.| 最好看的中文字幕久久| 一本久久综合亚洲鲁鲁五月天| 亚洲一卡二卡三卡四卡 | 日本va欧美va欧美va精品| 日韩一级高清毛片| 国产一区二区三区在线观看免费| 中文字幕av一区二区三区免费看 | 亚洲少妇最新在线视频| 欧美视频精品在线观看| 免费看欧美美女黄的网站| 国产亚洲欧美色| 一本大道综合伊人精品热热| 性做久久久久久久久| 精品少妇一区二区三区免费观看| 国产精品1024久久| 亚洲自拍偷拍网站| 欧美tickling挠脚心丨vk| 国产婷婷色一区二区三区| 99热这里都是精品| 亚洲伊人伊色伊影伊综合网| 精品区一区二区| 成人国产精品视频| 亚洲成人一区二区在线观看| 精品国精品国产| 91麻豆国产自产在线观看| 日韩综合在线视频| 国产精品私房写真福利视频| 欧美日韩卡一卡二| 久久蜜臀精品av| 欧美伊人精品成人久久综合97 | 国产欧美一区二区精品忘忧草| 99这里都是精品| 日韩精品亚洲一区| ●精品国产综合乱码久久久久| 欧美精品一级二级| 成人高清免费在线播放| 日韩中文字幕av电影| 中文字幕成人av| 91麻豆精品国产91久久久更新时间| 国产黄色精品网站| 五月婷婷欧美视频| 亚洲视频免费在线| 久久久久国色av免费看影院| 欧美日韩一区二区在线观看| 丰满岳乱妇一区二区三区| 日本欧美一区二区三区乱码 | 在线观看欧美黄色| 国产麻豆欧美日韩一区| 亚洲香蕉伊在人在线观| 欧美激情一二三区| 日韩一级大片在线观看| 色婷婷综合视频在线观看| 国产乱码精品1区2区3区| 亚洲18女电影在线观看| 亚洲国产精华液网站w| 91精品国产福利在线观看| 91久久精品日日躁夜夜躁欧美| 国产福利视频一区二区三区| 久久99在线观看| 日韩电影网1区2区| 亚洲一区二区三区四区的| 自拍偷自拍亚洲精品播放| 国产婷婷色一区二区三区在线| 欧美电影免费观看高清完整版在线| 欧美色图片你懂的| 91精彩视频在线观看| 福利一区二区在线| 国产精品一区二区久久精品爱涩| 日本不卡视频在线观看| 一区二区日韩av| 樱花影视一区二区| 中文字幕在线一区| 国产日韩综合av| 久久品道一品道久久精品| 精品人在线二区三区| 日韩色在线观看| 91精品国产综合久久久久| 欧美日韩精品是欧美日韩精品| 一本大道综合伊人精品热热| av在线免费不卡| 99精品视频中文字幕| bt7086福利一区国产| 成人黄色av网站在线| 成人综合婷婷国产精品久久蜜臀| 国产在线播精品第三| 国产在线精品一区二区| 蜜臀av性久久久久av蜜臀妖精| 日日摸夜夜添夜夜添精品视频| 亚洲国产sm捆绑调教视频| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲成av人影院| 亚洲制服丝袜av| 亚洲一区二区在线免费观看视频| 亚洲精品日韩一| 亚洲午夜国产一区99re久久| 亚洲一区二区三区视频在线播放| 亚洲小说春色综合另类电影| 亚洲第一激情av| 日韩精品亚洲一区二区三区免费| 日本成人超碰在线观看| 激情深爱一区二区| 国产成人综合在线| 成人av片在线观看| 在线视频国内自拍亚洲视频| 欧美疯狂做受xxxx富婆| 欧美一区二区国产| 精品国产一二三区| 国产精品毛片a∨一区二区三区 |