aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/register.h
diff options
context:
space:
mode:
authorMartin Schmölzer <martin@schmoelzer.at>2013-01-08 09:53:40 +0100
committerMartin Schmölzer <martin@schmoelzer.at>2013-01-08 09:53:40 +0100
commit94502c39a77af945db5b1615157894428305e5bf (patch)
tree443dcc59381e5f45104e408e9c50587be453328b /kernel/register.h
parent4f6cda502d8633068ebd137bbeb6cbc6bfabf938 (diff)
parenta24086d1db96b4f3553e279985331e49482934bc (diff)
downloadyosys-94502c39a77af945db5b1615157894428305e5bf.tar.gz
yosys-94502c39a77af945db5b1615157894428305e5bf.tar.bz2
yosys-94502c39a77af945db5b1615157894428305e5bf.zip
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'kernel/register.h')
-rw-r--r--kernel/register.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/kernel/register.h b/kernel/register.h
index 713d468e3..56350be34 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;