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

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

?? op_mem.h

?? QEMU 0.91 source code, supports ARM processor including S3C24xx series
?? H
?? 第 1 頁 / 共 3 頁
字號:
/* *  PowerPC emulation micro-operations for qemu. * *  Copyright (c) 2003-2007 Jocelyn Mayer * * 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 "op_mem_access.h"/***                             Integer load                              ***/#define PPC_LD_OP(name, op)                                                   \void OPPROTO glue(glue(op_l, name), MEMSUFFIX) (void)                         \{                                                                             \    T1 = glue(op, MEMSUFFIX)((uint32_t)T0);                                   \    RETURN();                                                                 \}#if defined(TARGET_PPC64)#define PPC_LD_OP_64(name, op)                                                \void OPPROTO glue(glue(glue(op_l, name), _64), MEMSUFFIX) (void)              \{                                                                             \    T1 = glue(op, MEMSUFFIX)((uint64_t)T0);                                   \    RETURN();                                                                 \}#endif#define PPC_ST_OP(name, op)                                                   \void OPPROTO glue(glue(op_st, name), MEMSUFFIX) (void)                        \{                                                                             \    glue(op, MEMSUFFIX)((uint32_t)T0, T1);                                    \    RETURN();                                                                 \}#if defined(TARGET_PPC64)#define PPC_ST_OP_64(name, op)                                                \void OPPROTO glue(glue(glue(op_st, name), _64), MEMSUFFIX) (void)             \{                                                                             \    glue(op, MEMSUFFIX)((uint64_t)T0, T1);                                    \    RETURN();                                                                 \}#endifPPC_LD_OP(bz, ldu8);PPC_LD_OP(ha, lds16);PPC_LD_OP(hz, ldu16);PPC_LD_OP(wz, ldu32);#if defined(TARGET_PPC64)PPC_LD_OP(wa, lds32);PPC_LD_OP(d, ldu64);PPC_LD_OP_64(bz, ldu8);PPC_LD_OP_64(ha, lds16);PPC_LD_OP_64(hz, ldu16);PPC_LD_OP_64(wz, ldu32);PPC_LD_OP_64(wa, lds32);PPC_LD_OP_64(d, ldu64);#endifPPC_LD_OP(ha_le, lds16r);PPC_LD_OP(hz_le, ldu16r);PPC_LD_OP(wz_le, ldu32r);#if defined(TARGET_PPC64)PPC_LD_OP(wa_le, lds32r);PPC_LD_OP(d_le, ldu64r);PPC_LD_OP_64(ha_le, lds16r);PPC_LD_OP_64(hz_le, ldu16r);PPC_LD_OP_64(wz_le, ldu32r);PPC_LD_OP_64(wa_le, lds32r);PPC_LD_OP_64(d_le, ldu64r);#endif/***                              Integer store                            ***/PPC_ST_OP(b, st8);PPC_ST_OP(h, st16);PPC_ST_OP(w, st32);#if defined(TARGET_PPC64)PPC_ST_OP(d, st64);PPC_ST_OP_64(b, st8);PPC_ST_OP_64(h, st16);PPC_ST_OP_64(w, st32);PPC_ST_OP_64(d, st64);#endifPPC_ST_OP(h_le, st16r);PPC_ST_OP(w_le, st32r);#if defined(TARGET_PPC64)PPC_ST_OP(d_le, st64r);PPC_ST_OP_64(h_le, st16r);PPC_ST_OP_64(w_le, st32r);PPC_ST_OP_64(d_le, st64r);#endif/***                Integer load and store with byte reverse               ***/PPC_LD_OP(hbr, ldu16r);PPC_LD_OP(wbr, ldu32r);PPC_ST_OP(hbr, st16r);PPC_ST_OP(wbr, st32r);#if defined(TARGET_PPC64)PPC_LD_OP_64(hbr, ldu16r);PPC_LD_OP_64(wbr, ldu32r);PPC_ST_OP_64(hbr, st16r);PPC_ST_OP_64(wbr, st32r);#endifPPC_LD_OP(hbr_le, ldu16);PPC_LD_OP(wbr_le, ldu32);PPC_ST_OP(hbr_le, st16);PPC_ST_OP(wbr_le, st32);#if defined(TARGET_PPC64)PPC_LD_OP_64(hbr_le, ldu16);PPC_LD_OP_64(wbr_le, ldu32);PPC_ST_OP_64(hbr_le, st16);PPC_ST_OP_64(wbr_le, st32);#endif/***                    Integer load and store multiple                    ***/void OPPROTO glue(op_lmw, MEMSUFFIX) (void){    glue(do_lmw, MEMSUFFIX)(PARAM1);    RETURN();}#if defined(TARGET_PPC64)void OPPROTO glue(op_lmw_64, MEMSUFFIX) (void){    glue(do_lmw_64, MEMSUFFIX)(PARAM1);    RETURN();}#endifvoid OPPROTO glue(op_lmw_le, MEMSUFFIX) (void){    glue(do_lmw_le, MEMSUFFIX)(PARAM1);    RETURN();}#if defined(TARGET_PPC64)void OPPROTO glue(op_lmw_le_64, MEMSUFFIX) (void){    glue(do_lmw_le_64, MEMSUFFIX)(PARAM1);    RETURN();}#endifvoid OPPROTO glue(op_stmw, MEMSUFFIX) (void){    glue(do_stmw, MEMSUFFIX)(PARAM1);    RETURN();}#if defined(TARGET_PPC64)void OPPROTO glue(op_stmw_64, MEMSUFFIX) (void){    glue(do_stmw_64, MEMSUFFIX)(PARAM1);    RETURN();}#endifvoid OPPROTO glue(op_stmw_le, MEMSUFFIX) (void){    glue(do_stmw_le, MEMSUFFIX)(PARAM1);    RETURN();}#if defined(TARGET_PPC64)void OPPROTO glue(op_stmw_le_64, MEMSUFFIX) (void){    glue(do_stmw_le_64, MEMSUFFIX)(PARAM1);    RETURN();}#endif/***                    Integer load and store strings                     ***/void OPPROTO glue(op_lswi, MEMSUFFIX) (void){    glue(do_lsw, MEMSUFFIX)(PARAM1);    RETURN();}#if defined(TARGET_PPC64)void OPPROTO glue(op_lswi_64, MEMSUFFIX) (void){    glue(do_lsw_64, MEMSUFFIX)(PARAM1);    RETURN();}#endif/* PPC32 specification says we must generate an exception if * rA is in the range of registers to be loaded. * In an other hand, IBM says this is valid, but rA won't be loaded. * For now, I'll follow the spec... */void OPPROTO glue(op_lswx, MEMSUFFIX) (void){    /* Note: T1 comes from xer_bc then no cast is needed */    if (likely(T1 != 0)) {        if (unlikely((PARAM1 < PARAM2 && (PARAM1 + T1) > PARAM2) ||                     (PARAM1 < PARAM3 && (PARAM1 + T1) > PARAM3))) {            do_raise_exception_err(POWERPC_EXCP_PROGRAM,                                   POWERPC_EXCP_INVAL |                                   POWERPC_EXCP_INVAL_LSWX);        } else {            glue(do_lsw, MEMSUFFIX)(PARAM1);        }    }    RETURN();}#if defined(TARGET_PPC64)void OPPROTO glue(op_lswx_64, MEMSUFFIX) (void){    /* Note: T1 comes from xer_bc then no cast is needed */    if (likely(T1 != 0)) {        if (unlikely((PARAM1 < PARAM2 && (PARAM1 + T1) > PARAM2) ||                     (PARAM1 < PARAM3 && (PARAM1 + T1) > PARAM3))) {            do_raise_exception_err(POWERPC_EXCP_PROGRAM,                                   POWERPC_EXCP_INVAL |                                   POWERPC_EXCP_INVAL_LSWX);        } else {            glue(do_lsw_64, MEMSUFFIX)(PARAM1);        }    }    RETURN();}#endifvoid OPPROTO glue(op_stsw, MEMSUFFIX) (void){    glue(do_stsw, MEMSUFFIX)(PARAM1);    RETURN();}#if defined(TARGET_PPC64)void OPPROTO glue(op_stsw_64, MEMSUFFIX) (void){    glue(do_stsw_64, MEMSUFFIX)(PARAM1);    RETURN();}#endif/***                         Floating-point store                          ***/#define PPC_STF_OP(name, op)                                                  \void OPPROTO glue(glue(op_st, name), MEMSUFFIX) (void)                        \{                                                                             \    glue(op, MEMSUFFIX)((uint32_t)T0, FT0);                                   \    RETURN();                                                                 \}#if defined(TARGET_PPC64)#define PPC_STF_OP_64(name, op)                                               \void OPPROTO glue(glue(glue(op_st, name), _64), MEMSUFFIX) (void)             \{                                                                             \    glue(op, MEMSUFFIX)((uint64_t)T0, FT0);                                   \    RETURN();                                                                 \}#endifstatic always_inline void glue(stfs, MEMSUFFIX) (target_ulong EA, double d){    glue(stfl, MEMSUFFIX)(EA, float64_to_float32(d, &env->fp_status));}#if defined(WORDS_BIGENDIAN)#define WORD0 0#define WORD1 1#else#define WORD0 1#define WORD1 0#endifstatic always_inline void glue(stfiw, MEMSUFFIX) (target_ulong EA, double d){    union {        double d;        uint32_t u[2];    } u;    /* Store the low order 32 bits without any conversion */    u.d = d;    glue(st32, MEMSUFFIX)(EA, u.u[WORD0]);}#undef WORD0#undef WORD1PPC_STF_OP(fd, stfq);PPC_STF_OP(fs, stfs);PPC_STF_OP(fiw, stfiw);#if defined(TARGET_PPC64)PPC_STF_OP_64(fd, stfq);PPC_STF_OP_64(fs, stfs);PPC_STF_OP_64(fiw, stfiw);#endifstatic always_inline void glue(stfqr, MEMSUFFIX) (target_ulong EA, double d){    union {        double d;        uint64_t u;    } u;    u.d = d;    u.u = bswap64(u.u);    glue(stfq, MEMSUFFIX)(EA, u.d);}static always_inline void glue(stfsr, MEMSUFFIX) (target_ulong EA, double d){    union {        float f;        uint32_t u;    } u;    u.f = float64_to_float32(d, &env->fp_status);    u.u = bswap32(u.u);    glue(stfl, MEMSUFFIX)(EA, u.f);}static always_inline void glue(stfiwr, MEMSUFFIX) (target_ulong EA, double d){    union {        double d;        uint64_t u;    } u;    /* Store the low order 32 bits without any conversion */    u.d = d;    u.u = bswap32(u.u);    glue(st32, MEMSUFFIX)(EA, u.u);}PPC_STF_OP(fd_le, stfqr);PPC_STF_OP(fs_le, stfsr);PPC_STF_OP(fiw_le, stfiwr);#if defined(TARGET_PPC64)PPC_STF_OP_64(fd_le, stfqr);PPC_STF_OP_64(fs_le, stfsr);PPC_STF_OP_64(fiw_le, stfiwr);#endif/***                         Floating-point load                           ***/#define PPC_LDF_OP(name, op)                                                  \void OPPROTO glue(glue(op_l, name), MEMSUFFIX) (void)                         \{                                                                             \    FT0 = glue(op, MEMSUFFIX)((uint32_t)T0);                                  \    RETURN();                                                                 \}#if defined(TARGET_PPC64)#define PPC_LDF_OP_64(name, op)                                               \void OPPROTO glue(glue(glue(op_l, name), _64), MEMSUFFIX) (void)              \{                                                                             \    FT0 = glue(op, MEMSUFFIX)((uint64_t)T0);                                  \    RETURN();                                                                 \}#endifstatic always_inline double glue(ldfs, MEMSUFFIX) (target_ulong EA){    return float32_to_float64(glue(ldfl, MEMSUFFIX)(EA), &env->fp_status);}PPC_LDF_OP(fd, ldfq);PPC_LDF_OP(fs, ldfs);#if defined(TARGET_PPC64)PPC_LDF_OP_64(fd, ldfq);PPC_LDF_OP_64(fs, ldfs);#endifstatic always_inline double glue(ldfqr, MEMSUFFIX) (target_ulong EA){    union {        double d;        uint64_t u;    } u;    u.d = glue(ldfq, MEMSUFFIX)(EA);    u.u = bswap64(u.u);    return u.d;}static always_inline double glue(ldfsr, MEMSUFFIX) (target_ulong EA){    union {        float f;        uint32_t u;    } u;    u.f = glue(ldfl, MEMSUFFIX)(EA);    u.u = bswap32(u.u);    return float32_to_float64(u.f, &env->fp_status);}PPC_LDF_OP(fd_le, ldfqr);PPC_LDF_OP(fs_le, ldfsr);#if defined(TARGET_PPC64)PPC_LDF_OP_64(fd_le, ldfqr);PPC_LDF_OP_64(fs_le, ldfsr);#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久先锋影音av| 国产成人综合在线| 欧美三级中文字| 亚洲国产精品视频| 欧美色窝79yyyycom| 一区二区三区 在线观看视频| 91在线视频免费观看| 亚洲女同ⅹxx女同tv| 91久久精品网| 日日夜夜一区二区| 久久综合久久综合亚洲| 国产乱一区二区| 中文字幕一区二区三区不卡| 99久久99久久久精品齐齐| 亚洲色图在线播放| 欧美一卡二卡在线| 国产成人高清视频| 亚洲精品一二三四区| 91精品国产乱| 国产白丝网站精品污在线入口| 亚洲男人电影天堂| www成人在线观看| 99国产精品一区| 亚洲成人av中文| 国产午夜精品一区二区三区视频| www.亚洲免费av| 久久成人免费网站| 亚洲永久精品国产| 亚洲精品在线一区二区| 色呦呦一区二区三区| 日韩黄色免费网站| 一个色在线综合| 欧美激情在线一区二区三区| 欧美日韩一区成人| 92精品国产成人观看免费| 国产精品亚洲第一区在线暖暖韩国| 中文字幕亚洲电影| 国产精品另类一区| 久久综合久久99| 日韩欧美一区二区久久婷婷| 欧美另类高清zo欧美| 在线亚洲高清视频| 日本道精品一区二区三区| 成人国产精品免费观看动漫| 捆绑调教一区二区三区| 丝袜美腿亚洲一区二区图片| 亚洲国产一区二区在线播放| 一区二区三区电影在线播| 亚洲日本乱码在线观看| 国产精品久久看| 亚洲人成人一区二区在线观看| 亚洲欧洲三级电影| 亚洲欧洲无码一区二区三区| 国产精品高潮呻吟久久| 亚洲精品国产高清久久伦理二区| 欧美激情自拍偷拍| 国产色产综合色产在线视频| 中文字幕欧美区| 亚洲精品日韩专区silk| 亚洲va国产va欧美va观看| 日韩精品成人一区二区三区| 日本欧美一区二区在线观看| 精品午夜久久福利影院| 不卡电影一区二区三区| 99久久精品免费观看| 7777精品伊人久久久大香线蕉超级流畅| 欧美日韩一区不卡| 久久久久久影视| 亚洲成在人线在线播放| 日日摸夜夜添夜夜添亚洲女人| 国产一区视频在线看| 欧美视频日韩视频在线观看| 欧美一区二区国产| 一区二区三区资源| 久久99久久99| 欧美日本在线播放| 久久久www免费人成精品| 一区二区三区欧美日韩| 国产成人精品三级麻豆| 欧美日韩小视频| 一区二区三区在线免费观看| 国产在线播精品第三| 欧美一区在线视频| 亚洲高清一区二区三区| 99国产精品国产精品久久| 久久亚洲综合色| 蜜桃精品在线观看| 欧美精品视频www在线观看| 亚洲美女精品一区| 色播五月激情综合网| 中文一区二区在线观看| 蜜桃精品视频在线| 日韩一区二区三区免费看 | 一区二区不卡在线播放| 欧美成人激情免费网| 免费在线观看视频一区| 日韩亚洲欧美在线观看| 丝袜亚洲另类欧美| 日韩三级精品电影久久久| 天堂va蜜桃一区二区三区漫画版 | 久久精品免费看| 日韩欧美国产小视频| 亚洲成av人**亚洲成av**| 在线观看一区日韩| 天天综合网天天综合色| 91精品国产综合久久精品| 日韩1区2区日韩1区2区| 91精品国产乱码久久蜜臀| 久久99国产精品成人| 国产精品女上位| 精品婷婷伊人一区三区三| 轻轻草成人在线| 国产精品久久久久久久久果冻传媒| 91伊人久久大香线蕉| 欧美bbbbb| 国产欧美一区二区三区在线老狼| 99视频精品免费视频| 五月婷婷久久综合| 久久亚洲捆绑美女| 欧美综合久久久| 国产成人亚洲精品狼色在线| 最新日韩在线视频| 精品久久久久久最新网址| 9i在线看片成人免费| 日本午夜一区二区| 亚洲综合在线免费观看| 欧美国产视频在线| 欧美一级在线观看| 色综合天天综合网国产成人综合天 | 国产aⅴ综合色| 一区二区三区在线高清| 欧美极品xxx| 久久女同精品一区二区| 欧美亚洲日本一区| 99re这里只有精品视频首页| 激情成人午夜视频| 免费成人在线视频观看| 亚洲国产欧美在线人成| 亚洲欧美日韩系列| 日本午夜精品一区二区三区电影| 亚洲最色的网站| 亚洲成人一区在线| 午夜视频一区二区三区| 亚洲午夜久久久久久久久电影院| 久久久久国产精品麻豆ai换脸| 日韩女优视频免费观看| 91精品久久久久久久91蜜桃| 欧美一区二区三区电影| 这里只有精品视频在线观看| 欧美日韩aaa| 3atv在线一区二区三区| 欧美日韩免费观看一区二区三区| 91视频一区二区| 欧美唯美清纯偷拍| 亚洲欧美日韩在线| 日本最新不卡在线| 激情综合网av| 色欧美日韩亚洲| 欧美成人性战久久| 久久久久久久性| 一区二区三区成人| 久久99深爱久久99精品| 国产成人在线视频网址| 白白色 亚洲乱淫| 9191精品国产综合久久久久久| 久久综合国产精品| 亚洲精品成人精品456| 日韩黄色一级片| 在线亚洲一区二区| 2020日本不卡一区二区视频| 亚洲欧美日韩国产一区二区三区| 日韩国产成人精品| 成人毛片老司机大片| 日韩一区二区精品葵司在线| 欧美精品一区二| 日日夜夜精品视频免费| 国产成人在线色| 日韩三区在线观看| 亚洲影视在线观看| 成人午夜免费av| 久久一二三国产| 日韩二区在线观看| 欧美亚洲国产一区二区三区| 久久久久亚洲综合| 久久er99精品| 欧美精品一区二区高清在线观看| 一区二区三区在线视频观看58| 懂色av一区二区三区蜜臀 | 色呦呦日韩精品| 国产精品福利av| 99视频国产精品| 成人欧美一区二区三区| 国产99精品国产| 久久综合久久99| 国产成人av电影在线观看| 久久久久久久久岛国免费| 狠狠色丁香久久婷婷综合_中| 日韩午夜在线观看| 久久99国产精品免费| 久久久国产一区二区三区四区小说|