Program Listing for File SSA.h

Program Listing for File SSA.h#

Return to documentation for file (src/midend/programAnalysis/OpenAnalysis/SSA/SSA.h)

// $Id: SSA.h,v 1.1 2004/07/07 10:26:34 dquinlan Exp $
// -*-C++-*-
// * BeginRiceCopyright *****************************************************
//
// Copyright ((c)) 2002, Rice University
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
//   notice, this list of conditions and the following disclaimer.
//
// * Redistributions in binary form must reproduce the above copyright
//   notice, this list of conditions and the following disclaimer in the
//   documentation and/or other materials provided with the distribution.
//
// * Neither the name of Rice University (RICE) nor the names of its
//   contributors may be used to endorse or promote products derived from
//   this software without specific prior written permission.
//
// This software is provided by RICE and contributors "as is" and any
// express or implied warranties, including, but not limited to, the
// implied warranties of merchantability and fitness for a particular
// purpose are disclaimed. In no event shall RICE or contributors be
// liable for any direct, indirect, incidental, special, exemplary, or
// consequential damages (including, but not limited to, procurement of
// substitute goods or services; loss of use, data, or profits; or
// business interruption) however caused and on any theory of liability,
// whether in contract, strict liability, or tort (including negligence
// or otherwise) arising in any way out of the use of this software, even
// if advised of the possibility of such damage.
//
// ******************************************************* EndRiceCopyright *

// Best seen in 120-column wide window (or print in landscape mode).
//--------------------------------------------------------------------------------------------------------------------
// This file is part of Mint.
// Arun Chauhan (achauhan@cs.rice.edu), Dept of Computer Science, Rice University, 2001.
//--------------------------------------------------------------------------------------------------------------------

#ifndef SSA_H
#define SSA_H

//--------------------------------------------------------------------------------------------------------------------
// OpenAnalysis headers
#include "DomTree.h"
#include "Phi.h"
//--------------------------------------------------------------------------------------------------------------------


//--------------------------------------------------------------------------------------------------------------------
class SSA {
public:
  SSA (CFG& _cfg);
  ~SSA () {}
  class PhiNodesIterator;
  friend class PhiNodesIterator;

  //------------------------------------------------------------------------------------------------------------------
  class Use;
  class Def {
  public:
    virtual ~Def () {}
    virtual void dump (ostream&) = 0;
    virtual std::list<Use*>* uses_list () = 0;
  };
  //------------------------------------------------------------------------------------------------------------------
  class Use {
  public:
    virtual ~Use () {}
    virtual void dump (ostream&) = 0;
    virtual Def* def () = 0;
  };
  //------------------------------------------------------------------------------------------------------------------
  class LeafDef : public Def {
  public:
    LeafDef (LeafHandle l) : Def() { leaf = l; }
    void dump (ostream&);
    std::list<Use*>* uses_list () { return &uses; }
  private:
    LeafHandle leaf;
    std::list<Use*> uses;
  };
  //------------------------------------------------------------------------------------------------------------------
  class PhiDef : public Def {
  public:
    PhiDef (Phi* p) : Def() { phi = p; }
    void dump (ostream&);
    std::list<Use*>* uses_list () { return &uses; }
  private:
    Phi* phi;
    std::list<Use*> uses;
  };
  //------------------------------------------------------------------------------------------------------------------
  class LeafUse : public Use {
  public:
    LeafUse (LeafHandle l) : Use() { leaf = l; }
    void dump (ostream&);
    Def* def () { return definition; }
  private:
    LeafHandle leaf;
    Def* definition;
  };
  //------------------------------------------------------------------------------------------------------------------
  class PhiUse : public Use {
  public:
    PhiUse (Phi* p) : Use() { phi = p; }
    void dump (ostream&);
    Def* def () { return definition; }
  private:
    Phi* phi;
    Def* definition;
  };
  //------------------------------------------------------------------------------------------------------------------
  class PhiNodesIterator : public Iterator {
  public:
    PhiNodesIterator (SSA& s, CFG::Node* n) { phi_set = &s.phi_node_sets[n];  iter = phi_set->begin(); }
    void operator++ () { ++iter; }
    operator bool () { return (iter != phi_set->end()); }
    operator Phi* () { return *iter; }
  private:
    std::set<Phi*>::iterator iter;
    std::set<Phi*>* phi_set;
  };
  //------------------------------------------------------------------------------------------------------------------

  void dump (ostream&);

private:
  CFG* cfg;
  std::map<CFG::Node*, std::set<Phi*> > phi_node_sets;
};
//--------------------------------------------------------------------------------------------------------------------

#endif