⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 helper2.c

📁 qemu虚拟机代码
💻 C
📖 第 1 页 / 共 3 页
字号:
                    env->tr.limit,                    env->tr.flags);        cpu_fprintf(f, "GDT=     %016llx %08x\n",                    env->gdt.base, env->gdt.limit);        cpu_fprintf(f, "IDT=     %016llx %08x\n",                    env->idt.base, env->idt.limit);        cpu_fprintf(f, "CR0=%08x CR2=%016llx CR3=%016llx CR4=%08x\n",                    (uint32_t)env->cr[0],                     env->cr[2],                     env->cr[3],                     (uint32_t)env->cr[4]);    } else#endif    {        for(i = 0; i < 6; i++) {            SegmentCache *sc = &env->segs[i];            cpu_fprintf(f, "%s =%04x %08x %08x %08x\n",                        seg_name[i],                        sc->selector,                        (uint32_t)sc->base,                        sc->limit,                        sc->flags);        }        cpu_fprintf(f, "LDT=%04x %08x %08x %08x\n",                    env->ldt.selector,                    (uint32_t)env->ldt.base,                    env->ldt.limit,                    env->ldt.flags);        cpu_fprintf(f, "TR =%04x %08x %08x %08x\n",                    env->tr.selector,                    (uint32_t)env->tr.base,                    env->tr.limit,                    env->tr.flags);        cpu_fprintf(f, "GDT=     %08x %08x\n",                    (uint32_t)env->gdt.base, env->gdt.limit);        cpu_fprintf(f, "IDT=     %08x %08x\n",                    (uint32_t)env->idt.base, env->idt.limit);        cpu_fprintf(f, "CR0=%08x CR2=%08x CR3=%08x CR4=%08x\n",                    (uint32_t)env->cr[0],                     (uint32_t)env->cr[2],                     (uint32_t)env->cr[3],                     (uint32_t)env->cr[4]);    }    if (flags & X86_DUMP_CCOP) {        if ((unsigned)env->cc_op < CC_OP_NB)            snprintf(cc_op_name, sizeof(cc_op_name), "%s", cc_op_str[env->cc_op]);        else            snprintf(cc_op_name, sizeof(cc_op_name), "[%d]", env->cc_op);#ifdef TARGET_X86_64        if (env->hflags & HF_CS64_MASK) {            cpu_fprintf(f, "CCS=%016llx CCD=%016llx CCO=%-8s\n",                        env->cc_src, env->cc_dst,                         cc_op_name);        } else #endif        {            cpu_fprintf(f, "CCS=%08x CCD=%08x CCO=%-8s\n",                        (uint32_t)env->cc_src, (uint32_t)env->cc_dst,                         cc_op_name);        }    }    if (flags & X86_DUMP_FPU) {        int fptag;        fptag = 0;        for(i = 0; i < 8; i++) {            fptag |= ((!env->fptags[i]) << i);        }        cpu_fprintf(f, "FCW=%04x FSW=%04x [ST=%d] FTW=%02x MXCSR=%08x\n",                    env->fpuc,                    (env->fpus & ~0x3800) | (env->fpstt & 0x7) << 11,                    env->fpstt,                    fptag,                    env->mxcsr);        for(i=0;i<8;i++) {#if defined(USE_X86LDOUBLE)            union {                long double d;                struct {                    uint64_t lower;                    uint16_t upper;                } l;            } tmp;            tmp.d = env->fpregs[i].d;            cpu_fprintf(f, "FPR%d=%016llx %04x",                        i, tmp.l.lower, tmp.l.upper);#else            cpu_fprintf(f, "FPR%d=%016llx",                        i, env->fpregs[i].mmx.q);#endif            if ((i & 1) == 1)                cpu_fprintf(f, "\n");            else                cpu_fprintf(f, " ");        }        if (env->hflags & HF_CS64_MASK)             nb = 16;        else            nb = 8;        for(i=0;i<nb;i++) {            cpu_fprintf(f, "XMM%02d=%08x%08x%08x%08x",                        i,                         env->xmm_regs[i].XMM_L(3),                        env->xmm_regs[i].XMM_L(2),                        env->xmm_regs[i].XMM_L(1),                        env->xmm_regs[i].XMM_L(0));            if ((i & 1) == 1)                cpu_fprintf(f, "\n");            else                cpu_fprintf(f, " ");        }    }}/***********************************************************//* x86 mmu *//* XXX: add PGE support */void cpu_x86_set_a20(CPUX86State *env, int a20_state){    a20_state = (a20_state != 0);    if (a20_state != ((env->a20_mask >> 20) & 1)) {#if defined(DEBUG_MMU)        printf("A20 update: a20=%d\n", a20_state);#endif        /* if the cpu is currently executing code, we must unlink it and           all the potentially executing TB */        cpu_interrupt(env, CPU_INTERRUPT_EXITTB);        /* when a20 is changed, all the MMU mappings are invalid, so           we must flush everything */        tlb_flush(env, 1);        env->a20_mask = 0xffefffff | (a20_state << 20);    }}void cpu_x86_update_cr0(CPUX86State *env, uint32_t new_cr0){    int pe_state;#if defined(DEBUG_MMU)    printf("CR0 update: CR0=0x%08x\n", new_cr0);#endif    if ((new_cr0 & (CR0_PG_MASK | CR0_WP_MASK | CR0_PE_MASK)) !=        (env->cr[0] & (CR0_PG_MASK | CR0_WP_MASK | CR0_PE_MASK))) {        tlb_flush(env, 1);    }#ifdef TARGET_X86_64    if (!(env->cr[0] & CR0_PG_MASK) && (new_cr0 & CR0_PG_MASK) &&        (env->efer & MSR_EFER_LME)) {        /* enter in long mode */        /* XXX: generate an exception */        if (!(env->cr[4] & CR4_PAE_MASK))            return;        env->efer |= MSR_EFER_LMA;        env->hflags |= HF_LMA_MASK;    } else if ((env->cr[0] & CR0_PG_MASK) && !(new_cr0 & CR0_PG_MASK) &&               (env->efer & MSR_EFER_LMA)) {        /* exit long mode */        env->efer &= ~MSR_EFER_LMA;        env->hflags &= ~(HF_LMA_MASK | HF_CS64_MASK);        env->eip &= 0xffffffff;    }#endif    env->cr[0] = new_cr0 | CR0_ET_MASK;        /* update PE flag in hidden flags */    pe_state = (env->cr[0] & CR0_PE_MASK);    env->hflags = (env->hflags & ~HF_PE_MASK) | (pe_state << HF_PE_SHIFT);    /* ensure that ADDSEG is always set in real mode */    env->hflags |= ((pe_state ^ 1) << HF_ADDSEG_SHIFT);    /* update FPU flags */    env->hflags = (env->hflags & ~(HF_MP_MASK | HF_EM_MASK | HF_TS_MASK)) |        ((new_cr0 << (HF_MP_SHIFT - 1)) & (HF_MP_MASK | HF_EM_MASK | HF_TS_MASK));}/* XXX: in legacy PAE mode, generate a GPF if reserved bits are set in   the PDPT */void cpu_x86_update_cr3(CPUX86State *env, target_ulong new_cr3){    env->cr[3] = new_cr3;    if (env->cr[0] & CR0_PG_MASK) {#if defined(DEBUG_MMU)        printf("CR3 update: CR3=" TARGET_FMT_lx "\n", new_cr3);#endif        tlb_flush(env, 0);    }}void cpu_x86_update_cr4(CPUX86State *env, uint32_t new_cr4){#if defined(DEBUG_MMU)    printf("CR4 update: CR4=%08x\n", (uint32_t)env->cr[4]);#endif    if ((new_cr4 & (CR4_PGE_MASK | CR4_PAE_MASK | CR4_PSE_MASK)) !=        (env->cr[4] & (CR4_PGE_MASK | CR4_PAE_MASK | CR4_PSE_MASK))) {        tlb_flush(env, 1);    }    /* SSE handling */    if (!(env->cpuid_features & CPUID_SSE))        new_cr4 &= ~CR4_OSFXSR_MASK;    if (new_cr4 & CR4_OSFXSR_MASK)        env->hflags |= HF_OSFXSR_MASK;    else        env->hflags &= ~HF_OSFXSR_MASK;    env->cr[4] = new_cr4;}/* XXX: also flush 4MB pages */void cpu_x86_flush_tlb(CPUX86State *env, target_ulong addr){    tlb_flush_page(env, addr);}#if defined(CONFIG_USER_ONLY) int cpu_x86_handle_mmu_fault(CPUX86State *env, target_ulong addr,                              int is_write, int is_user, int is_softmmu){    /* user mode only emulation */    is_write &= 1;    env->cr[2] = addr;    env->error_code = (is_write << PG_ERROR_W_BIT);    env->error_code |= PG_ERROR_U_MASK;    env->exception_index = EXCP0E_PAGE;    return 1;}target_ulong cpu_get_phys_page_debug(CPUState *env, target_ulong addr){    return addr;}#else#define PHYS_ADDR_MASK 0xfffff000/* return value:   -1 = cannot handle fault    0  = nothing more to do    1  = generate PF fault   2  = soft MMU activation required for this block*/int cpu_x86_handle_mmu_fault(CPUX86State *env, target_ulong addr,                              int is_write1, int is_user, int is_softmmu){    uint64_t ptep, pte;    uint32_t pdpe_addr, pde_addr, pte_addr;    int error_code, is_dirty, prot, page_size, ret, is_write;    unsigned long paddr, page_offset;    target_ulong vaddr, virt_addr;    #if defined(DEBUG_MMU)    printf("MMU fault: addr=" TARGET_FMT_lx " w=%d u=%d eip=" TARGET_FMT_lx "\n",            addr, is_write1, is_user, env->eip);#endif    is_write = is_write1 & 1;        if (!(env->cr[0] & CR0_PG_MASK)) {        pte = addr;        virt_addr = addr & TARGET_PAGE_MASK;        prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC;        page_size = 4096;        goto do_mapping;    }    if (env->cr[4] & CR4_PAE_MASK) {        uint64_t pde, pdpe;        /* XXX: we only use 32 bit physical addresses */#ifdef TARGET_X86_64        if (env->hflags & HF_LMA_MASK) {            uint32_t pml4e_addr;            uint64_t pml4e;            int32_t sext;            /* test virtual address sign extension */            sext = (int64_t)addr >> 47;            if (sext != 0 && sext != -1) {                env->error_code = 0;                env->exception_index = EXCP0D_GPF;                return 1;            }                        pml4e_addr = ((env->cr[3] & ~0xfff) + (((addr >> 39) & 0x1ff) << 3)) &                 env->a20_mask;            pml4e = ldq_phys(pml4e_addr);            if (!(pml4e & PG_PRESENT_MASK)) {                error_code = 0;                goto do_fault;            }            if (!(env->efer & MSR_EFER_NXE) && (pml4e & PG_NX_MASK)) {                error_code = PG_ERROR_RSVD_MASK;                goto do_fault;            }            if (!(pml4e & PG_ACCESSED_MASK)) {                pml4e |= PG_ACCESSED_MASK;                stl_phys_notdirty(pml4e_addr, pml4e);            }            ptep = pml4e ^ PG_NX_MASK;            pdpe_addr = ((pml4e & PHYS_ADDR_MASK) + (((addr >> 30) & 0x1ff) << 3)) &                 env->a20_mask;            pdpe = ldq_phys(pdpe_addr);            if (!(pdpe & PG_PRESENT_MASK)) {                error_code = 0;                goto do_fault;            }            if (!(env->efer & MSR_EFER_NXE) && (pdpe & PG_NX_MASK)) {                error_code = PG_ERROR_RSVD_MASK;                goto do_fault;            }            ptep &= pdpe ^ PG_NX_MASK;            if (!(pdpe & PG_ACCESSED_MASK)) {                pdpe |= PG_ACCESSED_MASK;                stl_phys_notdirty(pdpe_addr, pdpe);            }        } else#endif        {            /* XXX: load them when cr3 is loaded ? */            pdpe_addr = ((env->cr[3] & ~0x1f) + ((addr >> 30) << 3)) &                 env->a20_mask;            pdpe = ldq_phys(pdpe_addr);            if (!(pdpe & PG_PRESENT_MASK)) {                error_code = 0;                goto do_fault;            }            ptep = PG_NX_MASK | PG_USER_MASK | PG_RW_MASK;        }        pde_addr = ((pdpe & PHYS_ADDR_MASK) + (((addr >> 21) & 0x1ff) << 3)) &            env->a20_mask;        pde = ldq_phys(pde_addr);        if (!(pde & PG_PRESENT_MASK)) {            error_code = 0;            goto do_fault;        }        if (!(env->efer & MSR_EFER_NXE) && (pde & PG_NX_MASK)) {            error_code = PG_ERROR_RSVD_MASK;            goto do_fault;        }        ptep &= pde ^ PG_NX_MASK;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -