亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
精品国产1区二区| 国产精品电影一区二区| 精品国产免费人成在线观看| 一区在线中文字幕| 国产精品人人做人人爽人人添| 国产欧美日韩在线视频| 国产精品电影一区二区| 亚洲成av人片在线观看| 美腿丝袜亚洲三区| 国产精品12区| 91传媒视频在线播放| 88在线观看91蜜桃国自产| 精品精品国产高清a毛片牛牛| 在线播放欧美女士性生活| 久久综合色8888| 亚洲一区二区四区蜜桃| 精品一区二区三区在线观看| 色噜噜夜夜夜综合网| 日韩欧美高清在线| 亚洲色图视频网| 美国精品在线观看| 91视频.com| 国产亚洲欧美中文| 日韩激情一二三区| 色偷偷88欧美精品久久久| 欧美成人性战久久| 亚洲成av人综合在线观看| 91视频91自| 精品国产乱码久久久久久免费 | 久久69国产一区二区蜜臀| 在线视频亚洲一区| 精品动漫一区二区三区在线观看| 亚洲图片欧美色图| av日韩在线网站| 久久嫩草精品久久久精品| 日日夜夜一区二区| 欧美日韩在线播放一区| 亚洲视频一二三区| 不卡在线观看av| 国产蜜臀97一区二区三区| 国产欧美精品一区| 日韩福利视频导航| 欧美高清视频不卡网| 亚洲综合免费观看高清在线观看| av成人老司机| 一区二区三区视频在线看| 成人97人人超碰人人99| 中文字幕一区二区三中文字幕| 国产福利一区二区三区| 久久精品夜夜夜夜久久| 国产成人aaa| 中文字幕制服丝袜成人av| 成人av网站免费观看| 国产精品电影一区二区三区| 99久久综合国产精品| 亚洲一区在线看| 91精品国产91久久综合桃花 | 成人高清视频在线| 亚洲主播在线播放| 国产亚洲一二三区| 欧美久久久久久蜜桃| 韩国一区二区视频| 亚洲高清免费在线| 亚洲视频一区二区免费在线观看| 欧美一区二区三区免费| www.综合网.com| 开心九九激情九九欧美日韩精美视频电影 | 亚洲欧美另类图片小说| 欧美在线观看禁18| 成人av在线影院| 国产精品资源网| 久久国内精品自在自线400部| 亚洲免费成人av| 国产精品不卡在线| 国产日产精品一区| 欧美本精品男人aⅴ天堂| 精品视频色一区| 色久优优欧美色久优优| 成人18精品视频| 国产一区二区三区在线观看精品 | 欧美色中文字幕| 成人av免费在线| 成人黄色av电影| 久久不见久久见免费视频1| 日本伊人色综合网| 青青草视频一区| 激情av综合网| 国产馆精品极品| 国产成人精品免费看| 成人午夜av影视| 成人app软件下载大全免费| 97久久精品人人做人人爽50路 | 7777精品久久久大香线蕉| 欧美日韩在线播放三区四区| 8v天堂国产在线一区二区| 欧美一区二区三区免费| 欧美一区二区久久久| 91精品国产91久久综合桃花| 精品视频在线免费观看| 在线不卡中文字幕播放| 日韩欧美电影一二三| 国产欧美精品一区二区三区四区| 国产精品久久久久久亚洲伦| 亚洲欧美另类图片小说| 亚洲h动漫在线| 国产一区二区久久| www.欧美.com| 制服丝袜一区二区三区| 国产偷国产偷精品高清尤物| 综合久久给合久久狠狠狠97色| 一区二区三区在线不卡| 日本视频在线一区| 丁香婷婷深情五月亚洲| 666欧美在线视频| 亚洲美女视频在线| 美女视频黄a大片欧美| 99免费精品视频| 日韩欧美在线123| |精品福利一区二区三区| 日韩成人av影视| 一本久道中文字幕精品亚洲嫩| 日韩一区二区三区三四区视频在线观看 | 日韩激情一二三区| 成人午夜av在线| 日韩一区二区三区av| 亚洲婷婷在线视频| 国产成人三级在线观看| 欧洲视频一区二区| 中文字幕久久午夜不卡| 蜜桃视频在线观看一区二区| 在线观看一区日韩| 精品毛片乱码1区2区3区| 一区二区三区资源| www.性欧美| 欧美激情在线一区二区| 激情六月婷婷综合| 91精品国产欧美一区二区| 夜夜嗨av一区二区三区网页| 成人精品国产一区二区4080| 久久精品人人爽人人爽| 久久99精品一区二区三区三区| 7777精品伊人久久久大香线蕉经典版下载 | 国产视频一区二区在线| 久草精品在线观看| 日韩一级高清毛片| 亚洲国产精品久久久男人的天堂| 91蝌蚪国产九色| 亚洲国产人成综合网站| 欧美视频一区二区三区在线观看| 亚洲一区二区四区蜜桃| 91麻豆精品国产自产在线| 青娱乐精品在线视频| 久久先锋影音av| 成人白浆超碰人人人人| 亚洲欧洲精品一区二区三区| 色国产综合视频| 日韩国产精品久久| 久久综合五月天婷婷伊人| 国产成人免费在线观看| 国产精品灌醉下药二区| 欧美亚洲免费在线一区| 青青草原综合久久大伊人精品 | 91电影在线观看| 日韩av不卡一区二区| 久久久午夜精品| 在线一区二区观看| 久久99国产精品尤物| 亚洲欧美成人一区二区三区| 精品视频一区三区九区| 精品写真视频在线观看| 亚洲天堂精品视频| 日韩免费观看2025年上映的电影| 成人a免费在线看| 三级影片在线观看欧美日韩一区二区| 精品精品欲导航| 色呦呦国产精品| 国产精品亚洲午夜一区二区三区 | 精品粉嫩aⅴ一区二区三区四区| 成人av中文字幕| 久久国产尿小便嘘嘘尿| 一区二区三区在线高清| 国产色婷婷亚洲99精品小说| 91精品午夜视频| 欧美综合一区二区三区| 成人h动漫精品一区二区| 久久精品国产在热久久| 亚洲国产日韩在线一区模特| 国产精品天天摸av网| 久久精品一区二区三区不卡| 欧美一级生活片| 欧美一区在线视频| 欧美日韩1234| 成人免费在线观看入口| 国产丝袜在线精品| 2020国产精品自拍| 久久这里只精品最新地址| 久久久久九九视频| 国产无遮挡一区二区三区毛片日本| 日韩欧美一级在线播放| 精品久久一二三区|