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

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

?? pflash_cfi02.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* *  CFI parallel flash with AMD command set emulation * *  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 * - chip erase * - unlock bypass command * - CFI queries * * It does not support flash interleaving. * It does not implement boot blocs with reduced size * 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 */#include "hw.h"#include "flash.h"#include "qemu-timer.h"#include "block.h"//#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_phys_addr_t base;    uint32_t sector_len;    uint32_t 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];    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, uint32_t offset, int width){    uint32_t boff;    uint32_t ret;    uint8_t *p;    DPRINTF("%s: offset " TARGET_FMT_lx "\n", __func__, offset);    ret = -1;    offset -= pfl->base;    boff = offset & 0xFF;    if (pfl->width == 2)        boff = boff >> 1;    else if (pfl->width == 4)        boff = boff >> 2;    switch (pfl->cmd) {    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;    case 0x80:        /* We accept reads during second unlock sequence... */    case 0x00:    flash_read:        /* Flash area read */        p = pfl->storage;        switch (width) {        case 1:            ret = p[offset];//            DPRINTF("%s: data offset %08x %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 %08x %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 + 2] << 16;            ret |= p[offset + 3] << 24;#endif//            DPRINTF("%s: data offset %08x %08x\n", __func__, offset, ret);            break;        }        break;    case 0x90:        /* flash ID read */        switch (boff) {        case 0x00:        case 0x01:            ret = pfl->ident[boff & 0x01];            break;        case 0x02:            ret = 0x00; /* Pretend all sectors are unprotected */            break;        case 0x0E:        case 0x0F:            if (pfl->ident[2 + (boff & 0x01)] == (uint8_t)-1)                goto flash_read;            ret = pfl->ident[2 + (boff & 0x01)];            break;        default:            goto flash_read;        }        DPRINTF("%s: ID " TARGET_FMT_ld " %x\n", __func__, boff, ret);        break;    case 0xA0:    case 0x10:    case 0x30:        /* Status register read */        ret = pfl->status;        DPRINTF("%s: status %x\n", __func__, ret);        /* Toggle bit 6 */        pfl->status ^= 0x40;        break;    case 0x98:        /* CFI query mode */        if (boff > pfl->cfi_len)            ret = 0;        else            ret = pfl->cfi_table[boff];        break;    }    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, uint32_t offset, uint32_t value,                          int width){    uint32_t 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->cmd != 0xA0 && cmd == 0xF0) {#if 0        DPRINTF("%s: flash reset asked (%02x %02x)\n",                __func__, pfl->cmd, cmd);#endif        goto reset_flash;    }    DPRINTF("%s: offset " TARGET_FMT_lx " %08x %d %d\n", __func__,            offset, value, width, pfl->wcycle);    if (pfl->wcycle == 0)        offset -= (uint32_t)(long)pfl->storage;    else        offset -= pfl->base;    DPRINTF("%s: offset " TARGET_FMT_lx " %08x %d\n", __func__,            offset, value, width);    /* 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:        /* We're in read mode */    check_unlock0:        if (boff == 0x55 && cmd == 0x98) {        enter_CFI_mode:            /* Enter CFI query mode */            pfl->wcycle = 7;            pfl->cmd = 0x98;            return;        }        if (boff != 0x555 || cmd != 0xAA) {            DPRINTF("%s: unlock0 failed " TARGET_FMT_lx " %02x %04x\n",                    __func__, boff, cmd, 0x555);            goto reset_flash;        }        DPRINTF("%s: unlock sequence started\n", __func__);        break;    case 1:        /* We started an unlock sequence */    check_unlock1:        if (boff != 0x2AA || cmd != 0x55) {            DPRINTF("%s: unlock1 failed " TARGET_FMT_lx " %02x\n", __func__,                    boff, cmd);            goto reset_flash;        }        DPRINTF("%s: unlock sequence done\n", __func__);        break;    case 2:        /* We finished an unlock sequence */        if (!pfl->bypass && boff != 0x555) {            DPRINTF("%s: command failed " TARGET_FMT_lx " %02x\n", __func__,                    boff, cmd);            goto reset_flash;        }        switch (cmd) {        case 0x20:            pfl->bypass = 1;            goto do_bypass;        case 0x80:        case 0x90:        case 0xA0:            pfl->cmd = cmd;            DPRINTF("%s: starting command %02x\n", __func__, cmd);            break;        default:            DPRINTF("%s: unknown command %02x\n", __func__, cmd);            goto reset_flash;        }        break;    case 3:        switch (pfl->cmd) {        case 0x80:            /* We need another unlock sequence */            goto check_unlock0;        case 0xA0:            DPRINTF("%s: write data offset " TARGET_FMT_lx " %08x %d\n",                    __func__, offset, value, width);            p = pfl->storage;            switch (width) {            case 1:                p[offset] &= value;                pflash_update(pfl, offset, 1);                break;            case 2:#if defined(TARGET_WORDS_BIGENDIAN)                p[offset] &= value >> 8;                p[offset + 1] &= value;#else                p[offset] &= value;                p[offset + 1] &= value >> 8;#endif                pflash_update(pfl, offset, 2);                break;            case 4:#if defined(TARGET_WORDS_BIGENDIAN)                p[offset] &= value >> 24;                p[offset + 1] &= value >> 16;                p[offset + 2] &= value >> 8;                p[offset + 3] &= value;#else                p[offset] &= value;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu亚洲综合色欧美| 91亚洲资源网| 欧美精品一区二区高清在线观看| 日韩精品电影在线| 欧美成人aa大片| 国产精品综合二区| 国产精品高潮久久久久无| 成人av午夜电影| 亚洲福利视频一区二区| 欧美一区二区精品久久911| 黑人巨大精品欧美黑白配亚洲| 久久久久久免费网| 色老汉一区二区三区| 亚洲福利视频一区二区| 欧美成人国产一区二区| 成人av资源站| 日本免费在线视频不卡一不卡二| 精品国精品国产| 色嗨嗨av一区二区三区| 蜜臀av一区二区在线观看| 国产精品久线在线观看| 欧美日韩夫妻久久| 国产不卡免费视频| 三级不卡在线观看| 国产精品看片你懂得| 日韩一级大片在线观看| 99精品视频中文字幕| 免费欧美在线视频| 国产精品久久久久久久裸模| 欧美精品自拍偷拍| thepron国产精品| 久草在线在线精品观看| 亚洲综合色自拍一区| 久久久精品2019中文字幕之3| 欧洲av在线精品| 国产河南妇女毛片精品久久久| 亚洲午夜久久久久中文字幕久| 26uuu亚洲综合色欧美| 欧美日韩精品一区二区三区四区| 国产麻豆一精品一av一免费| 水蜜桃久久夜色精品一区的特点 | 波多野结衣中文一区| 欧美a一区二区| 亚洲黄色免费电影| 日本一二三四高清不卡| 精品久久久久久久久久久久包黑料| 9久草视频在线视频精品| 久久99国产精品免费| 无码av免费一区二区三区试看 | 国产一区视频网站| 日韩中文字幕不卡| 亚洲午夜日本在线观看| 1024成人网| 日本一区二区动态图| 久久久精品人体av艺术| 日韩视频中午一区| 在线不卡中文字幕| 欧美日韩在线播放| 91麻豆国产自产在线观看| 成人激情黄色小说| 国产风韵犹存在线视精品| 美女一区二区视频| 人人精品人人爱| 日本美女视频一区二区| 亚洲成av人影院在线观看网| 亚洲欧美激情在线| 亚洲人吸女人奶水| 中文字幕av一区二区三区| 国产欧美日韩视频在线观看| 久久久综合九色合综国产精品| 日韩免费观看高清完整版| 9191国产精品| 日韩一级二级三级精品视频| 欧美一三区三区四区免费在线看| 欧美久久久久久久久| 91精品国产综合久久久久久漫画| 69av一区二区三区| 日韩女优av电影在线观看| 欧美成人在线直播| 久久婷婷一区二区三区| 国产目拍亚洲精品99久久精品| 久久久.com| 国产精品高潮久久久久无| 亚洲激情成人在线| 亚洲成av人片观看| 捆绑调教一区二区三区| 国产精品18久久久久| 高清shemale亚洲人妖| 97久久精品人人做人人爽| 欧洲精品在线观看| 欧美一区二区三区视频| 久久久久久久综合| 国产精品女同一区二区三区| 亚洲男帅同性gay1069| 丝袜美腿亚洲一区二区图片| 久久国产精品一区二区| 国产成人免费视| 日本韩国一区二区| 91麻豆精品91久久久久久清纯| 精品欧美久久久| 国产精品乱码人人做人人爱 | 99riav一区二区三区| 91国产免费看| 日韩精品一区二区三区四区视频| 久久久久久久久久久99999| 亚洲欧美一区二区三区孕妇| 亚洲高清视频的网址| 黄色成人免费在线| 在线视频观看一区| 精品国产乱码久久久久久牛牛| 中文字幕一区二区三区不卡| 天使萌一区二区三区免费观看| 国产在线精品免费| 欧美亚洲国产一区二区三区va | 久久久久久久久久电影| 亚洲精品免费在线播放| 久草在线在线精品观看| 色久综合一二码| 久久综合久色欧美综合狠狠| 亚洲精品老司机| 国产一区二区看久久| 欧美色国产精品| 国产精品青草久久| 天天影视涩香欲综合网| 成人动漫中文字幕| 欧美一级搡bbbb搡bbbb| 一区二区三区在线高清| 国产福利电影一区二区三区| 欧美乱妇15p| 亚洲婷婷综合色高清在线| 久久国产福利国产秒拍| 在线视频你懂得一区二区三区| 国产亚洲欧美日韩在线一区| 婷婷成人激情在线网| 91丨九色丨黑人外教| 国产欧美一区二区精品忘忧草| 欧美aⅴ一区二区三区视频| 91免费在线视频观看| 国产香蕉久久精品综合网| 日韩电影免费在线| 欧美三级在线视频| 亚洲天堂av一区| 成人精品一区二区三区中文字幕| 日韩一区二区中文字幕| 午夜精品影院在线观看| 欧美在线一二三| 成人免费一区二区三区在线观看| 国产在线精品一区二区三区不卡| 欧美一区二区三区婷婷月色| 亚洲一区二区三区免费视频| 91国偷自产一区二区三区成为亚洲经典| 国产色综合一区| 韩国av一区二区| 久久综合久久鬼色| 久久99精品久久久久久动态图| 91精品一区二区三区久久久久久| 性感美女极品91精品| 91国偷自产一区二区三区成为亚洲经典 | 韩国理伦片一区二区三区在线播放| 欧美日韩一级黄| 亚洲午夜久久久| 在线观看欧美日本| 一区二区三区资源| 在线亚洲免费视频| 一区二区三区色| 欧美色图一区二区三区| 亚洲成人自拍偷拍| 欧美日韩国产首页在线观看| 午夜视频在线观看一区| 91精品欧美一区二区三区综合在| 日本色综合中文字幕| 日韩精品一区二区三区三区免费| 久久av资源网| 国产亚洲一区二区在线观看| 国产麻豆精品久久一二三| 欧美国产国产综合| 一本久道久久综合中文字幕 | 91福利在线播放| 亚洲一级在线观看| 欧美疯狂性受xxxxx喷水图片| 婷婷丁香久久五月婷婷| 精品日韩欧美一区二区| 国产精品66部| 亚洲视频1区2区| 6080日韩午夜伦伦午夜伦| 久久成人麻豆午夜电影| 久久精品水蜜桃av综合天堂| 懂色av中文一区二区三区| 国产精品国产a| 欧美少妇xxx| 极品少妇xxxx偷拍精品少妇| 日本一二三不卡| 欧美日韩精品久久久| 韩国女主播成人在线| 亚洲欧美日韩国产综合在线| 69堂精品视频| 成人污污视频在线观看| 五月天激情综合网| 久久久久久久久97黄色工厂| 在线观看亚洲成人|