当前位置: 首页>>代码示例>>C++>>正文


C++ Address::getBase方法代码示例

本文整理汇总了C++中Address::getBase方法的典型用法代码示例。如果您正苦于以下问题:C++ Address::getBase方法的具体用法?C++ Address::getBase怎么用?C++ Address::getBase使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Address的用法示例。


在下文中一共展示了Address::getBase方法的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: while

/// \brief Resolves the strongly connected components from the graph
void OffsetBasedAliasAnalysis::resolveSCCs
(std::map<int,std::pair<OffsetPointer*, int> > sccs) {
  std::deque<OffsetPointer*> dq;
  for(auto i : offset_pointers) i.second->color = 0;
  
  for(auto i : sccs) {
    dq.clear();
    DFS_visit_t_scc(i.second.first, &dq);
    
    while(!dq.empty()) {
      OffsetPointer* rp = dq.front();
      dq.pop_front();
      
      std::deque<Address*> ad;
      std::set<Address*> fn;
      
      //it expanded itself
      std::pair<OffsetPointer*, Offset> p = 
      std::pair<OffsetPointer*, Offset>(rp,  Offset());
      for(auto j = rp->addr_begin(), je = rp->addr_end(); j != je; j++) {
        ad.push_front(*j);
        (*j)->expanded.insert(p);
      }
      
      while(!ad.empty()) {
        Address* addr = ad.front();
        ad.pop_front();
        
        if
        (
          (addr->getBase()->scc == rp->scc)
          and
          (
            (addr->getBase()->getPointerType() == OffsetPointer::Phi) 
            or
            (addr->getBase()->getPointerType() == OffsetPointer::Cont)
          )
        ) {
          // if its in the same scc we must expand
          addr->Expand(ad, fn);
        } else {
          // if its not from the same scc there's nothing more to be done
          fn.insert(addr);
        }
      }
    }
  }
}
开发者ID:vmpaisante,项目名称:obaa,代码行数:49,代码来源:OffsetBasedAliasAnalysis.cpp

示例2: getPathToRoot

/// \brief Function that finds the pointer's path to the root of it's local
/// tree.
/// TODO: Optimize function to take advantage of topological ordering.
void OffsetPointer::getPathToRoot() {
  OffsetPointer* current = this;
  int index = 0;
  Offset offset;
  while(true) {
    path_to_root[current] = std::pair<int, Offset>(index, offset);
    if(current->addresses.size() == 1) {
      Address* addr = *(current->addresses.begin());
      current = addr->getBase();
      if(path_to_root.count(current)) {
        //This means that the local tree is actually a lonely loop
      	// so the local tree's root will be the pointer with the highest address
      	OffsetPointer* root = NULL;
      	for(auto i : path_to_root){
      		if(root < i.first) root = i.first;
      	}
      	local_root = root;
      	break;
      }
      index++;
      offset = offset + addr->getOffset();
    } else {
      local_root = current;
      break;
    }
  }
}
开发者ID:vmpaisante,项目名称:obaa,代码行数:30,代码来源:OffsetPointer.cpp

示例3: while

// Resolves the sccs in the dependence graph
void RangeBasedPointerAnalysis::resolveSCCs
	(std::map<int,std::pair<RangedPointer*, int> > sccs)
{
 std::deque<RangedPointer*> dq;
 for(auto i : RangedPointers) i.second->color = 0;
  for(auto i : sccs)
  {
    //std::cout << i.first << "/" << scc << "\n"; 
    // if the scc has more then one pointer than there is a loop
    //if(i.second.second > 1)
    {
      dq.clear();
      SCC_DFS_visit(i.second.first, &dq);
      
      while(!dq.empty())
      {
        RangedPointer* rp = dq.front();
        dq.pop_front();
        
        //std::cout << rp << "\n";
        
        std::deque<Address*> ad;
        std::set<Address*> fn;
        
        std::pair<RangedPointer*, Range> p = 
          std::pair<RangedPointer*, Range>(rp,  Range(Expr(*SI, 0)));
        for(auto j = rp->addr_begin(), je = rp->addr_end(); j != je; j++)
        {
          ad.push_front(*j);
          (*j)->expanded.insert(p);
        }
        
        while(!ad.empty())
        {
          //std::cout << "ad: " << ad.size() << "\n";
          Address* addr = ad.front();
          ad.pop_front();
          
          if(addr->getBase()->scc == rp->scc)
          {
            //std::cout << "expand\n";
            addr->Expand(ad, fn);
          }
          else
          {
            //std::cout << "insert\n";
            fn.insert(addr);
          }
        }
      }
    }
  }
}
开发者ID:Uncannytable,项目名称:rbaa,代码行数:54,代码来源:RangeBasedPointerAnalysis.cpp

