sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 1 | |
| 2 | /*--------------------------------------------------------------------*/ |
| 3 | /*--- Sets of words, with unique set identifiers. ---*/ |
| 4 | /*--- hg_wordset.h ---*/ |
| 5 | /*--------------------------------------------------------------------*/ |
| 6 | |
| 7 | /* |
| 8 | This file is part of Helgrind, a Valgrind tool for detecting errors |
| 9 | in threaded programs. |
| 10 | |
sewardj | 0f157dd | 2013-10-18 14:27:36 +0000 | [diff] [blame] | 11 | Copyright (C) 2007-2013 OpenWorks LLP |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 12 | info@open-works.co.uk |
| 13 | |
| 14 | This program is free software; you can redistribute it and/or |
| 15 | modify it under the terms of the GNU General Public License as |
| 16 | published by the Free Software Foundation; either version 2 of the |
| 17 | License, or (at your option) any later version. |
| 18 | |
| 19 | This program is distributed in the hope that it will be useful, but |
| 20 | WITHOUT ANY WARRANTY; without even the implied warranty of |
| 21 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| 22 | General Public License for more details. |
| 23 | |
| 24 | You should have received a copy of the GNU General Public License |
| 25 | along with this program; if not, write to the Free Software |
| 26 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA |
| 27 | 02111-1307, USA. |
| 28 | |
| 29 | The GNU General Public License is contained in the file COPYING. |
| 30 | |
| 31 | Neither the names of the U.S. Department of Energy nor the |
| 32 | University of California nor the names of its contributors may be |
| 33 | used to endorse or promote products derived from this software |
| 34 | without prior written permission. |
| 35 | */ |
| 36 | |
| 37 | #ifndef __HG_WORDSET_H |
| 38 | #define __HG_WORDSET_H |
| 39 | |
| 40 | //------------------------------------------------------------------// |
| 41 | //--- WordSet ---// |
| 42 | //--- Public Interface ---// |
| 43 | //------------------------------------------------------------------// |
| 44 | |
| 45 | typedef struct _WordSetU WordSetU; /* opaque */ |
| 46 | |
| 47 | typedef UInt WordSet; /* opaque, small int index */ |
| 48 | |
| 49 | /* Allocate and initialise a WordSetU */ |
florian | 54fe202 | 2012-10-27 23:07:42 +0000 | [diff] [blame] | 50 | WordSetU* HG_(newWordSetU) ( void* (*alloc_nofail)( const HChar*, SizeT ), |
| 51 | const HChar* cc, |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 52 | void (*dealloc)(void*), |
| 53 | Word cacheSize ); |
| 54 | |
| 55 | /* Free up the WordSetU. */ |
| 56 | void HG_(deleteWordSetU) ( WordSetU* ); |
| 57 | |
sewardj | 866c80c | 2011-10-22 19:29:51 +0000 | [diff] [blame] | 58 | /* Get the number of elements in this WordSetU. Note that the dead |
| 59 | WordSet are included in the WordSetU number of elements. */ |
sewardj | 250ec2e | 2008-02-15 22:02:30 +0000 | [diff] [blame] | 60 | UWord HG_(cardinalityWSU) ( WordSetU* ); |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 61 | |
| 62 | /* Show performance stats for this WordSetU. */ |
florian | 54fe202 | 2012-10-27 23:07:42 +0000 | [diff] [blame] | 63 | void HG_(ppWSUstats) ( WordSetU* wsu, const HChar* name ); |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 64 | |
| 65 | |
| 66 | /* Element-level operations on WordSets. Note that the WordSet |
| 67 | numbers given out are 0, 1, 2, 3, etc, and as it happens 0 always |
| 68 | represents the empty set. */ |
| 69 | |
| 70 | WordSet HG_(emptyWS) ( WordSetU* ); |
sewardj | 250ec2e | 2008-02-15 22:02:30 +0000 | [diff] [blame] | 71 | WordSet HG_(addToWS) ( WordSetU*, WordSet, UWord ); |
| 72 | WordSet HG_(delFromWS) ( WordSetU*, WordSet, UWord ); |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 73 | WordSet HG_(unionWS) ( WordSetU*, WordSet, WordSet ); |
| 74 | WordSet HG_(intersectWS) ( WordSetU*, WordSet, WordSet ); |
| 75 | WordSet HG_(minusWS) ( WordSetU*, WordSet, WordSet ); |
| 76 | Bool HG_(isEmptyWS) ( WordSetU*, WordSet ); |
sewardj | 250ec2e | 2008-02-15 22:02:30 +0000 | [diff] [blame] | 77 | Bool HG_(isSingletonWS) ( WordSetU*, WordSet, UWord ); |
| 78 | UWord HG_(anyElementOfWS) ( WordSetU*, WordSet ); |
| 79 | UWord HG_(cardinalityWS) ( WordSetU*, WordSet ); |
| 80 | Bool HG_(elemWS) ( WordSetU*, WordSet, UWord ); |
| 81 | WordSet HG_(doubletonWS) ( WordSetU*, UWord, UWord ); |
| 82 | WordSet HG_(singletonWS) ( WordSetU*, UWord ); |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 83 | WordSet HG_(isSubsetOf) ( WordSetU*, WordSet, WordSet ); |
| 84 | |
| 85 | Bool HG_(plausibleWS) ( WordSetU*, WordSet ); |
sewardj | 866c80c | 2011-10-22 19:29:51 +0000 | [diff] [blame] | 86 | |
| 87 | |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 88 | Bool HG_(saneWS_SLOW) ( WordSetU*, WordSet ); |
| 89 | |
| 90 | void HG_(ppWS) ( WordSetU*, WordSet ); |
sewardj | 866c80c | 2011-10-22 19:29:51 +0000 | [diff] [blame] | 91 | |
sewardj | 250ec2e | 2008-02-15 22:02:30 +0000 | [diff] [blame] | 92 | void HG_(getPayloadWS) ( /*OUT*/UWord** words, /*OUT*/UWord* nWords, |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 93 | WordSetU*, WordSet ); |
| 94 | |
sewardj | 866c80c | 2011-10-22 19:29:51 +0000 | [diff] [blame] | 95 | /* HG_(dieWS) indicates WordSet is not used/not referenced anymore, |
| 96 | and its memory can be reclaimed. |
| 97 | If ever a WordSet with the same content would be needed again, |
| 98 | a new WordSet will be reallocated. |
| 99 | |
| 100 | BUG ALERT: !!! Using HG_(dieWS) on a WSU introduces a risk of |
| 101 | dangling references. Dangling references can be created by keeping |
| 102 | a ws after having marked it dead. This ws (just an index in |
| 103 | reality) will be re-cycled : a newly created wv can get the same |
| 104 | index. This implies that the wrong wv will be used if the |
| 105 | "old" ws has been kept. |
| 106 | Re-using a "dead" ws will be detected if the index has not been |
| 107 | re-cycled yet. |
| 108 | |
| 109 | Another possibility of bug is to ask for the payload of a ws, and |
| 110 | then have this ws marked dead while the payload is still being |
| 111 | examined. This is a real dangling reference in free or re-allocated |
| 112 | memory. */ |
| 113 | void HG_(dieWS) ( WordSetU*, WordSet ); |
| 114 | |
| 115 | |
sewardj | b411202 | 2007-11-09 22:49:28 +0000 | [diff] [blame] | 116 | |
| 117 | //------------------------------------------------------------------// |
| 118 | //--- end WordSet ---// |
| 119 | //--- Public Interface ---// |
| 120 | //------------------------------------------------------------------// |
| 121 | |
| 122 | #endif /* ! __HG_WORDSET_H */ |
| 123 | |
| 124 | /*--------------------------------------------------------------------*/ |
| 125 | /*--- end hg_wordset.h ---*/ |
| 126 | /*--------------------------------------------------------------------*/ |