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

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

?? op_helper.c

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? C
?? 第 1 頁 / 共 5 頁
字號:
    if (((int32_t)T0 == INT32_MIN && (int32_t)T1 == (int32_t)-1) ||        (int32_t)T1 == 0) {        T0 = UINT32_MAX * ((uint32_t)T0 >> 31);        env->spr[SPR_MQ] = 0;    } else {        env->spr[SPR_MQ] = T0 % T1;        T0 = (int32_t)T0 / (int32_t)T1;    }}void do_POWER_divso (void){    if (((int32_t)T0 == INT32_MIN && (int32_t)T1 == (int32_t)-1) ||        (int32_t)T1 == 0) {        T0 = UINT32_MAX * ((uint32_t)T0 >> 31);        env->spr[SPR_MQ] = 0;        xer_ov = 1;    } else {        T0 = (int32_t)T0 / (int32_t)T1;        env->spr[SPR_MQ] = (int32_t)T0 % (int32_t)T1;        xer_ov = 0;    }    xer_so |= xer_ov;}void do_POWER_dozo (void){    if ((int32_t)T1 > (int32_t)T0) {        T2 = T0;        T0 = T1 - T0;        if (((uint32_t)(~T2) ^ (uint32_t)T1 ^ UINT32_MAX) &            ((uint32_t)(~T2) ^ (uint32_t)T0) & (1UL << 31)) {            xer_ov = 1;            xer_so = 1;        } else {            xer_ov = 0;        }    } else {        T0 = 0;        xer_ov = 0;    }}void do_POWER_maskg (void){    uint32_t ret;    if ((uint32_t)T0 == (uint32_t)(T1 + 1)) {        ret = UINT32_MAX;    } else {        ret = (UINT32_MAX >> ((uint32_t)T0)) ^            ((UINT32_MAX >> ((uint32_t)T1)) >> 1);        if ((uint32_t)T0 > (uint32_t)T1)            ret = ~ret;    }    T0 = ret;}void do_POWER_mulo (void){    uint64_t tmp;    tmp = (uint64_t)T0 * (uint64_t)T1;    env->spr[SPR_MQ] = tmp >> 32;    T0 = tmp;    if (tmp >> 32 != ((uint64_t)T0 >> 16) * ((uint64_t)T1 >> 16)) {        xer_ov = 1;        xer_so = 1;    } else {        xer_ov = 0;    }}#if !defined (CONFIG_USER_ONLY)void do_POWER_rac (void){    mmu_ctx_t ctx;    int nb_BATs;    /* We don't have to generate many instances of this instruction,     * as rac is supervisor only.     */    /* XXX: FIX THIS: Pretend we have no BAT */    nb_BATs = env->nb_BATs;    env->nb_BATs = 0;    if (get_physical_address(env, &ctx, T0, 0, ACCESS_INT) == 0)        T0 = ctx.raddr;    env->nb_BATs = nb_BATs;}void do_POWER_rfsvc (void){    __do_rfi(env->lr, env->ctr, 0x0000FFFF, 0);}void do_store_hid0_601 (void){    uint32_t hid0;    hid0 = env->spr[SPR_HID0];    if ((T0 ^ hid0) & 0x00000008) {        /* Change current endianness */        env->hflags &= ~(1 << MSR_LE);        env->hflags_nmsr &= ~(1 << MSR_LE);        env->hflags_nmsr |= (1 << MSR_LE) & (((T0 >> 3) & 1) << MSR_LE);        env->hflags |= env->hflags_nmsr;        if (loglevel != 0) {            fprintf(logfile, "%s: set endianness to %c => " ADDRX "\n",                    __func__, T0 & 0x8 ? 'l' : 'b', env->hflags);        }    }    env->spr[SPR_HID0] = T0;}#endif/*****************************************************************************//* 602 specific instructions *//* mfrom is the most crazy instruction ever seen, imho ! *//* Real implementation uses a ROM table. Do the same */#define USE_MFROM_ROM_TABLEvoid do_op_602_mfrom (void){    if (likely(T0 < 602)) {#if defined(USE_MFROM_ROM_TABLE)#include "mfrom_table.c"        T0 = mfrom_ROM_table[T0];#else        double d;        /* Extremly decomposed:         *                    -T0 / 256         * T0 = 256 * log10(10          + 1.0) + 0.5         */        d = T0;        d = float64_div(d, 256, &env->fp_status);        d = float64_chs(d);        d = exp10(d); // XXX: use float emulation function        d = float64_add(d, 1.0, &env->fp_status);        d = log10(d); // XXX: use float emulation function        d = float64_mul(d, 256, &env->fp_status);        d = float64_add(d, 0.5, &env->fp_status);        T0 = float64_round_to_int(d, &env->fp_status);#endif    } else {        T0 = 0;    }}/*****************************************************************************//* Embedded PowerPC specific helpers */void do_405_check_sat (void){    if (!likely((((uint32_t)T1 ^ (uint32_t)T2) >> 31) ||                !(((uint32_t)T0 ^ (uint32_t)T2) >> 31))) {        /* Saturate result */        if (T2 >> 31) {            T0 = INT32_MIN;        } else {            T0 = INT32_MAX;        }    }}/* XXX: to be improved to check access rights when in user-mode */void do_load_dcr (void){    target_ulong val;    if (unlikely(env->dcr_env == NULL)) {        if (loglevel != 0) {            fprintf(logfile, "No DCR environment\n");        }        do_raise_exception_err(POWERPC_EXCP_PROGRAM,                               POWERPC_EXCP_INVAL | POWERPC_EXCP_INVAL_INVAL);    } else if (unlikely(ppc_dcr_read(env->dcr_env, T0, &val) != 0)) {        if (loglevel != 0) {            fprintf(logfile, "DCR read error %d %03x\n", (int)T0, (int)T0);        }        do_raise_exception_err(POWERPC_EXCP_PROGRAM,                               POWERPC_EXCP_INVAL | POWERPC_EXCP_PRIV_REG);    } else {        T0 = val;    }}void do_store_dcr (void){    if (unlikely(env->dcr_env == NULL)) {        if (loglevel != 0) {            fprintf(logfile, "No DCR environment\n");        }        do_raise_exception_err(POWERPC_EXCP_PROGRAM,                               POWERPC_EXCP_INVAL | POWERPC_EXCP_INVAL_INVAL);    } else if (unlikely(ppc_dcr_write(env->dcr_env, T0, T1) != 0)) {        if (loglevel != 0) {            fprintf(logfile, "DCR write error %d %03x\n", (int)T0, (int)T0);        }        do_raise_exception_err(POWERPC_EXCP_PROGRAM,                               POWERPC_EXCP_INVAL | POWERPC_EXCP_PRIV_REG);    }}#if !defined(CONFIG_USER_ONLY)void do_40x_rfci (void){    __do_rfi(env->spr[SPR_40x_SRR2], env->spr[SPR_40x_SRR3],             ~((target_ulong)0xFFFF0000), 0);}void do_rfci (void){    __do_rfi(env->spr[SPR_BOOKE_CSRR0], SPR_BOOKE_CSRR1,             ~((target_ulong)0x3FFF0000), 0);}void do_rfdi (void){    __do_rfi(env->spr[SPR_BOOKE_DSRR0], SPR_BOOKE_DSRR1,             ~((target_ulong)0x3FFF0000), 0);}void do_rfmci (void){    __do_rfi(env->spr[SPR_BOOKE_MCSRR0], SPR_BOOKE_MCSRR1,             ~((target_ulong)0x3FFF0000), 0);}void do_load_403_pb (int num){    T0 = env->pb[num];}void do_store_403_pb (int num){    if (likely(env->pb[num] != T0)) {        env->pb[num] = T0;        /* Should be optimized */        tlb_flush(env, 1);    }}#endif/* 440 specific */void do_440_dlmzb (void){    target_ulong mask;    int i;    i = 1;    for (mask = 0xFF000000; mask != 0; mask = mask >> 8) {        if ((T0 & mask) == 0)            goto done;        i++;    }    for (mask = 0xFF000000; mask != 0; mask = mask >> 8) {        if ((T1 & mask) == 0)            break;        i++;    } done:    T0 = i;}/* SPE extension helpers *//* Use a table to make this quicker */static uint8_t hbrev[16] = {    0x0, 0x8, 0x4, 0xC, 0x2, 0xA, 0x6, 0xE,    0x1, 0x9, 0x5, 0xD, 0x3, 0xB, 0x7, 0xF,};static always_inline uint8_t byte_reverse (uint8_t val){    return hbrev[val >> 4] | (hbrev[val & 0xF] << 4);}static always_inline uint32_t word_reverse (uint32_t val){    return byte_reverse(val >> 24) | (byte_reverse(val >> 16) << 8) |        (byte_reverse(val >> 8) << 16) | (byte_reverse(val) << 24);}#define MASKBITS 16 // Random value - to be fixed (implementation dependant)void do_brinc (void){    uint32_t a, b, d, mask;    mask = UINT32_MAX >> (32 - MASKBITS);    a = T0 & mask;    b = T1 & mask;    d = word_reverse(1 + word_reverse(a | ~b));    T0 = (T0 & ~mask) | (d & b);}#define DO_SPE_OP2(name)                                                      \void do_ev##name (void)                                                       \{                                                                             \    T0_64 = ((uint64_t)_do_e##name(T0_64 >> 32, T1_64 >> 32) << 32) |         \        (uint64_t)_do_e##name(T0_64, T1_64);                                  \}#define DO_SPE_OP1(name)                                                      \void do_ev##name (void)                                                       \{                                                                             \    T0_64 = ((uint64_t)_do_e##name(T0_64 >> 32) << 32) |                      \        (uint64_t)_do_e##name(T0_64);                                         \}/* Fixed-point vector arithmetic */static always_inline uint32_t _do_eabs (uint32_t val){    if ((val & 0x80000000) && val != 0x80000000)        val -= val;    return val;}static always_inline uint32_t _do_eaddw (uint32_t op1, uint32_t op2){    return op1 + op2;}static always_inline int _do_ecntlsw (uint32_t val){    if (val & 0x80000000)        return clz32(~val);    else        return clz32(val);}static always_inline int _do_ecntlzw (uint32_t val){    return clz32(val);}static always_inline uint32_t _do_eneg (uint32_t val){    if (val != 0x80000000)        val -= val;    return val;}static always_inline uint32_t _do_erlw (uint32_t op1, uint32_t op2){    return rotl32(op1, op2);}static always_inline uint32_t _do_erndw (uint32_t val){    return (val + 0x000080000000) & 0xFFFF0000;}static always_inline uint32_t _do_eslw (uint32_t op1, uint32_t op2){    /* No error here: 6 bits are used */    return op1 << (op2 & 0x3F);}static always_inline int32_t _do_esrws (int32_t op1, uint32_t op2){    /* No error here: 6 bits are used */    return op1 >> (op2 & 0x3F);}static always_inline uint32_t _do_esrwu (uint32_t op1, uint32_t op2){    /* No error here: 6 bits are used */    return op1 >> (op2 & 0x3F);}static always_inline uint32_t _do_esubfw (uint32_t op1, uint32_t op2){    return op2 - op1;}/* evabs */DO_SPE_OP1(abs);/* evaddw */DO_SPE_OP2(addw);/* evcntlsw */DO_SPE_OP1(cntlsw);/* evcntlzw */DO_SPE_OP1(cntlzw);/* evneg */DO_SPE_OP1(neg);/* evrlw */DO_SPE_OP2(rlw);/* evrnd */DO_SPE_OP1(rndw);/* evslw */DO_SPE_OP2(slw);/* evsrws */DO_SPE_OP2(srws);/* evsrwu */DO_SPE_OP2(srwu);/* evsubfw */DO_SPE_OP2(subfw);/* evsel is a little bit more complicated... */static always_inline uint32_t _do_esel (uint32_t op1, uint32_t op2, int n){    if (n)        return op1;    else        return op2;}void do_evsel (void){    T0_64 = ((uint64_t)_do_esel(T0_64 >> 32, T1_64 >> 32, T0 >> 3) << 32) |        (uint64_t)_do_esel(T0_64, T1_64, (T0 >> 2) & 1);}/* Fixed-point vector comparisons */#define DO_SPE_CMP(name)                                                      \void do_ev##name (void)                                                       \{                                                                             \    T0 = _do_evcmp_merge((uint64_t)_do_e##name(T0_64 >> 32,                   \                                               T1_64 >> 32) << 32,            \                         _do_e##name(T0_64, T1_64));                          \}static always_inline uint32_t _do_evcmp_merge (int t0, int t1){    return (t0 << 3) | (t1 << 2) | ((t0 | t1) << 1) | (t0 & t1);}static always_inline int _do_ecmpeq (uint32_t op1, uint32_t op2){    return op1 == op2 ? 1 : 0;}static always_inline int _do_ecmpgts (int32_t op1, int32_t op2){    return op1 > op2 ? 1 : 0;}static always_inline int _do_ecmpgtu (uint32_t op1, uint32_t op2){    return op1 > op2 ? 1 : 0;}static always_inline int _do_ecmplts (int32_t op1, int32_t op2){    return op1 < op2 ? 1 : 0;}static always_inline int _do_ecmpltu (uint32_t op1, uint32_t op2){    return op1 < op2 ? 1 : 0;}/* evcmpeq */DO_SPE_CMP(cmpeq);/* evcmpgts */DO_SPE_CMP(cmpgts);/* evcmpgtu */DO_SPE_CMP(cmpgtu);/* evcmplts */DO_SPE_CMP(cmplts);/* evcmpltu */DO_SPE_CMP(cmpltu);/* Single precision floating-point conversions from/to integer */static always_inline uint32_t _do_efscfsi (int32_t val){    union {        uint32_t u;        float32 f;    } u;    u.f = int32_to_float32(val, &env->spe_status);    return u.u;}static always_inline uint32_t _do_efscfui (uint32_t val){    union {        uint32_t u;        float32 f;    } u;    u.f = uint32_to_float32(val, &env->spe_status);    return u.u;}static always_inline int32_t _do_efsctsi (uint32_t val){    union {        int32_t u;        float32 f;    } u;    u.u = val;    /* NaN are not treated the same way IEEE 754 does */    if (unlikely(isnan(u.f)))        return 0;    return float32_to_int32(u.f, &env->spe_status);}static always_inline uint32_t _do_efsctui (uint32_t val){    union {        int32_t u;        float32 f;    } u;    u.u = val;    /* NaN are not treated the same way IEEE 754 does */    if (unlikely(isnan(u.f)))        return 0;    return float32_to_uint32(u.f, &env->spe_status);}static always_inline int32_t _do_efsctsiz (uint32_t val){    union {        int32_t u;        float32 f;    } u;    u.u = val;    /* NaN are not treated the same way IEEE 754 does */    if (unlikely(isnan(u.f)))        return 0;    return float32_to_int32_round_to_zero(u.f, &env->spe_status);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
