Hello,

I am trying to find out all pointers which alias a pointer and place them in a set.

I am using `ptr_derefs_may_alias_p` to find out if two pointers may point to the same memory location. I think this yields conservative results (i.e., when it cannot be proven that to pointers may alias, it will give the result "true"). This is what I need.

To collect all pointers which alias pointer "p", this means is that I have to collect all pointer variables and all pointer expressions in the program and then call `ptr_derefs_may_alias_p` O(n) times to find the set of pointers which alias pointer "p". If I have to do this for all pointers in the program, that would mean O(n^2).

This also implies that in order for my sets to be correct I need to collect all pointer variables and all pointer expressions. I think that a better idea would be to have a list of all bitmap solutions and for every variable with a bitmap if position j is set, assigned to alias set j. In pseudocode:

compute_alias_sets(bitmap set)
{
  // create array of sets of same length as varmap
  // call it alias_map
  for (i = 0; i < varmap.length (); i++)
  {
    bitmap set = get_varinfo(i)->solution;
    EXECUTE_IF_SET_IN_BITMAP (set, 0, j, bi)
    {
      varinfo_t v = get_varinfo (j);
      alias_map[j].insert(v);
    }
  }
}

I think this is a better implementation. I don't need to worry about collecting all pointer expressions and I think varmap also contains declarations. (I think IPA-PTA already has "collected" all pointer expressions/declarations in varmap and created constraint variables for them.) *Would there be an issue with exporting varmap and delaying its deletion to this pass I'm working on?* This pass is intended to be run immediately after IPA-PTA. After this, I think I would still need to do some refining on the "alias_map" since (I think) there are more constraint variables than gimple variables in the partition, but the information I look for should be able to be derived from here.

Thanks!

Reply via email to