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

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

?? sparcjitcodegen.java

?? java 到c的轉換程序的原代碼.對喜歡C程序而不懂JAVA程序的人很有幫助
?? JAVA
?? 第 1 頁 / 共 5 頁
字號:
                break;            case Opcode.INT2BYTE:                code.ST ("%l0", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LDSB ("%fp", 3 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%l0");                break;            case Opcode.INT2CHAR:                code.ST ("%l0", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LDUH ("%fp", 2 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%l0");                break;            case Opcode.INT2SHORT:                code.ST ("%l0", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LDSH ("%fp", 2 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%l0");                break;                            /* long operands: %l2 -> %l0 */            case Opcode.LNEG:                code.SUBcc ("%g0", "%l3", "%l1");                code.SUBX ("%g0", "%l2", "%l0");                break;            case Opcode.L2I:                code.MOV ("%l3", "%l0");                break;            case Opcode.L2F:            case Opcode.L2D:                code.MOV ("%l2", "%o0");                code.MOV ("%l3", "%o1");                code.reserveCode (CodeBlock.brACALL, i, "noreg",                                  getFuncAddr ((Opcode.L2F == i.opcode.code) ? FID_long2f : FID_long2d));                code.NOP ();                break;            /* Float operands: %f2 -> %f0 */            case Opcode.FNEG:                code.FNEGs ("%f2", "%f0");                break;            case Opcode.F2I:                code.FsTOi ("%f2", "%f0");                code.FpushES ("%f0");                donestore = true;                break;            case Opcode.F2L:                code.FsTOd ("%f2", "%f0");                code.STDF ("%f0", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LD ("%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o0");                code.LD ("%fp", 4 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o1");                code.reserveCode (CodeBlock.brACALL, i, "noreg", getFuncAddr (FID_dtol));                code.NOP ();                code.LpushES ("%o0");                donestore = true;                break;            case Opcode.F2D:                code.FsTOd ("%f2", "%f0");                break;                            /* Double operands: %f2 -> %f0 */            case Opcode.DNEG:                code.FNEGs ("%f2", "%f0");                code.FMOVs ("%f3", "%f1");                break;            case Opcode.D2I:                code.FdTOi ("%f2", "%f0");                code.FpushES ("%f0");                donestore = true;                break;            case Opcode.D2F:                code.FdTOs ("%f2", "%f0");                break;            case Opcode.D2L:                code.STDF ("%f2", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LD ("%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o0");                code.LD ("%fp", 4 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o1");                code.reserveCode (CodeBlock.brACALL, i, "noreg", getFuncAddr (FID_dtol));                code.NOP ();                code.LpushES ("%o0");                donestore = true;                break;                            default:                throw new InternalError ("Unop code " + i.opcode + " not supported in JIT");        }        /* Store the result back on the execution stack, unless we did it         * already (e.g., for float-to-int conversions) */        if (! donestore) {            if (opdtype.equals ("i")) {                /* stack: %l0 -> val */                code.pushES ("%l0");            } else if (opdtype.equals ("f")) {                /* stack: %f0 -> val */                code.FpushES ("%f0");            } else if (opdtype.equals ("xl")) {                /* stack: %l0 -> val.w1 val.w2 */                code.LpushES ("%l0");            } else if (opdtype.equals ("xd")) {                /* stack: %f0 -> val.w1 val.w2 */                code.DpushES ("%f0");            } else {                throw new InternalError ("Bad type in binop.");            }        }        return;    }    /** Emit code for a binary operation      * @param i instruction for codegen      */    private void    EmitBinOp (Instr i)    {        String opdtype;         // Type of operands of instruction        opdtype = i.opcode.push;        /* Load the operands into their registers.  Fortunately, no         * binary operators are cast operators, so the output and input         * types are the same.  Um, except for long shifts. */        if (opdtype.equals ("i")) {            /* stack: op1 op2  -> %l0 %l1 */            code.popES ("%l1");            code.popES ("%l0");        } else if (opdtype.equals ("f")) {            /* stack: op1 op2  -> %f2 %f3 */            code.FpopES ("%f3");            code.FpopES ("%f2");        } else if (opdtype.equals ("xl")) {            if ((Opcode.LSHL == i.opcode.code) ||                (Opcode.LSHR == i.opcode.code) ||                (Opcode.LUSHR == i.opcode.code)) {                /* stack: op1.w1 op1.w2 op2 -> %o0 %o2 */                /* We're going to call a function to do these, so pop                 * right into the outgoing args. */                code.popES ("%o2");                code.LpopES ("%o0");            } else {                /* stack: op1.w1 op1.w2 op2.w1 op2.w2  -> %l2 %l4 */                code.LpopES ("%l4");                code.LpopES ("%l2");            }        } else if (opdtype.equals ("xd")) {            /* stack: op1.w1 op1.w2 op2.w1 op2.w2  -> %f2 %f4 */            code.DpopES ("%f4");            code.DpopES ("%f2");        } else {            throw new InternalError ("Bad type in binop.");        }        /* Emit the code to operate on the results */        switch (i.opcode.code) {            /* int operands: %l0 op %l1 -> %l0 */            case Opcode.IADD:                code.ADD ("%l0", "%l1", "%l0");                break;            case Opcode.ISUB:                code.SUB ("%l0", "%l1", "%l0");                break;            case Opcode.IMUL:                code.SMUL ("%l0", "%l1", "%l0");                break;            case Opcode.IREM:            case Opcode.IDIV:                /* We'll have to cheat until we get a v8 sparchitecture manual */                code.MOV ("%l0", "%o0");                code.MOV ("%l1", "%o1");                code.reserveCode (CodeBlock.brACALL, i, "noreg",                                  getFuncAddr ((Opcode.IREM == i.opcode.code) ? FID_intrem : FID_intdiv));                code.NOP ();                code.MOV ("%o0", "%l0");                break;            case Opcode.IAND:                code.AND ("%l0", "%l1", "%l0");                break;            case Opcode.IOR:                code.OR ("%l0", "%l1", "%l0");                break;            case Opcode.IXOR:                code.XOR ("%l0", "%l1", "%l0");                break;            case Opcode.ISHL:                code.SLL ("%l0", "%l1", "%l0");                break;            case Opcode.ISHR:                code.SRA ("%l0", "%l1", "%l0");                break;            case Opcode.IUSHR:                code.SRL ("%l0", "%l1", "%l0");                break;                                /* long operands: %l2 op %l4 -> %l0 */            case Opcode.LADD:                code.ADDcc ("%l3", "%l5", "%l1");                code.ADDX ("%l2", "%l4", "%l0");                break;            case Opcode.LSUB:                code.SUBcc ("%l3", "%l5", "%l1");                code.SUBX ("%l2", "%l4", "%l0");                break;            case Opcode.LMUL:                /* This is the sequence that gcc -mv8 -O3 uses. */                code.UMUL ("%l3", "%l5", "%l1");                code.RDY ("%l0");                code.SMUL ("%l3", "%l4", "%o7");                code.ADD ("%l0", "%o7", "%l0");                code.SMUL ("%l5", "%l2", "%l2");                code.ADD ("%l0", "%l2", "%l0");                break;            case Opcode.LREM:            case Opcode.LDIV:                /* Everybody else does this with a function call; let's                 * do it that way too. */                code.MOV ("%l2", "%o0");                code.MOV ("%l3", "%o1");                code.MOV ("%l4", "%o2");                code.MOV ("%l5", "%o3");                code.reserveCode (CodeBlock.brACALL, i, "noreg",                                  getFuncAddr ((Opcode.LREM == i.opcode.code) ? FID_longrem : FID_longdiv));                code.NOP ();                code.MOV ("%o0", "%l0");                code.MOV ("%o1", "%l1");                break;            case Opcode.LAND:                code.AND ("%l2", "%l4", "%l0");                code.AND ("%l3", "%l5", "%l1");                break;            case Opcode.LOR:                code.OR ("%l2", "%l4", "%l0");                code.OR ("%l3", "%l5", "%l1");                break;            case Opcode.LXOR:                code.XOR ("%l2", "%l4", "%l0");                code.XOR ("%l3", "%l5", "%l1");                break;            case Opcode.LSHL:            case Opcode.LSHR:            case Opcode.LUSHR:                /* Already have op1 and op2 into %o0, %o1, %o2, so put in                 * the operator type, and call the function. */                code.MOV (i.opcode.code, "%o3");                code.reserveCode (CodeBlock.brACALL, i, "noreg", getFuncAddr (FID_longshift));                code.NOP ();                /* Move result back into local registers */                code.MOV ("%o0", "%l0");                code.MOV ("%o1", "%l1");                break;                /* Float operands: %f2 op %f3 -> %f0 */            case Opcode.FADD:                code.FADDs ("%f2", "%f3", "%f0");                break;            case Opcode.FSUB:                code.FSUBs ("%f2", "%f3", "%f0");                break;            case Opcode.FMUL:                code.FMULs ("%f2", "%f3", "%f0");                break;            case Opcode.FDIV:                /*!! UNFINISHED -- check for divbyzero !!*/                code.FDIVs ("%f2", "%f3", "%f0");                break;            case Opcode.FREM:                /*!! UNFINISHED -- is this correct? !!*/                /* Convert from single to double precision, and call                 * the remdr function in toba */                code.FsTOd ("%f2", "%f0");                code.FsTOd ("%f3", "%f2");                code.STDF ("%f0", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LD ("%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o0");                code.LD ("%fp", 4 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o1");                code.STDF ("%f2", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LD ("%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o2");                code.LD ("%fp", 4 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o3");                code.reserveCode (CodeBlock.brACALL, i, "noreg", getFuncAddr (FID_remdr));                code.NOP ();                code.FdTOs ("%f0", "%f0");                break;                /* Double operands: %f2 %f4 -> %f0 */            case Opcode.DADD:                code.FADDd ("%f2", "%f4", "%f0");                break;            case Opcode.DSUB:                code.FSUBd ("%f2", "%f4", "%f0");                break;            case Opcode.DMUL:                code.FMULd ("%f2", "%f4", "%f0");                break;            case Opcode.DDIV:                /*!! UNFINISHED -- check for divbyzero !!*/                code.FDIVd ("%f2", "%f4", "%f0");                break;            case Opcode.DREM:                /* Call the remdr function in toba */                code.STDF ("%f2", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LD ("%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o0");                code.LD ("%fp", 4 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o1");                code.STDF ("%f4", "%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE));                code.LD ("%fp", - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o2");                code.LD ("%fp", 4 - (overheadSize + SPARC.ALUFPUXFERSIZE), "%o3");                code.reserveCode (CodeBlock.brACALL, i, "noreg", getFuncAddr (FID_remdr));                code.NOP ();                break;            default:                throw new InternalError ("Binop code " + i.opcode + " not supported in JIT");        }        /* Store the result back on the execution stack */        if (opdtype.equals ("i")) {            /* stack: %l0 -> val */            code.pushES ("%l0");        } else if (opdtype.equals ("f")) {            /* stack: %f0 -> val */            code.FpushES ("%f0");        } else if (opdtype.equals ("xl")) {            /* stack: %l0 -> val.w1 val.w2 */            code.LpushES ("%l0");        } else if (opdtype.equals ("xd")) {            /* stack: %f0 -> val.w1 val.w2 */            code.DpushES ("%f0");        } else {            throw new InternalError ("Bad type in binop.");        }        return;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人欧美日韩在线电影| 91高清视频免费看| 色婷婷久久久久swag精品| 日韩欧美国产麻豆| 亚洲男人的天堂在线观看| 裸体健美xxxx欧美裸体表演| 国产大陆精品国产| 欧美精品欧美精品系列| 中文字幕一区二区三区蜜月 | 麻豆国产精品一区二区三区| gogo大胆日本视频一区| 精品久久久影院| 亚洲成av人片www| 成人黄色综合网站| 26uuu精品一区二区三区四区在线| 亚洲亚洲人成综合网络| 九九国产精品视频| 日韩三级视频中文字幕| 亚洲电影第三页| 一本大道av伊人久久综合| 国产丝袜美腿一区二区三区| 免费高清在线视频一区·| 日本高清不卡在线观看| 国产精品嫩草久久久久| 国产精品自拍毛片| 精品少妇一区二区三区免费观看| 亚洲成av人片在www色猫咪| 日本久久电影网| 国产精品美女一区二区三区| 丁香网亚洲国际| 国产女同互慰高潮91漫画| 国产永久精品大片wwwapp| 日韩精品一区二区三区老鸭窝 | 日本午夜精品视频在线观看| 欧美麻豆精品久久久久久| 亚洲高清免费视频| 色8久久人人97超碰香蕉987| 亚洲第一久久影院| 欧美精品在线观看播放| 日韩高清一区在线| 日韩欧美中文字幕制服| 久久99国产精品尤物| 亚洲精品一区在线观看| 国产乱人伦精品一区二区在线观看| 欧美精品一区二区三| 韩国v欧美v亚洲v日本v| 日韩精品一区二区三区在线播放| 老司机精品视频导航| 久久综合色天天久久综合图片| 国产精品资源站在线| 国产精品家庭影院| 91老师片黄在线观看| 午夜精品一区二区三区三上悠亚| 欧美日韩中文字幕一区二区| 日韩中文字幕不卡| 26uuu精品一区二区三区四区在线| 久久精品国产色蜜蜜麻豆| 欧美一卡2卡三卡4卡5免费| 美女视频黄免费的久久| 国产视频一区二区在线观看| av中文字幕在线不卡| 亚洲影视资源网| 91福利在线看| 黑人精品欧美一区二区蜜桃| 亚洲欧美自拍偷拍色图| 色噜噜久久综合| 久久99日本精品| 中文字幕一区二区三区在线播放| 欧美性生活大片视频| 久久机这里只有精品| 亚洲天堂免费在线观看视频| 欧美一级欧美三级| 成人sese在线| 日本三级亚洲精品| 中文字幕在线观看不卡| 69久久99精品久久久久婷婷 | 午夜视频在线观看一区二区三区| 欧美v亚洲v综合ⅴ国产v| 99精品视频在线免费观看| 日韩精品欧美成人高清一区二区| 欧美激情一二三区| 欧美一级午夜免费电影| 91视频在线看| 韩日精品视频一区| 午夜精品一区二区三区三上悠亚| 国产精品剧情在线亚洲| 日韩欧美国产综合在线一区二区三区| 91在线观看视频| 日本va欧美va精品| 久久成人综合网| 亚洲精品免费在线| 久久综合一区二区| 7777精品伊人久久久大香线蕉| 91麻豆视频网站| 激情五月婷婷综合| 亚洲成a天堂v人片| |精品福利一区二区三区| 久久久99免费| 欧美一卡二卡三卡四卡| 欧美三级资源在线| 91在线精品一区二区| 国产精品一区二区三区99| 免费久久精品视频| 日韩va亚洲va欧美va久久| 中文字幕五月欧美| 国产亚洲精品资源在线26u| 欧美日韩精品一区二区三区四区| 99久久国产免费看| 99久久99久久精品国产片果冻| 国产精品小仙女| 国产精品资源站在线| 国产精品自拍三区| 国产精品 日产精品 欧美精品| 热久久一区二区| 蜜桃久久av一区| 另类中文字幕网| 国产真实乱子伦精品视频| 久久激情综合网| 经典一区二区三区| 国产精品一区二区三区99| 国产成人综合在线观看| 国产成人aaa| 成人激情小说网站| 91蝌蚪国产九色| 91美女蜜桃在线| 欧美主播一区二区三区| 欧美日韩一区小说| 91精品国产麻豆国产自产在线| 91精品欧美综合在线观看最新 | 欧美成人精品福利| 日韩女优制服丝袜电影| 久久免费电影网| 久久先锋影音av鲁色资源| 中文字幕中文字幕一区| 中文字幕在线视频一区| 亚洲福利一二三区| 成人黄色小视频| 欧美在线视频不卡| 日韩视频一区二区三区| 国产欧美视频一区二区| 一区二区在线观看免费| 喷水一区二区三区| 成人爱爱电影网址| 在线观看日产精品| 欧美一区二区三区免费观看视频| 久久精品人人爽人人爽| 国产精品成人一区二区三区夜夜夜| 亚洲老司机在线| 精品一区二区三区蜜桃| 国产精品99久久久久久宅男| 日本二三区不卡| 日韩欧美国产综合| 亚洲日本va午夜在线电影| 日本va欧美va欧美va精品| 成人免费高清视频| 欧美一级高清片在线观看| 国产精品国产三级国产aⅴ入口 | 北岛玲一区二区三区四区| 欧美性大战久久久久久久蜜臀| 日韩免费一区二区三区在线播放| 国产精品免费丝袜| 丝袜美腿亚洲一区| 99精品国产91久久久久久| 日韩欧美在线123| 一区二区三区四区在线免费观看 | 欧美视频在线不卡| 久久久久久久久久久久电影| 亚洲精品videosex极品| 激情欧美一区二区| 国产三级一区二区| 亚洲欧美另类久久久精品2019| 久久成人麻豆午夜电影| av在线播放不卡| 欧美一级片免费看| 夜夜夜精品看看| 国产91精品免费| 精品国产髙清在线看国产毛片| 亚洲一区二区三区在线看| 国产不卡在线一区| 欧美大胆一级视频| 亚洲精品国产一区二区三区四区在线| 国产乱码精品一区二区三区忘忧草 | 久久久久国产精品免费免费搜索| 国产精品久久久一本精品| 青草国产精品久久久久久| 在线免费观看不卡av| 国产精品人人做人人爽人人添| 久久国产免费看| 欧美日韩国产一级片| 一区二区三区精品在线| www.久久久久久久久| 国产欧美一区二区在线| 捆绑调教一区二区三区| 7777精品伊人久久久大香线蕉完整版 | 欧美精品一区二区久久久| 国产成人aaa| 欧美精品一区男女天堂| 麻豆精品在线播放| 欧美日韩亚洲综合| 五月婷婷色综合|