MimIR 0.1
MimIR is my Intermediate Representation
|
SSA construction algorithm that promotes slots, loads, and stores to SSA values. More...
#include <mim/plug/mem/pass/ssa.h>
Classes | |
struct | Info |
Public Types | |
enum | : u32 { Phixy , Sloxy , Traxy } |
using | Data = GIDNodeMap<Lam*, Info> |
![]() | |
using | Super |
using | Data |
Default. | |
Public Member Functions | |
SSA (World &world, flags_t annex) | |
void | init (PassMan *) final |
![]() | |
FPPass (World &world, std::string name) | |
FPPass (World &world, flags_t annex) | |
bool | fixed_point () const override |
![]() | |
RWPass (World &world, std::string name) | |
RWPass (World &world, flags_t annex) | |
bool | inspect () const override |
Should the PassMan even consider this pass? | |
Lam * | curr_mut () const |
![]() | |
Pass (World &world, std::string name) | |
Pass (World &world, flags_t annex) | |
PassMan & | man () |
const PassMan & | man () const |
size_t | index () const |
virtual const Def * | rewrite (const Var *var) |
virtual undo_t | analyze (const Var *) |
virtual void | prepare () |
Invoked once before entering the main rewrite loop. | |
const Proxy * | proxy (const Def *type, Defs ops, u32 tag=0) |
const Proxy * | isa_proxy (const Def *def, u32 tag=0) |
Check whether given def is a Proxy whose Proxy::pass matches this Pass's IPass::index . | |
const Proxy * | as_proxy (const Def *def, u32 tag=0) |
![]() | |
World & | world () |
Driver & | driver () |
Log & | log () const |
std::string_view | name () const |
flags_t | annex () const |
Stage (World &world, std::string name) | |
Stage (World &world, flags_t annex) | |
virtual | ~Stage ()=default |
virtual std::unique_ptr< Stage > | recreate () |
Creates a new instance; needed by a fixed-point PhaseMan. | |
virtual void | apply (const App *) |
Invoked if your Stage has additional args. | |
virtual void | apply (Stage &) |
Dito, but invoked by Stage::recreate. | |
Private Member Functions | |
PassMan hooks | |
void | enter () override |
Invoked just before Pass::rewriteing PassMan::curr_mut's body. | |
const Def * | rewrite (const Proxy *) override |
const Def * | rewrite (const Def *) override |
undo_t | analyze (const Proxy *) override |
undo_t | analyze (const Def *) override |
SSA construction helpers - see paper |
Additional Inherited Members | |
static auto | create (const Flags2Stages &stages, const Def *def) |
template<class A, class P> | |
static void | hook (Flags2Stages &stages) |
![]() | |
const auto & | states () const |
auto & | states () |
auto & | data () |
auto & | data () |
auto & | data (const K &key) |
Use this for your convenience if P::Data is a map. | |
auto & | data (const K &key) |
Use this for your convenience if P::Data<I> is a map. | |
undo_t | curr_undo () const |
Current undo point. | |
undo_t | undo_visit (Def *mut) const |
Retrieves the point to backtrack to just before mut was seen the very first time. | |
undo_t | undo_enter (Def *mut) const |
Retrieves the point to backtrack to just before rewriting mut's body. | |
![]() | |
std::string | name_ |
SSA construction algorithm that promotes slots, loads, and stores to SSA values.
This is loosely based upon: "Simple and Efficient Construction of Static Single Assignment Form" by Braun, Buchwald, Hack, Leißa, Mallon, Zwinkau.
struct mim::plug::mem::pass::SSA::Info |
using mim::plug::mem::pass::SSA::Data = GIDNodeMap<Lam*, Info> |
Definition at line 17 of file ssa.h.
References mim::Stage::annex(), mim::FPPass< SSA, Lam >::FPPass(), and mim::Stage::world().
Reimplemented from mim::Pass.
Definition at line 163 of file ssa.cpp.
References mim::RWPass< SSA, Lam >::curr_mut(), mim::FPPass< SSA, Lam >::data(), DLOG, mim::Lam::isa_basicblock(), mim::isa_callee(), mim::Def::isa_mut(), mim::isa_workable(), mim::No_Undo, mim::Def::num_ops(), and mim::Def::op().
Reimplemented from mim::Pass.
Definition at line 143 of file ssa.cpp.
References DLOG, mim::No_Undo, Phixy, mim::Pass::proxy(), Sloxy, mim::FPPass< SSA, Lam >::undo_enter(), and mim::FPPass< SSA, Lam >::undo_visit().
|
overrideprivatevirtual |
Invoked just before Pass::rewriteing PassMan::curr_mut's body.
Reimplemented from mim::Pass.
Definition at line 22 of file ssa.cpp.
References mim::RWPass< SSA, Lam >::curr_mut().
|
finalvirtual |
Reimplemented from mim::Pass.
Definition at line 17 of file ssa.cpp.
References mim::Pass::init(), mim::Pass::man(), and mim::Pass::PassMan.
Reimplemented from mim::Pass.
Definition at line 35 of file ssa.cpp.
References mim::RWPass< SSA, Lam >::curr_mut(), mim::FPPass< SSA, Lam >::data(), DLOG, mim::Axm::isa(), mim::isa_apped_mut_lam(), mim::Def::isa_mut(), mim::Pass::isa_proxy(), mim::isa_workable(), mim::Def::num_ops(), mim::Def::op(), mim::plug::mem::op_remem(), mim::Pass::proxy(), mim::Def::refine(), mim::Def::set(), Sloxy, mim::World::tuple(), and mim::Stage::world().
Reimplemented from mim::Pass.
Definition at line 24 of file ssa.cpp.
References mim::Pass::as_proxy(), mim::RWPass< SSA, Lam >::curr_mut(), DLOG, mim::Pass::proxy(), Sloxy, and Traxy.