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

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

?? alpha_palcode.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 2 頁
字號:
        break;    case 0x000000AA:        /* GENTRAP */        /* REQUIRED */        break;    case 0x000000AE:        /* CLRFEN */        break;    default:        break;    }}static void pal_unix_call (CPUState *env, uint32_t palcode){    uint64_t palid, val, oldval;    if (palcode < 0x00000080) {        /* Privileged palcodes */        if (!(env->ps >> 3)) {            /* TODO: generate privilege exception */        }    }    switch (palcode) {    case 0x00000000:        /* HALT */        /* REQUIRED */        break;    case 0x00000001:        /* CFLUSH */        break;    case 0x00000002:        /* DRAINA */        /* REQUIRED */        /* Implemented as no-op */        break;    case 0x00000009:        /* CSERVE */        /* REQUIRED */        break;    case 0x0000000A:        /* SWPPAL */        /* REQUIRED */        palid = env->ir[16];        do_swappal(env, palid);        break;    case 0x0000000D:        /* WRIPIR */        val = env->ir[16];        if (cpu_alpha_mtpr(env, IPR_IPIR, val, &oldval) == 1)            env->ir[0] = val;        break;    case 0x00000010:        /* RDMCES */        if (cpu_alpha_mfpr(env, IPR_MCES, &val) == 0)            env->ir[0] = val;        break;    case 0x00000011:        /* WRMCES */        val = env->ir[16];        if (cpu_alpha_mtpr(env, IPR_MCES, val, &oldval) == 1)            env->ir[0] = val;        break;    case 0x0000002B:        /* WRFEN */        val = env->ir[16];        if (cpu_alpha_mtpr(env, IPR_PERFMON, val, &oldval) == 1)            env->ir[0] = val;        break;    case 0x0000002D:        /* WRVPTPTR */        break;    case 0x00000030:        /* SWPCTX */        break;    case 0x00000031:        /* WRVAL */        break;    case 0x00000032:        /* RDVAL */        break;    case 0x00000033:        /* TBI */        val = env->ir[16];        if (cpu_alpha_mtpr(env, IPR_TBIS, val, &oldval) == 1)            env->ir[0] = val;        break;    case 0x00000034:        /* WRENT */        break;    case 0x00000035:        /* SWPIPL */        break;    case 0x00000036:        /* RDPS */        break;    case 0x00000037:        /* WRKGP */        break;    case 0x00000038:        /* WRUSP */        val = env->ir[16];        if (cpu_alpha_mtpr(env, IPR_USP, val, &oldval) == 1)            env->ir[0] = val;        break;    case 0x00000039:        /* WRPERFMON */        val = env->ir[16];        if (cpu_alpha_mtpr(env, IPR_PERFMON, val, &oldval) == 1)            env->ir[0] = val;        break;    case 0x0000003A:        /* RDUSP */        if (cpu_alpha_mfpr(env, IPR_USP, &val) == 0)            env->ir[0] = val;        break;    case 0x0000003C:        /* WHAMI */        if (cpu_alpha_mfpr(env, IPR_WHAMI, &val) == 0)            env->ir[0] = val;        break;    case 0x0000003D:        /* RETSYS */        break;    case 0x0000003E:        /* WTINT */        break;    case 0x0000003F:        /* RTI */        if (cpu_alpha_mfpr(env, IPR_WHAMI, &val) == 0)            env->ir[0] = val;        break;    case 0x00000080:        /* BPT */        /* REQUIRED */        break;    case 0x00000081:        /* BUGCHK */        /* REQUIRED */        break;    case 0x00000083:        /* CALLSYS */        break;    case 0x00000086:        /* IMB */        /* REQUIRED */        /* Implemented as no-op */        break;    case 0x00000092:        /* URTI */        break;    case 0x0000009E:        /* RDUNIQUE */        /* REQUIRED */        break;    case 0x0000009F:        /* WRUNIQUE */        /* REQUIRED */        break;    case 0x000000AA:        /* GENTRAP */        /* REQUIRED */        break;    case 0x000000AE:        /* CLRFEN */        break;    default:        break;    }}void call_pal (CPUState *env){    pal_handler_t *pal_handler = env->pal_handler;    switch (env->exception_index) {    case EXCP_RESET:        (*pal_handler->reset)(env);        break;    case EXCP_MCHK:        (*pal_handler->machine_check)(env);        break;    case EXCP_ARITH:        (*pal_handler->arithmetic)(env);        break;    case EXCP_INTERRUPT:        (*pal_handler->interrupt)(env);        break;    case EXCP_DFAULT:        (*pal_handler->dfault)(env);        break;    case EXCP_DTB_MISS_PAL:        (*pal_handler->dtb_miss_pal)(env);        break;    case EXCP_DTB_MISS_NATIVE:        (*pal_handler->dtb_miss_native)(env);        break;    case EXCP_UNALIGN:        (*pal_handler->unalign)(env);        break;    case EXCP_ITB_MISS:        (*pal_handler->itb_miss)(env);        break;    case EXCP_ITB_ACV:        (*pal_handler->itb_acv)(env);        break;    case EXCP_OPCDEC:        (*pal_handler->opcdec)(env);        break;    case EXCP_FEN:        (*pal_handler->fen)(env);        break;    default:        if (env->exception_index >= EXCP_CALL_PAL &&            env->exception_index < EXCP_CALL_PALP) {            /* Unprivileged PAL call */            (*pal_handler->call_pal)                (env, (env->exception_index - EXCP_CALL_PAL) >> 6);        } else if (env->exception_index >= EXCP_CALL_PALP &&                   env->exception_index < EXCP_CALL_PALE) {            /* Privileged PAL call */            (*pal_handler->call_pal)                (env, ((env->exception_index - EXCP_CALL_PALP) >> 6) + 0x80);        } else {            /* Should never happen */        }        break;    }    env->ipr[IPR_EXC_ADDR] &= ~1;}void pal_init (CPUState *env){    do_swappal(env, 0);}#if 0static uint64_t get_ptebase (CPUState *env, uint64_t vaddr){    uint64_t virbnd, ptbr;    if ((env->features & FEATURE_VIRBND)) {        cpu_alpha_mfpr(env, IPR_VIRBND, &virbnd);        if (vaddr >= virbnd)            cpu_alpha_mfpr(env, IPR_SYSPTBR, &ptbr);        else            cpu_alpha_mfpr(env, IPR_PTBR, &ptbr);    } else {        cpu_alpha_mfpr(env, IPR_PTBR, &ptbr);    }    return ptbr;}static int get_page_bits (CPUState *env){    /* XXX */    return 13;}static int get_pte (uint64_t *pfnp, int *zbitsp, int *protp,                    uint64_t ptebase, int page_bits, uint64_t level,                    int mmu_idx, int rw){    uint64_t pteaddr, pte, pfn;    uint8_t gh;    int ure, uwe, kre, kwe, foE, foR, foW, v, ret, ar, is_user;    /* XXX: TOFIX */    is_user = mmu_idx == MMU_USER_IDX;    pteaddr = (ptebase << page_bits) + (8 * level);    pte = ldq_raw(pteaddr);    /* Decode all interresting PTE fields */    pfn = pte >> 32;    uwe = (pte >> 13) & 1;    kwe = (pte >> 12) & 1;    ure = (pte >> 9) & 1;    kre = (pte >> 8) & 1;    gh = (pte >> 5) & 3;    foE = (pte >> 3) & 1;    foW = (pte >> 2) & 1;    foR = (pte >> 1) & 1;    v = pte & 1;    ret = 0;    if (!v)        ret = 0x1;    /* Check access rights */    ar = 0;    if (is_user) {        if (ure)            ar |= PAGE_READ;        if (uwe)            ar |= PAGE_WRITE;        if (rw == 1 && !uwe)            ret |= 0x2;        if (rw != 1 && !ure)            ret |= 0x2;    } else {        if (kre)            ar |= PAGE_READ;        if (kwe)            ar |= PAGE_WRITE;        if (rw == 1 && !kwe)            ret |= 0x2;        if (rw != 1 && !kre)            ret |= 0x2;    }    if (rw == 0 && foR)        ret |= 0x4;    if (rw == 2 && foE)        ret |= 0x8;    if (rw == 1 && foW)        ret |= 0xC;    *pfnp = pfn;    if (zbitsp != NULL)        *zbitsp = page_bits + (3 * gh);    if (protp != NULL)        *protp = ar;    return ret;}static int paddr_from_pte (uint64_t *paddr, int *zbitsp, int *prot,                           uint64_t ptebase, int page_bits,                           uint64_t vaddr, int mmu_idx, int rw){    uint64_t pfn, page_mask, lvl_mask, level1, level2, level3;    int lvl_bits, ret;    page_mask = (1ULL << page_bits) - 1ULL;    lvl_bits = page_bits - 3;    lvl_mask = (1ULL << lvl_bits) - 1ULL;    level3 = (vaddr >> page_bits) & lvl_mask;    level2 = (vaddr >> (page_bits + lvl_bits)) & lvl_mask;    level1 = (vaddr >> (page_bits + (2 * lvl_bits))) & lvl_mask;    /* Level 1 PTE */    ret = get_pte(&pfn, NULL, NULL, ptebase, page_bits, level1, 0, 0);    switch (ret) {    case 3:        /* Access violation */        return 2;    case 2:        /* translation not valid */        return 1;    default:        /* OK */        break;    }    /* Level 2 PTE */    ret = get_pte(&pfn, NULL, NULL, pfn, page_bits, level2, 0, 0);    switch (ret) {    case 3:        /* Access violation */        return 2;    case 2:        /* translation not valid */        return 1;    default:        /* OK */        break;    }    /* Level 3 PTE */    ret = get_pte(&pfn, zbitsp, prot, pfn, page_bits, level3, mmu_idx, rw);    if (ret & 0x1) {        /* Translation not valid */        ret = 1;    } else if (ret & 2) {        /* Access violation */        ret = 2;    } else {        switch (ret & 0xC) {        case 0:            /* OK */            ret = 0;            break;        case 0x4:            /* Fault on read */            ret = 3;            break;        case 0x8:            /* Fault on execute */            ret = 4;            break;        case 0xC:            /* Fault on write */            ret = 5;            break;        }    }    *paddr = (pfn << page_bits) | (vaddr & page_mask);    return 0;}static int virtual_to_physical (CPUState *env, uint64_t *physp,                                int *zbitsp, int *protp,                                uint64_t virtual, int mmu_idx, int rw){    uint64_t sva, ptebase;    int seg, page_bits, ret;    sva = ((int64_t)(virtual << (64 - VA_BITS))) >> (64 - VA_BITS);    if (sva != virtual)        seg = -1;    else        seg = sva >> (VA_BITS - 2);    virtual &= ~(0xFFFFFC0000000000ULL << (VA_BITS - 43));    ptebase = get_ptebase(env, virtual);    page_bits = get_page_bits(env);    ret = 0;    switch (seg) {    case 0:        /* seg1: 3 levels of PTE */        ret = paddr_from_pte(physp, zbitsp, protp, ptebase, page_bits,                             virtual, mmu_idx, rw);        break;    case 1:        /* seg1: 2 levels of PTE */        ret = paddr_from_pte(physp, zbitsp, protp, ptebase, page_bits,                             virtual, mmu_idx, rw);        break;    case 2:        /* kernel segment */        if (mmu_idx != 0) {            ret = 2;        } else {            *physp = virtual;        }        break;    case 3:        /* seg1: TB mapped */        ret = paddr_from_pte(physp, zbitsp, protp, ptebase, page_bits,                             virtual, mmu_idx, rw);        break;    default:        ret = 1;        break;    }    return ret;}/* XXX: code provision */int cpu_ppc_handle_mmu_fault (CPUState *env, uint32_t address, int rw,                              int mmu_idx, int is_softmmu){    uint64_t physical, page_size, end;    int prot, zbits, ret;    if (env->user_mode_only) {        ret = 2;    } else {        ret = virtual_to_physical(env, &physical, &zbits, &prot,                                  address, mmu_idx, rw);    }    switch (ret) {    case 0:        /* No fault */        page_size = 1ULL << zbits;        address &= ~(page_size - 1);        for (end = physical + page_size; physical < end; physical += 0x1000) {            ret = tlb_set_page(env, address, physical, prot,                               mmu_idx, is_softmmu);            address += 0x1000;        }        break;#if 0    case 1:        env->exception_index = EXCP_DFAULT;        env->ipr[IPR_EXC_ADDR] = address;        ret = 1;        break;    case 2:        env->exception_index = EXCP_ACCESS_VIOLATION;        env->ipr[IPR_EXC_ADDR] = address;        ret = 1;        break;    case 3:        env->exception_index = EXCP_FAULT_ON_READ;        env->ipr[IPR_EXC_ADDR] = address;        ret = 1;        break;    case 4:        env->exception_index = EXCP_FAULT_ON_EXECUTE;        env->ipr[IPR_EXC_ADDR] = address;        ret = 1;    case 5:        env->exception_index = EXCP_FAULT_ON_WRITE;        env->ipr[IPR_EXC_ADDR] = address;        ret = 1;#endif    default:        /* Should never happen */        env->exception_index = EXCP_MCHK;        env->ipr[IPR_EXC_ADDR] = address;        ret = 1;        break;    }    return ret;}#endif#else /* !defined (CONFIG_USER_ONLY) */void pal_init (CPUState *env){}void call_pal (CPUState *env, int palcode){    target_ulong ret;    printf("%s: palcode %02x\n", __func__, palcode);    if (logfile != NULL)        fprintf(logfile, "%s: palcode %02x\n", __func__, palcode);    switch (palcode) {    case 0x83:        /* CALLSYS */        printf("CALLSYS n " TARGET_FMT_ld "\n", env->ir[0]);        if (logfile != NULL)            fprintf(logfile, "CALLSYS n " TARGET_FMT_ld "\n", env->ir[0]);        ret = do_syscall(env, env->ir[IR_V0], env->ir[IR_A0], env->ir[IR_A1],                         env->ir[IR_A2], env->ir[IR_A3], env->ir[IR_A4],                         env->ir[IR_A5]);        env->ir[IR_A3] = ret;        if (ret > (target_ulong)(-515)) {            env->ir[IR_V0] = 1;        } else {            env->ir[IR_V0] = 0;        }        break;    case 0x9E:        /* RDUNIQUE */        env->ir[IR_V0] = env->unique;        printf("RDUNIQUE: " TARGET_FMT_lx "\n", env->unique);        break;    case 0x9F:        /* WRUNIQUE */        env->unique = env->ir[IR_A0];        printf("WRUNIQUE: " TARGET_FMT_lx "\n", env->unique);        break;    default:        printf("%s: unhandled palcode %02x\n", __func__, palcode);        if (logfile != NULL)            fprintf(logfile, "%s: unhandled palcode %02x\n",                    __func__, palcode);        exit(1);    }}#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
