stackwalker: added translation function for abstract
[dyninst.git] / instructionAPI / src / InstructionDecoder-aarch64.h
1 /*
2  * See the dyninst/COPYRIGHT file for copyright information.
3  *
4  * We provide the Paradyn Tools (below described as "Paradyn")
5  * on an AS IS basis, and do not warrant its validity or performance.
6  * We reserve the right to update, modify, or discontinue this
7  * software at any time.  We shall have no obligation to supply such
8  * updates or modifications or any other form of support to you.
9  *
10  * By your use of Paradyn, you understand and agree that we (or any
11  * other person or entity with proprietary rights in Paradyn) are
12  * under no obligation to provide either maintenance services,
13  * update services, notices of latent defects, or correction of
14  * defects for Paradyn.
15  *
16  * This library is free software; you can redistribute it and/or
17  * modify it under the terms of the GNU Lesser General Public
18  * License as published by the Free Software Foundation; either
19  * version 2.1 of the License, or (at your option) any later version.
20  *
21  * This library is distributed in the hope that it will be useful,
22  * but WITHOUT ANY WARRANTY; without even the implied warranty of
23  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
24  * Lesser General Public License for more details.
25  *
26  * You should have received a copy of the GNU Lesser General Public
27  * License along with this library; if not, write to the Free Software
28  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
29  */
30
31 #include "InstructionDecoderImpl.h"
32 #include <iostream>
33 #include "Immediate.h"
34 #include "dyn_regs.h"
35
36 namespace Dyninst {
37     namespace InstructionAPI
38     {
39
40         class InstructionDecoder_aarch64 : public InstructionDecoderImpl
41         {
42             public:
43                 InstructionDecoder_aarch64(Architecture a);
44                 virtual ~InstructionDecoder_aarch64();
45                 virtual void decodeOpcode(InstructionDecoder::buffer& b);
46                 virtual Instruction::Ptr decode(InstructionDecoder::buffer& b);
47                         virtual void setMode(bool);
48
49                 virtual bool decodeOperands(const Instruction* insn_to_complete);
50                 virtual void doDelayedDecode(const Instruction* insn_to_complete);
51
52                 using InstructionDecoderImpl::makeRegisterExpression;
53             private:
54                 virtual Result_Type makeSizeType(unsigned int opType);
55
56                 template <int start, int end>
57                 int field(unsigned int raw) ;
58
59                 template <int size>
60                 int sign_extend(int in)
61                 {
62                     assert(0);
63                     return (in << (32 - size)) >> (32 - size);
64                 }
65
66                 void mainDecode();
67
68                 template< int lowBit, int highBit>
69                 Expression::Ptr makeBranchTarget();
70
71                 Expression::Ptr makeFallThroughExpr();
72
73                 unsigned int insn;
74                 Instruction* insn_in_progress;
75                 bool isRAWritten;
76                 bool invertBranchCondition;
77                 bool isFPInsn;
78                 bool bcIsConditional;
79         };
80     }
81 }