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

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

?? main.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* *  qemu user main * *  Copyright (c) 2003 Fabrice Bellard *  Copyright (c) 2006 Pierre d'Herbemont * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program 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 General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */#include <stdlib.h>#include <stdio.h>#include <stdarg.h>#include <string.h>#include <errno.h>#include <unistd.h>#include <sys/syscall.h>#include <sys/mman.h>#include "qemu.h"#define DEBUG_LOGFILE "/tmp/qemu.log"#ifdef __APPLE__#include <crt_externs.h># define environ  (*_NSGetEnviron())#endif#include <mach/mach_init.h>#include <mach/vm_map.h>const char *interp_prefix = "";asm(".zerofill __STD_PROG_ZONE, __STD_PROG_ZONE, __std_prog_zone, 0x0dfff000");/* XXX: on x86 MAP_GROWSDOWN only works if ESP <= address + 32, so   we allocate a bigger stack. Need a better solution, for example   by remapping the process stack directly at the right place */unsigned long stack_size = 512 * 1024;void qerror(const char *fmt, ...){    va_list ap;    va_start(ap, fmt);    vfprintf(stderr, fmt, ap);    va_end(ap);    fprintf(stderr, "\n");    exit(1);}void gemu_log(const char *fmt, ...){    va_list ap;    va_start(ap, fmt);    vfprintf(stderr, fmt, ap);    va_end(ap);}void cpu_outb(CPUState *env, int addr, int val){    fprintf(stderr, "outb: port=0x%04x, data=%02x\n", addr, val);}void cpu_outw(CPUState *env, int addr, int val){    fprintf(stderr, "outw: port=0x%04x, data=%04x\n", addr, val);}void cpu_outl(CPUState *env, int addr, int val){    fprintf(stderr, "outl: port=0x%04x, data=%08x\n", addr, val);}int cpu_inb(CPUState *env, int addr){    fprintf(stderr, "inb: port=0x%04x\n", addr);    return 0;}int cpu_inw(CPUState *env, int addr){    fprintf(stderr, "inw: port=0x%04x\n", addr);    return 0;}int cpu_inl(CPUState *env, int addr){    fprintf(stderr, "inl: port=0x%04x\n", addr);    return 0;}int cpu_get_pic_interrupt(CPUState *env){    return -1;}#ifdef TARGET_PPCstatic inline uint64_t cpu_ppc_get_tb (CPUState *env){    /* TO FIX */    return 0;}uint32_t cpu_ppc_load_tbl (CPUState *env){    return cpu_ppc_get_tb(env) & 0xFFFFFFFF;}uint32_t cpu_ppc_load_tbu (CPUState *env){    return cpu_ppc_get_tb(env) >> 32;}uint32_t cpu_ppc_load_atbl (CPUState *env){    return cpu_ppc_get_tb(env) & 0xFFFFFFFF;}uint32_t cpu_ppc_load_atbu (CPUState *env){    return cpu_ppc_get_tb(env) >> 32;}uint32_t cpu_ppc601_load_rtcu (CPUState *env){    cpu_ppc_load_tbu(env);}uint32_t cpu_ppc601_load_rtcl (CPUState *env){    return cpu_ppc_load_tbl(env) & 0x3FFFFF80;}/* XXX: to be fixed */int ppc_dcr_read (ppc_dcr_t *dcr_env, int dcrn, target_ulong *valp){    return -1;}int ppc_dcr_write (ppc_dcr_t *dcr_env, int dcrn, target_ulong val){    return -1;}#define EXCP_DUMP(env, fmt, args...)                                         \do {                                                                          \    fprintf(stderr, fmt , ##args);                                            \    cpu_dump_state(env, stderr, fprintf, 0);                                  \    if (loglevel != 0) {                                                      \        fprintf(logfile, fmt , ##args);                                       \        cpu_dump_state(env, logfile, fprintf, 0);                             \    }                                                                         \} while (0)void cpu_loop(CPUPPCState *env){    int trapnr;    uint32_t ret;    target_siginfo_t info;    for(;;) {        trapnr = cpu_ppc_exec(env);        switch(trapnr) {        case POWERPC_EXCP_NONE:            /* Just go on */            break;        case POWERPC_EXCP_CRITICAL: /* Critical input                        */            cpu_abort(env, "Critical interrupt while in user mode. "                      "Aborting\n");            break;        case POWERPC_EXCP_MCHECK:   /* Machine check exception               */            cpu_abort(env, "Machine check exception while in user mode. "                      "Aborting\n");            break;        case POWERPC_EXCP_DSI:      /* Data storage exception                */#ifndef DAR/* To deal with multiple qemu header version as host for the darwin-user code */# define DAR SPR_DAR#endif            EXCP_DUMP(env, "Invalid data memory access: 0x" ADDRX "\n",                      env->spr[SPR_DAR]);            /* Handle this via the gdb */            gdb_handlesig (env, SIGSEGV);            info.si_addr = (void*)env->nip;            queue_signal(info.si_signo, &info);            break;        case POWERPC_EXCP_ISI:      /* Instruction storage exception         */            EXCP_DUMP(env, "Invalid instruction fetch: 0x\n" ADDRX "\n",                      env->spr[SPR_DAR]);            /* Handle this via the gdb */            gdb_handlesig (env, SIGSEGV);            info.si_addr = (void*)(env->nip - 4);            queue_signal(info.si_signo, &info);            break;        case POWERPC_EXCP_EXTERNAL: /* External input                        */            cpu_abort(env, "External interrupt while in user mode. "                      "Aborting\n");            break;        case POWERPC_EXCP_ALIGN:    /* Alignment exception                   */            EXCP_DUMP(env, "Unaligned memory access\n");            info.si_errno = 0;            info.si_code = BUS_ADRALN;            info.si_addr = (void*)(env->nip - 4);            queue_signal(info.si_signo, &info);            break;        case POWERPC_EXCP_PROGRAM:  /* Program exception                     */            /* XXX: check this */            switch (env->error_code & ~0xF) {            case POWERPC_EXCP_FP:                EXCP_DUMP(env, "Floating point program exception\n");                /* Set FX */                info.si_signo = SIGFPE;                info.si_errno = 0;                switch (env->error_code & 0xF) {                case POWERPC_EXCP_FP_OX:                    info.si_code = FPE_FLTOVF;                    break;                case POWERPC_EXCP_FP_UX:                    info.si_code = FPE_FLTUND;                    break;                case POWERPC_EXCP_FP_ZX:                case POWERPC_EXCP_FP_VXZDZ:                    info.si_code = FPE_FLTDIV;                    break;                case POWERPC_EXCP_FP_XX:                    info.si_code = FPE_FLTRES;                    break;                case POWERPC_EXCP_FP_VXSOFT:                    info.si_code = FPE_FLTINV;                    break;                case POWERPC_EXCP_FP_VXSNAN:                case POWERPC_EXCP_FP_VXISI:                case POWERPC_EXCP_FP_VXIDI:                case POWERPC_EXCP_FP_VXIMZ:                case POWERPC_EXCP_FP_VXVC:                case POWERPC_EXCP_FP_VXSQRT:                case POWERPC_EXCP_FP_VXCVI:                    info.si_code = FPE_FLTSUB;                    break;                default:                    EXCP_DUMP(env, "Unknown floating point exception (%02x)\n",                              env->error_code);                    break;                }                break;            case POWERPC_EXCP_INVAL:                EXCP_DUMP(env, "Invalid instruction\n");                info.si_signo = SIGILL;                info.si_errno = 0;                switch (env->error_code & 0xF) {                case POWERPC_EXCP_INVAL_INVAL:                    info.si_code = ILL_ILLOPC;                    break;                case POWERPC_EXCP_INVAL_LSWX:                    info.si_code = ILL_ILLOPN;                    break;                case POWERPC_EXCP_INVAL_SPR:                    info.si_code = ILL_PRVREG;                    break;                case POWERPC_EXCP_INVAL_FP:                    info.si_code = ILL_COPROC;                    break;                default:                    EXCP_DUMP(env, "Unknown invalid operation (%02x)\n",                              env->error_code & 0xF);                    info.si_code = ILL_ILLADR;                    break;                }                /* Handle this via the gdb */                gdb_handlesig (env, SIGSEGV);                break;            case POWERPC_EXCP_PRIV:                EXCP_DUMP(env, "Privilege violation\n");                info.si_signo = SIGILL;                info.si_errno = 0;                switch (env->error_code & 0xF) {                case POWERPC_EXCP_PRIV_OPC:                    info.si_code = ILL_PRVOPC;                    break;                case POWERPC_EXCP_PRIV_REG:                    info.si_code = ILL_PRVREG;                    break;                default:                    EXCP_DUMP(env, "Unknown privilege violation (%02x)\n",                              env->error_code & 0xF);                    info.si_code = ILL_PRVOPC;                    break;                }                break;            case POWERPC_EXCP_TRAP:                cpu_abort(env, "Tried to call a TRAP\n");                break;            default:                /* Should not happen ! */                cpu_abort(env, "Unknown program exception (%02x)\n",                          env->error_code);                break;            }            info.si_addr = (void*)(env->nip - 4);            queue_signal(info.si_signo, &info);            break;        case POWERPC_EXCP_FPU:      /* Floating-point unavailable exception  */            EXCP_DUMP(env, "No floating point allowed\n");            info.si_signo = SIGILL;            info.si_errno = 0;            info.si_code = ILL_COPROC;            info.si_addr = (void*)(env->nip - 4);            queue_signal(info.si_signo, &info);            break;        case POWERPC_EXCP_SYSCALL:  /* System call exception                 */            cpu_abort(env, "Syscall exception while in user mode. "                      "Aborting\n");            break;        case POWERPC_EXCP_APU:      /* Auxiliary processor unavailable       */            EXCP_DUMP(env, "No APU instruction allowed\n");            info.si_signo = SIGILL;            info.si_errno = 0;            info.si_code = ILL_COPROC;            info.si_addr = (void*)(env->nip - 4);            queue_signal(info.si_signo, &info);            break;        case POWERPC_EXCP_DECR:     /* Decrementer exception                 */            cpu_abort(env, "Decrementer interrupt while in user mode. "                      "Aborting\n");            break;        case POWERPC_EXCP_FIT:      /* Fixed-interval timer interrupt        */            cpu_abort(env, "Fix interval timer interrupt while in user mode. "                      "Aborting\n");            break;        case POWERPC_EXCP_WDT:      /* Watchdog timer interrupt              */            cpu_abort(env, "Watchdog timer interrupt while in user mode. "                      "Aborting\n");            break;        case POWERPC_EXCP_DTLB:     /* Data TLB error                        */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久激情视频| 亚洲靠逼com| 亚洲欧美日韩一区二区三区在线观看| 亚洲国产另类av| 成人在线视频一区| 日韩免费视频线观看| 亚洲精品大片www| 韩国女主播成人在线观看| 欧美三级电影网| 亚洲日本一区二区三区| 国产福利不卡视频| 日韩一区二区免费高清| 亚洲午夜国产一区99re久久| 粉嫩13p一区二区三区| 日韩欧美国产系列| 水野朝阳av一区二区三区| 91美女蜜桃在线| 成人欧美一区二区三区黑人麻豆 | 亚洲特黄一级片| 精品亚洲成av人在线观看| 欧美日韩在线直播| 亚洲一区二区三区四区在线免费观看 | 99视频在线观看一区三区| 久久综合九色综合久久久精品综合| 五月天婷婷综合| 欧美视频自拍偷拍| 亚洲尤物在线视频观看| 色999日韩国产欧美一区二区| 中文字幕不卡的av| 成人午夜电影久久影院| 中文字幕第一页久久| 大白屁股一区二区视频| 欧美激情综合五月色丁香| 国产成人综合在线播放| 久久久精品中文字幕麻豆发布| 精品一区二区三区影院在线午夜| 日韩三级免费观看| 国产麻豆视频一区二区| 久久丝袜美腿综合| 国产成人午夜精品影院观看视频| 久久久综合精品| 成人性色生活片| 亚洲人成网站在线| 欧美自拍偷拍一区| 日韩不卡在线观看日韩不卡视频| 日韩亚洲欧美中文三级| 国产一区二区三区黄视频| 国产欧美日韩中文久久| 91啦中文在线观看| 午夜精品在线视频一区| 欧美电视剧免费观看| 国产精品综合一区二区三区| 国产精品电影一区二区| 欧美日韩一区 二区 三区 久久精品| 午夜国产精品一区| 久久久久久免费网| 91性感美女视频| 日本在线不卡视频| 欧美激情一区二区三区四区| 色屁屁一区二区| 麻豆91免费看| 《视频一区视频二区| 在线91免费看| 成人美女视频在线观看18| 亚洲啪啪综合av一区二区三区| 51精品秘密在线观看| 国产精品18久久久久久久久久久久| 日韩毛片一二三区| 日韩一区二区在线免费观看| 成人a级免费电影| 日本大胆欧美人术艺术动态| 国产欧美精品区一区二区三区| 色噜噜久久综合| 国产在线精品免费| 亚洲国产日韩在线一区模特| 久久蜜桃av一区精品变态类天堂| 色伊人久久综合中文字幕| 久久se这里有精品| 亚洲综合999| 国产女人aaa级久久久级| 欧美美女直播网站| 99热国产精品| 国产精品99久久久| 美女性感视频久久| 亚洲午夜免费视频| 国产精品不卡在线观看| ww久久中文字幕| 91精品啪在线观看国产60岁| 91麻豆蜜桃一区二区三区| 国产一区二区不卡| 蜜臀精品一区二区三区在线观看| 亚洲精品乱码久久久久久久久| 久久久久久久免费视频了| 欧美一区二区三区四区在线观看| 色天使久久综合网天天| 粉嫩13p一区二区三区| 国产一区二区三区在线观看免费视频| 婷婷夜色潮精品综合在线| 亚洲精品乱码久久久久久黑人 | 成人网页在线观看| 狠狠网亚洲精品| 国模娜娜一区二区三区| 伦理电影国产精品| 蜜桃传媒麻豆第一区在线观看| 一区二区三区中文免费| 自拍偷拍国产精品| 国产精品伦一区| 国产精品久久久99| 国产精品久99| 亚洲人成影院在线观看| 亚洲欧美综合网| ㊣最新国产の精品bt伙计久久| 中文字幕不卡一区| 亚洲视频小说图片| 亚洲精品视频自拍| 亚洲成人资源网| 午夜精品福利久久久| 日韩综合小视频| 日本欧美韩国一区三区| 久久99精品网久久| 国内久久精品视频| 福利电影一区二区三区| 99久久er热在这里只有精品15 | 亚洲欧美日韩国产另类专区 | 一本到高清视频免费精品| 99久久99久久精品免费观看| 色综合久久天天| 欧美三级韩国三级日本三斤| 欧美一级黄色录像| 精品久久久久久亚洲综合网| 26uuu国产日韩综合| 国产精品久久久久久久久图文区| 亚洲视频免费在线观看| 亚洲午夜视频在线| 精品一区二区成人精品| 成人久久视频在线观看| 日本韩国欧美在线| 日韩视频免费观看高清完整版| 精品国产123| 中文字幕一区二区三区在线不卡 | 欧美日韩专区在线| 欧美一二三在线| 欧美国产激情一区二区三区蜜月| 亚洲人快播电影网| 免费观看成人鲁鲁鲁鲁鲁视频| 国产美女久久久久| 在线免费亚洲电影| 日韩欧美国产一区在线观看| 亚洲欧美综合另类在线卡通| 午夜精品免费在线观看| 国产乱码精品一区二区三| 欧美私模裸体表演在线观看| 26uuuu精品一区二区| 亚洲一区二区五区| 国产精品一区二区男女羞羞无遮挡 | ...xxx性欧美| 精品中文字幕一区二区小辣椒| 99久久er热在这里只有精品66| 91精品国模一区二区三区| 国产精品传媒视频| 美美哒免费高清在线观看视频一区二区| 国产福利视频一区二区三区| 欧美久久久久久蜜桃| 国产精品国产自产拍在线| 奇米亚洲午夜久久精品| 色综合天天综合色综合av| 久久综合久久综合亚洲| 日韩成人精品在线观看| 欧美在线观看视频在线| 国产午夜久久久久| 麻豆精品国产传媒mv男同| 日本久久一区二区三区| 欧美国产精品中文字幕| 狠狠色2019综合网| 欧美一区二区三区视频| 亚洲一区二区视频在线观看| 99re视频精品| 中文字幕免费一区| 精品亚洲国产成人av制服丝袜| 欧美三级日韩三级| 亚洲一区二区三区中文字幕 | 亚洲精品第1页| av一二三不卡影片| 国产欧美一区二区三区在线老狼 | 日韩国产欧美视频| 欧洲一区二区三区在线| **欧美大码日韩| www.欧美亚洲| 中文字幕乱码久久午夜不卡| 国产凹凸在线观看一区二区| 26uuu色噜噜精品一区| 国产自产2019最新不卡| 欧美成人福利视频| 九色综合狠狠综合久久| 欧美成人综合网站| 久久99久久精品欧美| 精品理论电影在线| 国产精品自拍av| 国产目拍亚洲精品99久久精品| 精品无人区卡一卡二卡三乱码免费卡|