blob: 24626151ae7cc3339e683525d97ae68d35c170df [file] [log] [blame]
sewardjde4a1d02002-03-22 01:27:54 +00001
2/*--------------------------------------------------------------------*/
njn2e8f4ef2005-05-14 21:44:20 +00003/*--- Asm-only TransTab stuff. pub_core_transtab_asm.h ---*/
sewardjde4a1d02002-03-22 01:27:54 +00004/*--------------------------------------------------------------------*/
5
6/*
njnb9c427c2004-12-01 14:14:42 +00007 This file is part of Valgrind, a dynamic binary instrumentation
8 framework.
sewardjde4a1d02002-03-22 01:27:54 +00009
njn2e8f4ef2005-05-14 21:44:20 +000010 Copyright (C) 2000-2005 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
njn2e8f4ef2005-05-14 21:44:20 +000031#ifndef __PUB_CORE_TRANSTAB_ASM_H
32#define __PUB_CORE_TRANSTAB_ASM_H
sewardj91f62782004-11-29 19:47:54 +000033
sewardj3387dda2005-12-26 17:58:58 +000034/* Constants for the fast translation lookup cache. It is a direct
35 mapped cache, with 2^VG_TT_FAST_BITS entries.
36
37 On x86/amd64, the cache index is computed as
38 'address[VG_TT_FAST_BITS-1 : 0]'.
39
40 On ppc32/ppc64, the bottom two bits of instruction addresses are
41 zero, which means that function causes only 1/4 of the entries to
42 ever be used. So instead the function is '(address >>u
43 2)[VG_TT_FAST_BITS-1 : 0]' on those targets. */
44
sewardjce29f372005-10-19 11:23:07 +000045#define VG_TT_FAST_BITS 15
sewardjde4a1d02002-03-22 01:27:54 +000046#define VG_TT_FAST_SIZE (1 << VG_TT_FAST_BITS)
47#define VG_TT_FAST_MASK ((VG_TT_FAST_SIZE) - 1)
48
sewardj3387dda2005-12-26 17:58:58 +000049/* This macro isn't usable in asm land; nevertheless this seems
50 like a good place to put it. */
51#if defined(VGA_x86) || defined(VGA_amd64)
52# define VG_TT_FAST_HASH(_addr) ((((UWord)(_addr)) ) & VG_TT_FAST_MASK)
53#elif defined(VGA_ppc32) || defined(VGA_ppc64)
54# define VG_TT_FAST_HASH(_addr) ((((UWord)(_addr)) >> 2) & VG_TT_FAST_MASK)
55#else
56# error "VG_TT_FAST_HASH: unknown platform"
57#endif
58
njn2e8f4ef2005-05-14 21:44:20 +000059#endif // __PUB_CORE_TRANSTAB_ASM_H
sewardjde4a1d02002-03-22 01:27:54 +000060
61/*--------------------------------------------------------------------*/
nethercote5a2664c2004-09-02 15:37:39 +000062/*--- end ---*/
sewardjde4a1d02002-03-22 01:27:54 +000063/*--------------------------------------------------------------------*/