stackwalker: added translation function for abstract
[dyninst.git] / instructionAPI / src / InstructionDecoder-aarch64.C
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 "InstructionDecoder-aarch64.h"
32 #include "Immediate.h"
33 #include <boost/assign/list_of.hpp>
34 #include "../../common/src/singleton_object_pool.h"
35
36 namespace Dyninst
37 {
38   namespace InstructionAPI
39   {
40     typedef void (InstructionDecoder_aarch64::*operandFactory)();
41     typedef std::vector< operandFactory > operandSpec;
42
43
44     InstructionDecoder_aarch64::InstructionDecoder_aarch64(Architecture a)
45       : InstructionDecoderImpl(a),
46         insn(0),
47         insn_in_progress(NULL),
48             isRAWritten(false),
49         invertBranchCondition(false),
50         isFPInsn(false),
51         bcIsConditional(false)
52     {
53     }
54
55     InstructionDecoder_aarch64::~InstructionDecoder_aarch64()
56     {
57     }
58
59     void InstructionDecoder_aarch64::decodeOpcode(InstructionDecoder::buffer& b)
60     {
61       b.start += 4;
62     }
63
64     void InstructionDecoder_aarch64::mainDecode()
65     {
66         assert(0);
67         return;
68     }
69   };
70 };
71
72
73
74