1 /* -*- mode: C; c-basic-offset: 3; -*- */
2 
3 /*---------------------------------------------------------------*/
4 /*--- begin                              libvex_guest_s390x.h ---*/
5 /*---------------------------------------------------------------*/
6 
7 /*
8    This file is part of Valgrind, a dynamic binary instrumentation
9    framework.
10 
11    Copyright IBM Corp. 2010-2015
12 
13    This program is free software; you can redistribute it and/or
14    modify it under the terms of the GNU General Public License as
15    published by the Free Software Foundation; either version 2 of the
16    License, or (at your option) any later version.
17 
18    This program is distributed in the hope that it will be useful, but
19    WITHOUT ANY WARRANTY; without even the implied warranty of
20    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
21    General Public License for more details.
22 
23    You should have received a copy of the GNU General Public License
24    along with this program; if not, write to the Free Software
25    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26    02110-1301, USA.
27 
28    The GNU General Public License is contained in the file COPYING.
29 */
30 
31 #ifndef __LIBVEX_PUB_GUEST_S390X_H
32 #define __LIBVEX_PUB_GUEST_S390X_H
33 
34 #include "libvex_basictypes.h"
35 
36 /*------------------------------------------------------------*/
37 /*--- Vex's representation of the s390 CPU state.          ---*/
38 /*------------------------------------------------------------*/
39 
40 typedef struct {
41 
42 /*------------------------------------------------------------*/
43 /*--- ar registers                                         ---*/
44 /*------------------------------------------------------------*/
45 
46    /*    0 */  UInt guest_a0;
47    /*    4 */  UInt guest_a1;
48    /*    8 */  UInt guest_a2;
49    /*   12 */  UInt guest_a3;
50    /*   16 */  UInt guest_a4;
51    /*   20 */  UInt guest_a5;
52    /*   24 */  UInt guest_a6;
53    /*   28 */  UInt guest_a7;
54    /*   32 */  UInt guest_a8;
55    /*   36 */  UInt guest_a9;
56    /*   40 */  UInt guest_a10;
57    /*   44 */  UInt guest_a11;
58    /*   48 */  UInt guest_a12;
59    /*   52 */  UInt guest_a13;
60    /*   56 */  UInt guest_a14;
61    /*   60 */  UInt guest_a15;
62 
63 /*------------------------------------------------------------*/
64 /*--- fpr registers                                        ---*/
65 /*------------------------------------------------------------*/
66 
67    /*   64 */  ULong guest_f0;
68    /*   72 */  ULong guest_f1;
69    /*   80 */  ULong guest_f2;
70    /*   88 */  ULong guest_f3;
71    /*   96 */  ULong guest_f4;
72    /*  104 */  ULong guest_f5;
73    /*  112 */  ULong guest_f6;
74    /*  120 */  ULong guest_f7;
75    /*  128 */  ULong guest_f8;
76    /*  136 */  ULong guest_f9;
77    /*  144 */  ULong guest_f10;
78    /*  152 */  ULong guest_f11;
79    /*  160 */  ULong guest_f12;
80    /*  168 */  ULong guest_f13;
81    /*  176 */  ULong guest_f14;
82    /*  184 */  ULong guest_f15;
83 
84 /*------------------------------------------------------------*/
85 /*--- gpr registers                                        ---*/
86 /*------------------------------------------------------------*/
87 
88    /*  192 */  ULong guest_r0;
89    /*  200 */  ULong guest_r1;
90    /*  208 */  ULong guest_r2;
91    /*  216 */  ULong guest_r3;
92    /*  224 */  ULong guest_r4;
93    /*  232 */  ULong guest_r5;
94    /*  240 */  ULong guest_r6;
95    /*  248 */  ULong guest_r7;
96    /*  256 */  ULong guest_r8;
97    /*  264 */  ULong guest_r9;
98    /*  272 */  ULong guest_r10;
99    /*  280 */  ULong guest_r11;
100    /*  288 */  ULong guest_r12;
101    /*  296 */  ULong guest_r13;
102    /*  304 */  ULong guest_r14;
103    /*  312 */  ULong guest_r15;
104 
105 /*------------------------------------------------------------*/
106 /*--- S390 miscellaneous registers                         ---*/
107 /*------------------------------------------------------------*/
108 
109    /*  320 */  ULong guest_counter;
110    /*  328 */  UInt guest_fpc;
111    /*  332 */  UChar unused[4]; /* 4-byte hole to get 8-byte alignment */
112    /*  336 */  ULong guest_IA;
113 
114 /*------------------------------------------------------------*/
115 /*--- S390 pseudo registers                                ---*/
116 /*------------------------------------------------------------*/
117 
118    /*  344 */  ULong guest_SYSNO;
119 
120 /*------------------------------------------------------------*/
121 /*--- 4-word thunk used to calculate the condition code    ---*/
122 /*------------------------------------------------------------*/
123 
124    /*  352 */  ULong guest_CC_OP;
125    /*  360 */  ULong guest_CC_DEP1;
126    /*  368 */  ULong guest_CC_DEP2;
127    /*  376 */  ULong guest_CC_NDEP;
128 
129 /*------------------------------------------------------------*/
130 /*--- Pseudo registers. Required by all architectures      ---*/
131 /*------------------------------------------------------------*/
132 
133    /* See comments at bottom of libvex.h */
134    /*  384 */  ULong guest_NRADDR;
135    /*  392 */  ULong guest_CMSTART;
136    /*  400 */  ULong guest_CMLEN;
137 
138    /* Used when backing up to restart a syscall that has
139       been interrupted by a signal. See also comment in
140       libvex_ir.h */
141    /*  408 */  ULong guest_IP_AT_SYSCALL;
142 
143    /* Emulation notes; see comments in libvex_emnote.h */
144    /*  416 */  UInt guest_EMNOTE;
145 
146    /* For translation chaining */
147    /*  420 */  UInt  host_EvC_COUNTER;
148    /*  424 */  ULong host_EvC_FAILADDR;
149 
150 /*------------------------------------------------------------*/
151 /*--- Force alignment to 16 bytes                          ---*/
152 /*------------------------------------------------------------*/
153    /*  432 */  UChar padding[0];
154 
155    /*  432 */  /* This is the size of the guest state */
156 } VexGuestS390XState;
157 
158 
159 /*------------------------------------------------------------*/
160 /*--- Function prototypes                                  ---*/
161 /*------------------------------------------------------------*/
162 
163 void LibVEX_GuestS390X_initialise(VexGuestS390XState *);
164 
165 /*------------------------------------------------------------*/
166 /*--- Dedicated registers                                  ---*/
167 /*------------------------------------------------------------*/
168 
169 #define guest_LR guest_r14  /* Link register */
170 #define guest_SP guest_r15  /* Stack pointer */
171 #define guest_FP guest_r11  /* Frame pointer */
172 
173 /*---------------------------------------------------------------*/
174 /*--- end                                libvex_guest_s390x.h ---*/
175 /*---------------------------------------------------------------*/
176 
177 #endif /* __LIBVEX_PUB_GUEST_S390X_H */
178