summaryrefslogtreecommitdiff
path: root/src/mem/slicc
diff options
context:
space:
mode:
authorSteve Reinhardt <steve.reinhardt@amd.com>2010-01-29 20:29:17 -0800
committerSteve Reinhardt <steve.reinhardt@amd.com>2010-01-29 20:29:17 -0800
commitc6f1d959be74de55b0c90f3c961314791342d03e (patch)
treed0ef0777894828291a6ced188c8bcae323cea442 /src/mem/slicc
parent98c94cfe3ce83634f3bad79ca18263f42e36ca6a (diff)
downloadgem5-c6f1d959be74de55b0c90f3c961314791342d03e.tar.xz
ruby: Make SLICC-generated objects SimObjects.
Also add SLICC support for state-machine parameter defaults (passed through to Python as SimObject Param defaults).
Diffstat (limited to 'src/mem/slicc')
-rw-r--r--src/mem/slicc/ast/FormalParamAST.py3
-rw-r--r--src/mem/slicc/ast/MachineAST.py1
-rw-r--r--src/mem/slicc/parser.py6
-rw-r--r--src/mem/slicc/symbols/StateMachine.py85
-rw-r--r--src/mem/slicc/symbols/SymbolTable.py57
-rw-r--r--src/mem/slicc/symbols/Type.py1
6 files changed, 53 insertions, 100 deletions
diff --git a/src/mem/slicc/ast/FormalParamAST.py b/src/mem/slicc/ast/FormalParamAST.py
index b169cbb1c..b821dc197 100644
--- a/src/mem/slicc/ast/FormalParamAST.py
+++ b/src/mem/slicc/ast/FormalParamAST.py
@@ -29,10 +29,11 @@ from slicc.ast.AST import AST
from slicc.symbols import Var
class FormalParamAST(AST):
- def __init__(self, slicc, type_ast, ident):
+ def __init__(self, slicc, type_ast, ident, default = None):
super(FormalParamAST, self).__init__(slicc)
self.type_ast = type_ast
self.ident = ident
+ self.default = default
def __repr__(self):
return "[FormalParamAST: %s]" % self.ident
diff --git a/src/mem/slicc/ast/MachineAST.py b/src/mem/slicc/ast/MachineAST.py
index ee75b6d6a..0fc79c710 100644
--- a/src/mem/slicc/ast/MachineAST.py
+++ b/src/mem/slicc/ast/MachineAST.py
@@ -43,6 +43,7 @@ class MachineAST(DeclAST):
def files(self, parent=None):
s = set(('%s_Controller.cc' % self.ident,
'%s_Controller.hh' % self.ident,
+ '%s_Controller.py' % self.ident,
'%s_Profiler.cc' % self.ident,
'%s_Profiler.hh' % self.ident,
'%s_Transitions.cc' % self.ident,
diff --git a/src/mem/slicc/parser.py b/src/mem/slicc/parser.py
index 226106678..891f22973 100644
--- a/src/mem/slicc/parser.py
+++ b/src/mem/slicc/parser.py
@@ -115,8 +115,6 @@ class SLICC(Grammar):
def files(self):
f = set([
- 'ControllerFactory.cc',
- 'ControllerFactory.hh',
'MachineType.cc',
'MachineType.hh',
'Types.hh' ])
@@ -418,6 +416,10 @@ class SLICC(Grammar):
"param : type ident"
p[0] = ast.FormalParamAST(self, p[1], p[2])
+ def p_param__default(self, p):
+ "param : type ident '=' NUMBER"
+ p[0] = ast.FormalParamAST(self, p[1], p[2], p[4])
+
# Idents and lists
def p_idents__braced(self, p):
"idents : '{' identx '}'"
diff --git a/src/mem/slicc/symbols/StateMachine.py b/src/mem/slicc/symbols/StateMachine.py
index 73c3fe720..0f32cebf6 100644
--- a/src/mem/slicc/symbols/StateMachine.py
+++ b/src/mem/slicc/symbols/StateMachine.py
@@ -124,6 +124,7 @@ class StateMachine(Symbol):
self.table = table
def writeCodeFiles(self, path):
+ self.printControllerPython(path)
self.printControllerHH(path)
self.printControllerCC(path)
self.printCSwitch(path)
@@ -134,6 +135,29 @@ class StateMachine(Symbol):
for func in self.functions:
func.writeCodeFiles(path)
+ def printControllerPython(self, path):
+ code = code_formatter()
+ ident = self.ident
+ py_ident = "%s_Controller" % ident
+ c_ident = "%s_Controller" % self.ident
+ code('''
+from m5.params import *
+from m5.SimObject import SimObject
+from Controller import RubyController
+
+class $py_ident(RubyController):
+ type = '$py_ident'
+''')
+ code.indent()
+ for param in self.config_parameters:
+ dflt_str = ''
+ if param.default is not None:
+ dflt_str = str(param.default) + ', '
+ code('${{param.name}} = Param.Int(${dflt_str}"")')
+ code.dedent()
+ code.write(path, '%s.py' % py_ident)
+
+
def printControllerHH(self, path):
'''Output the method declarations for the class declaration'''
code = code_formatter()
@@ -152,6 +176,8 @@ class StateMachine(Symbol):
#ifndef ${ident}_CONTROLLER_H
#define ${ident}_CONTROLLER_H
+#include "params/$c_ident.hh"
+
#include "mem/ruby/common/Global.hh"
#include "mem/ruby/common/Consumer.hh"
#include "mem/ruby/slicc_interface/AbstractController.hh"
@@ -174,9 +200,10 @@ class $c_ident : public AbstractController {
#ifdef CHECK_COHERENCE
#endif /* CHECK_COHERENCE */
public:
- $c_ident(const string & name);
+ typedef ${c_ident}Params Params;
+ $c_ident(const Params *p);
static int getNumControllers();
- void init(Network* net_ptr, const vector<string> & argv);
+ void init();
MessageBuffer* getMandatoryQueue() const;
const int & getVersion() const;
const string toString() const;
@@ -278,16 +305,30 @@ static int m_num_controllers;
seen_types.add(var.type.ident)
code('''
+$c_ident *
+${c_ident}Params::create()
+{
+ return new $c_ident(this);
+}
+
+
int $c_ident::m_num_controllers = 0;
stringstream ${ident}_transitionComment;
#define APPEND_TRANSITION_COMMENT(str) (${ident}_transitionComment << str)
/** \\brief constructor */
-$c_ident::$c_ident(const string &name)
- : m_name(name)
+$c_ident::$c_ident(const Params *p)
+ : AbstractController(p)
{
+ m_version = p->version;
+ m_transitions_per_cycle = p->transitions_per_cycle;
+ m_buffer_size = p->buffer_size;
+ m_recycle_latency = p->recycle_latency;
+ m_number_of_TBEs = p->number_of_TBEs;
''')
code.indent()
+ for param in self.config_parameters:
+ code('m_${{param.name}} = p->${{param.name}};')
code('m_num_controllers++;')
for var in self.objects:
@@ -298,44 +339,10 @@ $c_ident::$c_ident(const string &name)
code('''
}
-void $c_ident::init(Network *net_ptr, const vector<string> &argv)
+void $c_ident::init()
{
- for (size_t i = 0; i < argv.size(); i += 2) {
- if (argv[i] == "version")
- m_version = atoi(argv[i+1].c_str());
- else if (argv[i] == "transitions_per_cycle")
- m_transitions_per_cycle = atoi(argv[i+1].c_str());
- else if (argv[i] == "buffer_size")
- m_buffer_size = atoi(argv[i+1].c_str());
- else if (argv[i] == "recycle_latency")
- m_recycle_latency = atoi(argv[i+1].c_str());
- else if (argv[i] == "number_of_TBEs")
- m_number_of_TBEs = atoi(argv[i+1].c_str());
-''')
-
- code.indent()
- code.indent()
- for param in self.config_parameters:
- code('else if (argv[i] == "${{param.name}}")')
- if param.type_ast.type.ident == "int":
- code(' m_${{param.name}} = atoi(argv[i+1].c_str());')
- elif param.type_ast.type.ident == "bool":
- code(' m_${{param.name}} = string_to_bool(argv[i+1]);')
- else:
- self.error("only int and bool parameters are "\
- "currently supported")
- code.dedent()
- code.dedent()
- code('''
- }
-
- m_net_ptr = net_ptr;
m_machineID.type = MachineType_${ident};
m_machineID.num = m_version;
- for (size_t i = 0; i < argv.size(); i += 2) {
- if (argv[i] != "version")
- m_cfg[argv[i]] = argv[i+1];
- }
// Objects
s_profiler.setVersion(m_version);
diff --git a/src/mem/slicc/symbols/SymbolTable.py b/src/mem/slicc/symbols/SymbolTable.py
index 6b1bf13e6..deb971eb9 100644
--- a/src/mem/slicc/symbols/SymbolTable.py
+++ b/src/mem/slicc/symbols/SymbolTable.py
@@ -133,63 +133,6 @@ class SymbolTable(object):
for symbol in self.sym_vec:
symbol.writeCodeFiles(path)
- self.writeControllerFactory(path)
-
- def writeControllerFactory(self, path):
- code = code_formatter()
-
- code('''
-/** \\file ControllerFactory.hh
- * Auto generatred C++ code started by $__file__:$__line__
- */
-
-#ifndef CONTROLLERFACTORY_H
-#define CONTROLLERFACTORY_H
-
-#include <string>
-class Network;
-class AbstractController;
-
-class ControllerFactory {
- public:
- static AbstractController *createController(const std::string &controller_type, const std::string &name);
-};
-#endif // CONTROLLERFACTORY_H''')
- code.write(path, "ControllerFactory.hh")
-
- code = code_formatter()
- code('''
-/** \\file ControllerFactory.cc
- * Auto generatred C++ code started by $__file__:$__line__
- */
-
-#include "mem/protocol/ControllerFactory.hh"
-#include "mem/ruby/slicc_interface/AbstractController.hh"
-#include "mem/protocol/MachineType.hh"
-''')
-
- controller_types = []
- for symbol in self.getAllType(StateMachine):
- code('#include "mem/protocol/${{symbol.ident}}_Controller.hh"')
- controller_types.append(symbol.ident)
-
- code('''
-AbstractController *ControllerFactory::createController(const std::string &controller_type, const std::string &name) {
-''')
-
- for ct in controller_types:
- code('''
- if (controller_type == "$ct")
- return new ${ct}_Controller(name);
-''')
-
- code('''
- assert(0); // invalid controller type
- return NULL;
-}
-''')
- code.write(path, "ControllerFactory.cc")
-
def writeHTMLFiles(self, path):
machines = list(self.getAllType(StateMachine))
if len(machines) > 1:
diff --git a/src/mem/slicc/symbols/Type.py b/src/mem/slicc/symbols/Type.py
index bafc6ea9e..fc45c59df 100644
--- a/src/mem/slicc/symbols/Type.py
+++ b/src/mem/slicc/symbols/Type.py
@@ -478,7 +478,6 @@ ostream& operator<<(ostream& out, const ${{self.c_ident}}& obj);
''')
if self.isMachineType:
- code('#include "mem/protocol/ControllerFactory.hh"')
for enum in self.enums.itervalues():
code('#include "mem/protocol/${{enum.ident}}_Controller.hh"')