| "use strict"; |
| // Generated by Air::dumpAsJS from executeIteration#EVx8pJ in Octane/gbemu |
| function createPayloadGbemuExecuteIteration() |
| { |
| let code = new Code(); |
| let bb0 = code.addBlock(); |
| let bb1 = code.addBlock(); |
| let bb2 = code.addBlock(); |
| let bb3 = code.addBlock(); |
| let bb4 = code.addBlock(); |
| let bb5 = code.addBlock(); |
| let bb6 = code.addBlock(); |
| let bb7 = code.addBlock(); |
| let bb8 = code.addBlock(); |
| let bb9 = code.addBlock(); |
| let bb10 = code.addBlock(); |
| let bb11 = code.addBlock(); |
| let bb12 = code.addBlock(); |
| let bb13 = code.addBlock(); |
| let bb14 = code.addBlock(); |
| let bb15 = code.addBlock(); |
| let bb16 = code.addBlock(); |
| let bb17 = code.addBlock(); |
| let bb18 = code.addBlock(); |
| let bb19 = code.addBlock(); |
| let bb20 = code.addBlock(); |
| let bb21 = code.addBlock(); |
| let bb22 = code.addBlock(); |
| let bb23 = code.addBlock(); |
| let bb24 = code.addBlock(); |
| let bb25 = code.addBlock(); |
| let bb26 = code.addBlock(); |
| let bb27 = code.addBlock(); |
| let bb28 = code.addBlock(); |
| let bb29 = code.addBlock(); |
| let bb30 = code.addBlock(); |
| let bb31 = code.addBlock(); |
| let bb32 = code.addBlock(); |
| let bb33 = code.addBlock(); |
| let bb34 = code.addBlock(); |
| let bb35 = code.addBlock(); |
| let bb36 = code.addBlock(); |
| let bb37 = code.addBlock(); |
| let bb38 = code.addBlock(); |
| let bb39 = code.addBlock(); |
| let bb40 = code.addBlock(); |
| let bb41 = code.addBlock(); |
| let bb42 = code.addBlock(); |
| let slot0 = code.addStackSlot(64, Locked); |
| let slot1 = code.addStackSlot(8, Spill); |
| let slot2 = code.addStackSlot(8, Spill); |
| let slot3 = code.addStackSlot(8, Spill); |
| let slot4 = code.addStackSlot(8, Spill); |
| let slot5 = code.addStackSlot(8, Spill); |
| let slot6 = code.addStackSlot(8, Spill); |
| let slot7 = code.addStackSlot(8, Spill); |
| let slot8 = code.addStackSlot(8, Spill); |
| let slot9 = code.addStackSlot(8, Spill); |
| let slot10 = code.addStackSlot(8, Spill); |
| let slot11 = code.addStackSlot(8, Spill); |
| let slot12 = code.addStackSlot(40, Locked); |
| slot12.setOffsetFromFP(-40); |
| let tmp190 = code.newTmp(GP); |
| let tmp189 = code.newTmp(GP); |
| let tmp188 = code.newTmp(GP); |
| let tmp187 = code.newTmp(GP); |
| let tmp186 = code.newTmp(GP); |
| let tmp185 = code.newTmp(GP); |
| let tmp184 = code.newTmp(GP); |
| let tmp183 = code.newTmp(GP); |
| let tmp182 = code.newTmp(GP); |
| let tmp181 = code.newTmp(GP); |
| let tmp180 = code.newTmp(GP); |
| let tmp179 = code.newTmp(GP); |
| let tmp178 = code.newTmp(GP); |
| let tmp177 = code.newTmp(GP); |
| let tmp176 = code.newTmp(GP); |
| let tmp175 = code.newTmp(GP); |
| let tmp174 = code.newTmp(GP); |
| let tmp173 = code.newTmp(GP); |
| let tmp172 = code.newTmp(GP); |
| let tmp171 = code.newTmp(GP); |
| let tmp170 = code.newTmp(GP); |
| let tmp169 = code.newTmp(GP); |
| let tmp168 = code.newTmp(GP); |
| let tmp167 = code.newTmp(GP); |
| let tmp166 = code.newTmp(GP); |
| let tmp165 = code.newTmp(GP); |
| let tmp164 = code.newTmp(GP); |
| let tmp163 = code.newTmp(GP); |
| let tmp162 = code.newTmp(GP); |
| let tmp161 = code.newTmp(GP); |
| let tmp160 = code.newTmp(GP); |
| let tmp159 = code.newTmp(GP); |
| let tmp158 = code.newTmp(GP); |
| let tmp157 = code.newTmp(GP); |
| let tmp156 = code.newTmp(GP); |
| let tmp155 = code.newTmp(GP); |
| let tmp154 = code.newTmp(GP); |
| let tmp153 = code.newTmp(GP); |
| let tmp152 = code.newTmp(GP); |
| let tmp151 = code.newTmp(GP); |
| let tmp150 = code.newTmp(GP); |
| let tmp149 = code.newTmp(GP); |
| let tmp148 = code.newTmp(GP); |
| let tmp147 = code.newTmp(GP); |
| let tmp146 = code.newTmp(GP); |
| let tmp145 = code.newTmp(GP); |
| let tmp144 = code.newTmp(GP); |
| let tmp143 = code.newTmp(GP); |
| let tmp142 = code.newTmp(GP); |
| let tmp141 = code.newTmp(GP); |
| let tmp140 = code.newTmp(GP); |
| let tmp139 = code.newTmp(GP); |
| let tmp138 = code.newTmp(GP); |
| let tmp137 = code.newTmp(GP); |
| let tmp136 = code.newTmp(GP); |
| let tmp135 = code.newTmp(GP); |
| let tmp134 = code.newTmp(GP); |
| let tmp133 = code.newTmp(GP); |
| let tmp132 = code.newTmp(GP); |
| let tmp131 = code.newTmp(GP); |
| let tmp130 = code.newTmp(GP); |
| let tmp129 = code.newTmp(GP); |
| let tmp128 = code.newTmp(GP); |
| let tmp127 = code.newTmp(GP); |
| let tmp126 = code.newTmp(GP); |
| let tmp125 = code.newTmp(GP); |
| let tmp124 = code.newTmp(GP); |
| let tmp123 = code.newTmp(GP); |
| let tmp122 = code.newTmp(GP); |
| let tmp121 = code.newTmp(GP); |
| let tmp120 = code.newTmp(GP); |
| let tmp119 = code.newTmp(GP); |
| let tmp118 = code.newTmp(GP); |
| let tmp117 = code.newTmp(GP); |
| let tmp116 = code.newTmp(GP); |
| let tmp115 = code.newTmp(GP); |
| let tmp114 = code.newTmp(GP); |
| let tmp113 = code.newTmp(GP); |
| let tmp112 = code.newTmp(GP); |
| let tmp111 = code.newTmp(GP); |
| let tmp110 = code.newTmp(GP); |
| let tmp109 = code.newTmp(GP); |
| let tmp108 = code.newTmp(GP); |
| let tmp107 = code.newTmp(GP); |
| let tmp106 = code.newTmp(GP); |
| let tmp105 = code.newTmp(GP); |
| let tmp104 = code.newTmp(GP); |
| let tmp103 = code.newTmp(GP); |
| let tmp102 = code.newTmp(GP); |
| let tmp101 = code.newTmp(GP); |
| let tmp100 = code.newTmp(GP); |
| let tmp99 = code.newTmp(GP); |
| let tmp98 = code.newTmp(GP); |
| let tmp97 = code.newTmp(GP); |
| let tmp96 = code.newTmp(GP); |
| let tmp95 = code.newTmp(GP); |
| let tmp94 = code.newTmp(GP); |
| let tmp93 = code.newTmp(GP); |
| let tmp92 = code.newTmp(GP); |
| let tmp91 = code.newTmp(GP); |
| let tmp90 = code.newTmp(GP); |
| let tmp89 = code.newTmp(GP); |
| let tmp88 = code.newTmp(GP); |
| let tmp87 = code.newTmp(GP); |
| let tmp86 = code.newTmp(GP); |
| let tmp85 = code.newTmp(GP); |
| let tmp84 = code.newTmp(GP); |
| let tmp83 = code.newTmp(GP); |
| let tmp82 = code.newTmp(GP); |
| let tmp81 = code.newTmp(GP); |
| let tmp80 = code.newTmp(GP); |
| let tmp79 = code.newTmp(GP); |
| let tmp78 = code.newTmp(GP); |
| let tmp77 = code.newTmp(GP); |
| let tmp76 = code.newTmp(GP); |
| let tmp75 = code.newTmp(GP); |
| let tmp74 = code.newTmp(GP); |
| let tmp73 = code.newTmp(GP); |
| let tmp72 = code.newTmp(GP); |
| let tmp71 = code.newTmp(GP); |
| let tmp70 = code.newTmp(GP); |
| let tmp69 = code.newTmp(GP); |
| let tmp68 = code.newTmp(GP); |
| let tmp67 = code.newTmp(GP); |
| let tmp66 = code.newTmp(GP); |
| let tmp65 = code.newTmp(GP); |
| let tmp64 = code.newTmp(GP); |
| let tmp63 = code.newTmp(GP); |
| let tmp62 = code.newTmp(GP); |
| let tmp61 = code.newTmp(GP); |
| let tmp60 = code.newTmp(GP); |
| let tmp59 = code.newTmp(GP); |
| let tmp58 = code.newTmp(GP); |
| let tmp57 = code.newTmp(GP); |
| let tmp56 = code.newTmp(GP); |
| let tmp55 = code.newTmp(GP); |
| let tmp54 = code.newTmp(GP); |
| let tmp53 = code.newTmp(GP); |
| let tmp52 = code.newTmp(GP); |
| let tmp51 = code.newTmp(GP); |
| let tmp50 = code.newTmp(GP); |
| let tmp49 = code.newTmp(GP); |
| let tmp48 = code.newTmp(GP); |
| let tmp47 = code.newTmp(GP); |
| let tmp46 = code.newTmp(GP); |
| let tmp45 = code.newTmp(GP); |
| let tmp44 = code.newTmp(GP); |
| let tmp43 = code.newTmp(GP); |
| let tmp42 = code.newTmp(GP); |
| let tmp41 = code.newTmp(GP); |
| let tmp40 = code.newTmp(GP); |
| let tmp39 = code.newTmp(GP); |
| let tmp38 = code.newTmp(GP); |
| let tmp37 = code.newTmp(GP); |
| let tmp36 = code.newTmp(GP); |
| let tmp35 = code.newTmp(GP); |
| let tmp34 = code.newTmp(GP); |
| let tmp33 = code.newTmp(GP); |
| let tmp32 = code.newTmp(GP); |
| let tmp31 = code.newTmp(GP); |
| let tmp30 = code.newTmp(GP); |
| let tmp29 = code.newTmp(GP); |
| let tmp28 = code.newTmp(GP); |
| let tmp27 = code.newTmp(GP); |
| let tmp26 = code.newTmp(GP); |
| let tmp25 = code.newTmp(GP); |
| let tmp24 = code.newTmp(GP); |
| let tmp23 = code.newTmp(GP); |
| let tmp22 = code.newTmp(GP); |
| let tmp21 = code.newTmp(GP); |
| let tmp20 = code.newTmp(GP); |
| let tmp19 = code.newTmp(GP); |
| let tmp18 = code.newTmp(GP); |
| let tmp17 = code.newTmp(GP); |
| let tmp16 = code.newTmp(GP); |
| let tmp15 = code.newTmp(GP); |
| let tmp14 = code.newTmp(GP); |
| let tmp13 = code.newTmp(GP); |
| let tmp12 = code.newTmp(GP); |
| let tmp11 = code.newTmp(GP); |
| let tmp10 = code.newTmp(GP); |
| let tmp9 = code.newTmp(GP); |
| let tmp8 = code.newTmp(GP); |
| let tmp7 = code.newTmp(GP); |
| let tmp6 = code.newTmp(GP); |
| let tmp5 = code.newTmp(GP); |
| let tmp4 = code.newTmp(GP); |
| let tmp3 = code.newTmp(GP); |
| let tmp2 = code.newTmp(GP); |
| let tmp1 = code.newTmp(GP); |
| let tmp0 = code.newTmp(GP); |
| let ftmp7 = code.newTmp(FP); |
| let ftmp6 = code.newTmp(FP); |
| let ftmp5 = code.newTmp(FP); |
| let ftmp4 = code.newTmp(FP); |
| let ftmp3 = code.newTmp(FP); |
| let ftmp2 = code.newTmp(FP); |
| let ftmp1 = code.newTmp(FP); |
| let ftmp0 = code.newTmp(FP); |
| let inst; |
| let arg; |
| bb0.successors.push(new FrequentedBlock(bb2, Normal)); |
| bb0.successors.push(new FrequentedBlock(bb1, Normal)); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286904960, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbp, 16); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbp); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.extraEarlyClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.r11); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Scratch, type: GP, width: 64}); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbp, 40); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(2, -65536); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb0.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 5); |
| inst.args.push(arg); |
| arg = Arg.createImm(21); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 8}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 8}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb0.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createAddr(Reg.rbx, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286506544, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot10, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286455168, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot4, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287131344, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot6, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createImm(10); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot3, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286474592, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot2, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287209728, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot11, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot1, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(0, -65536); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287112728, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot8, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(0, 65536); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot9, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287112720, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot5, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286506192, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot7, 0); |
| inst.args.push(arg); |
| bb0.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(Equal); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createImm(862); |
| inst.args.push(arg); |
| bb0.append(inst); |
| bb1.successors.push(new FrequentedBlock(bb41, Normal)); |
| bb1.successors.push(new FrequentedBlock(bb3, Normal)); |
| bb1.predecessors.push(bb0); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createImm(881); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb1.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 224); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb1.append(inst); |
| inst = new Inst(BranchTest32); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb1.append(inst); |
| bb2.successors.push(new FrequentedBlock(bb41, Normal)); |
| bb2.successors.push(new FrequentedBlock(bb3, Normal)); |
| bb2.predecessors.push(bb0); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 224); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb2.append(inst); |
| inst = new Inst(BranchTest32); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb2.append(inst); |
| bb3.successors.push(new FrequentedBlock(bb5, Normal)); |
| bb3.successors.push(new FrequentedBlock(bb4, Normal)); |
| bb3.predecessors.push(bb1); |
| bb3.predecessors.push(bb40); |
| bb3.predecessors.push(bb39); |
| bb3.predecessors.push(bb2); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| bb3.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rsi, -1144); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb3.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(Equal); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| bb3.append(inst); |
| bb4.successors.push(new FrequentedBlock(bb6, Normal)); |
| bb4.successors.push(new FrequentedBlock(bb7, Normal)); |
| bb4.predecessors.push(bb3); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(Equal); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createImm(2); |
| inst.args.push(arg); |
| bb4.append(inst); |
| bb5.successors.push(new FrequentedBlock(bb6, Normal)); |
| bb5.predecessors.push(bb3); |
| inst = new Inst(Move); |
| arg = Arg.createImm(7); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 232); |
| inst.args.push(arg); |
| bb5.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 256); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb5.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 248); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb5.append(inst); |
| inst = new Inst(And32); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb5.append(inst); |
| inst = new Inst(And32); |
| arg = Arg.createImm(31); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb5.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb5.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 240); |
| inst.args.push(arg); |
| bb5.append(inst); |
| inst = new Inst(Jump); |
| bb5.append(inst); |
| bb6.successors.push(new FrequentedBlock(bb7, Normal)); |
| bb6.predecessors.push(bb4); |
| bb6.predecessors.push(bb5); |
| inst = new Inst(Add32); |
| arg = Arg.createImm(-1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb6.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb6.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rsi, -1144); |
| inst.args.push(arg); |
| bb6.append(inst); |
| inst = new Inst(Jump); |
| bb6.append(inst); |
| bb7.successors.push(new FrequentedBlock(bb8, Normal)); |
| bb7.successors.push(new FrequentedBlock(bb9, Normal)); |
| bb7.predecessors.push(bb4); |
| bb7.predecessors.push(bb6); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 240); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb7.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(GreaterThan); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createImm(0); |
| inst.args.push(arg); |
| bb7.append(inst); |
| bb8.successors.push(new FrequentedBlock(bb9, Normal)); |
| bb8.predecessors.push(bb7); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286455168, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb8.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286455168, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb8.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| bb8.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| bb8.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| bb8.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.extraEarlyClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.rcx); |
| inst.extraClobberedRegs.add(Reg.rdx); |
| inst.extraClobberedRegs.add(Reg.rsi); |
| inst.extraClobberedRegs.add(Reg.rdi); |
| inst.extraClobberedRegs.add(Reg.r8); |
| inst.extraClobberedRegs.add(Reg.r9); |
| inst.extraClobberedRegs.add(Reg.r10); |
| inst.extraClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.xmm0); |
| inst.extraClobberedRegs.add(Reg.xmm1); |
| inst.extraClobberedRegs.add(Reg.xmm2); |
| inst.extraClobberedRegs.add(Reg.xmm3); |
| inst.extraClobberedRegs.add(Reg.xmm4); |
| inst.extraClobberedRegs.add(Reg.xmm5); |
| inst.extraClobberedRegs.add(Reg.xmm6); |
| inst.extraClobberedRegs.add(Reg.xmm7); |
| inst.extraClobberedRegs.add(Reg.xmm8); |
| inst.extraClobberedRegs.add(Reg.xmm9); |
| inst.extraClobberedRegs.add(Reg.xmm10); |
| inst.extraClobberedRegs.add(Reg.xmm11); |
| inst.extraClobberedRegs.add(Reg.xmm12); |
| inst.extraClobberedRegs.add(Reg.xmm13); |
| inst.extraClobberedRegs.add(Reg.xmm14); |
| inst.extraClobberedRegs.add(Reg.xmm15); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Def, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| bb8.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb8.append(inst); |
| inst = new Inst(Jump); |
| bb8.append(inst); |
| bb9.successors.push(new FrequentedBlock(bb12, Normal)); |
| bb9.successors.push(new FrequentedBlock(bb10, Normal)); |
| bb9.predecessors.push(bb7); |
| bb9.predecessors.push(bb8); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 304); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 128); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.r8, 0); |
| inst.args.push(arg); |
| arg = Arg.createImm(80); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb9.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.r8, 8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(AboveOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rax, -8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb9.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createIndex(Reg.rax, Reg.rsi, 8, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createImm(10); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(MoveConditionallyTest64); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createImm(-1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb9.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rcx, 5); |
| inst.args.push(arg); |
| arg = Arg.createImm(23); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 8}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 8}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb9.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rcx, 24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb9.append(inst); |
| inst = new Inst(Branch64); |
| arg = Arg.createRelCond(Equal); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot7, 0); |
| inst.args.push(arg); |
| bb9.append(inst); |
| bb10.successors.push(new FrequentedBlock(bb11, Normal)); |
| bb10.successors.push(new FrequentedBlock(bb13, Normal)); |
| bb10.predecessors.push(bb9); |
| inst = new Inst(Branch64); |
| arg = Arg.createRelCond(Equal); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot10, 0); |
| inst.args.push(arg); |
| bb10.append(inst); |
| bb11.successors.push(new FrequentedBlock(bb14, Normal)); |
| bb11.predecessors.push(bb10); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot0, 0); |
| inst.args.push(arg); |
| bb11.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 344); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| bb11.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdi, 0); |
| inst.args.push(arg); |
| arg = Arg.createImm(502); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb11.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdi, 16); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb11.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(AboveOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdi, 24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb11.append(inst); |
| inst = new Inst(Load8); |
| arg = Arg.createIndex(Reg.rsi, Reg.rax, 1, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb11.append(inst); |
| inst = new Inst(Jump); |
| bb11.append(inst); |
| bb12.successors.push(new FrequentedBlock(bb14, Normal)); |
| bb12.predecessors.push(bb9); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createStack(slot0, 0); |
| inst.args.push(arg); |
| bb12.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 336); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| bb12.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 456); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| bb12.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 32}); |
| bb12.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdi, 0); |
| inst.args.push(arg); |
| arg = Arg.createImm(502); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb12.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdi, 16); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| bb12.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(AboveOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdi, 24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb12.append(inst); |
| inst = new Inst(Load8); |
| arg = Arg.createIndex(Reg.rsi, Reg.rax, 1, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb12.append(inst); |
| inst = new Inst(Jump); |
| bb12.append(inst); |
| bb13.predecessors.push(bb10); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb13.append(inst); |
| inst = new Inst(Oops); |
| bb13.append(inst); |
| bb14.successors.push(new FrequentedBlock(bb15, Normal)); |
| bb14.successors.push(new FrequentedBlock(bb16, Normal)); |
| bb14.predecessors.push(bb11); |
| bb14.predecessors.push(bb12); |
| inst = new Inst(Add32); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb14.append(inst); |
| inst = new Inst(ZeroExtend16To32); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb14.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb14.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 128); |
| inst.args.push(arg); |
| bb14.append(inst); |
| inst = new Inst(BranchTest32); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 216); |
| inst.args.push(arg); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| bb14.append(inst); |
| bb15.predecessors.push(bb14); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb15.append(inst); |
| inst = new Inst(Oops); |
| bb15.append(inst); |
| bb16.successors.push(new FrequentedBlock(bb18, Normal)); |
| bb16.successors.push(new FrequentedBlock(bb17, Normal)); |
| bb16.predecessors.push(bb14); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rax, -1752); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdx, 16); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(AboveOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdx, 24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Load8); |
| arg = Arg.createIndex(Reg.rax, Reg.rcx, 1, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 272); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287112720, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rax, 0); |
| inst.args.push(arg); |
| arg = Arg.createImm(80); |
| inst.args.push(arg); |
| arg = Arg.createBigImm(287112720, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287112728, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rax, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(AboveOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rax, -8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createIndex(Reg.rax, Reg.rcx, 8, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createImm(10); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(MoveConditionallyTest64); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createImm(-1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createImm(2); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287112720, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(32); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(32); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.extraEarlyClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.rcx); |
| inst.extraClobberedRegs.add(Reg.rdx); |
| inst.extraClobberedRegs.add(Reg.rsi); |
| inst.extraClobberedRegs.add(Reg.rdi); |
| inst.extraClobberedRegs.add(Reg.r8); |
| inst.extraClobberedRegs.add(Reg.r9); |
| inst.extraClobberedRegs.add(Reg.r10); |
| inst.extraClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.xmm0); |
| inst.extraClobberedRegs.add(Reg.xmm1); |
| inst.extraClobberedRegs.add(Reg.xmm2); |
| inst.extraClobberedRegs.add(Reg.xmm3); |
| inst.extraClobberedRegs.add(Reg.xmm4); |
| inst.extraClobberedRegs.add(Reg.xmm5); |
| inst.extraClobberedRegs.add(Reg.xmm6); |
| inst.extraClobberedRegs.add(Reg.xmm7); |
| inst.extraClobberedRegs.add(Reg.xmm8); |
| inst.extraClobberedRegs.add(Reg.xmm9); |
| inst.extraClobberedRegs.add(Reg.xmm10); |
| inst.extraClobberedRegs.add(Reg.xmm11); |
| inst.extraClobberedRegs.add(Reg.xmm12); |
| inst.extraClobberedRegs.add(Reg.xmm13); |
| inst.extraClobberedRegs.add(Reg.xmm14); |
| inst.extraClobberedRegs.add(Reg.xmm15); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Def, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdx, -1088); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 272); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 280); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Rshift32); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb16.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdx, -1088); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdx, -88); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdx, -1176); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rcx, 0); |
| inst.args.push(arg); |
| arg = Arg.createImm(80); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rcx, 8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(AboveOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rax, -8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb16.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createIndex(Reg.rax, Reg.rdx, 8, 0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createImm(10); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(MoveConditionallyTest64); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createImm(-1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rax, 5); |
| inst.args.push(arg); |
| arg = Arg.createImm(23); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 8}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 8}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createImm(2); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(32); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(32); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.extraEarlyClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.rcx); |
| inst.extraClobberedRegs.add(Reg.rdx); |
| inst.extraClobberedRegs.add(Reg.rsi); |
| inst.extraClobberedRegs.add(Reg.rdi); |
| inst.extraClobberedRegs.add(Reg.r8); |
| inst.extraClobberedRegs.add(Reg.r9); |
| inst.extraClobberedRegs.add(Reg.r10); |
| inst.extraClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.xmm0); |
| inst.extraClobberedRegs.add(Reg.xmm1); |
| inst.extraClobberedRegs.add(Reg.xmm2); |
| inst.extraClobberedRegs.add(Reg.xmm3); |
| inst.extraClobberedRegs.add(Reg.xmm4); |
| inst.extraClobberedRegs.add(Reg.xmm5); |
| inst.extraClobberedRegs.add(Reg.xmm6); |
| inst.extraClobberedRegs.add(Reg.xmm7); |
| inst.extraClobberedRegs.add(Reg.xmm8); |
| inst.extraClobberedRegs.add(Reg.xmm9); |
| inst.extraClobberedRegs.add(Reg.xmm10); |
| inst.extraClobberedRegs.add(Reg.xmm11); |
| inst.extraClobberedRegs.add(Reg.xmm12); |
| inst.extraClobberedRegs.add(Reg.xmm13); |
| inst.extraClobberedRegs.add(Reg.xmm14); |
| inst.extraClobberedRegs.add(Reg.xmm15); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Def, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 272); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 280); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Rshift32); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rsi); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rsi, -1048); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 32}); |
| bb16.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rsi, -1048); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rsi, -1072); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb16.append(inst); |
| inst = new Inst(Branch64); |
| arg = Arg.createRelCond(Below); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| bb16.append(inst); |
| bb17.successors.push(new FrequentedBlock(bb19, Normal)); |
| bb17.predecessors.push(bb16); |
| inst = new Inst(ConvertInt32ToDouble); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm0); |
| inst.args.push(arg); |
| bb17.append(inst); |
| inst = new Inst(Jump); |
| bb17.append(inst); |
| bb18.successors.push(new FrequentedBlock(bb19, Normal)); |
| bb18.predecessors.push(bb16); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb18.append(inst); |
| inst = new Inst(Move64ToDouble); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm0); |
| inst.args.push(arg); |
| bb18.append(inst); |
| inst = new Inst(Jump); |
| bb18.append(inst); |
| bb19.successors.push(new FrequentedBlock(bb20, Normal)); |
| bb19.successors.push(new FrequentedBlock(bb32, Normal)); |
| bb19.predecessors.push(bb17); |
| bb19.predecessors.push(bb18); |
| inst = new Inst(ConvertInt32ToDouble); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm1); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(AddDouble); |
| arg = Arg.createTmp(Reg.xmm0); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm1); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(MoveDoubleTo64); |
| arg = Arg.createTmp(Reg.xmm1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(0, 65536); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rsi, -1072); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rsi, -1080); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb19.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rsi, -1080); |
| inst.args.push(arg); |
| bb19.append(inst); |
| inst = new Inst(BranchTest32); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rsi, -1104); |
| inst.args.push(arg); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| bb19.append(inst); |
| bb20.successors.push(new FrequentedBlock(bb21, Normal)); |
| bb20.successors.push(new FrequentedBlock(bb32, Normal)); |
| bb20.predecessors.push(bb19); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rsi, -1096); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb20.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb20.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb20.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rsi, -1096); |
| inst.args.push(arg); |
| bb20.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rsi, -1112); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r11); |
| inst.args.push(arg); |
| bb20.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(GreaterThanOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r11); |
| inst.args.push(arg); |
| bb20.append(inst); |
| bb21.successors.push(new FrequentedBlock(bb23, Normal)); |
| bb21.predecessors.push(bb20); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 344); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r12); |
| inst.args.push(arg); |
| bb21.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.r12, 0); |
| inst.args.push(arg); |
| arg = Arg.createImm(502); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r12); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb21.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.r12, 16); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdi); |
| inst.args.push(arg); |
| bb21.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createAddr(Reg.r12, 24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r9); |
| inst.args.push(arg); |
| bb21.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(BelowOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r9); |
| inst.args.push(arg); |
| arg = Arg.createImm(65286); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb21.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 232); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r10); |
| inst.args.push(arg); |
| bb21.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 256); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| bb21.append(inst); |
| inst = new Inst(Jump); |
| bb21.append(inst); |
| bb22.successors.push(new FrequentedBlock(bb23, Normal)); |
| bb22.predecessors.push(bb30); |
| bb22.predecessors.push(bb31); |
| bb22.predecessors.push(bb29); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb22.append(inst); |
| inst = new Inst(Jump); |
| bb22.append(inst); |
| bb23.successors.push(new FrequentedBlock(bb25, Normal)); |
| bb23.successors.push(new FrequentedBlock(bb24, Normal)); |
| bb23.predecessors.push(bb21); |
| bb23.predecessors.push(bb22); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r11); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r11); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.UseZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 32}); |
| bb23.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb23.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb23.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rsi, -1096); |
| inst.args.push(arg); |
| bb23.append(inst); |
| inst = new Inst(Load8); |
| arg = Arg.createAddr(Reg.rdi, 65285); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb23.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| bb23.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r12); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.UseZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 32}); |
| bb23.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(BelowOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r9); |
| inst.args.push(arg); |
| arg = Arg.createImm(65285); |
| inst.args.push(arg); |
| bb23.append(inst); |
| bb24.successors.push(new FrequentedBlock(bb26, Normal)); |
| bb24.successors.push(new FrequentedBlock(bb30, Normal)); |
| bb24.predecessors.push(bb23); |
| inst = new Inst(Store8); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdi, 65285); |
| inst.args.push(arg); |
| bb24.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(Equal); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| arg = Arg.createImm(256); |
| inst.args.push(arg); |
| bb24.append(inst); |
| bb25.successors.push(new FrequentedBlock(bb26, Normal)); |
| bb25.successors.push(new FrequentedBlock(bb30, Normal)); |
| bb25.predecessors.push(bb23); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(Equal); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| arg = Arg.createImm(256); |
| inst.args.push(arg); |
| bb25.append(inst); |
| bb26.successors.push(new FrequentedBlock(bb28, Normal)); |
| bb26.successors.push(new FrequentedBlock(bb27, Normal)); |
| bb26.predecessors.push(bb24); |
| bb26.predecessors.push(bb25); |
| inst = new Inst(Load8); |
| arg = Arg.createAddr(Reg.rdi, 65286); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb26.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(BelowOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r9); |
| inst.args.push(arg); |
| arg = Arg.createImm(65285); |
| inst.args.push(arg); |
| bb26.append(inst); |
| bb27.successors.push(new FrequentedBlock(bb28, Normal)); |
| bb27.predecessors.push(bb26); |
| inst = new Inst(Store8); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdi, 65285); |
| inst.args.push(arg); |
| bb27.append(inst); |
| inst = new Inst(Jump); |
| bb27.append(inst); |
| bb28.successors.push(new FrequentedBlock(bb29, Normal)); |
| bb28.successors.push(new FrequentedBlock(bb31, Normal)); |
| bb28.predecessors.push(bb26); |
| bb28.predecessors.push(bb27); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 248); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb28.append(inst); |
| inst = new Inst(Or32); |
| arg = Arg.createImm(4); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb28.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| bb28.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| bb28.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 248); |
| inst.args.push(arg); |
| bb28.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| bb28.append(inst); |
| inst = new Inst(BranchTest64); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r10); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r13); |
| inst.args.push(arg); |
| bb28.append(inst); |
| bb29.successors.push(new FrequentedBlock(bb22, Normal)); |
| bb29.successors.push(new FrequentedBlock(bb32, Normal)); |
| bb29.predecessors.push(bb28); |
| inst = new Inst(And32); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb29.append(inst); |
| inst = new Inst(And32); |
| arg = Arg.createImm(31); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb29.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb29.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 240); |
| inst.args.push(arg); |
| bb29.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(GreaterThanOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r11); |
| inst.args.push(arg); |
| bb29.append(inst); |
| bb30.successors.push(new FrequentedBlock(bb22, Normal)); |
| bb30.successors.push(new FrequentedBlock(bb32, Normal)); |
| bb30.predecessors.push(bb24); |
| bb30.predecessors.push(bb25); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(GreaterThanOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r11); |
| inst.args.push(arg); |
| bb30.append(inst); |
| bb31.successors.push(new FrequentedBlock(bb22, Normal)); |
| bb31.successors.push(new FrequentedBlock(bb32, Normal)); |
| bb31.predecessors.push(bb28); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(GreaterThanOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r11); |
| inst.args.push(arg); |
| bb31.append(inst); |
| bb32.successors.push(new FrequentedBlock(bb33, Normal)); |
| bb32.successors.push(new FrequentedBlock(bb34, Normal)); |
| bb32.predecessors.push(bb19); |
| bb32.predecessors.push(bb20); |
| bb32.predecessors.push(bb30); |
| bb32.predecessors.push(bb31); |
| bb32.predecessors.push(bb29); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rsi, -1120); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb32.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(GreaterThan); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createImm(0); |
| inst.args.push(arg); |
| bb32.append(inst); |
| bb33.predecessors.push(bb32); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb33.append(inst); |
| inst = new Inst(Oops); |
| bb33.append(inst); |
| bb34.successors.push(new FrequentedBlock(bb36, Normal)); |
| bb34.successors.push(new FrequentedBlock(bb35, Normal)); |
| bb34.predecessors.push(bb32); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 136); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb34.append(inst); |
| inst = new Inst(Branch64); |
| arg = Arg.createRelCond(Below); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| bb34.append(inst); |
| bb35.successors.push(new FrequentedBlock(bb37, Normal)); |
| bb35.successors.push(new FrequentedBlock(bb38, Normal)); |
| bb35.predecessors.push(bb34); |
| inst = new Inst(ConvertInt32ToDouble); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm0); |
| inst.args.push(arg); |
| bb35.append(inst); |
| inst = new Inst(BranchDouble); |
| arg = Arg.createDoubleCond(DoubleGreaterThanOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm0); |
| inst.args.push(arg); |
| bb35.append(inst); |
| bb36.successors.push(new FrequentedBlock(bb37, Normal)); |
| bb36.successors.push(new FrequentedBlock(bb38, Normal)); |
| bb36.predecessors.push(bb34); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb36.append(inst); |
| inst = new Inst(Move64ToDouble); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm0); |
| inst.args.push(arg); |
| bb36.append(inst); |
| inst = new Inst(BranchDouble); |
| arg = Arg.createDoubleCond(DoubleGreaterThanOrEqual); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.xmm0); |
| inst.args.push(arg); |
| bb36.append(inst); |
| bb37.successors.push(new FrequentedBlock(bb38, Normal)); |
| bb37.predecessors.push(bb35); |
| bb37.predecessors.push(bb36); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286474592, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb37.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286474592, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb37.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| bb37.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| bb37.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| bb37.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.extraEarlyClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.rcx); |
| inst.extraClobberedRegs.add(Reg.rdx); |
| inst.extraClobberedRegs.add(Reg.rsi); |
| inst.extraClobberedRegs.add(Reg.rdi); |
| inst.extraClobberedRegs.add(Reg.r8); |
| inst.extraClobberedRegs.add(Reg.r9); |
| inst.extraClobberedRegs.add(Reg.r10); |
| inst.extraClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.xmm0); |
| inst.extraClobberedRegs.add(Reg.xmm1); |
| inst.extraClobberedRegs.add(Reg.xmm2); |
| inst.extraClobberedRegs.add(Reg.xmm3); |
| inst.extraClobberedRegs.add(Reg.xmm4); |
| inst.extraClobberedRegs.add(Reg.xmm5); |
| inst.extraClobberedRegs.add(Reg.xmm6); |
| inst.extraClobberedRegs.add(Reg.xmm7); |
| inst.extraClobberedRegs.add(Reg.xmm8); |
| inst.extraClobberedRegs.add(Reg.xmm9); |
| inst.extraClobberedRegs.add(Reg.xmm10); |
| inst.extraClobberedRegs.add(Reg.xmm11); |
| inst.extraClobberedRegs.add(Reg.xmm12); |
| inst.extraClobberedRegs.add(Reg.xmm13); |
| inst.extraClobberedRegs.add(Reg.xmm14); |
| inst.extraClobberedRegs.add(Reg.xmm15); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Def, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| bb37.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb37.append(inst); |
| inst = new Inst(Jump); |
| bb37.append(inst); |
| bb38.successors.push(new FrequentedBlock(bb39, Normal)); |
| bb38.successors.push(new FrequentedBlock(bb40, Normal)); |
| bb38.predecessors.push(bb35); |
| bb38.predecessors.push(bb37); |
| bb38.predecessors.push(bb36); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createRelCond(NotEqual); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 0); |
| inst.args.push(arg); |
| arg = Arg.createImm(881); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb38.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 8); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rdx); |
| inst.args.push(arg); |
| bb38.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdx, -1824); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb38.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb38.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createResCond(Overflow); |
| inst.args.push(arg); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.UseZDef, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.LateColdUse, type: GP, width: 32}); |
| bb38.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb38.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb38.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rdx, -1824); |
| inst.args.push(arg); |
| bb38.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rdx, -1832); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb38.append(inst); |
| inst = new Inst(Branch32); |
| arg = Arg.createRelCond(GreaterThan); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb38.append(inst); |
| bb39.successors.push(new FrequentedBlock(bb42, Normal)); |
| bb39.successors.push(new FrequentedBlock(bb3, Normal)); |
| bb39.predecessors.push(bb38); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286474592, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(286474592, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.extraEarlyClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.rcx); |
| inst.extraClobberedRegs.add(Reg.rdx); |
| inst.extraClobberedRegs.add(Reg.rsi); |
| inst.extraClobberedRegs.add(Reg.rdi); |
| inst.extraClobberedRegs.add(Reg.r8); |
| inst.extraClobberedRegs.add(Reg.r9); |
| inst.extraClobberedRegs.add(Reg.r10); |
| inst.extraClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.xmm0); |
| inst.extraClobberedRegs.add(Reg.xmm1); |
| inst.extraClobberedRegs.add(Reg.xmm2); |
| inst.extraClobberedRegs.add(Reg.xmm3); |
| inst.extraClobberedRegs.add(Reg.xmm4); |
| inst.extraClobberedRegs.add(Reg.xmm5); |
| inst.extraClobberedRegs.add(Reg.xmm6); |
| inst.extraClobberedRegs.add(Reg.xmm7); |
| inst.extraClobberedRegs.add(Reg.xmm8); |
| inst.extraClobberedRegs.add(Reg.xmm9); |
| inst.extraClobberedRegs.add(Reg.xmm10); |
| inst.extraClobberedRegs.add(Reg.xmm11); |
| inst.extraClobberedRegs.add(Reg.xmm12); |
| inst.extraClobberedRegs.add(Reg.xmm13); |
| inst.extraClobberedRegs.add(Reg.xmm14); |
| inst.extraClobberedRegs.add(Reg.xmm15); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Def, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| bb39.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 224); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Or32); |
| arg = Arg.createImm(2); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Add64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createAddr(Reg.rbx, 224); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287131344, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287131344, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move32); |
| arg = Arg.createImm(1); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createBigImm(287209728, 1); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createTmp(Reg.rcx); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(8); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(16); |
| inst.args.push(arg); |
| arg = Arg.createCallArg(24); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r15); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.r14); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.extraEarlyClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.rcx); |
| inst.extraClobberedRegs.add(Reg.rdx); |
| inst.extraClobberedRegs.add(Reg.rsi); |
| inst.extraClobberedRegs.add(Reg.rdi); |
| inst.extraClobberedRegs.add(Reg.r8); |
| inst.extraClobberedRegs.add(Reg.r9); |
| inst.extraClobberedRegs.add(Reg.r10); |
| inst.extraClobberedRegs.add(Reg.r11); |
| inst.extraClobberedRegs.add(Reg.xmm0); |
| inst.extraClobberedRegs.add(Reg.xmm1); |
| inst.extraClobberedRegs.add(Reg.xmm2); |
| inst.extraClobberedRegs.add(Reg.xmm3); |
| inst.extraClobberedRegs.add(Reg.xmm4); |
| inst.extraClobberedRegs.add(Reg.xmm5); |
| inst.extraClobberedRegs.add(Reg.xmm6); |
| inst.extraClobberedRegs.add(Reg.xmm7); |
| inst.extraClobberedRegs.add(Reg.xmm8); |
| inst.extraClobberedRegs.add(Reg.xmm9); |
| inst.extraClobberedRegs.add(Reg.xmm10); |
| inst.extraClobberedRegs.add(Reg.xmm11); |
| inst.extraClobberedRegs.add(Reg.xmm12); |
| inst.extraClobberedRegs.add(Reg.xmm13); |
| inst.extraClobberedRegs.add(Reg.xmm14); |
| inst.extraClobberedRegs.add(Reg.xmm15); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Def, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 32}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| bb39.append(inst); |
| inst = new Inst(Patch); |
| arg = Arg.createSpecial(); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rbx); |
| inst.args.push(arg); |
| inst.patchHasNonArgEffects = true; |
| inst.extraEarlyClobberedRegs = new Set(); |
| inst.extraClobberedRegs = new Set(); |
| inst.patchArgData = []; |
| inst.patchArgData.push({role: Arg.Use, type: GP, width: 64}); |
| inst.patchArgData.push({role: Arg.ColdUse, type: GP, width: 64}); |
| bb39.append(inst); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 224); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| inst = new Inst(BranchTest32); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb39.append(inst); |
| bb40.successors.push(new FrequentedBlock(bb42, Normal)); |
| bb40.successors.push(new FrequentedBlock(bb3, Normal)); |
| bb40.predecessors.push(bb38); |
| inst = new Inst(Move); |
| arg = Arg.createAddr(Reg.rbx, 224); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb40.append(inst); |
| inst = new Inst(BranchTest32); |
| arg = Arg.createResCond(NonZero); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb40.append(inst); |
| bb41.predecessors.push(bb1); |
| bb41.predecessors.push(bb2); |
| inst = new Inst(Move); |
| arg = Arg.createImm(10); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb41.append(inst); |
| inst = new Inst(Ret64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb41.append(inst); |
| bb42.predecessors.push(bb40); |
| bb42.predecessors.push(bb39); |
| inst = new Inst(Move); |
| arg = Arg.createImm(10); |
| inst.args.push(arg); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb42.append(inst); |
| inst = new Inst(Ret64); |
| arg = Arg.createTmp(Reg.rax); |
| inst.args.push(arg); |
| bb42.append(inst); |
| return code; |
| } |