mirror of
https://github.com/Zenithsiz/ftmemsim-valgrind.git
synced 2026-02-08 21:09:49 +00:00
* Add new client request VALGRIND_HG_CLEAN_MEMORY_HEAPBLOCK. This is like VALGRIND_HG_CLEAN_MEMORY but doesn't take an address range. Instead it takes a single argument which is supposed to be a pointer to the start of, or anywhere within, a heap allocated block. Helgrind then finds the block and paints it as belonging to the calling thread. This is needed for correctly describing the behaviour of threadsafe reference counting when applied to classes involving inheritance of release methods or involving multiple inheritance. * Add statistics counters for all basic VTS operations (tick, join, cmpLEQ, cmp_structural). * Rewrite VTS__cmp_structural to be much faster. git-svn-id: svn://svn.valgrind.org/valgrind/trunk@11123
87 lines
3.9 KiB
C
87 lines
3.9 KiB
C
|
|
/*--------------------------------------------------------------------*/
|
|
/*--- Error management for Helgrind. ---*/
|
|
/*--- hg_errors.h ---*/
|
|
/*--------------------------------------------------------------------*/
|
|
|
|
/*
|
|
This file is part of Helgrind, a Valgrind tool for detecting errors
|
|
in threaded programs.
|
|
|
|
Copyright (C) 2007-2010 OpenWorks Ltd
|
|
info@open-works.co.uk
|
|
|
|
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 __HG_ERRORS_H
|
|
#define __HG_ERRORS_H
|
|
|
|
|
|
/* The standard bundle of error management functions that we are
|
|
required to present to the core/tool interface at startup. */
|
|
Bool HG_(eq_Error) ( VgRes not_used, Error* e1, Error* e2 );
|
|
void HG_(before_pp_Error) ( Error* err );
|
|
void HG_(pp_Error) ( Error* err );
|
|
UInt HG_(update_extra) ( Error* err );
|
|
Bool HG_(recognised_suppression) ( Char* name, Supp *su );
|
|
Bool HG_(read_extra_suppression_info) ( Int fd, Char** bufpp, SizeT* nBufp,
|
|
Supp* su );
|
|
Bool HG_(error_matches_suppression) ( Error* err, Supp* su );
|
|
Char* HG_(get_error_name) ( Error* err );
|
|
Bool HG_(get_extra_suppression_info) ( Error* err,
|
|
/*OUT*/Char* buf, Int nBuf );
|
|
|
|
/* Functions for recording various kinds of errors. */
|
|
void HG_(record_error_Race) ( Thread* thr,
|
|
Addr data_addr, Int szB, Bool isWrite,
|
|
Thread* h1_confthr,
|
|
ExeContext* h1_ct_segstart,
|
|
ExeContext* h1_ct_mbsegend );
|
|
void HG_(record_error_UnlockUnlocked) ( Thread*, Lock* );
|
|
void HG_(record_error_UnlockForeign) ( Thread*, Thread*, Lock* );
|
|
void HG_(record_error_UnlockBogus) ( Thread*, Addr );
|
|
void HG_(record_error_PthAPIerror) ( Thread*, HChar*, Word, HChar* );
|
|
void HG_(record_error_LockOrder) ( Thread*, Addr, Addr,
|
|
ExeContext*, ExeContext* );
|
|
void HG_(record_error_Misc) ( Thread*, HChar* );
|
|
|
|
/* Statistics pertaining to error management. */
|
|
extern ULong HG_(stats__LockN_to_P_queries);
|
|
extern ULong HG_(stats__LockN_to_P_get_map_size) ( void );
|
|
extern ULong HG_(stats__string_table_queries);
|
|
extern ULong HG_(stats__string_table_get_map_size) ( void );
|
|
|
|
/* For error creation: map 'data_addr' to a malloc'd chunk, if any.
|
|
Slow linear search accelerated in some special cases normal hash
|
|
search of the mallocmeta table. This is an abuse of the normal file
|
|
structure since this is exported by hg_main.c, not hg_errors.c. Oh
|
|
Well. Returns True if found, False if not. Zero-sized blocks are
|
|
considered to contain the searched-for address if they equal that
|
|
address. */
|
|
Bool HG_(mm_find_containing_block)( /*OUT*/ExeContext** where,
|
|
/*OUT*/Addr* payload,
|
|
/*OUT*/SizeT* szB,
|
|
Addr data_addr );
|
|
|
|
#endif /* ! __HG_ERRORS_H */
|
|
|
|
/*--------------------------------------------------------------------*/
|
|
/*--- end hg_errors.h ---*/
|
|
/*--------------------------------------------------------------------*/
|