1f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project/*
2f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
3f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
4f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
5f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * you may not use this file except in compliance with the License.
6f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * You may obtain a copy of the License at
7f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
8f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
9f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project *
10f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
11f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
12f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * See the License for the specific language governing permissions and
14f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * limitations under the License.
15f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
16f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
17f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpackage com.android.dx.dex.code.form;
18f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
19f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.dex.code.CstInsn;
20f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.dex.code.DalvInsn;
21f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.dex.code.InsnFormat;
22f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.rop.code.RegisterSpecList;
23f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.rop.cst.Constant;
24f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.rop.cst.CstLiteralBits;
25f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectimport com.android.dx.util.AnnotatedOutput;
26dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhaoimport java.util.BitSet;
27dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao
28f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project/**
2999409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project * Instruction format {@code 22s}. See the instruction format spec
30f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * for details.
31f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
32f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpublic final class Form22s extends InsnFormat {
3399409883d9c4c0ffb49b070ce307bb33a9dfe9f1The Android Open Source Project    /** {@code non-null;} unique instance of this class */
34f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public static final InsnFormat THE_ONE = new Form22s();
35f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
36f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /**
37f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * Constructs an instance. This class is not publicly
38f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     * instantiable. Use {@link #THE_ONE}.
39f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project     */
40f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    private Form22s() {
41f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        // This space intentionally left blank.
42f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
43f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
44f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
45f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
46f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public String insnArgString(DalvInsn insn) {
47f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        RegisterSpecList regs = insn.getRegisters();
48f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        CstLiteralBits value = (CstLiteralBits) ((CstInsn) insn).getConstant();
49f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
50f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return regs.get(0).regString() + ", " + regs.get(1).regString()
51f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            + ", " + literalBitsString(value);
52f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
53f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
54f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
55f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
56f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public String insnCommentString(DalvInsn insn, boolean noteIndices) {
57f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        CstLiteralBits value = (CstLiteralBits) ((CstInsn) insn).getConstant();
58f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return literalBitsComment(value, 16);
59f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
60f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
61f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
62f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
63f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public int codeSize() {
64f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return 2;
65f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
66f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
67f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
68f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
69f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public boolean isCompatible(DalvInsn insn) {
70f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        RegisterSpecList regs = insn.getRegisters();
71f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (!((insn instanceof CstInsn) &&
72f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              (regs.size() == 2) &&
73f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              unsignedFitsInNibble(regs.get(0).getReg()) &&
74f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              unsignedFitsInNibble(regs.get(1).getReg()))) {
75f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            return false;
76f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
77f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
78f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        CstInsn ci = (CstInsn) insn;
79f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        Constant cst = ci.getConstant();
80f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
81f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (!(cst instanceof CstLiteralBits)) {
82f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            return false;
83f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
84f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
85f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        CstLiteralBits cb = (CstLiteralBits) cst;
86f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
87f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return cb.fitsInInt() && signedFitsInShort(cb.getIntBits());
88f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
89f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
90f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
91f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
92dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    public BitSet compatibleRegs(DalvInsn insn) {
93dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        RegisterSpecList regs = insn.getRegisters();
94dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        BitSet bits = new BitSet(2);
95dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao
96dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        bits.set(0, unsignedFitsInNibble(regs.get(0).getReg()));
97dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        bits.set(1, unsignedFitsInNibble(regs.get(1).getReg()));
98dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        return bits;
99dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    }
100dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao
101dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    /** {@inheritDoc} */
102dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    @Override
103f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public void writeTo(AnnotatedOutput out, DalvInsn insn) {
104f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        RegisterSpecList regs = insn.getRegisters();
105f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        int value =
106f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            ((CstLiteralBits) ((CstInsn) insn).getConstant()).getIntBits();
107f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
108f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        write(out,
109f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              opcodeUnit(insn,
110f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project                         makeByte(regs.get(0).getReg(), regs.get(1).getReg())),
111f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              (short) value);
112f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
113f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project}
114