HPCToolkit
instruction-set.h
Go to the documentation of this file.
1 // -*-Mode: C++;-*- // technically C99
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 #ifndef isa_lean_x86_instruction_set_h
48 #define isa_lean_x86_instruction_set_h
49 
50 //************************* System Include Files ****************************
51 
52 #include <stdbool.h>
53 
54 //************************** XED Include Files ******************************
55 
56 #ifdef __cplusplus
57 extern "C" {
58 #endif
59 
60 # include <xed-interface.h>
61 
62 #ifdef __cplusplus
63 };
64 #endif
65 
66 //*************************** User Include Files ****************************
67 
68 #include <include/hpctoolkit-config.h>
69 
70 //*************************** Forward Declarations **************************
71 
72 //***************************************************************************
73 // Laks: macro for detecting registers
74 //
75 #if defined (HOST_CPU_x86_64)
76 #define X86_ISREG(REG) \
77 static inline bool \
78 x86_isReg_ ## REG (xed_reg_enum_t reg) \
79 { \
80  return ( \
81  reg == XED_REG_R ## REG || \
82  reg == XED_REG_E ## REG || \
83  reg == XED_REG_ ## REG ); \
84 }
85 #else
86 #define X86_ISREG(REG) \
87 static inline bool \
88 x86_isReg_ ## REG (xed_reg_enum_t reg) \
89 { \
90  return ( \
91  reg == XED_REG_E ## REG || \
92  reg == XED_REG_ ## REG ); \
93 }
94 #endif
95 
96 #define X86_ISREG_R(REG) \
97 static inline bool \
98 x86_isReg_R ## REG (xed_reg_enum_t reg) \
99 { \
100  return (reg == XED_REG_R ## REG ); \
101 }
102 
103 //***************************************************************************
104 //
105 //***************************************************************************
106 
107 #ifdef __cplusplus
108 extern "C" {
109 #endif
110 
111 X86_ISREG(BP)
112 
113 X86_ISREG(SP)
114 
115 X86_ISREG(IP)
116 
117 X86_ISREG(AX)
118 
119 X86_ISREG(BX)
120 
121 X86_ISREG(CX)
122 
123 X86_ISREG(DX)
124 
125 X86_ISREG(SI)
126 
127 X86_ISREG(DI)
128 
129 X86_ISREG_R(8)
130 
131 X86_ISREG_R(9)
132 
133 X86_ISREG_R(10)
134 
135 X86_ISREG_R(11)
136 
137 X86_ISREG_R(12)
138 
139 X86_ISREG_R(13)
140 
141 X86_ISREG_R(14)
142 
143 X86_ISREG_R(15)
144 
145 
146 //***************************************************************************
147 
148 #ifdef __cplusplus
149 };
150 #endif
151 
152 
153 #endif // isa_lean_x86_instruction_set_h
#define X86_ISREG_R(REG)
#define X86_ISREG(REG)