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

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

?? mips_malta.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* * QEMU Malta board support * * Copyright (c) 2006 Aurelien Jarno * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */#include "hw.h"#include "pc.h"#include "fdc.h"#include "net.h"#include "boards.h"#include "smbus.h"#include "block.h"#include "flash.h"#include "mips.h"#include "pci.h"#include "qemu-char.h"#include "sysemu.h"#include "audio/audio.h"#include "boards.h"//#define DEBUG_BOARD_INIT#ifdef TARGET_WORDS_BIGENDIAN#define BIOS_FILENAME "mips_bios.bin"#else#define BIOS_FILENAME "mipsel_bios.bin"#endif#ifdef TARGET_MIPS64#define PHYS_TO_VIRT(x) ((x) | ~0x7fffffffULL)#else#define PHYS_TO_VIRT(x) ((x) | ~0x7fffffffU)#endif#define ENVP_ADDR (int32_t)0x80002000#define VIRT_TO_PHYS_ADDEND (-((int64_t)(int32_t)0x80000000))#define ENVP_NB_ENTRIES	 	16#define ENVP_ENTRY_SIZE	 	256#define MAX_IDE_BUS 2extern FILE *logfile;typedef struct {    uint32_t leds;    uint32_t brk;    uint32_t gpout;    uint32_t i2cin;    uint32_t i2coe;    uint32_t i2cout;    uint32_t i2csel;    CharDriverState *display;    char display_text[9];    SerialState *uart;} MaltaFPGAState;static PITState *pit;static struct _loaderparams {    int ram_size;    const char *kernel_filename;    const char *kernel_cmdline;    const char *initrd_filename;} loaderparams;/* Malta FPGA */static void malta_fpga_update_display(void *opaque){    char leds_text[9];    int i;    MaltaFPGAState *s = opaque;    for (i = 7 ; i >= 0 ; i--) {        if (s->leds & (1 << i))            leds_text[i] = '#';        else            leds_text[i] = ' ';    }    leds_text[8] = '\0';    qemu_chr_printf(s->display, "\e[H\n\n|\e[32m%-8.8s\e[00m|\r\n", leds_text);    qemu_chr_printf(s->display, "\n\n\n\n|\e[31m%-8.8s\e[00m|", s->display_text);}/* * EEPROM 24C01 / 24C02 emulation. * * Emulation for serial EEPROMs: * 24C01 - 1024 bit (128 x 8) * 24C02 - 2048 bit (256 x 8) * * Typical device names include Microchip 24C02SC or SGS Thomson ST24C02. *///~ #define DEBUG#if defined(DEBUG)#  define logout(fmt, args...) fprintf(stderr, "MALTA\t%-24s" fmt, __func__, ##args)#else#  define logout(fmt, args...) ((void)0)#endifstruct _eeprom24c0x_t {  uint8_t tick;  uint8_t address;  uint8_t command;  uint8_t ack;  uint8_t scl;  uint8_t sda;  uint8_t data;  //~ uint16_t size;  uint8_t contents[256];};typedef struct _eeprom24c0x_t eeprom24c0x_t;static eeprom24c0x_t eeprom = {    contents: {        /* 00000000: */ 0x80,0x08,0x04,0x0D,0x0A,0x01,0x40,0x00,        /* 00000008: */ 0x01,0x75,0x54,0x00,0x82,0x08,0x00,0x01,        /* 00000010: */ 0x8F,0x04,0x02,0x01,0x01,0x00,0x0E,0x00,        /* 00000018: */ 0x00,0x00,0x00,0x14,0x0F,0x14,0x2D,0x40,        /* 00000020: */ 0x15,0x08,0x15,0x08,0x00,0x00,0x00,0x00,        /* 00000028: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000030: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000038: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x12,0xD0,        /* 00000040: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000048: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000050: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000058: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000060: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000068: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000070: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,        /* 00000078: */ 0x00,0x00,0x00,0x00,0x00,0x00,0x64,0xF4,    },};static uint8_t eeprom24c0x_read(){    logout("%u: scl = %u, sda = %u, data = 0x%02x\n",        eeprom.tick, eeprom.scl, eeprom.sda, eeprom.data);    return eeprom.sda;}static void eeprom24c0x_write(int scl, int sda){    if (eeprom.scl && scl && (eeprom.sda != sda)) {        logout("%u: scl = %u->%u, sda = %u->%u i2c %s\n",                eeprom.tick, eeprom.scl, scl, eeprom.sda, sda, sda ? "stop" : "start");        if (!sda) {            eeprom.tick = 1;            eeprom.command = 0;        }    } else if (eeprom.tick == 0 && !eeprom.ack) {        /* Waiting for start. */        logout("%u: scl = %u->%u, sda = %u->%u wait for i2c start\n",                eeprom.tick, eeprom.scl, scl, eeprom.sda, sda);    } else if (!eeprom.scl && scl) {        logout("%u: scl = %u->%u, sda = %u->%u trigger bit\n",                eeprom.tick, eeprom.scl, scl, eeprom.sda, sda);        if (eeprom.ack) {            logout("\ti2c ack bit = 0\n");            sda = 0;            eeprom.ack = 0;        } else if (eeprom.sda == sda) {            uint8_t bit = (sda != 0);            logout("\ti2c bit = %d\n", bit);            if (eeprom.tick < 9) {                eeprom.command <<= 1;                eeprom.command += bit;                eeprom.tick++;                if (eeprom.tick == 9) {                    logout("\tcommand 0x%04x, %s\n", eeprom.command, bit ? "read" : "write");                    eeprom.ack = 1;                }            } else if (eeprom.tick < 17) {                if (eeprom.command & 1) {                    sda = ((eeprom.data & 0x80) != 0);                }                eeprom.address <<= 1;                eeprom.address += bit;                eeprom.tick++;                eeprom.data <<= 1;                if (eeprom.tick == 17) {                    eeprom.data = eeprom.contents[eeprom.address];                    logout("\taddress 0x%04x, data 0x%02x\n", eeprom.address, eeprom.data);                    eeprom.ack = 1;                    eeprom.tick = 0;                }            } else if (eeprom.tick >= 17) {                sda = 0;            }        } else {            logout("\tsda changed with raising scl\n");        }    } else {        logout("%u: scl = %u->%u, sda = %u->%u\n", eeprom.tick, eeprom.scl, scl, eeprom.sda, sda);    }    eeprom.scl = scl;    eeprom.sda = sda;}static uint32_t malta_fpga_readl(void *opaque, target_phys_addr_t addr){    MaltaFPGAState *s = opaque;    uint32_t val = 0;    uint32_t saddr;    saddr = (addr & 0xfffff);    switch (saddr) {    /* SWITCH Register */    case 0x00200:        val = 0x00000000;		/* All switches closed */	break;    /* STATUS Register */    case 0x00208:#ifdef TARGET_WORDS_BIGENDIAN        val = 0x00000012;#else        val = 0x00000010;#endif        break;    /* JMPRS Register */    case 0x00210:        val = 0x00;        break;    /* LEDBAR Register */    case 0x00408:        val = s->leds;        break;    /* BRKRES Register */    case 0x00508:        val = s->brk;        break;    /* UART Registers are handled directly by the serial device */    /* GPOUT Register */    case 0x00a00:        val = s->gpout;        break;    /* XXX: implement a real I2C controller */    /* GPINP Register */    case 0x00a08:        /* IN = OUT until a real I2C control is implemented */        if (s->i2csel)            val = s->i2cout;        else            val = 0x00;        break;    /* I2CINP Register */    case 0x00b00:        val = ((s->i2cin & ~1) | eeprom24c0x_read());        break;    /* I2COE Register */    case 0x00b08:        val = s->i2coe;        break;    /* I2COUT Register */    case 0x00b10:        val = s->i2cout;        break;    /* I2CSEL Register */    case 0x00b18:        val = s->i2csel;        break;    default:#if 0        printf ("malta_fpga_read: Bad register offset 0x" TARGET_FMT_lx "\n",		addr);#endif        break;    }    return val;}static void malta_fpga_writel(void *opaque, target_phys_addr_t addr,                              uint32_t val){    MaltaFPGAState *s = opaque;    uint32_t saddr;    saddr = (addr & 0xfffff);    switch (saddr) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av网站在线观看免费| 国产精品天美传媒| 天天操天天综合网| 欧美日韩亚洲综合在线 | 久久激情五月婷婷| 日韩视频永久免费| 麻豆中文一区二区| 久久众筹精品私拍模特| 国产成人在线视频网址| 国产精品久久久久久久久动漫| jiyouzz国产精品久久| 一级女性全黄久久生活片免费| 欧美无乱码久久久免费午夜一区 | 欧美综合一区二区| 五月婷婷欧美视频| 精品国产91洋老外米糕| 国产a级毛片一区| 一区二区成人在线视频 | 日韩高清国产一区在线| 欧美精品一区二| 成人天堂资源www在线| 亚洲精品国产一区二区三区四区在线 | 色婷婷国产精品| 日韩不卡一区二区三区| 久久久亚洲精品石原莉奈| 99久精品国产| 免费高清不卡av| 中文字幕日韩一区| 欧美一区二区三区成人| 成人黄色a**站在线观看| 亚洲国产精品久久久久婷婷884 | 色老综合老女人久久久| 日韩成人免费在线| 国产免费观看久久| 欧美日韩小视频| 国产99精品视频| 日欧美一区二区| 中文字幕免费不卡| 欧美一区二区视频在线观看2020| 国产sm精品调教视频网站| 亚洲成人激情综合网| 国产欧美久久久精品影院| 欧美日韩黄色一区二区| 丁香激情综合五月| 日本不卡的三区四区五区| 亚洲免费视频中文字幕| 亚洲精品一区二区三区蜜桃下载 | 欧美午夜精品久久久| 懂色一区二区三区免费观看| 亚洲国产精品人人做人人爽| 欧美经典一区二区| 欧美一级高清片| 91福利社在线观看| 成人美女视频在线看| 麻豆高清免费国产一区| 亚洲另类色综合网站| 久久精品视频在线看| 在线播放国产精品二区一二区四区| 成人av网站免费| 蜜臀av一区二区在线免费观看| 亚洲欧美另类小说视频| 国产网站一区二区| 日韩免费电影网站| 欧美久久久一区| 一本到不卡精品视频在线观看| 国产高清精品久久久久| 蜜臀久久久久久久| 亚洲电影一级黄| 亚洲精品视频一区| 亚洲色图都市小说| 国产精品久久久久久久久动漫 | 国产亚洲精品aa| 久久久国际精品| 精品福利一二区| 日韩精品在线看片z| 日韩欧美国产wwwww| 日韩一级欧美一级| 欧美一区二区三区在线| 69堂精品视频| 欧美电影在哪看比较好| 欧美性猛交xxxx乱大交退制版| 在线免费不卡视频| 欧美在线一二三| 欧美三级欧美一级| 欧美精品一二三| 91精品一区二区三区久久久久久 | www.99精品| 99精品热视频| 99国产精品久久| 色婷婷精品大在线视频| 欧美三级韩国三级日本三斤| 欧美日韩亚洲综合在线| 91精品久久久久久久99蜜桃| 日韩一级二级三级精品视频| 欧美mv日韩mv国产网站| 久久久久亚洲综合| 日本一区二区三区在线不卡 | 色综合久久精品| 欧洲一区在线观看| 56国语精品自产拍在线观看| 日韩片之四级片| 国产亚洲精品资源在线26u| 国产精品三级在线观看| 亚洲欧美激情在线| 亚洲成人tv网| 黑人巨大精品欧美一区| 国产成人av影院| 91女神在线视频| 欧美日本在线观看| 亚洲精品一区二区三区福利| 国产欧美精品一区| 亚洲一级在线观看| 久久不见久久见免费视频7| 国产99精品国产| 欧美无砖砖区免费| 久久久精品影视| 一区二区三区精品视频| 麻豆国产精品视频| 91亚洲大成网污www| 欧美一区二区三区色| 久久久精品影视| 亚洲成人免费看| 国产激情偷乱视频一区二区三区| 日本高清不卡一区| 亚洲最新视频在线观看| 日韩电影在线免费| 波多野结衣亚洲| 日韩写真欧美这视频| 日韩一区有码在线| 久草在线在线精品观看| 色美美综合视频| 久久免费视频一区| 亚洲午夜激情网页| 成人av网站大全| 精品福利一区二区三区免费视频| 亚洲主播在线观看| 成人激情黄色小说| 精品欧美一区二区久久| 亚洲小说欧美激情另类| 福利91精品一区二区三区| 91麻豆精品国产91久久久 | 一区二区三区日本| 狠狠狠色丁香婷婷综合激情| 一本久久精品一区二区| 久久精品视频在线看| 日欧美一区二区| 在线视频欧美精品| 专区另类欧美日韩| 国产精品 欧美精品| 欧美成人video| 视频一区欧美精品| 91电影在线观看| 亚洲日本在线天堂| 成人永久aaa| 久久精品一区八戒影视| 久久精品久久精品| 日韩精品一区二区在线观看| 亚洲国产综合色| 日本韩国一区二区| 亚洲人成人一区二区在线观看| 国产福利一区二区| 久久久美女艺术照精彩视频福利播放 | 欧美日韩在线直播| 一二三四社区欧美黄| 91小视频在线观看| 国产精品久久二区二区| 高清不卡一区二区在线| 国产网站一区二区| 国产高清成人在线| 国产精品久久久久永久免费观看 | 国产精品美女久久久久久久网站| 国产伦精品一区二区三区在线观看| 欧美不卡一区二区三区四区| 老司机精品视频在线| 日韩一区二区不卡| 美腿丝袜亚洲综合| 欧美xxxx老人做受| 激情小说亚洲一区| 久久精品视频在线免费观看| 国产69精品久久99不卡| 国产精品美女视频| 色综合久久中文综合久久97| 亚洲日本一区二区| 欧美日韩中文精品| 九九精品视频在线看| 日韩免费高清视频| 国产福利一区二区三区在线视频| 中文字幕av免费专区久久| kk眼镜猥琐国模调教系列一区二区 | 99在线视频精品| 亚洲精品自拍动漫在线| 欧美日韩一区不卡| 久久 天天综合| 国产精品久久久久久久久免费樱桃 | 国产精品美女久久福利网站| 97精品电影院| 天堂蜜桃91精品| 久久久久久久久蜜桃| 91在线观看成人| 亚洲成人资源在线|