blob: c5e307671e5db5673b4b4b56a883271183df2988 [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
njn9f207462009-03-10 22:02:09 +000010 Copyright (C) 2000-2009 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
sewardj59570ff2010-01-01 11:59:33 +000043 2)[VG_TT_FAST_BITS-1 : 0]' on those targets.
44
45 On ARM we do like ppc32/ppc64, although that will have to be
46 revisited when we come to implement Thumb. */
sewardj3387dda2005-12-26 17:58:58 +000047
sewardjce29f372005-10-19 11:23:07 +000048#define VG_TT_FAST_BITS 15
sewardjde4a1d02002-03-22 01:27:54 +000049#define VG_TT_FAST_SIZE (1 << VG_TT_FAST_BITS)
50#define VG_TT_FAST_MASK ((VG_TT_FAST_SIZE) - 1)
51
sewardj3387dda2005-12-26 17:58:58 +000052/* This macro isn't usable in asm land; nevertheless this seems
53 like a good place to put it. */
54#if defined(VGA_x86) || defined(VGA_amd64)
55# define VG_TT_FAST_HASH(_addr) ((((UWord)(_addr)) ) & VG_TT_FAST_MASK)
sewardj59570ff2010-01-01 11:59:33 +000056#elif defined(VGA_ppc32) || defined(VGA_ppc64) || defined(VGA_arm)
sewardj3387dda2005-12-26 17:58:58 +000057# define VG_TT_FAST_HASH(_addr) ((((UWord)(_addr)) >> 2) & VG_TT_FAST_MASK)
58#else
59# error "VG_TT_FAST_HASH: unknown platform"
60#endif
61
njn2e8f4ef2005-05-14 21:44:20 +000062#endif // __PUB_CORE_TRANSTAB_ASM_H
sewardjde4a1d02002-03-22 01:27:54 +000063
64/*--------------------------------------------------------------------*/
nethercote5a2664c2004-09-02 15:37:39 +000065/*--- end ---*/
sewardjde4a1d02002-03-22 01:27:54 +000066/*--------------------------------------------------------------------*/