激情文学综合网| 制服丝袜中文字幕亚洲| 欧美亚洲综合在线| 欧美一区二区三区啪啪| 精品福利av导航| 国产精品视频九色porn| 一区二区三区不卡在线观看 | 国产成人鲁色资源国产91色综| 不卡的看片网站| 欧美亚洲一区二区在线| 欧美成人精品3d动漫h| 国产精品人成在线观看免费| 亚洲电影欧美电影有声小说| 国产精品一区二区久久不卡| 欧美在线999| 精品少妇一区二区三区在线视频| 国产精品国产精品国产专区不蜜 | 91精品欧美综合在线观看最新| 精品国内二区三区| 亚洲免费观看高清完整版在线观看 | 欧美国产日韩精品免费观看| 亚洲精品乱码久久久久久久久| 美女久久久精品| 99久久99久久精品免费观看| 欧美一区二区在线播放| 国产精品情趣视频| 日韩电影在线免费观看| 成a人片国产精品| 制服丝袜亚洲播放| 国产精品高潮久久久久无| 亚洲h在线观看| 成人黄色一级视频| 欧美v日韩v国产v| 一区二区三区**美女毛片| 国产一区二区三区黄视频| 在线免费不卡电影| 亚洲国产岛国毛片在线| 日韩精品高清不卡| 91浏览器在线视频| 久久蜜桃香蕉精品一区二区三区| 婷婷国产v国产偷v亚洲高清| 99麻豆久久久国产精品免费优播| 另类小说视频一区二区| 在线视频观看一区| 18欧美乱大交hd1984| 国产在线精品不卡| 91精品国产高清一区二区三区 | 粉嫩av一区二区三区在线播放| 欧美日韩国产综合视频在线观看| 中文字幕一区日韩精品欧美| 韩国av一区二区| 欧美一区国产二区| 亚洲影院理伦片| 91香蕉视频污在线| 最新国产精品久久精品| 国产馆精品极品| 欧美不卡一区二区三区四区| 午夜精品爽啪视频| 在线观看91精品国产入口| 国产精品久久久久毛片软件| 久久爱www久久做| 日韩西西人体444www| 五月天亚洲婷婷| 欧美最猛黑人xxxxx猛交| 国产精品国产三级国产aⅴ入口 | 国产三级一区二区| 国内成人精品2018免费看| 91麻豆精品国产91久久久久久| 亚洲午夜久久久久久久久久久 | 亚洲专区一二三| 91官网在线观看| 一区二区三区国产精华| 色菇凉天天综合网| 一区二区三区精品| 欧美日韩精品三区| 亚瑟在线精品视频| 欧美高清视频一二三区| 亚洲aaa精品| 91麻豆精品国产91久久久使用方法| 午夜精品久久久久久久99水蜜桃| 欧美午夜电影在线播放| 亚洲国产另类精品专区| 欧美三级资源在线| 日韩精品一卡二卡三卡四卡无卡 | 日韩电影在线观看网站| 欧美一区二区三区视频在线| 日欧美一区二区| 日韩欧美高清dvd碟片| 久久精品国产在热久久| 26uuu久久综合| 国产激情精品久久久第一区二区| 国产三级一区二区| 91小视频在线观看| 亚洲精品老司机| 欧美日韩中文字幕精品| 丝袜亚洲精品中文字幕一区| 蜜桃av一区二区三区电影| 精品国产乱码久久久久久影片| 国内精品不卡在线| 国产精品乱码一区二三区小蝌蚪| 91影院在线观看| 亚洲h在线观看| 精品国产乱码久久久久久久| 成人激情校园春色| 亚洲国产毛片aaaaa无费看| 日韩欧美二区三区| 成人18视频在线播放| 亚洲综合精品久久| 日韩视频中午一区| 国产suv精品一区二区6| 亚洲欧美日本韩国| 91精品国产综合久久久久久漫画| 国产自产v一区二区三区c| 国产精品黄色在线观看| 欧美日韩综合不卡| 国产麻豆精品theporn| 亚洲免费电影在线| 91精品黄色片免费大全| 国产老女人精品毛片久久| 中文字幕日韩一区| 欧美精品在线观看播放| 国产风韵犹存在线视精品| 亚洲一区在线电影| 亚洲精品一区二区三区影院| 波多野结衣91| 日韩激情一区二区| 国产精品色一区二区三区| 欧美日本一区二区三区四区 | 国产精品网站一区| 欧美日韩一区二区在线观看视频| 激情综合色播激情啊| 亚洲精选在线视频| 欧美精品一区二区三区在线播放| 91蜜桃视频在线| 九色综合狠狠综合久久| 一区二区三区电影在线播| 久久人人超碰精品| 欧美日韩在线不卡| 成人性生交大合| 美女任你摸久久| 亚洲免费av在线| 久久综合国产精品| 欧美日韩aaaaa| 99国内精品久久| 韩国毛片一区二区三区| 亚洲一级不卡视频| 国产精品情趣视频| www激情久久| 欧美日韩国产美女| 91小视频在线免费看| 国产精品2024| 日韩av一二三| 亚洲综合色丁香婷婷六月图片| 国产欧美一区二区三区沐欲| 91精品国产91久久久久久一区二区 | 欧美在线一二三四区| 国产成人精品在线看| 久久精品国产亚洲5555| 亚洲 欧美综合在线网络| 亚洲色图欧美偷拍| 国产欧美精品一区二区色综合朱莉 | k8久久久一区二区三区| 美女久久久精品| 丝袜诱惑亚洲看片| 亚洲电影在线免费观看| 亚洲欧美日韩在线播放| 亚洲国产经典视频| 国产无遮挡一区二区三区毛片日本| 日韩一区二区三区电影在线观看 | 国产精品家庭影院| 欧美国产欧美综合| 26uuu色噜噜精品一区二区| 欧美一级午夜免费电影| 欧美日精品一区视频| 91精品福利在线| 一本久久精品一区二区| 成人av免费在线| 成人精品gif动图一区| 成人毛片老司机大片| 国产成人精品一区二区三区四区 | www.激情成人| 99视频在线精品| 成人h动漫精品一区二| 国产iv一区二区三区| 国产精品99久久久久| 国产中文字幕一区| 国产激情一区二区三区桃花岛亚洲| 国产一区二区女| 国产精品一区二区91| 国产伦精品一区二区三区免费 | 久久久国产精品午夜一区ai换脸| 欧美精品一区二区在线观看| 久久久www成人免费无遮挡大片| 久久这里都是精品| 久久久久久久电影| 中文字幕国产一区二区| 国产精品传媒入口麻豆| 1024成人网色www| 一区二区三区久久| 亚洲一区电影777|