Java Code Examples for com.android.dx.rop.code.RegOps#CONST
The following examples show how to use
com.android.dx.rop.code.RegOps#CONST .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source File: NormalSsaInsn.java From Box with Apache License 2.0 | 6 votes |
/** * {@inheritDoc} * * TODO: Increase the scope of this. */ @Override public boolean hasSideEffect() { Rop opcode = getOpcode(); if (opcode.getBranchingness() != Rop.BRANCH_NONE) { return true; } boolean hasLocalSideEffect = Optimizer.getPreserveLocals() && getLocalAssignment() != null; switch (opcode.getOpcode()) { case RegOps.MOVE_RESULT: case RegOps.MOVE: case RegOps.CONST: return hasLocalSideEffect; default: return true; } }
Example 2
Source File: NormalSsaInsn.java From Box with Apache License 2.0 | 6 votes |
/** * {@inheritDoc} * * TODO: Increase the scope of this. */ @Override public boolean hasSideEffect() { Rop opcode = getOpcode(); if (opcode.getBranchingness() != Rop.BRANCH_NONE) { return true; } boolean hasLocalSideEffect = Optimizer.getPreserveLocals() && getLocalAssignment() != null; switch (opcode.getOpcode()) { case RegOps.MOVE_RESULT: case RegOps.MOVE: case RegOps.CONST: return hasLocalSideEffect; default: return true; } }
Example 3
Source File: NormalSsaInsn.java From J2ME-Loader with Apache License 2.0 | 6 votes |
/** * {@inheritDoc} * * TODO: Increase the scope of this. */ @Override public boolean hasSideEffect() { Rop opcode = getOpcode(); if (opcode.getBranchingness() != Rop.BRANCH_NONE) { return true; } boolean hasLocalSideEffect = Optimizer.getPreserveLocals() && getLocalAssignment() != null; switch (opcode.getOpcode()) { case RegOps.MOVE_RESULT: case RegOps.MOVE: case RegOps.CONST: return hasLocalSideEffect; default: return true; } }
Example 4
Source File: NormalSsaInsn.java From buck with Apache License 2.0 | 6 votes |
/** * {@inheritDoc} * * TODO: Increase the scope of this. */ @Override public boolean hasSideEffect() { Rop opcode = getOpcode(); if (opcode.getBranchingness() != Rop.BRANCH_NONE) { return true; } boolean hasLocalSideEffect = Optimizer.getPreserveLocals() && getLocalAssignment() != null; switch (opcode.getOpcode()) { case RegOps.MOVE_RESULT: case RegOps.MOVE: case RegOps.CONST: return hasLocalSideEffect; default: return true; } }
Example 5
Source File: LiteralOpUpgrader.java From Box with Apache License 2.0 | 5 votes |
/** * Tries to replace an instruction with a const instruction. The given * instruction must have a constant result for it to be replaced. * * @param insn {@code non-null;} instruction to try to replace * @return true if the instruction was replaced */ private boolean tryReplacingWithConstant(NormalSsaInsn insn) { Insn originalRopInsn = insn.getOriginalRopInsn(); Rop opcode = originalRopInsn.getOpcode(); RegisterSpec result = insn.getResult(); if (result != null && !ssaMeth.isRegALocal(result) && opcode.getOpcode() != RegOps.CONST) { TypeBearer type = insn.getResult().getTypeBearer(); if (type.isConstant() && type.getBasicType() == Type.BT_INT) { // Replace the instruction with a constant replacePlainInsn(insn, RegisterSpecList.EMPTY, RegOps.CONST, (Constant) type); // Remove the source as well if this is a move-result-pseudo if (opcode.getOpcode() == RegOps.MOVE_RESULT_PSEUDO) { int pred = insn.getBlock().getPredecessors().nextSetBit(0); ArrayList<SsaInsn> predInsns = ssaMeth.getBlocks().get(pred).getInsns(); NormalSsaInsn sourceInsn = (NormalSsaInsn) predInsns.get(predInsns.size()-1); replacePlainInsn(sourceInsn, RegisterSpecList.EMPTY, RegOps.GOTO, null); } return true; } } return false; }
Example 6
Source File: LiteralOpUpgrader.java From Box with Apache License 2.0 | 5 votes |
/** * Tries to replace an instruction with a const instruction. The given * instruction must have a constant result for it to be replaced. * * @param insn {@code non-null;} instruction to try to replace * @return true if the instruction was replaced */ private boolean tryReplacingWithConstant(NormalSsaInsn insn) { Insn originalRopInsn = insn.getOriginalRopInsn(); Rop opcode = originalRopInsn.getOpcode(); RegisterSpec result = insn.getResult(); if (result != null && !ssaMeth.isRegALocal(result) && opcode.getOpcode() != RegOps.CONST) { TypeBearer type = insn.getResult().getTypeBearer(); if (type.isConstant() && type.getBasicType() == Type.BT_INT) { // Replace the instruction with a constant replacePlainInsn(insn, RegisterSpecList.EMPTY, RegOps.CONST, (Constant) type); // Remove the source as well if this is a move-result-pseudo if (opcode.getOpcode() == RegOps.MOVE_RESULT_PSEUDO) { int pred = insn.getBlock().getPredecessors().nextSetBit(0); ArrayList<SsaInsn> predInsns = ssaMeth.getBlocks().get(pred).getInsns(); NormalSsaInsn sourceInsn = (NormalSsaInsn) predInsns.get(predInsns.size()-1); replacePlainInsn(sourceInsn, RegisterSpecList.EMPTY, RegOps.GOTO, null); } return true; } } return false; }
Example 7
Source File: LiteralOpUpgrader.java From J2ME-Loader with Apache License 2.0 | 5 votes |
/** * Tries to replace an instruction with a const instruction. The given * instruction must have a constant result for it to be replaced. * * @param insn {@code non-null;} instruction to try to replace * @return true if the instruction was replaced */ private boolean tryReplacingWithConstant(NormalSsaInsn insn) { Insn originalRopInsn = insn.getOriginalRopInsn(); Rop opcode = originalRopInsn.getOpcode(); RegisterSpec result = insn.getResult(); if (result != null && !ssaMeth.isRegALocal(result) && opcode.getOpcode() != RegOps.CONST) { TypeBearer type = insn.getResult().getTypeBearer(); if (type.isConstant() && type.getBasicType() == Type.BT_INT) { // Replace the instruction with a constant replacePlainInsn(insn, RegisterSpecList.EMPTY, RegOps.CONST, (Constant) type); // Remove the source as well if this is a move-result-pseudo if (opcode.getOpcode() == RegOps.MOVE_RESULT_PSEUDO) { int pred = insn.getBlock().getPredecessors().nextSetBit(0); ArrayList<SsaInsn> predInsns = ssaMeth.getBlocks().get(pred).getInsns(); NormalSsaInsn sourceInsn = (NormalSsaInsn) predInsns.get(predInsns.size()-1); replacePlainInsn(sourceInsn, RegisterSpecList.EMPTY, RegOps.GOTO, null); } return true; } } return false; }
Example 8
Source File: LiteralOpUpgrader.java From buck with Apache License 2.0 | 5 votes |
/** * Tries to replace an instruction with a const instruction. The given * instruction must have a constant result for it to be replaced. * * @param insn {@code non-null;} instruction to try to replace * @return true if the instruction was replaced */ private boolean tryReplacingWithConstant(NormalSsaInsn insn) { Insn originalRopInsn = insn.getOriginalRopInsn(); Rop opcode = originalRopInsn.getOpcode(); RegisterSpec result = insn.getResult(); if (result != null && !ssaMeth.isRegALocal(result) && opcode.getOpcode() != RegOps.CONST) { TypeBearer type = insn.getResult().getTypeBearer(); if (type.isConstant() && type.getBasicType() == Type.BT_INT) { // Replace the instruction with a constant replacePlainInsn(insn, RegisterSpecList.EMPTY, RegOps.CONST, (Constant) type); // Remove the source as well if this is a move-result-pseudo if (opcode.getOpcode() == RegOps.MOVE_RESULT_PSEUDO) { int pred = insn.getBlock().getPredecessors().nextSetBit(0); ArrayList<SsaInsn> predInsns = ssaMeth.getBlocks().get(pred).getInsns(); NormalSsaInsn sourceInsn = (NormalSsaInsn) predInsns.get(predInsns.size()-1); replacePlainInsn(sourceInsn, RegisterSpecList.EMPTY, RegOps.GOTO, null); } return true; } } return false; }
Example 9
Source File: SCCP.java From Box with Apache License 2.0 | 4 votes |
/** * Simulates a statement and set the result lattice value. * @param insn instruction to simulate */ private void simulateStmt(SsaInsn insn) { Insn ropInsn = insn.getOriginalRopInsn(); if (ropInsn.getOpcode().getBranchingness() != Rop.BRANCH_NONE || ropInsn.getOpcode().isCallLike()) { simulateBranch(insn); } int opcode = insn.getOpcode().getOpcode(); RegisterSpec result = insn.getResult(); if (result == null) { // Find move-result-pseudo result for int div and int rem if (opcode == RegOps.DIV || opcode == RegOps.REM) { SsaBasicBlock succ = insn.getBlock().getPrimarySuccessor(); result = succ.getInsns().get(0).getResult(); } else { return; } } int resultReg = result.getReg(); int resultValue = VARYING; Constant resultConstant = null; switch (opcode) { case RegOps.CONST: { CstInsn cstInsn = (CstInsn)ropInsn; resultValue = CONSTANT; resultConstant = cstInsn.getConstant(); break; } case RegOps.MOVE: { if (insn.getSources().size() == 1) { int sourceReg = insn.getSources().get(0).getReg(); resultValue = latticeValues[sourceReg]; resultConstant = latticeConstants[sourceReg]; } break; } case RegOps.ADD: case RegOps.SUB: case RegOps.MUL: case RegOps.DIV: case RegOps.AND: case RegOps.OR: case RegOps.XOR: case RegOps.SHL: case RegOps.SHR: case RegOps.USHR: case RegOps.REM: { resultConstant = simulateMath(insn, result.getBasicType()); if (resultConstant != null) { resultValue = CONSTANT; } break; } case RegOps.MOVE_RESULT_PSEUDO: { if (latticeValues[resultReg] == CONSTANT) { resultValue = latticeValues[resultReg]; resultConstant = latticeConstants[resultReg]; } break; } // TODO: Handle non-int arithmetic. // TODO: Eliminate check casts that we can prove the type of. default: {} } if (setLatticeValueTo(resultReg, resultValue, resultConstant)) { addUsersToWorklist(resultReg, resultValue); } }
Example 10
Source File: EscapeAnalysis.java From Box with Apache License 2.0 | 4 votes |
/** * Determine the origin of a move result pseudo instruction that generates * an object. Creates a new EscapeSet for the new object accordingly. * * @param insn {@code non-null;} move result pseudo instruction to process * @return {@code non-null;} an EscapeSet for the object referred to by the * move result pseudo instruction */ private EscapeSet processMoveResultPseudoInsn(SsaInsn insn) { RegisterSpec result = insn.getResult(); SsaInsn prevSsaInsn = getInsnForMove(insn); int prevOpcode = prevSsaInsn.getOpcode().getOpcode(); EscapeSet escSet; RegisterSpec prevSource; switch(prevOpcode) { // New instance / Constant case RegOps.NEW_INSTANCE: case RegOps.CONST: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); break; // New array case RegOps.NEW_ARRAY: case RegOps.FILLED_NEW_ARRAY: prevSource = prevSsaInsn.getSources().get(0); if (prevSource.getTypeBearer().isConstant()) { // New fixed array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); escSet.replaceableArray = true; } else { // New variable array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; // Loading a static object case RegOps.GET_STATIC: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); break; // Type cast / load an object from a field or array case RegOps.CHECK_CAST: case RegOps.GET_FIELD: case RegOps.AGET: prevSource = prevSsaInsn.getSources().get(0); int setIndex = findSetIndex(prevSource); // Set should already exist, try to find it if (setIndex != latticeValues.size()) { escSet = latticeValues.get(setIndex); escSet.regSet.set(result.getReg()); return escSet; } // Set not found, must be either null or unknown if (prevSource.getType() == Type.KNOWN_NULL) { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); } else { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; default: return null; } // Add the newly created escSet to the lattice and return it latticeValues.add(escSet); return escSet; }
Example 11
Source File: SCCP.java From Box with Apache License 2.0 | 4 votes |
/** * Simulates a statement and set the result lattice value. * @param insn instruction to simulate */ private void simulateStmt(SsaInsn insn) { Insn ropInsn = insn.getOriginalRopInsn(); if (ropInsn.getOpcode().getBranchingness() != Rop.BRANCH_NONE || ropInsn.getOpcode().isCallLike()) { simulateBranch(insn); } int opcode = insn.getOpcode().getOpcode(); RegisterSpec result = insn.getResult(); if (result == null) { // Find move-result-pseudo result for int div and int rem if (opcode == RegOps.DIV || opcode == RegOps.REM) { SsaBasicBlock succ = insn.getBlock().getPrimarySuccessor(); result = succ.getInsns().get(0).getResult(); } else { return; } } int resultReg = result.getReg(); int resultValue = VARYING; Constant resultConstant = null; switch (opcode) { case RegOps.CONST: { CstInsn cstInsn = (CstInsn)ropInsn; resultValue = CONSTANT; resultConstant = cstInsn.getConstant(); break; } case RegOps.MOVE: { if (insn.getSources().size() == 1) { int sourceReg = insn.getSources().get(0).getReg(); resultValue = latticeValues[sourceReg]; resultConstant = latticeConstants[sourceReg]; } break; } case RegOps.ADD: case RegOps.SUB: case RegOps.MUL: case RegOps.DIV: case RegOps.AND: case RegOps.OR: case RegOps.XOR: case RegOps.SHL: case RegOps.SHR: case RegOps.USHR: case RegOps.REM: { resultConstant = simulateMath(insn, result.getBasicType()); if (resultConstant != null) { resultValue = CONSTANT; } break; } case RegOps.MOVE_RESULT_PSEUDO: { if (latticeValues[resultReg] == CONSTANT) { resultValue = latticeValues[resultReg]; resultConstant = latticeConstants[resultReg]; } break; } // TODO: Handle non-int arithmetic. // TODO: Eliminate check casts that we can prove the type of. default: {} } if (setLatticeValueTo(resultReg, resultValue, resultConstant)) { addUsersToWorklist(resultReg, resultValue); } }
Example 12
Source File: EscapeAnalysis.java From Box with Apache License 2.0 | 4 votes |
/** * Determine the origin of a move result pseudo instruction that generates * an object. Creates a new EscapeSet for the new object accordingly. * * @param insn {@code non-null;} move result pseudo instruction to process * @return {@code non-null;} an EscapeSet for the object referred to by the * move result pseudo instruction */ private EscapeSet processMoveResultPseudoInsn(SsaInsn insn) { RegisterSpec result = insn.getResult(); SsaInsn prevSsaInsn = getInsnForMove(insn); int prevOpcode = prevSsaInsn.getOpcode().getOpcode(); EscapeSet escSet; RegisterSpec prevSource; switch(prevOpcode) { // New instance / Constant case RegOps.NEW_INSTANCE: case RegOps.CONST: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); break; // New array case RegOps.NEW_ARRAY: case RegOps.FILLED_NEW_ARRAY: prevSource = prevSsaInsn.getSources().get(0); if (prevSource.getTypeBearer().isConstant()) { // New fixed array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); escSet.replaceableArray = true; } else { // New variable array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; // Loading a static object case RegOps.GET_STATIC: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); break; // Type cast / load an object from a field or array case RegOps.CHECK_CAST: case RegOps.GET_FIELD: case RegOps.AGET: prevSource = prevSsaInsn.getSources().get(0); int setIndex = findSetIndex(prevSource); // Set should already exist, try to find it if (setIndex != latticeValues.size()) { escSet = latticeValues.get(setIndex); escSet.regSet.set(result.getReg()); return escSet; } // Set not found, must be either null or unknown if (prevSource.getType() == Type.KNOWN_NULL) { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); } else { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; default: return null; } // Add the newly created escSet to the lattice and return it latticeValues.add(escSet); return escSet; }
Example 13
Source File: SCCP.java From J2ME-Loader with Apache License 2.0 | 4 votes |
/** * Simulates a statement and set the result lattice value. * @param insn instruction to simulate */ private void simulateStmt(SsaInsn insn) { Insn ropInsn = insn.getOriginalRopInsn(); if (ropInsn.getOpcode().getBranchingness() != Rop.BRANCH_NONE || ropInsn.getOpcode().isCallLike()) { simulateBranch(insn); } int opcode = insn.getOpcode().getOpcode(); RegisterSpec result = insn.getResult(); if (result == null) { // Find move-result-pseudo result for int div and int rem if (opcode == RegOps.DIV || opcode == RegOps.REM) { SsaBasicBlock succ = insn.getBlock().getPrimarySuccessor(); result = succ.getInsns().get(0).getResult(); } else { return; } } int resultReg = result.getReg(); int resultValue = VARYING; Constant resultConstant = null; switch (opcode) { case RegOps.CONST: { CstInsn cstInsn = (CstInsn)ropInsn; resultValue = CONSTANT; resultConstant = cstInsn.getConstant(); break; } case RegOps.MOVE: { if (insn.getSources().size() == 1) { int sourceReg = insn.getSources().get(0).getReg(); resultValue = latticeValues[sourceReg]; resultConstant = latticeConstants[sourceReg]; } break; } case RegOps.ADD: case RegOps.SUB: case RegOps.MUL: case RegOps.DIV: case RegOps.AND: case RegOps.OR: case RegOps.XOR: case RegOps.SHL: case RegOps.SHR: case RegOps.USHR: case RegOps.REM: { resultConstant = simulateMath(insn, result.getBasicType()); if (resultConstant != null) { resultValue = CONSTANT; } break; } case RegOps.MOVE_RESULT_PSEUDO: { if (latticeValues[resultReg] == CONSTANT) { resultValue = latticeValues[resultReg]; resultConstant = latticeConstants[resultReg]; } break; } // TODO: Handle non-int arithmetic. // TODO: Eliminate check casts that we can prove the type of. default: {} } if (setLatticeValueTo(resultReg, resultValue, resultConstant)) { addUsersToWorklist(resultReg, resultValue); } }
Example 14
Source File: EscapeAnalysis.java From J2ME-Loader with Apache License 2.0 | 4 votes |
/** * Determine the origin of a move result pseudo instruction that generates * an object. Creates a new EscapeSet for the new object accordingly. * * @param insn {@code non-null;} move result pseudo instruction to process * @return {@code non-null;} an EscapeSet for the object referred to by the * move result pseudo instruction */ private EscapeSet processMoveResultPseudoInsn(SsaInsn insn) { RegisterSpec result = insn.getResult(); SsaInsn prevSsaInsn = getInsnForMove(insn); int prevOpcode = prevSsaInsn.getOpcode().getOpcode(); EscapeSet escSet; RegisterSpec prevSource; switch(prevOpcode) { // New instance / Constant case RegOps.NEW_INSTANCE: case RegOps.CONST: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); break; // New array case RegOps.NEW_ARRAY: case RegOps.FILLED_NEW_ARRAY: prevSource = prevSsaInsn.getSources().get(0); if (prevSource.getTypeBearer().isConstant()) { // New fixed array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); escSet.replaceableArray = true; } else { // New variable array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; // Loading a static object case RegOps.GET_STATIC: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); break; // Type cast / load an object from a field or array case RegOps.CHECK_CAST: case RegOps.GET_FIELD: case RegOps.AGET: prevSource = prevSsaInsn.getSources().get(0); int setIndex = findSetIndex(prevSource); // Set should already exist, try to find it if (setIndex != latticeValues.size()) { escSet = latticeValues.get(setIndex); escSet.regSet.set(result.getReg()); return escSet; } // Set not found, must be either null or unknown if (prevSource.getType() == Type.KNOWN_NULL) { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); } else { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; default: return null; } // Add the newly created escSet to the lattice and return it latticeValues.add(escSet); return escSet; }
Example 15
Source File: SCCP.java From buck with Apache License 2.0 | 4 votes |
/** * Simulates a statement and set the result lattice value. * @param insn instruction to simulate */ private void simulateStmt(SsaInsn insn) { Insn ropInsn = insn.getOriginalRopInsn(); if (ropInsn.getOpcode().getBranchingness() != Rop.BRANCH_NONE || ropInsn.getOpcode().isCallLike()) { simulateBranch(insn); } int opcode = insn.getOpcode().getOpcode(); RegisterSpec result = insn.getResult(); if (result == null) { // Find move-result-pseudo result for int div and int rem if (opcode == RegOps.DIV || opcode == RegOps.REM) { SsaBasicBlock succ = insn.getBlock().getPrimarySuccessor(); result = succ.getInsns().get(0).getResult(); } else { return; } } int resultReg = result.getReg(); int resultValue = VARYING; Constant resultConstant = null; switch (opcode) { case RegOps.CONST: { CstInsn cstInsn = (CstInsn)ropInsn; resultValue = CONSTANT; resultConstant = cstInsn.getConstant(); break; } case RegOps.MOVE: { if (insn.getSources().size() == 1) { int sourceReg = insn.getSources().get(0).getReg(); resultValue = latticeValues[sourceReg]; resultConstant = latticeConstants[sourceReg]; } break; } case RegOps.ADD: case RegOps.SUB: case RegOps.MUL: case RegOps.DIV: case RegOps.AND: case RegOps.OR: case RegOps.XOR: case RegOps.SHL: case RegOps.SHR: case RegOps.USHR: case RegOps.REM: { resultConstant = simulateMath(insn, result.getBasicType()); if (resultConstant != null) { resultValue = CONSTANT; } break; } case RegOps.MOVE_RESULT_PSEUDO: { if (latticeValues[resultReg] == CONSTANT) { resultValue = latticeValues[resultReg]; resultConstant = latticeConstants[resultReg]; } break; } // TODO: Handle non-int arithmetic. // TODO: Eliminate check casts that we can prove the type of. default: {} } if (setLatticeValueTo(resultReg, resultValue, resultConstant)) { addUsersToWorklist(resultReg, resultValue); } }
Example 16
Source File: EscapeAnalysis.java From buck with Apache License 2.0 | 4 votes |
/** * Determine the origin of a move result pseudo instruction that generates * an object. Creates a new EscapeSet for the new object accordingly. * * @param insn {@code non-null;} move result pseudo instruction to process * @return {@code non-null;} an EscapeSet for the object referred to by the * move result pseudo instruction */ private EscapeSet processMoveResultPseudoInsn(SsaInsn insn) { RegisterSpec result = insn.getResult(); SsaInsn prevSsaInsn = getInsnForMove(insn); int prevOpcode = prevSsaInsn.getOpcode().getOpcode(); EscapeSet escSet; RegisterSpec prevSource; switch(prevOpcode) { // New instance / Constant case RegOps.NEW_INSTANCE: case RegOps.CONST: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); break; // New array case RegOps.NEW_ARRAY: case RegOps.FILLED_NEW_ARRAY: prevSource = prevSsaInsn.getSources().get(0); if (prevSource.getTypeBearer().isConstant()) { // New fixed array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); escSet.replaceableArray = true; } else { // New variable array escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; // Loading a static object case RegOps.GET_STATIC: escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); break; // Type cast / load an object from a field or array case RegOps.CHECK_CAST: case RegOps.GET_FIELD: case RegOps.AGET: prevSource = prevSsaInsn.getSources().get(0); int setIndex = findSetIndex(prevSource); // Set should already exist, try to find it if (setIndex != latticeValues.size()) { escSet = latticeValues.get(setIndex); escSet.regSet.set(result.getReg()); return escSet; } // Set not found, must be either null or unknown if (prevSource.getType() == Type.KNOWN_NULL) { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.NONE); } else { escSet = new EscapeSet(result.getReg(), regCount, EscapeState.GLOBAL); } break; default: return null; } // Add the newly created escSet to the lattice and return it latticeValues.add(escSet); return escSet; }