blob: c2221524748abd261094c24cd88b11753c9976d1 [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
sewardjde4a1d02002-03-22 01:27:54 +000057/* Constants for the fast translation lookup cache. */
58#define VG_TT_FAST_BITS 15
59#define VG_TT_FAST_SIZE (1 << VG_TT_FAST_BITS)
60#define VG_TT_FAST_MASK ((VG_TT_FAST_SIZE) - 1)
61
62/* Constants for the fast original-code-write check cache. */
63
sewardj2e93c502002-04-12 11:12:52 +000064
sewardj20917d82002-05-28 01:36:45 +000065/* Assembly code stubs make this request */
sewardj54cacf02002-04-12 23:24:59 +000066#define VG_USERREQ__SIGNAL_RETURNS 0x4001
sewardj54cacf02002-04-12 23:24:59 +000067
nethercote463c63c2004-10-26 11:18:32 +000068// XXX: all this will go into x86/ eventually...
fitzhardinge27574172004-01-26 21:11:51 +000069/*
70 0 - standard feature flags
71 1 - Intel extended flags
72 2 - Valgrind internal flags
73 3 - AMD-specific flags
74 */
75#define VG_N_FEATURE_WORDS 4
fitzhardinge0df2ac22004-01-25 02:38:29 +000076
fitzhardinge27574172004-01-26 21:11:51 +000077#define VG_X86_FEAT 0
78#define VG_EXT_FEAT 1
79#define VG_INT_FEAT 2
80#define VG_AMD_FEAT 3
81
82/* CPU features (generic) */
83#define VG_X86_FEAT_FPU (VG_X86_FEAT*32 + 0)
84#define VG_X86_FEAT_VME (VG_X86_FEAT*32 + 1)
85#define VG_X86_FEAT_DE (VG_X86_FEAT*32 + 2)
86#define VG_X86_FEAT_PSE (VG_X86_FEAT*32 + 3)
87#define VG_X86_FEAT_TSC (VG_X86_FEAT*32 + 4)
88#define VG_X86_FEAT_MSR (VG_X86_FEAT*32 + 5)
89#define VG_X86_FEAT_PAE (VG_X86_FEAT*32 + 6)
90#define VG_X86_FEAT_MCE (VG_X86_FEAT*32 + 7)
91#define VG_X86_FEAT_CX8 (VG_X86_FEAT*32 + 8)
92#define VG_X86_FEAT_APIC (VG_X86_FEAT*32 + 9)
93#define VG_X86_FEAT_SEP (VG_X86_FEAT*32 + 11)
94#define VG_X86_FEAT_MTRR (VG_X86_FEAT*32 + 12)
95#define VG_X86_FEAT_PGE (VG_X86_FEAT*32 + 13)
96#define VG_X86_FEAT_MCA (VG_X86_FEAT*32 + 14)
97#define VG_X86_FEAT_CMOV (VG_X86_FEAT*32 + 15)
98#define VG_X86_FEAT_PAT (VG_X86_FEAT*32 + 16)
99#define VG_X86_FEAT_PSE36 (VG_X86_FEAT*32 + 17)
100#define VG_X86_FEAT_CLFSH (VG_X86_FEAT*32 + 19)
101#define VG_X86_FEAT_DS (VG_X86_FEAT*32 + 21)
102#define VG_X86_FEAT_ACPI (VG_X86_FEAT*32 + 22)
103#define VG_X86_FEAT_MMX (VG_X86_FEAT*32 + 23)
104#define VG_X86_FEAT_FXSR (VG_X86_FEAT*32 + 24)
105#define VG_X86_FEAT_SSE (VG_X86_FEAT*32 + 25)
106#define VG_X86_FEAT_SSE2 (VG_X86_FEAT*32 + 26)
107#define VG_X86_FEAT_SS (VG_X86_FEAT*32 + 27)
108#define VG_X86_FEAT_HT (VG_X86_FEAT*32 + 28)
109#define VG_X86_FEAT_TM (VG_X86_FEAT*32 + 29)
110#define VG_X86_FEAT_IA64 (VG_X86_FEAT*32 + 30)
111#define VG_X86_FEAT_PBE (VG_X86_FEAT*32 + 31)
112
113/* Intel extended feature word */
114#define VG_X86_FEAT_SSE3 (VG_EXT_FEAT*32 + 0)
115#define VG_X86_FEAT_MON (VG_EXT_FEAT*32 + 3)
116#define VG_X86_FEAT_DSCPL (VG_EXT_FEAT*32 + 4)
117#define VG_X86_FEAT_EST (VG_EXT_FEAT*32 + 7)
118#define VG_X86_FEAT_TM2 (VG_EXT_FEAT*32 + 8)
119#define VG_X86_FEAT_CNXTID (VG_EXT_FEAT*32 + 10)
fitzhardinge0df2ac22004-01-25 02:38:29 +0000120
121/* Used internally to mark whether CPUID is even implemented */
fitzhardinge27574172004-01-26 21:11:51 +0000122#define VG_X86_FEAT_CPUID (VG_INT_FEAT*32 + 0)
fitzhardinge0df2ac22004-01-25 02:38:29 +0000123
fitzhardinge27574172004-01-26 21:11:51 +0000124/* AMD special features */
125#define VG_AMD_FEAT_SYSCALL (VG_AMD_FEAT*32 + 11)
126#define VG_AMD_FEAT_NXP (VG_AMD_FEAT*32 + 20)
127#define VG_AMD_FEAT_MMXEXT (VG_AMD_FEAT*32 + 22)
128#define VG_AMD_FEAT_FFXSR (VG_AMD_FEAT*32 + 25)
129#define VG_AMD_FEAT_LONGMODE (VG_AMD_FEAT*32 + 29)
130#define VG_AMD_FEAT_3DNOWEXT (VG_AMD_FEAT*32 + 30)
131#define VG_AMD_FEAT_3DNOW (VG_AMD_FEAT*32 + 31)
132
nethercote463c63c2004-10-26 11:18:32 +0000133#endif /* __CORE_ASM_H */
sewardjde4a1d02002-03-22 01:27:54 +0000134
135/*--------------------------------------------------------------------*/
nethercote5a2664c2004-09-02 15:37:39 +0000136/*--- end ---*/
sewardjde4a1d02002-03-22 01:27:54 +0000137/*--------------------------------------------------------------------*/