stackwalker: added translation function for abstract
[dyninst.git] / instructionAPI / src / InstructionDecoderImpl.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 "InstructionDecoderImpl.h"
32 #include "common/src/singleton_object_pool.h"
33 #include "InstructionDecoder-x86.h"
34 #include "InstructionDecoder-power.h"
35 #include "BinaryFunction.h"
36 #include "Dereference.h"
37
38 using namespace std;
39 namespace Dyninst
40 {
41     namespace InstructionAPI
42     {
43         Instruction* InstructionDecoderImpl::makeInstruction(entryID opcode, const char* mnem,
44             unsigned int decodedSize, const unsigned char* raw)
45         {
46             Operation::Ptr tmp(make_shared(singleton_object_pool<Operation>::construct(opcode, mnem, m_Arch)));
47             return singleton_object_pool<Instruction>::construct(tmp, decodedSize, raw, m_Arch);
48         }
49
50
51         Instruction::Ptr InstructionDecoderImpl::decode(InstructionDecoder::buffer& b)
52         {
53             //setMode(m_Arch == Arch_x86_64);
54             const unsigned char* start = b.start;
55             decodeOpcode(b);
56             unsigned int decodedSize = b.start - start;
57
58             return make_shared(singleton_object_pool<Instruction>::construct(
59                                    m_Operation, decodedSize, start, m_Arch));
60         }
61
62         std::map<Architecture, InstructionDecoderImpl::Ptr> InstructionDecoderImpl::impls;
63         InstructionDecoderImpl::Ptr InstructionDecoderImpl::makeDecoderImpl(Architecture a)
64         {
65             if(impls.empty())
66             {
67                 impls[Arch_x86] = Ptr(new InstructionDecoder_x86(Arch_x86));
68                 impls[Arch_x86_64] = Ptr(new InstructionDecoder_x86(Arch_x86_64));
69                 impls[Arch_ppc32] = Ptr(new InstructionDecoder_power(Arch_ppc32));
70                 impls[Arch_ppc64] = Ptr(new InstructionDecoder_power(Arch_ppc64));
71 #if defined(aarch_aarch64)
72                 impls[Arch_aarch64] = Ptr(new InstructionDecoder_aarch64(Arch_aarch64));
73 #endif
74             }
75             std::map<Architecture, Ptr>::const_iterator foundImpl = impls.find(a);
76             if(foundImpl == impls.end())
77             {
78                 return Ptr();
79             }
80             return foundImpl->second;
81         }
82         Expression::Ptr InstructionDecoderImpl::makeAddExpression(Expression::Ptr lhs,
83                 Expression::Ptr rhs, Result_Type resultType)
84         {
85             BinaryFunction::funcT::Ptr adder(new BinaryFunction::addResult());
86
87             return make_shared(singleton_object_pool<BinaryFunction>::construct(lhs, rhs, resultType, adder));
88         }
89         Expression::Ptr InstructionDecoderImpl::makeMultiplyExpression(Expression::Ptr lhs, Expression::Ptr rhs,
90                 Result_Type resultType)
91         {
92             BinaryFunction::funcT::Ptr multiplier(new BinaryFunction::multResult());
93             return make_shared(singleton_object_pool<BinaryFunction>::construct(lhs, rhs, resultType, multiplier));
94         }
95         Expression::Ptr InstructionDecoderImpl::makeDereferenceExpression(Expression::Ptr addrToDereference,
96                 Result_Type resultType)
97         {
98             return make_shared(singleton_object_pool<Dereference>::construct(addrToDereference, resultType));
99         }
100         Expression::Ptr InstructionDecoderImpl::makeRegisterExpression(MachRegister registerID)
101         {
102             int newID = registerID.val();
103             int minusArch = newID & ~(registerID.getArchitecture());
104             int convertedID = minusArch | m_Arch;
105             MachRegister converted(convertedID);
106             return make_shared(singleton_object_pool<RegisterAST>::construct(converted, 0, registerID.size() * 8));
107         }
108     };
109 };
110