1ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
2ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
3ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*--- begin                              libvex_guest_ppc64.h ---*/
4ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
5ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
6ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*
7ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   This file is part of Valgrind, a dynamic binary instrumentation
8ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   framework.
9ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
10b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov   Copyright (C) 2004-2011 OpenWorks LLP
11ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      info@open-works.net
12ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
13ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   This program is free software; you can redistribute it and/or
14ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   modify it under the terms of the GNU General Public License as
15ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   published by the Free Software Foundation; either version 2 of the
16ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   License, or (at your option) any later version.
17ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
18ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   This program is distributed in the hope that it will be useful, but
19ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   WITHOUT ANY WARRANTY; without even the implied warranty of
20ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
21ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   General Public License for more details.
22ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
23ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   You should have received a copy of the GNU General Public License
24ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   along with this program; if not, write to the Free Software
25ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   02110-1301, USA.
27ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
28ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   The GNU General Public License is contained in the file COPYING.
29ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
30ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   Neither the names of the U.S. Department of Energy nor the
31ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   University of California nor the names of its contributors may be
32ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   used to endorse or promote products derived from this software
33ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   without prior written permission.
34ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown*/
35ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
36ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#ifndef __LIBVEX_PUB_GUEST_PPC64_H
37ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#define __LIBVEX_PUB_GUEST_PPC64_H
38ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
39ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#include "libvex_basictypes.h"
40ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#include "libvex_emwarn.h"
41ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
42ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*
43ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown    volatile ==  caller-saved (not preserved across function calls)
44ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownnon-volatile ==  callee-saved (preserved across function calls)
45ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
46ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr0        Volatile register used in function prologs
47ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr1        Stack frame pointer
48ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr2        TOC pointer
49ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr3        Volatile parameter and return value register
50ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr4-r10    Volatile registers used for function parameters
51ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr11       Volatile register used in calls by pointer and as an
52ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown          environment pointer for languages which require one
53ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr12       Volatile register used for exception handling and glink code
54ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr13       Reserved for use as system thread ID
55ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownr14-r31   Nonvolatile registers used for local variables
56ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
57ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownf0        Volatile scratch register
58ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownf1-f4     Volatile floating point parameter and return value registers
59ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownf5-f13    Volatile floating point parameter registers
60ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownf14-f31   Nonvolatile registers
61ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
62ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownLR        Link register (volatile)
63ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownCTR       Loop counter register (volatile)
64ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownXER       Fixed point exception register (volatile)
65ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownFPSCR     Floating point status and control register (volatile)
66ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
67ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownCR0-CR1   Volatile condition code register fields
68ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownCR2-CR4   Nonvolatile condition code register fields
69ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownCR5-CR7   Volatile condition code register fields
70ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
71ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownOn processors with the VMX feature.
72ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
73ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownv0-v1     Volatile scratch registers
74ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownv2-v13    Volatile vector parameters registers
75ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownv14-v19   Volatile scratch registers
76ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownv20-v31   Non-volatile registers
77ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvrsave    Non-volatile 32-bit register
78ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown*/
79ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
80ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
81ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
82ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*--- Vex's representation of the PPC64 CPU state             ---*/
83ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
84ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
85ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#define VEX_GUEST_PPC64_REDIR_STACK_SIZE (16/*entries*/ * 2/*words per entry*/)
86ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
87ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Browntypedef
88ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   struct {
89ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* General Purpose Registers */
90ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*   0 */ ULong guest_GPR0;
91ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*   8 */ ULong guest_GPR1;
92ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  16 */ ULong guest_GPR2;
93ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  24 */ ULong guest_GPR3;
94ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  32 */ ULong guest_GPR4;
95ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  40 */ ULong guest_GPR5;
96ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  48 */ ULong guest_GPR6;
97ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  56 */ ULong guest_GPR7;
98ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  64 */ ULong guest_GPR8;
99ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  72 */ ULong guest_GPR9;
100ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  80 */ ULong guest_GPR10;
101ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  88 */ ULong guest_GPR11;
102ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /*  96 */ ULong guest_GPR12;
103ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 104 */ ULong guest_GPR13;
104ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 112 */ ULong guest_GPR14;
105ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 120 */ ULong guest_GPR15;
106ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 128 */ ULong guest_GPR16;
107ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 136 */ ULong guest_GPR17;
108ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 144 */ ULong guest_GPR18;
109ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 152 */ ULong guest_GPR19;
110ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 160 */ ULong guest_GPR20;
111ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 168 */ ULong guest_GPR21;
112ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 176 */ ULong guest_GPR22;
113ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 184 */ ULong guest_GPR23;
114ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 192 */ ULong guest_GPR24;
115ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 200 */ ULong guest_GPR25;
116ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 208 */ ULong guest_GPR26;
117ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 216 */ ULong guest_GPR27;
118ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 224 */ ULong guest_GPR28;
119ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 232 */ ULong guest_GPR29;
120ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 240 */ ULong guest_GPR30;
121ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* 248 */ ULong guest_GPR31;
122ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
123b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // Vector Registers, Floating Point Registers, and VSX Registers
124b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // With ISA 2.06, the "Vector-Scalar Floating-point" category
125b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // provides facilities to support vector and scalar binary floating-
126b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // point operations.  A unified register file is an integral part
127b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // of this new facility, combining floating point and vector registers
128b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // using a 64x128-bit vector.  These are referred to as VSR[0..63].
129b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // The floating point registers are now mapped into double word element 0
130b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // of VSR[0..31]. The 32x128-bit vector registers defined by the "Vector
131b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // Facility [Category: Vector]" are now mapped to VSR[32..63].
132b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov
133ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      // IMPORTANT: the user of libvex must place the guest state so as
134b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      // to ensure that guest_VSR{0..63}, and any shadows thereof, are
135ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      // 16-aligned.
136b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov
137b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  256 */ U128 guest_VSR0;
138b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  272 */ U128 guest_VSR1;
139b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  288 */ U128 guest_VSR2;
140b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  304 */ U128 guest_VSR3;
141b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  320 */ U128 guest_VSR4;
142b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  336 */ U128 guest_VSR5;
143b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  352 */ U128 guest_VSR6;
144b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  368 */ U128 guest_VSR7;
145b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  384 */ U128 guest_VSR8;
146b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  400 */ U128 guest_VSR9;
147b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  416 */ U128 guest_VSR10;
148b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  432 */ U128 guest_VSR11;
149b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  448 */ U128 guest_VSR12;
150b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  464 */ U128 guest_VSR13;
151b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  480 */ U128 guest_VSR14;
152b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  496 */ U128 guest_VSR15;
153b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  512 */ U128 guest_VSR16;
154b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  528 */ U128 guest_VSR17;
155b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  544 */ U128 guest_VSR18;
156b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  560 */ U128 guest_VSR19;
157b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  576 */ U128 guest_VSR20;
158b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  592 */ U128 guest_VSR21;
159b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  608 */ U128 guest_VSR22;
160b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  624 */ U128 guest_VSR23;
161b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  640 */ U128 guest_VSR24;
162b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  656 */ U128 guest_VSR25;
163b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  672 */ U128 guest_VSR26;
164b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  688 */ U128 guest_VSR27;
165b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  704 */ U128 guest_VSR28;
166b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  720 */ U128 guest_VSR29;
167b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  736 */ U128 guest_VSR30;
168b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  752 */ U128 guest_VSR31;
169b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  768 */ U128 guest_VSR32;
170b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  784 */ U128 guest_VSR33;
171b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  800 */ U128 guest_VSR34;
172b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  816 */ U128 guest_VSR35;
173b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  832 */ U128 guest_VSR36;
174b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  848 */ U128 guest_VSR37;
175b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  864 */ U128 guest_VSR38;
176b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  880 */ U128 guest_VSR39;
177b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  896 */ U128 guest_VSR40;
178b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  912 */ U128 guest_VSR41;
179b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  928 */ U128 guest_VSR42;
180b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  944 */ U128 guest_VSR43;
181b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  960 */ U128 guest_VSR44;
182b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  976 */ U128 guest_VSR45;
183b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /*  992 */ U128 guest_VSR46;
184b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1008 */ U128 guest_VSR47;
185b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1024 */ U128 guest_VSR48;
186b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1040 */ U128 guest_VSR49;
187b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1056 */ U128 guest_VSR50;
188b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1072 */ U128 guest_VSR51;
189b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1088 */ U128 guest_VSR52;
190b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1104 */ U128 guest_VSR53;
191b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1120 */ U128 guest_VSR54;
192b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1136 */ U128 guest_VSR55;
193b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1152 */ U128 guest_VSR56;
194b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1168 */ U128 guest_VSR57;
195b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1184 */ U128 guest_VSR58;
196b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1200 */ U128 guest_VSR59;
197b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1216 */ U128 guest_VSR60;
198b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1232 */ U128 guest_VSR61;
199b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1248 */ U128 guest_VSR62;
200b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1264 */ U128 guest_VSR63;
201b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov
202b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1280 */ ULong guest_CIA;    // IP (no arch visible register)
203b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1288 */ ULong guest_LR;     // Link Register
204b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1296 */ ULong guest_CTR;    // Count Register
205ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
206ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* XER pieces */
207b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1304 */ UChar guest_XER_SO; /* in lsb */
208b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1305 */ UChar guest_XER_OV; /* in lsb */
209b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1306 */ UChar guest_XER_CA; /* in lsb */
210b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1307 */ UChar guest_XER_BC; /* all bits */
211ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
212ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* CR pieces */
213b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1308 */ UChar guest_CR0_321; /* in [3:1] */
214b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1309 */ UChar guest_CR0_0;   /* in lsb */
215b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1310 */ UChar guest_CR1_321; /* in [3:1] */
216b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1311 */ UChar guest_CR1_0;   /* in lsb */
217b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1312 */ UChar guest_CR2_321; /* in [3:1] */
218b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1313 */ UChar guest_CR2_0;   /* in lsb */
219b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1314 */ UChar guest_CR3_321; /* in [3:1] */
220b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1315 */ UChar guest_CR3_0;   /* in lsb */
221b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1316 */ UChar guest_CR4_321; /* in [3:1] */
222b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1317 */ UChar guest_CR4_0;   /* in lsb */
223b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1318 */ UChar guest_CR5_321; /* in [3:1] */
224b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1319 */ UChar guest_CR5_0;   /* in lsb */
225b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1320 */ UChar guest_CR6_321; /* in [3:1] */
226b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1321 */ UChar guest_CR6_0;   /* in lsb */
227b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1322 */ UChar guest_CR7_321; /* in [3:1] */
228b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1323 */ UChar guest_CR7_0;   /* in lsb */
229ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
230ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* FP Status & Control Register fields */
231b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1324 */ UInt guest_FPROUND; // FP Rounding Mode
232ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
233ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* Vector Save/Restore Register */
234b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1328 */ UInt guest_VRSAVE;
235ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
236ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* Vector Status and Control Register */
237b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1332 */ UInt guest_VSCR;
238ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
239ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* Emulation warnings */
240b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1336 */ UInt guest_EMWARN;
241ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
242ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* gcc adds 4 bytes padding here: pre-empt it. */
243b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1340 */ UInt  padding;
244ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
245ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* For icbi: record start and length of area to invalidate */
246b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1344 */ ULong guest_TISTART;
247b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1352 */ ULong guest_TILEN;
248ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
249ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* Used to record the unredirected guest address at the start of
250ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown         a translation whose start has been redirected.  By reading
251ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown         this pseudo-register shortly afterwards, the translation can
252ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown         find out what the corresponding no-redirection address was.
253ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown         Note, this is only set for wrap-style redirects, not for
254ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown         replace-style ones. */
255b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1360 */ ULong guest_NRADDR;
256b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1368 */ ULong guest_NRADDR_GPR2;
257ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
258ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown     /* A grows-upwards stack for hidden saves/restores of LR and R2
259ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown        needed for function interception and wrapping on ppc64-linux.
260ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown        A horrible hack.  REDIR_SP points to the highest live entry,
261ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown        and so starts at -1. */
262b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1376 */ ULong guest_REDIR_SP;
263b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1384 */ ULong guest_REDIR_STACK[VEX_GUEST_PPC64_REDIR_STACK_SIZE];
264ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
265ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* Needed for AIX: CIA at the last SC insn.  Used when backing up
266ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown         to restart a syscall that has been interrupted by a signal. */
267b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1640 */ ULong guest_IP_AT_SYSCALL;
268ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
269ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown      /* SPRG3, which AIUI is readonly in user space.  Needed for
270ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown         threading on AIX. */
271b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1648 */ ULong guest_SPRG3_RO;
272ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
273b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* Padding to make it have an 16-aligned size */
274b32f58018498ea2225959b0ba11c18f0c433deefEvgeniy Stepanov      /* 1656 */ ULong padding2;
275ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   }
276ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   VexGuestPPC64State;
277ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
278ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
279ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
280ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*--- Utility functions for PPC64 guest stuff.                ---*/
281ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
282ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
283ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* ALL THE FOLLOWING ARE VISIBLE TO LIBRARY CLIENT */
284ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
285ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* Initialise all guest PPC64 state. */
286ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownextern
287ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid LibVEX_GuestPPC64_initialise ( /*OUT*/VexGuestPPC64State* vex_state );
288ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
289ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
290ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* Write the given native %CR value to the supplied VexGuestPPC64State
291ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   structure.  Note, %CR is 32-bits even for ppc64. */
292ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownextern
293ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid LibVEX_GuestPPC64_put_CR ( UInt cr_native,
294ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown                                /*OUT*/VexGuestPPC64State* vex_state );
295ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
296ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* Extract from the supplied VexGuestPPC64State structure the
297ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   corresponding native %CR value.  Note, %CR is 32-bits even for
298ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   ppc64. */
299ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownextern
300ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownUInt LibVEX_GuestPPC64_get_CR ( /*IN*/VexGuestPPC64State* vex_state );
301ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
302ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
303ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* Write the given native %XER value to the supplied
304ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   VexGuestPPC64State structure.  Note, %XER is 32-bits even for
305ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   ppc64. */
306ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownextern
307ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownvoid LibVEX_GuestPPC64_put_XER ( UInt xer_native,
308ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown                                 /*OUT*/VexGuestPPC64State* vex_state );
309ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
310ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/* Extract from the supplied VexGuestPPC64State structure the
311ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   corresponding native %XER value.  Note, %CR is 32-bits even for
312ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown   ppc64. */
313ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brownextern
314ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff BrownUInt LibVEX_GuestPPC64_get_XER ( /*IN*/VexGuestPPC64State* vex_state );
315ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
316ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown#endif /* ndef __LIBVEX_PUB_GUEST_PPC64_H */
317ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
318ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown
319ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
320ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---                                    libvex_guest_ppc64.h ---*/
321ed07e00d438c74b7a23c01bfffde77e3968305e4Jeff Brown/*---------------------------------------------------------------*/
322