首页国产丝袜综合| 人妖欧美一区二区| 国产69精品久久久久777| 91精品国产91久久综合桃花| 亚洲国产一区视频| 色婷婷精品久久二区二区蜜臂av| 国产精品久久久久影院亚瑟| 国产精品456| 久久久久高清精品| 国产精品自拍在线| 久久久久久电影| 国产大陆精品国产| 国产精品网站在线| 北岛玲一区二区三区四区| 国产精品女同一区二区三区| 丁香六月综合激情| 成人欧美一区二区三区1314 | 亚洲精品国产第一综合99久久| 不卡在线视频中文字幕| 国产精品国产三级国产普通话99| 国产99久久久久| 中文字幕一区二区三区乱码在线 | 欧美日韩一区二区三区不卡| 中文字幕免费一区| 国产精品亚洲一区二区三区在线 | 国产精品动漫网站| av在线一区二区| 中文字幕在线视频一区| 久久机这里只有精品| 激情六月婷婷久久| 久久综合九色综合97婷婷女人| 国产精品18久久久久久vr| 精品成人一区二区三区| 国产精品99久久久久| 国产精品网站导航| 欧洲av一区二区嗯嗯嗯啊| 亚洲精品欧美激情| 欧美精品九九99久久| 麻豆精品视频在线观看免费| 在线观看国产一区二区| 三级精品在线观看| 欧美一级欧美三级| 成人一区二区三区视频在线观看| 亚洲国产精华液网站w| 色婷婷av久久久久久久| 亚洲自拍偷拍麻豆| 日韩网站在线看片你懂的| 精品一区二区三区在线观看| 久久久欧美精品sm网站| 另类小说综合欧美亚洲| 亚洲精品一区二区三区香蕉| 精品一二三四在线| 欧美激情一区二区三区蜜桃视频| 色88888久久久久久影院按摩| 亚洲成人动漫一区| 91精品一区二区三区在线观看| 国产精品中文字幕日韩精品| 国产精品久线观看视频| 欧美四级电影网| 蜜桃传媒麻豆第一区在线观看| 欧美激情艳妇裸体舞| 色婷婷av一区二区三区大白胸| 免费观看在线综合色| 久久综合国产精品| 色哟哟欧美精品| 日韩一区精品视频| 国产欧美日韩综合精品一区二区| 91麻豆蜜桃一区二区三区| 有码一区二区三区| 欧美一区二区三区视频在线观看 | 日韩成人av影视| 国产日韩精品久久久| 91免费观看视频| 久久av中文字幕片| 国产精品美女久久久久aⅴ国产馆| 色综合久久久网| 偷拍日韩校园综合在线| 久久综合九色综合欧美就去吻| 日本韩国精品在线| 久久精品国产99国产| 亚洲精品欧美激情| 精品久久久久久久人人人人传媒| 在线亚洲人成电影网站色www| 蜜桃视频在线观看一区| 亚洲综合丝袜美腿| 26uuu久久综合| 亚洲网友自拍偷拍| 亚洲精品在线电影| 欧美优质美女网站| 国产麻豆91精品| 婷婷开心激情综合| 中文字幕免费观看一区| 欧美不卡123| 91精品福利在线| 国产精品一区不卡| 午夜不卡av免费| 亚洲色图制服诱惑| 精品99一区二区| 欧美日韩国产影片| 成人精品免费看| 久久精品噜噜噜成人av农村| 一区二区三区中文在线| 日韩一二三区不卡| 欧美三电影在线| www.亚洲色图.com| 国产精品一区免费在线观看| 午夜精品久久久久久久99水蜜桃| 亚洲少妇最新在线视频| 2014亚洲片线观看视频免费| 欧美一区二区精美| 色视频一区二区| 99久久免费视频.com| 六月婷婷色综合| 午夜欧美视频在线观看| 亚洲欧美国产77777| 国产亚洲一二三区| 91麻豆精品国产无毒不卡在线观看| 色综合天天做天天爱| 粉嫩在线一区二区三区视频| 国产酒店精品激情| 奇米色777欧美一区二区| 丝袜国产日韩另类美女| 亚洲激情一二三区| 亚洲色图都市小说| 中文字幕av不卡| 国产日韩精品一区| 久久久欧美精品sm网站| 久久综合久久综合亚洲| 日韩精品一区二区三区三区免费| 欧美一级欧美三级在线观看| 欧美精品123区| 欧美疯狂性受xxxxx喷水图片| 日本韩国欧美在线| 欧美在线观看视频在线| 日本韩国欧美三级| 欧美性色综合网| 在线视频亚洲一区| 欧美在线观看视频在线| 日本韩国视频一区二区| 欧美性猛交一区二区三区精品| 99re热这里只有精品免费视频| 91天堂素人约啪| 99久久精品费精品国产一区二区| 99精品在线免费| av在线播放成人| 色综合天天狠狠| 91啦中文在线观看| 欧美综合天天夜夜久久| 91福利视频久久久久| 欧美日韩一区二区三区高清| 欧美日韩精品一区二区三区蜜桃 | 成人精品高清在线| 成人午夜视频在线| 91免费版在线| 日本高清不卡一区| 欧美精三区欧美精三区| 宅男在线国产精品| 日韩精品中文字幕在线一区| 日韩午夜av电影| 国产欧美日韩视频一区二区| 国产日韩精品一区二区三区在线| 国产精品久久久久久久岛一牛影视| 国产精品网站导航| 亚洲一区二区三区四区不卡| 天天爽夜夜爽夜夜爽精品视频| 美日韩一级片在线观看| 国产一区二区伦理片| 99久久综合狠狠综合久久| 99riav一区二区三区| 欧美日韩一区二区不卡| 91精品欧美久久久久久动漫| 国产视频一区在线观看| 中文字幕中文乱码欧美一区二区| 亚洲一区二区在线观看视频| 午夜精品视频一区| 国产成人精品免费网站| 92精品国产成人观看免费| 欧美精品精品一区| 亚洲精品一区二区三区影院 | 午夜精彩视频在线观看不卡| 日韩av网站免费在线| 高清视频一区二区| 91免费观看国产| 日韩精品中文字幕在线不卡尤物| 国产欧美精品一区二区色综合朱莉| 亚洲少妇30p| 午夜伊人狠狠久久| 国产精品主播直播| 色综合久久久久综合体| 精品免费视频.| 国产精品狼人久久影院观看方式| 午夜一区二区三区视频| 精品一区二区三区在线播放| 91国偷自产一区二区开放时间 | 中文在线免费一区三区高中清不卡| 国产精品灌醉下药二区| 日韩va欧美va亚洲va久久| 国产精品小仙女| 欧美人体做爰大胆视频| 久久精子c满五个校花|