soot.toDex.instructions.Insn22x Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of soot Show documentation
Show all versions of soot Show documentation
A Java Optimization Framework
package soot.toDex.instructions;
/*-
* #%L
* Soot - a J*va Optimization Framework
* %%
* Copyright (C) 1997 - 2018 Raja Vallée-Rai and others
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 2.1 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
import java.util.BitSet;
import org.jf.dexlib2.Opcode;
import org.jf.dexlib2.builder.BuilderInstruction;
import org.jf.dexlib2.builder.instruction.BuilderInstruction22x;
import soot.toDex.LabelAssigner;
import soot.toDex.Register;
/**
* The "22x" instruction format: It needs two 16-bit code units, has two registers and is used for general purposes (hence
* the "x").
*
* It is used by the opcodes "move/from16", "move-wide/from16" and "move-object/from16".
*/
public class Insn22x extends AbstractInsn implements TwoRegInsn {
public Insn22x(Opcode opc, Register regA, Register regB) {
super(opc);
regs.add(regA);
regs.add(regB);
}
public Register getRegA() {
return regs.get(REG_A_IDX);
}
public Register getRegB() {
return regs.get(REG_B_IDX);
}
protected BuilderInstruction getRealInsn0(LabelAssigner assigner) {
return new BuilderInstruction22x(opc, (short) getRegA().getNumber(), getRegB().getNumber());
}
@Override
public BitSet getIncompatibleRegs() {
BitSet incompatRegs = new BitSet(2);
if (!getRegA().fitsShort()) {
incompatRegs.set(REG_A_IDX);
}
if (!getRegB().fitsUnconstrained()) {
incompatRegs.set(REG_B_IDX);
}
return incompatRegs;
}
}