| |
| /*--------------------------------------------------------------------*/ |
| /*--- Arch-specific declarations, cache configuration. cg_arch.h ---*/ |
| /*--------------------------------------------------------------------*/ |
| |
| /* |
| This file is part of Cachegrind, a Valgrind tool for cache |
| profiling programs. |
| |
| Copyright (C) 2002-2011 Nicholas Nethercote |
| njn@valgrind.org |
| |
| This program is free software; you can redistribute it and/or |
| modify it under the terms of the GNU General Public License as |
| published by the Free Software Foundation; either version 2 of the |
| License, or (at your option) any later version. |
| |
| This program is distributed in the hope that it will be useful, but |
| WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| General Public License for more details. |
| |
| You should have received a copy of the GNU General Public License |
| along with this program; if not, write to the Free Software |
| Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA |
| 02111-1307, USA. |
| |
| The GNU General Public License is contained in the file COPYING. |
| */ |
| |
| #ifndef __CG_ARCH_H |
| #define __CG_ARCH_H |
| |
| // For cache simulation |
| typedef struct { |
| Int size; // bytes |
| Int assoc; |
| Int line_size; // bytes |
| } cache_t; |
| |
| #define MIN_LINE_SIZE 16 |
| |
| // clo_*c used in the call to VG_(str_clo_cache_opt) should be statically |
| // initialized to UNDEFINED_CACHE. |
| #define UNDEFINED_CACHE { -1, -1, -1 } |
| |
| // Gives the auto-detected configuration of I1, D1 and LL caches. They get |
| // overridden by any cache configurations specified on the command line. |
| void VG_(configure_caches)(cache_t* I1c, cache_t* D1c, cache_t* LLc, |
| Bool all_caches_clo_defined); |
| |
| // If arg is a command line option configuring I1 or D1 or LL cache, |
| // then parses arg to set the relevant cache_t elements. |
| // Returns True if arg is a cache command line option, False otherwise. |
| Bool VG_(str_clo_cache_opt)(Char *arg, |
| cache_t* clo_I1c, |
| cache_t* clo_D1c, |
| cache_t* clo_LLc); |
| |
| // Checks the correctness of the auto-detected caches. |
| // If a cache has been configured by command line options, it |
| // replaces the equivalent auto-detected cache. |
| // Note that an invalid auto-detected cache will make Valgrind exit |
| // with an fatal error, except if the invalid auto-detected cache |
| // will be replaced by a command line defined cache. |
| void VG_(post_clo_init_configure_caches)(cache_t* I1c, |
| cache_t* D1c, |
| cache_t* LLc, |
| cache_t* clo_I1c, |
| cache_t* clo_D1c, |
| cache_t* clo_LLc); |
| |
| void VG_(print_cache_clo_opts)(void); |
| |
| #endif // __CG_ARCH_H |
| |
| /*--------------------------------------------------------------------*/ |
| /*--- end ---*/ |
| /*--------------------------------------------------------------------*/ |