blob: 25b62418eb9fa79d1e7e1a4b183503026c8a6e51 [file] [log] [blame]
sewardjde4a1d02002-03-22 01:27:54 +00001
2/*--------------------------------------------------------------------*/
nethercote5a2664c2004-09-02 15:37:39 +00003/*--- Asm-specific core stuff. core_asm.h ---*/
sewardjde4a1d02002-03-22 01:27:54 +00004/*--------------------------------------------------------------------*/
5
6/*
njnc9539842002-10-02 13:26:35 +00007 This file is part of Valgrind, an extensible x86 protected-mode
8 emulator for monitoring program execution on x86-Unixes.
sewardjde4a1d02002-03-22 01:27:54 +00009
nethercotebb1c9912004-01-04 16:43:23 +000010 Copyright (C) 2000-2004 Julian Seward
sewardjde4a1d02002-03-22 01:27:54 +000011 jseward@acm.org
sewardjde4a1d02002-03-22 01:27:54 +000012
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
njn25e49d8e72002-09-23 09:36:25 +000028 The GNU General Public License is contained in the file COPYING.
sewardjde4a1d02002-03-22 01:27:54 +000029*/
30
nethercote5a2664c2004-09-02 15:37:39 +000031#ifndef __CORE_ASM_H
32#define __CORE_ASM_H
sewardjde4a1d02002-03-22 01:27:54 +000033
nethercotec06e2132004-09-03 13:45:29 +000034#include "tool_asm.h" // tool asm stuff
35#include "core_arch_asm.h" // arch-specific asm stuff
sewardjde4a1d02002-03-22 01:27:54 +000036
37/* This file is included in all Valgrind source files, including
38 assembly ones. */
39
sewardj2e93c502002-04-12 11:12:52 +000040/* Magic values that %ebp might be set to when returning to the
sewardjde4a1d02002-03-22 01:27:54 +000041 dispatcher. The only other legitimate value is to point to the
sewardj2e93c502002-04-12 11:12:52 +000042 start of VG_(baseBlock). These also are return values from
sewardj54cacf02002-04-12 23:24:59 +000043 VG_(run_innerloop) to the scheduler.
sewardj2e93c502002-04-12 11:12:52 +000044
sewardj54cacf02002-04-12 23:24:59 +000045 EBP means %ebp can legitimately have this value when a basic block
46 returns to the dispatch loop. TRC means that this value is a valid
47 thread return code, which the dispatch loop may return to the
48 scheduler. */
sewardj54cacf02002-04-12 23:24:59 +000049#define VG_TRC_EBP_JMP_SYSCALL 19 /* EBP and TRC */
50#define VG_TRC_EBP_JMP_CLIENTREQ 23 /* EBP and TRC */
fitzhardingea02f8812003-12-18 09:06:09 +000051#define VG_TRC_EBP_JMP_YIELD 27 /* EBP and TRC */
sewardj54cacf02002-04-12 23:24:59 +000052
njn25e49d8e72002-09-23 09:36:25 +000053#define VG_TRC_INNER_FASTMISS 31 /* TRC only; means fast-cache miss. */
54#define VG_TRC_INNER_COUNTERZERO 29 /* TRC only; means bb ctr == 0 */
55#define VG_TRC_UNRESUMABLE_SIGNAL 37 /* TRC only; got sigsegv/sigbus */
sewardj54cacf02002-04-12 23:24:59 +000056
sewardj22854b92002-11-30 14:00:47 +000057/* maximum number of normal jumps which can appear in a basic block */
58#define VG_MAX_JUMPS 2
59
60/* Offset of code in a TCEntry */
61#define VG_CODE_OFFSET (8 + VG_MAX_JUMPS * 2)
sewardjde4a1d02002-03-22 01:27:54 +000062
fitzhardinge98abfc72003-12-16 02:05:15 +000063/* Client address space segment limit descriptor entry */
64#define VG_POINTERCHECK_SEGIDX 1
65
sewardjde4a1d02002-03-22 01:27:54 +000066/* Debugging hack for assembly code ... sigh. */
67#if 0
68#define OYNK(nnn) pushal; pushl $nnn; call VG_(oynk) ; addl $4,%esp; popal
69#else
70#define OYNK(nnn)
71#endif
72
sewardj2e93c502002-04-12 11:12:52 +000073#if 0
sewardjde4a1d02002-03-22 01:27:54 +000074#define OYNNK(nnn) pushal; pushl $nnn; call VG_(oynk) ; addl $4,%esp; popal
75#else
76#define OYNNK(nnn)
77#endif
78
sewardj2e93c502002-04-12 11:12:52 +000079
sewardjde4a1d02002-03-22 01:27:54 +000080/* Constants for the fast translation lookup cache. */
81#define VG_TT_FAST_BITS 15
82#define VG_TT_FAST_SIZE (1 << VG_TT_FAST_BITS)
83#define VG_TT_FAST_MASK ((VG_TT_FAST_SIZE) - 1)
84
85/* Constants for the fast original-code-write check cache. */
86
sewardj2e93c502002-04-12 11:12:52 +000087
sewardj20917d82002-05-28 01:36:45 +000088/* Assembly code stubs make this request */
sewardj54cacf02002-04-12 23:24:59 +000089#define VG_USERREQ__SIGNAL_RETURNS 0x4001
sewardj54cacf02002-04-12 23:24:59 +000090
fitzhardinge27574172004-01-26 21:11:51 +000091/*
92 0 - standard feature flags
93 1 - Intel extended flags
94 2 - Valgrind internal flags
95 3 - AMD-specific flags
96 */
97#define VG_N_FEATURE_WORDS 4
fitzhardinge0df2ac22004-01-25 02:38:29 +000098
fitzhardinge27574172004-01-26 21:11:51 +000099#define VG_X86_FEAT 0
100#define VG_EXT_FEAT 1
101#define VG_INT_FEAT 2
102#define VG_AMD_FEAT 3
103
104/* CPU features (generic) */
105#define VG_X86_FEAT_FPU (VG_X86_FEAT*32 + 0)
106#define VG_X86_FEAT_VME (VG_X86_FEAT*32 + 1)
107#define VG_X86_FEAT_DE (VG_X86_FEAT*32 + 2)
108#define VG_X86_FEAT_PSE (VG_X86_FEAT*32 + 3)
109#define VG_X86_FEAT_TSC (VG_X86_FEAT*32 + 4)
110#define VG_X86_FEAT_MSR (VG_X86_FEAT*32 + 5)
111#define VG_X86_FEAT_PAE (VG_X86_FEAT*32 + 6)
112#define VG_X86_FEAT_MCE (VG_X86_FEAT*32 + 7)
113#define VG_X86_FEAT_CX8 (VG_X86_FEAT*32 + 8)
114#define VG_X86_FEAT_APIC (VG_X86_FEAT*32 + 9)
115#define VG_X86_FEAT_SEP (VG_X86_FEAT*32 + 11)
116#define VG_X86_FEAT_MTRR (VG_X86_FEAT*32 + 12)
117#define VG_X86_FEAT_PGE (VG_X86_FEAT*32 + 13)
118#define VG_X86_FEAT_MCA (VG_X86_FEAT*32 + 14)
119#define VG_X86_FEAT_CMOV (VG_X86_FEAT*32 + 15)
120#define VG_X86_FEAT_PAT (VG_X86_FEAT*32 + 16)
121#define VG_X86_FEAT_PSE36 (VG_X86_FEAT*32 + 17)
122#define VG_X86_FEAT_CLFSH (VG_X86_FEAT*32 + 19)
123#define VG_X86_FEAT_DS (VG_X86_FEAT*32 + 21)
124#define VG_X86_FEAT_ACPI (VG_X86_FEAT*32 + 22)
125#define VG_X86_FEAT_MMX (VG_X86_FEAT*32 + 23)
126#define VG_X86_FEAT_FXSR (VG_X86_FEAT*32 + 24)
127#define VG_X86_FEAT_SSE (VG_X86_FEAT*32 + 25)
128#define VG_X86_FEAT_SSE2 (VG_X86_FEAT*32 + 26)
129#define VG_X86_FEAT_SS (VG_X86_FEAT*32 + 27)
130#define VG_X86_FEAT_HT (VG_X86_FEAT*32 + 28)
131#define VG_X86_FEAT_TM (VG_X86_FEAT*32 + 29)
132#define VG_X86_FEAT_IA64 (VG_X86_FEAT*32 + 30)
133#define VG_X86_FEAT_PBE (VG_X86_FEAT*32 + 31)
134
135/* Intel extended feature word */
136#define VG_X86_FEAT_SSE3 (VG_EXT_FEAT*32 + 0)
137#define VG_X86_FEAT_MON (VG_EXT_FEAT*32 + 3)
138#define VG_X86_FEAT_DSCPL (VG_EXT_FEAT*32 + 4)
139#define VG_X86_FEAT_EST (VG_EXT_FEAT*32 + 7)
140#define VG_X86_FEAT_TM2 (VG_EXT_FEAT*32 + 8)
141#define VG_X86_FEAT_CNXTID (VG_EXT_FEAT*32 + 10)
fitzhardinge0df2ac22004-01-25 02:38:29 +0000142
143/* Used internally to mark whether CPUID is even implemented */
fitzhardinge27574172004-01-26 21:11:51 +0000144#define VG_X86_FEAT_CPUID (VG_INT_FEAT*32 + 0)
fitzhardinge0df2ac22004-01-25 02:38:29 +0000145
fitzhardinge27574172004-01-26 21:11:51 +0000146/* AMD special features */
147#define VG_AMD_FEAT_SYSCALL (VG_AMD_FEAT*32 + 11)
148#define VG_AMD_FEAT_NXP (VG_AMD_FEAT*32 + 20)
149#define VG_AMD_FEAT_MMXEXT (VG_AMD_FEAT*32 + 22)
150#define VG_AMD_FEAT_FFXSR (VG_AMD_FEAT*32 + 25)
151#define VG_AMD_FEAT_LONGMODE (VG_AMD_FEAT*32 + 29)
152#define VG_AMD_FEAT_3DNOWEXT (VG_AMD_FEAT*32 + 30)
153#define VG_AMD_FEAT_3DNOW (VG_AMD_FEAT*32 + 31)
154
fitzhardinge98abfc72003-12-16 02:05:15 +0000155/* Various environment variables we pay attention to */
156
157/* The directory we look for all our auxillary files in */
158#define VALGRINDLIB "VALGRINDLIB"
159
160/* Additional command-line arguments; they are overridden by actual
161 command-line option. Each argument is separated by spaces. There
162 is no quoting mechanism.
163 */
164#define VALGRINDOPTS "VALGRIND_OPTS"
165
166/* If this variable is present in the environment, then valgrind will
167 not parse the command line for options at all; all options come
168 from this variable. Arguments are terminated by ^A (\001). There
169 is no quoting mechanism.
170
171 This variable is not expected to be set by anything other than
172 Valgrind itself, as part of its handling of execve with
173 --trace-children=yes. This variable should not be present in the
174 client environment.
175 */
176#define VALGRINDCLO "_VALGRIND_CLO"
177
nethercote5a2664c2004-09-02 15:37:39 +0000178#endif /* ndef __CORE_ASM_H */
sewardjde4a1d02002-03-22 01:27:54 +0000179
180/*--------------------------------------------------------------------*/
nethercote5a2664c2004-09-02 15:37:39 +0000181/*--- end ---*/
sewardjde4a1d02002-03-22 01:27:54 +0000182/*--------------------------------------------------------------------*/