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 11n}. See the instruction format spec
30f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project * for details.
31f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project */
32f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Projectpublic final class Form11n 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 Form11n();
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 Form11n() {
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() + ", " + literalBitsString(value);
51f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
52f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
53f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
54f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
55f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public String insnCommentString(DalvInsn insn, boolean noteIndices) {
56f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        CstLiteralBits value = (CstLiteralBits) ((CstInsn) insn).getConstant();
57f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return literalBitsComment(value, 4);
58f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
59f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
60f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
61f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
62f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public int codeSize() {
63f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return 1;
64f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
65f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
66f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
67f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
68f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public boolean isCompatible(DalvInsn insn) {
69f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        RegisterSpecList regs = insn.getRegisters();
70f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
71f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (!((insn instanceof CstInsn) &&
72f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              (regs.size() == 1) &&
73f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              unsignedFitsInNibble(regs.get(0).getReg()))) {
74f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            return false;
75f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
76f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
77f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        CstInsn ci = (CstInsn) insn;
78f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        Constant cst = ci.getConstant();
79f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
80f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        if (!(cst instanceof CstLiteralBits)) {
81f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            return false;
82f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        }
83f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
84f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        CstLiteralBits cb = (CstLiteralBits) cst;
85f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
86f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        return cb.fitsInInt() && signedFitsInNibble(cb.getIntBits());
87f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
88f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
89f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    /** {@inheritDoc} */
90f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    @Override
91dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    public BitSet compatibleRegs(DalvInsn insn) {
92dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        RegisterSpecList regs = insn.getRegisters();
93dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        BitSet bits = new BitSet(1);
94dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao
95dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        bits.set(0, unsignedFitsInNibble(regs.get(0).getReg()));
96dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao        return bits;
97dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    }
98dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao
99dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    /** {@inheritDoc} */
100dd79e4e11fa20d6677b70ce6618a8653a1f3520djeffhao    @Override
101f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    public void writeTo(AnnotatedOutput out, DalvInsn insn) {
102f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        RegisterSpecList regs = insn.getRegisters();
103f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        int value =
104f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project            ((CstLiteralBits) ((CstInsn) insn).getConstant()).getIntBits();
105f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project
106f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project        write(out,
107f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project              opcodeUnit(insn, makeByte(regs.get(0).getReg(), value & 0xf)));
108f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project    }
109f6c387128427e121477c1b32ad35cdcaa5101ba3The Android Open Source Project}
110