Update copyright
[dyninst.git] / instructionAPI / src / InstructionDecoderImpl.C
1 /*
2  * Copyright (c) 1996-2011 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as "Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * By your use of Paradyn, you understand and agree that we (or any
12  * other person or entity with proprietary rights in Paradyn) are
13  * under no obligation to provide either maintenance services,
14  * update services, notices of latent defects, or correction of
15  * defects for Paradyn.
16  * 
17  * This library is free software; you can redistribute it and/or
18  * modify it under the terms of the GNU Lesser General Public
19  * License as published by the Free Software Foundation; either
20  * version 2.1 of the License, or (at your option) any later version.
21  * 
22  * This library is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25  * Lesser General Public License for more details.
26  * 
27  * You should have received a copy of the GNU Lesser General Public
28  * License along with this library; if not, write to the Free Software
29  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
30  */
31
32 #include "InstructionDecoderImpl.h"
33 #include "common/h/singleton_object_pool.h"
34 #include "InstructionDecoder-x86.h"
35 #include "InstructionDecoder-power.h"
36 #include "BinaryFunction.h"
37 #include "Dereference.h"
38
39 using namespace std;
40 namespace Dyninst
41 {
42     namespace InstructionAPI
43     {
44         Instruction* InstructionDecoderImpl::makeInstruction(entryID opcode, const char* mnem,
45             unsigned int decodedSize, const unsigned char* raw)
46         {
47             Operation::Ptr tmp(make_shared(singleton_object_pool<Operation>::construct(opcode, mnem, m_Arch)));
48             return singleton_object_pool<Instruction>::construct(tmp, decodedSize, raw, m_Arch);
49         }
50     
51     
52         Instruction::Ptr InstructionDecoderImpl::decode(InstructionDecoder::buffer& b)
53         {
54             //setMode(m_Arch == Arch_x86_64);
55             const unsigned char* start = b.start;
56             decodeOpcode(b);
57             unsigned int decodedSize = b.start - start;
58
59             return make_shared(singleton_object_pool<Instruction>::construct(
60                                    m_Operation, decodedSize, start, m_Arch));
61         }
62
63         std::map<Architecture, InstructionDecoderImpl::Ptr> InstructionDecoderImpl::impls;
64         InstructionDecoderImpl::Ptr InstructionDecoderImpl::makeDecoderImpl(Architecture a)
65         {
66             if(impls.empty())
67             {
68                 impls[Arch_x86] = Ptr(new InstructionDecoder_x86(Arch_x86));
69                 impls[Arch_x86_64] = Ptr(new InstructionDecoder_x86(Arch_x86_64));
70                 impls[Arch_ppc32] = Ptr(new InstructionDecoder_power(Arch_ppc32));
71                 impls[Arch_ppc64] = Ptr(new InstructionDecoder_power(Arch_ppc64));
72             }
73             std::map<Architecture, Ptr>::const_iterator foundImpl = impls.find(a);
74             if(foundImpl == impls.end())
75             {
76                 return Ptr();
77             }
78             return foundImpl->second;
79         }
80         Expression::Ptr InstructionDecoderImpl::makeAddExpression(Expression::Ptr lhs,
81                 Expression::Ptr rhs, Result_Type resultType)
82         {
83             static BinaryFunction::funcT::Ptr adder(new BinaryFunction::addResult());
84
85             return make_shared(singleton_object_pool<BinaryFunction>::construct(lhs, rhs, resultType, adder));
86         }
87         Expression::Ptr InstructionDecoderImpl::makeMultiplyExpression(Expression::Ptr lhs, Expression::Ptr rhs,
88                 Result_Type resultType)
89         {
90             static BinaryFunction::funcT::Ptr multiplier(new BinaryFunction::multResult());
91             return make_shared(singleton_object_pool<BinaryFunction>::construct(lhs, rhs, resultType, multiplier));
92         }
93         Expression::Ptr InstructionDecoderImpl::makeDereferenceExpression(Expression::Ptr addrToDereference,
94                 Result_Type resultType)
95         {
96             return make_shared(singleton_object_pool<Dereference>::construct(addrToDereference, resultType));
97         }
98         Expression::Ptr InstructionDecoderImpl::makeRegisterExpression(MachRegister registerID)
99         {
100             int newID = registerID.val();
101             int minusArch = newID & ~(registerID.getArchitecture());
102             int convertedID = minusArch | m_Arch;
103             MachRegister converted(convertedID);
104             return make_shared(singleton_object_pool<RegisterAST>::construct(converted, 0, registerID.size() * 8));
105         }
106     };
107 };
108