1
0
mirror of https://github.com/myhdl/myhdl.git synced 2024-12-14 07:44:38 +08:00

Factor visitor traversal out to top class

This commit is contained in:
Jan Decaluwe 2016-01-31 12:15:18 +01:00
parent f5de3b3af4
commit a48eb2e4ca
4 changed files with 19 additions and 27 deletions

View File

@ -32,8 +32,6 @@ from myhdl._util import _isGenFunc, _dedent
from myhdl._Waiter import _Waiter, _SignalWaiter, _SignalTupleWaiter from myhdl._Waiter import _Waiter, _SignalWaiter, _SignalTupleWaiter
from myhdl._instance import _Instantiator from myhdl._instance import _Instantiator
from myhdl._always import _Always from myhdl._always import _Always
from myhdl._resolverefs import _AttrRefTransformer
from myhdl._visitors import _SigNameVisitor
class _error: class _error:
pass pass
@ -91,20 +89,11 @@ class _AlwaysComb(_Always):
senslist = [] senslist = []
super(_AlwaysComb, self).__init__(func, senslist) super(_AlwaysComb, self).__init__(func, senslist)
tree = self.ast inouts = self.inouts | self.inputs.intersection(self.outputs)
# print ast.dump(tree)
v = _AttrRefTransformer(self)
v.visit(tree)
v = _SigNameVisitor(self.symdict)
v.visit(tree)
self.inputs = v.inputs
self.outputs = v.outputs
inouts = v.inouts | self.inputs.intersection(self.outputs)
if inouts: if inouts:
raise AlwaysCombError(_error.SignalAsInout % inouts) raise AlwaysCombError(_error.SignalAsInout % inouts)
if v.embedded_func: if self.embedded_func:
raise AlwaysCombError(_error.EmbeddedFunction) raise AlwaysCombError(_error.EmbeddedFunction)
for n in self.inputs: for n in self.inputs:

View File

@ -32,8 +32,6 @@ from myhdl._delay import delay
from myhdl._Signal import _Signal, _WaiterList,_isListOfSigs from myhdl._Signal import _Signal, _WaiterList,_isListOfSigs
from myhdl._Waiter import _Waiter, _EdgeWaiter, _EdgeTupleWaiter from myhdl._Waiter import _Waiter, _EdgeWaiter, _EdgeTupleWaiter
from myhdl._always import _Always from myhdl._always import _Always
from myhdl._resolverefs import _AttrRefTransformer
from myhdl._visitors import _SigNameVisitor
# evacuate this later # evacuate this later
AlwaysSeqError = AlwaysError AlwaysSeqError = AlwaysError
@ -101,23 +99,15 @@ class _AlwaysSeq(_Always):
super(_AlwaysSeq, self).__init__(func, senslist) super(_AlwaysSeq, self).__init__(func, senslist)
# now infer outputs to be reset if self.inouts:
tree = self.ast
# print ast.dump(tree)
v = _AttrRefTransformer(self)
v.visit(tree)
v = _SigNameVisitor(self.symdict)
v.visit(tree)
if v.inouts:
raise AlwaysSeqError(_error.SigAugAssign, v.inouts) raise AlwaysSeqError(_error.SigAugAssign, v.inouts)
if v.embedded_func: if self.embedded_func:
raise AlwaysSeqError(_error.EmbeddedFunction) raise AlwaysSeqError(_error.EmbeddedFunction)
sigregs = self.sigregs = [] sigregs = self.sigregs = []
varregs = self.varregs = [] varregs = self.varregs = []
for n in v.outputs: for n in self.outputs:
reg = self.symdict[n] reg = self.symdict[n]
if isinstance(reg, _Signal): if isinstance(reg, _Signal):
sigregs.append(reg) sigregs.append(reg)

View File

@ -26,6 +26,8 @@ from types import FunctionType
from myhdl import InstanceError from myhdl import InstanceError
from myhdl._util import _isGenFunc, _makeAST from myhdl._util import _isGenFunc, _makeAST
from myhdl._Waiter import _inferWaiter from myhdl._Waiter import _inferWaiter
from myhdl._resolverefs import _AttrRefTransformer
from myhdl._visitors import _SigNameVisitor
class _error: class _error:
pass pass
@ -61,6 +63,17 @@ class _Instantiator(object):
symdict.update(zip(freevars, closure)) symdict.update(zip(freevars, closure))
self.symdict = symdict self.symdict = symdict
tree = self.ast
# print ast.dump(tree)
v = _AttrRefTransformer(self)
v.visit(tree)
v = _SigNameVisitor(self.symdict)
v.visit(tree)
self.inputs = v.inputs
self.outputs = v.outputs
self.inouts = v.inouts
self.embedded_func = v.embedded_func
@property @property
def funcobj(self): def funcobj(self):
return self.genfunc return self.genfunc

View File

@ -1,6 +1,6 @@
import ast import ast
from myhdl import intbv from myhdl._intbv import intbv
from myhdl._Signal import _Signal, _isListOfSigs from myhdl._Signal import _Signal, _isListOfSigs