diff options
author | Clifford Wolf <clifford@clifford.at> | 2013-01-06 13:50:30 +0100 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2013-01-06 13:50:30 +0100 |
commit | ae731369ddb8838302b5d9a3fa32689c44ab7934 (patch) | |
tree | e66382b963b39412e6ec6c91eab7513a59bdf611 /kernel/register.h | |
parent | bc630ba0fa249c09d4f3fb5ef48eb6d573a21879 (diff) |
Improvements in command shell
- Added 'shell' command (run interactive shell from synth script)
- Added support for ; as cmd seperator as in "proc; opt"
- Fixed c++ static initialization order problem with pass register
Diffstat (limited to 'kernel/register.h')
-rw-r--r-- | kernel/register.h | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/kernel/register.h b/kernel/register.h index 713d468e..56350be3 100644 --- a/kernel/register.h +++ b/kernel/register.h @@ -30,6 +30,7 @@ struct Pass { std::string pass_name; Pass(std::string name); + virtual void run_register(); virtual ~Pass(); virtual void help(); virtual void execute(std::vector<std::string> args, RTLIL::Design *design) = 0; @@ -40,12 +41,16 @@ struct Pass static void call(RTLIL::Design *design, std::string command); static void call(RTLIL::Design *design, std::vector<std::string> args); + + static void init_register(); + static void done_register(); }; struct Frontend : Pass { std::string frontend_name; Frontend(std::string name); + virtual void run_register(); virtual ~Frontend(); virtual void execute(std::vector<std::string> args, RTLIL::Design *design); virtual void execute(FILE *&f, std::string filename, std::vector<std::string> args, RTLIL::Design *design) = 0; @@ -61,6 +66,7 @@ struct Backend : Pass { std::string backend_name; Backend(std::string name); + virtual void run_register(); virtual ~Backend(); virtual void execute(std::vector<std::string> args, RTLIL::Design *design); virtual void execute(FILE *&f, std::string filename, std::vector<std::string> args, RTLIL::Design *design) = 0; @@ -72,6 +78,9 @@ struct Backend : Pass }; namespace REGISTER_INTERN { + extern int raw_register_count; + extern bool raw_register_done; + extern Pass *raw_register_array[]; extern std::map<std::string, Pass*> pass_register; extern std::map<std::string, Frontend*> frontend_register; extern std::map<std::string, Backend*> backend_register; |