[cfe-dev] Proposed: change tracking for RegionStore
jediknil at belkadan.com
Fri Jul 30 15:33:08 PDT 2010
On Fri, 30 Jul 2010 13:29:57 -0700, Ted Kremenek <kremenek at apple.com>
> On Jul 30, 2010, at 12:56 PM, Jordy Rose wrote:
>> It's mainly an API problem as well. A StoreManager may do multiple
>> or Remove() calls as part of a single action, and between those actions
>> store isn't exactly in a reasonable state. For example, the old code
>> initializing an array with a string would copy each element of the
>> into the array. All that happens here is that change markers get
>> redundantly cleared, but with callbacks the observer might be able to
>> the store with undefined values, or whatever.
>> (I haven't looked through RegionStore to see if that's actually true.)
>> Moving the callback up to Bind or Invalidate might work,
> This is the level I was thinking of.
>> but then the
>> stores would have to keep track of every region touched during the call
>> annoying, but not impossible.
> Not necessarily. Instead of tracking all regions that modified, we can
> have a registered list of subscribers (provides as input to
> Bind/Invalidate) that want to know when *specific* regions (and/or their
> subregions) have been touched. If there are no subscribers, then we
> nothing. If there are subscribers, we only record information for
> that they have said they care about. Most subscribers will only care
> regions for which they have checker-specific state, and that set should
That's true, but I meant we have to pass a list down from method to method
for any possible modifications. The simplest way would be to add all
regions to the list, but we could also pass a set of interesting regions
and have the methods mark the ones that are touched.
Would it be better to store a region<->listeners map or a listener set
that we then query for a list of regions? I'm leaning towards the former.
>> This could still show up during a larger
>> operation, since the StoreManager doesn't know who's modifying the
>> (It could be part of modeling a function's behavior, for example.)
> That is true, and we want individual subscribers (which are probably
> Checkers) to have the ability to interject new analysis state (either
> new GRState objects or ExplodedNodes). Not every call to
> is structured to work that way, but it could probably be done.
> One thing I like about this approach is that it could be a natural
> extension of the Checker callback interface.
If that's the case, what's the best way for checkers to register their
interest in a region? Do they register with the GRExprEngine, the
GRStateManager, or directly with the StoreManager?
And hm. How can we inject new analysis state at the level of Bind or
Invalidate, where only the Store is being changed? Not all store-modifying
code goes through GRState.
>> If we can work out the right API for that, I'd be happy to switch over.
>> First pass: any call that returns a new Store will call
>> void RegionWatcher::RegionChanged(Store NewStore, const MemRegion *MR)
>> for each region, and it's up to the RegionWatcher to traverse
Super-regions, sorry. If we're figuring out which observers to notify
within the store, however, it's going to have to be the store's
responsibility to check super-regions.
>> This would probably be using the logical view of regions
>> rather than the internal view, which I'm still not sure is better.
> Subscribers/checkers need to be StoreManager agnostic, and in the common
> cases they will be reasoning (with checker-specific state) about
> SymbolicRegions and VarRegions (or other "base" regions). We really
> want checkers to get into the business of directly reasoning about
> individual array elements, as that could implicitly require discretizing
> the representation of the contents of the array instead of reasoning
> it symbolically.
Good point, never mind.
More information about the cfe-dev