HPCToolkit
IA64ISA.hpp
Go to the documentation of this file.
1 // -*-Mode: C++;-*-
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 //***************************************************************************
48 //
49 // File:
50 // IA64ISA.h
51 //
52 // Purpose:
53 // [The purpose of this file]
54 //
55 // Description:
56 // [The set of functions, macros, etc. defined in the file]
57 //
58 //***************************************************************************
59 
60 #ifndef isa_IA64ISA_hpp
61 #define isa_IA64ISA_hpp
62 
63 //************************* System Include Files ****************************
64 
65 //*************************** User Include Files ****************************
66 
67 #include <include/gcc-attr.h>
68 #include <include/uint.h>
69 #include <include/gnu_bfd.h>
70 #include <include/gnu_dis-asm.h> // gnu binutils
71 
72 #include "ISA.hpp"
73 
74 //*************************** Forward Declarations ***************************
75 
76 //***************************************************************************
77 // IA64ISA
78 //***************************************************************************
79 
80 // 'IA64ISA': Implements the IA-64 Instruction Set Architecture.
81 
82 class IA64ISA : public ISA {
83 public:
84  IA64ISA();
85 
86  virtual ~IA64ISA();
87 
88  // --------------------------------------------------------
89  // Instructions:
90  // --------------------------------------------------------
91 
92  virtual ushort
94  { return 16; /* Each IA64 VLIW packet is 16 bytes long. */ }
95 
96  virtual ushort
98 
99  virtual InsnDesc
100  getInsnDesc(MachInsn* mi, ushort opIndex, ushort sz = 0);
101 
102  virtual VMA
103  getInsnTargetVMA(MachInsn* mi, VMA pc, ushort opIndex, ushort sz = 0);
104 
105  virtual ushort
107  ushort GCC_ATTR_UNUSED opIndex,
108  ushort GCC_ATTR_UNUSED sz = 0)
109  { return 0; }
110 
111  virtual bool
113  ushort GCC_ATTR_UNUSED opIndex1,
116  ushort GCC_ATTR_UNUSED opIndex2,
117  ushort GCC_ATTR_UNUSED sz2) const
118  { return false; /* FIXME */ }
119 
120  virtual VMA
121  convertVMAToOpVMA(VMA vma, ushort opIndex) const
122  {
123  // This is identical to the GNU scheme for now. Note that the
124  // offsets do not actually match the IA64 template [5,41,41,41].
125  //BriefAssertion(opIndex <= 2 && "Programming Error");
126  return (vma + 6 * opIndex); // 0, 6, 12
127  }
128 
129  virtual VMA
130  convertOpVMAToVMA(VMA opvma, ushort& opIndex) const
131  {
132  // See above comments
133  ushort offset = (opvma & 0xf); // 0, 6, 12
134  opIndex = (ushort)(offset / 6);
135  return (opvma - offset);
136  }
137 
138  virtual void
139  decode(std::ostream& os, MachInsn* mi, VMA vma, ushort opIndex);
140 
141 private:
142  // Should not be used
144  { }
145 
147  { return *this; }
148 
149 protected:
150 private:
151  struct disassemble_info* m_di;
152  struct disassemble_info* m_di_dis;
154 };
155 
156 //****************************************************************************
157 
158 #endif /* isa_IA64ISA_hpp */
struct disassemble_info * m_di
Definition: IA64ISA.hpp:151
virtual bool isParallelWithSuccessor(MachInsn *GCC_ATTR_UNUSED mi1, ushort GCC_ATTR_UNUSED opIndex1, ushort GCC_ATTR_UNUSED sz1, MachInsn *GCC_ATTR_UNUSED mi2, ushort GCC_ATTR_UNUSED opIndex2, ushort GCC_ATTR_UNUSED sz2) const
Definition: IA64ISA.hpp:112
bfd_vma VMA
Definition: ISATypes.hpp:79
virtual VMA getInsnTargetVMA(MachInsn *mi, VMA pc, ushort opIndex, ushort sz=0)
Definition: IA64ISA.cpp:202
virtual InsnDesc getInsnDesc(MachInsn *mi, ushort opIndex, ushort sz=0)
Definition: IA64ISA.cpp:143
virtual ushort getInsnNumOps(MachInsn *mi)
Definition: IA64ISA.cpp:225
virtual void decode(std::ostream &os, MachInsn *mi, VMA vma, ushort opIndex)
Definition: IA64ISA.cpp:238
IA64ISA(const IA64ISA &GCC_ATTR_UNUSED x)
Definition: IA64ISA.hpp:143
virtual VMA convertOpVMAToVMA(VMA opvma, ushort &opIndex) const
Definition: IA64ISA.hpp:130
unsigned short int ushort
Definition: uint.h:120
virtual ~IA64ISA()
Definition: IA64ISA.cpp:135
virtual ushort getInsnSize(MachInsn *GCC_ATTR_UNUSED mi)
Definition: IA64ISA.hpp:93
Definition: ISA.hpp:106
IA64ISA()
Definition: IA64ISA.cpp:114
void MachInsn
Definition: ISATypes.hpp:87
virtual VMA convertVMAToOpVMA(VMA vma, ushort opIndex) const
Definition: IA64ISA.hpp:121
IA64ISA & operator=(const IA64ISA &GCC_ATTR_UNUSED x)
Definition: IA64ISA.hpp:146
GNUbu_disdata m_dis_data
Definition: IA64ISA.hpp:153
#define GCC_ATTR_UNUSED
Definition: gcc-attr.h:80
struct disassemble_info * m_di_dis
Definition: IA64ISA.hpp:152
static MachInsn * mi
Definition: x86ISAXed.cpp:91
virtual ushort getInsnNumDelaySlots(MachInsn *GCC_ATTR_UNUSED mi, ushort GCC_ATTR_UNUSED opIndex, ushort GCC_ATTR_UNUSED sz=0)
Definition: IA64ISA.hpp:106