blob: 062c2eaa29d22a5b1776109b2081177175beacbe [file] [log] [blame]
njnf536bbb2005-06-13 04:21:38 +00001
2/*--------------------------------------------------------------------*/
3/*--- Machine-related stuff. pub_tool_machine.h ---*/
4/*--------------------------------------------------------------------*/
5
6/*
7 This file is part of Valgrind, a dynamic binary instrumentation
8 framework.
9
sewardj9eecbbb2010-05-03 21:37:12 +000010 Copyright (C) 2000-2010 Julian Seward
njnf536bbb2005-06-13 04:21:38 +000011 jseward@acm.org
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., 59 Temple Place, Suite 330, Boston, MA
26 02111-1307, USA.
27
28 The GNU General Public License is contained in the file COPYING.
29*/
30
njn4a164d02005-06-18 18:49:40 +000031#ifndef __PUB_TOOL_MACHINE_H
32#define __PUB_TOOL_MACHINE_H
njnf536bbb2005-06-13 04:21:38 +000033
sewardjf1c91e02006-10-17 01:35:58 +000034#if defined(VGP_x86_linux)
njna5ad9ba2005-11-10 15:20:37 +000035# define VG_MIN_INSTR_SZB 1 // min length of native instruction
36# define VG_MAX_INSTR_SZB 16 // max length of native instruction
sewardj0ec07f32006-01-12 12:32:32 +000037# define VG_CLREQ_SZB 14 // length of a client request, may
njna5ad9ba2005-11-10 15:20:37 +000038 // be larger than VG_MAX_INSTR_SZB
sewardjc2812332005-12-23 23:34:51 +000039# define VG_STACK_REDZONE_SZB 0 // number of addressable bytes below %RSP
sewardj59570ff2010-01-01 11:59:33 +000040
sewardjf1c91e02006-10-17 01:35:58 +000041#elif defined(VGP_amd64_linux)
njnaf839f52005-06-23 03:27:57 +000042# define VG_MIN_INSTR_SZB 1
43# define VG_MAX_INSTR_SZB 16
sewardj0ec07f32006-01-12 12:32:32 +000044# define VG_CLREQ_SZB 19
njnaf839f52005-06-23 03:27:57 +000045# define VG_STACK_REDZONE_SZB 128
sewardj59570ff2010-01-01 11:59:33 +000046
sewardjf1c91e02006-10-17 01:35:58 +000047#elif defined(VGP_ppc32_linux)
njnaf839f52005-06-23 03:27:57 +000048# define VG_MIN_INSTR_SZB 4
49# define VG_MAX_INSTR_SZB 4
sewardjd68ac3e2006-01-20 14:31:57 +000050# define VG_CLREQ_SZB 20
njnaf839f52005-06-23 03:27:57 +000051# define VG_STACK_REDZONE_SZB 0
sewardj59570ff2010-01-01 11:59:33 +000052
sewardjf1c91e02006-10-17 01:35:58 +000053#elif defined(VGP_ppc64_linux)
sewardj2c48c7b2005-11-29 13:05:56 +000054# define VG_MIN_INSTR_SZB 4
55# define VG_MAX_INSTR_SZB 4
sewardjd68ac3e2006-01-20 14:31:57 +000056# define VG_CLREQ_SZB 20
sewardjc2812332005-12-23 23:34:51 +000057# define VG_STACK_REDZONE_SZB 288 // number of addressable bytes below R1
sewardj59570ff2010-01-01 11:59:33 +000058 // from 64-bit PowerPC ELF ABI
59 // Supplement 1.7
60
61#elif defined(VGP_arm_linux)
sewardj1dbd3372010-08-22 12:21:14 +000062# define VG_MIN_INSTR_SZB 2
sewardj59570ff2010-01-01 11:59:33 +000063# define VG_MAX_INSTR_SZB 4
sewardj807725e2010-10-12 10:13:17 +000064# define VG_CLREQ_SZB 20
sewardj59570ff2010-01-01 11:59:33 +000065# define VG_STACK_REDZONE_SZB 0
66
sewardjf1c91e02006-10-17 01:35:58 +000067#elif defined(VGP_ppc32_aix5)
68# define VG_MIN_INSTR_SZB 4
69# define VG_MAX_INSTR_SZB 4
70# define VG_CLREQ_SZB 20
71 /* The PowerOpen ABI actually says 220 bytes, but that is not an
72 8-aligned number, and frequently forces Memcheck's
73 mc_{new,die}_mem_stack_N routines into slow cases by losing
74 8-alignment of the area to be messed with. So let's just say
75 224 instead. Gdb has a similar kludge. */
76# define VG_STACK_REDZONE_SZB 224
sewardj59570ff2010-01-01 11:59:33 +000077
sewardjf1c91e02006-10-17 01:35:58 +000078#elif defined(VGP_ppc64_aix5)
79# define VG_MIN_INSTR_SZB 4
80# define VG_MAX_INSTR_SZB 4
81# define VG_CLREQ_SZB 20
82# define VG_STACK_REDZONE_SZB 288 // is this right?
sewardj59570ff2010-01-01 11:59:33 +000083
sewardjb5b87402011-03-07 16:05:35 +000084#elif defined(VGP_s390x_linux)
85# define VG_MIN_INSTR_SZB 2
86# define VG_MAX_INSTR_SZB 6
87# define VG_CLREQ_SZB 10
88# define VG_STACK_REDZONE_SZB 0 // s390 has no redzone
89
njnf76d27a2009-05-28 01:53:07 +000090#elif defined(VGP_x86_darwin)
91# define VG_MIN_INSTR_SZB 1 // min length of native instruction
92# define VG_MAX_INSTR_SZB 16 // max length of native instruction
93# define VG_CLREQ_SZB 14 // length of a client request, may
94 // be larger than VG_MAX_INSTR_SZB
95# define VG_STACK_REDZONE_SZB 0 // number of addressable bytes below %RSP
sewardj59570ff2010-01-01 11:59:33 +000096
njnf76d27a2009-05-28 01:53:07 +000097#elif defined(VGP_amd64_darwin)
98# define VG_MIN_INSTR_SZB 1
99# define VG_MAX_INSTR_SZB 16
100# define VG_CLREQ_SZB 19
101# define VG_STACK_REDZONE_SZB 128
sewardj59570ff2010-01-01 11:59:33 +0000102
njnf536bbb2005-06-13 04:21:38 +0000103#else
sewardjf1c91e02006-10-17 01:35:58 +0000104# error Unknown platform
njnf536bbb2005-06-13 04:21:38 +0000105#endif
106
107// Guest state accessors
sewardj1dbd3372010-08-22 12:21:14 +0000108// Are mostly in the core_ header.
109// Only these two are available to tools.
110Addr VG_(get_IP) ( ThreadId tid );
111Addr VG_(get_SP) ( ThreadId tid );
njnf536bbb2005-06-13 04:21:38 +0000112
njnf536bbb2005-06-13 04:21:38 +0000113
sewardj9c606bd2008-09-18 18:12:50 +0000114// For get/set, 'area' is where the asked-for guest state will be copied
115// into/from. If shadowNo == 0, the real (non-shadow) guest state is
116// accessed. If shadowNo == 1, the first shadow area is accessed, and
117// if shadowNo == 2, the second shadow area is accessed. This gives a
118// completely general way to read/modify a thread's guest register state
119// providing you know the offsets you need.
sewardj7cf4e6b2008-05-01 20:24:26 +0000120void
121VG_(get_shadow_regs_area) ( ThreadId tid,
122 /*DST*/UChar* dst,
njnc4431bf2009-01-15 21:29:24 +0000123 /*SRC*/Int shadowNo, PtrdiffT offset, SizeT size );
sewardj7cf4e6b2008-05-01 20:24:26 +0000124void
125VG_(set_shadow_regs_area) ( ThreadId tid,
njnc4431bf2009-01-15 21:29:24 +0000126 /*DST*/Int shadowNo, PtrdiffT offset, SizeT size,
sewardj7cf4e6b2008-05-01 20:24:26 +0000127 /*SRC*/const UChar* src );
njnf536bbb2005-06-13 04:21:38 +0000128
sewardj9c606bd2008-09-18 18:12:50 +0000129// Sets the shadow values for the syscall return value register(s).
130// This is platform specific.
131void VG_(set_syscall_return_shadows) ( ThreadId tid,
132 /* shadow vals for the result */
133 UWord s1res, UWord s2res,
134 /* shadow vals for the error val */
135 UWord s1err, UWord s2err );
136
njn6ace3ea2005-06-17 03:06:27 +0000137// Apply a function 'f' to all the general purpose registers in all the
138// current threads.
139// This is very Memcheck-specific -- it's used to find the roots when
140// doing leak checking.
141extern void VG_(apply_to_GP_regs)(void (*f)(UWord val));
142
sewardjb8b79ad2008-03-03 01:35:41 +0000143// This iterator lets you inspect each live thread's stack bounds.
144// Returns False at the end. 'tid' is the iterator and you can only
145// safely change it by making calls to these functions.
146extern void VG_(thread_stack_reset_iter) ( /*OUT*/ThreadId* tid );
147extern Bool VG_(thread_stack_next) ( /*MOD*/ThreadId* tid,
148 /*OUT*/Addr* stack_min,
149 /*OUT*/Addr* stack_max );
njnb506bd82005-06-21 04:01:51 +0000150
sewardjbbec7722007-11-25 14:08:53 +0000151// Returns .client_stack_highest_word for the given thread
152extern Addr VG_(thread_get_stack_max) ( ThreadId tid );
153
bart0fb03202008-03-29 09:25:53 +0000154// Returns how many bytes have been allocated for the stack of the given thread
bart019a43f2010-09-02 14:41:05 +0000155extern SizeT VG_(thread_get_stack_size) ( ThreadId tid );
bart0fb03202008-03-29 09:25:53 +0000156
bart83c5a922010-09-02 14:38:38 +0000157// Returns the bottommost address of the alternate signal stack.
158// See also the man page of sigaltstack().
159extern Addr VG_(thread_get_altstack_min) ( ThreadId tid );
160
161// Returns how many bytes have been allocated for the alternate signal stack.
162// See also the man page of sigaltstack().
163extern SizeT VG_(thread_get_altstack_size) ( ThreadId tid );
164
sewardj53ee1fc2005-12-23 02:29:58 +0000165// Given a pointer to a function as obtained by "& functionname" in C,
166// produce a pointer to the actual entry point for the function. For
167// most platforms it's the identity function. Unfortunately, on
168// ppc64-linux it isn't (sigh).
169extern void* VG_(fnptr_to_fnentry)( void* );
170
njn4a164d02005-06-18 18:49:40 +0000171#endif // __PUB_TOOL_MACHINE_H
njnf536bbb2005-06-13 04:21:38 +0000172
173/*--------------------------------------------------------------------*/
174/*--- end ---*/
175/*--------------------------------------------------------------------*/