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

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

?? exec.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* *  virtual page mapping and translated block handling * *  Copyright (c) 2003 Fabrice Bellard * * 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 */#include "config.h"#ifdef _WIN32#define WIN32_LEAN_AND_MEAN#include <windows.h>#else#include <sys/types.h>#include <sys/mman.h>#endif#include <stdlib.h>#include <stdio.h>#include <stdarg.h>#include <string.h>#include <errno.h>#include <unistd.h>#include <inttypes.h>#include "cpu.h"#include "exec-all.h"#if defined(CONFIG_USER_ONLY)#include <qemu.h>#endif//#define DEBUG_TB_INVALIDATE//#define DEBUG_FLUSH//#define DEBUG_TLB//#define DEBUG_UNASSIGNED/* make various TB consistency checks *///#define DEBUG_TB_CHECK//#define DEBUG_TLB_CHECK//#define DEBUG_IOPORT//#define DEBUG_SUBPAGE#if !defined(CONFIG_USER_ONLY)/* TB consistency checks only implemented for usermode emulation.  */#undef DEBUG_TB_CHECK#endif/* threshold to flush the translated code buffer */#define CODE_GEN_BUFFER_MAX_SIZE (CODE_GEN_BUFFER_SIZE - code_gen_max_block_size())#define SMC_BITMAP_USE_THRESHOLD 10#define MMAP_AREA_START        0x00000000#define MMAP_AREA_END          0xa8000000#if defined(TARGET_SPARC64)#define TARGET_PHYS_ADDR_SPACE_BITS 41#elif defined(TARGET_SPARC)#define TARGET_PHYS_ADDR_SPACE_BITS 36#elif defined(TARGET_ALPHA)#define TARGET_PHYS_ADDR_SPACE_BITS 42#define TARGET_VIRT_ADDR_SPACE_BITS 42#elif defined(TARGET_PPC64)#define TARGET_PHYS_ADDR_SPACE_BITS 42#else/* Note: for compatibility with kqemu, we use 32 bits for x86_64 */#define TARGET_PHYS_ADDR_SPACE_BITS 32#endifTranslationBlock tbs[CODE_GEN_MAX_BLOCKS];TranslationBlock *tb_phys_hash[CODE_GEN_PHYS_HASH_SIZE];int nb_tbs;/* any access to the tbs or the page table must use this lock */spinlock_t tb_lock = SPIN_LOCK_UNLOCKED;uint8_t code_gen_buffer[CODE_GEN_BUFFER_SIZE] __attribute__((aligned (32)));uint8_t *code_gen_ptr;int phys_ram_size;int phys_ram_fd;uint8_t *phys_ram_base;uint8_t *phys_ram_dirty;static ram_addr_t phys_ram_alloc_offset = 0;CPUState *first_cpu;/* current CPU in the current thread. It is only valid inside   cpu_exec() */CPUState *cpu_single_env;typedef struct PageDesc {    /* list of TBs intersecting this ram page */    TranslationBlock *first_tb;    /* in order to optimize self modifying code, we count the number       of lookups we do to a given page to use a bitmap */    unsigned int code_write_count;    uint8_t *code_bitmap;#if defined(CONFIG_USER_ONLY)    unsigned long flags;#endif} PageDesc;typedef struct PhysPageDesc {    /* offset in host memory of the page + io_index in the low 12 bits */    uint32_t phys_offset;} PhysPageDesc;#define L2_BITS 10#if defined(CONFIG_USER_ONLY) && defined(TARGET_VIRT_ADDR_SPACE_BITS)/* XXX: this is a temporary hack for alpha target. *      In the future, this is to be replaced by a multi-level table *      to actually be able to handle the complete 64 bits address space. */#define L1_BITS (TARGET_VIRT_ADDR_SPACE_BITS - L2_BITS - TARGET_PAGE_BITS)#else#define L1_BITS (32 - L2_BITS - TARGET_PAGE_BITS)#endif#define L1_SIZE (1 << L1_BITS)#define L2_SIZE (1 << L2_BITS)static void io_mem_init(void);unsigned long qemu_real_host_page_size;unsigned long qemu_host_page_bits;unsigned long qemu_host_page_size;unsigned long qemu_host_page_mask;/* XXX: for system emulation, it could just be an array */static PageDesc *l1_map[L1_SIZE];PhysPageDesc **l1_phys_map;/* io memory support */CPUWriteMemoryFunc *io_mem_write[IO_MEM_NB_ENTRIES][4];CPUReadMemoryFunc *io_mem_read[IO_MEM_NB_ENTRIES][4];void *io_mem_opaque[IO_MEM_NB_ENTRIES];static int io_mem_nb;#if defined(CONFIG_SOFTMMU)static int io_mem_watch;#endif/* log support */char *logfilename = "/tmp/qemu.log";FILE *logfile;int loglevel;static int log_append = 0;/* statistics */static int tlb_flush_count;static int tb_flush_count;static int tb_phys_invalidate_count;#define SUBPAGE_IDX(addr) ((addr) & ~TARGET_PAGE_MASK)typedef struct subpage_t {    target_phys_addr_t base;    CPUReadMemoryFunc **mem_read[TARGET_PAGE_SIZE][4];    CPUWriteMemoryFunc **mem_write[TARGET_PAGE_SIZE][4];    void *opaque[TARGET_PAGE_SIZE][2][4];} subpage_t;static void page_init(void){    /* NOTE: we can always suppose that qemu_host_page_size >=       TARGET_PAGE_SIZE */#ifdef _WIN32    {        SYSTEM_INFO system_info;        DWORD old_protect;        GetSystemInfo(&system_info);        qemu_real_host_page_size = system_info.dwPageSize;        VirtualProtect(code_gen_buffer, sizeof(code_gen_buffer),                       PAGE_EXECUTE_READWRITE, &old_protect);    }#else    qemu_real_host_page_size = getpagesize();    {        unsigned long start, end;        start = (unsigned long)code_gen_buffer;        start &= ~(qemu_real_host_page_size - 1);        end = (unsigned long)code_gen_buffer + sizeof(code_gen_buffer);        end += qemu_real_host_page_size - 1;        end &= ~(qemu_real_host_page_size - 1);        mprotect((void *)start, end - start,                 PROT_READ | PROT_WRITE | PROT_EXEC);    }#endif    if (qemu_host_page_size == 0)        qemu_host_page_size = qemu_real_host_page_size;    if (qemu_host_page_size < TARGET_PAGE_SIZE)        qemu_host_page_size = TARGET_PAGE_SIZE;    qemu_host_page_bits = 0;    while ((1 << qemu_host_page_bits) < qemu_host_page_size)        qemu_host_page_bits++;    qemu_host_page_mask = ~(qemu_host_page_size - 1);    l1_phys_map = qemu_vmalloc(L1_SIZE * sizeof(void *));    memset(l1_phys_map, 0, L1_SIZE * sizeof(void *));#if !defined(_WIN32) && defined(CONFIG_USER_ONLY)    {        long long startaddr, endaddr;        FILE *f;        int n;        f = fopen("/proc/self/maps", "r");        if (f) {            do {                n = fscanf (f, "%llx-%llx %*[^\n]\n", &startaddr, &endaddr);                if (n == 2) {                    page_set_flags(TARGET_PAGE_ALIGN(startaddr),                                   TARGET_PAGE_ALIGN(endaddr),                                   PAGE_RESERVED);                 }            } while (!feof(f));            fclose(f);        }    }#endif}static inline PageDesc *page_find_alloc(unsigned int index){    PageDesc **lp, *p;    lp = &l1_map[index >> L2_BITS];    p = *lp;    if (!p) {        /* allocate if not found */        p = qemu_malloc(sizeof(PageDesc) * L2_SIZE);        memset(p, 0, sizeof(PageDesc) * L2_SIZE);        *lp = p;    }    return p + (index & (L2_SIZE - 1));}static inline PageDesc *page_find(unsigned int index){    PageDesc *p;    p = l1_map[index >> L2_BITS];    if (!p)        return 0;    return p + (index & (L2_SIZE - 1));}static PhysPageDesc *phys_page_find_alloc(target_phys_addr_t index, int alloc){    void **lp, **p;    PhysPageDesc *pd;    p = (void **)l1_phys_map;#if TARGET_PHYS_ADDR_SPACE_BITS > 32#if TARGET_PHYS_ADDR_SPACE_BITS > (32 + L1_BITS)#error unsupported TARGET_PHYS_ADDR_SPACE_BITS#endif    lp = p + ((index >> (L1_BITS + L2_BITS)) & (L1_SIZE - 1));    p = *lp;    if (!p) {        /* allocate if not found */        if (!alloc)            return NULL;        p = qemu_vmalloc(sizeof(void *) * L1_SIZE);        memset(p, 0, sizeof(void *) * L1_SIZE);        *lp = p;    }#endif    lp = p + ((index >> L2_BITS) & (L1_SIZE - 1));    pd = *lp;    if (!pd) {        int i;        /* allocate if not found */        if (!alloc)            return NULL;        pd = qemu_vmalloc(sizeof(PhysPageDesc) * L2_SIZE);        *lp = pd;        for (i = 0; i < L2_SIZE; i++)          pd[i].phys_offset = IO_MEM_UNASSIGNED;    }    return ((PhysPageDesc *)pd) + (index & (L2_SIZE - 1));}static inline PhysPageDesc *phys_page_find(target_phys_addr_t index){    return phys_page_find_alloc(index, 0);}#if !defined(CONFIG_USER_ONLY)static void tlb_protect_code(ram_addr_t ram_addr);static void tlb_unprotect_code_phys(CPUState *env, ram_addr_t ram_addr,                                    target_ulong vaddr);#endifvoid cpu_exec_init(CPUState *env){    CPUState **penv;    int cpu_index;    if (!code_gen_ptr) {        code_gen_ptr = code_gen_buffer;        page_init();        io_mem_init();    }    env->next_cpu = NULL;    penv = &first_cpu;    cpu_index = 0;    while (*penv != NULL) {        penv = (CPUState **)&(*penv)->next_cpu;        cpu_index++;    }    env->cpu_index = cpu_index;    env->nb_watchpoints = 0;    *penv = env;}static inline void invalidate_page_bitmap(PageDesc *p){    if (p->code_bitmap) {        qemu_free(p->code_bitmap);        p->code_bitmap = NULL;    }    p->code_write_count = 0;}/* set to NULL all the 'first_tb' fields in all PageDescs */static void page_flush_tb(void){    int i, j;    PageDesc *p;    for(i = 0; i < L1_SIZE; i++) {        p = l1_map[i];        if (p) {            for(j = 0; j < L2_SIZE; j++) {                p->first_tb = NULL;                invalidate_page_bitmap(p);                p++;            }        }    }}/* flush all the translation blocks *//* XXX: tb_flush is currently not thread safe */void tb_flush(CPUState *env1){    CPUState *env;#if defined(DEBUG_FLUSH)    printf("qemu: flush code_size=%ld nb_tbs=%d avg_tb_size=%ld\n",           (unsigned long)(code_gen_ptr - code_gen_buffer),           nb_tbs, nb_tbs > 0 ?           ((unsigned long)(code_gen_ptr - code_gen_buffer)) / nb_tbs : 0);#endif    nb_tbs = 0;    for(env = first_cpu; env != NULL; env = env->next_cpu) {        memset (env->tb_jmp_cache, 0, TB_JMP_CACHE_SIZE * sizeof (void *));    }    memset (tb_phys_hash, 0, CODE_GEN_PHYS_HASH_SIZE * sizeof (void *));    page_flush_tb();    code_gen_ptr = code_gen_buffer;    /* XXX: flush processor icache at this point if cache flush is       expensive */    tb_flush_count++;}#ifdef DEBUG_TB_CHECKstatic void tb_invalidate_check(target_ulong address){    TranslationBlock *tb;    int i;    address &= TARGET_PAGE_MASK;    for(i = 0;i < CODE_GEN_PHYS_HASH_SIZE; i++) {        for(tb = tb_phys_hash[i]; tb != NULL; tb = tb->phys_hash_next) {            if (!(address + TARGET_PAGE_SIZE <= tb->pc ||                  address >= tb->pc + tb->size)) {                printf("ERROR invalidate: address=%08lx PC=%08lx size=%04x\n",                       address, (long)tb->pc, tb->size);            }        }    }}/* verify that all the pages have correct rights for code */static void tb_page_check(void){    TranslationBlock *tb;    int i, flags1, flags2;    for(i = 0;i < CODE_GEN_PHYS_HASH_SIZE; i++) {        for(tb = tb_phys_hash[i]; tb != NULL; tb = tb->phys_hash_next) {            flags1 = page_get_flags(tb->pc);            flags2 = page_get_flags(tb->pc + tb->size - 1);            if ((flags1 & PAGE_WRITE) || (flags2 & PAGE_WRITE)) {                printf("ERROR page flags: PC=%08lx size=%04x f1=%x f2=%x\n",                       (long)tb->pc, tb->size, flags1, flags2);            }        }    }}void tb_jmp_check(TranslationBlock *tb){    TranslationBlock *tb1;    unsigned int n1;    /* suppress any remaining jumps to this TB */    tb1 = tb->jmp_first;    for(;;) {        n1 = (long)tb1 & 3;        tb1 = (TranslationBlock *)((long)tb1 & ~3);        if (n1 == 2)            break;        tb1 = tb1->jmp_next[n1];

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃视频一区二区三区| 国产不卡一区视频| 亚洲精品菠萝久久久久久久| 中文在线一区二区| 欧美激情一区三区| 中文字幕精品一区二区三区精品| 26uuu亚洲| wwww国产精品欧美| 久久中文字幕电影| 国产亲近乱来精品视频| 亚洲国产精品传媒在线观看| 国产精品女上位| 综合亚洲深深色噜噜狠狠网站| 国产精品久久久久久久久免费相片 | 国产日韩精品视频一区| 欧美精品一区二区三区四区| 精品盗摄一区二区三区| 久久夜色精品一区| 日本一区二区三区四区在线视频| 国产日韩欧美亚洲| 国产精品美女一区二区三区| 亚洲精品老司机| 亚洲成a人v欧美综合天堂| 日韩经典中文字幕一区| 麻豆91免费看| 国产精品一品视频| 99天天综合性| 欧美亚洲综合网| 日韩欧美国产小视频| 久久久久久久电影| 亚洲视频一二区| 午夜亚洲国产au精品一区二区| 日本午夜精品一区二区三区电影| 麻豆精品新av中文字幕| 国产精品123| 一本到高清视频免费精品| 欧美日本乱大交xxxxx| 精品国产乱码久久久久久闺蜜| 国产日韩av一区| 一区二区三区在线观看欧美| 日本最新不卡在线| 成人黄色软件下载| 欧美高清视频一二三区 | 国产成人在线电影| 欧美探花视频资源| 久久亚洲免费视频| 亚洲精品国产无天堂网2021| 日韩国产精品大片| 成人性色生活片| 欧美日韩国产精选| 欧美国产97人人爽人人喊| 亚洲一区二区3| 国产乱码一区二区三区| 91成人在线精品| 日韩一区二区电影| 亚洲色欲色欲www在线观看| 免费的国产精品| 99国产一区二区三精品乱码| 欧美电影免费观看高清完整版| 亚洲欧美日韩久久精品| 韩国精品在线观看| 欧美日韩中文一区| 中文字幕欧美激情| 蜜桃av一区二区在线观看| 99久久伊人网影院| 精品欧美久久久| 亚洲国产日韩一级| 成人免费视频视频在线观看免费| 7777精品伊人久久久大香线蕉超级流畅| 国产亚洲欧洲一区高清在线观看| 香港成人在线视频| 91在线一区二区三区| 精品国产百合女同互慰| 亚洲bt欧美bt精品777| av电影在线观看一区| 欧美成人vps| 午夜精品福利一区二区三区av| 国产成人av一区二区三区在线| 91麻豆精品国产91久久久更新时间| 国产精品久久午夜| 国产精品香蕉一区二区三区| 在线播放/欧美激情| 伊人夜夜躁av伊人久久| k8久久久一区二区三区| 久久久久久久久久看片| 美腿丝袜在线亚洲一区 | 综合自拍亚洲综合图不卡区| 极品少妇xxxx偷拍精品少妇| 欧美日韩国产免费一区二区| 一区二区三区美女| 色综合天天综合网国产成人综合天| 久久精品欧美一区二区三区不卡| 久久国产精品免费| 91精品福利在线一区二区三区 | 91在线视频在线| 国产欧美一区二区三区网站| 韩国三级在线一区| 精品国产伦理网| 极品少妇xxxx偷拍精品少妇| 日韩免费视频一区二区| 午夜精品在线视频一区| 欧美午夜精品久久久久久孕妇| 亚洲精品欧美专区| 91免费在线播放| 综合色中文字幕| av激情亚洲男人天堂| 《视频一区视频二区| 成人av资源站| 中文字幕一区二区三区在线播放 | 亚洲大尺度视频在线观看| 欧美在线看片a免费观看| 亚洲男人的天堂av| 日本韩国视频一区二区| 亚洲女人的天堂| 日本道免费精品一区二区三区| 亚洲欧美日韩久久| 日本韩国精品在线| 亚洲高清中文字幕| 3d成人动漫网站| 久久er99热精品一区二区| 精品久久人人做人人爰| 精品一区二区三区在线观看| 欧美精品一区二区精品网| 国产一区二区免费视频| 中文字幕第一页久久| 色综合中文综合网| 国产在线精品一区二区不卡了| 国产婷婷色一区二区三区四区| 成人av电影观看| 亚洲精品乱码久久久久久| 欧美日韩精品福利| 久久国内精品自在自线400部| 久久久久久久久久久电影| aaa欧美色吧激情视频| 亚洲精品一卡二卡| 欧美一区二区不卡视频| 国产九色sp调教91| 亚洲女性喷水在线观看一区| 777午夜精品免费视频| 国产精品一级片| 亚洲精品写真福利| 欧美一级高清片| 成人一区在线观看| 亚洲一区二区欧美日韩| 精品嫩草影院久久| 91在线视频播放地址| 天天综合色天天综合| 久久夜色精品国产欧美乱极品| 91天堂素人约啪| 日本女人一区二区三区| 中文字幕不卡三区| 欧美男同性恋视频网站| 国产一区中文字幕| 一区二区不卡在线播放 | 亚洲欧美激情插| 精品国免费一区二区三区| 99视频有精品| 蜜臀久久99精品久久久久久9| 成人免费在线观看入口| 日韩一区二区影院| 色综合天天综合网国产成人综合天| 老色鬼精品视频在线观看播放| 国产精品热久久久久夜色精品三区 | aaa欧美色吧激情视频| 日韩成人免费电影| 综合久久久久综合| 精品91自产拍在线观看一区| 在线观看视频一区二区欧美日韩| 国产在线精品一区二区不卡了| 亚洲国产欧美日韩另类综合| 久久九九久久九九| 日韩视频在线一区二区| 91毛片在线观看| 国产成人免费在线观看不卡| 午夜激情一区二区三区| |精品福利一区二区三区| 亚洲精品一区二区三区四区高清 | 久久久久九九视频| 欧美精品一二三四| 91无套直看片红桃| 国产999精品久久| 老汉av免费一区二区三区| 亚洲福利一区二区三区| 国产精品久久久久久久久晋中| 精品三级在线观看| 在线播放中文字幕一区| 一本色道综合亚洲| 成人丝袜高跟foot| 国产激情精品久久久第一区二区| 狂野欧美性猛交blacked| 香蕉av福利精品导航| 亚洲精品久久嫩草网站秘色| 国产精品久久久一区麻豆最新章节| 精品国产成人系列| 精品三级在线观看| 精品国产一区二区三区忘忧草 | 欧美日韩中文字幕一区| 91久久一区二区| 91视频在线观看| 成人18精品视频|