示例4: resolveWholeGraph

/// \brief Resolves the whole graph
void OffsetBasedAliasAnalysis::resolveWholeGraph() {
  std::deque<OffsetPointer*> dq;
  for(auto i : offset_pointers) i.second->color = 0;
  for(auto i : offset_pointers) {
    if(i.second->getPointerType() != OffsetPointer::Cont 
      and i.second->color == 0) {
      DFS_visit_t(i.second, &dq);
    }
  }
  
  while(!dq.empty()) {
    OffsetPointer* rp = dq.front();
    dq.pop_front();
    
    std::deque<Address*> ad;
    std::set<Address*> fn;
    
    for(auto j = rp->addr_begin(), je = rp->addr_end(); j != je; j++)
      ad.push_front(*j);
      
    while(!ad.empty()) {
      Address* addr = ad.front();
      ad.pop_front();
      
      if(addr->getBase() == addr->getAddressee()) {
        //if the base is the very addressee, then we have a meaningless loop
        delete addr;
      } else if(addr->getBase()->getPointerType() == OffsetPointer::Phi 
      or addr->getBase()->getPointerType() == OffsetPointer::Cont) {
        //if its a phi or a continuous pointer there must be expansion
        addr->Expand(ad, fn);
      } else {
        //if its not a phi or a continuous pointer there's nothing more to 
        // be done
        fn.insert(addr);
      }
    }
  }
}
开发者ID:vmpaisante,项目名称:obaa,代码行数:40,代码来源:OffsetBasedAliasAnalysis.cpp

示例5: resolveWholeGraph

// Resolves the whole graph
void RangeBasedPointerAnalysis::resolveWholeGraph()
{
	std::deque<RangedPointer*> dq;
  for(auto i : RangedPointers) i.second->color = 0;
  for(auto i : RangedPointers)
  {
    if(i.second->getPointerType() != RangedPointer::Cont 
      and i.second->color == 0)
    {
      DFS_visit(i.second, &dq);
    }
  }
  
  /*std::cout << "Expanded sizes:\n";
  for(auto i : RangedPointers)
  {
    for(auto j : i.second->Addresses)
    {
      std::cout << j->expanded.size();
      if(j->expanded.find(i.second) != j->expanded.end())
        std::cout << "SIM ";
      else
        std::cout << "NAO ";
    }
    std::cout << "\n";
  }
  int n;
  std::cin >> n;
  */
  
  while(!dq.empty())
  {
    RangedPointer* rp = dq.front();
    dq.pop_front();
    
    std::deque<Address*> ad;
    std::set<Address*> fn;
    
    for(auto j = rp->addr_begin(), je = rp->addr_end(); j != je; j++)
      ad.push_front(*j);
    
    while(!ad.empty())
    {
      Address* addr = ad.front();
      ad.pop_front();
      
      if(addr->getBase() == addr->getAddressee())
      {
        delete addr;
      }
      else if(addr->getBase()->getPointerType() == RangedPointer::Phi 
      or addr->getBase()->getPointerType() == RangedPointer::Cont)
      {
        //std::cout << "expand ";
        addr->Expand(ad, fn);
      }
      else
      {
        //std::cout << "insert\n";
        fn.insert(addr);
      }
    }
  }
}
开发者ID:Uncannytable,项目名称:rbaa,代码行数:65,代码来源:RangeBasedPointerAnalysis.cpp


注:本文中的Address::getBase方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。